*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:var(--mono);
  background: var(--bg);
  color:var(--fg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100dvh;
}

/* ============================================================
   DESKTOP environment — wallpaper, menu bar, dock.
   The terminal is a window floating on it. Collapses to
   fullscreen on small screens.
   ============================================================ */
.desktop{
  position:fixed; inset:0;
  display:flex; flex-direction:column;
  overflow:hidden;
}
/* wallpaper: aurora orbs over deep ink */
.desktop::before{
  content:""; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(40% 50% at 18% 22%, var(--wall-a) 0%, transparent 60%),
    radial-gradient(46% 52% at 84% 30%, var(--wall-b) 0%, transparent 62%),
    radial-gradient(50% 55% at 70% 96%, var(--wall-c) 0%, transparent 60%),
    radial-gradient(60% 60% at 30% 88%, var(--wall-d) 0%, transparent 60%),
    linear-gradient(160deg, var(--wall-1), var(--wall-2));
}
.desktop::after{ /* faint honeycomb / hex motif — color follows theme */
  content:""; position:absolute; inset:0; z-index:0; opacity:var(--hex-op);
  background-color:var(--hex-stroke);
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='49' viewBox='0 0 28 49'%3E%3Cg fill='none' stroke='%23000' stroke-width='1'%3E%3Cpath d='M13.99 9.25l13 7.5v15l-13 7.5L1 31.75v-15z'/%3E%3Cpath d='M0 .5L13 8v15L0 30.5M27 .5L14 8v15l13 7.5'/%3E%3C/g%3E%3C/svg%3E"),radial-gradient(130% 100% at 50% -10%, #000 35%, transparent 100%);
          mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='49' viewBox='0 0 28 49'%3E%3Cg fill='none' stroke='%23000' stroke-width='1'%3E%3Cpath d='M13.99 9.25l13 7.5v15l-13 7.5L1 31.75v-15z'/%3E%3Cpath d='M0 .5L13 8v15L0 30.5M27 .5L14 8v15l13 7.5'/%3E%3C/g%3E%3C/svg%3E"),radial-gradient(130% 100% at 50% -10%, #000 35%, transparent 100%);
  -webkit-mask-size:56px 98px, 100% 100%;
          mask-size:56px 98px, 100% 100%;
  -webkit-mask-composite:source-in;
          mask-composite:intersect;
  background-size:56px 98px;
}

/* ---- menu bar ---- */
.menubar{
  position:relative; z-index:3;
  flex:0 0 auto;
  height:34px;
  display:flex; align-items:center; gap:18px;
  padding:0 14px;
  font-size:12.5px; color:var(--dim);
  background:var(--menubar-bg);
  border-bottom:1px solid var(--hairline);
  -webkit-backdrop-filter:blur(18px) saturate(1.3);
          backdrop-filter:blur(18px) saturate(1.3);
  user-select:none;
}
.menubar .logo{ color:var(--iris); font-size:13px; }
.menubar .app{ color:var(--fg); font-weight:700; letter-spacing:.01em; }
.menubar .menus{ display:flex; gap:16px; }
.menubar .menus span{ cursor:default; transition:color .15s; }
.menubar .menus span:hover{ color:var(--fg); }
.menubar .spacer{ flex:1; }
.menubar .tray{ display:flex; align-items:center; gap:16px; white-space:nowrap; }
/* margin:0 guards against the terminal's .block content styles,
   whose class name collides with the tray's .item.block */
.menubar .tray .item{ display:inline-flex; align-items:center; gap:6px; margin:0; line-height:1; font-variant-numeric:tabular-nums; white-space:nowrap; }
.menubar .tray .lbl{ color:var(--dim); font-size:12px; }
.menubar .tray .unit{ color:var(--faint); font-size:11px; }
.menubar .tray .block b{ color:var(--fg); font-weight:600; }
.menubar .tray .pill{
  padding:3px 10px 3px 9px; gap:6px;
  border:1px solid oklch(0.74 0.135 285 / 0.35);
  border-radius:999px;
  background:oklch(0.74 0.135 285 / 0.10);
}
.menubar .tray .pill .led2{ width:7px; height:7px; border-radius:50%; background:var(--mint); box-shadow:0 0 0 0 var(--mint); animation:pulse 2.4s ease-in-out infinite; }
.menubar .tray .pill b{ color:var(--iris); font-weight:600; }
.menubar .clock{ color:var(--fg); font-variant-numeric:tabular-nums; min-width:46px; text-align:right; line-height:1; }

/* odometer-style rolling number (gas / block) — animated per digit.
   Static line-height matches the rest of the tray (1) so it aligns;
   the slide animation sets its own height inline while it runs. */
.menubar .tray .roll{ display:inline-flex; align-items:center; line-height:1; }
.menubar .tray .roll .digits{ display:inline-flex; align-items:center; line-height:1; }
.menubar .tray .roll .digit{ display:inline-block; line-height:1; }
@media (max-width:900px){ .menubar .tray .block{ display:none; } }
@media (max-width:760px){ .menubar .menus{ display:none; } }

/* ---- stage (centers the window, nudged slightly off-center on desktop) ---- */
.stage{
  position:relative; z-index:2;
  flex:1 1 auto; min-height:0;
  display:flex; align-items:center; justify-content:center;
  padding:clamp(16px, 3.2vw, 44px);
}
@media (min-width:761px){
  .stage{ padding-left:138px; padding-right:6%; padding-bottom:104px; }
  .win{ margin-bottom:0; }
}

/* ---- dock ---- */
.dock{
  position:fixed; z-index:4;
  bottom:14px; left:50%; transform:translateX(-50%);
  display:flex; align-items:flex-end; gap:10px;
  padding:9px 12px;
  border-radius:18px;
  background:var(--dock-bg);
  border:1px solid var(--hairline);
  box-shadow:0 1px 0 var(--inset-hi) inset, 0 18px 40px -18px var(--shadow-1);
  -webkit-backdrop-filter:blur(20px) saturate(1.3);
          backdrop-filter:blur(20px) saturate(1.3);
}
.dock .tile{
  position:relative;
  width:44px; height:44px;
  display:flex; align-items:center; justify-content:center;
  border-radius:12px;
  font-size:20px;
  background:linear-gradient(160deg, var(--tile-1), var(--tile-2));
  border:1px solid var(--hairline);
  color:var(--fg);
  cursor:pointer;
  transition:transform .16s cubic-bezier(.2,.8,.2,1), box-shadow .16s, border-color .16s;
}
.dock .tile:hover{ transform:translateY(-8px) scale(1.06); border-color:var(--iris); box-shadow:0 12px 22px -10px var(--shadow-1); }
.dock .tile:active{ transform:translateY(-3px) scale(1.0); }
.dock .tile:focus-visible{ outline:2px solid var(--iris); outline-offset:3px; }
.dock .tile.term{ background:linear-gradient(160deg, var(--iris-dim), var(--tile-2)); border-color:color-mix(in oklch, var(--iris) 50%, transparent); }
.dock .tile .run{ position:absolute; bottom:-7px; left:50%; transform:translateX(-50%); width:4px; height:4px; border-radius:50%; background:var(--iris); }
.dock .tip{
  position:absolute; bottom:54px; left:50%; transform:translateX(-50%) translateY(4px);
  background:var(--tip-bg); color:var(--fg);
  font-size:11px; padding:3px 8px; border-radius:6px; white-space:nowrap;
  border:1px solid var(--line);
  opacity:0; pointer-events:none; transition:opacity .15s, transform .15s;
}
.dock .tile:hover .tip{ opacity:1; transform:translateX(-50%) translateY(0); }
@media (max-width:760px){ .dock{ display:none; } }

/* ---- desktop program icons (top-left of the wallpaper) ---- */
.deskicons{
  position:fixed; top:46px; left:16px; z-index:4;
  display:flex; flex-direction:column; gap:4px;
}
.deskicon{
  display:flex; flex-direction:column; align-items:center; gap:7px;
  width:86px; padding:9px 6px 7px;
  border:1px solid transparent; border-radius:13px;
  background:transparent; cursor:pointer;
  font-family:var(--mono); -webkit-tap-highlight-color:transparent;
  transition:background .15s, border-color .15s;
}
.deskicon:hover{ background:color-mix(in oklch, var(--fg) 8%, transparent); }
.deskicon.sel{ background:var(--iris-dim); border-color:color-mix(in oklch, var(--iris) 35%, transparent); }
.deskicon:focus-visible{ outline:2px solid var(--iris); outline-offset:2px; }
.ic-tile{
  width:52px; height:52px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(160deg, var(--tile-1), var(--tile-2));
  border:1px solid var(--hairline);
  box-shadow:0 8px 16px -10px var(--shadow-1), 0 1px 0 var(--inset-hi) inset;
  transition:transform .16s cubic-bezier(.2,.8,.2,1);
}
.deskicon:hover .ic-tile{ transform:translateY(-3px); }
.deskicon:active .ic-tile{ transform:translateY(-1px) scale(.97); }
.ic-tile svg{ width:27px; height:27px; display:block; }
.ic-term svg{ color:var(--mint); }
.ic-browser svg{ color:var(--iris); }
.ic-label{
  font-size:11.5px; color:var(--fg); line-height:1;
  padding:2px 6px; border-radius:6px;
  text-shadow:0 1px 4px var(--shadow-1);
}
.deskicon.sel .ic-label{ background:var(--iris); color:var(--bg); text-shadow:none; }

/* ---------- terminal window ---------- */
.win{
  width:100%;
  max-width:var(--maxw);
  height:100%;
  max-height:820px;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:
    0 1px 0 var(--inset-hi) inset,
    0 40px 90px -40px var(--shadow-1),
    0 12px 30px -18px var(--shadow-2);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  position:relative;
}

.titlebar{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  gap:14px;
  padding:0 16px;
  height:44px;
  background:linear-gradient(var(--bar), var(--bar-2));
  border-bottom:1px solid var(--line);
  user-select:none;
}
.dots{ display:flex; gap:8px; }
.dot{ width:12px; height:12px; border-radius:50%; background:var(--line); border:none; padding:0; cursor:pointer; position:relative; transition:filter .15s, transform .05s; display:flex; align-items:center; justify-content:center; }
/* keep the 12px mac-style visual but give each dot a 24px hit target (WCAG 2.5.8) */
.dot::after{ content:""; position:absolute; inset:-6px; border-radius:50%; }
.dot:hover{ filter:brightness(1.18); }
.dot:active{ transform:scale(0.9); }
.dot:focus-visible{ outline:2px solid var(--iris); outline-offset:2px; }
.dot.a{ background:oklch(0.66 0.16 18); }
.dot.b{ background:oklch(0.80 0.13 75); }
.dot.c{ background:oklch(0.74 0.13 165); }
/* tiny hover glyph, mac-style */
.dot .g{ font-size:8px; line-height:1; color:oklch(0.2 0.04 30 / 0.75); opacity:0; transition:opacity .12s; font-family:var(--mono); }
.dots:hover .dot .g{ opacity:1; }

/* minimize animation */
.win{ transition:transform .32s cubic-bezier(.4,0,.2,1), opacity .32s; transform-origin:bottom center; }
.win.min{ transform:scale(0.06) translateY(360%); opacity:0; pointer-events:none; }
.win.zoom{ max-width:1180px; max-height:94%; }
@media (max-width:760px){ .win.min{ transform:none; opacity:1; } }
@media (prefers-reduced-motion: reduce){ .win{ transition:opacity .2s; } .win.min{ transform:none; opacity:0; } }

.titlebar .name{
  font-size:12.5px;
  letter-spacing:0.02em;
  color:var(--dim);
  display:flex;
  align-items:center;
  gap:8px;
}
.titlebar .name b{ color:var(--fg); font-weight:600; }
.titlebar .spacer{ flex:1; }
.netpill{
  display:flex; align-items:center; gap:7px;
  font-size:11.5px; color:var(--dim);
  padding:4px 10px;
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--surface);
}
.netpill .led{
  width:7px; height:7px; border-radius:50%;
  background:var(--mint);
  box-shadow:0 0 0 0 var(--mint);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ box-shadow:0 0 0 0 oklch(0.80 0.095 165 / 0.5); }
  50%{ box-shadow:0 0 0 4px oklch(0.80 0.095 165 / 0); }
}

/* ---------- chips row ---------- */
.chips{
  flex:0 0 auto;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:12px 16px;
  border-bottom:1px solid var(--line);
  background:var(--surface);
}
.chip{
  font-family:var(--mono);
  font-size:12.5px;
  color:var(--dim);
  background:transparent;
  border:1px solid var(--line);
  border-radius:8px;
  padding:6px 11px;
  cursor:pointer;
  transition:color .15s, border-color .15s, background .15s, transform .05s;
  display:inline-flex;
  align-items:center;
  gap:7px;
  white-space:nowrap;
}
.chip .pre{ color:var(--iris); opacity:.7; }
.chip:hover{
  color:var(--fg);
  border-color:var(--iris);
  background:var(--iris-dim);
}
.chip:active{ transform:translateY(1px); }
.chip:focus-visible{ outline:2px solid var(--iris); outline-offset:2px; }

/* ---------- screen / scroll area ---------- */
.screen{
  flex:1 1 auto;
  overflow-y:auto;
  overflow-x:hidden;
  padding:20px clamp(16px, 3vw, 28px) 8px;
  font-size:14px;
  line-height:1.65;
  scrollbar-width:thin;
  scrollbar-color:var(--line) transparent;
}
.screen::-webkit-scrollbar{ width:10px; }
.screen::-webkit-scrollbar-thumb{ background:var(--line); border-radius:10px; border:3px solid transparent; background-clip:content-box; }

/* output blocks */
.block{ margin:0 0 6px; white-space:pre-wrap; word-break:break-word; }
.block + .block{ margin-top:2px; }

/* "drawing" reveal for command output (lines + project cards) */
@keyframes term-in{ from{ opacity:0; transform:translateY(4px); } to{ opacity:1; transform:none; } }
.screen .term-in{ animation:term-in .18s ease-out both; }
@media (prefers-reduced-motion: reduce){ .screen .term-in{ animation:none; } }
.muted{ color:var(--dim); }
.dim{ color:var(--dim); }
.faint{ color:var(--faint); }
.cathdr{ margin:14px 0 2px; font-size:13px; letter-spacing:.02em; }
.cathdr:first-child{ margin-top:0; }
.iris{ color:var(--iris); }
.peach{ color:var(--peach); }
.mint{ color:var(--mint); }
.rose{ color:var(--rose); }
.fg{ color:var(--fg); }
b,strong{ font-weight:700; color:var(--fg); }

a{ color:var(--peach); text-decoration:none; border-bottom:1px solid color-mix(in oklch, var(--peach) 32%, transparent); transition:border-color .15s, background .15s; }
a:hover{ border-color:var(--peach); background:var(--peach-dim); }
a:focus-visible{ outline:2px solid var(--peach); outline-offset:2px; }

/* echoed command line */
.cmd-echo{ color:var(--fg); }
.cmd-echo .prompt{ color:var(--iris); margin-right:8px; }
.cmd-echo .ps{ color:var(--mint); }
.cmd-echo .pp{ color:var(--peach); }

/* generic two-column listing */
.rows{ display:grid; gap:3px 18px; }
.kv{ display:grid; grid-template-columns: 132px 1fr; gap:18px; }
.kv .k{ color:var(--dim); }
.kv a{ justify-self:start; }
@media (max-width:560px){
  .kv{ grid-template-columns: 1fr; gap:0; }
  .kv .k{ color:var(--faint); font-size:12px; }
}

/* banner */
.banner{ color:var(--iris); line-height:1.05; font-size:clamp(8px, 2.1vw, 14px); margin:4px 0 10px; text-shadow:0 0 22px oklch(0.74 0.135 285 / 0.35); }
.banner .sub{ display:block; color:var(--dim); font-size:13px; letter-spacing:0.18em; margin-top:10px; text-shadow:none; }

/* theme picker */
.theme-grid{ display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:8px; max-width:520px; margin:2px 0 2px; }
.theme-card{
  font-family:var(--mono); text-align:left; cursor:pointer;
  display:flex; align-items:center; gap:11px;
  padding:9px 11px; border:1px solid var(--line); border-radius:10px;
  background:var(--surface); color:var(--fg);
  transition:border-color .15s, background .15s, transform .05s;
}
.theme-card:hover{ border-color:var(--iris); background:var(--iris-dim); }
.theme-card:active{ transform:translateY(1px); }
.theme-card:focus-visible{ outline:2px solid var(--iris); outline-offset:2px; }
.theme-card.on{ border-color:var(--iris); box-shadow:0 0 0 1px var(--iris) inset; }
.theme-card .sw{ display:flex; flex:0 0 auto; }
.theme-card .sw i{ width:15px; height:15px; border-radius:50%; border:1px solid var(--hairline); margin-left:-5px; }
.theme-card .sw i:first-child{ margin-left:0; }
.theme-card .tl{ display:flex; flex-direction:column; line-height:1.25; min-width:0; }
.theme-card .tl b{ color:var(--fg); font-weight:600; font-size:13px; }
.theme-card .tl small{ color:var(--dim); font-size:11px; }
@media (max-width:560px){ .theme-grid{ grid-template-columns:1fr; } }
.proj{ padding:12px 0; border-top:1px solid var(--line); }
.proj:first-child{ border-top:none; }
.proj .top{ display:flex; flex-wrap:wrap; align-items:center; gap:6px 10px; }
.proj .nm{ color:var(--fg); font-weight:600; white-space:nowrap; }
.proj .tag{ font-size:11px; color:var(--iris); border:1px solid var(--line); border-radius:999px; padding:2px 8px; }
.proj .stk{ color:var(--faint); font-size:12.5px; margin-top:3px; }
.proj .desc{ color:var(--dim); margin:5px 0 6px; }
.proj .addr{ font-size:12.5px; color:var(--faint); display:flex; flex-wrap:wrap; align-items:center; gap:6px 8px; }
.proj .addr .mono{ color:var(--peach); }

/* projects "load more" pager button */
.loadmore{
  font-family:var(--mono); font-size:12.5px; color:var(--iris);
  background:transparent; border:1px dashed var(--line); border-radius:8px;
  padding:9px 12px; margin:8px 0 2px; width:100%; text-align:center; cursor:pointer;
  transition:border-color .15s, background .15s, color .15s, transform .05s;
}
.loadmore:hover{ border-color:var(--iris); background:var(--iris-dim); color:var(--fg); }
.loadmore:active{ transform:translateY(1px); }
.loadmore:focus-visible{ outline:2px solid var(--iris); outline-offset:2px; }
.loadmore .faint{ color:var(--faint); }
/* a newer command supersedes old pagers left in scrollback */
.loadmore:disabled{ opacity:.45; cursor:default; pointer-events:none; }

/* skills bars */
.skill{ display:grid; grid-template-columns: 150px 1fr auto; align-items:center; gap:14px; padding:3px 0; }
.skill .lab{ color:var(--fg); }
.skill .bar{ height:8px; border-radius:999px; background:var(--track); overflow:hidden; }
.skill .fill{ height:100%; border-radius:999px; background:linear-gradient(90deg, var(--iris), var(--peach)); width:0; transition:width 1s cubic-bezier(.2,.7,.2,1); }
.skill .pct{ color:var(--dim); font-size:12px; min-width:40px; text-align:right; }
@media (max-width:560px){ .skill{ grid-template-columns: 110px 1fr auto; gap:10px; } }

/* gas widget */
.gas{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin:8px 0 4px; }
.gas .card{ border:1px solid var(--line); border-radius:10px; padding:12px 14px; background:var(--surface); }
.gas .card .t{ font-size:11.5px; color:var(--dim); letter-spacing:.04em; }
.gas .card .v{ font-size:22px; font-weight:700; margin-top:4px; }
.gas .card .u{ font-size:11px; color:var(--faint); }
.gas .card.slow .v{ color:var(--mint); }
.gas .card.avg  .v{ color:var(--peach); }
.gas .card.fast .v{ color:var(--rose); }
@media (max-width:560px){ .gas{ grid-template-columns:1fr; } }

/* ---------- input line ---------- */
.inputwrap{
  flex:0 0 auto;
  border-top:1px solid var(--line);
  background:var(--surface);
  padding:0 clamp(16px, 3vw, 28px);
}
.suggest{
  height:0; overflow:hidden;
  color:var(--faint); font-size:12px;
  transition:height .15s;
  display:flex; align-items:center; gap:6px;
}
.suggest.show{ height:26px; }
.suggest .hl{ color:var(--iris); }
.inline{ display:flex; align-items:center; gap:10px; height:52px; }
.inline .ps{ color:var(--mint); white-space:nowrap; }
.inline .pp{ color:var(--peach); }
.inline .arrow{ color:var(--iris); }
.field{ position:relative; flex:1; display:flex; align-items:center; }
#cmd{
  font-family:var(--mono);
  font-size:14px;
  color:var(--fg);
  background:transparent;
  border:none;
  outline:none;
  width:100%;
  padding:0;
  caret-color:transparent;
}
#cmd::placeholder{ color:var(--faint); }
/* ghost autocomplete text */
.ghost{
  position:absolute; left:0; top:0;
  pointer-events:none;
  font-size:14px; color:var(--faint);
  white-space:pre;
}
.ghost .typed{ color:transparent; }
/* fake caret */
.caret{
  display:inline-block; width:9px; height:18px;
  background:var(--iris);
  margin-left:1px;
  transform:translateY(3px);
  animation:blink 1.1s steps(1) infinite;
}
@keyframes blink{ 50%{ opacity:0; } }
.inline.away .caret{ animation:none; opacity:.35; }

/* boot skip button */
.skip{
  position:absolute; top:54px; right:16px; z-index:5;
  font-family:var(--mono); font-size:11.5px; color:var(--dim);
  background:var(--surface);
  border:1px solid var(--line); border-radius:8px;
  padding:5px 10px; cursor:pointer;
  transition:color .15s, border-color .15s, opacity .3s;
}
.skip:hover{ color:var(--fg); border-color:var(--iris); }
.skip[hidden]{ display:none; }

/* typed-out boot caret */
.bootcaret{ color:var(--iris); }

/* hint footer line */
.hint{ color:var(--faint); font-size:12px; }
.hint kbd{
  font-family:var(--mono); font-size:11px;
  border:1px solid var(--line); border-radius:5px;
  padding:1px 6px; color:var(--dim);
  background:var(--surface-2);
}

/* ---------- snakechain (hidden TUI game) ---------- */
.snakewrap{ margin:6px 0 10px; user-select:none; }
.snake-title{ font-size:12.5px; color:var(--dim); margin-bottom:4px; letter-spacing:.04em; }
.snake-title b{ color:var(--iris); font-weight:600; }
.snake-screen{
  --snk-fs: clamp(15px, 4.2vw, 21px);
  position:relative;
  font-size:var(--snk-fs);
  line-height:1;
  display:grid;
  grid-template-columns:repeat(20, 1ch); /* COLS + 2, sized to glyph advance */
  grid-auto-rows:1em;
  width:max-content;
  margin:2px 0;
  font-variant-ligatures:none;
  -webkit-user-select:none; user-select:none;
}
.snk-cell{
  text-align:center;
  overflow:hidden;
}
.snk-txt{ font-size:0.6em; font-weight:600; }
.snk-dot{ color:oklch(0.40 0.018 285); font-size:0.62em; }
.snk-blank{ color:transparent; }
.snk-border{ color:var(--faint); }
.snk-body{ color:var(--iris); }
.snk-head{ color:oklch(0.90 0.15 95); }
.snk-food{ color:var(--peach); font-size:0.82em; }
.snk-gem{ color:var(--mint); font-size:0.92em; animation:gemPulse 1s ease-in-out infinite; }
@keyframes gemPulse{ 50%{ opacity:.35; } }
.snk-dead{ color:var(--rose); }
.snk-sub{ color:var(--dim); }
.snk-keys{ color:var(--peach); }
/* game-over overlay (floats inside the box so prose can breathe) */
.snk-over{
  position:absolute; inset:0.6ch 0.4ch;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:0.34em; text-align:center; padding:0 0.3em;
  background:var(--glass);
  -webkit-backdrop-filter:blur(1.5px); backdrop-filter:blur(1.5px);
}
.snk-over div{ white-space:nowrap; }
.snk-over-title{ color:var(--rose); font-weight:700; letter-spacing:.1em; font-size:0.66em; }
.snk-over-sub{ color:var(--dim); font-size:0.5em; letter-spacing:.02em; white-space:normal !important; line-height:1.35; max-width:90%; }
.snk-over-score{ color:oklch(0.90 0.15 95); font-size:0.56em; margin-top:0.5em; }
.snk-over-blocks{ color:var(--iris); font-size:0.52em; }
.snk-over-keys{ color:var(--peach); font-size:0.54em; margin-top:0.5em; }
.snk-over b{ color:var(--fg); font-weight:700; }
.snake-status{ margin-top:11px; font-size:12.5px; color:var(--dim); line-height:1.7; font-variant-numeric:tabular-nums; }
.snake-status b{ font-weight:600; color:var(--fg); }
.snake-status .peach{ color:var(--peach); }
.snake-status .sep{ color:oklch(0.42 0.018 285); margin:0 7px; }
.snake-net .on{ color:var(--iris); }
.snake-net .off{ color:oklch(0.40 0.018 285); }
.snake-legend{ margin-top:5px; font-size:11.5px; color:var(--faint); line-height:1.7; }
.snake-legend .sep{ color:oklch(0.40 0.018 285); margin:0 7px; }
.snake-legend .iris{ color:var(--iris); } .snake-legend .peach{ color:var(--peach); } .snake-legend .mint{ color:var(--mint); }
/* on-screen dpad (touch) */
.snake-pad{ display:none; margin-top:13px; grid-template-columns:repeat(3,50px); grid-template-rows:repeat(3,50px); gap:6px; }
.snake-pad button{ font-family:var(--mono); font-size:18px; color:var(--fg); background:var(--surface-2); border:1px solid var(--line); border-radius:10px; cursor:pointer; -webkit-tap-highlight-color:transparent; }
.snake-pad button:active{ background:var(--iris-dim); border-color:var(--iris); }
.snake-pad .pu{ grid-column:2; grid-row:1; } .snake-pad .pl{ grid-column:1; grid-row:2; }
.snake-pad .pc{ grid-column:2; grid-row:2; font-size:11px; color:var(--dim); }
.snake-pad .pr{ grid-column:3; grid-row:2; } .snake-pad .pd{ grid-column:2; grid-row:3; }
@media (hover:none) and (pointer:coarse){ .snake-pad{ display:grid; } }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .caret{ animation:none; }
  .netpill .led{ animation:none; }
}

@media (max-width:560px){
  .titlebar .name .path{ display:none; }
  .screen{ font-size:13.5px; }
  .skip{ top:50px; }
}

/* mobile-only app switcher; hidden on desktop and on the bare mobile desktop */
.mobiledock{ display:none; }

/* ============================================================
   MOBILE — phone-style OS: full-screen apps with close/minimize,
   a compact status bar, and a home screen of app icons.
   ============================================================ */
@media (max-width:760px){
  /* full-screen, edge-to-edge windows; keep close + minimize, drop maximize */
  .oswin{ border-radius:0; border-left:none; border-right:none; }
  .oswin .dot.c{ display:none; }

  /* compact status bar: app name + clock */
  .menubar{ display:flex; gap:10px; padding:0 12px; }
  .menubar .tray{ gap:12px; }
  .menubar .tray .pill, .menubar .tray .block{ display:none; }

  /* app icons live on the home screen (revealed when all windows are closed) */
  .deskicons{
    position:fixed; top:0; left:0; right:0; bottom:auto;
    flex-direction:row; flex-wrap:wrap; align-content:flex-start; justify-content:center;
    gap:22px 26px; padding:74px 24px 24px;
    z-index:4;
  }
  .deskicon{ flex-direction:column; width:92px; gap:9px; padding:12px 8px; border-radius:18px; border:1px solid transparent; }
  .deskicon:active{ background:color-mix(in oklch, var(--fg) 10%, transparent); }
  .deskicon .ic-tile{ width:58px; height:58px; border-radius:16px; }
  .deskicon .ic-tile svg{ width:29px; height:29px; }
  .deskicon .ic-label{ font-size:13px; }

  /* bottom app switcher — only while a window is open (it covers the icons) */
  .desktop.windowed .mobiledock{
    position:fixed; inset:auto 0 0 0; z-index:1000;
    display:flex; justify-content:center; gap:8px;
    padding:7px 12px calc(7px + env(safe-area-inset-bottom));
    background:var(--menubar-bg); border-top:1px solid var(--hairline);
    -webkit-backdrop-filter:blur(18px) saturate(1.3); backdrop-filter:blur(18px) saturate(1.3);
  }
  .md-btn{
    display:inline-flex; align-items:center; gap:8px;
    padding:9px 18px; border-radius:13px; border:1px solid transparent;
    background:transparent; color:var(--fg); font-family:var(--mono); font-size:13px; cursor:pointer;
    -webkit-tap-highlight-color:transparent; transition:background .15s, border-color .15s, color .15s;
  }
  .md-btn svg{ width:18px; height:18px; flex:0 0 auto; }
  .md-btn:active{ background:color-mix(in oklch, var(--fg) 10%, transparent); }
  .md-btn.sel{ background:var(--iris-dim); border-color:color-mix(in oklch, var(--iris) 40%, transparent); color:var(--iris); }
}

/* ============================================================
   BROWSER window — the web view, running as a window inside
   the OS (sits above the terminal, below the dock + icons).
   ============================================================ */
.browserwin{
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:0 1px 0 var(--inset-hi) inset, 0 40px 90px -40px var(--shadow-1), 0 12px 30px -18px var(--shadow-2);
  display:flex; flex-direction:column; overflow:hidden;
  transition:transform .32s cubic-bezier(.4,0,.2,1), opacity .32s;
  transform-origin:bottom center;
}
.browserbar{
  flex:0 0 auto; display:flex; align-items:center; gap:12px;
  padding:0 14px; height:46px;
  background:linear-gradient(var(--bar), var(--bar-2));
  border-bottom:1px solid var(--line); user-select:none;
}
.browserbar .nav{ display:flex; gap:5px; }
.browserbar .nav button{
  width:27px; height:27px; border-radius:7px; border:1px solid var(--line);
  background:var(--surface); color:var(--dim); cursor:pointer; font-size:14px; line-height:1;
  display:flex; align-items:center; justify-content:center; transition:color .15s, border-color .15s;
}
.browserbar .nav button:hover{ color:var(--fg); border-color:var(--iris); }
.urlbar{
  flex:1; display:flex; align-items:center; gap:7px;
  height:28px; padding:0 12px; min-width:0;
  background:var(--surface-2); border:1px solid var(--line); border-radius:999px;
  color:var(--dim); font-size:12.5px; overflow:hidden; white-space:nowrap; text-overflow:ellipsis;
}
.urlbar .lock{ font-size:10px; }
.urlbar .u{ color:var(--fg); }
.urlbar .path{ color:var(--dim); }
.browserframe{ flex:1 1 auto; width:100%; border:0; background:var(--bg); display:block; }

/* ============================================================
   WINDOW MANAGER — free-floating, draggable, resizable windows.
   ============================================================ */
.menubar{ z-index:1000; }                 /* OS menu bar always on top */
.oswin{ position:absolute; max-width:none; max-height:none; margin:0; transform:none; }
.oswin[hidden]{ display:none !important; }   /* beat .browserwin{display:flex} */
.oswin.min{ transform:scale(0.06) translateY(360%); opacity:0; pointer-events:none; }
.oswin.closing{ transform:scale(0.94); opacity:0; pointer-events:none; }
.oswin.active{ box-shadow:0 1px 0 var(--inset-hi) inset, 0 50px 100px -38px var(--shadow-1), 0 14px 34px -16px var(--shadow-2); }
.oswin:not(.active) .titlebar, .oswin:not(.active) .browserbar{ filter:saturate(.65) brightness(.97); }
.oswin.animating{ transition:left .3s cubic-bezier(.4,0,.2,1), top .3s cubic-bezier(.4,0,.2,1), width .3s cubic-bezier(.4,0,.2,1), height .3s cubic-bezier(.4,0,.2,1), transform .3s, opacity .3s; }
/* title bar sits above the resize handles so its buttons stay clickable;
   this also means top-edge resize is disabled, which is fine. */
.oswin-bar{ touch-action:none; position:relative; z-index:40; }
.rz{ position:absolute; z-index:30; touch-action:none; }
.rz-n{ top:0; left:16px; right:16px; height:6px; cursor:ns-resize; }
.rz-s{ bottom:0; left:16px; right:16px; height:8px; cursor:ns-resize; }
.rz-e{ right:0; top:16px; bottom:16px; width:8px; cursor:ew-resize; }
.rz-w{ left:0; top:16px; bottom:16px; width:8px; cursor:ew-resize; }
.rz-ne{ top:0; right:0; width:16px; height:16px; cursor:nesw-resize; }
.rz-nw{ top:0; left:0; width:16px; height:16px; cursor:nwse-resize; }
.rz-se{ bottom:0; right:0; width:18px; height:18px; cursor:nwse-resize; }
.rz-sw{ bottom:0; left:0; width:16px; height:16px; cursor:nesw-resize; }
@media (max-width:760px){ .rz{ display:none; } }
@media (prefers-reduced-motion: reduce){
  .browserwin{ transition:opacity .2s; }
  .oswin.min{ transform:none; opacity:0; }
  .oswin.animating{ transition:opacity .2s; }
}
