/* ============================================================
   Theron OS · the shell
   An operating system where Theron lives, acts, and receipts
   every action. Built on the Vext Labs brand tokens (vext.css).
   shell = room · menubar · dock · windows · command bar · companion
   ============================================================ */

/* ─── UNISEX BASE CANVAS ───────────────────────────────────────
   Neutral slate default — overrides vext.css "Liquid Candy" pinks
   & purples so JUWEL ships gender-neutral out of the box. Amber
   stays the one accent (brand/entity). Users re-skin freely via
   Personalize (sunrise / ocean / orchid / coral / plum … intact).
   ─────────────────────────────────────────────────────────────── */
:root{
  --paper:#F7F7F8; --paper-warm:#F0F0F2; --bone:#EBEBED; --bone-deep:#E0E0E3;
  --ink:#17181B;
  --ink-1:#17181B;
  --ink-2:rgba(23,24,27,.62);
  --ink-3:rgba(23,24,27,.40);
  --line:rgba(23,24,27,.11);
  --line-2:rgba(23,24,27,.06);
  /* neutral elevation — drop the warm-ink bias */
  --shadow-1:0 1px 3px rgba(20,21,24,.06);
  --shadow-2:0 4px 10px -4px rgba(20,21,24,.05), 0 18px 36px -22px rgba(20,21,24,.20);
  --shadow-3:0 8px 18px -10px rgba(20,21,24,.08), 0 30px 60px -36px rgba(20,21,24,.28);
}

/* ─── gem ambient motion (theron-entity.js needs these) ─── */
@media (prefers-reduced-motion:no-preference){
 .th-rock{animation:th-rock 5.4s cubic-bezier(.22,1,.36,1) infinite;transform-box:fill-box;transform-origin:center;}
 .th-fc{animation:th-tw 3.8s cubic-bezier(.22,1,.36,1) infinite;}
 .th-sheen{animation:th-sheen 5.2s cubic-bezier(.22,1,.36,1) infinite;transform-box:fill-box;}
 .th-eye{animation:th-blink 5.2s ease-in-out infinite;transform-box:fill-box;transform-origin:center;}
}
@keyframes th-rock{0%,100%{transform:translateY(0) rotate(-2.4deg)}50%{transform:translateY(-2.2px) rotate(2.4deg)}}
@keyframes th-tw{0%,100%{opacity:.7}50%{opacity:1}}
@keyframes th-sheen{0%{transform:translateX(-36px) skewX(-18deg);opacity:0}14%{opacity:.85}42%{opacity:0}100%{transform:translateX(150px) skewX(-18deg);opacity:0}}
@keyframes th-blink{0%,93%,100%{transform:scaleY(1)}95.5%{transform:scaleY(.08)}98%{transform:scaleY(1)}}
.th-glow{display:none!important;}

html,body{height:100%;}
body{overflow:hidden;margin:0;background:var(--bg);color:var(--ink-1);
  font-family:var(--ff-ui);font-feature-settings:"ss01","tnum","cv11";
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  transition:background .5s var(--ease), color .5s var(--ease);}
svg{fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;}
::selection{background:var(--amber-glow);}
.no-select{user-select:none;-webkit-user-select:none;}

/* ============================================================
   THE ROOM — wallpaper: drifting brand auras + faint dot grid
   ============================================================ */
#room{position:fixed;inset:0;z-index:0;overflow:hidden;
  background:
    radial-gradient(125% 90% at 50% -14%, rgba(255,180,42,.06), transparent 56%),
    radial-gradient(90% 72% at 96% 2%, rgba(120,134,156,.05), transparent 52%),
    var(--paper);
  transition:background .6s var(--ease);}
/* fine grain + soft vignette — gives the glass something to refract, kills the flat wash */
#room::after{content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(120% 120% at 50% 30%, transparent 56%, rgba(60,42,12,.07) 100%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  background-size:auto, 180px 180px;
  mix-blend-mode:soft-light;opacity:.5;}
html[data-theme="dark"] #room::after{opacity:.7;
  background-image:
    radial-gradient(120% 120% at 50% 26%, transparent 50%, rgba(0,0,0,.5) 100%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");}
html[data-theme="dark"] #room{
  background:
    radial-gradient(58vw 60vh at 78% -6%, rgba(255,180,42,.16), transparent 58%),
    radial-gradient(50vw 52vh at 6% 108%, rgba(111,160,189,.13), transparent 62%),
    radial-gradient(40vw 44vh at 50% 50%, rgba(107,142,90,.06), transparent 70%),
    linear-gradient(168deg, #14110C, #0E0C09 60%, #0B0907);}
#room .grid{position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(var(--line-2) 1px, transparent 1px);
  background-size:30px 30px;
  -webkit-mask-image:radial-gradient(90% 86% at 50% 44%, #000, transparent 100%);
          mask-image:radial-gradient(90% 86% at 50% 44%, #000, transparent 100%);}
#room .blob{position:absolute;border-radius:50%;will-change:transform;filter:blur(8px);opacity:.7;}
#room .a1{width:46vw;height:52vh;top:-14vh;left:22vw;background:radial-gradient(circle,rgba(255,106,0,.16),transparent 64%);}
#room .a2{width:50vw;height:58vh;bottom:-22vh;left:-12vw;background:radial-gradient(circle,rgba(139,224,75,.16),transparent 64%);}
#room .a3{width:44vw;height:50vh;top:-12vh;right:-10vw;background:radial-gradient(circle,rgba(40,194,255,.18),transparent 64%);}
html[data-theme="dark"] #room .a1{background:radial-gradient(circle,rgba(255,180,42,.14),transparent 62%);}
html[data-theme="dark"] #room .a2{background:radial-gradient(circle,rgba(107,142,90,.12),transparent 62%);}
html[data-theme="dark"] #room .a3{background:radial-gradient(circle,rgba(111,160,189,.16),transparent 62%);}
@media (prefers-reduced-motion:no-preference){
  #room .a1{animation:roam1 34s var(--ease-inout) infinite;}
  #room .a2{animation:roam2 40s var(--ease-inout) infinite;}
  #room .a3{animation:roam3 30s var(--ease-inout) infinite;}
}
@keyframes roam1{0%,100%{transform:translate3d(0,0,0) scale(1);}50%{transform:translate3d(-7vw,6vh,0) scale(1.14);}}
@keyframes roam2{0%,100%{transform:translate3d(0,0,0) scale(1);}50%{transform:translate3d(8vw,-5vh,0) scale(1.1);}}
@keyframes roam3{0%,100%{transform:translate3d(0,0,0) scale(1);}50%{transform:translate3d(-6vw,7vh,0) scale(1.16);}}

/* ============================================================
   STAGE FLOW — frontdoor / boot / desktop
   ============================================================ */
#frontdoor,#desktop{position:fixed;inset:0;}
#frontdoor{z-index:30;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:0 24px 16vh;text-align:center;
  transition:opacity .6s var(--ease), transform .7s var(--ease), filter .6s var(--ease);}
body[data-stage="desktop"] #frontdoor{opacity:0;transform:translateY(-26px) scale(.965);filter:blur(7px);pointer-events:none;}

#desktop{z-index:10;opacity:0;pointer-events:none;transition:opacity .7s var(--ease);}
body[data-stage="desktop"] #desktop{opacity:1;pointer-events:auto;}

/* ─── FRONT DOOR ─── */
.fd-gem{display:inline-flex;line-height:0;position:relative;cursor:default;width:148px;height:148px;}
.fd-gem img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 18px 40px rgba(120,40,140,.34));pointer-events:none;-webkit-user-select:none;user-select:none;}
@media (prefers-reduced-motion:no-preference){.fd-gem{animation:fd-hover 6.5s var(--ease-inout) infinite;}}
@keyframes fd-hover{0%,100%{transform:translateY(0);}50%{transform:translateY(-13px);}}
.fd-phrase{position:relative;min-height:132px;width:min(820px,92vw);margin:26px 0 6px;display:flex;align-items:center;justify-content:center;}
.fd-line{font-family:var(--ff-display);font-weight:500;letter-spacing:-.022em;font-size:clamp(26px,3.6vw,42px);line-height:1.14;color:var(--ink-1);}
.fd-line .acc{font-family:var(--ff-serif);font-style:italic;font-weight:400;color:var(--accent-ink);letter-spacing:0;}
.fd-caret{display:inline-block;width:2.5px;height:.9em;background:var(--accent);border-radius:1.5px;margin-left:5px;vertical-align:-.08em;box-shadow:0 0 8px var(--amber-glow);}
@media (prefers-reduced-motion:no-preference){.fd-caret{animation:caretblink 1.05s steps(1) infinite;}}
@keyframes caretblink{0%,52%{opacity:1;}52.01%,100%{opacity:0;}}
.fd-sub{font-size:14.5px;color:var(--ink-2);max-width:54ch;margin:6px 0 0;line-height:1.5;}
.fd-sub .k{font-family:var(--ff-mono);font-size:12px;color:var(--ink-1);background:var(--code-bg);border:1px solid var(--line);border-radius:var(--r-sm);padding:2px 7px;}

/* front-door composer */
.fd-composer{margin-top:40px;width:min(640px,92vw);display:flex;align-items:center;gap:6px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-full);
  padding:8px 8px 8px 18px;box-shadow:var(--shadow-3);
  transition:border-color .25s var(--ease), box-shadow .3s var(--ease);}
.fd-composer.focused{border-color:color-mix(in srgb,var(--amber) 55%,var(--line));box-shadow:0 0 0 4px var(--amber-glow),var(--shadow-3);}
.fd-composer input{flex:1;min-width:0;border:0;outline:0;background:transparent;
  font-family:var(--ff-ui);font-size:16.5px;color:var(--ink-1);height:42px;line-height:42px;}
.fd-composer input::placeholder{color:var(--ink-3);}
.fd-enter{flex-shrink:0;position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:8px;height:42px;padding:0 18px;border:0;cursor:pointer;
  border-radius:var(--r-full);background:linear-gradient(180deg,var(--c-amber),var(--c-burn));color:#fff;font-family:var(--ff-ui);font-weight:700;font-size:14.5px;
  box-shadow:0 10px 24px -8px rgba(255,106,0,.55), inset 0 1px 0 rgba(255,255,255,.55);transition:transform .15s var(--ease), box-shadow .2s var(--ease);}
.fd-enter::before{content:"";position:absolute;left:8%;right:8%;top:3px;height:42%;border-radius:999px;background:var(--gloss-sheen);pointer-events:none;}
.fd-enter:hover{transform:translateY(-1px);box-shadow:0 10px 28px -10px var(--amber-glow);}
.fd-enter svg{width:16px;height:16px;}
.fd-quick{margin-top:22px;display:flex;flex-wrap:wrap;gap:9px;justify-content:center;max-width:680px;}
.fd-chip{font-family:var(--ff-ui);font-size:13.5px;color:var(--ink-2);white-space:nowrap;background:color-mix(in srgb,var(--surface) 64%,transparent);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:var(--r-full);padding:8px 15px;cursor:pointer;
  transition:border-color .15s, color .15s, transform .15s, background .15s;}
.fd-chip:hover{border-color:var(--ink-2);color:var(--ink-1);transform:translateY(-1px);}
.fd-corner{position:fixed;top:22px;right:24px;z-index:40;display:flex;align-items:center;gap:10px;}
.fd-brand{position:fixed;top:24px;left:28px;z-index:40;display:inline-flex;align-items:center;}
.fd-wordmark{height:22px;width:auto;display:block;}
.logo-light{display:block;} .logo-dark{display:none;}
html[data-theme="dark"] .logo-light{display:none;} html[data-theme="dark"] .logo-dark{display:block;}
body[data-stage="desktop"] .fd-corner{opacity:0;pointer-events:none;}
body[data-stage="desktop"] .fd-brand{display:none;}

/* ─── BOOT veil — the soft transition into the OS ─── */
#boot{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;flex-direction:column;gap:22px;
  background:color-mix(in srgb,var(--bg) 86%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);}
#boot.on{display:flex;animation:bootfade .4s var(--ease) both;}
#boot.off{animation:bootout .5s var(--ease) both;}
@keyframes bootfade{from{opacity:0;}to{opacity:1;}}
@keyframes bootout{from{opacity:1;}to{opacity:0;visibility:hidden;}}
#boot .bgem{line-height:0;width:104px;height:104px;}
#boot .bgem img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 12px 28px rgba(120,40,140,.34));}
@media (prefers-reduced-motion:no-preference){#boot .bgem{animation:bootrise 1.1s var(--ease) both;}}
@keyframes bootrise{0%{transform:translateY(14px) scale(.86);opacity:0;}100%{transform:translateY(0) scale(1);opacity:1;}}
#boot .bsteps{font-family:var(--ff-mono);font-size:12.5px;letter-spacing:.04em;color:var(--ink-2);height:20px;text-align:center;}
#boot .bsteps b{color:var(--accent-ink);font-weight:500;}
#boot .bbar{width:188px;height:3px;border-radius:var(--r-full);background:var(--line);overflow:hidden;}
#boot .bbar i{display:block;height:100%;width:0;background:var(--amber);border-radius:var(--r-full);box-shadow:var(--shadow-glow);transition:width .5s var(--ease);}

/* ============================================================
   MENUBAR — top OS chrome
   ============================================================ */
#menubar{position:fixed;top:0;left:0;right:0;z-index:90;height:40px;display:flex;align-items:center;gap:2px;}
body:not([data-stage="desktop"]) #menubar{opacity:0;transform:translateY(-100%);pointer-events:none;transition:opacity .45s var(--ease), transform .45s var(--ease);}
#menubar{
  padding:0 12px;background:color-mix(in srgb,var(--surface) 55%,transparent);
  -webkit-backdrop-filter:blur(28px) saturate(1.7);backdrop-filter:blur(28px) saturate(1.7);
  border-bottom:1px solid color-mix(in srgb,var(--line) 65%,transparent);
  box-shadow:0 1px 0 rgba(255,255,255,.4) inset, 0 8px 24px -18px rgba(20,14,4,.4);}
html[data-theme="dark"] #menubar{background:color-mix(in srgb,var(--surface) 50%,transparent);box-shadow:0 1px 0 rgba(255,255,255,.05) inset, 0 8px 24px -18px rgba(0,0,0,.5);}
.mb-logo{display:inline-flex;align-items:center;justify-content:center;height:30px;padding:0 9px;border:0;background:transparent;border-radius:8px;cursor:pointer;
  transition:background .15s;}
.mb-logo:hover{background:var(--surface-2);}
.mb-logo img{height:14px;width:auto;}
.mb-item{font-family:var(--ff-ui);font-size:13px;font-weight:500;color:var(--ink-1);padding:6px 11px;border-radius:7px;cursor:pointer;
  transition:background .14s, color .14s;white-space:nowrap;}
.mb-item:hover{background:var(--surface-2);}
.mb-space{display:inline-flex;align-items:center;gap:6px;font-family:var(--ff-ui);font-size:12.5px;font-weight:600;color:var(--ink-1);
  background:var(--surface-2);border:1px solid var(--line);padding:4px 9px 4px 7px;border-radius:8px;cursor:pointer;white-space:nowrap;
  transition:background .14s, border-color .14s, transform .12s;}
.mb-space:hover{background:var(--surface);border-color:color-mix(in srgb,var(--accent) 40%,var(--line));}
.mb-space:active{transform:scale(.96);}
.mb-space svg{width:13px;height:13px;}
.mb-space svg:last-child{width:11px;height:11px;opacity:.5;margin-left:-2px;}
body[data-device="phone"] #mb-space{display:none;}
.mb-item.strong{font-weight:600;}
.mb-item.muted{color:var(--ink-2);font-weight:500;}
.mb-sep{width:1px;height:18px;background:var(--line);margin:0 6px;}
.mb-spacer{flex:1;}
.mb-right{display:flex;align-items:center;gap:4px;}
.mb-pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--ff-mono);font-size:11px;font-weight:500;
  letter-spacing:.04em;color:var(--ok);background:var(--ok-soft);border:1px solid color-mix(in srgb,var(--ok) 40%,transparent);
  border-radius:var(--r-full);padding:4px 11px;cursor:pointer;transition:transform .15s;white-space:nowrap;}
.mb-pill:hover{transform:translateY(-1px);}
.mb-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--ok);position:relative;}
.mb-pill .dot::after{content:'';position:absolute;inset:-3px;border-radius:50%;background:var(--ok);opacity:.2;}
@media (prefers-reduced-motion:no-preference){.mb-pill .dot::after{animation:ping 2.6s var(--ease) infinite;}}
@keyframes ping{0%,100%{transform:scale(.7);opacity:.24;}50%{transform:scale(1.6);opacity:0;}}
.mb-kbtn{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;font-family:var(--ff-ui);font-size:12.5px;color:var(--ink-2);
  background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-full);padding:5px 9px 5px 12px;cursor:pointer;
  transition:border-color .15s, color .15s;}
.mb-kbtn:hover{border-color:var(--ink-2);color:var(--ink-1);}
.mb-kbtn svg{width:14px;height:14px;}
.mb-kbtn .kbd{font-family:var(--ff-mono);font-size:10.5px;color:var(--ink-3);border:1px solid var(--line);border-radius:4px;padding:1px 5px;}
.mb-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--ink-2);cursor:pointer;
  transition:background .14s, color .14s;background:transparent;border:0;}
.mb-icon:hover{background:var(--surface-2);color:var(--ink-1);}
.mb-icon svg{width:16px;height:16px;}
.mb-icon .sun{display:none;}html[data-theme="dark"] .mb-icon .sun{display:block;}html[data-theme="dark"] .mb-icon .moon{display:none;}
.mb-clock{font-family:var(--ff-mono);font-size:12px;color:var(--ink-1);padding:0 8px;letter-spacing:.02em;white-space:nowrap;}
.mb-status{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 9px;border:0;background:transparent;border-radius:8px;cursor:pointer;color:var(--ink-1);transition:background .14s;}
.mb-status:hover,.mb-status.on{background:var(--surface-2);}
.mb-status svg{width:16px;height:16px;}

/* ══════ Control Center ══════ */
#control-center{position:fixed;top:46px;right:10px;z-index:200;width:320px;padding:14px;border-radius:22px;
  background:color-mix(in srgb,var(--surface) 78%,transparent);
  -webkit-backdrop-filter:blur(30px) saturate(1.7);backdrop-filter:blur(30px) saturate(1.7);
  border:1px solid color-mix(in srgb,var(--line) 70%,transparent);
  box-shadow:0 1px 0 rgba(255,255,255,.5) inset, 0 24px 60px -24px rgba(120,40,140,.4);
  opacity:0;transform:translateY(-10px) scale(.97);transform-origin:top right;pointer-events:none;
  transition:opacity .2s var(--ease), transform .24s var(--bounce);}
#control-center.on{opacity:1;transform:none;pointer-events:auto;}
.cc-head{display:flex;align-items:baseline;justify-content:space-between;padding:2px 4px 12px;}
.cc-title{font-family:var(--ff-display);font-weight:800;font-size:15px;letter-spacing:-.02em;}
.cc-date{font-family:var(--ff-mono);font-size:11px;color:var(--ink-3);}
.cc-tiles{display:grid;grid-template-columns:1fr 1fr;gap:9px;}
.cc-tile{position:relative;display:flex;flex-direction:column;gap:3px;align-items:flex-start;text-align:left;
  border:1px solid var(--line);border-radius:15px;padding:12px 13px;background:var(--surface);cursor:pointer;
  transition:transform .14s var(--bounce), box-shadow .18s, border-color .15s;overflow:hidden;}
.cc-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-2);}
.cc-tile b{font-size:13px;font-weight:700;letter-spacing:-.01em;color:var(--ink-1);}
.cc-tile i{font-style:normal;font-family:var(--ff-mono);font-size:10.5px;color:var(--ink-3);}
.cc-tile .cc-d{width:24px;height:24px;border-radius:8px;margin-bottom:5px;background:var(--surface-2);box-shadow:inset 0 1px 0 rgba(255,255,255,.5);}
.cc-tile[data-cc-toggle="theme"] .cc-d{background:linear-gradient(165deg,var(--c-amber),var(--c-burn));}
.cc-tile[data-cc-toggle="follow"] .cc-d{background:linear-gradient(165deg,#C08CFF,var(--c-plum));}
.cc-tile[data-cc-toggle="dnd"] .cc-d{background:linear-gradient(165deg,#FF8AA6,var(--c-coral));}
.cc-tile[data-cc-toggle="proof"] .cc-d{background:linear-gradient(165deg,#AEEB6E,#5FC72B);}
.cc-tile.active{border-color:transparent;color:#fff;}
.cc-tile.active b{color:#fff;} .cc-tile.active i{color:rgba(255,255,255,.82);}
.cc-tile[data-cc-toggle="theme"].active{background:linear-gradient(165deg,var(--c-amber),var(--c-burn));}
.cc-tile[data-cc-toggle="follow"].active{background:linear-gradient(165deg,#C08CFF,var(--c-plum));}
.cc-tile[data-cc-toggle="dnd"].active{background:linear-gradient(165deg,#FF8AA6,var(--c-coral));}
.cc-tile[data-cc-toggle="proof"].active{background:linear-gradient(165deg,#AEEB6E,#5FC72B);}
.cc-tile.active .cc-d{background:rgba(255,255,255,.3);}
.cc-tile.big{grid-column:span 2;flex-direction:row;align-items:center;gap:11px;}
.cc-tile.big .cc-ic{width:38px;height:38px;flex-shrink:0;}
.cc-tile.big .cc-ic img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(120,40,140,.35));}
.cc-tile.big .cc-tl{display:flex;flex-direction:column;gap:2px;}
.cc-sub{font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);padding:16px 4px 9px;}
.cc-notes{display:flex;flex-direction:column;gap:7px;max-height:230px;overflow:auto;}
.cc-note{display:flex;gap:10px;align-items:flex-start;padding:11px 12px;border-radius:13px;background:var(--surface);border:1px solid var(--line-2);}
.cc-note .cn-ic{width:28px;height:28px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;color:#fff;}
.cc-note .cn-ic svg{width:15px;height:15px;}
.cc-note .cn-m{flex:1;min-width:0;}
.cc-note .cn-t{font-size:12.5px;font-weight:600;color:var(--ink-1);line-height:1.35;}
.cc-note .cn-s{font-family:var(--ff-mono);font-size:10.5px;color:var(--ink-3);margin-top:2px;}
.cc-note .cn-time{font-family:var(--ff-mono);font-size:10px;color:var(--ink-3);white-space:nowrap;}
.cc-empty{text-align:center;color:var(--ink-3);font-size:12.5px;padding:20px;}
@media(max-width:640px){#control-center{right:6px;left:6px;width:auto;}}

/* menubar dropdown */
.mb-menu{position:fixed;top:42px;z-index:200;min-width:240px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-md);box-shadow:var(--shadow-3);padding:6px;display:none;animation:menupop .16s var(--ease-soft) both;}
.mb-menu.on{display:block;}
@keyframes menupop{from{opacity:0;transform:translateY(-6px) scale(.98);}to{opacity:1;transform:none;}}
.mb-menu .mrow{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:7px;cursor:pointer;white-space:nowrap;
  font-family:var(--ff-ui);font-size:13.5px;color:var(--ink-1);transition:background .12s;}
.mb-menu .mrow:hover{background:var(--surface-2);}
.mb-menu .mrow svg{width:16px;height:16px;color:var(--ink-2);flex-shrink:0;}
.mb-menu .mrow .mk{margin-left:auto;font-family:var(--ff-mono);font-size:11px;color:var(--ink-3);}
.mb-menu .mrow .msub{font-size:12px;color:var(--ink-3);}
.mb-menu .mdiv{height:1px;background:var(--line-2);margin:5px 4px;}
.mb-menu .mhead{font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);padding:8px 11px 5px;}

/* ============================================================
   WINDOWS
   ============================================================ */
#winlayer{position:fixed;inset:0;z-index:40;pointer-events:none;}
.win{position:absolute;pointer-events:auto;display:flex;flex-direction:column;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-3);transition:box-shadow .25s var(--ease), border-color .2s var(--ease);
  animation:winopen .42s var(--ease-soft) both;will-change:transform;}
@keyframes winopen{from{opacity:0;transform:translateY(18px) scale(.95);}to{opacity:1;transform:none;}}
.win.closing{animation:winclose .26s var(--ease) both;pointer-events:none;}
@keyframes winclose{to{opacity:0;transform:translateY(10px) scale(.96);}}
.win.minimizing{animation:winmin .34s var(--ease) both;pointer-events:none;}
@keyframes winmin{to{opacity:0;transform:translateY(40vh) scale(.4);}}
.win.focused{box-shadow:0 0 0 1px color-mix(in srgb,var(--amber) 26%,transparent),var(--shadow-3);}
.win:not(.focused){box-shadow:var(--shadow-2);}
.win:not(.focused) .win-bar{opacity:.78;}
.win.maximized{border-radius:0;border:0;}

.win-bar{display:flex;align-items:center;gap:10px;height:44px;padding:0 12px 0 14px;cursor:grab;user-select:none;
  border-bottom:1px solid var(--line-2);flex-shrink:0;background:color-mix(in srgb,var(--surface) 92%,transparent);}
.win-bar:active{cursor:grabbing;}
.win-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 3px color-mix(in srgb,currentColor 20%,transparent);}
.win-title{font-family:var(--ff-display);font-size:14px;font-weight:600;letter-spacing:-.01em;color:var(--ink-1);white-space:nowrap;flex-shrink:0;}
.win-sub{font-family:var(--ff-mono);font-size:11px;color:var(--ink-3);letter-spacing:.04em;white-space:nowrap;flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;}
.win-bar .sp{flex:1;}
.win-ctl{display:flex;align-items:center;gap:2px;}
.win-cbtn{width:28px;height:28px;border-radius:7px;border:0;background:transparent;color:var(--ink-3);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .14s, color .14s;}
.win-cbtn:hover{background:var(--surface-2);color:var(--ink-1);}
.win-cbtn.close:hover{background:var(--bad-soft);color:var(--bad);}
.win-cbtn svg{width:15px;height:15px;}
.win-body{flex:1;min-height:0;overflow:auto;position:relative;}
.win-body::-webkit-scrollbar{width:9px;height:9px;}
.win-body::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px;border:2px solid var(--surface);}
.win-body::-webkit-scrollbar-thumb:hover{background:var(--ink-3);}
.win-resize{position:absolute;right:0;bottom:0;width:18px;height:18px;cursor:nwse-resize;z-index:5;}
.win-resize::after{content:'';position:absolute;right:4px;bottom:4px;width:7px;height:7px;
  border-right:1.5px solid var(--ink-3);border-bottom:1.5px solid var(--ink-3);border-radius:0 0 2px 0;opacity:.6;}

/* ============================================================
   DOCK
   ============================================================ */
#dock{position:fixed;left:50%;bottom:14px;transform:translateX(-50%);z-index:95;
  display:flex;align-items:flex-end;gap:7px;padding:8px;
  background:color-mix(in srgb,var(--surface) 70%,transparent);
  -webkit-backdrop-filter:blur(22px) saturate(1.5);backdrop-filter:blur(22px) saturate(1.5);
  border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-3);}
body:not([data-stage="desktop"]) #dock{opacity:0;transform:translateX(-50%) translateY(20px);pointer-events:none;}
.dock-app{position:relative;width:46px;height:46px;border-radius:12px;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;color:#fff;
  transition:transform .2s var(--ease), margin .2s var(--ease);transform-origin:bottom center;}
.dock-app:hover{transform:translateY(-9px) scale(1.16);}
.dock-app:hover + .dock-app{transform:scale(1.05);}
.dock-app svg{width:23px;height:23px;stroke-width:1.7;}
.dock-app .run{position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;
  background:var(--ink-2);opacity:0;transition:opacity .2s;}
.dock-app.running .run{opacity:1;}
.dock-app .tip{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(4px);
  font-family:var(--ff-ui);font-size:12.5px;font-weight:500;color:var(--ink-1);white-space:nowrap;
  background:var(--surface);border:1px solid var(--line);border-radius:7px;padding:5px 10px;box-shadow:var(--shadow-2);
  opacity:0;pointer-events:none;transition:opacity .16s var(--ease), transform .16s var(--ease);}
.dock-app:hover .tip{opacity:1;transform:translateX(-50%) translateY(0);}
.dock-app .tip .ts{color:var(--ink-3);font-family:var(--ff-mono);font-size:10.5px;margin-left:6px;}
.dock-div{width:1px;align-self:center;height:30px;background:var(--line);margin:0 3px;}

/* product colors for icons (rounded-square fills) — candy palette, matches the dock */
.ic-home{background:linear-gradient(160deg,#FFD27A,#FF9E2C 72%);color:#5a3000;}
.ic-workspace{background:linear-gradient(165deg,#C08CFF,#8A4FD0 72%);color:#fff;}
.ic-hive{background:linear-gradient(165deg,#AEEB6E,#5FC72B 72%);color:#16330a;}
.ic-ledger{background:linear-gradient(165deg,#6FD4FF,#2BA4E0 72%);color:#06283a;}
.ic-lens{background:linear-gradient(165deg,#C08CFF,#9B6FE0 72%);color:#fff;}
.ic-settings{background:linear-gradient(165deg,#FF8AA6,#F0577E 72%);color:#fff;}
html[data-theme="dark"] .ic-workspace{background:linear-gradient(165deg,#B27BF0,#7A42C0 72%);}
html[data-theme="dark"] .ic-lens{background:linear-gradient(165deg,#B27BF0,#8A5FD0 72%);color:#fff;}

/* ============================================================
   COMMAND BAR — Cmd-K / summon Theron
   ============================================================ */
#cmd{position:fixed;inset:0;z-index:210;display:none;align-items:flex-start;justify-content:center;
  padding-top:16vh;background:color-mix(in srgb,var(--bg) 50%,transparent);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);}
#cmd.on{display:flex;animation:bootfade .2s var(--ease) both;}
.cmd-box{width:min(620px,92vw);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);
  box-shadow:var(--shadow-3);overflow:hidden;animation:cmdpop .26s var(--ease-soft) both;}
@keyframes cmdpop{from{opacity:0;transform:translateY(-14px) scale(.97);}to{opacity:1;transform:none;}}
.cmd-top{display:flex;align-items:center;gap:13px;padding:15px 18px;border-bottom:1px solid var(--line-2);}
.cmd-top .cg{line-height:0;flex-shrink:0;}
.cmd-top input{flex:1;border:0;outline:0;background:transparent;font-family:var(--ff-ui);font-size:18px;color:var(--ink-1);}
.cmd-top input::placeholder{color:var(--ink-3);}
.cmd-top .esc{font-family:var(--ff-mono);font-size:10.5px;color:var(--ink-3);border:1px solid var(--line);border-radius:5px;padding:3px 7px;}
.cmd-list{max-height:46vh;overflow:auto;padding:7px;}
.cmd-head{font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);padding:9px 11px 5px;}
.cmd-row{display:flex;align-items:center;gap:13px;padding:10px 12px;border-radius:9px;cursor:pointer;transition:background .12s;}
.cmd-row.sel,.cmd-row:hover{background:var(--surface-2);}
.cmd-ic{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;}
.cmd-ic svg{width:17px;height:17px;}
.cmd-ic.ask{background:var(--amber-glow);color:var(--accent-ink);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--amber) 50%,transparent);}
.cmd-meta{flex:1;min-width:0;}
.cmd-meta .ct{font-family:var(--ff-ui);font-size:14.5px;font-weight:500;color:var(--ink-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cmd-meta .cs{font-size:12.5px;color:var(--ink-2);margin-top:1px;}
.cmd-row .cgo{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.cmd-foot{display:flex;align-items:center;gap:16px;padding:10px 16px;border-top:1px solid var(--line-2);
  font-family:var(--ff-mono);font-size:11px;color:var(--ink-3);}
.cmd-foot .kk{border:1px solid var(--line);border-radius:4px;padding:1px 5px;color:var(--ink-2);margin-right:5px;}

/* ============================================================
   FILES-IN-FOCUS RAIL — per-space working set
   ============================================================ */
#focusrail{position:fixed;right:16px;top:54px;z-index:60;width:188px;display:flex;flex-direction:column;gap:5px;
  padding:9px;border-radius:16px;opacity:0;transform:translateX(16px);pointer-events:none;
  background:color-mix(in srgb,var(--surface) 78%,transparent);
  -webkit-backdrop-filter:blur(22px) saturate(1.5);backdrop-filter:blur(22px) saturate(1.5);
  border:1px solid var(--line);box-shadow:var(--shadow-2);
  transition:opacity .3s var(--ease), transform .3s var(--ease);}
#focusrail.show{opacity:1;transform:none;pointer-events:auto;}
body:not([data-stage="desktop"]) #focusrail{display:none;}
.fr-h{display:flex;align-items:center;gap:6px;padding:3px 6px 6px;font-family:var(--ff-mono);font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-3);border-bottom:1px solid var(--line-2);margin-bottom:2px;}
.fr-h svg{width:12px;height:12px;color:var(--accent-ink);}
.fr-h em{margin-left:auto;font-style:normal;color:var(--accent-ink);font-weight:600;}
.fr-item{display:flex;align-items:center;gap:8px;width:100%;border:0;background:transparent;cursor:pointer;border-radius:9px;padding:6px 7px;text-align:left;transition:background .14s;}
.fr-item:hover{background:var(--surface-2);}
.fr-ic{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;color:#fff;flex-shrink:0;}
.fr-ic svg{width:12px;height:12px;}
.fr-n{flex:1;min-width:0;font-family:var(--ff-ui);font-size:12px;color:var(--ink-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.fr-x{width:16px;height:16px;flex-shrink:0;display:grid;place-items:center;color:var(--ink-3);border-radius:5px;opacity:0;transition:opacity .14s, color .14s, background .14s;}
.fr-x svg{width:11px;height:11px;}
.fr-item:hover .fr-x{opacity:1;}
.fr-x:hover{background:var(--bad-soft);color:var(--bad);}
@media (max-width:900px){ #focusrail{display:none!important;} }

/* ============================================================
   TOUR VIDEO — clean cinematic chrome around the live walkthrough
   ============================================================ */
body.tour-video #chatbar,
body.tour-video #focusrail,
body.tour-video .help-menu,
body.tour-video #compsay,
body.tour-video #ccpanel{ display:none !important; }
#tourvid{ position:fixed; inset:0; z-index:140; pointer-events:none; }
#tourvid .tv-bars{ position:fixed; inset:0; pointer-events:none;
  box-shadow: inset 0 0 220px 40px rgba(20,10,30,.34); }      /* soft cinematic vignette */
#tourvid .tv-prog{ position:fixed; left:0; right:0; bottom:0; height:4px; background:rgba(0,0,0,.12); opacity:0; transition:opacity .4s; }
#tourvid .tv-prog.show{ opacity:1; }
#tourvid .tv-prog i{ display:block; height:100%; width:0;
  background:linear-gradient(90deg,#FFD27A,#FF7A2C 60%,#FF4F9A); box-shadow:0 0 12px rgba(255,122,44,.6); }
/* big video-style caption card (replaces the tiny companion bubble during the tour) */
#tourvid .tv-lower{ position:fixed; left:50%; bottom:46px; transform:translateX(-50%) translateY(14px);
  display:flex; align-items:center; gap:13px; max-width:min(760px,86vw);
  font-family:var(--ff-ui); font-size:21px; line-height:1.4; font-weight:600; color:#fff; letter-spacing:-.01em;
  background:linear-gradient(180deg, rgba(34,20,46,.86), rgba(20,12,30,.92));
  backdrop-filter:blur(16px) saturate(1.2); border:1px solid rgba(255,255,255,.16);
  padding:16px 24px 16px 18px; border-radius:20px;
  box-shadow:0 1px 0 rgba(255,255,255,.12) inset, 0 24px 60px rgba(20,10,30,.5), 0 0 0 1px rgba(255,122,44,.12);
  opacity:0; visibility:hidden; transition:opacity .45s cubic-bezier(.2,.9,.3,1), transform .45s cubic-bezier(.2,.9,.3,1); }
#tourvid .tv-lower.show{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
#tourvid .tvc-av{ flex-shrink:0; line-height:0; filter:drop-shadow(0 4px 10px var(--amber-glow));
  animation:tvFloat 3.4s ease-in-out infinite; }
#tourvid .tvc-who{ flex-shrink:0; align-self:flex-start; margin-top:3px; font-family:var(--ff-mono); font-size:11px; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase; color:var(--amber); }
#tourvid .tvc-txt{ text-wrap:pretty; }
#tourvid .tvc-txt b{ color:#FFD27A; font-weight:700; }
@media (max-width:640px){ #tourvid .tv-lower{ font-size:17px; bottom:24px; padding:13px 18px; } }
/* poster */
#tourvid .tv-poster{ position:fixed; inset:0; pointer-events:auto; display:grid; place-items:center;
  background:radial-gradient(120% 120% at 50% 30%, rgba(255,236,212,.5), rgba(28,18,38,.86) 70%);
  backdrop-filter:blur(8px); transition:opacity .5s ease, visibility .5s; }
html[data-theme="dark"] #tourvid .tv-poster{ background:radial-gradient(120% 120% at 50% 30%, rgba(60,30,70,.5), rgba(10,8,16,.9) 70%); }
#tourvid .tv-poster.gone{ opacity:0; visibility:hidden; }
#tourvid .tv-card{ text-align:center; max-width:440px; padding:0 28px; animation:tvPop .5s cubic-bezier(.2,.9,.3,1.2) both; }
@keyframes tvPop{ from{ opacity:0; transform:translateY(10px) scale(.96); } to{ opacity:1; transform:none; } }
#tourvid .tv-gem{ display:inline-block; filter:drop-shadow(0 14px 30px var(--amber-glow)); margin-bottom:18px; line-height:0;
  animation:tvFloat 4s ease-in-out infinite; }
@keyframes tvFloat{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-7px); } }
#tourvid .tv-kicker{ font-family:var(--ff-mono); font-size:12px; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--amber); }
#tourvid .tv-title{ font-family:var(--ff-display,var(--ff-ui)); font-size:38px; font-weight:800; letter-spacing:-.02em; color:#fff; margin:6px 0 10px; }
html[data-theme="light"] #tourvid .tv-title{ color:#1a1020; }
#tourvid .tv-sub{ font-family:var(--ff-ui); font-size:15.5px; line-height:1.55; color:rgba(255,255,255,.82); margin-bottom:24px; text-wrap:pretty; }
html[data-theme="light"] #tourvid .tv-sub{ color:#5a4a66; }
#tourvid .tv-play{ display:inline-flex; align-items:center; gap:10px; font-family:var(--ff-ui); font-size:15.5px; font-weight:700; color:#5a2a00;
  background:linear-gradient(180deg,#FFD27A,#FF9E2C 72%); border:1px solid rgba(255,255,255,.4); border-radius:999px;
  padding:13px 26px; cursor:pointer; box-shadow:0 2px 0 rgba(255,255,255,.5) inset, 0 12px 30px rgba(255,122,44,.4); transition:transform .15s, box-shadow .2s; }
#tourvid .tv-play:hover{ transform:translateY(-2px); box-shadow:0 2px 0 rgba(255,255,255,.6) inset, 0 16px 40px rgba(255,122,44,.5); }
#tourvid .tv-play:active{ transform:scale(.97); }
#tourvid .tv-play svg{ fill:#5a2a00; }

/* ============================================================
   COMPANION — floating Theron
   ============================================================ */
#companion{position:fixed;right:22px;bottom:78px;z-index:88;line-height:0;cursor:pointer;  filter:drop-shadow(0 10px 22px var(--amber-glow));
  transition:opacity .5s var(--ease) .3s, transform .3s var(--ease);}
body:not([data-stage="desktop"]) #companion{opacity:0;transform:translateY(16px) scale(.8);pointer-events:none;}
#companion:hover{transform:translateY(-3px);}
@media (prefers-reduced-motion:no-preference){#companion{animation:comp-float 6s var(--ease-inout) infinite;}}
@keyframes comp-float{0%,100%{transform:translateY(0);}50%{transform:translateY(-7px);}}
#compgem{display:inline-block;transform-origin:50% 82%;width:60px;height:60px;}
#compgem img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 8px 16px rgba(120,40,140,.34));pointer-events:none;-webkit-user-select:none;user-select:none;}
#compgem.pop{animation:gem-pop .55s var(--ease);}
@keyframes gem-pop{0%{transform:scale(1) rotate(0);}34%{transform:scale(.84) rotate(-6deg);}68%{transform:scale(1.07) rotate(5deg);}100%{transform:scale(1) rotate(0);}}
.comp-say{position:absolute;right:calc(100% + 14px);bottom:14px;width:max-content;max-width:300px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);border-bottom-right-radius:var(--r-sm);
  box-shadow:var(--shadow-3);padding:13px 16px;opacity:0;transform:translateX(8px) scale(.96);transform-origin:right bottom;
  pointer-events:none;transition:opacity .3s var(--ease), transform .3s var(--ease);}
.comp-say.show{opacity:1;transform:none;pointer-events:auto;}
.comp-say .cst{font-family:var(--ff-serif);font-style:italic;font-size:16px;line-height:1.4;color:var(--ink-1);}
.comp-say .csa{display:flex;gap:9px;margin-top:12px;}
.comp-say .csbtn{font-family:var(--ff-ui);font-size:12.5px;font-weight:600;border-radius:var(--r-full);padding:7px 13px;cursor:pointer;border:1px solid transparent;background:transparent;white-space:nowrap;transition:transform .14s, border-color .14s, background .14s;}
.comp-say .csbtn.go{background:var(--amber);color:#1A1100;box-shadow:var(--shadow-glow);}
.comp-say .csbtn.go:hover{transform:translateY(-1px);}
.comp-say .csbtn.no{color:var(--ink-2);border-color:var(--line);background:var(--surface-2);}
.comp-say .csbtn.no:hover{color:var(--ink-1);border-color:var(--ink-2);}
.comp-say .csx{position:absolute;top:8px;right:9px;color:var(--ink-3);cursor:pointer;display:inline-flex;}
.comp-say .csx svg{width:13px;height:13px;}

/* ─── toast ─── */
#toast{position:fixed;left:50%;bottom:84px;transform:translateX(-50%) translateY(10px);z-index:230;
  background:var(--ink-1);color:var(--bg);font-family:var(--ff-ui);font-size:13.5px;font-weight:500;
  padding:11px 19px;border-radius:var(--r-full);box-shadow:var(--shadow-3);opacity:0;pointer-events:none;
  display:inline-flex;align-items:center;gap:9px;transition:opacity .3s var(--ease), transform .3s var(--ease);max-width:80vw;}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
#toast svg{width:16px;height:16px;color:var(--ok);}

/* generic small chip for in-window use */
.chip-mono{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff-mono);font-size:12px;color:var(--ink-1);
  background:var(--code-bg);border:1px solid var(--line);border-radius:var(--r-sm);padding:7px 11px;}
.chip-mono .pr{color:var(--ink-3);}
.chip-mono .cp{margin-left:2px;color:var(--ink-3);cursor:pointer;display:inline-flex;}
.chip-mono .cp:hover{color:var(--ink-1);}
.chip-mono .cp svg{width:13px;height:13px;}

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

/* ============================================================
   v2 — chat-first OS: left rail · chat bar · following companion
   ============================================================ */
.ic-chat{background:linear-gradient(160deg,#FFD27A,#FF9E2C 72%);color:#5a3000;}
.ic-files{background:linear-gradient(160deg,#C8A0D2,#9B6FA8 72%);color:#fff;}
.ic-studio{background:linear-gradient(160deg,#7FC8B0,#3F9B86 72%);color:#06291f;}
.ic-terminal{background:linear-gradient(160deg,#3A3550,#1A1726 72%);color:#9BE8C8;}
html[data-theme="dark"] .ic-studio{background:linear-gradient(160deg,#6FBFA6,#358977 72%);}
html[data-theme="dark"] .ic-files{background:linear-gradient(160deg,#B98FC6,#8A5E97 72%);}
html[data-theme="dark"] .ic-chat{background:linear-gradient(160deg,#FFC658,#F08A1E 72%);color:#3a2200;}

/* dock → refined vertical left rail */
#dock{left:16px;top:50%;right:auto;bottom:auto;transform:translateY(-50%);flex-direction:column;align-items:center;gap:5px;
  padding:8px 7px;border-radius:20px;
  background:linear-gradient(180deg, color-mix(in srgb,var(--surface) 70%,transparent), color-mix(in srgb,var(--surface) 58%,transparent));
  -webkit-backdrop-filter:blur(30px) saturate(1.7);backdrop-filter:blur(30px) saturate(1.7);
  border:1px solid color-mix(in srgb,var(--line) 60%,transparent);
  box-shadow:0 1px 0 rgba(255,255,255,.5) inset, 0 1px 2px rgba(20,14,4,.06), 0 22px 50px -24px rgba(20,14,4,.4);}
html[data-theme="dark"] #dock{background:linear-gradient(180deg, color-mix(in srgb,#fff 8%,transparent), color-mix(in srgb,#fff 4%,transparent));box-shadow:0 1px 0 rgba(255,255,255,.08) inset, 0 22px 50px -24px rgba(0,0,0,.6);}
body:not([data-stage="desktop"]) #dock{opacity:0;transform:translateY(-50%) translateX(-22px);pointer-events:none;transition:opacity .3s var(--ease), transform .3s var(--ease);}
.dock-app{width:42px;height:42px;border-radius:13px;transform-origin:left center;
  box-shadow:0 1px 0 rgba(255,255,255,.18) inset, var(--shadow-1);transition:transform .18s var(--ease), box-shadow .18s var(--ease);}
/* ── unified dock material — one system, monochrome glyphs, amber only when active ── */
#dock .dock-app{background:color-mix(in srgb,var(--surface-2) 58%,transparent);color:var(--ink-2);
  border:1px solid color-mix(in srgb,var(--line) 60%,transparent);
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset;}
#dock .dock-app svg{width:21px;height:21px;stroke-width:1.75;transition:color .16s var(--ease);}
#dock .dock-app:hover{background:color-mix(in srgb,var(--surface-2) 92%,transparent);color:var(--ink-1);
  box-shadow:0 1px 0 rgba(255,255,255,.4) inset, var(--shadow-2);}
#dock .dock-app.running{color:var(--ink-1);}
#dock .dock-app.focused-app{color:#fff;
  background:linear-gradient(165deg, color-mix(in srgb,var(--amber) 92%,#fff), var(--amber));
  border-color:transparent;}
/* active tile fills with the glyph's OWN candy color */
#dock [data-dock="chat"].focused-app{background:linear-gradient(165deg,#FF8AA6,var(--c-coral));}
#dock [data-dock="home"].focused-app{background:linear-gradient(165deg,var(--c-amber),var(--c-burn));}
#dock [data-dock="files"].focused-app{background:linear-gradient(165deg,#C08CFF,var(--c-plum));}
#dock [data-dock="workspace"].focused-app{background:linear-gradient(165deg,var(--c-plum),var(--c-grape));}
#dock [data-dock="hive"].focused-app{background:linear-gradient(165deg,#AEEB6E,#5FC72B);}
#dock [data-dock="ledger"].focused-app{background:linear-gradient(165deg,#6FD4FF,var(--c-sky));}
#dock [data-dock="lens"].focused-app{background:linear-gradient(165deg,#C08CFF,var(--c-plum));}
#dock [data-dock="studio"].focused-app{background:linear-gradient(165deg,#7FC8B0,#3F9B86);}
#dock [data-dock="terminal"].focused-app{background:linear-gradient(165deg,#4A4468,#1A1726);}
#dock [data-dock="settings"].focused-app{background:linear-gradient(165deg,#FF8AA6,var(--c-coral));}
#dock .dock-app.focused-app{
  box-shadow:0 1px 0 rgba(255,255,255,.5) inset, 0 4px 14px -4px var(--amber-glow), 0 0 0 1px color-mix(in srgb,var(--amber) 40%,transparent);}
html[data-theme="dark"] #dock .dock-app{background:color-mix(in srgb,#fff 7%,transparent);border-color:color-mix(in srgb,#fff 9%,transparent);box-shadow:0 1px 0 rgba(255,255,255,.07) inset;}
html[data-theme="dark"] #dock .dock-app:hover{background:color-mix(in srgb,#fff 13%,transparent);}
.dock-app svg{width:20px;height:20px;}
.dock-app:hover{transform:translateX(4px) scale(1.07);}
.dock-app:hover + .dock-app{transform:none;}
.dock-app:active{transform:scale(.94);}
/* running = soft outer ring · focused = amber edge bar */
.dock-app .run{position:absolute;left:-7px;top:50%;bottom:auto;transform:translateY(-50%) scaleY(.4);width:3px;height:18px;border-radius:3px;
  background:var(--ink-3);opacity:0;transition:opacity .2s var(--ease), transform .2s var(--ease);}
.dock-app.running .run{opacity:.7;transform:translateY(-50%) scaleY(1);}
.dock-app.focused-app .run{opacity:1;background:currentColor;}
.dock-app.focused-app{box-shadow:0 6px 16px -6px rgba(120,40,140,.3), var(--shadow-1);}
.dock-app .tip{bottom:auto;left:calc(100% + 14px);top:50%;transform:translateX(-4px) translateY(-50%);
  display:flex;flex-direction:column;gap:1px;align-items:flex-start;}
.dock-app:hover .tip{transform:translateX(0) translateY(-50%);}
.dock-app .tip .ts{margin-left:0;}
.dock-div{width:22px;height:1px;align-self:center;margin:4px 0;background:var(--line);}
/* candy-tinted dock glyphs per app — vibrant but unified frosted tiles */
#dock [data-dock="chat"] svg{color:var(--c-coral);}
#dock [data-dock="home"] svg{color:var(--c-burn);}
#dock [data-dock="files"] svg{color:var(--c-plum);}
#dock [data-dock="workspace"] svg{color:var(--c-grape);}
#dock [data-dock="hive"] svg{color:var(--c-lime);}
#dock [data-dock="ledger"] svg{color:var(--c-sky);}
#dock [data-dock="lens"] svg{color:var(--c-plum);}
#dock [data-dock="studio"] svg{color:#3F9B86;}
#dock [data-dock="terminal"] svg{color:#6E63A8;}
#dock [data-dock="settings"] svg{color:var(--c-coral);}
#dock .dock-app.focused-app svg{color:#fff!important;}
.dock-gem{width:48px;height:48px;border:0;background:transparent;cursor:pointer;line-height:0;display:grid;place-items:center;flex-shrink:0;
  border-radius:13px;transition:transform .18s var(--ease), background .18s;filter:drop-shadow(0 2px 7px var(--amber-glow));}
.dock-gem:hover{transform:scale(1.12) translateX(2px);background:var(--surface-2);}
.dock-gem:active{transform:scale(.95);}

/* persistent chat bar */
#chatbar{position:fixed;left:calc(50% + 32px);bottom:46px;transform:translateX(-50%);z-index:96;
  width:min(660px,calc(100vw - 150px));display:flex;align-items:flex-end;gap:8px;padding:7px 7px 7px 14px;
  background:color-mix(in srgb,var(--surface) 80%,transparent);-webkit-backdrop-filter:blur(22px) saturate(1.5);backdrop-filter:blur(22px) saturate(1.5);
  border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-3);
  transition:opacity .5s var(--ease) .25s, transform .35s var(--ease), border-color .2s var(--ease), box-shadow .3s var(--ease);}
body:not([data-stage="desktop"]) #chatbar{opacity:0;transform:translateX(-50%) translateY(22px);pointer-events:none;}
#chatbar.focused{border-color:color-mix(in srgb,var(--amber) 52%,var(--line));box-shadow:0 0 0 4px var(--amber-glow),var(--shadow-3);}
#chatbar .cb-gem{flex-shrink:0;line-height:0;align-self:center;filter:drop-shadow(0 2px 6px var(--amber-glow));}
#chatbar-input{flex:1;min-width:0;border:0;outline:0;background:transparent;resize:none;
  font-family:var(--ff-ui);font-size:15.5px;line-height:1.5;color:var(--ink-1);max-height:120px;padding:9px 2px;}
#chatbar-input::placeholder{color:var(--ink-3);}
#chatbar .cb-actions{display:flex;align-items:center;gap:3px;align-self:flex-end;}
.cb-btn{width:38px;height:38px;border:0;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;
  background:transparent;color:var(--ink-3);transition:background .15s,color .15s,transform .15s;}
.cb-btn:hover{background:var(--surface-2);color:var(--ink-1);}
.cb-btn svg{width:17px;height:17px;}
.cb-send{background:var(--amber)!important;color:#1A1100!important;box-shadow:var(--shadow-glow);}
.cb-send:hover{transform:translateY(-1px);}
.cb-send svg{width:16px;height:16px;}

/* following companion (overrides) */
#companion{right:auto;bottom:auto;left:0;top:0;will-change:transform;}
#companion.following{animation:none!important;}
body.no-follow #companion{opacity:0;pointer-events:none;}
.comp-say{right:calc(100% + 6px);bottom:6px;}

/* Theron's right-click help menu reuses .mb-menu; ensure it floats above */
#help-menu{z-index:240;min-width:248px;}

/* ══════ floating window desktop ══════ */
#stage{position:fixed;inset:40px 0 0 84px;z-index:40;overflow:hidden;}
body:not([data-stage="desktop"]) #stage{pointer-events:none;opacity:0;}
@media (max-width:860px){ #stage{left:0;} }

.fwin{position:absolute;display:flex;flex-direction:column;min-width:300px;min-height:200px;
  background:
    linear-gradient(180deg, color-mix(in srgb,var(--surface) 99%,#fff), color-mix(in srgb,var(--surface) 94%,transparent));
  -webkit-backdrop-filter:blur(26px) saturate(1.7);backdrop-filter:blur(26px) saturate(1.7);
  border:1px solid transparent;border-radius:22px;overflow:hidden;
  background-clip:padding-box;
  box-shadow:
    0 0 0 .5px color-mix(in srgb,var(--ink-1) 8%,transparent),
    0 1px 0 rgba(255,255,255,.6) inset,
    0 2px 6px -2px rgba(120,40,90,.14),
    0 20px 44px -18px rgba(120,40,140,.26),
    0 44px 100px -40px rgba(120,40,140,.34);
  transition:box-shadow .2s var(--ease), border-color .15s var(--ease);}
/* gradient hairline that catches “light” at the top — the liquid-glass tell */
.fwin::before{content:'';position:absolute;inset:0;border-radius:22px;padding:1px;pointer-events:none;z-index:3;
  background:linear-gradient(150deg, rgba(255,255,255,.85), rgba(255,255,255,.12) 26%, transparent 50%, color-mix(in srgb,var(--amber) 14%,transparent));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;}
html[data-theme="dark"] .fwin{
  background:linear-gradient(180deg, color-mix(in srgb,var(--surface) 96%,#fff), color-mix(in srgb,var(--surface) 90%,transparent));
  box-shadow:
    0 0 0 .5px rgba(255,255,255,.06),
    0 1px 0 rgba(255,255,255,.07) inset,
    0 20px 50px -22px rgba(0,0,0,.6),
    0 50px 100px -44px rgba(0,0,0,.7);}
html[data-theme="dark"] .fwin::before{background:linear-gradient(150deg, rgba(255,255,255,.32), rgba(255,255,255,.05) 26%, transparent 52%, color-mix(in srgb,var(--amber) 20%,transparent));}
.fwin.focused{box-shadow:
    0 0 0 1px color-mix(in srgb,var(--amber) 30%,transparent),
    0 1px 0 rgba(255,255,255,.55) inset,
    0 0 50px -10px var(--amber-glow),
    0 24px 60px -24px rgba(20,14,4,.45),
    0 50px 110px -44px rgba(20,14,4,.55);}
html[data-theme="dark"] .fwin.focused{box-shadow:
    0 0 0 1px color-mix(in srgb,var(--amber) 34%,transparent),
    0 1px 0 rgba(255,255,255,.08) inset,
    0 0 56px -12px var(--amber-glow),
    0 50px 110px -44px rgba(0,0,0,.7);}
.fwin:not(.focused) .fwin-bar{opacity:.72;}
.fwin.opening{animation:fwin-open .2s var(--ease-soft);}
@keyframes fwin-open{from{opacity:0;transform:translateY(9px) scale(.985);}to{opacity:1;transform:none;}}
.fwin.closing{opacity:0;transform:translateY(7px) scale(.985);pointer-events:none;transition:opacity .15s var(--ease), transform .15s var(--ease);}
.fwin.minimized{opacity:0;transform:translateY(40vh) scale(.4);pointer-events:none;transition:opacity .2s var(--ease), transform .2s var(--ease);transform-origin:bottom left;}
.fwin.maximized{border-radius:0;border-color:transparent;}
.fwin.dragging{transition:none;cursor:grabbing;}

.fwin-bar{display:flex;align-items:center;gap:9px;height:48px;padding:0 10px 0 15px;flex-shrink:0;cursor:grab;user-select:none;position:relative;z-index:4;
  border-bottom:1px solid color-mix(in srgb,var(--line-2) 70%,transparent);
  background:linear-gradient(180deg,color-mix(in srgb,var(--surface-2) 50%,transparent),transparent);}
.fwin-bar:active{cursor:grabbing;}
.fwin-ic{width:25px;height:25px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;color:#fff;
  box-shadow:0 1px 2px rgba(20,14,4,.25), 0 0 0 .5px rgba(255,255,255,.25) inset;}
.fwin-ic svg{width:14px;height:14px;stroke-width:1.85;}
.fwin-tt{font-family:var(--ff-display);font-size:14px;font-weight:650;letter-spacing:-.012em;color:var(--ink-1);white-space:nowrap;flex-shrink:0;}
.fwin-sub{font-family:var(--ff-mono);font-size:10px;letter-spacing:.06em;text-transform:lowercase;color:var(--ink-3);white-space:nowrap;flex-shrink:0;
  padding-left:9px;margin-left:3px;border-left:1px solid var(--line-2);}
.fwin-sp{flex:1;}
.fwin-ctl{display:flex;align-items:center;gap:4px;flex-shrink:0;}
.fwc{width:28px;height:28px;border:0;background:transparent;color:var(--ink-3);border-radius:8px;cursor:pointer;display:grid;place-items:center;
  transition:background .14s, color .14s;}
.fwc:hover{background:var(--surface-2);color:var(--ink-1);}
.fwc.close:hover{background:var(--bad-soft);color:var(--bad);}
.fwc svg{width:15px;height:15px;}
.fwin-body{flex:1;min-height:0;overflow:auto;position:relative;}
.fwin-body::-webkit-scrollbar{width:10px;}
.fwin-body::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px;border:2px solid var(--surface);}
.fwin-body::-webkit-scrollbar-thumb:hover{background:var(--ink-3);}
.fwin-grip{position:absolute;right:0;bottom:0;width:18px;height:18px;cursor:nwse-resize;z-index:6;}
.fwin-grip::after{content:'';position:absolute;right:4px;bottom:4px;width:7px;height:7px;
  border-right:2px solid var(--ink-3);border-bottom:2px solid var(--ink-3);border-radius:0 0 3px 0;opacity:.5;}
/* full-height apps fill their window */
.fwin[data-app="ledger"] .app,.fwin[data-app="settings"] .app,.fwin[data-app="chat"] .app{height:100%;}
.fwin[data-app="chat"] .chatapp{height:100%;}

/* ══════ adaptive: phone — one full-screen app + bottom dock ══════ */
body[data-device="phone"] #stage{inset:40px 0 64px 0;}
body[data-device="phone"] .fwin{inset:0!important;width:auto!important;height:auto!important;
  border-radius:0;border:0;box-shadow:none;opacity:1;}
/* entrance: transform ONLY, gated on motion pref — never gate visibility on an animation
   (a stalled clock at frame 0 must not be able to hide the window; cf. the menubar fix) */
@media (prefers-reduced-motion:no-preference){
  body[data-device="phone"] .fwin.focused{animation:phone-app .22s var(--ease-soft) both;}
}
@keyframes phone-app{from{transform:translateY(8px);}to{transform:none;}}
body[data-device="phone"] .fwin:not(.focused){display:none;}
body[data-device="phone"] .fwin.focused{box-shadow:none;}
body[data-device="phone"] .fwin-grip{display:none;}
body[data-device="phone"] .fwin-bar{cursor:default;height:42px;}
body[data-device="phone"] .fwin .max{display:none;}
body[data-device="phone"] #dock{left:50%;top:auto;bottom:0;transform:translateX(-50%);flex-direction:row;align-items:center;gap:4px;
  width:100%;max-width:none;border-radius:0;border-left:0;border-right:0;border-bottom:0;justify-content:space-around;padding:8px 6px calc(8px + env(safe-area-inset-bottom));}
body[data-device="phone"] .dock-app{width:40px;height:40px;transform-origin:center;}
body[data-device="phone"] .dock-app:hover{transform:none;}
body[data-device="phone"] .dock-app:active{transform:scale(.9);}
body[data-device="phone"] .dock-app .tip{display:none;}
body[data-device="phone"] .dock-app .run{left:50%;top:auto;bottom:-4px;transform:translateX(-50%);}
body[data-device="phone"] .dock-div{display:none;}
body[data-device="phone"] #chatbar{display:none;}
body[data-device="phone"] #companion{bottom:74px;right:14px;}
body[data-device="phone"] #theron-cursor{display:none;}
body[data-device="phone"] .mb-kbtn .kbd,body[data-device="phone"] #mb-clock,body[data-device="phone"] #mb-active{display:none;}
body[data-device="phone"] .mb-kbtn span:not(.kbd){display:none;}

/* chat bar without leading face — give the text a touch more breathing room */
#chatbar{padding-left:18px;}
#chatbar-disclaimer{position:fixed;left:calc(50% + 32px);bottom:18px;transform:translateX(-50%);z-index:95;
  width:min(720px,calc(100vw - 150px));text-align:center;font-family:var(--ff-ui);font-size:11px;line-height:1.3;
  color:var(--ink-3);pointer-events:none;padding:0 12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  transition:opacity .5s var(--ease) .3s;}
body:not([data-stage="desktop"]) #chatbar-disclaimer{opacity:0;}
body.chat-active #chatbar-disclaimer{opacity:0;}
body[data-device="phone"] #chatbar-disclaimer{display:none;}

/* Theron's synthetic cursor — her hands on the OS */
#theron-cursor{position:fixed;left:0;top:0;z-index:236;width:26px;height:26px;pointer-events:none;
  opacity:0;transform:translate(-100px,-100px);transition:opacity .3s var(--ease);
  filter:drop-shadow(0 3px 7px rgba(20,12,0,.3));will-change:transform;}
#theron-cursor.on{opacity:1;}
#theron-cursor svg{width:100%;height:100%;transition:transform .12s var(--ease);}
#theron-cursor.press svg{transform:scale(.78);}
.tcur-ripple{position:fixed;z-index:235;width:16px;height:16px;margin:-8px 0 0 -8px;border-radius:50%;
  border:2px solid var(--amber);pointer-events:none;animation:tcur-rip .6s var(--ease) forwards;}
@keyframes tcur-rip{from{transform:scale(.4);opacity:.85;}to{transform:scale(3.2);opacity:0;}}
