/* ============================================================
   HyperOS. windows 95 design system. all paint, all chunky.
   Hyperliquid teal/mint palette.
   ============================================================ */

@font-face {
  font-family: 'HyperOS';
  src: url('../assets/ponzi-Regular.ttf') format('truetype');
  font-display: swap;
}

:root {
  /* Win95 chrome shifted to Hyperliquid teal/mint */
  --w95-teal:    #0a3834;   /* desktop background tint */
  --w95-gray:    #c0c0c0;   /* chrome gray */
  --w95-bright:  #ffffff;
  --w95-dark:    #808080;
  --w95-darker:  #404040;
  --w95-black:   #000000;
  --w95-blue:    #0a3834;   /* title-bar dark (was Windows blue) */
  --w95-blue2:   #50d2c1;   /* title-bar light - Hyperliquid mint */
  --w95-tab:     #d4d0c8;

  /* Hyperliquid brand */
  --hl-mint:        #50d2c1;
  --hl-mint-bright: #97fce4;
  --hl-dark:        #0b0e0d;
  --hl-teal-dark:   #0a3834;

  /* paint accents */
  --pal-red:     #ff0000;
  --pal-yellow:  #ffff00;
  --pal-green:   #00aa00;
  --pal-lime:    #00ff00;
  --pal-cyan:    #97fce4;   /* shifted to Hyperliquid mint-bright */
  --pal-magenta: #ff00ff;
  --pal-orange:  #ff8800;
  --pal-pink:    #ff66cc;
}

* { box-sizing: border-box; image-rendering: pixelated; image-rendering: crisp-edges; }
html, body { margin: 0; padding: 0; }

body {
  font-family: 'MS Sans Serif', 'Tahoma', Verdana, sans-serif;
  font-size: 12px;
  line-height: 1.4;
  color: var(--w95-black);
  background: var(--w95-teal);
  background-image:
    repeating-linear-gradient(0deg,
      rgba(0,0,0,0.04) 0px, rgba(0,0,0,0.04) 1px,
      transparent 1px, transparent 2px),
    repeating-linear-gradient(90deg,
      rgba(0,0,0,0.04) 0px, rgba(0,0,0,0.04) 1px,
      transparent 1px, transparent 2px);
  min-height: 100vh;
  cursor: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' shape-rendering='crispEdges'><polygon points='1,1 1,22 7,17 11,26 14,24 11,16 18,16' fill='%23000'/><polygon points='2,3 2,19 6,15 10,24 13,22 10,15 15,15' fill='%23fff'/></svg>") 1 1, default;
}

a { color: var(--w95-blue); text-decoration: underline; }
a:hover { color: var(--pal-magenta); cursor: pointer; }
a:active { color: var(--pal-red); }

/* fonts */
.hos, .ponzi { font-family: 'HyperOS', 'Comic Sans MS', cursive; }
.pixel { font-family: 'Courier New', monospace; }

/* ============================================================
   CHROME: window, title bar, taskbar, start
   ============================================================ */

.window {
  background: var(--w95-gray);
  border: 2px solid;
  border-color: var(--w95-bright) var(--w95-darker) var(--w95-darker) var(--w95-bright);
  box-shadow: 1px 1px 0 var(--w95-black);
  margin: 0 0 16px;
}

.window .titlebar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(90deg, var(--w95-blue) 0%, var(--w95-blue2) 100%);
  color: var(--w95-bright);
  padding: 3px 4px 3px 6px;
  font-weight: bold;
  font-size: 12px;
  letter-spacing: 0.02em;
  user-select: none;
}
.window .titlebar.inactive {
  background: linear-gradient(90deg, var(--w95-dark) 0%, #b8b8b8 100%);
}
.window .titlebar .title {
  display: flex; align-items: center; gap: 6px;
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.window .titlebar .title img,
.window .titlebar .title svg { width: 16px; height: 16px; flex-shrink: 0; }
.window .titlebar .controls { display: flex; gap: 2px; }
.window .titlebar .controls button {
  width: 18px; height: 16px;
  background: var(--w95-gray);
  border: 1px solid;
  border-color: var(--w95-bright) var(--w95-darker) var(--w95-darker) var(--w95-bright);
  color: var(--w95-black);
  font-family: monospace;
  font-size: 10px;
  font-weight: bold;
  line-height: 12px;
  padding: 0; cursor: pointer;
}
.window .titlebar .controls button:active {
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
}

.window .menubar {
  background: var(--w95-gray);
  border-bottom: 1px solid var(--w95-dark);
  padding: 2px 4px;
  display: flex;
  gap: 2px;
  font-size: 12px;
}
.window .menubar a {
  color: var(--w95-black);
  text-decoration: none;
  padding: 1px 6px;
}
.window .menubar a:hover { background: var(--w95-blue); color: var(--w95-bright); }
.window .menubar a u { text-decoration: underline; }

.window .body {
  background: var(--w95-gray);
  padding: 16px;
}
.window .body.tight { padding: 10px; }
.window .body.field {
  background: var(--w95-bright);
  border: 1px solid;
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  margin: 12px;
  padding: 12px;
}

.window .statusbar {
  display: flex;
  gap: 4px;
  padding: 4px;
  border-top: 1px solid var(--w95-dark);
}
.window .statusbar span {
  background: var(--w95-gray);
  border: 1px solid;
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  padding: 2px 6px;
  font-size: 11px;
  flex: 1;
}

/* taskbar */
.taskbar {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  height: 32px;
  background: var(--w95-gray);
  border-top: 2px solid var(--w95-bright);
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 2px 4px;
  z-index: 100;
}
.taskbar .start-btn {
  display: flex; align-items: center; gap: 6px;
  background: var(--w95-gray);
  border: 2px solid;
  border-color: var(--w95-bright) var(--w95-darker) var(--w95-darker) var(--w95-bright);
  padding: 2px 8px 2px 4px;
  font-weight: bold;
  font-size: 12px;
  cursor: pointer;
  height: 26px;
  user-select: none;
}
.taskbar .start-btn:active,
.taskbar .start-btn.open {
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  padding: 3px 7px 1px 5px;
}
.taskbar .start-btn img,
.taskbar .start-btn svg { width: 16px; height: 16px; }
.taskbar .tray {
  margin-left: auto;
  display: flex; align-items: center; gap: 6px;
  background: var(--w95-gray);
  border: 1px solid;
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  padding: 2px 8px;
  height: 24px;
  font-size: 11px;
  font-variant-numeric: tabular-nums;
}
.taskbar .task {
  background: var(--w95-gray);
  border: 2px solid;
  border-color: var(--w95-bright) var(--w95-darker) var(--w95-darker) var(--w95-bright);
  padding: 2px 8px;
  font-size: 11px;
  display: flex; align-items: center; gap: 4px;
  height: 26px;
  cursor: pointer;
}
.taskbar .task.active {
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  background: linear-gradient(90deg, #d4d0c8 25%, transparent 25%, transparent 50%, #d4d0c8 50%, #d4d0c8 75%, transparent 75%);
  background-size: 4px 4px; background-color: var(--w95-gray);
}

/* start menu */
.start-menu {
  position: fixed;
  bottom: 32px;
  left: 4px;
  width: 220px;
  background: var(--w95-gray);
  border: 2px solid;
  border-color: var(--w95-bright) var(--w95-darker) var(--w95-darker) var(--w95-bright);
  display: none;
  z-index: 200;
  box-shadow: 2px 2px 0 var(--w95-black);
}
.start-menu.open { display: flex; }
.start-menu .rail {
  width: 24px;
  background: linear-gradient(180deg, var(--w95-dark), var(--w95-darker));
  color: var(--w95-bright);
  writing-mode: vertical-rl;
  text-orientation: mixed;
  text-align: center;
  font-family: 'HyperOS', 'Comic Sans MS', cursive;
  font-size: 18px;
  padding: 8px 0;
}
.start-menu ul {
  list-style: none;
  margin: 0;
  padding: 4px 0;
  flex: 1;
}
.start-menu li { display: block; }
.start-menu li a {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 10px;
  color: var(--w95-black);
  text-decoration: none;
  font-size: 13px;
}
.start-menu li a:hover { background: var(--w95-blue); color: var(--w95-bright); }
.start-menu li a img { width: 18px; height: 18px; }
.start-menu li.sep { border-top: 1px solid var(--w95-dark); margin: 4px 2px; }

/* desktop icons */
.desktop {
  display: grid;
  grid-template-columns: repeat(auto-fill, 80px);
  gap: 8px;
  padding: 12px;
  position: relative;
  z-index: 1;
}
.desktop .icon {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  text-decoration: none;
  padding: 4px;
  user-select: none;
  width: 80px;
}
.desktop .icon img,
.desktop .icon .glyph {
  width: 36px; height: 36px;
  margin-bottom: 4px;
}
.desktop .icon span {
  color: var(--w95-bright);
  font-size: 11px;
  text-shadow: 1px 1px 0 var(--w95-black);
  background: transparent;
  padding: 1px 3px;
  text-decoration: none;
  word-break: break-word;
}
.desktop .icon:hover span {
  background: var(--w95-blue);
  outline: 1px dotted var(--w95-bright);
}

/* ============================================================
   BUTTONS: chunky w95 buttons that depress on click
   ============================================================ */

.btn95 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 4px 14px;
  min-height: 24px;
  background: var(--w95-gray);
  border: 2px solid;
  border-color: var(--w95-bright) var(--w95-darker) var(--w95-darker) var(--w95-bright);
  color: var(--w95-black);
  font: inherit;
  font-size: 12px;
  cursor: pointer;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
.btn95:hover { color: var(--w95-blue); }
.btn95:active,
.btn95.pressed {
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  padding: 5px 13px 3px 15px;
}
.btn95:disabled {
  color: var(--w95-dark);
  cursor: not-allowed;
}
.btn95.primary {
  font-weight: bold;
}
.btn95.big { padding: 8px 22px; font-size: 14px; }
.btn95.big:active { padding: 9px 21px 7px 23px; }

/* form inputs (paint style: white well with sunken edges) */
.field-input {
  background: var(--w95-bright);
  border: 2px solid;
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  padding: 4px 6px;
  font-family: inherit;
  font-size: 13px;
  width: 100%;
  -webkit-appearance: none;
}
.field-input:focus { outline: 1px dotted var(--w95-black); outline-offset: -3px; }

label.lbl {
  display: block;
  font-size: 11px;
  margin: 6px 0 4px;
  color: var(--w95-black);
}

/* ============================================================
   STATIC STRUCTURES
   ============================================================ */

main {
  padding: 20px;
  padding-bottom: 60px;
  max-width: 1100px;
  margin: 0 auto;
}

.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.row3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.row5 { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }

.row { display: flex; justify-content: space-between; align-items: baseline; padding: 4px 0; border-bottom: 1px dotted var(--w95-dark); font-size: 12px; }
.row:last-of-type { border: none; }
.row .lab { color: var(--w95-darker); }
.row .val { color: var(--w95-black); font-weight: bold; }

@media (max-width: 720px) {
  .row2, .row3, .row5 { grid-template-columns: 1fr; }
}

/* ============================================================
   PAINT-CARD: the chunky cartoon node card
   ============================================================ */

.node-card {
  background: var(--w95-bright);
  border: 2px solid;
  border-color: var(--w95-bright) var(--w95-darker) var(--w95-darker) var(--w95-bright);
  padding: 0;
  display: flex; flex-direction: column;
}
.node-card .head {
  background: linear-gradient(90deg, var(--w95-blue), var(--w95-blue2));
  color: var(--w95-bright);
  padding: 3px 8px;
  font-weight: bold;
  font-size: 12px;
  display: flex; justify-content: space-between;
}
.node-card .pic {
  background: var(--w95-bright);
  padding: 8px;
  display: flex;
  justify-content: center;
}
.node-card .pic img,
.node-card .pic svg {
  image-rendering: pixelated;
  width: 100%;
  max-width: 160px;
  height: auto;
  display: block;
}
.node-card .meta {
  padding: 8px;
  background: var(--w95-gray);
  font-size: 11px;
}
.node-card .meta .n { font-weight: bold; font-size: 12px; }
.node-card .ctrls {
  padding: 6px 8px;
  background: var(--w95-gray);
  border-top: 1px solid var(--w95-dark);
  display: flex; gap: 6px;
}
.node-card .ctrls .btn95 { flex: 1; }

/* ============================================================
   HERO + LOGO
   ============================================================ */

.hero {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 18px;
  align-items: center;
}
.hero .splash {
  background: var(--w95-bright);
  border: 2px solid;
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  padding: 24px 18px;
  text-align: center;
}
.hero .splash h1 {
  font-family: 'HyperOS', 'Comic Sans MS', cursive;
  font-size: 36px;
  color: var(--pal-red);
  margin: 0 0 6px;
  text-shadow: 2px 2px 0 var(--w95-bright), 4px 4px 0 var(--w95-black);
  -webkit-text-stroke: 1px black;
  letter-spacing: 0.02em;
  line-height: 1;
}
.hero .splash h1 .v4 {
  color: var(--w95-blue);
  display: inline-block;
  transform: rotate(-3deg);
  margin-left: 6px;
}
.hero .splash p { font-size: 13px; max-width: 36ch; margin: 8px auto; }
.hero .splash .cta { display: flex; gap: 8px; justify-content: center; margin-top: 12px; flex-wrap: wrap; }
.hero .splash .logo { width: 96px; height: 96px; image-rendering: pixelated; margin-bottom: 8px; }

.hero .picker {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}
.hero .picker .node-card { padding: 0; cursor: default; }

@media (max-width: 720px) {
  .hero { grid-template-columns: 1fr; }
  .hero .picker { grid-template-columns: repeat(3, 1fr); }
  .hero .splash h1 { font-size: 28px; }
}

/* ============================================================
   ANIMATIONS: subtle + chunky
   ============================================================ */

@keyframes blink-cursor {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0; }
}
.blink::after { content: '_'; animation: blink-cursor 1s steps(1) infinite; }

@keyframes wobble {
  0%, 100% { transform: rotate(0); }
  25% { transform: rotate(-2deg); }
  75% { transform: rotate(2deg); }
}
.wobble { animation: wobble 1.5s ease-in-out infinite; transform-origin: center; }

@keyframes float95 {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-4px); }
}
.float { animation: float95 2.6s ease-in-out infinite; }

@keyframes marquee {
  from { transform: translateX(100%); }
  to   { transform: translateX(-100%); }
}
.marquee {
  background: var(--w95-blue);
  color: var(--w95-bright);
  padding: 4px 0;
  overflow: hidden;
  white-space: nowrap;
  font-family: 'HyperOS', 'Comic Sans MS', cursive;
  font-size: 14px;
}
.marquee span {
  display: inline-block;
  padding-left: 100%;
  animation: marquee 28s linear infinite;
}

/* ============================================================
   STAT BOXES (paint-art counters)
   ============================================================ */

.stats95 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin: 12px 0;
}
.stats95 .stat {
  background: var(--w95-bright);
  border: 2px solid;
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  padding: 8px 10px;
  font-size: 12px;
  display: flex; flex-direction: column; gap: 4px;
}
.stats95 .stat .k { color: var(--w95-darker); font-size: 11px; }
.stats95 .stat .v {
  font-family: 'HyperOS', 'Comic Sans MS', cursive;
  font-size: 22px;
  color: var(--pal-red);
  letter-spacing: 0.02em;
  -webkit-text-stroke: 0.5px black;
}
.stats95 .stat .v.hot   { color: var(--pal-red); }
.stats95 .stat .v.cold  { color: var(--w95-blue); }
.stats95 .stat .v.lime  { color: var(--pal-green); }
.stats95 .stat .v.bold  { color: var(--w95-black); }

@media (max-width: 720px) { .stats95 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 460px) { .stats95 { grid-template-columns: 1fr; } }

/* ============================================================
   TOAST (a paint-style modal)
   ============================================================ */

#toast95 {
  position: fixed;
  top: 24px; left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  display: none;
  min-width: 280px;
}
#toast95.show { display: block; animation: pop95 0.18s steps(3, end); }
#toast95 .body {
  display: flex; align-items: center; gap: 10px;
  padding: 12px;
}
#toast95 .body .ico {
  width: 32px; height: 32px;
  flex-shrink: 0;
}

@keyframes pop95 {
  from { transform: translate(-50%, -10px); opacity: 0; }
  to   { transform: translate(-50%, 0);     opacity: 1; }
}

/* ============================================================
   PAINT TABS
   ============================================================ */

.tabs95 {
  display: flex;
  border-bottom: 1px solid var(--w95-dark);
  margin: 0 0 12px;
  background: var(--w95-gray);
}
.tabs95 .tab {
  background: var(--w95-tab);
  border: 2px solid;
  border-color: var(--w95-bright) var(--w95-darker) transparent var(--w95-bright);
  padding: 4px 12px 6px;
  margin-right: 2px;
  margin-top: 2px;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  color: var(--w95-black);
}
.tabs95 .tab.active {
  background: var(--w95-gray);
  margin-top: 0;
  padding-top: 6px;
  border-bottom-color: var(--w95-gray);
  position: relative;
  z-index: 1;
  font-weight: bold;
}

/* ============================================================
   PAINT FRAME for big illustrations
   ============================================================ */

.paint-frame {
  background: var(--w95-bright);
  border: 2px solid;
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  padding: 10px;
  display: inline-block;
}

/* ============================================================
   MISC HELPERS
   ============================================================ */

.center { text-align: center; }
.spacer { height: 12px; }
.spacer-lg { height: 24px; }
.muted { color: var(--w95-darker); }
.mono { font-family: 'Courier New', monospace; }
.small { font-size: 11px; }
.tabular { font-variant-numeric: tabular-nums; }

/* dotted focus halo (paint vibe) */
:focus-visible { outline: 1px dotted var(--w95-black); outline-offset: 2px; }

/* ============================================================
   ANIMATIONS - alive-mode (Hyperliquid teal vibe)
   ============================================================ */

/* desktop background: gentle mint scanline drift */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    repeating-linear-gradient(
      180deg,
      rgba(80,210,193,0.05) 0,
      rgba(80,210,193,0.05) 1px,
      transparent 1px,
      transparent 4px);
  animation: scanDrift 14s linear infinite;
  mix-blend-mode: screen;
}
@keyframes scanDrift {
  0%   { transform: translateY(0); }
  100% { transform: translateY(40px); }
}

/* drifting mint stars layer on the desktop only */
.desktop {
  position: relative;
  isolation: isolate;
}
.desktop::after {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    radial-gradient(2px 2px at 12% 24%, rgba(151,252,228,0.7) 50%, transparent 60%),
    radial-gradient(2px 2px at 78% 36%, rgba(80,210,193,0.7) 50%, transparent 60%),
    radial-gradient(2px 2px at 32% 76%, rgba(151,252,228,0.55) 50%, transparent 60%),
    radial-gradient(2px 2px at 88% 88%, rgba(80,210,193,0.55) 50%, transparent 60%),
    radial-gradient(2px 2px at 56% 14%, rgba(151,252,228,0.6) 50%, transparent 60%),
    radial-gradient(2px 2px at 18% 64%, rgba(80,210,193,0.6) 50%, transparent 60%);
  animation: starDrift 28s linear infinite;
}
@keyframes starDrift {
  0%   { transform: translate(0,0) }
  50%  { transform: translate(-20px,12px) }
  100% { transform: translate(0,0) }
}

/* desktop icon: idle bob + glyph glow */
.desktop .icon {
  animation: iconBob 5.2s ease-in-out infinite;
  transform-origin: center;
  transition: transform .12s ease, filter .12s ease;
}
.desktop .icon:nth-child(2) { animation-delay: -.4s; }
.desktop .icon:nth-child(3) { animation-delay: -.8s; }
.desktop .icon:nth-child(4) { animation-delay: -1.2s; }
.desktop .icon:nth-child(5) { animation-delay: -1.6s; }
.desktop .icon:nth-child(6) { animation-delay: -2.0s; }
.desktop .icon:nth-child(7) { animation-delay: -2.4s; }
.desktop .icon:nth-child(8) { animation-delay: -2.8s; }
@keyframes iconBob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-3px); }
}
.desktop .icon:hover {
  transform: translateY(-4px) scale(1.05);
  filter: drop-shadow(0 4px 0 rgba(80,210,193,0.45));
}
.desktop .icon:hover .glyph {
  background: var(--hl-mint, #50d2c1);
  color: var(--w95-black);
  animation: glyphPulse 1.1s ease-in-out infinite;
}
@keyframes glyphPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(151,252,228,0.7); }
  50%      { box-shadow: 0 0 0 6px rgba(151,252,228,0); }
}

/* windows: fade + scale-in on open */
.window {
  animation: winPop .22s cubic-bezier(.2,.9,.3,1.15);
  transform-origin: top center;
}
@keyframes winPop {
  from { opacity: 0; transform: translateY(-6px) scale(.96); }
  to   { opacity: 1; transform: translateY(0)    scale(1);   }
}

/* titlebar: subtle mint sheen sliding */
.window .titlebar.active {
  background: linear-gradient(90deg, var(--w95-blue) 0%, var(--w95-blue2) 100%);
  position: relative;
  overflow: hidden;
}
.window .titlebar.active::after {
  content: "";
  position: absolute; top: 0; left: -40%; height: 100%; width: 40%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.18), transparent);
  animation: titleSheen 6s ease-in-out infinite;
}
@keyframes titleSheen {
  0%, 100% { transform: translateX(0); opacity: 0; }
  10%      { opacity: .6; }
  50%      { transform: translateX(250%); opacity: 0; }
}

/* buttons: lift on hover, press on active */
.btn95 {
  transition: transform .08s ease, box-shadow .08s ease, background .12s ease;
}
.btn95:hover:not(:disabled):not(.ghost) {
  transform: translateY(-1px);
  box-shadow: 0 2px 0 rgba(80,210,193,0.4);
}
.btn95.primary:hover:not(:disabled) {
  background: var(--hl-mint-bright, #97fce4);
  color: var(--w95-black);
}
.btn95:active:not(:disabled) {
  transform: translateY(1px);
  box-shadow: none;
}

/* taskbar entries pulse on activity */
.taskbar .task.active {
  animation: taskGlow 2.4s ease-in-out infinite;
}
@keyframes taskGlow {
  0%, 100% { box-shadow: inset 0 0 0 0 rgba(80,210,193,0); }
  50%      { box-shadow: inset 0 0 14px 0 rgba(80,210,193,0.3); }
}

/* stat cards: numbers tick on hover */
.stats95 .stat {
  transition: transform .15s ease, background .15s ease;
}
.stats95 .stat:hover {
  transform: translateY(-2px);
  background: linear-gradient(180deg, var(--w95-bright), #e9f7f3);
}
.stats95 .stat .v {
  transition: color .2s ease, text-shadow .2s ease;
}
.stats95 .stat:hover .v {
  color: var(--hl-teal-dark, #0a3834);
  text-shadow: 0 0 8px rgba(80,210,193,0.5);
}

/* pulse modifier: for live values (tax-now, pending HYPE, etc) */
.stats95 .stat.pulse .v {
  animation: livePulse 1.6s ease-in-out infinite;
}
@keyframes livePulse {
  0%, 100% { text-shadow: 0 0 0 rgba(80,210,193,0);   color: var(--w95-black); }
  50%      { text-shadow: 0 0 8px rgba(80,210,193,0.8); color: var(--hl-teal-dark, #0a3834); }
}

/* hero splash float */
.hero .splash .logo.float {
  animation: heroFloat 5.5s ease-in-out infinite;
}
@keyframes heroFloat {
  0%, 100% { transform: translateY(0)   rotate(0); }
  50%      { transform: translateY(-8px) rotate(-1.5deg); }
}

/* hero title: gentle gradient sweep */
.hero .splash h1 {
  background: linear-gradient(90deg, #97fce4, #50d2c1, #97fce4);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-stroke: 1px #0a3834;
  animation: heroGradient 6s linear infinite;
}
@keyframes heroGradient {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

/* marquee: keep horizontal scroll; subtle vertical shimmer */
.marquee-wrap { background: linear-gradient(180deg, #0a3834, #072420); border-bottom: 2px solid var(--hl-mint, #50d2c1); }
.marquee span {
  display: inline-block;
  animation: marqueeRoll 36s linear infinite;
  color: var(--hl-mint-bright, #97fce4);
  text-shadow: 0 0 6px rgba(80,210,193,0.5);
  white-space: nowrap;
  padding-left: 100%;
}
@keyframes marqueeRoll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}

/* paint-frame: hover lifts a tick */
.paint-frame {
  transition: transform .15s ease, box-shadow .15s ease;
}
.paint-frame:hover {
  transform: translateY(-1px);
  box-shadow: 2px 2px 0 rgba(80,210,193,0.35), 0 0 0 1px var(--hl-mint, #50d2c1);
}

/* node pickers (forge nodes): tile sway on hover */
.picker .pick, [data-gpk="node-picker"] .pick {
  transition: transform .15s ease, filter .15s ease;
}
.picker .pick:hover, [data-gpk="node-picker"] .pick:hover {
  transform: translateY(-3px) rotate(-1.5deg);
  filter: drop-shadow(0 6px 0 rgba(80,210,193,0.4));
}

/* table row pulse on hover */
table.rate-table tr {
  transition: background .15s ease;
}
table.rate-table tr:hover td {
  background: linear-gradient(90deg, #d8f5ee, #f7fffd, #d8f5ee);
  background-size: 200% 100%;
  animation: rowSweep 1.6s linear infinite;
}
@keyframes rowSweep {
  0%   { background-position: 0% 0; }
  100% { background-position: 200% 0; }
}

/* loading dots class - drop on data-gpk="loading" */
[data-gpk-loading]::after {
  content: "";
  display: inline-block;
  width: 6px; height: 6px;
  margin-left: 4px;
  border-radius: 50%;
  background: var(--hl-mint, #50d2c1);
  box-shadow:
    10px 0 0 var(--hl-mint, #50d2c1),
    20px 0 0 var(--hl-mint, #50d2c1);
  animation: dotsBlink 1.2s infinite steps(3);
}
@keyframes dotsBlink {
  0%   { opacity: 0.2; }
  50%  { opacity: 1.0; }
  100% { opacity: 0.2; }
}

/* respect reduced-motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001s !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001s !important;
  }
}

/* ============================================================
   HOS LENDING - preview UI
   ============================================================ */

.soon-tag {
  display: inline-block;
  font-size: 8px;
  font-weight: 900;
  letter-spacing: .12em;
  background: var(--hl-mint, #50d2c1);
  color: var(--hl-teal-dark, #0a3834);
  padding: 1px 4px;
  margin-left: 4px;
  border: 1px solid var(--w95-black);
  text-transform: uppercase;
  vertical-align: middle;
  animation: soonFlash 2.4s ease-in-out infinite;
}
@keyframes soonFlash {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.55; }
}

.soon-banner {
  background: repeating-linear-gradient(
    45deg,
    #fef9c3,
    #fef9c3 8px,
    #fde68a 8px,
    #fde68a 16px);
  color: var(--hl-teal-dark, #0a3834);
  font-weight: 700;
  font-size: 12px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--w95-black);
  border-top: 1px solid var(--w95-bright);
  animation: stripeMove 8s linear infinite;
  background-size: 200% 200%;
}
@keyframes stripeMove {
  0%   { background-position: 0 0; }
  100% { background-position: 100% 100%; }
}
.soon-pill {
  background: var(--hl-teal-dark, #0a3834);
  color: var(--hl-mint, #50d2c1);
  padding: 2px 8px;
  border: 1px solid var(--w95-black);
  font-weight: 900;
  letter-spacing: .08em;
}

.menubar a.active {
  background: var(--hl-mint, #50d2c1);
  color: var(--hl-teal-dark, #0a3834);
  font-weight: 700;
}

.lend-pane {
  display: none;
  padding: 14px 16px 18px;
}
.lend-pane.active {
  display: block;
  animation: lendFade .25s ease;
}
@keyframes lendFade {
  from { opacity: 0; transform: translateY(2px); }
  to   { opacity: 1; transform: translateY(0); }
}

.lend-section-head {
  margin-bottom: 10px;
}
.lend-section-head h3 {
  margin: 0 0 4px;
  font-family: 'HyperOS', 'Comic Sans MS', cursive;
  color: var(--hl-teal-dark, #0a3834);
  font-size: 18px;
  letter-spacing: .02em;
}

.lend-form .form-row {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 12px;
  align-items: center;
  margin: 8px 0;
}
.lend-form .form-row .lbl {
  font-size: 11px;
  color: var(--w95-darker);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin: 0;
}
.lend-form input[type=text],
.lend-form select {
  background: var(--w95-bright);
  border: 2px solid;
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  padding: 4px 6px;
  font-family: inherit;
  font-size: 12px;
  width: 100%;
}
.lend-form input:disabled,
.lend-form select:disabled {
  background: #ecece4;
  color: var(--w95-darker);
  cursor: not-allowed;
}

/* sliders (range) */
.slider-wrap {
  display: flex; align-items: center; gap: 12px;
}
.slider-wrap input[type=range] {
  flex: 1;
  accent-color: var(--hl-mint, #50d2c1);
}
.slider-val {
  min-width: 48px;
  text-align: right;
  font-family: 'Courier New', monospace;
  font-weight: 900;
  color: var(--hl-teal-dark, #0a3834);
}

/* toggle switch */
.toggle {
  position: relative;
  display: inline-block;
  width: 44px; height: 20px;
}
.toggle input { display: none; }
.toggle .toggle-knob {
  position: absolute; inset: 0;
  background: var(--w95-gray);
  border: 2px solid;
  border-color: var(--w95-darker) var(--w95-bright) var(--w95-bright) var(--w95-darker);
  border-radius: 11px;
  cursor: pointer;
  transition: background .15s ease;
}
.toggle .toggle-knob::before {
  content: "";
  position: absolute;
  top: 1px; left: 1px;
  width: 14px; height: 14px;
  background: var(--w95-darker);
  border-radius: 50%;
  transition: transform .15s ease, background .15s ease;
}
.toggle input:checked + .toggle-knob {
  background: var(--hl-mint, #50d2c1);
}
.toggle input:checked + .toggle-knob::before {
  transform: translateX(22px);
  background: var(--w95-bright);
}
.toggle input:disabled + .toggle-knob {
  cursor: not-allowed;
  filter: opacity(0.7);
}

/* small buttons inline in tables */
.btn95.small {
  padding: 2px 8px;
  font-size: 10px;
  min-width: 60px;
}

/* disabled buttons (coming soon) get a striped overlay */
button[disabled][data-soon] {
  cursor: not-allowed;
  background: linear-gradient(135deg,
    var(--w95-gray) 0%, var(--w95-gray) 40%,
    #d8e6e2 40%, #d8e6e2 60%,
    var(--w95-gray) 60%, var(--w95-gray) 100%);
  background-size: 8px 8px;
  color: var(--w95-darker);
  opacity: 0.85;
}

/* roadmap list */
.roadmap {
  list-style: none;
  padding: 0;
  margin: 0;
}
.roadmap li {
  position: relative;
  padding: 10px 12px 10px 36px;
  margin-bottom: 8px;
  background: var(--w95-bright);
  border: 2px solid;
  border-color: var(--w95-bright) var(--w95-darker) var(--w95-darker) var(--w95-bright);
  transition: transform .15s ease, box-shadow .15s ease;
}
.roadmap li:hover {
  transform: translateY(-1px);
  box-shadow: 2px 2px 0 rgba(80,210,193,0.45);
}
.roadmap li::before {
  content: "○";
  position: absolute;
  left: 12px; top: 10px;
  font-size: 16px;
  color: var(--hl-mint, #50d2c1);
  font-weight: 900;
}
.roadmap li.done::before {
  content: "●";
  color: var(--pal-green);
}
.roadmap li b { color: var(--hl-teal-dark, #0a3834); }
.roadmap li p { margin: 4px 0 0; font-size: 11px; color: var(--w95-darker); line-height: 1.55; }


/* ============================================================
   HOS PERPS - long/short toggle
   ============================================================ */
.long-short-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
}
.long-short-toggle .btn95 {
  font-weight: 900;
  letter-spacing: .08em;
  padding: 8px 0;
  font-size: 12px;
}
.long-short-toggle .ls-long.active {
  background: var(--pal-green);
  color: var(--w95-bright);
  border-color: var(--w95-bright) #2d6b2d #2d6b2d var(--w95-bright);
}
.long-short-toggle .ls-short.active {
  background: var(--pal-red);
  color: var(--w95-bright);
  border-color: var(--w95-bright) #6b1b1b #6b1b1b var(--w95-bright);
}
.long-short-toggle .btn95:not(.active) {
  background: var(--w95-gray);
  color: var(--w95-darker);
}

/* ============================================================
   HOS MARKET - NFT cards
   ============================================================ */

.nft-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
  padding: 4px 14px 14px;
}

.nft-card {
  background: var(--w95-bright);
  border: 2px solid;
  border-color: var(--w95-bright) var(--w95-darker) var(--w95-darker) var(--w95-bright);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform .15s ease, box-shadow .15s ease;
}
.nft-card:hover {
  transform: translateY(-2px);
  box-shadow: 2px 2px 0 rgba(80,210,193,0.45), 0 0 0 1px var(--hl-mint, #50d2c1);
}

.nft-card.placeholder {
  background: linear-gradient(135deg, #ecece4, #d4d0c8);
  text-align: center;
}

.nft-cover {
  position: relative;
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.9);
  font-size: 60px;
  text-shadow: 2px 2px 0 rgba(0,0,0,0.4);
  border-bottom: 1px solid var(--w95-darker);
  overflow: hidden;
}
.nft-cover .nft-emoji {
  animation: nftBob 4s ease-in-out infinite;
}
@keyframes nftBob {
  0%, 100% { transform: translateY(0) scale(1); }
  50%      { transform: translateY(-4px) scale(1.05); }
}

.nft-badge {
  position: absolute;
  top: 6px; right: 6px;
  background: var(--hl-mint, #50d2c1);
  color: var(--hl-teal-dark, #0a3834);
  font-family: 'Courier New', monospace;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .08em;
  padding: 2px 6px;
  text-transform: uppercase;
  border: 1px solid var(--w95-black);
}
.nft-badge.live {
  background: var(--pal-red);
  color: var(--w95-bright);
  animation: liveBlink 1.4s ease-in-out infinite;
}
@keyframes liveBlink {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.55; }
}

.nft-meta {
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.nft-meta h4 {
  margin: 0 0 4px;
  font-family: 'HyperOS', 'Comic Sans MS', cursive;
  color: var(--hl-teal-dark, #0a3834);
  font-size: 15px;
}
.nft-meta .row {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
}
.nft-meta .lab { color: var(--w95-darker); }
.nft-meta .val { color: var(--w95-black); font-weight: bold; }
.nft-meta .val.mono { font-family: 'Courier New', monospace; }
.nft-meta .btn95 {
  margin-top: 6px;
  width: 100%;
}

/* ============================================================
   MOBILE RESPONSIVE - fluid breakpoints, not per-device
   ============================================================ */

/* On phones, switch to a single-column flow.
   Anything below 720px width gets the mobile treatment. */
@media (max-width: 720px) {

  /* tighter body padding */
  body { font-size: 13px; }

  /* marquee fits on small screens */
  .marquee-wrap { font-size: 11px; }
  .marquee span { padding-left: 60%; }

  /* desktop icons: 4-col, smaller, clears the marquee */
  .desktop {
    padding: 64px 12px 92px !important;
    display: grid !important;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: minmax(74px, auto);
    gap: 6px;
    align-content: start;
    justify-items: center;
  }
  .desktop .icon {
    width: 100%;
    max-width: 78px;
    display: flex; flex-direction: column;
    align-items: center; text-align: center;
    padding: 4px;
    font-size: 11px;
    line-height: 1.15;
  }
  .desktop .icon .glyph { width: 36px; height: 36px; font-size: 18px; }
  .desktop .icon span { font-size: 10px; word-break: break-word; }
  .soon-tag { font-size: 7px; margin-left: 2px; padding: 0 3px; }

  /* every window goes full-width, pinned, with scrollable body so the
     titlebar (and close button) stay visible at the top */
  .window {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    top: 56px !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: calc(100vh - 88px) !important;
    max-height: calc(100vh - 88px) !important;
    border-width: 1px !important;
    margin: 0 !important;
    /* the window itself does NOT scroll - body inside does */
    overflow: hidden !important;
    /* no !important on display so inline display:none from close/minimise wins */
    display: flex;
    flex-direction: column;
  }
  /* titlebar / menubar / statusbar stay at fixed size, body fills + scrolls */
  .window > .titlebar,
  .window > .menubar,
  .window > .statusbar { flex: 0 0 auto; }
  .window > .body {
    flex: 1 1 auto !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    max-height: none !important;
  }
  #welcome-window {
    top: 56px !important;
    left: 0 !important;
    width: 100vw !important;
    height: calc(100vh - 88px) !important;
    max-height: calc(100vh - 88px) !important;
    overflow: hidden !important;
    /* no !important on display so the close button's inline display:none takes effect */
    display: flex;
    flex-direction: column;
  }
  /* hidden windows stay hidden even with the flex display rule above */
  .window[style*="display: none"],
  .window[style*="display:none"] { display: none !important; }

  /* titlebar bigger touch targets so the X is easy to hit */
  .window .titlebar { font-size: 12px; padding: 6px 8px; min-height: 36px; }
  .window .titlebar .controls button {
    width: 30px; height: 28px; font-size: 14px; line-height: 1;
  }

  /* menubar scrolls horizontally on small screens */
  .window .menubar {
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }
  .window .menubar a {
    flex-shrink: 0;
    padding: 6px 8px;
    font-size: 12px;
  }

  /* body padding tighter */
  .window .body { padding: 12px; }

  /* taskbar stays at bottom but tighter */
  .taskbar { height: 36px; padding: 3px; gap: 3px; }
  .taskbar .start-btn { padding: 2px 6px; font-size: 11px; height: 28px; }
  .taskbar .start-btn img, .taskbar .start-btn svg { width: 14px; height: 14px; }
  .taskbar .task { padding: 2px 6px; font-size: 10px; height: 28px; }
  .taskbar .task .lbl { max-width: 90px; }
  .taskbar .tray { padding: 2px 6px; height: 26px; font-size: 10px; }

  /* row3 / row5 collapse to a single column */
  .row3, .row5 { display: flex !important; flex-direction: column; gap: 10px; }

  /* hero stacks vertically and the picker drops below */
  .hero { display: block !important; }
  .hero .splash { text-align: center; }
  .hero .splash h1 { font-size: 30px; }
  .hero .splash .logo { max-width: 120px; height: auto; }

  /* CTA buttons full width on mobile */
  .cta { display: flex; flex-direction: column; gap: 6px; }
  .cta .btn95.big { width: 100%; }

  /* rate-table compresses; the wrapper scrolls */
  .paint-frame { padding: 8px; }
  table.rate-table { font-size: 11px; }
  table.rate-table th, table.rate-table td { padding: 4px 6px; }

  /* form rows stack the label above the input */
  .form-row, .lend-form .form-row {
    grid-template-columns: 1fr !important;
    gap: 4px !important;
    margin: 10px 0 !important;
  }
  .lend-form input, .lend-form select { font-size: 14px; padding: 8px 10px; }

  /* stats grid: 2 columns on phones */
  .stats95 { grid-template-columns: 1fr 1fr !important; gap: 6px; }
  .stats95 .stat { padding: 6px 8px; }
  .stats95 .stat .v { font-size: 13px; }
  .stats95 .stat .k { font-size: 10px; }

  /* NFT grid: 2 cards per row */
  .nft-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; padding: 4px 10px 10px; }
  .nft-cover { font-size: 40px; }
  .nft-meta { padding: 8px; }
  .nft-meta h4 { font-size: 13px; }

  /* perp Trade tab: chart + ticket stack */
  .row3[style*="grid-template-columns: 2fr 1fr"] { grid-template-columns: 1fr !important; }

  /* start menu fills the screen width on mobile */
  .start-menu {
    width: 90vw;
    left: 5vw;
    bottom: 40px;
  }
  .start-menu ul { font-size: 12px; }
  .start-menu .rail { writing-mode: vertical-rl; transform: rotate(180deg); }

  /* welcome window scrolls inside body */
  #welcome-window .body { padding: 14px; }

  /* tables fit smaller */
  .doc table { font-size: 10px; }
  .doc table th, .doc table td { padding: 3px 5px; }

  /* big buttons stay readable */
  .btn95.big { font-size: 13px; padding: 8px 12px; }
  .btn95.primary.big { padding: 10px 14px; }
  .actions-row { flex-direction: column; align-items: stretch; gap: 6px; }
  .actions-row .btn95 { width: 100%; }

  /* roadmap cards lose excess padding */
  .roadmap li { padding: 8px 10px 8px 28px; }
  .roadmap li::before { left: 8px; top: 8px; font-size: 14px; }

  /* hover effects degrade gracefully on touch */
  .desktop .icon:hover { transform: none; filter: none; }
  .desktop .icon { animation: none; }
}

/* even smaller phones (350-400px wide), 3-column icon grid */
@media (max-width: 400px) {
  .desktop { grid-template-columns: repeat(3, 1fr) !important; }
  .nft-grid { grid-template-columns: 1fr; }
  .stats95 { grid-template-columns: 1fr !important; }
  .hero .splash h1 { font-size: 26px; }
}

/* tablets / small laptops: 6-col desktop icons */
@media (max-width: 980px) and (min-width: 721px) {
  .desktop { padding: 60px 16px 90px; }
  .window { max-width: calc(100vw - 16px) !important; }
}

/* prevent horizontal page scroll, ever */
html, body { overflow-x: hidden; }
