/* Windows 95 inspired interface */
:root {
  --win95-desktop: #008080;
  --win95-face: #c0c0c0;
  --win95-light: #ffffff;
  --win95-mid: #dfdfdf;
  --win95-shadow: #808080;
  --win95-dark: #000000;
  --win95-blue: #000080;
  --win95-blue-light: #1084d0;
  --win95-text: #000000;
}

* { box-sizing: border-box; }

html {
  min-height: 100%;
  background: var(--win95-desktop);
  scrollbar-color: var(--win95-face) var(--win95-light);
}

body {
  min-height: 100vh;
  margin: 0 !important;
  color: var(--win95-text) !important;
  background: var(--win95-desktop) !important;
  background-image: none !important;
  font-family: "MS Sans Serif", Tahoma, Geneva, sans-serif !important;
  font-size: 14px !important;
  -webkit-font-smoothing: none;
}

body::before { content: none !important; }

body::after { content: none !important; }

body > *:last-child { margin-bottom: 34px; }

nav, .navbar, header, .topbar {
  color: #000 !important;
  background: var(--win95-face) !important;
  border: 0 !important;
  border-bottom: 2px solid var(--win95-shadow) !important;
  box-shadow: inset 0 1px var(--win95-light), 0 2px 0 #000 !important;
}

.navbar a, nav a, header a, .topbar a,
.navbar-brand, .navbar-toggler, .nav-link {
  color: #000 !important;
  text-shadow: none !important;
}

.navbar-toggler {
  background: var(--win95-face) !important;
  border: 2px outset var(--win95-light) !important;
}

a { color: #000080; text-decoration: underline; }
a:visited { color: #800080; }
a:hover { color: #fff; background: #000080; }

h1, h2, h3, h4, h5, h6 {
  color: #000 !important;
  font-family: "MS Sans Serif", Tahoma, Geneva, sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  text-shadow: none !important;
}

main, .wrapper { position: relative; }

.retro-article {
  position: relative;
  max-width: 1120px;
  margin: 24px auto;
  padding: 44px 14px 15px;
  color: #000;
  background: var(--win95-face);
  border: 2px outset var(--win95-light);
  box-shadow: 2px 2px 0 rgba(0,0,0,.35);
}

.retro-article::before {
  content: "Heapwah.com.my - Internet Explorer";
  position: absolute;
  top: 3px;
  right: 3px;
  left: 3px;
  display: block;
  height: 25px;
  margin: 0;
  padding: 4px 7px;
  color: #fff;
  background: linear-gradient(90deg, var(--win95-blue), var(--win95-blue-light));
  border: 0;
  font-family: "MS Sans Serif", Tahoma, sans-serif;
  font-size: 13px;
  font-weight: 700;
  line-height: 17px;
}

.retro-article::after {
  content: "_  □  ×";
  position: absolute;
  top: 6px;
  right: 7px;
  height: 19px;
  padding: 0 4px;
  color: #000;
  background: var(--win95-face);
  border: 2px outset #fff;
  font-size: 12px;
  font-weight: 700;
  line-height: 15px;
}

.retro-article h1 {
  margin-top: 0;
  padding: 8px 7px;
  color: #000 !important;
  background: #fff;
  border: 2px inset var(--win95-light);
  font-family: "MS Sans Serif", Tahoma, sans-serif !important;
  font-size: clamp(20px, 4vw, 30px) !important;
  line-height: 1.2;
  text-shadow: none !important;
}

.retro-article .retro-lead {
  margin-top: 12px;
  font-size: 14px;
  font-weight: 700;
}

.container, .container-lg, .container-fluid { padding-top: 8px; padding-bottom: 12px; }

.card, .box, .terms-box, .content-container, .modal-content,
.list-group, .accordion, form, fieldset, .alert, .dropdown-menu {
  color: #000 !important;
  background: var(--win95-face) !important;
  border: 2px outset var(--win95-light) !important;
  border-radius: 0 !important;
  box-shadow: 2px 2px 0 rgba(0,0,0,.35) !important;
}

.card-header, .modal-header, .accordion-header,
.bg-dark, .text-bg-dark {
  color: #fff !important;
  background: var(--win95-blue) !important;
  border-radius: 0 !important;
}

.btn, button, [type="button"], [type="submit"], [type="reset"],
.badge, .list-group-item, .page-link {
  min-height: 28px;
  padding: 4px 10px;
  color: #000 !important;
  background: var(--win95-face) !important;
  border: 2px outset var(--win95-light) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font-family: "MS Sans Serif", Tahoma, sans-serif !important;
  font-weight: 700 !important;
  text-shadow: none !important;
}

.btn:hover, button:hover, [type="button"]:hover, [type="submit"]:hover {
  color: #fff !important;
  background: var(--win95-blue) !important;
  transform: none !important;
}

.btn:active, button:active, [type="button"]:active, [type="submit"]:active,
.list-group-item.active {
  color: #fff !important;
  background: var(--win95-blue) !important;
  border-style: inset !important;
}

input, select, textarea, .form-control, .form-select {
  color: #000 !important;
  background: #fff !important;
  border: 2px inset var(--win95-light) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font-family: "MS Sans Serif", Tahoma, sans-serif !important;
}

input:focus, select:focus, textarea:focus, .form-control:focus {
  outline: 1px dotted #000 !important;
  outline-offset: -4px;
}

table {
  color: #000 !important;
  background: #fff !important;
  border: 2px inset var(--win95-light) !important;
  border-collapse: separate !important;
  border-spacing: 1px !important;
}

th { color: #fff !important; background: var(--win95-blue) !important; }
td, th { border: 1px solid var(--win95-shadow) !important; }

img { image-rendering: auto; }
.rounded, .rounded-1, .rounded-2, .rounded-3, .rounded-4, .rounded-pill { border-radius: 0 !important; }
.shadow, .shadow-sm, .shadow-lg { box-shadow: 2px 2px 0 rgba(0,0,0,.4) !important; }

footer {
  margin-bottom: 34px;
  color: #000 !important;
  background: var(--win95-face) !important;
  border: 0 !important;
  border-top: 2px outset #fff !important;
  box-shadow: none !important;
}
footer a { color: #000080 !important; }

.win95-taskbar {
  position: fixed;
  z-index: 99998;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  gap: 4px;
  min-height: 38px;
  padding: 3px 5px;
  color: #000;
  background: var(--win95-face);
  border-top: 2px solid var(--win95-light);
  box-shadow: inset 0 1px var(--win95-mid);
  font-family: "MS Sans Serif", Tahoma, sans-serif;
  font-size: 13px;
}

.win95-start,
.win95-app-button,
.win95-clock-button {
  min-height: 30px;
  padding: 5px 9px;
  color: #000 !important;
  background: var(--win95-face) !important;
  border: 2px outset #fff !important;
  border-radius: 0 !important;
  font: 700 13px/16px "MS Sans Serif", Tahoma, sans-serif !important;
}

.win95-start { white-space: nowrap; }
.win95-flag { color: #000080; font-size: 16px; }

.win95-app-button {
  min-width: 150px;
  border-style: inset !important;
}

.win95-clock-button {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-left: 0;
  margin-right: auto;
  cursor: pointer;
}

.win95-clock-button:hover,
.win95-clock-button:focus-visible {
  color: #fff !important;
  background: #000080 !important;
  outline: 1px dotted #fff;
  outline-offset: -5px;
}

.win95-live-time {
  min-width: 64px;
  font-variant-numeric: tabular-nums;
  text-align: center;
}

.win95-live-date { white-space: nowrap; }

.win95-calendar[hidden] { display: none !important; }

.win95-calendar {
  position: absolute;
  right: auto;
  left: 5px;
  bottom: 42px;
  width: min(340px, calc(100vw - 10px));
  padding: 4px;
  color: #000;
  background: var(--win95-face);
  border: 2px outset #fff;
  box-shadow: 3px 3px 0 rgba(0,0,0,.5);
}

.win95-calendar-titlebar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 26px;
  padding-left: 7px;
  color: #fff;
  background: linear-gradient(90deg, #000080, #1084d0);
  font-weight: 700;
}

.win95-calendar-close,
.win95-calendar-prev,
.win95-calendar-next,
.win95-calendar-today {
  min-height: 24px;
  padding: 2px 7px;
  color: #000 !important;
  background: var(--win95-face) !important;
  border: 2px outset #fff !important;
  border-radius: 0 !important;
  font: 700 12px/16px "MS Sans Serif", Tahoma, sans-serif !important;
}

.win95-calendar-close { margin: 2px; min-width: 24px; }

.win95-calendar-controls {
  display: grid;
  grid-template-columns: 32px 1fr 32px;
  align-items: center;
  gap: 6px;
  padding: 7px 2px;
  text-align: center;
}

.win95-calendar-grid {
  width: 100%;
  margin: 0 0 6px;
  color: #000 !important;
  background: #fff !important;
  border: 2px inset #fff !important;
  border-collapse: collapse !important;
  table-layout: fixed;
  font-size: 12px;
}

.win95-calendar-grid th {
  padding: 4px 1px;
  color: #fff !important;
  background: #000080 !important;
  text-align: center;
}

.win95-calendar-grid td {
  height: 28px;
  padding: 3px;
  color: #000 !important;
  background: #fff !important;
  border: 1px solid #dfdfdf !important;
  text-align: center;
}

.win95-calendar-grid td.is-today {
  color: #fff !important;
  background: #000080 !important;
  outline: 1px dotted #fff;
  outline-offset: -3px;
  font-weight: 700;
}

.win95-calendar-today { width: 100%; }

/* Keep the three floating utilities clear of the taskbar and calendar. */
.footer-feature {
  right: 12px !important;
  bottom: 160px !important;
  margin: 0 !important;
  z-index: 99990 !important;
  transition: bottom .18s ease !important;
}

.intercom-lightweight-app-launcher,
iframe.intercom-launcher-frame,
iframe.intercom-lightweight-app-launcher,
iframe[name="intercom-launcher-frame"] {
  bottom: 90px !important;
  transition: bottom .18s ease !important;
}

body.win95-calendar-open .footer-feature {
  bottom: 160px !important;
}

body.win95-calendar-open .intercom-lightweight-app-launcher,
body.win95-calendar-open iframe.intercom-launcher-frame,
body.win95-calendar-open iframe.intercom-lightweight-app-launcher,
body.win95-calendar-open iframe[name="intercom-launcher-frame"] {
  bottom: 90px !important;
}

/* Contrast corrections for inherited site components */
.bg-dark, .text-bg-dark, .bg-primary, .text-bg-primary,
.card-header, .modal-header, .accordion-button:not(.collapsed) {
  color: #fff !important;
}

.bg-dark a, .text-bg-dark a, .bg-primary a, .text-bg-primary a,
.card-header a, .modal-header a {
  color: #fff !important;
  text-decoration-color: #fff !important;
}

.nf, .nf .container-lg, .nf .bar {
  color: #000 !important;
  background: var(--win95-face) !important;
}

.nf .subtext, .nf .bar, .nf .bar a {
  color: #000 !important;
}

.nf .f-card {
  color: #fff !important;
  background: #0f172a !important;
  border: 2px inset #fff !important;
}

.nf .f-title, .nf .f-title span {
  color: #fff !important;
}

.nf .f-card .link-clean a,
.nf .f-card a,
.nf .f-card a:visited {
  color: #7de8ff !important;
  background: transparent !important;
  text-decoration-color: #7de8ff !important;
}

.nf .f-card a:hover,
.nf .f-card a:focus-visible {
  color: #000 !important;
  background: #fff !important;
  outline: 2px solid #ffff00;
}

.nf .soc a {
  color: #000080 !important;
  background: var(--win95-face) !important;
  border: 2px outset #fff !important;
}

.nf .soc a:hover, .nf .soc a:focus-visible {
  color: #fff !important;
  background: #000080 !important;
}

.nf .footer-chip {
  color: #000 !important;
  background: #fff !important;
  border: 2px inset #fff !important;
}

.nf .badge-brand {
  color: #000 !important;
  background: linear-gradient(90deg, #40c9ff, #ff78b7) !important;
}

.text-muted, .form-text, .hint {
  color: #3f3f3f !important;
}

.alert-warning, .bg-warning, .text-bg-warning {
  color: #000 !important;
}

.alert-info, .bg-info, .text-bg-info {
  color: #000 !important;
}

.alert-danger, .bg-danger, .text-bg-danger,
.alert-success, .bg-success, .text-bg-success {
  color: #fff !important;
}

/* Component-level fixes found during the full-page contrast audit */
.badge {
  color: #000 !important;
  background: var(--win95-face) !important;
}

.accordion-button,
.accordion-button:not(.collapsed) {
  color: #000 !important;
  background: var(--win95-face) !important;
}

.list-group-item,
.list-group-item.bg-dark,
.list-group-item.text-white {
  color: #000 !important;
  background: var(--win95-face) !important;
}

.list-group-item a,
.list-group-item .text-reset {
  color: #000080 !important;
}

.list-group-item.active,
.list-group-item.active a {
  color: #fff !important;
  background: #000080 !important;
}

.lead-small,
.page-subtitle {
  color: #000 !important;
}

.scanner-btn {
  color: #000 !important;
}

.scanner-page .sub,
.helper {
  color: #fff !important;
}

.scanner-page .agree {
  color: #000 !important;
}

.scanner-page .agree a {
  color: #000080 !important;
}

.topbar .back-btn {
  color: #fff !important;
}

a.btn.btn-light.text-dark {
  color: #000 !important;
}

.login-card .right-pane {
  color: #fff !important;
  background: #000080 !important;
}

.login-card .right-pane li,
.login-card .right-pane p,
.login-card .right-pane h1,
.login-card .right-pane h2,
.login-card .right-pane h3,
.login-card .right-pane h4 {
  color: #fff !important;
}

.login-card .right-pane a:not(.btn),
.login-card .right-pane a:not(.btn):visited {
  color: #7de8ff !important;
}

.login-card .right-pane a:not(.btn):hover,
.login-card .right-pane a:not(.btn):focus-visible {
  color: #000 !important;
  background: #fff !important;
}

.helper {
  color: #000 !important;
}

::-webkit-scrollbar { width: 16px; height: 16px; }
::-webkit-scrollbar-track { background: repeating-conic-gradient(#fff 0 25%, #c0c0c0 0 50%) 0 / 2px 2px; }
::-webkit-scrollbar-thumb { background: var(--win95-face); border: 2px outset #fff; }
::-webkit-scrollbar-button { background: var(--win95-face); border: 2px outset #fff; }

@media (max-width: 640px) {
  body { font-size: 13px !important; }
  .retro-article { margin: 14px 7px 20px; padding: 42px 9px 11px; }
  .retro-article::before { content: "Heapwah.com.my"; }
  .retro-article h1 { font-size: 21px !important; }
  .win95-app-button { display: none; }
  .win95-clock-button { gap: 5px; padding-inline: 6px; }
  .win95-live-date { font-size: 11px; }
  .win95-calendar { right: auto; left: 3px; bottom: 41px; }
  .footer-feature { right: 8px !important; bottom: 156px !important; }
  body.win95-calendar-open .footer-feature { bottom: 156px !important; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition: none !important; animation: none !important; }
}
