/* ═══ NOTIFICATION CENTER ═══ */
.notif-wrap{position:relative}
.notif-bell{width:34px;height:34px;border-radius:50%;border:1px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:all .2s;flex-shrink:0;position:relative}
.notif-bell:hover{border-color:var(--gold);background:var(--gold-bg)}
.notif-count{position:absolute;top:-4px;right:-4px;background:var(--ruby);color:#fff;font-size:9px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}
.notif-panel{position:absolute;top:calc(100% + 10px);right:0;width:340px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:500;display:none;overflow:hidden}
.notif-panel.open{display:block}
.notif-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.notif-title{font-size:14px;font-weight:600;color:var(--ink)}
.notif-clear{font-size:11px;color:var(--gold);cursor:pointer;font-weight:500}
.notif-clear:hover{text-decoration:underline}
.notif-list{max-height:340px;overflow-y:auto}
.notif-item{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;gap:10px;align-items:flex-start;cursor:pointer;transition:background .12s}
.notif-item:hover{background:var(--bg)}
.notif-item:last-child{border-bottom:none}
.notif-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.notif-body{flex:1;min-width:0}
.notif-msg{font-size:12px;font-weight:500;color:var(--ink);line-height:1.4}
.notif-sub{font-size:11px;color:var(--muted);margin-top:2px}
.notif-empty{padding:28px;text-align:center;font-size:13px;color:var(--muted)}
.notif-footer{padding:10px 16px;border-top:1px solid var(--border);text-align:center;font-size:12px;color:var(--azure);cursor:pointer;font-weight:500}
.notif-footer:hover{text-decoration:underline}

/* ═══ BCC MINI WIDGET (on event dashboard) ═══ */
.bcc-mini{background:var(--ink);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}
.bcc-mini-top{padding:16px 20px;display:grid;grid-template-columns:1fr auto;align-items:center;gap:16px}
.bcc-mini-label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.45);font-weight:600;margin-bottom:3px}
.bcc-mini-amount{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:#fff;line-height:1}
.bcc-mini-sub{font-size:11px;color:rgba(255,255,255,.4);margin-top:3px}
.bcc-mini-metrics{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(255,255,255,.08)}
.bcc-mini-metric{padding:12px 16px;border-right:1px solid rgba(255,255,255,.06);text-align:center}
.bcc-mini-metric:last-child{border-right:none}
.bcc-mini-val{font-size:14px;font-weight:700;color:#fff;font-family:'Playfair Display',serif}
.bcc-mini-lbl{font-size:10px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}
.bcc-mini-bar{padding:0 20px 14px}

/* ═══ TEAM BUDGET ENRICHED ═══ */
.team-bcc-header{background:linear-gradient(135deg,var(--ink),var(--ink2));border-radius:var(--radius);padding:20px 24px;margin-bottom:16px;color:#fff}
.team-bcc-alloc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}
.team-bcc-metric{background:rgba(255,255,255,.08);border-radius:8px;padding:12px 16px;text-align:center}
.team-bcc-val{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:#fff}
.team-bcc-lbl{font-size:10px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
.spend-ring-wrap{display:flex;justify-content:center;margin:16px 0 8px}
.spend-ring{position:relative;width:100px;height:100px}
.spend-ring svg{transform:rotate(-90deg)}
.spend-ring-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.spend-ring-pct{font-size:20px;font-weight:700;font-family:'Playfair Display',serif;color:var(--ink)}
.spend-ring-sub{font-size:10px;color:var(--muted)}
.act-state-pill{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;white-space:nowrap}

/* ═══ BCC SPEND FUNNEL (analytics) ═══ */
.funnel-wrap{display:flex;flex-direction:column;gap:8px;padding:8px 0}
.funnel-row{display:flex;align-items:center;gap:12px}
.funnel-label{font-size:12px;font-weight:500;color:var(--ink);min-width:130px;text-align:right}
.funnel-bar-wrap{flex:1;height:28px;background:var(--bg);border-radius:6px;overflow:hidden;border:1px solid var(--border)}
.funnel-bar{height:100%;border-radius:6px;display:flex;align-items:center;padding:0 10px;font-size:11px;font-weight:600;color:#fff;white-space:nowrap;transition:width .8s ease}
.funnel-amt{font-size:12px;font-weight:600;color:var(--ink);min-width:80px}

/* Milestone WA trigger badge */
.ms-wa-badge{font-size:10px;background:rgba(37,211,102,.15);color:#25D366;border:1px solid rgba(37,211,102,.3);border-radius:10px;padding:2px 7px;margin-left:6px;font-weight:600}

/* ═══ PHASE F: USER MANAGEMENT & SETTINGS ═══ */
.user-table-wrap{background:var(--surface);border-radius:var(--r);border:1px solid var(--border);overflow:hidden}
.user-row{display:grid;grid-template-columns:36px 1fr 120px 140px 80px auto;gap:0;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border);transition:background .1s}
.user-row:hover{background:var(--bg)}
.user-row:last-child{border-bottom:none}
.user-row.header{background:var(--bg);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);padding:8px 16px}
.user-avatar-sm{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.user-name-cell{display:flex;flex-direction:column}
.user-name{font-size:13px;font-weight:600;color:var(--ink)}
.user-email{font-size:11px;color:var(--muted)}
.toggle-switch{position:relative;width:36px;height:20px;display:inline-block}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--border);border-radius:20px;transition:.2s}
.toggle-slider::before{content:'';position:absolute;height:14px;width:14px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}
input:checked+.toggle-slider{background:var(--emerald)}
input:checked+.toggle-slider::before{transform:translateX(16px)}
.user-actions{display:flex;gap:4px}

/* Settings panel */
.settings-section{background:var(--surface);border-radius:var(--r);border:1px solid var(--border);overflow:hidden;margin-bottom:14px}
/* ── Toggle switch ── */
.toggle-switch{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--border2);border-radius:22px;transition:.2s}
.toggle-slider:before{position:absolute;content:'';width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}
.toggle-switch input:checked+.toggle-slider{background:var(--emerald)}
.toggle-switch input:checked+.toggle-slider:before{transform:translateX(18px)}
/* ── Closeout Checklist ── */
.cl-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);margin-bottom:12px;overflow:hidden}
.cl-section-head{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg);border-bottom:1px solid var(--border);font-weight:600;font-size:13px}
.cl-section-badge{font-size:11px;color:var(--muted);font-weight:400;margin-left:auto}
.cl-item{display:flex;align-items:flex-start;gap:12px;padding:11px 16px;border-bottom:1px solid var(--border)}
.cl-item:last-child{border-bottom:none}
.cl-item-done{opacity:.5}
.cl-item-done .cl-item-title{text-decoration:line-through;color:var(--muted)}
.cl-item-title{font-size:13px;font-weight:500;color:var(--ink);flex:1}
.cl-item-meta{font-size:11px;color:var(--muted);margin-top:2px}
.cl-item-owner{font-size:11px;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:1px 8px;color:var(--slate);flex-shrink:0}
.cl-priority-high{color:var(--ruby)}
.cl-priority-med{color:var(--amber)}
.cl-priority-low{color:var(--muted)}
.settings-section-head{padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--ink);background:var(--bg);display:flex;align-items:center;gap:8px}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px}
.settings-row:last-child{border-bottom:none}
.settings-label{color:var(--ink);font-weight:500}
.settings-sub{font-size:11px;color:var(--muted);margin-top:2px}

/* Danger zone */
.danger-zone{background:var(--ru-bg);border:1px solid rgba(214,59,59,.25);border-radius:var(--r);padding:20px;margin-bottom:14px}
.danger-zone h3{font-size:14px;font-weight:700;color:var(--ruby);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.danger-item{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(214,59,59,.15);font-size:13px}
.danger-item:last-child{border-bottom:none}
.danger-label{color:var(--ruby);font-weight:500}
.danger-desc{font-size:11px;color:rgba(214,59,59,.7);margin-top:2px}
.bridge-status-bar{background:var(--surface);border-bottom:1px solid var(--border);padding:6px 20px;display:flex;align-items:center;gap:16px;font-size:11px;flex-wrap:wrap;color:var(--slate)}
.bridge-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);flex-shrink:0}
.bridge-pill{display:flex;align-items:center;gap:5px;padding:3px 9px;border-radius:10px;font-weight:600;font-size:11px}
.bridge-pill.ok{background:var(--em-bg);color:var(--emerald);border:1px solid rgba(16,160,106,.3)}
.bridge-pill.warn{background:var(--am-bg);color:var(--amber);border:1px solid rgba(217,119,6,.3)}
.bridge-pill.err{background:var(--ru-bg);color:var(--ruby);border:1px solid rgba(214,59,59,.3)}
.bridge-dot{width:5px;height:5px;border-radius:50%;background:currentColor}

/* WA send from app — wire the compose button to real bridge */
.wa-bridge-connected .wa-send-btn{background:#25D366!important}
.wa-bridge-connecting .wa-send-btn{background:var(--amber)!important}
.wa-bridge-disconnected .wa-send-btn{background:var(--ruby)!important;cursor:not-allowed}

/* Group mapping modal */
.group-map-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.group-map-row:last-child{border-bottom:none}
.group-jid{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);margin-top:2px}

/* Phase E env notice — shown when BRIDGE_URL not set yet */
.setup-notice{background:var(--am-bg);border:1px solid rgba(217,119,6,.25);border-radius:10px;padding:14px 18px;font-size:13px;color:var(--amber);display:flex;gap:10px;align-items:flex-start;margin-bottom:16px}
.ably-status{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;cursor:default}
.ably-status.connected{background:var(--em-bg);color:var(--emerald);border:1px solid rgba(16,160,106,.25)}
.ably-status.connecting{background:var(--am-bg);color:var(--amber);border:1px solid rgba(217,119,6,.25)}
.ably-status.disconnected{background:var(--ru-bg);color:var(--ruby);border:1px solid rgba(214,59,59,.25)}
.ably-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.ably-dot.connected{background:var(--emerald);animation:pulse-dot 2s infinite}
.ably-dot.connecting{background:var(--amber)}
.ably-dot.disconnected{background:var(--ruby)}

/* Presence avatar strip */
.presence-strip{display:flex;align-items:center;gap:4px}
.presence-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;border:2px solid var(--surface);cursor:default;transition:transform .15s;flex-shrink:0;position:relative}
.presence-avatar:hover{transform:scale(1.15);z-index:10}
.presence-avatar .pa-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;font-size:10px;padding:3px 8px;border-radius:6px;white-space:nowrap;display:none;pointer-events:none;z-index:100}
.presence-avatar:hover .pa-tooltip{display:block}
.presence-count{font-size:10px;color:var(--muted);font-weight:600;white-space:nowrap}

/* Live update toast — distinct from regular toasts */
.live-toast{background:var(--ink2);border-left-color:var(--violet)!important}

/* Channel activity pulse on topbar bell when Ably message arrives */
@keyframes bell-pulse{0%,100%{transform:scale(1)}30%{transform:scale(1.25) rotate(-10deg)}60%{transform:scale(1.1) rotate(8deg)}}
.bell-pulse{animation:bell-pulse .4s ease}

/* WA delivery status badges */
.wa-status-badge{font-size:9px;color:rgba(255,255,255,.4);margin-left:4px}
.wa-status-badge.sent{color:rgba(255,255,255,.5)}
.wa-status-badge.delivered{color:#53bdeb}
.wa-status-badge.read{color:#53bdeb}
.wa-status-badge.failed{color:var(--ruby)}
.fb-sync-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:var(--azure);color:#fff;font-size:13px;font-weight:500;padding:10px 20px;display:flex;align-items:center;gap:10px;justify-content:center;transform:translateY(-100%);transition:transform .3s ease}
.fb-sync-banner.show{transform:translateY(0)}
.fb-sync-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.fb-error-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:var(--ruby);color:#fff;font-size:13px;font-weight:500;padding:10px 20px;display:flex;align-items:center;gap:10px;justify-content:center;display:none}
.fb-error-banner.show{display:flex}
.fb-offline-pill{display:flex;align-items:center;gap:5px;background:rgba(217,119,6,.15);border:1px solid rgba(217,119,6,.3);border-radius:20px;padding:3px 10px;font-size:11px;color:var(--amber);font-weight:600}
.fb-online-pill{display:flex;align-items:center;gap:5px;background:rgba(16,160,106,.12);border:1px solid rgba(16,160,106,.3);border-radius:20px;padding:3px 10px;font-size:11px;color:var(--emerald);font-weight:600}
.fb-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.fb-dot.online{background:var(--emerald);animation:pulse-dot 2s infinite}
.fb-dot.offline{background:var(--amber)}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}

/* Firebase login enhancements */
.fb-login-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--muted);font-size:12px}
.fb-login-divider::before,.fb-login-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.btn-google{background:#fff;border:1.5px solid var(--border);color:var(--ink);font-weight:500;width:100%;justify-content:center;padding:11px}
.btn-google:hover{border-color:var(--azure);box-shadow:var(--shadow)}
.btn-google svg{width:18px;height:18px;flex-shrink:0}
.fb-status-tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;padding:3px 9px;border-radius:10px;font-weight:600}
.fb-status-tag.connected{background:var(--em-bg);color:var(--emerald);border:1px solid rgba(16,160,106,.25)}
.fb-status-tag.disconnected{background:var(--am-bg);color:var(--amber);border:1px solid rgba(217,119,6,.25)}

/* ═══ PHASE 3: GLOBAL SEARCH ═══ */
.search-btn{width:34px;height:34px;border-radius:50%;border:1px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px;transition:all .2s;flex-shrink:0}
.search-btn:hover{border-color:var(--gold);background:var(--gold-bg)}
.search-overlay{position:fixed;inset:0;background:rgba(11,15,26,.6);z-index:2000;display:none;align-items:flex-start;justify-content:center;padding-top:80px;backdrop-filter:blur(4px)}
.search-overlay.open{display:flex}
.search-box{background:var(--surface);border-radius:var(--radius);width:100%;max-width:640px;box-shadow:var(--shadow-lg);overflow:hidden}
.search-input-row{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border)}
.search-icon{font-size:18px;color:var(--muted);flex-shrink:0}
.search-field{flex:1;border:none;outline:none;font-size:16px;background:transparent;color:var(--ink);font-family:'Outfit',sans-serif}
.search-field::placeholder{color:var(--muted)}
.search-close{width:28px;height:28px;border-radius:50%;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:var(--muted);flex-shrink:0}
.search-close:hover{background:var(--ru-bg);color:var(--ruby)}
.search-results{max-height:440px;overflow-y:auto}
.search-section-head{padding:8px 20px 4px;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600;background:var(--bg)}
.search-result-item{display:flex;align-items:center;gap:12px;padding:11px 20px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border)}
.search-result-item:hover{background:var(--bg)}
.search-result-item:last-child{border-bottom:none}
.sr-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.sr-body{flex:1;min-width:0}
.sr-name{font-size:13px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-meta{font-size:11px;color:var(--muted);margin-top:1px}
.sr-tag{font-size:10px;padding:2px 7px;border-radius:10px;font-weight:500}
.search-empty{padding:32px;text-align:center;color:var(--muted);font-size:13px}
body.dark .search-box{background:var(--surface)}
body.dark .search-field{color:var(--ink)}

/* ═══ PHASE 3: EVENT HEALTH SCORE ═══ */
.health-score{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.health-ring{position:relative;width:44px;height:44px}
.health-ring svg{transform:rotate(-90deg)}
.health-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}
.health-text{font-size:10px;color:var(--muted);text-align:right}

/* ═══ PHASE 3: GANTT CHART ═══ */
.gantt-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}
.gantt-header{display:grid;border-bottom:2px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:10}
.gantt-hcell{padding:8px 10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);border-right:1px solid var(--border);text-align:center}
.gantt-hcell.today-col{background:rgba(212,168,67,.1);color:var(--gold)}
.gantt-row{display:grid;border-bottom:1px solid var(--border);align-items:center;min-height:42px;transition:background .1s}
.gantt-row:hover{background:var(--bg)}
.gantt-row:last-child{border-bottom:none}
.gantt-label{padding:8px 14px;font-size:12px;border-right:1px solid var(--border);display:flex;align-items:center;gap:8px;overflow:hidden}
.gantt-label-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;color:var(--ink)}
.gantt-label-sub{font-size:10px;color:var(--muted);white-space:nowrap}
.gantt-cells{display:contents}
.gantt-cell{border-right:1px solid var(--border);height:100%;position:relative;min-height:42px}
.gantt-cell.today-col{background:rgba(212,168,67,.06)}
.gantt-bar{position:absolute;top:50%;transform:translateY(-50%);height:20px;border-radius:10px;display:flex;align-items:center;padding:0 8px;font-size:10px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;z-index:2;cursor:default;transition:filter .15s}
.gantt-bar:hover{filter:brightness(1.15)}
.gantt-done-bar{opacity:.55}
.gantt-today-line{position:absolute;top:0;bottom:0;width:2px;background:var(--gold);z-index:5;pointer-events:none}
.gantt-controls{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg)}
.gantt-team-legend{display:flex;gap:10px;flex-wrap:wrap;font-size:11px}
.gantt-legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px}

/* ═══ PHASE 3: WA BROADCAST TEMPLATES ═══ */
.wa-template-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}
.wa-tpl-btn{padding:8px 10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:8px;color:rgba(255,255,255,.75);font-size:11px;cursor:pointer;text-align:left;font-family:'Outfit',sans-serif;transition:all .15s;line-height:1.4}
.wa-tpl-btn:hover{background:rgba(255,255,255,.1);border-color:var(--gold);color:#fff}
.wa-tpl-icon{font-size:14px;display:block;margin-bottom:3px}
.wa-char-count{font-size:10px;color:rgba(255,255,255,.3);text-align:right;margin-top:2px}
.wa-send-section{display:flex;flex-direction:column;gap:6px}

/* ═══ PHASE 3: PRINT REPORT ═══ */
.print-overlay{position:fixed;inset:0;background:rgba(11,15,26,.5);z-index:3000;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}
.print-overlay.open{display:flex}
.print-modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:740px;max-height:88vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.print-modal-head{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.print-preview{padding:24px;background:var(--bg);margin:16px;border-radius:8px;border:1px solid var(--border)}
.print-report-head{text-align:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid var(--gold)}
.print-report-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--ink)}
.print-report-sub{font-size:12px;color:var(--muted);margin-top:4px}
.print-section{margin-bottom:16px}
.print-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--slate);border-bottom:1px solid var(--border);padding-bottom:4px;margin-bottom:10px}
.print-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}
.print-kpi{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px;text-align:center}
.print-kpi-val{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:var(--ink)}
.print-kpi-lbl{font-size:10px;color:var(--muted);margin-top:2px}
.print-table{width:100%;border-collapse:collapse;font-size:12px}
.print-table th{background:var(--bg);text-align:left;padding:6px 10px;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);border-bottom:1px solid var(--border)}
.print-table td{padding:7px 10px;border-bottom:1px solid var(--border)}
body.dark .print-preview{background:var(--bg)}
body.dark .gantt-wrap{background:var(--surface)}

