/* ═══════════════════════════════════════════════════════════════════════════
   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   : 276px;
  --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-color:rgba(240,82,82,.3); }
.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;
  scrollbar-gutter:stable;
  scrollbar-width:thin;
  scrollbar-color:rgba(154,163,190,.34) transparent;
}
.sidebar::-webkit-scrollbar { width:8px; }
.sidebar::-webkit-scrollbar-track { background:transparent; }
.sidebar::-webkit-scrollbar-thumb {
  background:rgba(154,163,190,.28);
  border:2px solid var(--surface);
  border-radius:var(--r-full);
}
.sidebar::-webkit-scrollbar-thumb:hover { background:rgba(154,163,190,.48); }

/* 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 var(--border);
}
.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:grid; gap:8px; flex:1; align-content:start; padding-bottom:var(--sp-3); }
.nav-section  {
  display:block; overflow:hidden; border:1px solid var(--border);
  border-radius:var(--r-md); background:var(--sf2);
}
.nav-section-summary {
  display:flex; align-items:center; justify-content:space-between; gap:var(--sp-2);
  padding:9px 10px; cursor:pointer; list-style:none; user-select:none;
}
.nav-section-summary::-webkit-details-marker { display:none; }
.nav-section-summary::marker { content:""; }
.nav-section-title {
  font-size:10px; font-weight:800; letter-spacing:.11em; text-transform:uppercase;
  color:var(--muted); padding:0;
}
.nav-section-chevron {
  width:18px; height:18px; display:grid; place-items:center; color:var(--muted);
  transition:transform .14s, color .14s; flex-shrink:0;
}
.nav-section-chevron svg { width:15px; height:15px; }
.nav-section[open] .nav-section-chevron { transform:rotate(180deg); color:var(--text2); }
.nav-section-links { display:grid; gap:2px; padding:0 var(--sp-2) var(--sp-2); }
.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;
  min-width:0;
}
.nav-item:hover    { background:var(--sf3); color:var(--text); }
.nav-item-active   { background:var(--surface); border-color:var(--border2); 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:16px; height:16px; }
.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:transparent; 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-primary.button-danger { background:var(--red); border-color:var(--red); color:#fff; }
.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; }
.inline-form { display:inline-flex; margin:0; }

/* ── Cards ──────────────────────────────────────────────────────────────────── */
.card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:var(--pad-card);
}
.card + .card, .card + .table-wrap { margin-top:0; }   /* handled by parent gap */
.card > * + * { margin-top:var(--sp-4); }
.card > .section-head { margin-bottom:0; }
.card > script,
.card > style,
.card > input[type="hidden"] { display:none; }
.card > script + *,
.card > style + *,
.card > input[type="hidden"] + * { margin-top:0; }
/* script tags inside grids should not affect layout */
.tabs script, .tab-panel script, .firm-subtabs script, .firm-profile-stack script, .firm-hub-main script { display:none; }

/* 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:var(--border2); 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); }

/* ── Firm CMMS Dashboard ────────────────────────────────────────────────────── */
.cmms-filter-card { display:grid; gap:var(--sp-3); }
.cmms-filter-form {
  display:grid; grid-template-columns:1.1fr 1.2fr .8fr auto;
  gap:var(--sp-3); align-items:end;
}
.cmms-filter-actions { display:flex; gap:var(--sp-2); flex-wrap:wrap; align-items:center; }
.cmms-alert-strip {
  display:flex; justify-content:space-between; align-items:center; gap:var(--sp-4);
}
.cmms-alert-head { display:flex; align-items:center; gap:var(--sp-3); min-width:220px; }
.cmms-alert-head strong { display:block; font-size:14px; font-weight:850; }
.cmms-alert-head p { margin:2px 0 0; color:var(--muted); font-size:12px; line-height:1.45; }
.cmms-alert-icon,
.cmms-kpi-icon {
  width:40px; height:40px; border-radius:var(--r-md); display:grid; place-items:center;
  background:rgba(91,142,240,.12); color:var(--accent); flex-shrink:0;
}
.cmms-alert-icon svg,
.cmms-kpi-icon svg { width:18px; height:18px; }
.cmms-alert-items { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:var(--sp-2); flex:1; }
.cmms-alert-item {
  display:grid; gap:4px; padding:10px 12px; border:1px solid var(--border);
  border-radius:var(--r-md); background:var(--sf2); transition:border-color .14s, background .14s;
}
.cmms-alert-item:hover { border-color:var(--border2); background:var(--sf3); }
.cmms-alert-item strong { font-size:12px; font-weight:850; color:var(--text); }
.cmms-alert-item span { color:var(--muted); font-size:12px; line-height:1.35; }
.cmms-kpi-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:var(--sp-3); }
.cmms-kpi-card {
  min-height:184px; display:grid; grid-template-rows:auto 1fr auto; gap:var(--sp-3);
  padding:var(--sp-4); border:1px solid var(--border); border-radius:var(--r-lg);
  background:var(--surface); transition:border-color .14s, background .14s, transform .14s;
}
.cmms-kpi-card:hover { border-color:var(--border2); background:var(--sf2); transform:translateY(-1px); }
.cmms-kpi-head { display:flex; justify-content:space-between; align-items:flex-start; gap:var(--sp-2); min-height:40px; }
.cmms-kpi-body { display:grid; gap:6px; align-content:start; }
.cmms-kpi-body h2 {
  font-size:12px; font-weight:850; color:var(--muted);
  text-transform:uppercase; letter-spacing:.07em; line-height:1.3;
}
.cmms-kpi-body strong { font-size:31px; font-weight:900; letter-spacing:-.04em; line-height:1; color:var(--text); }
.cmms-kpi-body p { color:var(--text2); font-size:12px; line-height:1.45; margin:0; }
.cmms-kpi-success .cmms-kpi-icon { color:var(--green); background:rgba(47,143,103,.13); }
.cmms-kpi-warning .cmms-kpi-icon { color:var(--yellow); background:rgba(251,191,36,.14); }
.cmms-kpi-danger  .cmms-kpi-icon { color:var(--red); background:rgba(240,82,82,.13); }
.cmms-kpi-danger-strong { border-color:rgba(240,82,82,.42); background:rgba(240,82,82,.08); }
.cmms-kpi-danger-strong .cmms-kpi-icon { color:var(--red); background:rgba(240,82,82,.22); }
.cmms-kpi-neutral .cmms-kpi-icon { color:var(--accent); background:rgba(91,142,240,.12); }
.cmms-trend {
  display:inline-flex; align-items:center; gap:5px; padding:4px 8px;
  border-radius:var(--r-full); border:1px solid var(--border);
  color:var(--muted); font-size:11px; font-weight:800; line-height:1.2;
}
.cmms-trend span { font-size:13px; line-height:1; }
.cmms-trend-good { color:var(--green); background:rgba(47,143,103,.10); border-color:rgba(47,143,103,.22); }
.cmms-trend-bad { color:var(--red); background:rgba(240,82,82,.10); border-color:rgba(240,82,82,.22); }
.cmms-trend-neutral { color:var(--muted); background:var(--sf2); }
.cmms-chart-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:var(--sp-4); }
.cmms-chart-card { min-width:0; overflow:hidden; }
.cmms-chart-latest { font-size:18px; font-weight:900; letter-spacing:-.03em; white-space:nowrap; }
.cmms-chart-svg { width:100%; min-height:180px; display:block; overflow:visible; }
.cmms-chart-grid .cmms-chart-card > .cmms-chart-svg { margin-top:var(--sp-2); }
.cmms-chart-grid path,
.cmms-chart-grid polyline,
.cmms-chart-grid rect,
.cmms-chart-grid circle { vector-effect:non-scaling-stroke; }
.cmms-chart-grid text { font:10px var(--font); fill:var(--muted); }
.cmms-chart-guide { stroke:var(--border); stroke-width:1; fill:none; }
.cmms-chart-line { fill:none; stroke:var(--accent); stroke-width:3; stroke-linecap:round; stroke-linejoin:round; }
.cmms-chart-point { fill:var(--surface); stroke:var(--accent); stroke-width:2; }
.cmms-chart-point-last { fill:var(--accent); stroke:var(--surface); stroke-width:2.5; }
.cmms-chart-bar { fill:var(--accent); opacity:.82; }

/* ── 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; overflow-wrap:anywhere; }
.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; }
.ref-link:not(.button)           { color:var(--accent); font-weight:800; text-decoration:none; }
.ref-link:not(.button):hover     { text-decoration:underline; }

/* ── 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:var(--border2); background:var(--surface); }
.select-search-input { height:36px; font-size:12px; }
.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); }

.sidebar-editor-stack,
.sidebar-editor-block,
.sidebar-editor-groups,
.sidebar-editor-list { display:grid; gap:var(--sp-4); }
.sidebar-editor-block {
  padding:var(--sp-4); border:1px solid var(--border);
  border-radius:var(--r-md); background:var(--sf2);
}
.sidebar-editor-group-card {
  display:grid; gap:var(--sp-3); padding:var(--sp-3);
  border:1px solid var(--border); border-radius:var(--r-md); background:var(--surface);
}
.sidebar-editor-group-head {
  display:grid; grid-template-columns:36px minmax(220px,1fr) 120px 150px;
  gap:var(--sp-3); align-items:end;
}
.sidebar-editor-dropzone {
  display:grid; gap:var(--sp-3); min-height:58px; padding:var(--sp-2);
  border:1px dashed var(--border); border-radius:var(--r-md); background:var(--sf2);
}
.sidebar-editor-dropzone.is-drop-target {
  border-color:var(--border2); background:var(--sf3);
}
.sidebar-editor-row {
  display:grid; grid-template-columns:36px minmax(220px,1.3fr) minmax(160px,.8fr) 96px 130px;
  gap:var(--sp-3); align-items:end; padding:var(--sp-3);
  border:1px solid var(--border); border-radius:var(--r-md); background:var(--surface);
}
.sidebar-editor-row-group { grid-template-columns:minmax(220px,1fr) 120px 150px; }
.sidebar-editor-row.is-dragging,
.sidebar-editor-group-card.is-dragging { opacity:.48; }
.drag-handle {
  width:34px; height:34px; display:grid; place-items:center; align-self:end;
  border:1px solid var(--border); border-radius:var(--r-sm);
  background:var(--sf2); color:var(--muted); cursor:grab; font-weight:800;
}
.drag-handle:active { cursor:grabbing; }
.sidebar-editor-item-name {
  display:grid; grid-template-columns:28px minmax(0,1fr); align-items:end; gap:var(--sp-2);
}
.sidebar-editor-item-name .nav-icon { align-self:end; margin-bottom:2px; }
.sidebar-editor-disabled { opacity:.68; cursor:not-allowed; }

.mail-preview-open { overflow:hidden; }
.mail-preview-backdrop {
  position:fixed; inset:0; z-index:1200; display:none; align-items:center; justify-content:center;
  padding:18px; background:rgba(15,23,42,.68); backdrop-filter:blur(8px);
}
.mail-preview-backdrop.is-open { display:flex; }
.mail-preview-dialog {
  width:min(980px,100%); height:min(86vh,820px); display:grid; grid-template-rows:auto 1fr;
  overflow:hidden; border:1px solid var(--border2); border-radius:var(--r-lg);
  background:var(--surface); box-shadow:0 28px 90px rgba(0,0,0,.36);
}
.mail-preview-head {
  display:flex; align-items:center; justify-content:space-between; gap:var(--sp-3);
  padding:14px 16px; border-bottom:1px solid var(--border); background:var(--sf2);
}
.mail-preview-head span {
  display:block; margin-bottom:3px; font-size:10px; font-weight:800; text-transform:uppercase;
  letter-spacing:.1em; color:var(--accent);
}
.mail-preview-head strong { display:block; font-size:14px; font-weight:800; color:var(--text); }
.mail-preview-frame { width:100%; height:100%; border:0; background:#eef2f7; }

.mail-setup-steps { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:var(--sp-3); }
.mail-simple-card {
  display:grid; gap:8px; padding:15px;
  border:1px solid var(--border); border-radius:var(--r-md); background:var(--sf2);
}
.mail-simple-card span {
  display:grid; place-items:center; width:28px; height:28px;
  border-radius:999px; background:var(--accent); color:#fff; font-weight:850; font-size:13px;
}
.mail-simple-card strong { font-size:14px; font-weight:850; color:var(--text); line-height:1.25; }
.mail-simple-card p { margin:0; color:var(--muted); font-size:12px; line-height:1.45; }
.mail-simple-note {
  display:grid; gap:5px; margin-bottom:var(--sp-3); padding:13px 14px;
  border:1px solid rgba(22,163,110,.28); border-radius:var(--r-md); background:rgba(22,163,110,.08);
}
.mail-simple-note strong { font-size:13px; font-weight:850; color:var(--text); }
.mail-simple-note span { color:var(--text2); font-size:12px; line-height:1.45; }
.mail-status-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:var(--sp-3); }
.mail-status-card {
  display:grid; gap:5px; min-height:96px; padding:15px; border:1px solid var(--border);
  border-radius:var(--r-md); background:var(--surface);
}
.mail-status-card span { font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); }
.mail-status-card strong { font-size:18px; font-weight:850; color:var(--text); line-height:1.15; }
.mail-status-card small { color:var(--text2); line-height:1.45; }
.mail-status-ok { color:var(--green) !important; }
.mail-status-muted { color:var(--muted) !important; }
.mail-admin-tabs { display:grid; gap:var(--sp-4); }
.mail-template-list { display:grid; gap:var(--sp-4); }
.mail-template-card {
  display:grid; gap:var(--sp-4); padding:var(--sp-4); border:1px solid var(--border);
  border-radius:var(--r-md); background:var(--sf2);
}
.mail-template-head { display:flex; align-items:flex-start; justify-content:space-between; gap:var(--sp-3); }
.mail-template-head span:first-child {
  display:block; margin-bottom:4px; font-size:10px; font-weight:850; text-transform:uppercase;
  letter-spacing:.1em; color:var(--accent);
}
.mail-template-head h3 { font-size:17px; font-weight:850; line-height:1.2; }
.mail-template-head p { margin-top:5px; color:var(--muted); font-size:12px; line-height:1.5; }
.mail-preset-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:var(--sp-2); }
.mail-preset-card {
  appearance:none; display:grid; gap:5px; text-align:left; padding:12px; min-height:98px;
  border:1px solid var(--border2); border-radius:var(--r-sm); background:var(--surface);
  color:var(--text); cursor:pointer; transition:border-color .14s, background .14s, transform .14s;
}
.mail-preset-card:hover { border-color:var(--border2); background:var(--sf3); transform:translateY(-1px); }
.mail-preset-card span { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--accent); }
.mail-preset-card strong { font-size:13px; font-weight:800; }
.mail-preset-card small { color:var(--muted); line-height:1.4; }
.mail-live-subject {
  margin-top:8px; padding:9px 11px; border:1px solid var(--border); border-radius:var(--r-sm);
  background:var(--surface); color:var(--muted); font-size:12px; line-height:1.45;
}
.mail-live-subject strong { color:var(--text); font-weight:750; overflow-wrap:anywhere; }
.mail-body-editor { min-height:180px; font-family:inherit; font-size:13px; line-height:1.6; }
.mail-variable-panel {
  display:grid; grid-template-columns:minmax(180px,.8fr) minmax(0,2fr); gap:var(--sp-3);
  padding:12px; border:1px dashed var(--border2); border-radius:var(--r-md); background:var(--surface);
}
.mail-variable-panel strong { display:block; font-size:13px; font-weight:850; margin-bottom:4px; }
.mail-variable-panel p { color:var(--muted); font-size:12px; line-height:1.45; }
.mail-variable-chips { display:flex; flex-wrap:wrap; gap:7px; align-items:flex-start; }
.mail-variable-chip {
  appearance:none; display:inline-grid; gap:2px; max-width:210px; padding:8px 10px;
  border:1px solid var(--border); border-radius:var(--r-sm); background:var(--sf2);
  color:var(--text); cursor:pointer; text-align:left;
}
.mail-variable-chip:hover { border-color:var(--border2); background:var(--sf3); }
.mail-variable-chip span { font-size:12px; font-weight:800; }
.mail-variable-chip small { color:var(--muted); font-size:10px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.mail-form-group {
  padding:12px 14px; border:1px solid var(--border); border-radius:var(--r-md); background:var(--sf2);
}
.mail-form-group h3 { font-size:14px; font-weight:850; margin-bottom:4px; }
.mail-form-group p { color:var(--muted); font-size:12px; line-height:1.45; }
.mail-cron-box {
  display:flex; justify-content:space-between; align-items:center; gap:var(--sp-3); flex-wrap:wrap;
  margin-bottom:var(--sp-3); padding:14px; border:1px solid var(--border); border-radius:var(--r-md);
  background:var(--sf2);
}
.mail-cron-box span { display:block; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); margin-bottom:4px; }
.mail-cron-box strong { display:block; max-width:760px; overflow-wrap:anywhere; font-size:13px; }
.mail-cron-box small { display:block; margin-top:4px; color:var(--muted); line-height:1.45; }
.mail-flow-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:var(--sp-3); margin-bottom:var(--sp-4); }
.mail-flow-card {
  display:grid; gap:8px; padding:13px; border:1px solid var(--border);
  border-radius:var(--r-md); background:var(--sf2);
}
.mail-flow-card > span {
  font-size:10px; font-weight:850; text-transform:uppercase; letter-spacing:.1em; color:var(--accent);
}
.mail-flow-card > strong { font-size:14px; font-weight:850; }
.mail-flow-card ul { display:grid; gap:8px; list-style:none; padding:0; margin:0; }
.mail-flow-card li { display:grid; gap:2px; padding-top:8px; border-top:1px solid var(--border); }
.mail-flow-card li:first-child { border-top:0; padding-top:0; }
.mail-flow-card b { font-size:12px; color:var(--text); }
.mail-flow-card small { color:var(--muted); line-height:1.45; }
.row-highlight { outline:2px solid rgba(91,142,240,.38); outline-offset:-2px; background:rgba(91,142,240,.08); }
.fault-action-stack { display:grid; gap:8px; min-width:260px; }
.fault-timeline { border:1px solid var(--border); border-radius:var(--r-sm); background:var(--sf2); overflow:hidden; }
.fault-timeline summary { cursor:pointer; padding:8px 10px; font-size:12px; font-weight:750; color:var(--text2); }
.fault-timeline-list { display:grid; gap:0; border-top:1px solid var(--border); }
.fault-timeline-item { display:grid; gap:3px; padding:10px 11px; border-top:1px solid var(--border); }
.fault-timeline-item:first-child { border-top:0; }
.fault-timeline-item span { font-size:10px; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.06em; }
.fault-timeline-item strong { font-size:13px; font-weight:800; color:var(--text); }
.fault-timeline-item small { font-size:12px; color:var(--accent); }
.fault-timeline-item p { margin:0; color:var(--text2); font-size:12px; line-height:1.45; }
.fault-timeline-item em { color:var(--muted); font-size:11px; font-style:normal; }
.fault-timeline-empty { padding:10px; color:var(--muted); font-size:12px; border-top:1px solid var(--border); }
.firm-mail-pref-grid { display:grid; gap:var(--sp-3); }
.firm-mail-pref-card {
  display:grid; gap:var(--sp-3); padding:var(--sp-4);
  border:1px solid var(--border); border-radius:var(--r-md); background:var(--sf2);
}
.firm-mail-pref-head { display:flex; justify-content:space-between; align-items:flex-start; gap:var(--sp-3); }
.firm-mail-pref-head span {
  display:block; margin-bottom:4px; font-size:10px; font-weight:850;
  text-transform:uppercase; letter-spacing:.08em; color:var(--accent);
}
.firm-mail-pref-head strong { display:block; font-size:15px; font-weight:850; color:var(--text); }
.firm-mail-pref-head p { margin:4px 0 0; color:var(--muted); font-size:12px; line-height:1.45; }
.flow-summary-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:var(--sp-3); }
.flow-summary-card {
  display:grid; gap:4px; padding:15px;
  border:1px solid var(--border); border-radius:var(--r-md); background:var(--sf2);
}
.flow-summary-card span { font-size:10px; font-weight:850; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); }
.flow-summary-card strong { font-size:26px; font-weight:900; line-height:1; color:var(--text); }
.flow-summary-card small { color:var(--muted); font-size:12px; line-height:1.35; }
.flow-critical { border-color:rgba(239,68,68,.35); background:rgba(239,68,68,.07); }
.flow-warning { border-color:rgba(245,158,11,.35); background:rgba(245,158,11,.07); }
.flow-info { border-color:var(--border); background:var(--sf2); }
.flow-ok { border-color:rgba(22,163,110,.35); background:rgba(22,163,110,.07); }
.flow-issue-list { display:grid; gap:var(--sp-3); }
.flow-issue {
  display:flex; align-items:flex-start; justify-content:space-between; gap:var(--sp-3);
  padding:14px 15px; border:1px solid var(--border);
  border-radius:var(--r-md); background:var(--sf2);
}
.flow-issue-main { display:grid; gap:5px; min-width:0; }
.flow-issue-head { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.flow-issue-head small { color:var(--muted); font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.07em; }
.flow-issue strong { color:var(--text); font-size:14px; font-weight:850; line-height:1.25; }
.flow-issue p { margin:0; color:var(--text2); font-size:12px; line-height:1.5; overflow-wrap:anywhere; }
.flow-playbook { display:grid; gap:10px; }
.flow-playbook-step { display:flex; gap:10px; align-items:flex-start; padding:10px; border:1px solid var(--border); border-radius:var(--r-sm); background:var(--sf2); }
.flow-playbook-step > span {
  display:grid; place-items:center; width:26px; height:26px; border-radius:999px;
  background:var(--accent); color:#fff; font-size:12px; font-weight:850; flex-shrink:0;
}
.flow-playbook-step strong { display:block; font-size:13px; font-weight:850; color:var(--text); margin-bottom:3px; }
.flow-playbook-step p { margin:0; color:var(--muted); font-size:12px; line-height:1.45; }
.flow-watch-card { display:grid; gap:var(--sp-4); }
.flow-watch-head { display:flex; justify-content:space-between; align-items:flex-start; gap:var(--sp-3); }
.flow-watch-head .section-note { margin-top:4px; }
.flow-watch-updated {
  flex-shrink:0; padding:5px 9px; border:1px solid var(--border); border-radius:999px;
  color:var(--muted); background:var(--sf2); font-size:11px; font-weight:800;
}
.flow-watch-status {
  display:flex; justify-content:space-between; align-items:center; gap:var(--sp-3);
  padding:13px 14px; border:1px solid var(--border); border-radius:var(--r-md); background:var(--sf2);
}
.flow-watch-status strong { display:block; font-size:15px; font-weight:900; color:var(--text); }
.flow-watch-status span { display:block; margin-top:3px; color:var(--muted); font-size:12px; }
.flow-watch-status-critical { border-color:rgba(239,68,68,.38); background:rgba(239,68,68,.08); }
.flow-watch-status-warning { border-color:rgba(245,158,11,.38); background:rgba(245,158,11,.08); }
.flow-watch-status-info { border-color:var(--border); background:var(--sf2); }
.flow-watch-status-ok { border-color:rgba(22,163,110,.35); background:rgba(22,163,110,.07); }
.flow-watch-counts { display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; }
.flow-watch-counts span {
  min-width:58px; padding:7px 9px; border:1px solid var(--border); border-radius:var(--r-sm);
  background:var(--surface); color:var(--muted); font-size:10px; font-weight:850; text-align:center;
  text-transform:uppercase; letter-spacing:.06em;
}
.flow-watch-counts b { display:block; color:var(--text); font-size:18px; line-height:1; margin-bottom:3px; }
.flow-watch-list { display:grid; gap:10px; }
.flow-watch-item {
  display:flex; justify-content:space-between; align-items:flex-start; gap:var(--sp-3);
  padding:12px 13px; border:1px solid var(--border);
  border-radius:var(--r-md); background:var(--surface);
}
.flow-watch-item-main { display:grid; gap:5px; min-width:0; }
.flow-watch-item-head { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.flow-watch-item-head small { color:var(--muted); font-size:10px; font-weight:850; text-transform:uppercase; letter-spacing:.07em; }
.flow-watch-item strong { color:var(--text); font-size:13px; font-weight:850; line-height:1.25; }
.flow-watch-item p { margin:0; color:var(--text2); font-size:12px; line-height:1.45; overflow-wrap:anywhere; }

/* ── 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; min-width:0; overflow-wrap:anywhere; }
.grid-2 { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:var(--sp-4); }

/* System health */
.system-health-page { display:grid; gap:var(--gap-page); }
.system-health-actions form { display:flex; }
.system-health-mobile-list { display:none; }
.system-health-page code,
.system-health-page .detail-key-value strong { overflow-wrap:anywhere; word-break:break-word; min-width:0; }
.system-health-mobile-card {
  display:grid; gap:10px; padding:12px; border:1px solid var(--border);
  border-radius:var(--r-md); background:var(--sf2);
}
.system-health-mobile-head {
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:10px; flex-wrap:wrap;
}
.system-health-mobile-head strong {
  font-size:13px; font-weight:800; line-height:1.3; overflow-wrap:anywhere;
}
.system-health-mobile-card dl { display:grid; gap:8px; margin:0; }
.system-health-mobile-card dl > div {
  display:grid; gap:3px; padding-top:8px; border-top:1px solid var(--border);
}
.system-health-mobile-card dt {
  font-size:10px; font-weight:850; text-transform:uppercase;
  letter-spacing:.08em; color:var(--muted);
}
.system-health-mobile-card dd {
  margin:0; color:var(--text2); font-size:12px; line-height:1.45;
  overflow-wrap:anywhere; word-break:break-word;
}
.system-health-log-card code {
  display:block; white-space:pre-wrap; color:var(--text2);
  font-size:11px; line-height:1.5;
}

/* ── 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:transparent; 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-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);
  transition:border-color .14s, background .14s;
}
.worker-task-card:hover   { background:var(--sf2); border-color:var(--border2); }
.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); }
.upload-area {
  display:flex;
  flex-direction:column;
  gap:var(--sp-2);
}
.upload-area button {
  align-self:start;
}
.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; }

/* Checklist Item Row (List View) */
.checklist-item-row {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:var(--sp-4); display:grid; gap:var(--sp-3); transition:all .2s;
}
.checklist-item-row:hover { border-color:var(--border2); background:var(--sf2); }
.checklist-item-done {
  opacity:0.78;
}
.checklist-item-done:hover { border-color:var(--border); background:var(--surface); }
.checklist-item-row-left { display:flex; align-items:center; gap:var(--sp-3); flex:1; }
.checklist-item-number {
  width:28px; height:28px; display:flex; align-items:center; justify-content:center;
  background:var(--sf3); border-radius:var(--r-full); font-size:12px; font-weight:700;
  color:var(--text2); flex-shrink:0;
}
.checklist-item-text { font-size:14px; font-weight:600; }
.checklist-item-row-right { display:flex; align-items:center; gap:var(--sp-2); }
.checklist-item-arrow { font-size:18px; color:var(--muted); }
.checklist-item-check { font-size:18px; color:var(--green); font-weight:700; }
.checklist-item-head { display:flex; align-items:center; justify-content:space-between; gap:var(--sp-3); }
.checklist-item-controls { display:grid; gap:var(--sp-3); }
.checklist-item-actions { display:flex; align-items:center; gap:var(--sp-2); flex-wrap:wrap; }
.checklist-item-media { display:flex; align-items:center; gap:var(--sp-2); flex-wrap:wrap; }
.checklist-item-media .input { max-width:320px; }

/* Checklist Detail View */
.checklist-result-buttons { display:flex; gap:var(--sp-3); }
.button-success { background:var(--green); border-color:var(--green); color:#fff; }
.button-success:hover { opacity:0.9; }
.button-lg { padding:var(--sp-4) var(--sp-5); font-size:16px; font-weight:700; }
.button-full { width:100%; }
.checklist-fail-fields { border-top:1px solid var(--border); padding-top:var(--sp-3); }

/* ── 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; }
.firm-permission-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:8px; }
.firm-scope-wrap { display:grid; gap:14px; }
.firm-scope-group { border:1px solid var(--border); border-radius:8px; padding:12px; background:var(--surface-muted); }
.firm-scope-title { font-weight:800; margin-bottom:10px; color:var(--text); }
.service-measurement { border:1px solid var(--border); border-radius:var(--r-md); padding:var(--sp-3); background:var(--sf1); display:grid; gap:var(--sp-3); }
.service-measurement-head { display:grid; grid-template-columns:minmax(220px, 320px) 1fr; gap:var(--sp-3); align-items:end; }
.service-measurement-fields { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:var(--sp-3); }
.service-measurement-field { display:grid; gap:var(--sp-2); }
.service-measurement-result { padding:10px 12px; border-radius:var(--r-md); background:var(--sf3); color:var(--text); font-weight:800; }
.service-measurement-result-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:8px; }
.service-measurement-result-card { border:1px solid var(--border); border-radius:var(--r-md); padding:10px; background:var(--surface); display:grid; gap:4px; min-height:78px; }
.service-measurement-result-card span { color:var(--muted); font-size:11px; font-weight:800; }
.service-measurement-result-card strong { color:var(--text); font-size:14px; line-height:1.25; }
.service-measurement-result-card small { color:var(--text2); font-size:11px; line-height:1.3; }
.service-measurement-result-card.phase-normal { border-color:rgba(47,143,103,.45); background:rgba(47,143,103,.08); }
.service-measurement-result-card.phase-normal strong { color:var(--green); }
.service-measurement-result-card.phase-warning { border-color:rgba(251,191,36,.5); background:rgba(251,191,36,.08); }
.service-measurement-result-card.phase-warning strong { color:var(--yellow); }
.service-measurement-result-card.phase-critical { border-color:rgba(240,82,82,.5); background:rgba(240,82,82,.08); }
.service-measurement-result-card.phase-critical strong { color:var(--red); }
.service-measurement-comparison { border:1px solid var(--border); border-radius:var(--r-md); background:var(--surface); padding:12px; display:grid; gap:10px; }
.service-measurement-comparison-empty { color:var(--muted); font-size:12px; font-weight:700; background:var(--sf2); }
.service-measurement-comparison-head { display:flex; justify-content:space-between; gap:10px; align-items:center; flex-wrap:wrap; }
.service-measurement-comparison-head strong { font-size:13px; color:var(--text); }
.service-measurement-comparison-head span { font-size:12px; color:var(--muted); }
.service-measurement-comparison-table { overflow:auto; }
.service-measurement-comparison-table table { width:100%; border-collapse:collapse; font-size:12px; min-width:520px; }
.service-measurement-comparison-table th,
.service-measurement-comparison-table td { border-bottom:1px solid var(--border); padding:7px 8px; text-align:left; white-space:nowrap; }
.service-measurement-comparison-table th { color:var(--muted); font-size:11px; font-weight:800; }
.service-measurement-comparison-status { justify-self:start; border-radius:999px; padding:6px 10px; font-size:12px; font-weight:900; }
.service-measurement-comparison-status.comparison-normal { background:rgba(47,143,103,.12); color:var(--green); }
.service-measurement-comparison-status.comparison-warning { background:rgba(251,191,36,.12); color:var(--yellow); }
.service-measurement-comparison-status.comparison-critical { background:rgba(240,82,82,.12); color:var(--red); }
.service-measurement-view { margin-top:var(--sp-3); border-top:1px solid var(--border); padding-top:var(--sp-3); display:grid; gap:var(--sp-2); }
.service-measurement-view h5 { margin:0; font-size:14px; }
.service-measurement-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:var(--sp-2); }
.service-measurement-cell { border:1px solid var(--border); border-radius:var(--r-md); padding:10px; display:grid; gap:6px; background:var(--sf1); }
.service-measurement-cell strong { font-size:12px; color:var(--muted); }
.service-measurement-cell span { font-weight:800; color:var(--text); }
.service-measurement-cell.phase-normal { border-color:rgba(47,143,103,.45); background:rgba(47,143,103,.08); }
.service-measurement-cell.phase-normal span { color:var(--green); }
.service-measurement-cell.phase-warning { border-color:rgba(251,191,36,.5); background:rgba(251,191,36,.08); }
.service-measurement-cell.phase-warning span { color:var(--yellow); }
.service-measurement-cell.phase-critical { border-color:rgba(240,82,82,.5); background:rgba(240,82,82,.08); }
.service-measurement-cell.phase-critical span { color:var(--red); }
.camera-capture-modal {
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
  background:rgba(15,23,42,.78);
}
.camera-capture-panel {
  width:min(720px,100%);
  padding:14px;
  border-radius:var(--r-lg);
  background:var(--surface);
  box-shadow:var(--shadow-lg);
}
.camera-capture-video {
  width:100%;
  max-height:70vh;
  aspect-ratio:4/3;
  border-radius:var(--r-md);
  background:#0f172a;
  object-fit:cover;
}
.camera-capture-actions {
  display:flex;
  gap:10px;
  justify-content:flex-end;
  margin-top:12px;
}
.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-entry { display:flex; flex-direction:column; gap:6px; align-items:flex-start; }
.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:var(--border2);background:var(--sf3)}.web-cms-tab.active{border-color:var(--border2);background:var(--sf3);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:var(--border2);background:var(--sf3);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:1px solid var(--border);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:var(--border2);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:var(--border2);box-shadow:0 0 0 3px rgba(148,163,184,.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)}

/* Page Tour */
.page-tour-spotlight {
  position:fixed; z-index:1400; pointer-events:none;
  border:2px solid var(--orange); border-radius:14px;
  box-shadow:0 0 0 9999px rgba(0,0,0,.52), 0 14px 40px rgba(0,0,0,.28);
  transition:left .18s ease, top .18s ease, width .18s ease, height .18s ease;
}
.page-tour-popover {
  position:fixed; z-index:1401; width:min(460px, calc(100vw - 24px));
  max-height:calc(100vh - 24px); overflow:auto; overscroll-behavior:contain;
  display:grid; gap:12px; padding:16px; border:1px solid var(--border2);
  border-radius:var(--r-lg); background:var(--surface); box-shadow:var(--shadow);
}
.page-tour-kicker {
  font-size:10px; font-weight:850; text-transform:uppercase; letter-spacing:.1em;
  color:var(--orange);
}
.page-tour-popover strong { font-size:16px; font-weight:850; color:var(--text); line-height:1.25; }
.page-tour-section {
  display:grid; gap:4px; padding:10px 11px; border:1px solid var(--border);
  border-radius:var(--r-md); background:var(--sf2);
}
.page-tour-section span {
  font-size:10px; line-height:1; font-weight:850; text-transform:uppercase;
  letter-spacing:.08em; color:var(--muted);
}
.page-tour-section p { color:var(--text2); font-size:12px; line-height:1.55; }
.page-tour-section-warn { background:rgba(245,158,11,.08); border-color:rgba(245,158,11,.26); }
.page-tour-section-warn span { color:var(--orange); }
.page-tour-actions { display:flex; justify-content:flex-end; gap:8px; flex-wrap:wrap; }
.page-tour-actions button:disabled { opacity:.45; cursor:not-allowed; }

/* ── Responsive 1280px ──────────────────────────────────────────────────────── */
@media (max-width:1280px) {
  .stats-grid,
  .dashboard-highlight-grid,
  .cmms-kpi-grid,
  .cmms-chart-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .cmms-filter-form { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .cmms-filter-actions { align-self:end; }
  .cmms-alert-strip { align-items:flex-start; }
  .cmms-alert-items { grid-template-columns: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; }
  .cmms-alert-strip { display:grid; }
  .mail-status-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .mail-setup-steps { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .flow-summary-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .mail-flow-grid { grid-template-columns:1fr; }
  .mail-preset-grid { grid-template-columns:1fr; }
  .mail-variable-panel { 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) {
  :root {
    --pad-card:16px;
    --pad-cell:10px 12px;
    --pad-btn:8px 12px;
    --pad-btn-sm:6px 10px;
  }
  html, body { max-width:100%; overflow-x:hidden; }
  .button {
    max-width:100%; min-width:0; white-space:normal; text-align:center;
    justify-content:center; line-height:1.2;
  }
  .page-content       { padding:var(--sp-3); gap:var(--sp-3); }
  .stats-grid,
  .dashboard-highlight-grid,
  .cmms-kpi-grid,
  .cmms-chart-grid,
  .quick-link-grid,
  .form-grid          { grid-template-columns:1fr; }
  .cmms-filter-form   { grid-template-columns:1fr; }
  .cmms-filter-actions .button { width:100%; }
  .cmms-kpi-card      { min-height:0; }
  .cmms-alert-head    { min-width:0; }
  .service-measurement-head,
  .service-measurement-fields,
  .service-measurement-result-grid,
  .service-measurement-grid { grid-template-columns:1fr; }
  .grid-2             { grid-template-columns:1fr; }
  .mail-status-grid   { grid-template-columns:1fr; }
  .mail-setup-steps   { grid-template-columns:1fr; }
  .flow-summary-grid  { grid-template-columns:1fr; }
  .system-health-page .table-wrap { display:none; }
  .system-health-mobile-list { display:grid; gap:var(--sp-3); }
  .system-health-actions,
  .system-health-actions form { display:grid; grid-template-columns:1fr; width:100%; }
  .system-health-actions .button { width:100%; }
  .system-health-page .detail-key-value {
    display:grid; justify-content:stretch; align-items:start; gap:4px;
  }
  .system-health-page .detail-key-value strong { text-align:left; }
  .detail-key-value {
    display:grid; justify-content:stretch; align-items:start; gap:4px;
  }
  .detail-key-value strong { text-align:left; }
  .flow-issue         { display:grid; }
  .flow-watch-head,
  .flow-watch-status,
  .flow-watch-item    { display:grid; }
  .flow-watch-counts  { justify-content:stretch; }
  .flow-watch-counts span { min-width:0; }
  .mail-template-head { display:grid; }
  .mail-template-card { padding:var(--sp-3); }
  .sidebar-editor-group-head,
  .sidebar-editor-row,
  .sidebar-editor-row-group { grid-template-columns:1fr; align-items:stretch; }
  .sidebar-editor-block { padding:var(--sp-3); }
  .sidebar-editor-item-name { grid-template-columns:28px minmax(0,1fr); }
  .drag-handle { width:100%; height:30px; }
  .mail-cron-box      { display:grid; align-items:start; }
  .card               { padding:var(--pad-card); }
  .page-hero          { flex-direction:column; padding:var(--sp-4); gap:var(--sp-3); }
  .page-hero-copy     { min-width:0; width:100%; }
  .page-hero-actions  { width:100%; }
  .page-hero-actions .button,
  .toolbar .button,
  .actions .button,
  .row-actions .button,
  .row-actions-compact .button { flex:1 1 auto; }
  .section-head,
  .toolbar,
  .card-header-row,
  .checklist-item-header { display:grid; align-items:start; }
  .checklist-actions,
  .checklist-result-buttons { display:grid; grid-template-columns:1fr; gap:var(--sp-2); }
  .checklist-actions .button,
  .checklist-result-buttons .button { width:100%; }
  .tab-btn            { padding:7px 12px; font-size:12px; }
  .topbar {
    min-height:var(--topbar-h); height:auto; align-items:flex-start;
    flex-wrap:wrap; padding:8px var(--sp-3); gap:8px;
  }
  .topbar-info-row    { width:100%; flex:1 1 100%; }
  .topbar-title-block { min-width:0; }
  .topbar-subtitle    { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .topbar-actions {
    width:100%; flex:1 1 100%; overflow-x:auto; flex-wrap:nowrap;
    padding-bottom:2px; scrollbar-width:none;
  }
  .topbar-actions::-webkit-scrollbar { display:none; }
  .topbar-actions .button,
  .topbar-actions .topbar-badge { flex:0 0 auto; }
  .topbar-badge        { display:none; }
  .worker-topbar {
    min-height:var(--topbar-h); height:auto; align-items:flex-start;
    flex-wrap:wrap; padding:8px var(--sp-3); gap:8px;
  }
  .worker-topbar > div:first-child { min-width:0; flex:1 1 180px; }
  .worker-topbar .topbar-actions {
    width:100%; flex:1 1 100%; overflow-x:auto; flex-wrap:nowrap;
    padding-bottom:2px; scrollbar-width:none;
  }
  .worker-topbar .topbar-actions::-webkit-scrollbar { display:none; }
  .worker-topbar .button-xs { flex:0 0 auto; font-size:11px; padding:6px 9px; }
  .worker-content     { padding:var(--sp-3); padding-bottom:88px; }
  .worker-nav         { padding-left:var(--sp-2); padding-right:var(--sp-2); }
  .worker-nav-item    { padding:7px 4px; font-size:10px; }
  .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}
  .mail-preview-backdrop{padding:8px}
  .mail-preview-dialog{height:92vh;border-radius:var(--r-md)}
  .mail-preview-head{display:grid;align-items:start}
  .mail-preview-head .actions{width:100%}
  .mail-preview-head .button{flex:1;justify-content:center}
}

/* ── Error Tracker ────────────────────────────────────────────────────────── */
.error-tracker-controls {
  display: grid;
  gap: var(--sp-3);
}

.error-tracker-banner {
  padding: 12px 14px;
  border-radius: var(--r-md);
  font-size: 13px;
  font-weight: 600;
  line-height: 1.5;
}

.error-tracker-banner.banner-danger {
  background: rgba(240,82,82,.12);
  border: 1px solid rgba(240,82,82,.3);
  color: var(--red);
}

.error-tracker-banner:not(.banner-danger) {
  background: rgba(34,201,138,.1);
  border: 1px solid rgba(34,201,138,.25);
  color: var(--green);
}

.banner-icon {
  margin-right: var(--sp-2);
}

.error-tracker-filters {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  align-items: flex-end;
}

.filter-group {
  display: grid;
  gap: var(--sp-1);
}

.filter-group label {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
}

.filter-buttons {
  display: flex;
  gap: var(--sp-1);
  flex-wrap: wrap;
}

.filter-buttons .button.active {
  background: var(--accent);
  border-color: transparent;
  color: #fff;
}

.error-tracker-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  flex-wrap: wrap;
  padding: var(--sp-2) 0;
}

.error-tracker-stats {
  display: flex;
  gap: var(--sp-3);
  font-size: 12px;
  color: var(--muted);
  flex-wrap: wrap;
}

.error-tracker-stats .stat-item strong {
  color: var(--text);
  font-weight: 700;
}

.error-tracker-table {
  width: 100%;
  border-collapse: collapse;
}

.error-tracker-table th {
  padding: 10px 12px;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
  text-align: left;
  background: var(--sf2);
  white-space: nowrap;
}

.error-tracker-table td {
  padding: 8px 12px;
  font-size: 12px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

.error-tracker-table tr:last-child td {
  border-bottom: none;
}

.error-tracker-table tr:hover td {
  background: var(--sf2);
}

.error-tracker-table tr.error-resolved td {
  opacity: 0.55;
}

.error-tracker-table tr.error-resolved .error-message code {
  text-decoration: line-through;
}

.error-tracker-table tr.error-resolved .error-date {
  text-decoration: line-through;
}

.error-tracker-table .error-checkbox {
  accent-color: var(--accent);
  width: 16px;
  height: 16px;
  cursor: pointer;
}

.error-tracker-table .error-date {
  font-size: 11px;
  color: var(--text2);
  white-space: nowrap;
}

.error-tracker-table .error-file {
  font-size: 11px;
  color: var(--text2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 180px;
}

.error-tracker-table .error-message code {
  display: block;
  font-size: 11px;
  line-height: 1.5;
  color: var(--text2);
  overflow-wrap: anywhere;
  word-break: break-word;
  max-height: 60px;
  overflow-y: auto;
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
}

.error-tracker-table .button-ghost {
  color: var(--muted);
  font-size: 12px;
}

.error-tracker-table .button-ghost:hover {
  color: var(--red);
}

/* Error tracker mobile cards */
#error-tracker-mobile .system-health-log-card code {
  display: block;
  white-space: pre-wrap;
  color: var(--text2);
  font-size: 11px;
  line-height: 1.5;
  background: var(--sf3);
  padding: var(--sp-2);
  border-radius: var(--r-sm);
  max-height: 80px;
  overflow-y: auto;
}

#error-tracker-mobile .system-health-log-card.error-resolved {
  opacity: 0.55;
}

#error-tracker-mobile .system-health-log-card.error-resolved code {
  text-decoration: line-through;
}

#error-tracker-mobile .system-health-log-card .error-file {
  font-size: 11px;
  color: var(--text2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#error-tracker-mobile .error-checkbox {
  accent-color: var(--accent);
  width: 16px;
  height: 16px;
  cursor: pointer;
}

@media (max-width:767px) {
  .error-tracker-table th,
  .error-tracker-table td {
    font-size: 10px;
    padding: 6px 8px;
  }
  .error-tracker-table .error-file {
    max-width: 100px;
  }
}

/* ── Admin Apps (Bakım / Satın Alma / Stok / Satış / Faturalama) ────────── */
.app-launch-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sp-3);
  margin-top: var(--sp-4);
}

.app-launch-card {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--sf2);
  padding: var(--sp-4);
  display: grid;
  gap: var(--sp-3);
}

.app-launch-card span {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--accent);
  font-weight: 800;
}

.app-launch-card strong {
  display: block;
  font-size: 17px;
  font-weight: 800;
  margin-top: 4px;
}

.app-launch-card p {
  margin: 8px 0 0;
  font-size: 12px;
  line-height: 1.55;
  color: var(--muted);
}

.app-product-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sp-3);
}

.app-product-card {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--sf2);
  display: grid;
}

.app-product-image img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
}

.app-product-empty {
  width: 100%;
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: center;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
  background: var(--sf3);
}

.app-product-empty svg {
  width: 28px;
  height: 28px;
}

.app-product-content {
  display: grid;
  gap: 4px;
  padding: 12px;
}

.app-product-content strong {
  font-size: 14px;
  font-weight: 800;
}

.app-product-content span {
  font-size: 11px;
  color: var(--muted);
}

.stock-planned-highlight {
  display: inline-block;
  background: rgba(251, 191, 36, .2);
  color: #f8cc52;
  border: 1px solid rgba(251, 191, 36, .35);
  padding: 2px 8px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 700;
}

.stock-plan-date {
  background: rgba(251, 191, 36, .08);
}

.barcode-help-list {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
}

.barcode-help-list li {
  line-height: 1.45;
}

.barcode-warehouse-select {
  min-width: 180px;
}

@media (max-width: 1100px) {
  .app-product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .app-launch-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .app-product-grid {
    grid-template-columns: 1fr;
  }
}
