/* ─────────────────────────────────────────────────────────────
   Super Agency System — MVP Shell (sidebar + topbar)
   Shared structure across all internal app screens.
   ───────────────────────────────────────────────────────────── */

.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* ───── SIDEBAR ───── */
.side{
  background:var(--cream-2);border-left:1px solid var(--line);
  padding:18px 12px;position:sticky;top:0;height:100vh;overflow-y:auto;
  display:flex;flex-direction:column;gap:18px;
}
.side-logo{
  display:inline-flex;align-items:baseline;gap:6px;direction:ltr;
  font-family:var(--font-serif);font-weight:500;font-size:20px;
  letter-spacing:-0.025em;padding:6px 10px;line-height:1;color:var(--ink);
}
.side-logo em{font-style:italic;color:var(--tangerine);position:relative;display:inline-block}
.side-logo em::after{
  content:"";position:absolute;left:-2px;right:-2px;bottom:-3px;height:5px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 10' preserveAspectRatio='none'%3E%3Cpath d='M2 6 Q 50 1 100 5 T 198 4' stroke='%23FFD23F' stroke-width='5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-size:100% 100%;background-repeat:no-repeat;
}

/* Client switcher */
.switcher{
  display:flex;align-items:center;gap:10px;padding:8px 10px;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);
  cursor:pointer;transition:all .15s;
}
.switcher:hover{border-color:var(--line-2);background:var(--paper-2)}
.switcher .sw-thumb{
  width:30px;height:30px;border-radius:8px;background:var(--tangerine-soft);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);
  font-weight:600;font-size:13px;color:var(--tangerine-ink);flex-shrink:0;
}
.switcher .sw-info{flex:1;min-width:0}
.switcher .sw-label{font-size:9px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted);font-weight:600;line-height:1}
.switcher .sw-name{font-size:13px;font-weight:600;color:var(--ink);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.switcher .sw-caret{flex-shrink:0;width:14px;height:14px;stroke:var(--muted);stroke-width:2;fill:none}

.side-group{display:flex;flex-direction:column;gap:1px}
.side-label{font-size:9px;text-transform:uppercase;letter-spacing:0.14em;color:var(--muted);padding:8px 12px 4px;font-weight:600}
.side-item{
  display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-md);
  font-size:13px;color:var(--ink-2);transition:all .15s;font-weight:500;position:relative;
}
.side-item:hover{background:rgba(255,253,248,0.6);color:var(--ink)}
.side-item.active{background:var(--ink);color:var(--cream)}
.side-item .ic{width:17px;height:17px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.8}
.side-item .count{margin-inline-start:auto;font-size:10px;padding:1px 6px;border-radius:999px;background:var(--tangerine);color:#fff;font-weight:700;font-variant-numeric:tabular-nums}
.side-item.active .count{background:var(--butter);color:var(--ink)}
.side-item .badge-dot{margin-inline-start:auto;width:6px;height:6px;border-radius:50%;background:var(--tangerine)}

.side-footer{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--r-md);background:var(--paper);border:1px solid var(--line)}
.side-me{flex:1;min-width:0}
.side-me .nm{font-size:12px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-me .rl{font-size:10px;color:var(--muted)}
.side-me .rl .role-pill{display:inline-block;padding:1px 5px;background:var(--cream-2);border-radius:3px;font-weight:600;color:var(--ink-2);font-size:9px;letter-spacing:.04em;text-transform:uppercase;margin-inline-end:3px}

/* ───── MAIN ───── */
.main{padding:0;max-width:none;width:100%;display:flex;flex-direction:column;min-width:0}

/* ───── TOPBAR ───── */
.top{
  display:flex;align-items:center;gap:16px;
  padding:14px 28px;background:var(--cream);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:var(--z-top);backdrop-filter:blur(6px);
}
.crumbs{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted)}
.crumbs .sep{color:var(--muted-2)}
.crumbs .here{color:var(--ink);font-weight:600}
.search{flex:1;max-width:420px;position:relative}
.search input{
  width:100%;background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r-full);
  padding:9px 38px 9px 14px;font-family:inherit;font-size:13px;color:var(--ink);transition:all .15s;
}
.search input:focus{outline:none;border-color:var(--ink);background:var(--paper-2)}
.search input::placeholder{color:var(--muted-2)}
.search .sicon{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:15px;height:15px;stroke:var(--muted);stroke-width:2;fill:none}
.search .kbd{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:10px;color:var(--muted);background:var(--cream-2);padding:2px 6px;border-radius:4px;border:1px solid var(--line)}

.top-actions{display:flex;align-items:center;gap:6px;margin-inline-start:auto}
.icon-btn{
  width:36px;height:36px;border-radius:var(--r-md);display:inline-flex;align-items:center;justify-content:center;
  background:transparent;color:var(--ink-2);transition:all .15s;position:relative;
}
.icon-btn:hover{background:var(--paper);color:var(--ink)}
.icon-btn svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.8;fill:none}
.icon-btn .nb{position:absolute;top:6px;left:6px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--tangerine);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--cream);font-variant-numeric:tabular-nums}

.user-menu{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 6px;border-radius:var(--r-full);transition:all .15s;cursor:pointer}
.user-menu:hover{background:var(--paper)}
.user-menu .nm{font-size:12px;font-weight:600;color:var(--ink);line-height:1.2}
.user-menu .rl{font-size:10px;color:var(--muted);line-height:1.2}
.user-menu .info{text-align:start}

/* ───── PAGE BODY ───── */
.page{padding:24px 28px 40px;flex:1;min-width:0}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px;flex-wrap:wrap}
.page-head h1{font-family:var(--font-serif);font-weight:500;font-size:30px;letter-spacing:-0.02em;line-height:1.1;color:var(--ink)}
.page-head .sub{font-size:13px;color:var(--muted);margin-top:6px;max-width:560px;line-height:1.5}
.page-head .actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* ───── SECTION TITLE ───── */
.sec-title{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:14px}
.sec-title h2{font-family:var(--font-serif);font-weight:500;font-size:18px;letter-spacing:-0.015em;color:var(--ink)}
.sec-title .meta{font-size:11px;color:var(--muted)}

/* ───── KPI ───── */
.kpi{padding:18px;display:flex;flex-direction:column;gap:10px}
.kpi .lbl{font-size:10px;text-transform:uppercase;letter-spacing:0.14em;color:var(--muted);font-weight:600}
.kpi .v{font-family:var(--font-serif);font-weight:500;font-size:32px;letter-spacing:-0.02em;color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
.kpi .delta{font-size:11px;color:var(--muted)}
.kpi .delta.up{color:var(--sage-ink)}
.kpi .delta.down{color:var(--rose-ink)}

/* ───── TABLE ───── */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl thead th{
  text-align:start;padding:10px 14px;font-size:10px;text-transform:uppercase;letter-spacing:0.12em;
  color:var(--muted);font-weight:600;border-bottom:1px solid var(--line-2);background:var(--paper-2);
  position:sticky;top:0;z-index:1;
}
.tbl tbody td{padding:12px 14px;border-bottom:1px solid var(--line);color:var(--ink-2);vertical-align:middle}
.tbl tbody tr:hover{background:var(--paper-3)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl .num{text-align:end;font-variant-numeric:tabular-nums}
.tbl .name{font-weight:600;color:var(--ink);font-size:13px}
.tbl .sub{font-size:11px;color:var(--muted);margin-top:2px}

/* ───── DRAWER ───── */
.drawer{
  position:fixed;top:0;bottom:0;inset-inline-start:auto;inset-inline-end:0;width:480px;max-width:100vw;
  background:var(--paper);border-inline-start:1px solid var(--line-2);box-shadow:var(--sh-pop);
  z-index:var(--z-drawer);display:flex;flex-direction:column;
}
.drawer-head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.drawer-body{flex:1;overflow-y:auto;padding:20px 22px}

/* ───── EMPTY/ERROR/DENIED illustrations (text-based) ───── */
.state{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:48px 24px;gap:14px;
}
.state .glyph{
  width:64px;height:64px;border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;
  background:var(--cream-2);color:var(--ink-2);
}
.state .glyph svg{width:30px;height:30px;stroke:currentColor;stroke-width:1.6;fill:none}
.state h3{font-family:var(--font-serif);font-weight:500;font-size:20px;letter-spacing:-0.015em;color:var(--ink)}
.state p{font-size:13px;color:var(--muted);max-width:380px;line-height:1.6}
.state-empty .glyph{background:var(--cream-2);color:var(--muted)}
.state-error .glyph{background:var(--rose-soft);color:var(--rose-ink)}
.state-denied .glyph{background:var(--amber-soft);color:var(--amber-ink)}
.state-loading .glyph{background:var(--sky-soft);color:var(--sky-ink)}
