/* ─────────────────────────────────────────────────────────────
   Walklix Control Room · editorial dark, electric lime
   Type: Instrument Serif (display) · JetBrains Mono (data) · Geist (body)
   ────────────────────────────────────────────────────────────── */

:root{
  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px;
  --serif:'Instrument Serif', 'Times New Roman', serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;
  --sans:'Geist', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;

  /* Brand accents — same across themes */
  --signal:    #FF5C3D;
  --gold:      #FFC83D;
  --cyan:      #58E1FF;
  --rose:      #FF3D7F;
}

/* ── DARK THEME (default) ─────────────────────────────── */
body[data-theme="dark"]{
  --bg:        #0A0A0F;
  --bg-2:      #0E0E15;
  --bg-3:      #14141C;
  --panel:     #15151F;
  --panel-2:   #1B1B27;
  --line:      #232331;
  --line-2:    #2D2D3F;
  --text:      #F5F5F2;
  --text-sub:  #A4A4B5;
  --text-mut:  #5F5F75;
  --lime:      #BFFF3C;
  --lime-2:    #D6FF6E;
  --lime-soft: rgba(191,255,60,.12);
  --lime-line: rgba(191,255,60,.32);
  --grain-opacity: .05;
  --grid-line: rgba(255,255,255,.025);
  --grid-mask-fade: 90%;
  color-scheme: dark;
}

/* ── LIGHT THEME ──────────────────────────────────────── */
body[data-theme="light"]{
  --bg:        #FAFAF6;
  --bg-2:      #F3F3EC;
  --bg-3:      #ECECE3;
  --panel:     #FFFFFF;
  --panel-2:   #F6F6EE;
  --line:      #E4E2D6;
  --line-2:    #C9C7B7;
  --text:      #15151B;
  --text-sub:  #4F4F5B;
  --text-mut:  #8A8A95;
  --lime:      #5C8C0E;
  --lime-2:    #6BA213;
  --lime-soft: rgba(92,140,14,.10);
  --lime-line: rgba(92,140,14,.30);
  --grain-opacity: .025;
  --grid-line: rgba(0,0,0,.04);
  --grid-mask-fade: 85%;
  color-scheme: light;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--sans);
  background:var(--bg);
  color:var(--text);
  font-size:14px;
  font-weight:400;
  letter-spacing:-0.005em;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
button,input,textarea,select{font:inherit;color:inherit}
button{cursor:pointer;background:none;border:none;padding:0}
input,textarea,select{outline:none}
a{color:inherit;text-decoration:none}
.hidden{display:none !important}

/* ─── BACKDROP ────────────────────────────────────────────── */
.bg-grid{
  position:fixed;inset:0;z-index:-3;pointer-events:none;
  background-image:
    linear-gradient(to right, var(--grid-line) 1px, transparent 1px),
    linear-gradient(to bottom, var(--grid-line) 1px, transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse 90% 80% at 50% 30%, #000 40%, transparent var(--grid-mask-fade));
}
.bg-noise{
  position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:var(--grain-opacity);mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/></svg>");
}
.bg-glow{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(800px 400px at 90% -10%, var(--lime-soft), transparent 60%),
    radial-gradient(700px 500px at -10% 110%, rgba(88,225,255,.07), transparent 60%);
}
body[data-theme="light"] .bg-glow{
  background:
    radial-gradient(800px 400px at 90% -10%, rgba(92,140,14,.06), transparent 60%),
    radial-gradient(700px 500px at -10% 110%, rgba(88,225,255,.05), transparent 60%);
}

/* ─── BOOT ────────────────────────────────────────────────── */
.boot{
  position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
  background:var(--bg);z-index:50;animation:fadeOut .4s ease 1.2s forwards;
}
.boot-mark{animation:pop .8s cubic-bezier(.2,.9,.3,1.4)}
.boot-text{font-family:var(--mono);font-size:12px;color:var(--text-sub);letter-spacing:.04em;text-transform:uppercase}
.dots i{display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--lime);margin-left:3px;animation:blink 1s infinite}
.dots i:nth-child(2){animation-delay:.2s}
.dots i:nth-child(3){animation-delay:.4s}
@keyframes pop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes blink{0%,100%{opacity:.2}50%{opacity:1}}
@keyframes fadeOut{to{opacity:0;visibility:hidden}}

/* ─── LOGIN ───────────────────────────────────────────────── */
.login{
  min-height:100dvh;display:grid;place-items:center;padding:24px;
  animation:rise .8s cubic-bezier(.2,.9,.3,1) both;
}
.login-cardwrap{
  width:min(1080px,100%);
  display:grid;grid-template-columns:1.05fr .95fr;
  background:linear-gradient(160deg,var(--panel) 0%,var(--bg-2) 100%);
  border:1px solid var(--line);border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:0 40px 120px -40px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.02) inset;
  position:relative;
}
.login-cardwrap::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 0% 0%, rgba(191,255,60,.07), transparent 35%);
}
.login-side{padding:48px 44px;border-right:1px solid var(--line);position:relative;display:flex;flex-direction:column;gap:24px}
.login-mark{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--text)}
.login-display{
  font-family:var(--serif);font-weight:400;font-size:clamp(48px,6vw,84px);line-height:.95;
  margin:0;letter-spacing:-.025em;color:var(--text);
}
.login-display em{color:var(--lime);font-style:italic;font-weight:400}
.login-sub{color:var(--text-sub);font-size:15px;max-width:36ch;line-height:1.55;margin:0}
.login-meta{list-style:none;padding:0;margin:auto 0 0;display:flex;flex-direction:column;gap:8px;font-family:var(--mono);font-size:11.5px;color:var(--text-sub);letter-spacing:.02em}
.login-meta .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--lime);box-shadow:0 0 10px var(--lime);margin-right:8px}

.login-form{padding:48px 44px;display:flex;flex-direction:column;gap:18px;justify-content:center}
.login-form-head h2{margin:6px 0 0;font-family:var(--serif);font-style:italic;font-size:36px;font-weight:400}
.kbd-tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--lime);background:var(--lime-soft);border:1px solid var(--lime-line);padding:4px 8px;border-radius:6px;text-transform:uppercase}
.login-form label{display:flex;flex-direction:column;gap:7px}
.login-form label span{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mut)}
.login-form input{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-md);
  padding:14px 16px;font-size:15px;color:var(--text);transition:border-color .15s, background .15s, box-shadow .15s;
}
.login-form input:focus{border-color:var(--lime-line);background:var(--bg-3);box-shadow:0 0 0 3px var(--lime-soft)}
.login-err{margin:4px 0 0;color:var(--signal);font-family:var(--mono);font-size:12px;min-height:1em}
.login-foot{margin-top:14px;font-size:12px;color:var(--text-mut);line-height:1.5}
.login-foot span{color:var(--text-sub);font-weight:600}

@media (max-width:780px){
  .login-cardwrap{grid-template-columns:1fr}
  .login-side{border-right:none;border-bottom:1px solid var(--line);padding:36px 28px}
  .login-form{padding:36px 28px}
}

/* ─── BUTTONS ─────────────────────────────────────────────── */
.btn-primary{
  background:var(--lime);color:#0A0A0F;font-weight:700;font-size:14px;letter-spacing:.01em;
  padding:14px 18px;border-radius:var(--r-md);display:inline-flex;align-items:center;gap:10px;justify-content:center;
  transition:transform .12s ease, box-shadow .15s ease, background .15s;
  box-shadow:0 8px 28px -10px rgba(191,255,60,.55);
}
.btn-primary:hover{transform:translateY(-1px);background:var(--lime-2);box-shadow:0 14px 36px -10px rgba(191,255,60,.7)}
.btn-primary:active{transform:translateY(0)}
.btn-primary[disabled]{opacity:.5;cursor:wait}

.btn-ghost{
  background:var(--panel);border:1px solid var(--line);color:var(--text);
  padding:11px 16px;border-radius:var(--r-md);font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:8px;
  transition:border-color .15s, background .15s;
}
.btn-ghost:hover{border-color:var(--line-2);background:var(--panel-2)}
.btn-ghost-sm{
  background:transparent;border:1px solid var(--line);color:var(--text-sub);
  padding:6px 10px;border-radius:8px;font-size:11.5px;font-weight:600;display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);
  transition:color .15s, border-color .15s, background .15s;
}
.btn-ghost-sm:hover{color:var(--text);border-color:var(--line-2);background:var(--panel)}
.btn-danger{
  background:rgba(255,92,61,.12);border:1px solid rgba(255,92,61,.35);color:#FF8A6E;
  padding:8px 12px;border-radius:8px;font-size:12px;font-weight:700;display:inline-flex;gap:6px;align-items:center;
  transition:background .15s;
}
.btn-danger:hover{background:rgba(255,92,61,.22)}
.btn-success{
  background:rgba(191,255,60,.14);border:1px solid var(--lime-line);color:var(--lime);
  padding:8px 12px;border-radius:8px;font-size:12px;font-weight:700;display:inline-flex;gap:6px;align-items:center;
}
.btn-success:hover{background:rgba(191,255,60,.22)}

/* ─── SHELL ──────────────────────────────────────────────── */
.shell{display:grid;grid-template-columns:260px 1fr;min-height:100dvh;animation:rise .5s ease both}

/* ─── SIDEBAR ────────────────────────────────────────────── */
.sidebar{
  border-right:1px solid var(--line);background:linear-gradient(180deg,var(--bg-2) 0%, var(--bg) 100%);
  padding:22px 16px;display:flex;flex-direction:column;gap:18px;position:sticky;top:0;height:100dvh;
}
.sb-mark{display:flex;align-items:center;gap:10px;padding:0 6px}
.sb-mark strong{display:block;font-family:var(--serif);font-style:italic;font-size:22px;letter-spacing:-.02em}
.sb-mark span{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-mut)}
.sb-nav{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.sb-link{
  display:grid;grid-template-columns:14px 1fr auto;align-items:center;gap:10px;
  padding:9px 12px;border-radius:10px;color:var(--text-sub);font-weight:500;font-size:13.5px;cursor:pointer;
  transition:background .12s, color .12s;
  position:relative;
}
.sb-link i{
  width:6px;height:6px;border-radius:50%;background:var(--line-2);display:inline-block;justify-self:center;
  transition:background .15s, box-shadow .15s, transform .15s;
}
.sb-link kbd{
  font-family:var(--mono);font-size:10px;color:var(--text-mut);
  background:var(--panel);border:1px solid var(--line);border-radius:5px;padding:1px 5px;
}
.sb-link:hover{color:var(--text);background:var(--panel)}
.sb-link.active{
  color:var(--text);background:var(--panel-2);
  box-shadow:inset 0 0 0 1px var(--line-2);
}
.sb-link.active i{background:var(--lime);box-shadow:0 0 12px var(--lime);transform:scale(1.5)}
.sb-foot{margin-top:auto;padding:14px 6px 6px;border-top:1px dashed var(--line);display:flex;flex-direction:column;gap:10px}
.sb-user{display:flex;align-items:center;gap:10px}
.sb-avatar{
  width:38px;height:38px;border-radius:10px;background:var(--lime);color:#0A0A0F;
  display:grid;place-items:center;font-weight:800;font-size:15px;
}
.sb-user-meta{font-size:12.5px;line-height:1.3}
.sb-user-meta strong{display:block;color:var(--text);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-user-meta span{font-family:var(--mono);font-size:10.5px;color:var(--text-mut)}

/* ─── MAIN / TOPBAR ─────────────────────────────────────── */
.main{padding:0 32px 60px;min-width:0}
.topbar{
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
  padding:28px 0 22px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:linear-gradient(var(--bg) 70%, transparent);z-index:5;
}
.crumb-trail{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-mut)}
#pageTitle{margin:6px 0 0;font-family:var(--serif);font-weight:400;font-size:42px;letter-spacing:-.025em;line-height:1}
#pageTitle em{color:var(--lime);font-style:italic}
.topbar-right{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;color:var(--text-sub)}
.status-dot{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 12px var(--lime);animation:pulse 2s infinite}
.status-text code{color:var(--lime);background:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.view{padding-top:24px;animation:rise .35s ease both}

@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ─── DASHBOARD GRID ────────────────────────────────────── */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.card{
  background:linear-gradient(180deg,var(--panel) 0%,var(--bg-2) 100%);
  border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 22px;position:relative;overflow:hidden;
  transition:border-color .15s, transform .15s;
}
.card:hover{border-color:var(--line-2)}
.card h3{margin:0;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-mut);font-weight:500}
.card .figure{font-family:var(--serif);font-style:italic;font-weight:400;font-size:64px;line-height:.95;letter-spacing:-.03em;margin:14px 0 4px;color:var(--text)}
.card .figure.lime{color:var(--lime)}
.card .figure.gold{color:var(--gold)}
.card .figure.cyan{color:var(--cyan)}
.card .delta{font-family:var(--mono);font-size:12px;color:var(--text-sub)}
.card .delta.up{color:var(--lime)}
.card .delta.down{color:var(--signal)}
.card .badge-row{margin-top:12px;display:flex;gap:6px;flex-wrap:wrap}
.span-3{grid-column:span 3}
.span-4{grid-column:span 4}
.span-5{grid-column:span 5}
.span-6{grid-column:span 6}
.span-7{grid-column:span 7}
.span-8{grid-column:span 8}
.span-9{grid-column:span 9}
.span-12{grid-column:span 12}
@media (max-width:1100px){
  .span-3,.span-4,.span-5{grid-column:span 6}
  .span-7,.span-8,.span-9{grid-column:span 12}
}
@media (max-width:680px){
  .span-3,.span-4,.span-5,.span-6,.span-7,.span-8,.span-9{grid-column:span 12}
  .shell{grid-template-columns:1fr}
  .sidebar{position:relative;flex-direction:row;height:auto;overflow-x:auto;padding:14px 16px;gap:8px}
  .sb-foot{display:none}
  .sb-nav{flex-direction:row;gap:4px;flex:1;overflow-x:auto}
  .sb-link kbd{display:none}
  .main{padding:0 18px 60px}
  #pageTitle{font-size:34px}
}

.section-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:8px 0 18px}
.section-head h2{margin:0;font-family:var(--serif);font-style:italic;font-weight:400;font-size:28px;letter-spacing:-.02em}
.section-head .sub{font-family:var(--mono);font-size:11px;color:var(--text-mut);letter-spacing:.06em;text-transform:uppercase}

/* ─── TABLES ────────────────────────────────────────────── */
.table-wrap{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
}
.table-tools{
  display:flex;gap:10px;align-items:center;padding:14px;border-bottom:1px solid var(--line);
  background:var(--bg-2);
}
.search-input{
  flex:1;background:transparent;border:1px solid var(--line);border-radius:10px;padding:10px 14px;font-size:13px;color:var(--text);
  font-family:var(--mono);
}
.search-input:focus{border-color:var(--lime-line);box-shadow:0 0 0 3px var(--lime-soft)}
.table{width:100%;border-collapse:collapse;font-size:13px}
.table th{
  text-align:left;padding:11px 14px;font-family:var(--mono);font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--text-mut);border-bottom:1px solid var(--line);font-weight:500;background:var(--bg-2);
}
.table td{padding:14px;border-bottom:1px solid var(--line);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tr:hover td{background:var(--bg-3)}
.table .num{font-family:var(--mono);font-weight:500}
.cell-user{display:flex;align-items:center;gap:10px;min-width:0}
.cell-user img,.cell-user .ph{width:34px;height:34px;border-radius:9px;flex:0 0 auto;background:var(--bg-3);object-fit:cover;display:grid;place-items:center;font-weight:700;color:var(--text-sub);font-size:13px}
.cell-user .meta{min-width:0}
.cell-user strong{display:block;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}
.cell-user span{font-family:var(--mono);font-size:11px;color:var(--text-mut);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;max-width:200px}
.actions{display:flex;gap:6px;justify-content:flex-end}

/* ─── CHIPS / BADGES ───────────────────────────────────── */
.chip{
  display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;
  background:var(--panel-2);color:var(--text-sub);border:1px solid var(--line);
}
.chip.lime{background:var(--lime-soft);color:var(--lime);border-color:var(--lime-line)}
.chip.signal{background:rgba(255,92,61,.12);color:#FF8A6E;border-color:rgba(255,92,61,.32)}
.chip.gold{background:rgba(255,200,61,.10);color:var(--gold);border-color:rgba(255,200,61,.32)}
.chip.cyan{background:rgba(88,225,255,.10);color:var(--cyan);border-color:rgba(88,225,255,.32)}
.chip.rose{background:rgba(255,61,127,.10);color:var(--rose);border-color:rgba(255,61,127,.32)}
.chip .dot{width:5px;height:5px;border-radius:50%;background:currentColor}

/* ─── EMPTY STATE / SKELETON ───────────────────────────── */
.empty{padding:48px 18px;text-align:center;color:var(--text-mut);font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.skel{display:flex;flex-direction:column;gap:8px;padding:20px}
.skel-row{height:54px;background:linear-gradient(90deg,var(--bg-2),var(--panel),var(--bg-2));background-size:200% 100%;border-radius:10px;animation:shimmer 1.4s linear infinite}
@keyframes shimmer{0%{background-position:0 0}100%{background-position:-200% 0}}

/* ─── MODAL ─────────────────────────────────────────────── */
.modal{position:fixed;inset:0;z-index:100;background:rgba(5,5,8,.7);backdrop-filter:blur(8px);display:grid;place-items:center;padding:20px;animation:fadeIn .15s ease both}
.modal-card{
  width:min(560px,100%);background:linear-gradient(160deg,var(--panel),var(--bg-2));
  border:1px solid var(--line-2);border-radius:var(--r-lg);padding:28px;position:relative;
  box-shadow:0 40px 120px -40px rgba(0,0,0,.8);
  animation:rise .25s cubic-bezier(.2,.9,.3,1) both;
}
.modal-card h3{margin:0 0 6px;font-family:var(--serif);font-style:italic;font-size:28px;font-weight:400;letter-spacing:-.02em}
.modal-card p{margin:0 0 16px;color:var(--text-sub);font-size:13.5px;line-height:1.55}
.modal-card label{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.modal-card label span{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-mut)}
.modal-card input,.modal-card select,.modal-card textarea{
  background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:11px 14px;font-size:13.5px;color:var(--text);
  width:100%;font-family:inherit;
}
.modal-card textarea{resize:vertical;min-height:80px;line-height:1.5}
.modal-card input:focus,.modal-card select:focus,.modal-card textarea:focus{border-color:var(--lime-line);box-shadow:0 0 0 3px var(--lime-soft)}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ─── TOAST ─────────────────────────────────────────────── */
.toast{
  position:fixed;bottom:22px;left:50%;transform:translateX(-50%);
  background:var(--text);color:#0A0A0F;font-family:var(--mono);font-size:12.5px;font-weight:600;
  padding:11px 18px;border-radius:999px;z-index:200;
  box-shadow:0 16px 40px -10px rgba(0,0,0,.6);
  animation:toastIn .25s cubic-bezier(.2,.9,.3,1.4);
}
.toast.err{background:var(--signal);color:#fff}
.toast.ok{background:var(--lime)}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%,0)}}

/* ─── DASHBOARD: ACTIVITY TICKER ───────────────────────── */
.ticker{
  display:flex;flex-direction:column;gap:8px;max-height:260px;overflow:auto;padding-right:6px;
}
.ticker::-webkit-scrollbar{width:4px}
.ticker::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:4px}
.tick-row{display:flex;gap:10px;align-items:center;padding:9px 11px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;font-size:12.5px}
.tick-row strong{color:var(--text);font-weight:600}
.tick-row span{color:var(--text-mut);font-family:var(--mono);font-size:10.5px;margin-left:auto}
.tick-row .ico{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:var(--panel-2);font-size:13px}

/* ─── KPI MICRO-CHART ──────────────────────────────────── */
.spark{height:34px;display:flex;align-items:flex-end;gap:3px;margin-top:14px}
.spark span{flex:1;background:var(--lime-soft);border-radius:2px;transition:height .3s}
.spark span:hover{background:var(--lime)}

/* ─── COMPOSE NOTIFICATION ─────────────────────────────── */
.compose{
  display:grid;grid-template-columns:1.1fr .9fr;gap:18px;
}
.compose-form{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px}
.compose-form h3{margin:0 0 14px;font-family:var(--serif);font-style:italic;font-weight:400;font-size:24px}
.preview{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;
  display:flex;flex-direction:column;gap:14px;
}
.preview-frame{
  background:#1A1A24;border:1px solid var(--line-2);border-radius:18px;padding:14px;
  position:relative;overflow:hidden;
}
.preview-frame::before{content:'';position:absolute;left:50%;top:6px;width:60px;height:5px;background:#0A0A0F;border-radius:5px;transform:translateX(-50%)}
.preview-toast{
  margin-top:18px;background:#FFFFFF;color:#111;padding:12px 14px;border-radius:14px;
  display:flex;gap:10px;align-items:flex-start;
  box-shadow:0 12px 30px -10px rgba(0,0,0,.5);
}
.preview-toast .ico{width:32px;height:32px;border-radius:8px;background:var(--lime);display:grid;place-items:center;font-weight:800;font-size:14px;color:#0A0A0F;flex:0 0 auto}
.preview-toast .body{font-family:var(--sans);font-size:12.5px;line-height:1.45}
.preview-toast .body strong{display:block;font-size:13px;color:#000;margin-bottom:2px}
.preview-toast .meta{font-family:var(--mono);font-size:9.5px;color:#999;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}

@media (max-width:980px){.compose{grid-template-columns:1fr}}

/* ─── DETAIL DRAWER ─────────────────────────────────────── */
.kvs{display:grid;grid-template-columns:160px 1fr;gap:8px 14px;font-size:12.5px;margin-top:8px}
.kvs dt{color:var(--text-mut);font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase}
.kvs dd{margin:0;color:var(--text);word-break:break-all}

/* ─── SEGMENTED ─────────────────────────────────────────── */
.seg{display:inline-flex;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px}
.seg button{
  padding:6px 12px;font-size:12px;font-family:var(--mono);font-weight:600;color:var(--text-mut);border-radius:7px;
  letter-spacing:.04em;text-transform:uppercase;
}
.seg button.active{background:var(--panel-2);color:var(--lime);box-shadow:inset 0 0 0 1px var(--lime-line)}
.seg button:hover{color:var(--text)}

.login-theme-toggle{
  position:fixed;top:18px;right:18px;z-index:5;
  width:36px;height:36px;padding:0;display:grid;place-items:center;
  border-radius:999px;
}

/* ─── THEME TOGGLE ─────────────────────────────────────── */
.theme-toggle{position:relative;overflow:hidden}
.theme-toggle .ico-sun,.theme-toggle .ico-moon{transition:opacity .2s ease, transform .25s cubic-bezier(.2,.9,.3,1)}
body[data-theme="dark"]  .theme-toggle .ico-sun{opacity:0;position:absolute;left:10px;transform:rotate(60deg)}
body[data-theme="dark"]  .theme-toggle .ico-moon{opacity:1;color:var(--lime)}
body[data-theme="light"] .theme-toggle .ico-moon{opacity:0;position:absolute;left:10px;transform:rotate(-60deg)}
body[data-theme="light"] .theme-toggle .ico-sun{opacity:1;color:var(--gold)}

/* ─── LIGHT-MODE CONTRAST FIXES ────────────────────────── */
body[data-theme="light"] .login-cardwrap{
  box-shadow:0 30px 80px -28px rgba(15,15,30,.18), 0 0 0 1px rgba(0,0,0,.02) inset;
}
body[data-theme="light"] .login-cardwrap::before{
  background:radial-gradient(circle at 0% 0%, rgba(92,140,14,.06), transparent 35%);
}
body[data-theme="light"] .login-display em{color:var(--lime)}
body[data-theme="light"] .btn-primary{
  color:#FFFFFF;
  box-shadow:0 8px 28px -10px rgba(92,140,14,.45);
}
body[data-theme="light"] .btn-primary:hover{box-shadow:0 14px 36px -10px rgba(92,140,14,.55)}
body[data-theme="light"] .toast{background:#15151B;color:#fff}
body[data-theme="light"] .toast.ok{background:var(--lime);color:#fff}
body[data-theme="light"] .preview-frame{background:#1A1A24;border-color:#2D2D3F}
body[data-theme="light"] .modal{background:rgba(20,20,28,.45)}
body[data-theme="light"] .sb-link.active{box-shadow:inset 0 0 0 1px var(--line-2)}
body[data-theme="light"] .sb-link.active i{box-shadow:0 0 8px rgba(92,140,14,.5)}
body[data-theme="light"] .skel-row{background:linear-gradient(90deg,var(--bg-2),var(--panel-2),var(--bg-2));background-size:200% 100%}
body[data-theme="light"] .table th{background:var(--bg-2)}
body[data-theme="light"] .table tr:hover td{background:var(--bg-3)}
body[data-theme="light"] .sb-avatar{color:#FFFFFF}
body[data-theme="light"] .topbar{background:linear-gradient(var(--bg) 70%, transparent)}
