/* ═══════════════════════════════════════════════════════════════════════════
   BakımSis Design System
   Spacing scale : 4 · 8 · 12 · 16 · 20 · 24 · 32
   Radius scale  : --r-sm 8px · --r-md 10px · --r-lg 12px · --r-xl 16px
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Design Tokens ─────────────────────────────────────────────────────────── */
:root {
  --r-sm : 8px;
  --r-md : 10px;
  --r-lg : 12px;
  --r-xl : 16px;
  --r-full: 9999px;

  --sp-1 : 4px;
  --sp-2 : 8px;
  --sp-3 : 12px;
  --sp-4 : 16px;
  --sp-5 : 20px;
  --sp-6 : 24px;
  --sp-8 : 32px;

  /* Semantic */
  --pad-card    : 20px;
  --pad-cell    : 12px 16px;
  --pad-input   : 10px 14px;
  --pad-btn     : 9px 16px;
  --pad-btn-sm  : 6px 12px;
  --gap-page    : 20px;
  --gap-section : 16px;
  --gap-form    : 14px;
  --input-h     : 40px;
  --sidebar-w   : 236px;
  --topbar-h    : 56px;

  color-scheme: dark;
}

/* ── Tema: Dark ─────────────────────────────────────────────────────────────── */
[data-theme="dark"] {
  --bg      : #0c0e16;
  --surface : #121520;
  --sf2     : #181c2a;
  --sf3     : #1e2338;
  --border  : rgba(255,255,255,0.07);
  --border2 : rgba(255,255,255,0.13);
  --accent  : #5b8ef0;
  --accent2 : #8b6cf7;
  --green   : #22c98a;
  --orange  : #f5a623;
  --red     : #f05252;
  --yellow  : #fbbf24;
  --text    : #e2e8f4;
  --text2   : #9aa3be;
  --muted   : #606880;
  --shadow  : 0 8px 32px rgba(0,0,0,.45);
}

/* ── Tema: Light ────────────────────────────────────────────────────────────── */
[data-theme="light"] {
  --bg      : #eef1f8;
  --surface : #ffffff;
  --sf2     : #f4f6fc;
  --sf3     : #e8ecf5;
  --border  : rgba(0,0,0,0.08);
  --border2 : rgba(0,0,0,0.14);
  --accent  : #3b6fd4;
  --accent2 : #6c44e8;
  --green   : #16a36e;
  --orange  : #d4850a;
  --red     : #d63b3b;
  --yellow  : #c8960a;
  --text    : #1a1f35;
  --text2   : #4a5275;
  --muted   : #8791ad;
  --shadow  : 0 8px 32px rgba(0,0,0,.08);
}

/* ── Reset ──────────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin:0; font-family:'Plus Jakarta Sans',sans-serif; font-size:14px; line-height:1.55;
       background:var(--bg); color:var(--text); }
h1,h2,h3,h4 { margin:0; font-weight:700; letter-spacing:-0.022em; line-height:1.25; }
p  { margin:0; }
a  { color:inherit; text-decoration:none; }
svg { flex-shrink:0; }
button, input, select, textarea { font:inherit; }

/* ── Utility ────────────────────────────────────────────────────────────────── */
.muted       { color:var(--muted); }
.text-sm     { font-size:12px; }
.text-xs     { font-size:11px; }
.fw-600      { font-weight:600; }
.fw-700      { font-weight:700; }
.mt-1        { margin-top: var(--sp-1); }
.mt-2        { margin-top: var(--sp-2); }
.mt-3        { margin-top: var(--sp-3); }
.mt-4        { margin-top: var(--sp-4); }
.hidden      { display:none; }
.card-error  { border-top:2px solid var(--red); }
.gap-4       { gap: var(--sp-4); }
.d-grid      { display:grid; }
.d-flex      { display:flex; }
.ai-center   { align-items:center; }
.jc-between  { justify-content:space-between; }
.wrap        { flex-wrap:wrap; }
.full-col    { grid-column:1/-1; }

/* ── App Shell ──────────────────────────────────────────────────────────────── */
.app-shell    { min-height:100vh; display:flex; }
.main-wrapper { flex:1; min-width:0; margin-left:var(--sidebar-w);
                display:flex; flex-direction:column; min-height:100vh; }
.page-content { flex:1; padding:var(--gap-page); display:grid;
                gap:var(--gap-page); align-content:start; }
.page-surface, .content-shell { display:grid; gap:var(--gap-section); }

/* ── Sidebar ────────────────────────────────────────────────────────────────── */
.sidebar {
  position:fixed; inset:0 auto 0 0; width:var(--sidebar-w);
  background:var(--surface); border-right:1px solid var(--border);
  display:flex; flex-direction:column; padding:var(--sp-4); gap:0; z-index:30;
  overflow-y:auto;
}

/* brand */
.sidebar-brand-block {
  display:flex; align-items:center; gap:var(--sp-3);
  padding:var(--sp-1) 0 var(--sp-3);
  border-bottom:1px solid var(--border); margin-bottom:var(--sp-3);
}
.brand-mark {
  width:36px; height:36px; border-radius:var(--r-md); display:grid; place-items:center; flex-shrink:0;
  background:linear-gradient(135deg,rgba(91,142,240,.18),rgba(139,108,247,.18));
  border:1px solid rgba(91,142,240,.25);
}
.brand-core { font-weight:800; font-size:16px; color:var(--accent); }
.nav-header strong { font-size:14px; font-weight:700; display:block; }
.nav-header span   { font-size:11px; color:var(--muted); }

/* nav */
.sidebar-nav  { display:flex; flex-direction:column; gap:2px; flex:1; }
.nav-section  { display:flex; flex-direction:column; gap:2px; }
.nav-section-title {
  font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--muted); padding:var(--sp-2) var(--sp-3) var(--sp-1);
}
.nav-item {
  display:flex; align-items:center; gap:var(--sp-2);
  padding:9px 12px; border-radius:var(--r-md);
  font-size:13px; font-weight:500; color:var(--text2);
  border:1px solid transparent; transition:background .14s,color .14s,border-color .14s;
}
.nav-item:hover    { background:var(--sf2); color:var(--text); }
.nav-item-active   { background:linear-gradient(135deg,rgba(91,142,240,.14),rgba(139,108,247,.1));
                     border-color:rgba(91,142,240,.22); color:var(--text); }
.nav-icon {
  width:28px; height:28px; border-radius:var(--r-sm); display:grid; place-items:center;
  background:var(--sf2); color:var(--text2); flex-shrink:0; transition:color .14s;
}
.nav-icon svg { width:14px; height:14px; }
.nav-item-active .nav-icon { background:rgba(91,142,240,.15); color:var(--accent); }
.nav-copy  { display:grid; gap:1px; min-width:0; }
.nav-label { font-size:13px; font-weight:600; }
.nav-meta  { font-size:11px; color:var(--muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* profile card */
.sidebar-user {
  display:flex; gap:var(--sp-2); align-items:center; margin-top:auto;
  padding:10px var(--sp-3); border-radius:var(--r-md);
  background:var(--sf2); border:1px solid var(--border);
}
.sidebar-user-avatar {
  width:32px; height:32px; border-radius:var(--r-sm); display:grid; place-items:center;
  font-weight:800; font-size:12px; background:rgba(91,142,240,.15); color:var(--accent); flex-shrink:0;
}
.sidebar-user-copy          { display:grid; gap:1px; min-width:0; }
.sidebar-user-copy strong   { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sidebar-user-copy span     { font-size:11px; color:var(--muted); }
.sidebar-footer-note        { font-size:11px; color:var(--muted); padding:var(--sp-2) 0 0;
                              text-align:center; border-top:1px solid var(--border); margin-top:var(--sp-2); }
.sidebar-overlay            { display:none; position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:20; }

/* ── Topbar ─────────────────────────────────────────────────────────────────── */
.topbar {
  height:var(--topbar-h); background:var(--surface); border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between; gap:var(--sp-3);
  padding:0 var(--sp-5); position:sticky; top:0; z-index:10;
}
.topbar-info-row  { display:flex; align-items:center; gap:var(--sp-3); min-width:0; flex:1; }
.topbar-title-block { display:grid; gap:1px; min-width:0; }
.topbar-title     { font-size:15px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.topbar-subtitle  { font-size:11px; color:var(--muted); }
.topbar-actions   { display:flex; align-items:center; gap:var(--sp-2); flex-shrink:0; }
.topbar-badge {
  display:inline-flex; align-items:center; padding:4px 10px; border-radius:var(--r-full);
  font-size:11px; font-weight:600; color:var(--text2);
  border:1px solid var(--border); background:var(--sf2); white-space:nowrap;
}
.hamburger {
  appearance:none; background:transparent; border:1px solid var(--border2);
  border-radius:var(--r-sm); padding:7px; cursor:pointer; display:none;
  color:var(--text2); flex-shrink:0;
}
.hamburger svg { width:16px; height:16px; }

/* ── Buttons ────────────────────────────────────────────────────────────────── */
.button {
  appearance:none; display:inline-flex; align-items:center; gap:var(--sp-2);
  padding:var(--pad-btn); border-radius:var(--r-sm);
  border:1px solid var(--border2); background:var(--sf2); color:var(--text);
  font:inherit; font-size:13px; font-weight:600; cursor:pointer; white-space:nowrap;
  transition:opacity .14s, background .14s;
  line-height:1;
}
.button:hover        { opacity:.82; }
.button-primary      { background:var(--accent); border-color:var(--accent); color:#fff; }
.button-secondary    { background:var(--sf2); }
.button-ghost        { background:transparent; border-color:transparent; }
.button-xs           { padding:var(--pad-btn-sm); font-size:12px; }
.button-danger       { border-color:rgba(240,82,82,.3); color:var(--red); background:transparent; }
.button-icon-wrap    { width:16px; height:16px; display:grid; place-items:center; flex-shrink:0; }
.actions, .row-actions, .row-actions-compact { display:flex; gap:var(--sp-2); flex-wrap:wrap; align-items:center; }

/* ── Cards ──────────────────────────────────────────────────────────────────── */
.card {
  background:var(--surface); border:1px solid var(--border);
  border-top:2px solid var(--accent); border-radius:var(--r-lg); padding:var(--pad-card);
}
.card + .card, .card + .table-wrap { margin-top:0; }   /* handled by parent gap */

/* section head inside card */
.section-head {
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:var(--sp-3); flex-wrap:wrap; margin-bottom:var(--sp-4);
}
.section-head-tight { margin-bottom:0; }
.section-title  { font-size:15px; font-weight:700; }
.section-note   { font-size:12px; color:var(--muted); margin-top:3px; line-height:1.5; }
.field-hint     { font-size:12px; color:var(--muted); margin-top:var(--sp-1); line-height:1.5; }

/* ── Page Hero ──────────────────────────────────────────────────────────────── */
.page-hero {
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:var(--sp-5); flex-wrap:wrap;
  padding:var(--sp-5); border-radius:var(--r-lg);
  background:linear-gradient(180deg, var(--surface) 0%, var(--sf2) 100%); border:1px solid var(--border);
  box-shadow:0 10px 30px rgba(15,23,42,.05);
}
.page-hero-rich      { border-color:var(--border2); position:relative; overflow:hidden; }
.page-hero-rich::after { content:""; position:absolute; inset:auto -60px -80px auto; width:220px; height:220px; background:radial-gradient(circle, rgba(91,142,240,.14) 0%, rgba(91,142,240,0) 68%); pointer-events:none; }
.page-hero-copy      { display:grid; gap:var(--sp-2); min-width:min(100%,520px); position:relative; z-index:1; justify-items:start; }
.page-eyebrow        { font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); }
.page-hero-title     { font-size:clamp(1.45rem,2.8vw,2.15rem); font-weight:800; letter-spacing:-.04em; line-height:1.08; text-wrap:balance; }
.page-hero-description { color:var(--muted); font-size:13px; line-height:1.6; max-width:68ch; text-wrap:pretty; }
.page-hero-actions   { display:flex; gap:var(--sp-2); flex-wrap:wrap; align-items:flex-start; flex-shrink:0; padding-top:2px; position:relative; z-index:1; }
.breadcrumb          { display:flex; gap:var(--sp-2); flex-wrap:wrap; color:var(--muted); font-size:11px; margin-bottom:var(--sp-2); position:relative; z-index:1; justify-content:flex-start; align-items:center; width:100%; }
.breadcrumb-sep      { opacity:.4; }

/* ── Stat Cards ─────────────────────────────────────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:var(--sp-3); }
.stat-card {
  display:flex; align-items:center; gap:var(--sp-3); padding:var(--sp-4);
  border-radius:var(--r-lg); border:1px solid var(--border); background:var(--surface);
}
.stat-card-icon {
  width:44px; height:44px; border-radius:var(--r-md); display:grid; place-items:center;
  flex-shrink:0; background:rgba(91,142,240,.12); color:var(--accent);
}
.stat-card-icon svg  { width:20px; height:20px; }
.stat-card-body      { display:grid; gap:3px; }
.stat-card-label     { font-size:11px; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:.06em; }
.stat-card-value     { font-size:26px; font-weight:800; letter-spacing:-.035em; line-height:1; }
.stat-card-violet .stat-card-icon { color:var(--accent2); background:rgba(139,108,247,.12); }
.stat-card-green  .stat-card-icon { color:var(--green);   background:rgba(47,143,103,.12); }
.stat-card-orange .stat-card-icon { color:var(--orange);  background:rgba(184,117,37,.12); }

/* ── Dashboard Highlights ───────────────────────────────────────────────────── */
.dashboard-highlight-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:var(--sp-3); }
.dashboard-highlight {
  padding:var(--sp-4); border-radius:var(--r-lg); border:1px solid var(--border); background:var(--surface);
  display:grid; gap:var(--sp-2);
}
.dashboard-highlight-icon {
  width:40px; height:40px; border-radius:var(--r-md); display:grid; place-items:center;
  background:rgba(91,142,240,.12); color:var(--accent);
}
.dashboard-highlight-icon svg { width:18px; height:18px; }
.dashboard-highlight-count  { font-size:28px; font-weight:800; letter-spacing:-.04em; line-height:1; }
.dashboard-highlight-title  { font-size:13px; font-weight:700; }
.dashboard-highlight-desc   { font-size:12px; color:var(--muted); line-height:1.45; }
.dashboard-highlight-accent .dashboard-highlight-icon { color:var(--accent);  background:rgba(91,142,240,.12); }
.dashboard-highlight-violet .dashboard-highlight-icon { color:var(--accent2); background:rgba(139,108,247,.12); }
.dashboard-highlight-green  .dashboard-highlight-icon { color:var(--green);   background:rgba(47,143,103,.12); }
.dashboard-highlight-orange .dashboard-highlight-icon { color:var(--orange);  background:rgba(184,117,37,.12); }

/* ── Hero Metric Row ────────────────────────────────────────────────────────── */
.hero-metric-row  { display:flex; flex-wrap:wrap; gap:var(--sp-2); }
.panel-stat-pill  {
  display:flex; align-items:center; gap:var(--sp-3); padding:10px var(--sp-4);
  border-radius:var(--r-md); border:1px solid var(--border); background:var(--surface);
}
.panel-stat-pill span   { font-size:12px; color:var(--muted); font-weight:500; }
.panel-stat-pill strong { font-size:14px; font-weight:700; }

/* ── Quick Links ────────────────────────────────────────────────────────────── */
.quick-link-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:var(--sp-3); }
.quick-link {
  display:flex; gap:var(--sp-3); align-items:flex-start; padding:var(--sp-4);
  border-radius:var(--r-lg); border:1px solid var(--border); background:var(--sf2);
  transition:border-color .14s, background .14s;
}
.quick-link:hover       { border-color:rgba(91,142,240,.3); background:var(--sf3); }
.quick-link-icon        { width:34px; height:34px; border-radius:var(--r-md); display:grid; place-items:center;
                          background:rgba(91,142,240,.12); color:var(--accent); flex-shrink:0; }
.quick-link-icon svg    { width:16px; height:16px; }
.quick-link-copy        { display:grid; gap:3px; }
.quick-link-copy strong { font-size:13px; font-weight:700; }
.quick-link-copy span   { font-size:12px; color:var(--muted); }

/* ── Dashboard Panel Grid ───────────────────────────────────────────────────── */
.dashboard-panel-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:var(--sp-4); }

/* ── Tables ─────────────────────────────────────────────────────────────────── */
.table-wrap { overflow-x:auto; border-radius:var(--r-lg); border:1px solid var(--border); background:var(--surface); }
.table { width:100%; border-collapse:collapse; }
.table th {
  padding:var(--pad-cell); color:var(--muted); font-size:11px; font-weight:700;
  letter-spacing:.07em; text-transform:uppercase; border-bottom:1px solid var(--border);
  white-space:nowrap; text-align:left; background:var(--sf2);
}
.table td { padding:var(--pad-cell); border-bottom:1px solid var(--border); font-size:13px; vertical-align:middle; }
.table tr:last-child td          { border-bottom:none; }
.table tbody tr:hover td         { background:var(--sf2); }
.row-meta-block                  { display:grid; gap:3px; }
.row-meta-block span             { color:var(--muted); font-size:12px; }

/* ── Badges ─────────────────────────────────────────────────────────────────── */
.badge          { display:inline-flex; align-items:center; padding:3px 10px; border-radius:var(--r-full);
                  font-size:11px; font-weight:700; border:1px solid transparent; white-space:nowrap; }
.badge-success  { background:rgba(47,143,103,.14); color:var(--green); }
.badge-danger   { background:rgba(240,82,82,.14);  color:var(--red); }
.badge-info     { background:rgba(91,142,240,.14); color:var(--accent); }
.badge-warning  { background:rgba(251,191,36,.14); color:var(--yellow); }
.badge-neutral  { background:rgba(148,163,184,.1); color:var(--text2); border-color:var(--border); }

/* ── Forms ──────────────────────────────────────────────────────────────────── */
.form-layout  { display:grid; grid-template-columns:minmax(0,2fr) minmax(0,1fr);
                gap:var(--sp-5); align-items:start; }
.form-main    { display:grid; gap:var(--sp-4); }
.form-sidebar { display:grid; gap:var(--sp-4); position:sticky; top:calc(var(--topbar-h) + 20px); }
.form-grid    { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:var(--gap-form); }
.form-grid .full { grid-column:1/-1; }
.label  { display:block; margin-bottom:var(--sp-1); font-size:12px; font-weight:600; color:var(--text2); }
.input, .select, .textarea {
  width:100%; background:var(--sf2); border:1px solid var(--border2);
  border-radius:var(--r-sm); color:var(--text); padding:var(--pad-input);
  outline:none; transition:border-color .14s, background .14s;
}
.input, .select { height:var(--input-h); }
.input:focus, .select:focus, .textarea:focus { border-color:rgba(91,142,240,.45); background:var(--surface); }
.textarea         { min-height:110px; resize:vertical; height:auto; }
.checkbox-chip    { display:inline-flex; align-items:center; gap:var(--sp-2); padding:7px 12px;
                    border-radius:var(--r-full); border:1px solid var(--border);
                    background:var(--sf2); color:var(--text2); font-size:13px; }
.checkbox-chip input { accent-color:var(--accent); }

/* ── Info / Key-Value Grid ──────────────────────────────────────────────────── */
.detail-key-value-grid { display:grid; gap:0; }
.detail-key-value {
  display:flex; justify-content:space-between; align-items:center;
  gap:var(--sp-3); padding:10px 0; border-bottom:1px solid var(--border);
}
.detail-key-value:last-child { border-bottom:none; }
.detail-key-value span   { font-size:12px; color:var(--muted); flex-shrink:0; }
.detail-key-value strong { font-size:13px; font-weight:600; text-align:right; }
.grid-2 { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:var(--sp-4); }

/* ── Tabs ───────────────────────────────────────────────────────────────────── */
.tabs     { display:grid; gap:var(--sp-4); }
.tab-list {
  display:flex; gap:var(--sp-1); padding:var(--sp-1);
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg);
  overflow-x:auto; scrollbar-width:none;
}
.tab-list::-webkit-scrollbar { display:none; }
.tab-btn {
  flex-shrink:0; display:inline-flex; align-items:center; gap:var(--sp-2);
  padding:8px 16px; border-radius:var(--r-md);
  font-size:13px; font-weight:600; border:1px solid transparent;
  background:transparent; color:var(--text2); cursor:pointer; white-space:nowrap;
  transition:all .14s;
}
.tab-btn svg           { width:14px; height:14px; opacity:.7; }
.tab-btn:hover         { background:var(--sf2); color:var(--text); }
.tab-btn.tab-active    { background:var(--accent); border-color:var(--accent); color:#fff; }
.tab-btn.tab-active svg{ opacity:1; }
.tab-count             { display:inline-flex; align-items:center; justify-content:center;
                         min-width:20px; height:18px; padding:0 6px; border-radius:var(--r-full);
                         font-size:11px; font-weight:700; background:rgba(255,255,255,.18); }
.tab-btn:not(.tab-active) .tab-count { background:var(--sf3); color:var(--text2); }
.tab-panel             { display:none; }
.tab-panel.tab-active  { display:grid; gap:var(--sp-4); }

/* ── Empty State ────────────────────────────────────────────────────────────── */
.empty-state {
  padding:32px var(--sp-5); text-align:center; border:1px dashed var(--border2);
  border-radius:var(--r-md); color:var(--muted); font-size:13px;
}
.empty-state svg { display:block; margin:0 auto var(--sp-3); opacity:.35; width:36px; height:36px; }

/* ── Auth ───────────────────────────────────────────────────────────────────── */
.auth-page { min-height:100vh; display:grid; place-items:center; padding:var(--sp-6); background:var(--bg); }
.auth-card {
  width:min(100%, 420px); background:var(--surface); border:1px solid var(--border);
  border-top:2px solid var(--accent); border-radius:var(--r-lg); padding:var(--sp-6);
}
.auth-grid { display:grid; gap:var(--sp-4); }

/* ── Toolbar ────────────────────────────────────────────────────────────────── */
.toolbar { display:flex; align-items:center; justify-content:space-between; gap:var(--sp-3); flex-wrap:wrap; }

/* ── Worker Shell ───────────────────────────────────────────────────────────── */
.worker-shell   { min-height:100vh; background:var(--bg); display:flex; flex-direction:column; }
.worker-topbar  {
  height:var(--topbar-h); background:var(--surface); border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between; gap:var(--sp-3);
  padding:0 var(--sp-4); position:sticky; top:0; z-index:10;
}
.worker-content {
  flex:1; padding:var(--sp-4); padding-bottom:80px;
  max-width:640px; margin:0 auto; width:100%;
  display:grid; gap:var(--sp-3); align-content:start;
}

/* Worker bottom nav */
.worker-nav {
  position:fixed; bottom:0; left:0; right:0; z-index:20;
  background:var(--surface); border-top:1px solid var(--border);
  display:flex; padding:var(--sp-2) var(--sp-4) calc(env(safe-area-inset-bottom,0px) + var(--sp-2));
  gap:var(--sp-1);
}
.worker-nav-item {
  flex:1; display:flex; flex-direction:column; align-items:center; gap:3px;
  padding:var(--sp-2); border-radius:var(--r-md); font-size:11px; font-weight:600;
  color:var(--text2); transition:all .14s;
}
.worker-nav-item svg       { width:20px; height:20px; }
.worker-nav-item.wni-active { color:var(--accent); background:rgba(91,142,240,.1); }

/* Worker task cards */
.worker-task-card {
  display:block; padding:var(--sp-4) var(--sp-5); border-radius:var(--r-lg);
  background:var(--surface); border:1px solid var(--border); border-left:3px solid var(--accent);
  transition:border-color .14s, background .14s;
}
.worker-task-card:hover   { background:var(--sf2); border-left-color:var(--accent2); }
.worker-task-card h3      { font-size:15px; font-weight:700; margin-bottom:var(--sp-1); }
.worker-task-card .meta   { font-size:12px; color:var(--muted); }

/* Card header row utility */
.card-header-row { display:flex; justify-content:space-between; align-items:flex-start; gap:var(--sp-3); flex-wrap:wrap; }
.card-header-row + .checklist-progress { margin-top:var(--sp-4); }
.back-link       { font-size:12px; color:var(--muted); }
.textarea-note   { min-height:70px; }

/* Checklist */
.checklist-list   { display:grid; gap:var(--sp-3); }
.checklist-item   {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:var(--sp-4); display:grid; gap:var(--sp-3);
}
.checklist-item-header { display:flex; justify-content:space-between; align-items:flex-start; gap:var(--sp-3); }
.checklist-item-text   { font-size:14px; font-weight:600; flex:1; }
.checklist-actions     { display:flex; gap:var(--sp-2); flex-wrap:wrap; }
.checklist-media       { display:grid; gap:var(--sp-2); }
.upload-status         { font-size:12px; color:var(--muted); }
.checklist-complete-bar {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:var(--sp-4); display:flex; align-items:center;
  justify-content:space-between; gap:var(--sp-3); flex-wrap:wrap;
}
.checklist-progress { display:flex; align-items:center; gap:var(--sp-3); }
.progress-bar       { width:100px; height:5px; background:var(--sf3); border-radius:var(--r-full); overflow:hidden; }
.progress-fill      { height:100%; background:var(--accent); border-radius:var(--r-full); transition:width .3s; }
.progress-text      { font-size:12px; color:var(--muted); font-weight:600; }

/* ── Aside / Sidebar Blocks ─────────────────────────────────────────────────── */
.aside-action-row { margin-top:var(--sp-3); }

/* ── Firm Hub ───────────────────────────────────────────────────────────────── */
.firm-hub-grid { display:grid; grid-template-columns:minmax(0,1.6fr) minmax(320px,.9fr); gap:var(--sp-4); align-items:start; }
.firm-hub-main,
.firm-hub-side { display:grid; gap:var(--sp-4); }
.firm-subtabs { display:grid; gap:var(--sp-3); }
.firm-profile-stack { display:grid; gap:var(--sp-4); }
.firm-document-list { display:grid; gap:var(--sp-3); }
.firm-document-row {
  display:flex; justify-content:space-between; align-items:flex-start; gap:var(--sp-3);
  padding:var(--sp-4); border:1px solid var(--border); border-radius:var(--r-md); background:var(--sf2);
}
.firm-document-meta { display:grid; gap:4px; }
.firm-document-title { font-size:14px; font-weight:700; }
.firm-document-note { font-size:12px; color:var(--muted); line-height:1.5; }
.firm-document-actions { display:flex; gap:var(--sp-2); flex-wrap:wrap; }
.firm-finance-summary { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:var(--sp-3); }
.firm-amount { font-weight:700; }
.firm-positive { color:var(--green); }
.firm-negative { color:var(--red); }
.form-upload-grid { display:grid; gap:var(--sp-3); }
.file-hint { font-size:12px; color:var(--muted); }
.service-item-stack { display:grid; gap:var(--sp-3); }
.service-item-card { background:var(--sf2); border:1px solid var(--border); border-radius:var(--r-md); padding:var(--sp-4); display:grid; gap:var(--sp-3); }
.service-item-head { display:flex; align-items:center; justify-content:space-between; gap:var(--sp-3); }
.service-total-bar { display:flex; justify-content:space-between; align-items:center; gap:var(--sp-3); padding:var(--sp-3) var(--sp-4); border:1px solid var(--border); border-radius:var(--r-md); background:var(--surface); }
.service-total-value { font-size:18px; font-weight:800; letter-spacing:-.03em; }
.catalog-template { display:none; }
.service-upload-list { display:grid; gap:var(--sp-2); }
.service-upload-row { display:flex; align-items:center; gap:var(--sp-2); flex-wrap:wrap; }
.service-upload-chip { display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:var(--r-full); background:var(--sf3); font-size:12px; color:var(--text2); }
.service-upload-status { font-size:12px; color:var(--muted); }
.service-meta-grid { display:grid; gap:var(--sp-2); }
.service-summary-note { font-size:12px; color:var(--muted); line-height:1.5; }
.service-inline-list { display:grid; gap:var(--sp-2); }
.service-inline-item { padding:10px 12px; border:1px solid var(--border); border-radius:var(--r-md); background:var(--sf2); }
.service-inline-head { display:flex; align-items:center; justify-content:space-between; gap:var(--sp-3); margin-bottom:6px; }
.service-inline-meta { font-size:12px; color:var(--muted); display:flex; gap:10px; flex-wrap:wrap; }
.service-inline-note { font-size:12px; color:var(--text2); margin-top:6px; }
.service-inline-actions { display:flex; gap:var(--sp-2); flex-wrap:wrap; margin-top:8px; }
.service-inline-actions a { font-size:12px; }
.service-detail-stack { display:grid; gap:var(--sp-3); }
.service-detail-card { padding:var(--sp-4); border:1px solid var(--border); border-radius:var(--r-md); background:var(--surface); }
.service-detail-card h4 { margin-bottom:8px; }
.service-detail-kv { display:grid; gap:6px; font-size:12px; color:var(--text2); }
.service-detail-kv span { color:var(--muted); }
.service-detail-gallery { display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.service-detail-gallery a { font-size:12px; }
.service-item-divider { height:1px; background:var(--border); margin:4px 0; }
.service-form-block { display:grid; gap:var(--sp-4); }
.service-hidden { display:none; }
.service-upload-input { height:auto; }
.service-item-count { white-space:nowrap; }
.service-item-total { white-space:nowrap; }
.service-detail-empty { font-size:12px; color:var(--muted); }
.service-detail-grid { display:grid; gap:var(--sp-3); }
.service-card-shell { display:grid; gap:var(--sp-3); }
.service-upload-actions { display:flex; gap:var(--sp-2); align-items:center; flex-wrap:wrap; }
.service-item-card .form-grid { align-items:start; }
.service-gallery-link { font-size:12px; }
.service-gallery-link:hover { text-decoration:underline; }
.service-badge-row { display:flex; gap:var(--sp-2); flex-wrap:wrap; }
.service-upload-name { max-width:240px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.service-upload-muted { color:var(--muted); font-size:12px; }
.service-media-preview { display:flex; flex-wrap:wrap; gap:8px; }
.service-media-preview img { width:64px; height:64px; object-fit:cover; border-radius:var(--r-sm); border:1px solid var(--border); }
.service-table-note { font-size:12px; color:var(--muted); }
.service-actions-end { justify-content:flex-end; }
.service-form-inline-script { display:none; }
.service-item-empty { font-size:12px; color:var(--muted); }
.service-inline-wrap { display:grid; gap:var(--sp-3); }
.service-upload-tag { display:inline-flex; align-items:center; gap:6px; }
.service-meta-soft { color:var(--muted); font-size:12px; }
.service-text-strong { font-weight:700; }
.service-grid-two { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:var(--sp-3); }
@media (max-width:767px) { .service-grid-two { grid-template-columns:1fr; } }
.detail-page-stack { display:grid; gap:var(--sp-4); }
.detail-actions { display:flex; gap:var(--sp-2); flex-wrap:wrap; }
.checklist-readonly-item { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:var(--sp-4); display:grid; gap:var(--sp-3); }
.checklist-readonly-head { display:flex; align-items:flex-start; justify-content:space-between; gap:var(--sp-3); }
.checklist-readonly-meta { display:flex; gap:var(--sp-2); flex-wrap:wrap; }
.checklist-media-links { display:flex; flex-wrap:wrap; gap:8px; }
.checklist-media-links a { font-size:12px; }
.checklist-info-grid { display:grid; gap:var(--sp-3); grid-template-columns:repeat(2,minmax(0,1fr)); }
@media (max-width:767px) { .checklist-info-grid { grid-template-columns:1fr; } }

/* ── Web Site Admin ─────────────────────────────────────────────────────────── */
.web-admin-layout{display:grid;grid-template-columns:1fr;gap:var(--sp-5);align-items:start}
.web-cms-nav{position:static;display:grid;gap:10px;border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:12px}
.web-cms-nav-head{display:flex;justify-content:space-between;gap:12px;align-items:center;border-bottom:1px solid var(--border);padding-bottom:10px}
.web-cms-nav-head strong{display:block;font-size:15px;font-weight:850;letter-spacing:-.025em}.web-cms-nav-head span{display:block;margin-top:2px;font-size:11px;color:var(--muted)}
.web-cms-lang{display:flex;gap:6px;flex-shrink:0}.web-cms-tabs{display:flex;gap:7px;overflow-x:auto;padding-bottom:2px;scrollbar-width:thin}
.web-cms-tab{display:grid;gap:2px;min-width:132px;border:1px solid var(--border);border-radius:13px;background:var(--sf2);padding:9px 10px;color:var(--text2);transition:border-color .16s,background .16s}.web-cms-tab:hover{border-color:rgba(91,142,240,.32);background:var(--sf3)}.web-cms-tab.active{border-color:rgba(91,142,240,.52);background:rgba(91,142,240,.13);color:var(--text)}.web-cms-tab strong{font-size:12px;font-weight:850}.web-cms-tab span{font-size:10px;line-height:1.25;color:var(--muted)}
.web-cms-pages{display:grid;gap:6px}.web-cms-pages>span{font-size:10px;text-transform:uppercase;letter-spacing:.12em;font-weight:850;color:var(--muted)}.web-cms-pages>div{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;scrollbar-width:thin}
.web-page-link{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-radius:11px;border:1px solid var(--border);background:var(--sf2);font-size:11px;font-weight:750;color:var(--text2);white-space:nowrap}
.web-page-link:hover,.web-page-link.active{border-color:rgba(91,142,240,.35);background:rgba(91,142,240,.12);color:var(--text)}
.web-lang-row{display:flex;gap:8px;margin:4px 0 8px}
.web-admin-main{min-width:0;width:100%;padding:28px;border-radius:22px}
.web-admin-side .web-lang-row{margin-left:auto;margin-right:0}
.web-admin-side .web-lang-row+.web-page-link{margin-left:0}
.web-quote-list{display:grid;gap:var(--sp-3)}
.web-quote-card{display:grid;gap:var(--sp-3);padding:var(--sp-4);border:1px solid var(--border);border-radius:var(--r-lg);background:var(--sf2)}
.web-quote-card-head{display:flex;justify-content:space-between;gap:var(--sp-3);align-items:flex-start}
.web-quote-card-head span{display:block;font-size:11px;color:var(--muted);font-weight:700;margin-bottom:3px}
.web-quote-card-head strong{display:block;font-size:16px;font-weight:800;color:var(--text)}
.web-quote-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.web-quote-grid div{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);padding:10px;min-width:0}
.web-quote-grid span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700;margin-bottom:5px}
.web-quote-grid b{display:block;font-size:13px;font-weight:650;color:var(--text);overflow-wrap:anywhere}
.web-quote-message{border-left:3px solid var(--accent);border-radius:var(--r-sm);background:var(--surface);padding:12px;font-size:13px;color:var(--text2);line-height:1.55}
.web-field-form{display:grid;gap:var(--sp-4)}
.web-live-hero{display:grid;grid-template-columns:1fr 340px;gap:var(--sp-4);align-items:stretch;background:linear-gradient(135deg,var(--surface),var(--sf2))}
.web-live-copy{display:grid;align-content:center;gap:var(--sp-2)}
.web-live-copy span,.web-mini-preview span{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.web-live-copy h2{font-size:clamp(1.6rem,3vw,2.5rem);font-weight:800;line-height:1.05;letter-spacing:-.05em}
.web-live-copy p,.web-mini-preview p{color:var(--muted);font-size:13px;line-height:1.55}
.web-live-media,.web-mini-media{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--sf3);display:grid;place-items:center;overflow:hidden;min-height:190px;color:var(--muted);font-size:12px;font-weight:700}
.web-live-media img,.web-mini-media img{width:100%;height:100%;object-fit:cover}
.web-block-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--sp-2)}
.web-block-toggle{display:flex;align-items:center;gap:var(--sp-2);border:1px solid var(--border);border-radius:var(--r-md);background:var(--sf2);padding:10px 12px;font-size:13px;font-weight:700;color:var(--text2)}
.web-block-toggle input{accent-color:var(--accent)}
.web-section-list{display:grid;gap:var(--sp-3)}
.web-section-editor{border:1px solid var(--border);border-radius:var(--r-md);background:var(--sf2);overflow:hidden}
.web-section-editor summary{cursor:pointer;padding:12px 14px;font-size:13px;font-weight:750;color:var(--text);border-bottom:1px solid var(--border)}
.web-section-editor:not([open]) summary{border-bottom:0}
.web-section-editor .form-grid{padding:14px}
.web-section-editor summary{display:flex;align-items:center;gap:10px}
.web-section-editor summary span{font-size:11px;color:var(--muted);font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.web-section-editor summary strong{font-size:14px;color:var(--text)}
.web-visual-row{display:grid;grid-template-columns:300px 1fr;gap:var(--sp-3);padding:14px}
.web-mini-preview{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);overflow:hidden;display:grid;grid-template-rows:150px auto}
.web-mini-preview>div:last-child{padding:12px;display:grid;gap:6px}
.web-mini-preview strong{font-size:15px;font-weight:800;line-height:1.15}
.web-advanced-json{margin-top:var(--sp-4);border:1px solid var(--border);border-radius:var(--r-lg);background:var(--sf2);overflow:hidden}
.web-advanced-json>summary{cursor:pointer;padding:14px 16px;font-size:13px;font-weight:800;color:var(--text)}
.web-advanced-json .web-json-form{padding:0 16px 16px}
.web-menu-list{display:grid;gap:var(--sp-2)}
.web-menu-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2);align-items:center}
.web-overview-hero{display:flex;justify-content:space-between;gap:16px;align-items:center;border:1px solid var(--border);border-radius:18px;background:var(--sf2);padding:18px 20px;margin-bottom:14px}.web-overview-hero span{font-size:10px;text-transform:uppercase;letter-spacing:.14em;font-weight:850;color:var(--accent)}.web-overview-hero h2{margin-top:5px;font-size:24px;line-height:1.05;font-weight:850;letter-spacing:-.04em}.web-overview-hero p{margin-top:7px;max-width:720px;color:var(--text2);font-size:12px;line-height:1.55}.web-overview-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;flex-shrink:0}.web-overview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.web-overview-card{display:grid;gap:5px;min-height:96px;border:1px solid var(--border);border-radius:16px;background:var(--sf2);padding:15px;transition:border-color .16s,background .16s}.web-overview-card:hover{border-color:rgba(91,142,240,.38);background:var(--sf3)}.web-overview-card strong{font-size:15px;font-weight:850;letter-spacing:-.025em}.web-overview-card span{font-size:12px;line-height:1.45;color:var(--muted)}
.web-media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--sp-3)}
.web-media-card{border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--sf2);margin:0}
.web-media-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.web-media-card figcaption{padding:8px 10px;font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.web-json-form{display:grid;gap:var(--sp-3)}
.web-json-form textarea{width:100%;min-height:620px;border:1px solid var(--border2);border-radius:var(--r-lg);background:#080a10;color:#e2e8f4;padding:16px;font:12px/1.6 ui-monospace,SFMono-Regular,Consolas,monospace;outline:none;resize:vertical}
.web-json-form textarea:focus{border-color:rgba(91,142,240,.55);box-shadow:0 0 0 3px rgba(91,142,240,.12)}
.web-json-actions{position:sticky;bottom:0;margin:0 calc(var(--pad-card) * -1) calc(var(--pad-card) * -1);padding:12px var(--pad-card);border-top:1px solid var(--border);background:rgba(18,21,32,.86);backdrop-filter:blur(12px);border-radius:0 0 var(--r-lg) var(--r-lg)}

/* ── Responsive 1280px ──────────────────────────────────────────────────────── */
@media (max-width:1280px) {
  .stats-grid,
  .dashboard-highlight-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
}

/* ── Responsive 1023px ──────────────────────────────────────────────────────── */
@media (max-width:1023px) {
  .sidebar          { transform:translateX(-110%); transition:transform .22s ease; }
  .sidebar.is-open  { transform:translateX(0); }
  .sidebar-overlay.is-open { display:block; }
  .main-wrapper     { margin-left:0; }
  .hamburger        { display:inline-flex; }
  .form-layout      { grid-template-columns:1fr; }
  .form-sidebar     { position:static; }
  .dashboard-panel-grid { grid-template-columns:1fr; }
  .firm-hub-grid    { grid-template-columns:1fr; }
  .firm-finance-summary { grid-template-columns:1fr; }
  .web-admin-layout { grid-template-columns:1fr; }
  .web-cms-nav{position:static;border-radius:16px;padding:10px}
  .web-cms-tabs{display:flex}
  .web-quote-grid   { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .web-overview-hero{display:grid;align-items:start}.web-overview-actions{justify-content:flex-start}.web-overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .web-live-hero{grid-template-columns:1fr}
  .web-live-media{min-height:220px}
  .web-visual-row{grid-template-columns:1fr}
  .web-mini-preview{grid-template-rows:180px auto}
}

/* ── Responsive 767px ───────────────────────────────────────────────────────── */
@media (max-width:767px) {
  .page-content       { padding:var(--sp-3); gap:var(--sp-3); }
  .stats-grid,
  .dashboard-highlight-grid,
  .quick-link-grid,
  .form-grid          { grid-template-columns:1fr; }
  .grid-2             { grid-template-columns:1fr; }
  .page-hero          { flex-direction:column; }
  .tab-btn            { padding:7px 12px; font-size:12px; }
  .topbar             { padding:0 var(--sp-3); }
  .web-quote-card-head{display:grid;}
  .web-menu-row{grid-template-columns:1fr;}
  .web-quote-grid     { grid-template-columns:1fr; }
  .web-json-form textarea{min-height:420px;font-size:11px;padding:12px;}
  .web-json-actions .button{width:100%;justify-content:center;}
  .web-block-grid{grid-template-columns:1fr}
  .web-cms-nav-head{display:grid}
  .web-cms-tabs{display:flex}
  .web-overview-grid{grid-template-columns:1fr}.web-overview-hero{padding:16px;border-radius:16px}
  .web-live-media{min-height:170px}
  .web-section-editor .form-grid{padding:10px}
  .web-visual-row{padding:10px}
}
