/* ============ Stormwarden — outer frame ============ */
:root{
  --blue:#4a90e2;
  --blue-dim:#2c5f96;
  --red:#e2574a;
  --gold:#d8b75a;
  --ink:#e9e4f5;
  --ink-dim:#9b94b8;
  --ink-faint:#6c6690;
  --panel:rgba(20,16,38,0.62);
  --panel-2:rgba(28,22,52,0.55);
  --edge:rgba(150,120,220,0.26);
  --edge-soft:rgba(150,120,220,0.14);
  --void-0:#05030d;
  --rail-w:272px;
  --rail-w-collapsed:80px;
  --hex:polygon(25% 1%, 75% 1%, 100% 50%, 75% 99%, 25% 99%, 0% 50%);
}
*{ box-sizing:border-box; margin:0; padding:0; }
html,body{ height:100%; }
body{
  font-family:'Oswald',system-ui,sans-serif;
  color:var(--ink);
  background:var(--void-0);
  -webkit-font-smoothing:antialiased;
  overflow:hidden;
}
button{ font-family:inherit; color:inherit; cursor:pointer; background:none; border:none; }
a{ color:inherit; text-decoration:none; }

/* ---------- shared cosmic backdrop ---------- */
.cosmos{ position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.cosmos .void{
  position:absolute; inset:0;
  background:radial-gradient(130% 90% at 22% 8%, #3a2168 0%, #241449 26%, #130a2b 52%, #08040f 78%);
}
.cosmos .neb{ position:absolute; border-radius:50%; filter:blur(80px); opacity:.34; mix-blend-mode:screen; }
.cosmos .neb.a{ width:900px; height:760px; left:-6%; top:-10%; background:radial-gradient(circle,#7d3fb8,transparent 62%); }
.cosmos .neb.b{ width:740px; height:680px; right:-8%; top:8%;  background:radial-gradient(circle,#3f5fb8,transparent 60%); opacity:.3; }
.cosmos .neb.c{ width:780px; height:720px; right:14%; bottom:-22%; background:radial-gradient(circle,#b83f7d,transparent 60%); opacity:.26; }
.cosmos .vig{ position:absolute; inset:0; background:radial-gradient(120% 100% at 50% 40%, transparent 50%, rgba(3,2,9,.78) 100%); }

/* ---------- app shell ---------- */
.app{
  position:relative; z-index:1; height:100%;
}

/* ============ sidebar ============ */
.rail{
  position:fixed; left:0; top:0; bottom:0; z-index:10;
  width:var(--rail-w);
  transition:width .28s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column;
  background:linear-gradient(180deg, rgba(18,12,36,.82), rgba(10,7,22,.92));
  border-right:1px solid var(--edge);
  backdrop-filter:blur(10px);
}
.rail::after{ content:''; position:absolute; top:0; right:0; bottom:0; width:1px;
  background:linear-gradient(180deg, transparent, rgba(150,120,220,.5) 18%, rgba(150,120,220,.5) 82%, transparent); }

/* brand */
.brand{
  display:flex; align-items:center; gap:13px;
  padding:22px 20px 20px; min-height:88px;
}
.brand-mark{
  width:40px; height:40px; flex:0 0 auto; position:relative;
  display:grid; place-items:center;
  filter:drop-shadow(0 0 9px rgba(74,144,226,.4));
}
.brand-mark .glyph{ width:40px; height:40px; overflow:visible; }
.brand-mark .g-eye{
  fill:rgba(8,5,20,.5);
  stroke:url(#swEye); stroke-width:2.3; stroke-linejoin:round;
}
.brand-mark .g-ring{ fill:none; stroke:url(#swEye); stroke-width:1; opacity:.45; }
.brand-mark .g-bolt{ fill:url(#swBolt); filter:drop-shadow(0 0 4px rgba(216,183,90,.55)); }
.brand-txt{ display:flex; flex-direction:column; line-height:1; min-width:0; overflow:visible; white-space:nowrap; padding-right:4px; }
.brand-txt .wm{
  font-family:'Rajdhani',sans-serif; font-weight:700; font-size:19px;
  letter-spacing:.07em; color:#eaf0ff; text-transform:uppercase;
  text-shadow:0 0 14px rgba(110,150,255,.4);
}
.brand-txt .wm2{ color:var(--gold); font-weight:600; text-shadow:0 0 12px rgba(216,183,90,.35); }

/* nav */
.nav{ flex:1; padding:8px 14px; overflow-y:auto; overflow-x:hidden; scrollbar-width:thin; scrollbar-color:rgba(150,120,220,.3) transparent; }
.nav::-webkit-scrollbar{ width:8px; }
.nav::-webkit-scrollbar-thumb{ background:rgba(150,120,220,.3); border-radius:4px; }
.nav::-webkit-scrollbar-track{ background:transparent; }
.nav-label{
  font-size:10.5px; letter-spacing:.32em; text-transform:uppercase; color:var(--ink-faint);
  padding:14px 12px 9px; white-space:nowrap;
}
.nav-item{
  position:relative; width:100%;
  display:flex; align-items:center; gap:12px;
  padding:11px 11px; border-radius:10px;
  border:1px solid transparent;
  color:var(--ink-dim); transition:.15s; text-align:left;
  margin-bottom:3px;
}
.nav-item .ic{ width:24px; height:24px; flex:0 0 auto; display:grid; place-items:center; }
.nav-item .ic svg{ display:block; width:22px; height:22px; }
.nav-item .lbl{ display:flex; flex-direction:column; gap:2px; min-width:0; flex:1 1 auto; overflow:hidden; }
.nav-item .lbl .t{
  font-size:14px; font-weight:500; letter-spacing:.02em; text-transform:uppercase;
  white-space:nowrap; line-height:1.1;
}
.nav-item .lbl .s{ font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); white-space:nowrap; }
.nav-item:hover{ color:var(--ink); background:rgba(255,255,255,.04); border-color:var(--edge-soft); }
.nav-item:hover .ic svg{ filter:drop-shadow(0 0 6px rgba(150,120,220,.5)); }
.nav-item.on{
  color:#eef2ff; background:linear-gradient(90deg, rgba(74,144,226,.16), rgba(74,144,226,.03));
  border-color:rgba(74,144,226,.45);
}
.nav-item.on .ic svg{ color:var(--blue); filter:drop-shadow(0 0 7px rgba(74,144,226,.6)); }
.nav-item.on .lbl .s{ color:var(--blue); opacity:.85; }
.nav-item.on::before{
  content:''; position:absolute; left:-14px; top:50%; transform:translateY(-50%);
  width:4px; height:26px; border-radius:0 4px 4px 0;
  background:var(--blue); box-shadow:0 0 12px var(--blue);
}
.nav-item .badge{
  margin-left:auto; flex:0 0 auto;
  font-family:'Rajdhani',sans-serif; font-size:9.5px; font-weight:700; letter-spacing:.14em;
  padding:3px 7px; border-radius:5px; text-transform:uppercase;
}
.nav-item .badge.live{ color:#bdf0d3; background:rgba(90,200,140,.14); border:1px solid rgba(90,200,140,.4); }

/* footer */
.rail-foot{ padding:14px; border-top:1px solid var(--edge-soft); display:flex; flex-direction:column; gap:6px; }
.foot-btn{
  display:flex; align-items:center; gap:13px; width:100%;
  padding:9px 12px; border-radius:9px; color:var(--ink-dim); transition:.15s;
}
.foot-btn .ic{ width:24px; height:24px; flex:0 0 auto; display:grid; place-items:center; }
.foot-btn .ic svg{ width:20px; height:20px; }
.foot-btn .t{ font-size:13px; letter-spacing:.06em; text-transform:uppercase; white-space:nowrap; }
.foot-btn:hover{ color:var(--ink); background:rgba(255,255,255,.04); }
.collapse-ic{ transition:transform .28s; }
.app.collapsed .collapse-ic{ transform:rotate(180deg); }

/* collapsed state hides text */
.app.collapsed .rail{ width:var(--rail-w-collapsed); }
.app.collapsed .main{ margin-left:var(--rail-w-collapsed); }
.app.collapsed .brand-txt{ overflow:hidden; }
.app.collapsed .brand-txt,
.app.collapsed .nav-label,
.app.collapsed .nav-item .lbl,
.app.collapsed .foot-btn .t{ opacity:0; width:0; pointer-events:none; }
.app.collapsed .nav-item .badge{ display:none; }
.app.collapsed .brand{ justify-content:center; padding-left:0; padding-right:0; }
.app.collapsed .nav-item,
.app.collapsed .foot-btn{ justify-content:center; gap:0; }
.app.collapsed .nav-item.on::before{ left:-14px; }

/* ============ main content ============ */
.main{ position:relative; height:100%; margin-left:var(--rail-w); transition:margin-left .28s cubic-bezier(.4,0,.2,1); overflow:hidden; }
.view{ display:none; height:100%; }
.view.on{ display:block; }

/* tool views — embedded page docked in a framed 16:9 panel */
.view-draft, .view-tele{ position:relative; }
.tool-frame{ height:100%; display:flex; flex-direction:column; }
.tool-dock{
  flex:1; min-height:0;
  padding:20px 40px 30px;
  display:grid; place-items:center;
  container-type:size;
}
.tool-panel{
  position:relative;
  width:min(100%, calc(100cqh * 16 / 9)); max-height:100%; aspect-ratio:16/9;
  border-radius:14px; overflow:hidden;
  background:var(--void-0); border:1px solid var(--edge);
  box-shadow:0 24px 60px rgba(0,0,0,.5);
}
.tool-panel iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; display:block; }

/* expanded: full-bleed over the entire viewport, including the rail */
.view-draft.expanded, .view-tele.expanded{
  position:fixed; inset:0; z-index:200;
  background:var(--void-0);
}
.view-draft.expanded .tool-dock, .view-tele.expanded .tool-dock{ padding:16px 0 0; }
.view-draft.expanded .tool-panel, .view-tele.expanded .tool-panel{
  width:100%; height:100%; max-height:none; aspect-ratio:auto;
  border-radius:0; border:none; box-shadow:none;
}

.frame-load{
  position:absolute; inset:0; z-index:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px;
  color:var(--ink-dim); font-size:13px; letter-spacing:.24em; text-transform:uppercase;
}
.frame-load .spin{
  width:36px; height:36px; border-radius:50%;
  border:2px solid var(--edge); border-top-color:var(--blue);
  animation:spin 1s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg); } }
.frame-load.off{ display:none; }

/* scrollable content views */
.scroller{ height:100%; overflow-y:auto; overflow-x:hidden; }
.scroller::-webkit-scrollbar{ width:10px; }
.scroller::-webkit-scrollbar-thumb{ background:rgba(150,120,220,.3); border-radius:5px; }
.scroller::-webkit-scrollbar-track{ background:transparent; }

/* top bar */
.topbar{
  display:flex; align-items:center; gap:18px;
  padding:26px 40px 0; width:100%;
}
.topbar.wide{ max-width:none; }
.crumb{ display:flex; align-items:center; gap:11px; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-faint); }
.crumb .sep{ opacity:.5; }
.crumb .cur{ color:var(--ink-dim); }
.topbar .spacer{ flex:1; }
.status-chip{
  display:flex; align-items:center; gap:8px; white-space:nowrap;
  font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-dim);
  padding:7px 13px; border-radius:8px; background:var(--panel); border:1px solid var(--edge);
}
.status-chip .dot{ width:7px; height:7px; border-radius:50%; background:#5ac88c; box-shadow:0 0 8px #5ac88c; }
@media (max-width:1000px){ .status-chip{ display:none; } }

/* interactive topbar chip */
.chip-btn{
  display:flex; align-items:center; gap:8px; white-space:nowrap;
  font-family:inherit; font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-dim);
  padding:7px 13px; border-radius:8px; background:var(--panel); border:1px solid var(--edge);
  cursor:pointer; transition:.15s;
}
.chip-btn svg{ width:14px; height:14px; }
.chip-btn:hover{ color:var(--ink); border-color:rgba(180,150,240,.5); background:var(--panel-2); }

/* ---------- dashboard ---------- */
.dash{ max-width:1280px; margin:0 auto; padding:0 40px 60px; }
.hero-head{ padding:40px 0 30px; }
.hero-head .eyebrow{
  font-size:12px; letter-spacing:.34em; text-transform:uppercase; color:var(--gold); margin-bottom:16px;
  display:flex; align-items:center; gap:12px;
}
.hero-head .eyebrow::before{ content:''; width:30px; height:1px; background:var(--gold); opacity:.7; }
.hero-head h1{
  font-family:'Rajdhani',sans-serif; font-weight:700; font-size:clamp(34px, 4.5vw, 54px); line-height:1.02;
  letter-spacing:.02em; text-transform:uppercase; color:#f2f0ff;
  text-shadow:0 2px 30px rgba(110,150,255,.25);
}
.hero-head h1 .accent{ color:var(--blue); }
.hero-head p{ margin-top:16px; max-width:560px; font-size:17px; line-height:1.5; color:var(--ink-dim); letter-spacing:.01em; text-wrap:pretty; }

.cards{ display:grid; grid-template-columns:repeat(auto-fill, minmax(300px,1fr)); gap:18px; }

.card{
  position:relative; display:flex; flex-direction:column;
  border-radius:14px; overflow:hidden;
  background:var(--panel); border:1px solid var(--edge);
  transition:transform .18s cubic-bezier(.4,0,.2,1), border-color .18s, box-shadow .18s;
  text-align:left;
}
.card:hover{ transform:translateY(-4px); border-color:rgba(180,150,240,.5); box-shadow:0 20px 44px rgba(0,0,0,.45); }
.card-art{ position:relative; height:148px; overflow:hidden; border-bottom:1px solid var(--edge-soft); }
.card-art .glow{ position:absolute; inset:0; }
.card-art .ico{ position:absolute; inset:0; display:grid; place-items:center; }
.card-art .ico svg{ width:62px; height:62px; opacity:.92; filter:drop-shadow(0 4px 14px rgba(0,0,0,.5)); }
.card-art .hexmotif{ position:absolute; inset:0; opacity:.5; }
.card-body{ padding:18px 20px 20px; display:flex; flex-direction:column; gap:8px; flex:1; }
.card-body .tt{
  font-family:'Rajdhani',sans-serif; font-weight:700; font-size:22px; letter-spacing:.04em;
  text-transform:uppercase; color:#f0eeff; line-height:1.05;
}
.card-body .dd{ font-size:14px; line-height:1.45; color:var(--ink-dim); flex:1; text-wrap:pretty; }
.card-foot{ display:flex; align-items:center; gap:10px; margin-top:6px; }
.card-foot .pill{
  font-family:'Rajdhani',sans-serif; font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  padding:4px 9px; border-radius:5px;
}
.pill.live{ color:#bdf0d3; background:rgba(90,200,140,.14); border:1px solid rgba(90,200,140,.4); }
.card-foot .go{ margin-left:auto; font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-dim); display:flex; align-items:center; gap:7px; transition:.15s; }
.card:hover .go{ color:var(--blue); gap:11px; }

/* primary (draft) card spans wider */
.card.feature{ grid-column:span 2; flex-direction:row; }
.card.feature .card-art{ width:300px; height:auto; border-bottom:none; border-right:1px solid var(--edge-soft); flex:0 0 auto; }
.card.feature .card-art .ico svg{ width:84px; height:84px; }
.card.feature .card-body{ padding:26px 28px; justify-content:center; }
.card.feature .card-body .tt{ font-size:30px; }
.card.feature .card-body .dd{ flex:0; font-size:15.5px; max-width:440px; }
@media (max-width:900px){ .card.feature{ grid-column:span 1; flex-direction:column; } .card.feature .card-art{ width:auto; height:148px; border-right:none; border-bottom:1px solid var(--edge-soft); } }

/* tooltip for collapsed rail */
.rail-tip{
  position:fixed; z-index:60; pointer-events:none; transform:translateY(-50%);
  background:rgba(12,9,26,.97); border:1px solid var(--edge); border-radius:8px;
  padding:8px 13px; white-space:nowrap; box-shadow:0 8px 28px rgba(0,0,0,.55);
  opacity:0; transition:opacity .12s; font-size:13px; letter-spacing:.05em;
}
.rail-tip.on{ opacity:1; }
.rail-tip .rt-t{ font-weight:500; letter-spacing:.06em; text-transform:uppercase; }
.rail-tip .rt-s{ font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); margin-top:2px; }

/* ---------- focus visibility ---------- */
:is(button, a, .nav-item, .card, .foot-btn):focus-visible{
  outline:2px solid var(--blue); outline-offset:2px;
}

/* ---------- narrow viewports: rail is forced collapsed via JS ---------- */
@media (max-width:800px){
  #collapseBtn{ display:none; }
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  .frame-load .spin{ animation:none; }
  .card:hover{ transform:none; }
  .rail, .main, .collapse-ic{ transition:none; }
}
