/* ── Shared components ──────────────────────────────────────────── */

/* Page header */
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:26px}
.eyebrow{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;font-weight:500}
.page-title{font-family:var(--font-display);font-weight:700;font-size:27px;letter-spacing:-.02em;color:var(--text);line-height:1.1}
.page-sub{color:var(--text-soft);font-size:14px;margin-top:7px;max-width:62ch;overflow-wrap:anywhere}
.page-actions{display:flex;gap:9px;flex:0 0 auto}

/* Sections (vertical spacing handled by .module-body rhythm) */
.sec{margin-bottom:0}
.sec-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:13px}
.sec-head h2{font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:-.01em}
.sec-actions{display:flex;gap:8px}

/* Orchestrator banner (Settings → Workflows) */
.orchestrator{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  padding:18px 20px;border:1px solid var(--accent);border-radius:var(--radius);
  background:linear-gradient(110deg,color-mix(in srgb,var(--accent) 9%,var(--surface)),var(--surface));
  box-shadow:var(--shadow)}
.orchestrator-main{display:flex;align-items:center;gap:14px;flex:1 1 320px;min-width:0}
.orchestrator-icon{width:38px;height:38px;border-radius:10px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  background:var(--accent);color:#fff;font-size:18px}
.orchestrator-title{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--text)}
.orchestrator-sub{font-size:12.5px;color:var(--text-soft);margin-top:3px;line-height:1.45;max-width:54ch}
.orchestrator-pick{flex:0 0 auto;min-width:220px}

/* Grid */
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-5{grid-template-columns:repeat(5,1fr)}
@media (max-width:1080px){.grid-4,.grid-5{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.grid-2,.grid-3,.grid-4,.grid-5{grid-template-columns:1fr}}

/* Cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.card-flush{padding:0;overflow:hidden}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.card-head h3{font-family:var(--font-display);font-weight:700;font-size:14.5px}

/* Stat tiles */
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.stat-icon{font-size:18px;margin-bottom:10px;opacity:.85}
.stat-label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);font-weight:500}
.stat-value{font-family:var(--font-display);font-weight:700;font-size:26px;letter-spacing:-.02em;margin-top:6px;color:var(--text)}
.stat-delta{font-size:12px;font-weight:600;margin-top:6px;display:inline-flex;align-items:center;gap:4px}
.stat-delta.up{color:#0f9d63}.stat-delta.up::before{content:'▲';font-size:8px}
.stat-delta.down{color:#dc2626}.stat-delta.down::before{content:'▼';font-size:8px}
.stat-delta.flat{color:var(--text-faint)}
.stat-hint{font-size:11px;color:var(--text-faint);margin-top:4px}

/* Compact list */
.clist{list-style:none}
.clist-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--line-soft)}
.clist-row:first-child{border-top:0}
.clist-title{font-size:13.5px;font-weight:500;color:var(--text)}
.clist-meta{font-size:11.5px;color:var(--text-faint);margin-top:2px}
.clist-right{flex:0 0 auto}

/* Tables */
.tbl-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);font-weight:500;text-align:left;padding:13px 16px;border-bottom:1.5px solid var(--line);background:var(--surface-2)}
.tbl td{padding:13px 16px;border-bottom:1px solid var(--line-soft);color:var(--text-soft)}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl tbody tr{transition:background .12s}
.tbl tbody tr:hover{background:var(--surface-2)}
.tbl.zebra tbody tr:nth-child(even){background:color-mix(in srgb,var(--surface-2) 55%,transparent)}
.ta-right{text-align:right}.ta-center{text-align:center}
.tbl td strong{color:var(--text);font-weight:600}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;font-weight:500;padding:4px 9px;border-radius:6px;border:1px solid transparent}
.badge-neutral{background:var(--surface-2);color:var(--text-soft);border-color:var(--line)}
.badge-accent{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 30%,transparent)}
.badge-success{background:#e7f6ee;color:#0f8a52;border-color:#bfe8d2}
.badge-warning{background:#fdf3e3;color:#b5730e;border-color:#f3dcae}
.badge-danger{background:#fdecec;color:#cf2f2f;border-color:#f6caca}
.badge-info{background:#eaf2fe;color:#2563eb;border-color:#cfe0fb}
.sdot{width:7px;height:7px;border-radius:50%;display:inline-block}
.sdot-success{background:#10b981}.sdot-warning{background:#f59e0b}.sdot-danger{background:#ef4444}.sdot-neutral{background:#94a3b8}.sdot-accent{background:var(--accent)}

/* Buttons */
.ui-btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-body);font-size:12.5px;font-weight:600;padding:9px 15px;border-radius:9px;cursor:pointer;border:1px solid var(--line);background:var(--surface);color:var(--text);transition:.15s}
.ui-btn:hover{border-color:var(--accent);color:var(--accent)}
.ui-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.ui-btn-primary:hover{filter:brightness(1.08);color:#fff}
.ui-btn-ghost{background:transparent}
.ui-btn-soft{background:var(--surface-2);border-color:transparent}
.ui-btn-ico{font-size:14px}

/* AI smart button */
.smart-btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-body);font-size:12px;font-weight:600;padding:7px 13px;border-radius:8px;cursor:pointer;color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent);border:1px solid color-mix(in srgb,var(--accent) 26%,transparent);transition:.16s;position:relative;overflow:hidden}
.smart-btn:hover{background:color-mix(in srgb,var(--accent) 15%,transparent);transform:translateY(-1px)}
.smart-btn .smart-spark{animation:spark 2.4s ease-in-out infinite}
.smart-block{width:100%;justify-content:center}
@keyframes spark{0%,100%{opacity:1}50%{opacity:.5;transform:scale(1.15)}}

/* Charts */
.spark{display:block}
.donut-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}
.donut-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint)}

/* Meter */
.meter{height:7px;border-radius:5px;background:var(--surface-2);overflow:hidden}
.meter-fill{height:100%;border-radius:5px;background:var(--accent);transition:width .6s cubic-bezier(.2,.7,.2,1)}
.meter-success{background:#10b981}.meter-warning{background:#f59e0b}.meter-danger{background:#ef4444}

/* Toggle */
.tg{display:inline-flex;align-items:center;gap:10px;cursor:pointer}
.tg input{display:none}
.tg-track{width:40px;height:23px;border-radius:14px;background:var(--line);position:relative;transition:.2s;flex:0 0 auto}
.tg-knob{position:absolute;top:2.5px;left:2.5px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:.2s}
.tg input:checked+.tg-track{background:var(--accent)}
.tg input:checked+.tg-track .tg-knob{transform:translateX(17px)}
.tg-label{font-size:13px;color:var(--text-soft)}

/* Fields & selects */
.ui-field{display:flex;flex-direction:column;gap:6px}
.ui-field-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint)}
.ui-select{position:relative;display:inline-block}
.ui-select::after{content:'▾';position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-faint);pointer-events:none;font-size:11px}
.ui-select select{appearance:none;font-family:var(--font-body);font-size:13px;color:var(--text);padding:9px 32px 9px 13px;border:1px solid var(--line);border-radius:9px;background:var(--surface);cursor:pointer;min-width:200px;transition:.15s}
.ui-select select:hover{border-color:var(--accent)}

/* Avatar */
.uavatar{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;background:var(--accent);color:#fff;font-family:var(--font-display);font-weight:700;font-size:11px}

/* Settings rows */
.set-row{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:16px 0;border-top:1px solid var(--line-soft)}
.set-row:first-child{border-top:0}
.set-row-text{flex:1 1 auto}
.set-row-title{font-size:14px;font-weight:600;color:var(--text)}
.set-row-desc{font-size:12.5px;color:var(--text-faint);margin-top:3px;max-width:62ch}

/* ── AI helper (floating) ───────────────────────────────────────── */
.ai-launcher{position:fixed;right:22px;bottom:22px;z-index:70;--ai-accent:var(--accent)}
.ai-fab{width:58px;height:58px;border-radius:50%;border:0;cursor:pointer;background:var(--ai-accent);color:#fff;box-shadow:0 12px 30px color-mix(in srgb,var(--ai-accent) 45%,transparent);display:flex;align-items:center;justify-content:center;transition:.22s cubic-bezier(.2,.7,.2,1);position:relative}
.ai-fab:hover{transform:translateY(-2px) scale(1.04)}
.ai-fab-icon{font-size:24px;transition:.2s}
.ai-fab-close{position:absolute;font-size:20px;opacity:0;transform:scale(.5);transition:.2s}
body.ai-open .ai-fab-icon{opacity:0;transform:scale(.5)}
body.ai-open .ai-fab-close{opacity:1;transform:scale(1)}
body.ai-open .ai-fab{transform:rotate(0)}

.ai-panel{position:absolute;right:0;bottom:74px;width:390px;max-width:calc(100vw - 36px);height:560px;max-height:calc(100vh - 130px);background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(14px) scale(.97);pointer-events:none;transform-origin:bottom right;transition:.24s cubic-bezier(.2,.7,.2,1)}
body.ai-open .ai-panel{opacity:1;transform:none;pointer-events:auto}
.ai-head{display:flex;align-items:center;gap:11px;padding:15px 16px;background:var(--ai-accent);color:#fff}
.ai-head-avatar{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-size:18px}
.ai-head-meta{flex:1 1 auto;min-width:0}
.ai-head-name{font-family:var(--font-display);font-weight:700;font-size:15px}
.ai-head-sub{font-size:11px;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ai-head-clear{background:rgba(255,255,255,.16);border:0;color:#fff;width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:14px;transition:.15s}
.ai-head-clear:hover{background:rgba(255,255,255,.28)}
.ai-demo-note{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);background:var(--surface-2);padding:8px 16px;border-bottom:1px solid var(--line-soft);text-align:center}
.ai-log{flex:1 1 auto;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.ai-msg{display:flex;gap:9px;align-items:flex-end;max-width:90%}
.ai-user{align-self:flex-end;flex-direction:row-reverse}
.ai-msg-avatar{width:26px;height:26px;border-radius:8px;background:color-mix(in srgb,var(--ai-accent) 14%,transparent);color:var(--ai-accent);display:flex;align-items:center;justify-content:center;font-size:13px;flex:0 0 auto}
.ai-bubble{padding:10px 13px;border-radius:13px;font-size:13.5px;line-height:1.5;color:var(--text)}
.ai-assistant .ai-bubble{background:var(--surface-2);border-bottom-left-radius:4px}
.ai-user .ai-bubble{background:var(--ai-accent);color:#fff;border-bottom-right-radius:4px}
.ai-typing{display:flex;gap:4px;padding:13px}
.ai-typing span{width:6px;height:6px;border-radius:50%;background:var(--text-faint);animation:blink 1.3s infinite}
.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.3}30%{opacity:1}}
.ai-suggest{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 12px}
.ai-chip{font-size:11.5px;padding:7px 11px;border-radius:8px;border:1px solid var(--line);background:var(--surface);color:var(--text-soft);cursor:pointer;transition:.15s;text-align:left}
.ai-chip:hover{border-color:var(--ai-accent);color:var(--ai-accent)}
.ai-form{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line-soft)}
.ai-form-locked{opacity:.5;pointer-events:none}
.ai-input{flex:1 1 auto;border:1px solid var(--line);border-radius:11px;padding:11px 13px;font-family:var(--font-body);font-size:13.5px;color:var(--text);background:var(--surface);outline:none;transition:.15s}
.ai-input:focus{border-color:var(--ai-accent)}
.ai-send{width:42px;border:0;border-radius:11px;background:var(--ai-accent);color:#fff;cursor:pointer;font-size:18px;transition:.15s}
.ai-send:hover{filter:brightness(1.08)}
/* Lead capture card (shown at message cap) */
.ai-lead{margin:8px 4px 2px;padding:16px;border:1px solid var(--ai-accent);border-radius:14px;background:linear-gradient(180deg,color-mix(in srgb,var(--ai-accent) 7%,var(--surface)),var(--surface));animation:leadIn .3s ease}
@keyframes leadIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.ai-lead-head{font-family:var(--font-display,var(--font-body));font-weight:700;font-size:15px;color:var(--text);margin-bottom:4px}
.ai-lead-sub{font-size:12.5px;line-height:1.5;color:var(--text-soft);margin-bottom:12px}
.ai-lead-form{display:flex;flex-direction:column;gap:8px}
.ai-lead-input{border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-family:var(--font-body);font-size:13px;color:var(--text);background:var(--surface);outline:none;transition:.15s;width:100%;box-sizing:border-box}
.ai-lead-input:focus{border-color:var(--ai-accent)}
.ai-lead-area{resize:vertical;min-height:38px}
.ai-lead-btn{margin-top:2px;border:0;border-radius:11px;background:var(--ai-accent);color:#fff;font-family:var(--font-body);font-weight:600;font-size:13.5px;padding:11px 14px;cursor:pointer;transition:.15s;text-align:center;text-decoration:none;display:block}
.ai-lead-btn:hover{filter:brightness(1.08)}
.ai-lead-btn:disabled{opacity:.6;cursor:default}
.ai-lead-link{margin-top:8px}
.ai-lead-err{color:var(--danger,#ef4444);font-size:11.5px;min-height:4px}
.ai-lead-done{border-color:color-mix(in srgb,var(--ai-accent) 50%,var(--line))}
@media (max-width:520px){.ai-panel{width:calc(100vw - 24px);height:calc(100vh - 120px)}.ai-launcher{right:14px;bottom:14px}}

/* ── Industry-flavor layout blocks ─────────────────────────────── */
/* Asymmetric split (main + rail) */
.split{display:grid;grid-template-columns:1.85fr 1fr;gap:16px;align-items:start}
@media (max-width:980px){.split{grid-template-columns:1fr}}
.split-main > * + *,.split-rail > * + *{margin-top:16px}

/* Event feed / timeline */
.feed{list-style:none}
.feed-row{display:flex;align-items:flex-start;gap:12px;padding:11px 0;border-top:1px solid var(--line-soft)}
.feed-row:first-child{border-top:0}
.feed-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;margin-top:5px;box-shadow:0 0 0 3px color-mix(in srgb,currentColor 12%,transparent)}
.feed-body{flex:1 1 auto;min-width:0}
.feed-top{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.feed-title{font-size:13.5px;font-weight:600;color:var(--text)}
.feed-time{font-family:var(--font-mono);font-size:10.5px;color:var(--text-faint);flex:0 0 auto}
.feed-meta{font-size:12px;color:var(--text-faint);margin-top:2px;line-height:1.45}
.feed-right{flex:0 0 auto;align-self:center}

/* Spotlight / hero panel */
.spotlight{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  padding:22px 24px;border:1px solid color-mix(in srgb,var(--accent) 40%,var(--line));border-radius:var(--radius);
  background:linear-gradient(115deg,color-mix(in srgb,var(--accent) 12%,var(--surface)),var(--surface) 70%);
  box-shadow:var(--shadow)}
.spotlight-text{flex:1 1 340px;min-width:0}
.spotlight-title{font-family:var(--font-display);font-weight:700;font-size:19px;letter-spacing:-.01em;color:var(--text);margin-top:2px;line-height:1.2}
.spotlight-body{font-size:13px;color:var(--text-soft);margin-top:8px;max-width:60ch;line-height:1.5}
.spotlight-action{margin-top:14px}
.spotlight-metric{flex:0 0 auto;text-align:right}
.spotlight-metric-val{font-family:var(--font-display);font-weight:800;font-size:40px;letter-spacing:-.03em;color:var(--accent);line-height:1}
.spotlight-metric-lbl{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);margin-top:6px}

/* Progress list */
.plist-row{margin:0 0 16px}
.plist-row:last-child{margin-bottom:0}
.plist-top{display:flex;justify-content:space-between;font-size:13px;margin-bottom:7px}
.plist-name{font-weight:600;color:var(--text)}
.plist-n{color:var(--text-faint);font-family:var(--font-mono);font-size:11px}

/* KPI rail */
.kpi-rail-card{padding:0}
.kpi-rail{display:flex;flex-wrap:wrap}
.kpi{flex:1 1 0;min-width:120px;padding:18px 20px;border-right:1px solid var(--line-soft)}
.kpi:last-child{border-right:0}
.kpi-val{font-family:var(--font-display);font-weight:700;font-size:23px;letter-spacing:-.02em;color:var(--text)}
.kpi-lbl{font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);margin-top:5px}
.kpi-delta{font-size:11.5px;font-weight:600;margin-top:5px;display:inline-flex;align-items:center;gap:3px}
.kpi-delta.up{color:#0f9d63}.kpi-delta.up::before{content:'▲';font-size:7px}
.kpi-delta.down{color:#dc2626}.kpi-delta.down::before{content:'▼';font-size:7px}
.kpi-delta.flat{color:var(--text-faint)}
@media (max-width:680px){.kpi{flex:1 1 50%;border-bottom:1px solid var(--line-soft)}}
/* compact KPI rail inside detail modals so 4 fit in one row */
.modal-body .kpi-rail{flex-wrap:nowrap}
.modal-body .kpi{min-width:0;padding:12px 12px}
.modal-body .kpi-val{font-size:18px}
.modal-body .kpi:last-child{border-right:0}

/* ── Task list ─────────────────────────────────────────────────── */
.tasklist-card{padding:0;overflow:hidden}
.tasklist{list-style:none}
.task-row{display:flex;align-items:flex-start;gap:14px;padding:16px 20px;border-top:1px solid var(--line-soft)}
.task-row:first-child{border-top:0}
.task-row:hover{background:color-mix(in srgb,var(--accent) 3%,transparent)}
/* select checkbox + visual check box, stacked so one click toggles */
.task-check-wrap{flex:0 0 auto;position:relative;width:18px;height:18px;margin-top:1px;display:inline-flex;cursor:pointer}
.task-check-wrap .task-sel-cb{position:absolute;inset:0;width:18px;height:18px;margin:0;opacity:0;cursor:pointer;z-index:2}
.task-check{width:18px;height:18px;border-radius:6px;border:1.5px solid color-mix(in srgb,var(--text-faint) 65%,var(--line));
  display:inline-flex;align-items:center;justify-content:center;font-size:11px;color:#fff;background:transparent;transition:.12s}
.task-check-wrap .task-sel-cb:checked ~ .task-check{background:var(--accent);border-color:var(--accent)}
.task-check-wrap .task-sel-cb:checked ~ .task-check::after{content:'\2713'}
.task-check-wrap .task-sel-cb:disabled{cursor:default}
.task-done .task-check{background:var(--accent);border-color:var(--accent)}
.task-body{flex:1 1 auto;min-width:0}
.task-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.35}
.task-done .task-title{text-decoration:line-through;color:var(--text-faint)}
.task-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:5px;font-size:12px;color:var(--text-faint)}
.task-assignee{font-weight:500;color:var(--text-soft)}
.task-sep{color:var(--text-faint);opacity:.6}
/* assignee pill (primary meta chip) */
.task-pill{display:inline-flex;align-items:center;font-size:11px;font-weight:600;line-height:1;
  padding:4px 9px;border-radius:999px;background:color-mix(in srgb,var(--accent) 12%,var(--surface-2));
  color:color-mix(in srgb,var(--accent) 75%,var(--text));border:1px solid color-mix(in srgb,var(--accent) 22%,transparent)}
/* subtle priority — small dot + muted text, not a loud badge */
.task-pri{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--text-faint)}
.task-pri::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--text-faint)}
.task-pri-danger::before{background:#ef4444}
.task-pri-warning::before{background:#e0a106}
.task-pri-neutral::before{background:color-mix(in srgb,var(--text-faint) 70%,var(--line))}
.task-smart{margin-top:11px;display:flex;align-items:center;flex-wrap:wrap;gap:6px}
/* task smart buttons: smaller + subtler + uniform height */
.task-smart .smart-btn{font-size:11px;font-weight:500;padding:4px 10px;gap:5px;
  line-height:16px;height:26px;border-radius:7px;
  background:color-mix(in srgb,var(--accent) 5%,transparent);
  border-color:color-mix(in srgb,var(--accent) 18%,transparent)}
.task-smart .smart-btn:hover{transform:none;background:color-mix(in srgb,var(--accent) 11%,transparent)}
.task-smart .smart-btn .smart-spark{font-size:11px;line-height:16px}
.task-actions{flex:0 0 auto;display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end;max-width:300px}
.task-act{font-family:var(--font-body);font-size:12px;font-weight:600;padding:6px 12px;border-radius:8px;
  border:1px solid color-mix(in srgb,var(--text-faint) 38%,var(--line));background:var(--surface-2);color:var(--text);cursor:pointer;transition:.15s;white-space:nowrap}
.task-act:hover{border-color:var(--accent);color:var(--text);background:color-mix(in srgb,var(--accent) 8%,var(--surface-2))}
.task-act-go{border-color:color-mix(in srgb,var(--accent) 45%,var(--line));color:var(--accent)}
.task-act-go:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.task-act-done{border-color:color-mix(in srgb,#10b981 45%,var(--line));color:#0f9d63}
.task-act-done:hover{background:#10b981;color:#fff;border-color:#10b981}
.task-act-dismiss:hover{border-color:#ef4444;color:#ef4444}
/* ── Task toolbar: select-all, filters, bulk actions ───────────── */
.task-toolbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:12px;padding:0 2px}
.task-selall{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--text-soft);cursor:pointer;user-select:none}
.task-selall input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}
.task-filters{display:flex;gap:8px;flex-wrap:wrap}
.task-filter{font-family:var(--font-body);font-size:12.5px;font-weight:500;color:var(--text);
  padding:7px 11px;border-radius:9px;border:1px solid var(--line);background:var(--surface);cursor:pointer;transition:.15s}
.task-filter:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--line))}
.task-filter:focus{outline:none;border-color:var(--accent)}
.task-bulk{display:inline-flex;align-items:center;gap:8px;margin-left:auto;padding:5px 8px;border-radius:10px;
  background:color-mix(in srgb,var(--accent) 7%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 20%,var(--line))}
.task-bulk[hidden]{display:none}
.task-bulk-count{font-size:12px;font-weight:700;color:var(--text-soft)}
@media (max-width:760px){
  .task-row{flex-wrap:wrap}
  .task-actions{max-width:none;width:100%;justify-content:flex-start;margin-top:10px;margin-left:32px}
}

/* ── Modal ─────────────────────────────────────────────────────── */
.modal-root{position:fixed;inset:0;z-index:150;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .18s}
.modal-root.modal-show{opacity:1}
.modal-backdrop{position:absolute;inset:0;background:rgba(8,12,22,.55);backdrop-filter:blur(2px)}
.modal-shell{position:relative;width:min(520px,calc(100vw - 32px));max-height:calc(100vh - 64px);
  background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);
  display:flex;flex-direction:column;transform:scale(.96) translateY(8px);
  transition:transform .2s cubic-bezier(.2,.7,.2,1);overflow:hidden}
.modal-root.modal-show .modal-shell{transform:none}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line-soft)}
.modal-title{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--text)}
.modal-close{background:transparent;border:0;color:var(--text-faint);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:.15s}
.modal-close:hover{background:var(--surface-2);color:var(--text)}
.modal-body{padding:18px 20px;overflow-y:auto;flex:1 1 auto;font-size:13.5px;color:var(--text-soft);line-height:1.55}
.modal-body strong{color:var(--text);font-weight:600}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--line-soft);background:var(--surface-2)}

.modal-field{display:flex;flex-direction:column;gap:6px;margin:12px 0}
.modal-field-label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint)}
.modal-input{font-family:var(--font-body);font-size:14px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--text);outline:none;transition:.15s}
.modal-input:focus{border-color:var(--accent)}
.modal-meta{display:grid;grid-template-columns:max-content 1fr;column-gap:18px;row-gap:8px;font-size:13px;margin-bottom:6px}
.modal-meta .k{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);align-self:center}
.modal-meta .v{color:var(--text);font-weight:500}
.modal-action-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.modal-action-list button{font-family:var(--font-body);font-size:13.5px;font-weight:600;padding:11px 14px;border-radius:10px;
  border:1px solid var(--line);background:var(--surface);color:var(--text);cursor:pointer;text-align:left;transition:.15s}
.modal-action-list button:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--surface))}

/* ── Multi-select chip list ────────────────────────────────────── */
.multi-select{display:flex;flex-wrap:wrap;gap:6px;max-width:560px}
.multi-chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;padding:5px 11px;border-radius:7px;
  border:1px solid var(--line);background:var(--surface);color:var(--text-soft);cursor:pointer;transition:.15s;user-select:none;line-height:1.4}
.multi-chip:hover{border-color:var(--accent);color:var(--accent)}
.multi-chip input{display:none}
.multi-chip.on{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);
  border-color:color-mix(in srgb,var(--accent) 40%,transparent);font-weight:600}
.multi-chip.on::before{content:'✓';font-size:10px;line-height:1}

/* ── Lumière floor-map (hover popover) ─────────────────────────── */
.flmap-card{border:1px solid var(--line);border-radius:14px;background:var(--surface);box-shadow:var(--shadow);overflow:visible}
.flmap-canvas{position:relative;width:100%;height:440px;border-radius:14px 14px 0 0;overflow:visible;
  background:
    linear-gradient(0deg,transparent 23px,rgba(184,137,63,.05) 24px) 0 0/100% 24px,
    linear-gradient(90deg,transparent 23px,rgba(184,137,63,.05) 24px) 0 0/24px 100%,
    var(--surface-2)}
.flmap-section-label{position:absolute;transform:translateX(-50%);font-family:'Playfair Display',serif;font-style:italic;font-size:12px;color:var(--text-faint);letter-spacing:.04em;pointer-events:none}
.flmap-legend{display:flex;flex-wrap:wrap;gap:18px;padding:14px 18px;border-top:1px solid var(--line);background:var(--surface);border-radius:0 0 14px 14px}
.flmap-table{position:absolute;transform:translate(-50%,-50%);z-index:1}
.flmap-table:hover,.flmap-table:focus-within{z-index:50}
.flmap-node{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;
  border-width:2px;border-style:solid;cursor:pointer;box-shadow:0 2px 10px rgba(0,0,0,.35);transition:transform .15s;padding:0}
.flmap-table:hover .flmap-node{transform:scale(1.08)}
.flmap-node .flmap-num{font-family:'Playfair Display',serif;font-weight:700;font-size:14px;line-height:1}
.flmap-node .flmap-seats{font-size:8px;font-family:var(--font-mono);opacity:.85;line-height:1}
.flmap-pop{position:absolute;left:50%;top:calc(100% + 10px);transform:translateX(-50%) translateY(-4px);
  width:280px;padding:14px;border-radius:12px;background:var(--surface);border:1px solid var(--line);
  box-shadow:0 18px 40px rgba(0,0,0,.45);opacity:0;pointer-events:none;
  transition:opacity .18s,transform .18s;z-index:60;text-align:left;color:var(--text)}
.flmap-table:hover .flmap-pop,.flmap-table:focus-within .flmap-pop{opacity:1;pointer-events:auto;transform:translateX(-50%)}
.flmap-table.up .flmap-pop{top:auto;bottom:calc(100% + 10px)}
.flmap-pop-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:8px}
.flmap-pop-head strong{font-family:var(--font-display);font-size:14px;color:var(--text)}
.flmap-pop-meta{font-size:12px;color:var(--text-soft);line-height:1.5;margin-bottom:10px}
.flmap-pop-meta .row{padding:2px 0;display:flex;gap:8px}
.flmap-pop-meta .k{color:var(--text-faint);font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;flex:0 0 64px;padding-top:2px}
.flmap-pop-meta .v{color:var(--text);flex:1 1 auto}
.flmap-pop-acts{display:flex;flex-wrap:wrap;gap:6px;padding-top:10px;border-top:1px solid var(--line-soft)}
.flmap-pop-acts .smart-btn{font-size:11px;padding:5px 9px}

/* ── AI avatar img (when company.ai.avatarImg is set) ──────────── */
.ai-fab-icon img{width:46px;height:46px;border-radius:50%;object-fit:cover;display:block;
  border:2px solid rgba(255,255,255,.22);box-shadow:0 1px 4px rgba(0,0,0,.18)}
.ai-head-avatar:has(img){background:transparent;padding:0}
.ai-head-avatar img{width:38px;height:38px;border-radius:50%;object-fit:cover;display:block}
.ai-msg-avatar:has(img){background:transparent}
.ai-msg-avatar img{width:26px;height:26px;border-radius:50%;object-fit:cover;display:block}

/* ── Order action buttons (Delivery) ───────────────────────────── */
.ord-act{font-family:var(--font-body);font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:7px;
  border:1px solid var(--line);background:var(--surface);color:var(--text-soft);cursor:pointer;transition:.15s;white-space:nowrap;margin-left:4px}
.ord-act:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--surface))}
.ord-act-primary{border-color:color-mix(in srgb,var(--accent) 45%,var(--line));color:var(--accent)}
.ord-act-primary:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.ord-act-warn:hover{border-color:#f59e0b;color:#b5730e;background:#fdf3e3}
.ord-act-danger:hover{border-color:#ef4444;color:#cf2f2f;background:#fdecec}
.ord-actions-cell{display:flex;gap:4px;justify-content:flex-end;flex-wrap:wrap}

/* ── Finance ───────────────────────────────────────────────────── */
.fin-table{width:100%;font-size:13px;border-collapse:collapse}
.fin-table td{padding:8px 4px;border-bottom:1px solid var(--line-soft);color:var(--text-soft)}
.fin-table td:last-child{text-align:right;font-family:var(--font-mono);font-size:12px;color:var(--text)}
.fin-table tr.fin-section td{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);padding-top:14px;border-bottom:1.5px solid var(--accent)}
.fin-table tr.fin-section td:last-child{color:var(--accent)}
.fin-table tr.fin-total td{font-weight:700;color:var(--text);border-top:1.5px solid var(--line);border-bottom:0;padding-top:10px}
.fin-table tr.fin-total td:last-child{color:var(--text)}
.fin-table tr.fin-net td{font-family:var(--font-display);font-weight:700;font-size:14.5px;color:var(--accent);border-top:2px solid var(--accent);border-bottom:0;padding:14px 4px}
.fin-table tr.fin-net td:last-child{color:var(--accent)}

/* ── Toast ─────────────────────────────────────────────────────── */
.toast-host{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}
.toast{background:var(--text);color:var(--surface);font-size:13px;font-weight:600;padding:11px 18px;border-radius:10px;box-shadow:var(--shadow-lg);opacity:0;transform:translateY(10px);transition:.25s cubic-bezier(.2,.7,.2,1);max-width:80vw}
.toast.show{opacity:1;transform:none}

/* ── Hover tooltip (JS-positioned floating popover) ─────────────── */
.htip{position:relative;display:inline-flex;align-items:center;gap:6px;cursor:help}
.htip .htip-pop{display:none}            /* source content; rendered into .htip-float */
.htip-float{
  position:fixed;z-index:9999;display:none;
  min-width:200px;max-width:320px;padding:10px 12px;
  background:var(--text);color:var(--surface);
  border-radius:9px;box-shadow:var(--shadow-lg);
  font-size:12px;font-weight:500;line-height:1.55;text-align:left;white-space:normal;
  pointer-events:none;
}
.htip-float .htip-title{font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;opacity:.6;margin-bottom:5px;font-weight:700}
.htip-float ul{margin:0;padding:0;list-style:none}
.htip-float li{padding:2px 0;display:flex;gap:7px;align-items:baseline}
.htip-float li::before{content:'•';opacity:.55}

/* ── Table search box (sits in section header actions) ──────────── */
.tbl-search{display:inline-flex;align-items:center;gap:7px;padding:6px 11px;border-radius:9px;
  border:1px solid var(--line);background:var(--surface);min-width:230px;transition:.15s}
.tbl-search:focus-within{border-color:color-mix(in srgb,var(--accent) 50%,var(--line))}
.tbl-search-ico{color:var(--text-faint);font-size:13px}
.tbl-search-input{border:0;outline:none;background:transparent;font-family:var(--font-body);font-size:13px;color:var(--text);width:100%}
.tbl-search-input::placeholder{color:var(--text-faint)}
