:root{
  /* Default palette: light CRM-style */
  --bg:#f3f4f6;
  --panel:#ffffff;
  --muted:#6b7280;
  --text:#111827;
  --link:#0b79b7;
  --brand:#0b79b7;
  --ok:#16a34a;
  --warn:#f59e0b;
  --info:#0ea5e9;
  --done:#15803d;
  --border:#d1d5db;
  --danger:#dc2626;
  --surface-panel:#ffffff;
  --surface-button:#e5edf7;
  --surface-button-hover:#d7e4f3;
  --surface-input:#ffffff;
  --surface-input-alt:#f1f5f9;
  --surface-chip:#e5edf7;
  --surface-subtle:#eef2f7;
  --surface-card:#ffffff;
  --surface-menu:#f5f7fa;
  --surface-topbar:#0b79b7;
  --surface-image:#e5edf7;
  --focus-ring:rgba(11,121,183,0.35);
  --glow-accent:rgba(11,121,183,0.12);
  --radius-xs:4px;
  --radius-sm:6px;
  --radius-md:8px;
  --radius-lg:12px;
  --radius-xl:16px;
  --radius-pill:20px;
  --shadow-elevated:0 18px 44px rgba(15,23,42,0.18);
  --shadow-soft:0 10px 24px rgba(15,23,42,0.12);
}

*{ box-sizing:border-box }
a{ color:var(--link, var(--brand)); }
a:hover{ color:var(--brand-hover, var(--link, var(--brand))); }

html,body{
  margin:0; padding:0;
  background:var(--bg); color:var(--text);
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu;
}

body.theme-tech{
  background:
    radial-gradient(circle at 20% 20%, rgba(88,224,255,0.18), transparent 55%),
    radial-gradient(circle at 82% 12%, rgba(47,213,160,0.16), transparent 52%),
    radial-gradient(circle at 50% 110%, rgba(124,236,255,0.12), transparent 65%),
    linear-gradient(180deg, rgba(3,14,28,0.94), rgba(3,10,21,0.96)),
    var(--bg);
  background-attachment: fixed;
  background-repeat: no-repeat;
}

/* Top bar */
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 16px;
  border-bottom:1px solid var(--border);
  background:var(--surface-topbar);
}
.brand{ font-weight:700; color:var(--brand); text-decoration:none }
.topbar .brand{ color:var(--brand-contrast,#ffffff); }
.pill{
  margin-left:10px; background:var(--surface-chip); /* was #1c2330 */
  border:1px solid var(--border); padding:2px 8px; border-radius:999px;
  color:var(--muted); font-size:12px
}
.nav-actions{ display:flex; gap:8px; margin-left:16px }

.topbar-left{ display:flex; align-items:center; gap:12px; flex:1 }
.topbar-center{ flex:1; display:flex; justify-content:center; align-items:center; gap:12px; flex-wrap:wrap }
.manual-link{ font-weight:600 }
.manual-link:hover{ text-decoration:underline }
.topbar-right{ display:flex; align-items:center; gap:12px; flex:1; justify-content:flex-end }
.layer-indicator{ margin-left:8px; padding:4px 10px; border-radius:999px; border:1px solid var(--border); background:var(--surface-chip); color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:0.08em }
.icon-btn.ghost{ background:transparent; border-color:transparent }
.icon-btn.ghost:hover{ background:rgba(255,255,255,0.05) }
.icon-btn[disabled], .icon-btn.disabled{ opacity:0.45; pointer-events:none }
.user-trigger{ display:flex; align-items:center; gap:10px; padding:6px 12px; border-radius:999px; border:1px solid var(--border); background:var(--surface-button); color:var(--text); cursor:pointer; transition:background .15s ease }
.user-trigger:hover{ background:var(--surface-button-hover) }
.user-trigger:focus{ outline:none; box-shadow:0 0 0 3px rgba(157,182,255,.25) }
.user-trigger-figure{ display:flex; align-items:center; gap:8px; position:relative }
.user-trigger-photo{ width:38px; height:38px; border-radius:999px; overflow:hidden; background:var(--surface-chip); display:flex; align-items:center; justify-content:center; font-weight:700; text-transform:uppercase }
.user-trigger-photo img{ width:100%; height:100%; object-fit:cover }
.user-trigger-icon{ position:absolute; right:-6px; bottom:-4px; width:20px; height:20px; border-radius:999px; background:var(--surface-topbar); border:1px solid var(--border); display:flex; align-items:center; justify-content:center }
.user-trigger-icon svg{ width:14px; height:14px }
.user-trigger-caret{ width:18px; height:18px }
.user-dropdown{ min-width:260px }
.user-summary{ align-items:center }
.user-summary-avatar{ width:44px; height:44px; border-radius:999px; background:var(--surface-chip); display:flex; align-items:center; justify-content:center; font-weight:700; text-transform:uppercase; overflow:hidden }
.user-summary-avatar img{ width:100%; height:100%; object-fit:cover }
.user-summary-meta{ display:flex; flex-direction:column; gap:2px }
.user-layer{ font-size:0.7rem; letter-spacing:0.08em; text-transform:uppercase }
.menu-divider{ height:1px; background:var(--border); margin:8px 0 }
.logout-item button{ width:100%; background:none; border:none; padding:0; color:var(--danger); font-weight:600; text-align:left; cursor:pointer }
.logout-item button:hover{ color:var(--text) }

/* Icon buttons slightly brighter */
.icon-btn{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px;
  border:1px solid var(--border); border-radius:10px;
  color:var(--text); background:var(--surface-button); /* was #121720 */
  text-decoration:none; transition:background .15s ease, transform .05s ease
}
.icon-btn:hover{ background:var(--surface-button-hover) } /* was #18202c */
.icon-btn:active{ transform:translateY(1px) }

.user-menu{ position:relative }
.user-menu .menu{
  display:none; position:absolute; right:0; top:48px;
  background:var(--surface-input); /* was #0e1116 */
  border:1px solid var(--border); border-radius:12px; min-width:240px; padding:8px;
  box-shadow:0 12px 30px rgba(0,0,0,.35); z-index:50
}
.user-menu .menu.open{ display:block }
.menu-item{ padding:8px 10px; color:var(--menu-text); border-radius:8px; display:flex; align-items:center; gap:8px }
.menu-item:hover{ background:var(--surface-subtle) } /* was #171d28 */
.menu .row-center{ display:flex; align-items:center; gap:8px }
.icon-btn.sm{ width:34px; height:34px }
.submenu{ display:none; margin-top:6px; border-top:1px solid var(--border); padding-top:6px }
.submenu.open{ display:block }

/* Larger glyphs inside icon buttons */
.icon-btn svg{ width:24px; height:24px }
.icon-btn.sm svg{ width:20px; height:20px }

[hidden]{ display:none !important }
.nav-backdrop{ position:fixed; inset:0; background:rgba(6,10,16,0.55); background:color-mix(in srgb, var(--bg) 70%, transparent); backdrop-filter:blur(2px); z-index:70; opacity:0; pointer-events:none; transition:opacity .2s ease }
body.nav-open .nav-backdrop{ opacity:1; pointer-events:auto }
.side-menu{ position:fixed; top:0; left:0; height:100vh; width:min(320px,82vw); background:rgba(23,30,39,0.9); background:color-mix(in srgb, var(--surface-menu) 92%, transparent); border-right:1px solid var(--border); box-shadow:0 18px 36px rgba(0,0,0,0.4); transform:translateX(-110%); transition:transform .25s ease; z-index:80; display:flex; flex-direction:column; gap:16px; padding:24px 20px 32px }
.side-menu.open{ transform:translateX(0) }
body.nav-open .side-menu{ transform:translateX(0) }
.side-menu-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; color:var(--muted); text-transform:uppercase; letter-spacing:0.08em; font-size:0.78rem }
.side-menu-head-actions{ display:flex; align-items:center; gap:8px }
.nav-pin.active{ color:var(--brand); border-color:var(--brand) }
.side-menu-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; overflow-y:auto }
.side-menu-list > li{ list-style:none }
.side-menu-list > li > a,
.side-menu-group > summary{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:10px 12px; border-radius:10px; color:var(--menu-text); text-decoration:none; font-weight:600; background:transparent; cursor:pointer; transition:background .15s ease, color .15s ease }
.side-menu-list > li > a:hover,
.side-menu-group > summary:hover{ background:rgba(255,255,255,0.08) }
.side-menu-list > li > a.active{ background:rgba(157,182,255,0.18); color:var(--brand) }
.side-menu-group{ border:1px solid rgba(255,255,255,0.05); border-radius:12px; padding:6px; background:rgba(0,0,0,0.05) }
.side-menu-group > summary{ margin:-6px; padding:10px 12px; list-style:none }
.side-menu-group summary::-webkit-details-marker{ display:none }
.side-menu-group[open] > summary .chevron{ transform:rotate(180deg) }
.side-menu-group ul{ list-style:none; margin:8px 0 0 0; padding:0; display:flex; flex-direction:column; gap:6px }
.side-menu-group ul li a{ display:block; padding:8px 12px; border-radius:8px; text-decoration:none; color:var(--muted); transition:background .15s ease, color .15s ease }
.side-menu-group ul li a:hover{ background:rgba(255,255,255,0.08); color:var(--text) }
.side-menu-group ul li a.active{ background:rgba(157,182,255,0.18); color:var(--brand) }
.summary-link{ font-size:0.75rem; color:var(--brand); text-decoration:none }
.summary-link:hover{ text-decoration:underline }
.chevron{ width:18px; height:18px; transition:transform .2s ease }
body.nav-open{ overflow:hidden }
@media (min-width:1024px){
  body.nav-pinned .nav-backdrop{ display:none !important }
  body.nav-pinned .side-menu{
    transform:translateX(0);
    box-shadow:none;
    width:260px;
  }
  body.nav-pinned .topbar,
  body.nav-pinned .container,
  body.nav-pinned main.page{
    margin-left:260px;
  }
}
/* Controls: lighter background + focus ring pops a bit more */
select{
  appearance:none; background:var(--surface-input); /* was #0e1116 */
  color:var(--menu-text); border:1px solid var(--border); border-radius:8px; padding:8px 10px
}
select:focus{ outline:none; border-color:var(--brand); box-shadow:0 0 0 3px rgba(157,182,255,.25) }
.user{ display:flex; gap:12px; align-items:center }

.container{ max-width:1180px; width:100%; margin:32px auto 64px; padding:0 24px }
.manual-page{ display:flex; flex-direction:column; gap:32px }
.manual-layout{ display:grid; grid-template-columns:minmax(220px,280px) 1fr; gap:32px }
.manual-toc{ position:sticky; top:96px; align-self:start; background:var(--surface-panel); border:1px solid var(--border); border-radius:18px; padding:20px }
.manual-toc h2{ margin:0 0 12px; font-size:0.9rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--muted) }
.manual-toc ol{ margin:0; padding-left:20px; display:flex; flex-direction:column; gap:8px }
.manual-toc a{ color:var(--text); text-decoration:none; font-weight:600 }
.manual-toc a:hover{ color:var(--brand) }
.manual-content{ display:flex; flex-direction:column; gap:28px }
.manual-section{ background:var(--surface-panel); border:1px solid var(--border); border-radius:20px; padding:24px; display:flex; flex-direction:column; gap:16px; scroll-margin-top:96px }
.manual-section h2{ margin:0; font-size:1.45rem }
.manual-section figure{ margin:0; background:var(--surface-input); border:1px solid var(--border); border-radius:16px; padding:16px; display:flex; flex-direction:column; gap:12px }
.manual-section figure img{ width:100%; height:auto; border-radius:10px; background:var(--surface-image); border:1px solid rgba(255,255,255,0.08) }
.manual-section figure figcaption{ font-size:0.9rem; color:var(--muted) }
.manual-terminology{ display:grid; gap:12px; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); margin:0 }
.manual-terminology dt{ font-weight:700; margin:0 0 4px }
.manual-terminology dd{ margin:0; color:var(--muted); font-size:0.95rem; line-height:1.5 }
.manual-section ul,.manual-section ol{ margin:0; padding-left:20px; display:flex; flex-direction:column; gap:8px }
.manual-section li{ line-height:1.6 }
.manual-section kbd{ background:var(--surface-chip); border:1px solid var(--border); border-radius:6px; padding:2px 6px; font-size:0.85rem }
@media (max-width:960px){
  .manual-layout{ grid-template-columns:1fr }
  .manual-toc{ position:relative; top:auto }
}
.toolbar{ display:flex; align-items:center; gap:12px }
.spacer{ flex:1 }

.card{
  background:var(--panel); border:1px solid var(--border);
  border-radius:8px; padding:16px; margin:12px 0
}

.grid-form{ display:grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap:8px }
label{ display:block; margin:8px 0 4px; color:var(--muted) }

input,select,textarea{
  width:100%; padding:10px;
  border:1px solid var(--border); border-radius:6px;
  background:var(--surface-input); /* was #0e1116 */
  color:var(--text)
}

button,.button{
  display:inline-block; padding:8px 12px; border-radius:6px;
  border:1px solid var(--border);
  background:var(--surface-chip); /* was #1c2330 */
  color:var(--text); cursor:pointer; text-decoration:none
}
.link{ background:none; border:none; color:var(--brand); cursor:pointer }

.table{
  width:100%; border-collapse:collapse;
  background:var(--panel); border:1px solid var(--border);
  border-radius:8px; overflow:hidden
}
.table th,.table td{ padding:10px 12px; border-bottom:1px solid var(--border); text-align:left }

.tabs{ display:flex; gap:8px; margin:12px 0 }
.tab{ padding:8px 12px; border:1px solid var(--border); border-radius:999px; color:var(--muted) }
.tab.active{ color:var(--text); border-color:var(--brand) }

/* List layout (CRM-style) */
.status-overview-card{margin-bottom:16px}
.status-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:4px}
.status-header h2{margin:0;font-size:1rem}
.status-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-size:.85rem;color:var(--muted)}
.status-label{font-weight:500}
.status-total strong{font-size:1rem}
.status-chart-container{position:relative;height:28px}
.list-filters.card{margin-bottom:16px}
.list-filters-grid{display:grid;grid-template-columns:minmax(0,2.4fr) minmax(0,1.2fr);gap:16px;align-items:flex-end}
.list-filters .field label{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:4px;display:block}
.input-with-icon{position:relative;display:flex;align-items:center}
.input-with-icon input{padding-left:34px}
.input-icon{position:absolute;left:10px;display:flex;align-items:center;justify-content:center;color:var(--muted)}
.input-icon svg{width:16px;height:16px}
.list-card{margin-top:8px}
.list-table .cell-checkbox{width:40px;text-align:center}
.list-table .cell-checkbox input{width:16px;height:16px}
.list-table .cell-narrow{width:44px;text-align:center}
.icon-link{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;border:1px solid transparent;color:var(--muted);text-decoration:none;background:transparent}
.icon-link svg{width:16px;height:16px}
.icon-link:hover{border-color:var(--border);background:var(--surface-input-alt);color:var(--brand)}

/* Badges on slightly brighter chip */
.badge{
  display:inline-block; padding:2px 8px; border-radius:999px;
  background:var(--surface-chip); /* was #1c2330 */
  border:1px solid var(--border)
}
.badge.submitted{ border-color:var(--info); color:var(--info) }
.badge.assigned{ border-color:var(--warn); color:var(--warn) }
.badge.in_progress{ border-color:var(--brand); color:var(--brand) }
.badge.finished{ border-color:var(--done); color:var(--done) }

.grid{ display:grid; grid-template-columns:1fr; gap:16px }
@media(min-width:900px){ .grid{ grid-template-columns:1fr 1fr } }

.flow{ display:flex; align-items:center; flex-wrap:wrap; gap:8px }
.flow-step{
  background:var(--surface-input); /* was #0e1116 */
  border:1px dashed var(--border); border-radius:8px; padding:10px; min-width:180px
}
.flow-step .meta{ font-size:12px; color:var(--muted); margin-top:4px }
.flow-step .note{ font-size:12px; color:var(--text); margin-top:4px }
.flow-step.pending{ opacity:.85 } /* was .7 */
.flow-arrow{ color:var(--muted); padding:0 6px }

/* Workflow editor */
.wf-top{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:8px }
.wf-controls button{ margin-left:6px }
.wf-canvas{
  background:var(--surface-input); /* was #0e1116 */
  border:1px solid var(--border); border-radius:8px; overflow:hidden
}
.wf-panel{ margin-top:8px; display:flex; gap:12px; align-items:center }
.wf-panel select{ padding:6px; background:var(--surface-input); color:var(--text); border:1px solid var(--border); border-radius:6px }
.wf-inspector{ margin-top:8px; display:none }
.wf-inspector.active{ display:block }
.wf-inspector .row{ display:flex; gap:8px; align-items:center }
.wf-inspector .row + .row{ margin-top:8px }
.wf-node{ cursor:default }
.wf-node.status circle{ fill:var(--workflow-node-fill); stroke:var(--border) } /* was #1c2330 */
.wf-node.task rect{ fill:var(--workflow-node-fill); stroke:var(--border) }
.wf-node text{ fill:var(--text); font-size:12px; user-select:none }
.wf-node.current circle,.wf-node.current rect{ stroke:var(--brand); }
.wf-node.selected circle,.wf-node.selected rect{ stroke:var(--info); }
.wf-edge{ stroke:var(--workflow-edge); stroke-width:2.5px; cursor:pointer } /* was #000 */
.wf-edge.selected{ stroke:var(--workflow-edge) }
.wf-edge-label{ fill:var(--muted); font-size:12px; pointer-events:auto }
.wf-handle{ fill:var(--workflow-handle-fill); stroke:var(--workflow-handle-stroke); stroke-width:2px; cursor:crosshair } /* was #0b0d10 / #7c9cff */
.wf-handle.target{ stroke:var(--ok) }
.wf-rubber{ stroke:var(--workflow-handle-stroke); stroke-dasharray:4 4; stroke-width:2px }
.page-lead{ color:var(--muted); margin-top:-4px; max-width:640px }
.muted{ color:var(--muted); font-size:0.95rem }
.request-grid{ display:grid; gap:16px }
@media(min-width:980px){ .request-grid{ grid-template-columns:1fr 1fr; align-items:flex-start } }
.card-header{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:8px }
.ai-card .badge{ background:var(--surface-button-hover); color:var(--muted) }
.ai-preview{
  margin-top:12px; padding:12px;
  border:1px dashed var(--border); border-radius:10px;
  background:var(--surface-input);
  min-height:180px;
  display:flex; align-items:center; justify-content:center;
  text-align:center; color:var(--muted)
}
.ai-preview img{ max-width:100%; max-height:240px; border-radius:8px; border:1px solid var(--border); object-fit:contain; background:var(--surface-image) }
.ai-actions{ display:flex; flex-wrap:wrap; gap:8px; margin-top:12px }
.button.ghost{ background:transparent; color:var(--muted) }
.button.ghost:hover{ background:var(--surface-button); color:var(--text) }
.ai-status{
  margin-top:12px; font-size:14px;
  background:var(--surface-input); border:1px solid var(--border);
  border-radius:6px; padding:8px 10px;
  color:var(--muted)
}
.ai-status.success{ border-color:var(--done); color:var(--done) }
.ai-status.pending{ border-color:var(--info); color:var(--info) }
.ai-status.error{ border-color:var(--danger); color:var(--danger) }
.ai-summary{ margin-top:12px; padding:12px; border-radius:8px; background:var(--surface-input); border:1px solid var(--border) }
.ai-summary h3{ margin:0 0 6px; font-size:18px }
.ai-summary ul{ margin:8px 0 0; padding-left:18px; color:var(--muted) }
.ai-controls{ display:flex; flex-wrap:wrap; gap:8px; margin-top:12px }
.form-actions{ margin-top:16px; display:flex; justify-content:flex-end }
.ai-stack{ display:flex; flex-direction:column; gap:16px }
.ai-chat-log{
  min-height:180px; max-height:220px;
  overflow-y:auto;
  background:var(--surface-input);
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px;
  display:flex; flex-direction:column; gap:10px;
}
.ai-chat-placeholder{ color:var(--muted); font-size:0.95rem; text-align:center; padding:12px; border:1px dashed var(--border); border-radius:10px }
.ai-chat-entry{ padding:10px 12px; border-radius:10px; white-space:pre-wrap; line-height:1.4 }
.ai-chat-entry.user{ background:var(--chat-user-bg); align-self:flex-end; border:1px solid var(--chat-user-border) }
.ai-chat-entry.assistant{ background:var(--chat-assistant-bg); border:1px solid var(--chat-assistant-border) }
.ai-chat-input{ margin-top:12px; display:flex; flex-direction:column; gap:8px }
.ai-chat-input textarea{ width:100%; resize:vertical; min-height:70px }
.ai-chat-input button{ align-self:flex-end }
.button.sm{ padding:6px 10px; font-size:0.9rem }
.draft-card .ai-status{ margin-top:0 }
.card.stack{ display:flex; flex-direction:column; gap:24px }
.page-header{ display:flex; align-items:flex-start; justify-content:space-between; gap:16px; margin:24px 0 16px }
.page-header h1{ margin:0; font-size:1.6rem }
.header-actions{ display:flex; align-items:center; gap:12px; flex-wrap:wrap }

.account-card{ gap:24px }
.profile-head{ display:flex; align-items:center; gap:20px }
.profile-avatar{ width:72px; height:72px; border-radius:999px; background:var(--surface-chip); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:1.8rem; font-weight:700; text-transform:uppercase; overflow:hidden }
.profile-avatar img{ width:100%; height:100%; object-fit:cover }
.profile-meta h1{ margin:0 0 4px; font-size:1.6rem }
.profile-meta .muted{ margin:2px 0 0 }

.btn{ display:inline-flex; align-items:center; justify-content:center; padding:10px 18px; border-radius:10px; border:1px solid var(--border); background:var(--surface-button); color:var(--text); font-weight:600; text-decoration:none; transition:background .15s ease, transform .05s ease }
.btn:hover{ background:var(--surface-button-hover) }
.btn:active{ transform:translateY(1px) }
.btn.primary{ background:var(--brand); border-color:var(--brand); color:#09121f }
.btn.primary:hover{ background:#b6c7ff }
.btn.ghost{ background:transparent }
.btn.ghost:hover{ background:rgba(255,255,255,0.05) }
.btn.sm{ padding:6px 12px; font-size:0.9rem }
.btn:disabled{ opacity:0.6; pointer-events:none }

.badge{ display:inline-flex; align-items:center; gap:6px; padding:4px 10px; border-radius:999px; background:var(--surface-subtle); font-size:0.75rem; font-weight:600; text-transform:capitalize }
.badge-draft{ background:rgba(111,210,255,0.18); color:var(--info) }
.badge-active{ background:rgba(61,220,114,0.18); color:var(--ok) }
.badge-expired{ background:rgba(248,181,74,0.18); color:var(--warn) }
.badge-terminated{ background:rgba(248,114,114,0.18); color:var(--danger) }
.badge-planned{ background:rgba(111,210,255,0.18); color:var(--info) }
.badge-closed{ background:rgba(160,174,192,0.2); color:var(--muted) }

.section{ margin:24px 0 }
.section-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px }

.form-grid{ display:grid; gap:16px; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)) }
.field{ display:flex; flex-direction:column; gap:6px }
.field span{ font-size:0.8rem; letter-spacing:0.05em; color:var(--muted); text-transform:uppercase }
.field .required{ color:var(--danger); margin-left:4px }
.field input,
.field textarea,
.field select{ width:100%; padding:10px 12px; border:1px solid var(--border); border-radius:8px; background:var(--surface-input); color:var(--text); font-size:0.95rem }
.field textarea{ resize:vertical; min-height:80px }
.field select{ cursor:pointer }
.field.span-2{ grid-column:span 2 }
@media (max-width:640px){ .field.span-2{ grid-column:span 1 } }

.form-actions{ display:flex; justify-content:flex-end; gap:12px; margin-top:32px }
.contract-form{ padding:24px; display:block }

.alert{ padding:12px 16px; border-radius:10px; margin-bottom:16px }
.alert.error{ background:var(--alert-error-bg); border:1px solid var(--alert-error-border); color:var(--alert-error-text) }

.period-card{ margin-top:18px; padding:18px; background:var(--panel); border:1px solid var(--border); border-radius:14px }
.period-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom:16px }
.period-top h3{ margin:0; font-size:1.1rem }
.period-meta{ display:flex; align-items:center; gap:12px; margin-top:6px }
.period-actions{ display:flex; align-items:center; gap:8px }
.inline-actions{ margin-top:12px }

.items-table input,
.items-table textarea,
.items-table select{ width:100%; box-sizing:border-box; background:var(--surface-input-alt) }
.items-table .stacked{ flex-direction:column }

.stack{ display:flex; flex-direction:column; gap:16px }
.stacked{ display:flex; flex-direction:column; gap:4px }
.stacked.no-gap{ gap:6px }

.empty{ text-align:center; padding:32px 0 }
.actions{ text-align:right }
.table.compact th,
.table.compact td{ padding:8px 10px }

.header-actions .badge{ margin-right:8px }

.detail-grid{ display:grid; gap:14px 20px; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)) }
.detail-grid dt{ margin:0; font-size:0.75rem; letter-spacing:0.04em; color:var(--muted); text-transform:uppercase }
.detail-grid dd{ margin:2px 0 0; font-size:1rem; font-weight:600 }
.detail-grid .span-2{ grid-column:span 2 }
@media (max-width:640px){ .detail-grid .span-2{ grid-column:span 1 } }

.highlight-card{ margin:24px 0; padding:18px 20px; border-radius:14px; border:1px solid rgba(61,220,114,0.25); background:rgba(61,220,114,0.12); display:flex; justify-content:space-between; align-items:center }
.highlight-card strong{ font-size:1.35rem }

.period-detail{ margin:24px 0; padding:20px 22px }
.period-detail .period-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px }
.period-detail .period-head h2{ margin:0; font-size:1.2rem }
.period-detail .period-head .muted{ font-size:0.9rem }
.sep{ margin:0 6px; color:var(--muted) }
.cap{ text-transform:capitalize }
.mini{ font-size:0.75rem; display:block }
.subtotal td{ border-top:1px solid var(--border); font-weight:600 }
.period-items td{ vertical-align:top }
.small{ font-size:0.9rem }




.property-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:24px}
.property-title h1{margin:0;font-size:1.9rem}
.property-title p{margin:4px 0 0;color:var(--muted)}
.property-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--muted);margin-bottom:8px}
.property-breadcrumb a{color:inherit;text-decoration:none}
.property-breadcrumb a:hover{text-decoration:underline}
.property-quick{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.quick-stat{min-width:120px;padding:12px 16px;border:1px solid var(--border);border-radius:10px;background:var(--surface-panel);text-align:left}
.quick-stat span{display:block;font-size:.75rem;text-transform:uppercase;color:var(--muted);letter-spacing:.04em}
.quick-stat strong{display:block;margin-top:6px;font-size:1.1rem;color:var(--fg-strong)}
.message-banner{padding:12px 16px;border-radius:10px;font-weight:500;margin-bottom:18px;border:1px solid transparent}
.message-success{background:rgba(46,160,67,.12);color:#2ea043;border-color:rgba(46,160,67,.3)}
.message-error{background:rgba(248,81,73,.12);color:#f85149;border-color:rgba(248,81,73,.3)}
.property-detail-columns{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:24px;margin-bottom:24px}
@media (max-width:960px){.property-detail-columns{grid-template-columns:minmax(0,1fr)}}
.property-meta-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.property-meta-card{background:var(--surface-card);border:1px solid var(--border);border-radius:14px;padding:18px}
.property-meta-card h3{margin:0 0 12px;font-size:1rem}
.property-meta-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 16px}
.property-meta-list dt{margin:0;font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.property-meta-list dd{margin:0;font-weight:500;color:var(--fg)}
.property-side{display:flex;flex-direction:column;gap:20px}
.property-photo{display:flex;align-items:center;justify-content:center;background:var(--surface-panel);border:1px solid var(--border);border-radius:14px;min-height:220px;overflow:hidden}
.property-photo img{display:block;width:100%;height:auto}
.property-plan.card{padding:16px}
.property-plan-viewer{margin-bottom:12px;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff}
.property-plan-viewer embed{width:100%;height:320px;display:block;border:0}
.form-inline{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin-top:8px}
.file-field span{display:block;font-size:.75rem;color:var(--muted);margin-bottom:4px}
.area-form .form-actions{grid-column:1/-1;display:flex;justify-content:flex-end}
.area-plan-actions{display:flex;flex-direction:column;gap:12px}
.area-plan-actions .form-inline select{min-width:200px}
.tree-table .tree-cell{display:flex;flex-direction:column}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.tree-table .tree-cell strong{font-weight:600}
.form-sections{display:flex;flex-direction:column;gap:24px}
.form-section h3{margin:0 0 12px}
.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:16px}
.table .actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.message-banner + .card{margin-top:0}
.area-detail-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:24px}
.area-summary{display:flex;flex-direction:column;gap:12px}
.area-actions{display:flex;flex-direction:column;gap:8px}
@media (max-width:720px){.table .actions{justify-content:flex-start}}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.ai-pill{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;font-size:14px}
.ai-pill svg{width:18px;height:18px}
.ai-pill kbd{background:var(--surface-chip);border:1px solid var(--border);border-radius:6px;padding:2px 6px;font-size:11px;color:var(--muted)}
.ai-assistant-backdrop{position:fixed;inset:0;background:rgba(9,12,16,0.55);backdrop-filter:blur(2px);z-index:90}
.ai-assistant-backdrop[hidden]{display:none}
.event-modal-backdrop{position:fixed;inset:0;background:rgba(9,12,16,0.6);backdrop-filter:blur(2px);z-index:140}
.event-modal-backdrop[hidden]{display:none}
.event-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;z-index:150}
.event-modal[hidden]{display:none}
.event-modal-dialog{background:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);width:min(560px,100%);max-height:90vh;overflow:auto;display:flex;flex-direction:column}
.event-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 24px 0}
.event-modal-head h2{margin:0;font-size:1.25rem}
.event-modal-head p{margin:4px 0 0}
.event-form{display:flex;flex-direction:column;gap:16px;padding:0 24px 24px}
.event-form .alert{margin-bottom:0}
.event-form-grid{gap:16px}
.event-form-grid .field textarea{min-height:96px}
.event-schedule-note{margin-top:-8px;grid-column:span 2}
.event-checkbox{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--border);grid-column:span 2}
.event-checkbox span{font-weight:500}
@media (max-width:640px){ .event-checkbox{grid-column:span 1} }
.event-checkbox input{width:18px;height:18px}
.event-form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}
.event-error-list{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:4px}
.event-conflict details{margin-top:8px}
.event-conflict summary{cursor:pointer;color:var(--link)}
.event-conflict ul{margin:8px 0 0 16px;padding:0;list-style:disc;display:flex;flex-direction:column;gap:4px}
.event-form.is-submitting{opacity:0.9}
body.modal-open{overflow:hidden}
.ai-assistant{position:fixed;top:72px;left:50%;transform:translateX(-50%);width:min(440px,calc(100% - 32px));background:var(--surface-panel);border:1px solid var(--border);border-radius:16px;box-shadow:0 18px 40px rgba(0,0,0,0.35);z-index:95;display:flex;flex-direction:column;max-height:calc(100vh - 128px)}
.ai-assistant[hidden]{display:none}
.ai-assistant-head{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 20px;gap:16px;border-bottom:1px solid var(--border)}
.ai-assistant-actions{display:flex;align-items:center;gap:8px}
.ai-assistant-pin.active{color:var(--brand)}
.ai-assistant-head h2{margin:0;font-size:1.05rem}
.ai-assistant-status{margin:4px 0 0;font-size:.85rem;color:var(--muted)}
.ai-chat-log{padding:16px 20px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;max-height:320px}
.ai-chat-message{display:flex}
.ai-chat-message.user{justify-content:flex-end}
.ai-chat-message.assistant{justify-content:flex-start}
.ai-chat-bubble{max-width:85%;padding:10px 14px;border-radius:12px;border:1px solid var(--border);background:var(--surface-subtle);box-shadow:0 6px 16px rgba(0,0,0,0.18);white-space:pre-line}
.ai-chat-message.user .ai-chat-bubble{background:var(--chat-user-bg,var(--surface-button));border-color:var(--chat-user-border,var(--border))}
.ai-chat-message.assistant .ai-chat-bubble{background:var(--chat-assistant-bg,var(--surface-input));border-color:var(--chat-assistant-border,var(--border))}
.ai-chat-suggestions{padding:0 20px 12px}
.ai-action-list{display:flex;flex-wrap:wrap;gap:8px}
.ai-action-btn{border:1px solid var(--border);background:var(--surface-chip);color:var(--text);border-radius:999px;padding:6px 12px;font-size:13px;cursor:pointer;transition:background .15s ease,transform .15s ease}
.ai-action-btn:hover{background:var(--surface-button-hover);transform:translateY(-1px)}
.ai-chat-form{padding:12px 20px 20px;display:flex;flex-direction:column;gap:12px;border-top:1px solid var(--border)}
.ai-chat-form textarea{resize:vertical;min-height:64px;max-height:220px;border-radius:12px;border:1px solid var(--border);background:var(--surface-input);color:var(--text);padding:12px;font-size:14px}
.ai-chat-form textarea:focus{outline:2px solid var(--brand);outline-offset:2px}
.ai-chat-form-actions{display:flex;justify-content:flex-end}
.ai-assistant.open{animation:aiAssistantFade .18s ease-out}
.ai-assistant.pinned{left:auto;right:24px;transform:none;top:96px;max-height:calc(100vh - 144px)}
.ai-assistant.pinned .ai-chat-log{max-height:calc(100vh - 320px);min-height:200px}
.ai-assistant.pinned .ai-chat-form textarea{min-height:80px}
@keyframes aiAssistantFade{from{opacity:0;transform:translate(-50%,-6px);}to{opacity:1;transform:translate(-50%,0);}}
@media (max-width:640px){.ai-assistant{top:56px;width:calc(100% - 24px);left:12px;transform:none}.ai-assistant.open{animation:none}}
@media (max-width:640px){.ai-assistant.pinned{right:12px;left:12px;top:64px}}

.metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.metric-card{background:var(--surface-panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow-soft)}
.metric-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:4px}
.metric-value{font-size:1.75rem;font-weight:600;color:var(--fg-strong)}

.schedule-card .stepper{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.step-trigger{border:1px solid var(--border);background:var(--surface-button);color:var(--muted);border-radius:var(--radius-pill);padding:6px 16px;font-size:.9rem;cursor:pointer;transition:all .2s ease}
.step-trigger:hover{border-color:var(--brand);color:var(--brand)}
.step-trigger.active{background:var(--brand);color:#0b1020;border-color:var(--brand);font-weight:600;box-shadow:0 0 0 3px var(--focus-ring)}
.step-pane{display:none}
.step-pane.active{display:block}
.scope-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}
.scope-option{display:flex;gap:12px;padding:12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-subtle);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}
.scope-option input{margin-top:4px}
.scope-option strong{display:block;font-size:1rem;margin-bottom:4px;color:var(--fg)}
.scope-option small{display:block;font-size:.78rem;color:var(--muted)}
.scope-option input:checked + span strong{color:var(--brand)}
.scope-option input:checked + span small{color:var(--text)}
.scope-option input:checked ~ span{font-weight:500}
.scope-selectors{display:grid;gap:16px;margin-bottom:12px}
.scope-selectors .field{transition:all .2s ease}
.scope-selectors .field.active select{border-color:var(--brand);box-shadow:0 0 0 3px var(--focus-ring)}

.chip-group{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}
.chip{border:1px solid var(--border);background:var(--surface-chip);color:var(--muted);padding:6px 14px;border-radius:var(--radius-pill);font-size:.85rem;cursor:pointer;transition:all .2s ease}
.chip:hover{border-color:var(--brand);color:var(--brand)}
.chip.active{background:var(--brand);color:#0b1020;border-color:var(--brand);box-shadow:0 0 0 3px var(--focus-ring)}

.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:16px}
.filters-grid .field select,.filters-grid .field input{width:100%}

.segmented-control{display:flex;gap:8px;flex-wrap:wrap}
.segment{border:1px solid var(--border);background:var(--surface-button);color:var(--muted);padding:6px 16px;border-radius:var(--radius-pill);cursor:pointer;transition:all .2s ease}
.segment:hover{border-color:var(--brand);color:var(--brand)}
.segment.active{background:var(--brand);color:#0b1020;border-color:var(--brand);font-weight:600}

.schedule-table .actions,.inspection-table .actions,.card .actions{display:flex;flex-wrap:wrap;gap:8px}
.btn.ghost{border:1px solid var(--border);background:transparent;color:var(--muted);border-radius:var(--radius-pill);padding:6px 14px;font-size:.85rem;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.btn.ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn.ghost.active{border-color:var(--brand);color:var(--brand);background:rgba(124,156,255,0.12)}

.schedule-table tr.highlight{animation:scheduleHighlight 2s ease-out forwards}
@keyframes scheduleHighlight{0%{background:rgba(157,182,255,0.18);}100%{background:transparent;}}

.customizer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}

.template-hint{margin-top:8px}

.table.tight th,.table.tight td{padding:8px 12px}

.sub-card{background:var(--surface-subtle);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;margin-bottom:16px}
.sub-card.active{border-color:var(--brand);box-shadow:0 0 0 3px var(--focus-ring)}
.sub-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.sub-card .form-grid{margin-top:12px}

.schedule-list-card .empty-state,.inspection-table .empty-state,.card .empty-state{margin-top:12px}

.calendar-page{display:flex;flex-direction:column;gap:16px}
.calendar-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:12px}
.calendar-toolbar .field{min-width:220px}
.calendar-toolbar-actions{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-left:auto}
.calendar-nav{display:flex;align-items:center;gap:8px}
.calendar-current{font-weight:600;color:var(--fg)}
.calendar-view-toggle{display:flex;gap:8px}
.calendar-card{padding:16px;display:flex;flex-direction:column;gap:16px}
.calendar-legend{display:flex;flex-wrap:wrap;gap:12px}
.calendar-legend-item{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:.85rem}
.calendar-legend-item.active{color:var(--fg)}
.calendar-legend-dot{width:10px;height:10px;border-radius:50%}
.calendar-container{display:flex;flex-direction:column;gap:8px;--calendar-hour-height:52px}
.calendar-month-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}
.calendar-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px;text-transform:uppercase;font-size:.75rem;color:var(--muted)}
.calendar-weekdays div{text-align:center;padding:6px 0}
.calendar-cell{border:1px solid var(--border);border-radius:8px;min-height:120px;padding:8px;display:flex;flex-direction:column;gap:6px;background:var(--surface-subtle)}
.calendar-weekdays-grid{grid-template-columns:72px repeat(7,minmax(0,1fr));gap:8px;align-items:end;text-transform:uppercase}
.calendar-weekdays-day{grid-template-columns:72px 1fr}
.calendar-weekday-spacer{padding:6px 0}
.calendar-weekday-cell{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 0;text-transform:none;font-size:.8rem;color:var(--muted)}
.calendar-weekday-cell.today,.calendar-weekday-cell.selected{color:var(--fg);font-weight:600}
.calendar-weekday-name{font-size:.7rem;letter-spacing:.05em;color:var(--muted);text-transform:uppercase}
.calendar-weekday-cell.today .calendar-weekday-name,.calendar-weekday-cell.selected .calendar-weekday-name{color:var(--fg)}
.calendar-weekday-date{font-size:1rem;font-weight:600;color:var(--fg);text-transform:none}
.calendar-week-grid{display:grid;grid-template-columns:72px repeat(7,minmax(0,1fr));gap:8px;align-items:flex-start}
.calendar-week-grid-day{grid-template-columns:72px 1fr}
.calendar-time-column{display:flex;flex-direction:column;align-items:flex-end;height:calc(var(--calendar-hour-height)*24);padding-top:6px;gap:0;position:relative}
.calendar-time-label{height:var(--calendar-hour-height);font-size:.75rem;color:var(--muted);display:flex;align-items:flex-start;justify-content:flex-end;padding-right:8px}
.calendar-day-column{display:flex;flex-direction:column}
.calendar-day-body{position:relative;height:calc(var(--calendar-hour-height)*24);background:var(--surface-subtle);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.calendar-day-body::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(to bottom,transparent,transparent calc(var(--calendar-hour-height) - 1px),rgba(233,238,243,.08) calc(var(--calendar-hour-height) - 1px),rgba(233,238,243,.08) var(--calendar-hour-height));pointer-events:none}
.calendar-day-body.today,.calendar-day-body.selected{border-color:var(--brand,#7c9cff);box-shadow:0 0 0 1px rgba(124,156,255,.35)}
.calendar-date{font-weight:600;color:var(--fg)}
.calendar-events{display:flex;flex-direction:column;gap:6px}
.calendar-event{display:block;padding:6px 8px;border-radius:6px;color:#0b1020;font-weight:600;text-decoration:none;transition:transform .1s ease,box-shadow .1s ease}
.calendar-event:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(12,18,28,0.25)}
.calendar-event-block{position:absolute;left:8px;right:8px;border-radius:10px;color:#0b1020;padding:6px 8px;display:flex;flex-direction:column;gap:4px;font-size:.85rem;text-decoration:none;box-shadow:0 10px 24px rgba(11,16,32,.28);transition:transform .1s ease,box-shadow .1s ease}
.calendar-event-block:hover{transform:translateY(-1px);box-shadow:0 14px 32px rgba(11,16,32,.35)}
.calendar-event-range{font-size:.75rem;font-weight:600}
.calendar-event-title{font-weight:600;line-height:1.2}
.calendar-container .muted .calendar-date{color:var(--muted)}



.toast-container{position:fixed;bottom:2rem;right:2rem;display:flex;flex-direction:column;gap:.75rem;z-index:2147483647;pointer-events:none}
.toast{min-width:280px;max-width:min(360px,calc(100vw - 2rem));background:var(--surface-menu,#1c2430);color:var(--text,#f5f7fb);border:1px solid var(--border,rgba(255,255,255,.1));border-radius:12px;padding:1rem 1.25rem;box-shadow:0 18px 48px rgba(0,0,0,.25);opacity:0;transform:translateY(10px);transition:opacity .2s ease,transform .2s ease;pointer-events:auto}
.toast.visible{opacity:1;transform:translateY(0)}
.toast-title{font-weight:600;margin-bottom:.4rem}
.toast-body{font-size:.95rem;line-height:1.4;margin:0 0 .6rem;color:var(--muted,#b2bdc8)}
.toast-url{display:block;font-family:ui-monospace,SFMono-Regular,SFMono,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:.85rem;background:var(--surface-input,rgba(255,255,255,.08));color:var(--link,#9db6ff);padding:.35rem .5rem;border-radius:8px;margin-bottom:.75rem;word-break:break-all}
.toast-action{align-self:flex-start;border:none;border-radius:999px;background:var(--brand,#7c9cff);color:var(--brand-contrast,#09121f);font-weight:600;font-size:.9rem;padding:.45rem .9rem;cursor:pointer;transition:background .2s ease,transform .2s ease}
.toast-action:focus,.toast-action:hover{background:var(--brand-hover,#b6c7ff);transform:translateY(-1px)}
.toast-action:focus{outline:2px solid var(--focus-shadow,rgba(124,156,255,.4));outline-offset:2px}
