
:root {
  --ink:#0f2136;--ink-2:#314255;--ink-3:#667789;--ink-4:#a6adb5;
  --paper:#f5f7fa;--paper-2:#edf2f7;--paper-3:#dfe6ee;--white:#ffffff;
  --accent:#004680;--accent-2:#2c6696;--accent-light:#e9f2f9;
  --gold:#a86c13;--gold-light:#fcf3e6;
  --danger:#a53b37;--danger-light:#fcf0ef;
  --info:#004680;--info-light:#e9f2f9;--navy:#004680;
  --purple:#5567b4;--purple-light:#eef1fb;
  --border:rgba(15,33,54,0.11);--border-strong:rgba(15,33,54,0.2);
  --shadow:0 1px 3px rgba(26,26,24,0.08),0 4px 12px rgba(26,26,24,0.06);
  --shadow-lg:0 4px 16px rgba(26,26,24,0.12),0 12px 40px rgba(26,26,24,0.08);
  --radius:10px;--radius-lg:16px;
  --font-display:'DM Serif Display',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --font-mono:'DM Mono',monospace;
  --nav-width:224px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;margin:0;padding:0;font-family:var(--font-body);background:var(--paper);color:var(--ink);font-size:14px;line-height:1.5;}
button{font-family:var(--font-body);cursor:pointer;border:none;background:none;}
input,textarea,select{font-family:var(--font-body);font-size:14px;}

/* Layout */
.app{display:flex;position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden;}
.sidebar{width:var(--nav-width);background:var(--ink);color:var(--paper);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;height:100vh;-webkit-overflow-scrolling:touch;}
.main{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;min-width:0;}

/* Sidebar */
.sidebar-brand{padding:26px 20px 18px;border-bottom:1px solid rgba(255,255,255,0.08);}
.sidebar-brand .wordmark{font-family:var(--font-display);font-size:19px;color:var(--paper);letter-spacing:-0.3px;}
.sidebar-brand .tagline{font-size:10px;color:rgba(245,243,238,0.4);margin-top:2px;letter-spacing:0.8px;text-transform:uppercase;}
.sidebar-nav{padding:10px 0;flex:1;}
.nav-section{padding:14px 20px 3px;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:rgba(245,243,238,0.3);font-weight:500;}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 20px;font-size:13px;color:rgba(245,243,238,0.6);cursor:pointer;transition:all 0.15s;border-left:2px solid transparent;-webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none;-webkit-user-select:none;background:none;border-top:none;border-right:none;border-bottom:none;border-radius:0;width:100%;text-align:left;font-family:inherit;}
.nav-item:hover{color:var(--paper);background:rgba(255,255,255,0.05);}
.nav-item.active{color:var(--paper);background:rgba(255,255,255,0.09);border-left-color:#4a8c61;}
.nav-icon{width:15px;height:15px;opacity:0.65;flex-shrink:0;}
.nav-item.active .nav-icon{opacity:1;}
.nav-badge{margin-left:auto;background:var(--accent-2);color:white;font-size:10px;padding:1px 6px;border-radius:10px;font-weight:600;}
.nav-badge-alert{margin-left:auto;background:var(--danger);color:white;font-size:10px;padding:1px 6px;border-radius:10px;font-weight:600;}
.sidebar-footer{padding:14px 20px;border-top:1px solid rgba(255,255,255,0.08);font-size:10px;color:rgba(245,243,238,0.3);line-height:1.6;}


/* ── DARK MODE ────────────────────────────────────────────── */
[data-theme="dark"] {
  --ink:#e8e6e0;
  --ink-2:#c8c5bc;
  --ink-3:#8a8880;
  --ink-4:#5a5852;
  --paper:#1a1a18;
  --paper-2:#222220;
  --paper-3:#2a2a28;
  --white:#1e1e1c;
  --border:rgba(255,255,255,0.10);
  --shadow:0 1px 4px rgba(0,0,0,0.4);
  --accent:#3f86c2;
  --accent-2:#63a4dc;
  --accent-light:rgba(63,134,194,0.16);
  --gold:#c8960c;
  --gold-light:rgba(200,150,12,0.12);
  --danger:#c0392b;
  --danger-light:rgba(192,57,43,0.12);
  --purple:#7c5cbf;
  --navy:#1a2840;
}
[data-theme="dark"] .sidebar { background:#071221; }
[data-theme="dark"] .topbar { background:#0f1620; border-color:rgba(255,255,255,0.08); }
[data-theme="dark"] .modal { background:#222220; }
[data-theme="dark"] .form-input { background:#2a2a28; border-color:rgba(255,255,255,0.12); color:var(--ink); }
[data-theme="dark"] .form-input:focus { border-color:var(--accent); background:#2e2e2c; }
[data-theme="dark"] .card { background:#222220; border-color:rgba(255,255,255,0.06); }
[data-theme="dark"] .dash-widget { background:#222220; }
[data-theme="dark"] .btn-ghost { border-color:rgba(255,255,255,0.15); color:var(--ink-2); }
[data-theme="dark"] .btn-ghost:hover { background:rgba(255,255,255,0.06); }
[data-theme="dark"] table thead th { background:#2a2a28; }
[data-theme="dark"] tr:hover td { background:rgba(255,255,255,0.03); }
[data-theme="dark"] .stat-card { background:#2a2a28; }
[data-theme="dark"] .login-card { background:#222220; }
[data-theme="dark"] select option { background:#222220; color:var(--ink); }
[data-theme="dark"] #ai-panel { background:#1e1e1c; border-color:rgba(255,255,255,0.1); }
[data-theme="dark"] .ai-msg-assistant { background:#2a2a28; }
[data-theme="dark"] .sidebar-overlay { background:rgba(0,0,0,0.6); }

/* Top bar */
.topbar{background:var(--white);border-bottom:1px solid var(--border);padding:0 28px;height:54px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;position:sticky;top:0;z-index:50;}
.topbar-title{font-family:var(--font-display);font-size:20px;letter-spacing:-0.3px;}
.topbar-actions{display:flex;align-items:center;gap:8px;}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--radius);font-size:13px;font-weight:500;cursor:pointer;transition:all 0.15s;border:1px solid transparent;}
.btn-primary{background:var(--accent);color:white;}.btn-primary:hover{background:var(--accent-2);}
.btn-ghost{background:transparent;border-color:var(--border-strong);color:var(--ink-2);}.btn-ghost:hover{background:var(--paper);}
.btn-danger{background:var(--danger-light);color:var(--danger);border-color:rgba(139,32,32,0.2);}
.btn-purple{background:var(--purple-light);color:var(--purple);border-color:rgba(90,63,160,0.2);}
.btn-sm{padding:3px 9px;font-size:11px;} .btn-icon{padding:5px;border-radius:8px;}

/* Pages */
.page{padding:24px 28px;display:none;flex:1;overflow-x:hidden;} .page.active{display:block;}

/* Cards */
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 22px;box-shadow:var(--shadow);}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.card-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.7px;color:var(--ink-3);}

/* Stat cards */
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:20px;}
.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow);}
.stat-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.7px;color:var(--ink-3);margin-bottom:5px;}
.stat-value{font-family:var(--font-display);font-size:26px;color:var(--ink);letter-spacing:-0.5px;}
.stat-sub{font-size:11px;color:var(--ink-3);margin-top:3px;}
.stat-card.s-accent{border-left:3px solid var(--accent);} .stat-card.s-gold{border-left:3px solid var(--gold);}
.stat-card.s-danger{border-left:3px solid var(--danger);} .stat-card.s-info{border-left:3px solid var(--info);}
.stat-card.s-purple{border-left:3px solid var(--purple);}

/* Dashboard grid */
.dash-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,300px);gap:18px;}

/* Badges */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:0.3px;}
.badge-active{background:var(--accent-light);color:var(--accent);}
.badge-presales{background:var(--purple-light);color:var(--purple);}
.badge-prospect{background:var(--gold-light);color:var(--gold);}
.badge-dormant,.badge-paused,.badge-draft{background:var(--paper-3);color:var(--ink-3);}
.badge-closed,.badge-overdue{background:var(--danger-light);color:var(--danger);}
.badge-paid{background:var(--accent-light);color:var(--accent);}
.badge-sent{background:var(--info-light);color:var(--info);}
.badge-internal{background:#f0eaf8;color:#5a3fa0;}

/* Health indicators */
.health-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.health-green{background:#2d9c6a;} .health-amber{background:#c47f0a;} .health-red{background:#c0392b;}
.health-label-green{color:#2d9c6a;font-size:11px;font-weight:600;}
.health-label-amber{color:#c47f0a;font-size:11px;font-weight:600;}
.health-label-red{color:#c0392b;font-size:11px;font-weight:600;}

/* Engagement stage bar */
.stage-bar{display:flex;gap:3px;align-items:center;margin:8px 0 4px;}
.stage-pip{height:5px;flex:1;border-radius:3px;background:var(--paper-3);}
.stage-pip.done{background:var(--accent);}
.stage-pip.current{background:var(--accent-2);opacity:0.7;}
.stage-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--ink-3);}

/* Client row */
.client-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);}
.client-row:last-child{border-bottom:none;}
.client-avatar{width:34px;height:34px;border-radius:50%;display:flex;font-size:12px;font-weight:600;align-items:center;justify-content:center;flex-shrink:0;}
.client-meta{margin-left:auto;display:flex;align-items:center;gap:8px;}

/* Tables */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
th{text-align:left;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.7px;color:var(--ink-3);padding:7px 11px;border-bottom:1px solid var(--border-strong);white-space:nowrap;}
td{padding:10px 11px;border-bottom:1px solid var(--border);font-size:13px;color:var(--ink-2);vertical-align:middle;}
tr:last-child td{border-bottom:none;} tr:hover td{background:var(--paper);}

/* Forms */
.form-grid{display:grid;gap:14px;} .form-grid-2{grid-template-columns:repeat(2,minmax(0,1fr));} .form-grid-3{grid-template-columns:repeat(3,minmax(0,1fr));}
.form-group{display:flex;flex-direction:column;gap:4px;}
.form-label{font-size:11px;font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:0.5px;}
.form-input{padding:8px 11px;border:1px solid var(--border-strong);border-radius:var(--radius);background:var(--white);color:var(--ink);font-size:14px;transition:border-color 0.15s;outline:none;}
.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,90,61,0.1);}
select.form-input{cursor:pointer;} textarea.form-input{resize:vertical;min-height:76px;line-height:1.5;}
.form-section{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.7px;color:var(--ink-3);padding:6px 0 3px;border-bottom:1px solid var(--border);margin-bottom:2px;}

/* Modals */
.modal-backdrop{position:fixed;inset:0;background:rgba(26,26,24,0.5);z-index:100;display:none;align-items:center;justify-content:center;padding:20px;}
.modal-backdrop.open{display:flex;pointer-events:auto;}
.modal{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;}
.modal-header{padding:20px 22px 0;display:flex;align-items:flex-start;justify-content:space-between;}
.modal-title{font-family:var(--font-display);font-size:19px;letter-spacing:-0.2px;}
.modal-body{padding:18px 22px;} .modal-footer{padding:0 22px 20px;display:flex;justify-content:flex-end;gap:8px;}
.modal-close{background:none;border:none;cursor:pointer;color:var(--ink-3);padding:3px;border-radius:6px;font-size:18px;line-height:1;}
.modal-close:hover{background:var(--paper);}

/* Invoice preview */
.invoice-preview{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 44px;}
.invoice-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;}
.invoice-company{font-family:var(--font-display);font-size:20px;}
.invoice-tagline{font-size:11px;color:var(--ink-3);margin-top:2px;}
.invoice-number{font-family:var(--font-mono);font-size:17px;color:var(--accent);font-weight:500;}
.invoice-dates{font-size:11px;color:var(--ink-3);margin-top:4px;line-height:1.8;text-align:right;}
.invoice-parties{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;margin-bottom:28px;}
.invoice-party-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--ink-3);margin-bottom:5px;}
.invoice-party-name{font-weight:600;font-size:13px;}
.invoice-party-details{font-size:12px;color:var(--ink-3);line-height:1.7;margin-top:2px;}
.invoice-table th{background:var(--paper-2);} .invoice-table td,.invoice-table th{padding:9px 13px;}
.invoice-totals{margin-top:14px;display:flex;justify-content:flex-end;}
.invoice-totals-inner{width:260px;}
.invoice-total-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px;color:var(--ink-2);}
.invoice-total-row.grand{border-top:2px solid var(--ink);margin-top:5px;padding-top:9px;font-weight:700;font-size:15px;color:var(--ink);}
.invoice-footer{margin-top:32px;padding-top:18px;border-top:1px solid var(--border);font-size:11px;color:var(--ink-3);}

/* Line items */
.time-entry-row{display:flex;align-items:center;gap:8px;margin-bottom:7px;}
.time-entry-row input{flex:1;} .time-hrs{width:72px;flex-shrink:0;} .time-rate{width:96px;flex-shrink:0;} .time-del{color:var(--danger);}

/* Focus items */
.focus-section{margin-bottom:18px;}
.focus-section-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:0.8px;color:var(--ink);margin-bottom:9px;display:flex;align-items:center;gap:8px;}
.focus-section-title::after{content:'';flex:1;height:1px;background:var(--border);}
.focus-item{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:10px 13px;margin-bottom:5px;display:flex;align-items:flex-start;gap:9px;}
.client-chip{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;background:var(--accent-light);color:var(--accent);padding:2px 7px;border-radius:10px;white-space:nowrap;flex-shrink:0;}
.focus-text{font-size:12px;color:var(--ink-2);}
.focus-item.urgent{border-left:3px solid var(--danger);}
.focus-item.warn{border-left:3px solid var(--gold);}
.focus-item.purple{border-left:3px solid var(--purple);}
.focus-item.steward{border-left:3px solid #2d9c6a;}

/* Pipeline */
.pipeline-cols{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;}
.pipeline-col{background:var(--paper-2);border-radius:var(--radius-lg);padding:12px;}
.pipeline-col-header{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--ink-3);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;}
.col-count{background:var(--white);color:var(--ink-3);border-radius:10px;padding:1px 6px;font-size:10px;}
.pipeline-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:11px 13px;margin-bottom:7px;cursor:pointer;transition:all 0.15s;box-shadow:var(--shadow);}
.pipeline-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px);}
.pipeline-card-name{font-weight:600;font-size:13px;margin-bottom:2px;}
.pipeline-card-sub{font-size:11px;color:var(--ink-3);}
.pipeline-card-value{font-family:var(--font-mono);font-size:11px;color:var(--accent);margin-top:7px;font-weight:500;}

/* Tax */
.tax-category{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:12px;overflow:hidden;}
.tax-cat-header{padding:11px 16px;background:var(--paper-2);display:flex;align-items:center;justify-content:space-between;}
.tax-cat-name{font-weight:600;font-size:13px;}
.tax-cat-total{font-family:var(--font-mono);font-size:13px;color:var(--accent);font-weight:500;}
.tax-cat-items{padding:4px 0;}
.tax-cat-item{padding:6px 16px;display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--ink-2);border-bottom:1px solid var(--border);}
.tax-cat-item:last-child{border-bottom:none;}

/* Tabs */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:18px;}
.tab{padding:7px 14px;font-size:13px;font-weight:500;color:var(--ink-3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all 0.15s;}
.tab:hover{color:var(--ink);} .tab.active{color:var(--accent);border-bottom-color:var(--accent);}

/* Rate pill */
.rate-pill{display:inline-flex;align-items:center;background:var(--paper-2);border:1px solid var(--border);border-radius:20px;padding:1px 9px;font-size:11px;color:var(--ink-3);font-family:var(--font-mono);}

/* Client detail */
.detail-back{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--ink-3);cursor:pointer;margin-bottom:18px;padding:3px 0;}
.detail-back:hover{color:var(--ink);}
.detail-hero{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 26px;box-shadow:var(--shadow);margin-bottom:18px;}
.detail-hero-top{display:flex;align-items:flex-start;gap:16px;margin-bottom:14px;}
.detail-avatar{width:50px;height:50px;border-radius:13px;display:flex;font-size:17px;font-weight:600;align-items:center;justify-content:center;flex-shrink:0;}
.detail-name{font-family:var(--font-display);font-size:22px;letter-spacing:-0.3px;line-height:1.2;}
.detail-sub{font-size:12px;color:var(--ink-3);margin-top:2px;}
.detail-meta-row{display:flex;gap:20px;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--border);}
.detail-meta-item{display:flex;flex-direction:column;gap:2px;}
.detail-meta-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;color:var(--ink-4);}
.detail-meta-value{font-size:12px;color:var(--ink-2);font-weight:500;}
.detail-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,300px);gap:18px;}
.detail-section-title{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:0.75px;color:var(--ink);margin-bottom:11px;display:flex;align-items:center;justify-content:space-between;}

/* Engagement stage display */
.eng-stage{background:var(--paper-2);border-radius:var(--radius);padding:12px 14px;margin-bottom:10px;}
.eng-stage-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.eng-stage-name{font-size:13px;font-weight:600;color:var(--ink);}
.stage-track{display:flex;gap:4px;margin-bottom:4px;}
.stage-node{flex:1;height:6px;border-radius:3px;background:var(--paper-3);}
.stage-node.done{background:var(--accent);}
.stage-node.active{background:var(--accent-2);}
.stage-node-labels{display:flex;justify-content:space-between;font-size:9px;color:var(--ink-4);text-transform:uppercase;letter-spacing:0.5px;}

/* Project cards */
.project-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;margin-bottom:7px;box-shadow:var(--shadow);}
.project-card-name{font-weight:600;font-size:13px;color:var(--ink);margin-bottom:3px;}
.project-card-meta{font-size:11px;color:var(--ink-3);display:flex;gap:10px;flex-wrap:wrap;}
.project-card-desc{font-size:12px;color:var(--ink-2);margin-top:5px;line-height:1.5;}
.project-card-actions{margin-top:8px;display:flex;gap:6px;}

/* Subtasks */
.subtask-list{margin-top:8px;border-top:1px solid var(--border);padding-top:8px;}
.subtask-item{display:flex;align-items:flex-start;gap:8px;padding:5px 0;border-bottom:1px solid var(--border);font-size:12px;}
.subtask-item:last-child{border-bottom:none;}
.subtask-check{width:14px;height:14px;border-radius:3px;border:1px solid var(--border-strong);cursor:pointer;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;}
.subtask-check.done{background:var(--accent);border-color:var(--accent);color:white;}
.subtask-type{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;padding:1px 5px;border-radius:8px;flex-shrink:0;}
.st-action{background:var(--info-light);color:var(--info);}
.st-decision{background:var(--gold-light);color:var(--gold);}
.st-blocked{background:var(--danger-light);color:var(--danger);}
.st-note{background:var(--paper-3);color:var(--ink-3);}
.subtask-text{flex:1;color:var(--ink-2);}
.subtask-text.done-text{text-decoration:line-through;color:var(--ink-3);}

/* Notes */
.note-block{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;margin-bottom:7px;}
.note-date{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--ink-4);margin-bottom:5px;}
.note-text{font-size:12px;color:var(--ink-2);line-height:1.6;white-space:pre-wrap;}

/* Links */
.link-item{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:9px 12px;margin-bottom:5px;display:flex;align-items:center;gap:9px;}
.link-icon{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.link-label{font-size:13px;font-weight:500;color:var(--ink);flex:1;}
.link-url{font-size:11px;color:var(--ink-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px;}

/* Proposals */
.proposal-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:12px;}
.proposal-item:last-child{border-bottom:none;}
.proposal-name{font-weight:500;color:var(--ink);font-size:13px;}
.proposal-meta{font-size:11px;color:var(--ink-3);}

/* Referral network */
.referral-node{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:8px;}
.referral-source{font-weight:600;font-size:13px;color:var(--ink);}
.referral-children{margin-top:8px;padding-left:20px;border-left:2px solid var(--accent-light);}
.referral-child{font-size:12px;color:var(--ink-2);padding:3px 0 3px 10px;display:flex;align-items:center;gap:6px;}
.referral-child::before{content:'→';color:var(--accent);font-size:11px;flex-shrink:0;}

/* Stewardship prompts */
.steward-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;margin-bottom:6px;border-left:3px solid #2d9c6a;}
.steward-client{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:#2d9c6a;margin-bottom:4px;}
.steward-text{font-size:13px;color:var(--ink-2);line-height:1.5;}
.steward-age{font-size:11px;color:var(--ink-3);margin-top:3px;}

/* My Business */
.internal-section{margin-bottom:16px;}
.internal-task-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px;}
.internal-task-row:last-child{border-bottom:none;}
.internal-area{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--purple);background:var(--purple-light);padding:2px 7px;border-radius:8px;flex-shrink:0;}

/* Utility */
.mt-4{margin-top:16px;} .mt-6{margin-top:24px;} .mb-4{margin-bottom:16px;}
.flex{display:flex;} .items-center{align-items:center;} .justify-between{justify-content:space-between;}
.gap-3{gap:12px;} .gap-2{gap:8px;}
.text-muted{color:var(--ink-3);} .text-sm{font-size:12px;}
.text-accent{color:var(--accent);} .text-danger{color:var(--danger);}
.font-display{font-family:var(--font-display);}
.mono{font-family:var(--font-mono);font-size:12px;}
.empty-state{text-align:center;padding:36px 16px;color:var(--ink-3);}
.empty-state p{font-size:13px;}
.section-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;padding:2px 8px;border-radius:10px;}

/* ── DRAGGABLE DASHBOARD WIDGETS ───────────────────────────── */
.dash-widget-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
  padding: 4px 2px;
}
.dash-widget {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px 18px;
  box-shadow: var(--shadow);
  min-height: 120px;
  transition: box-shadow 0.15s, transform 0.15s;
  position: relative;
}
.dash-widget.widget-wide {
  grid-column: 1 / -1;
}
.dash-widget.dragging {
  opacity: 0.55;
  box-shadow: var(--shadow-lg);
  transform: scale(0.98);
  z-index: 10;
}
.dash-widget.drag-over {
  border: 2px dashed var(--accent-2);
  background: var(--accent-light);
}
.widget-handle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  cursor: grab;
  user-select: none;
}
.widget-handle:active { cursor: grabbing; }
.widget-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}
.drag-hint {
  font-size: 16px;
  color: var(--ink-4);
  cursor: grab;
  padding: 2px 4px;
  border-radius: 4px;
  transition: color 0.15s;
  line-height: 1;
}
.drag-hint:hover { color: var(--ink-2); background: var(--paper-2); }

/* ── MOBILE: widgets stack ─────────────────────────────────── */
@media (max-width: 900px) {
  .dash-widget-grid { grid-template-columns: minmax(0,1fr); }
  .dash-widget.widget-wide { grid-column: 1; }
}

/* ── MEDIUM SCREENS (1024px and below) ────────────────────── */
@media (max-width: 1024px) {
  .dash-grid { grid-template-columns: minmax(0,1fr); }
  .detail-grid { grid-template-columns: minmax(0,1fr); }
  .stats-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  [style*="grid-template-columns:minmax(0,1fr) minmax(0,1fr)"] { grid-template-columns: minmax(0,1fr) !important; }
}

/* ── MEDIUM-SMALL (900px and below) ───────────────────────── */
@media (max-width: 900px) {
  .form-grid-3 { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .pipeline-cols { grid-template-columns: repeat(2,minmax(0,1fr)); }
}

/* ── MOBILE RESPONSIVE ─────────────────────────────────────── */
@media (max-width: 768px) {
  :root { --nav-width: 0px; }

  /* ── APP CONTAINER ── */
  .app { overflow: visible; }
  .main { height: 100vh; overflow: hidden; }

  /* ── SIDEBAR DRAWER ── */
  .sidebar {
    position: fixed; left: -280px; top: 0; bottom: 0;
    width: 280px; z-index: 500; height: 100vh;
    transition: left 0.25s ease; box-shadow: none;
  }
  .sidebar.mobile-open { left: 0; box-shadow: 4px 0 24px rgba(26,26,24,0.25); }
  .sidebar-overlay {
    display: none; position: fixed; inset: 0;
    background: rgba(26,26,24,0.4); z-index: 490; pointer-events: none;
  }
  .sidebar-overlay.visible { display: block; pointer-events: auto; }

  /* ── TOPBAR ── */
  .topbar {
    padding: 0 12px;
    height: auto !important;
    min-height: 52px;
    flex-wrap: wrap;
    gap: 6px;
    padding-top: 8px;
    padding-bottom: 8px;
    position: sticky; top: 0; z-index: 50;
  }
  .topbar > div:first-child {
    flex: 1;
    min-width: 0;
    max-width: calc(100% - 44px);
  }
  .topbar-title {
    font-size: 15px !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
  }
  .topbar-actions {
    width: 100%;
    gap: 5px;
    flex-wrap: wrap;
    padding-bottom: 4px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    flex-shrink: 0;
  }
  .topbar-actions::-webkit-scrollbar { display: none; }
  .topbar-actions .btn { font-size: 11px !important; padding: 5px 9px !important; white-space: nowrap; flex-shrink: 0; }
  .topbar-actions .btn-sm { font-size: 10px !important; padding: 4px 7px !important; }
  .mobile-menu-btn {
    display: flex !important; align-items: center; justify-content: center;
    width: 36px; height: 36px; border-radius: 8px;
    background: var(--paper-2); border: none; cursor: pointer;
    flex-shrink: 0; margin-right: 8px;
  }

  /* ── PAGE PADDING ── */
  .page { padding: 14px 12px; }

  /* ── OVERFLOW ── */
  .page, .card, .dash-widget, .detail-hero { overflow-x: hidden; }
  body, .main { overflow-x: hidden; }

  /* ── GRIDS → SINGLE COLUMN ── */
  .stats-grid { grid-template-columns: 1fr 1fr !important; gap: 8px !important; margin-bottom: 12px; }
  .stat-value { font-size: 20px; }
  .dash-grid { grid-template-columns: 1fr !important; gap: 12px; }
  .detail-grid { grid-template-columns: 1fr !important; gap: 12px; }
  .form-grid-2, .form-grid-3 { grid-template-columns: 1fr !important; }

  /* ── TABLES ── */
  .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  table { min-width: 500px; }
  td, th { padding: 7px 8px; font-size: 12px; }
  .hide-mobile { display: none !important; }

  /* ── CARDS ── */
  .card { padding: 12px 14px; }
  .card-header { flex-wrap: wrap; gap: 8px; }
  .card-header .btn { font-size: 11px; padding: 5px 10px; }

  /* ── MODALS ── */
  .modal-backdrop { align-items: flex-end !important; padding: 0 !important; }
  .modal-backdrop.open { display: flex; }
  .modal {
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 !important;
    border-radius: 20px 20px 0 0 !important;
    max-height: 92vh !important;
    overflow-y: auto;
  }
  .modal-body { padding: 14px 16px !important; overflow-y: auto; }
  .modal-header {
    padding: 14px 16px 0 !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    position: sticky !important;
    top: 0 !important;
    background: var(--white) !important;
    z-index: 2 !important;
  }
  [data-theme="dark"] .modal-header { background: #222220 !important; }
  .modal-footer {
    padding: 10px 16px !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    position: sticky !important;
    bottom: 0 !important;
    background: var(--white) !important;
    border-top: 1px solid var(--border) !important;
    z-index: 2 !important;
  }
  [data-theme="dark"] .modal-footer { background: #222220 !important; }
  .modal-footer .btn { flex: 1; justify-content: center; min-width: 100px; }
  .modal-title { font-size: 16px !important; }
  /* All form grids collapse inside modals on mobile */
  .modal .form-grid-2,
  .modal .form-grid-3,
  .modal [style*="display:grid"],
  .modal [style*="grid-template-columns"] { grid-template-columns: 1fr !important; }
  /* Invoice line items inside modal */
  .modal #line-items-container > div { overflow-x: hidden; }
  /* Preview modals - full height */
  #preview-modal .modal,
  #onenote-preview-modal .modal { max-height: 96vh !important; }
  #preview-modal .modal-body,
  #onenote-preview-modal .modal-body { padding: 10px 12px !important; }
  /* Confirm modal - compact */
  #confirm-modal .modal { border-radius: 16px 16px 0 0 !important; }
  /* Pipeline modal columns */
  .modal .pipeline-cols { grid-template-columns: 1fr !important; overflow-x: unset; }

  /* ── INVOICE LINE ITEMS — stack on mobile ── */
  .li-inputs-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 6px !important;
  }
  .li-inputs-row .li-desc { grid-column: 1 / -1; }
  .li-ext-display { display: none !important; }

  /* ── PIPELINE ── */
  .pipeline-cols {
    grid-template-columns: repeat(4, 220px);
    overflow-x: auto; padding-bottom: 8px; scrollbar-width: thin;
  }

  /* ── CLIENT DETAIL ── */
  .detail-hero { padding: 14px; }
  .detail-hero-top { gap: 10px; flex-wrap: wrap; }
  .detail-name { font-size: 17px; }
  .detail-meta-row { gap: 10px; flex-wrap: wrap; }
  .detail-meta-value { font-size: 11px; }
  .detail-meta-label { font-size: 9px; }

  /* ── STAGE BAR ── */
  .stage-labels { font-size: 8px; }

  /* ── AI PANEL ── */
  #ai-panel {
    width: calc(100vw - 20px) !important;
    right: 10px !important; left: 10px !important;
    bottom: 80px !important;
  }
  #ai-fab button { width: 46px !important; height: 46px !important; bottom: 16px !important; right: 16px !important; }

  /* ── INVOICE PREVIEW ── */
  .invoice-preview { padding: 16px 12px; }
  .invoice-header { flex-direction: column; gap: 10px; }
  .invoice-dates { text-align: left; }
  .invoice-parties { grid-template-columns: 1fr !important; gap: 10px; }

  /* ── TAX PAGE ── */
  #tax-chart { max-height: 200px; }

  /* ── REFERRAL ── */
  .referral-node { padding: 10px; }

  /* ── INSIGHT TOAST ── */
  #insight-toast { left: 10px !important; right: 10px !important; width: auto !important; bottom: 80px !important; }

  /* ── TOUR ── */
  #tour-overlay { bottom: 72px; left: 10px; right: 10px; }

  /* ── MY BUSINESS WIDGETS ── */
  #biz-widget-grid { grid-template-columns: 1fr !important; }
  #dash-widget-grid { grid-template-columns: 1fr !important; }

  /* ── HERO STATS ── */
  .hero-stats { grid-template-columns: 1fr 1fr !important; }

  /* ── MISC ── */
  .section-tag { font-size: 10px; }
  .badge { font-size: 10px; padding: 2px 7px; }
  .btn { touch-action: manipulation; }

}

@media (max-width: 480px) {
  .stats-grid { grid-template-columns: 1fr; }
  .topbar-actions .btn:not(.btn-primary) { display: none; }
  .topbar-actions .btn-primary { font-size: 12px; }
}

/* ── iOS SAFARI SPECIFIC FIXES ─────────────────────────────── */
@media (max-width: 768px) {
  @supports (-webkit-touch-callout: none) {
    .topbar {
      -webkit-transform: translateZ(0);
      transform: translateZ(0);
      will-change: transform;
    }
    .main { overscroll-behavior: none; }
  }
}

/* ── PREVENT ALL HORIZONTAL OVERFLOW ──────────────────────── */
* { max-width: 100%; box-sizing: border-box; }
img, svg, video { max-width: 100%; }

@media print{
  .sidebar,.topbar,.topbar-actions,.no-print{display:none!important;}
  .main{overflow:visible;} .page{display:block!important;padding:0;}
  .invoice-preview{border:none;box-shadow:none;padding:20px 0;}
}


/* Topbar utility controls */
.topbar-context-actions,.topbar-utility-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.topbar-context-actions{min-width:0;}
.topbar-utility-actions{margin-left:auto;}
.topbar-status-region{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.status-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:600;border:1px solid var(--border);background:var(--paper-2);color:var(--ink-2);white-space:nowrap;}
.status-pill .dot{width:8px;height:8px;border-radius:999px;display:inline-block;flex-shrink:0;}
.status-pill.saved .dot{background:var(--accent);}
.status-pill.dirty .dot{background:var(--gold);}
.status-pill.saving .dot{background:var(--info);}
.status-pill.error .dot{background:var(--danger);}
.status-pill.offline .dot{background:var(--ink-3);}
.status-pill.saved{background:var(--accent-light);color:var(--accent);border-color:rgba(45,90,61,0.18);}
.status-pill.dirty{background:var(--gold-light);color:var(--gold);border-color:rgba(184,134,11,0.2);}
.status-pill.saving{background:var(--info-light);color:var(--info);border-color:rgba(26,58,92,0.2);}
.status-pill.error{background:var(--danger-light);color:var(--danger);border-color:rgba(139,32,32,0.2);}
.status-pill.offline{background:var(--paper-3);color:var(--ink-2);}
.status-meta{font-size:10px;color:var(--ink-3);white-space:nowrap;}
@media (max-width: 768px){.topbar-utility-actions{width:100%;justify-content:space-between;}.topbar-status-region{flex:1;overflow-x:auto;scrollbar-width:none;}.topbar-status-region::-webkit-scrollbar{display:none;}.status-meta{display:none;}}


/* Brand refresh */
.sidebar-brand{padding:20px 18px 16px;background:linear-gradient(180deg, rgba(0,70,128,0.1), rgba(0,70,128,0));}
.sidebar-brand .wordmark{display:flex;align-items:center;gap:10px;min-height:34px;}
.sidebar-logo{display:block;width:172px;max-width:100%;height:auto;filter:brightness(1.02);flex-shrink:0;}
.sidebar-wordmark-text{display:none;font-family:var(--font-display);font-size:24px;letter-spacing:-0.4px;color:var(--paper);line-height:1.1;}
.sidebar-brand .tagline{color:rgba(255,255,255,0.55);letter-spacing:1.1px;margin-top:10px;}
.login-brand{display:flex;justify-content:center;margin-bottom:18px;}
.login-brand img{width:220px;max-width:100%;height:auto;}
.login-card-title{font-family:var(--font-display);font-size:28px;color:var(--accent);margin-bottom:4px;}
.topbar{backdrop-filter:saturate(1.2) blur(8px);}
.topbar-title{color:var(--accent);}
.nav-item.active{border-left-color:var(--accent-2);}
.nav-badge,.nav-badge-alert{box-shadow:0 2px 6px rgba(0,0,0,0.12);}
.status-pill.saved{background:rgba(0,70,128,0.09);color:var(--accent);}
.status-pill.offline{background:#f5e8d7;color:#8a5a14;}
.steward-card{border-left-color:var(--accent);}
.steward-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;}
.steward-state{font-size:11px;color:var(--ink-3);margin-top:6px;}
.client-chip-link{border:none;cursor:pointer;transition:transform 0.12s ease, box-shadow 0.12s ease;}
.client-chip-link:hover{transform:translateY(-1px);box-shadow:0 0 0 1px rgba(45,90,61,0.08) inset;}
.client-chip-link:focus-visible{outline:2px solid rgba(45,90,61,0.35);outline-offset:2px;}
.linklike-name{border:none;background:none;color:var(--accent);font:inherit;font-weight:700;cursor:pointer;padding:0;text-align:left;}
.linklike-name:hover{text-decoration:underline;}
.client-row-name{border:none;background:none;color:var(--ink);font:inherit;font-weight:600;cursor:pointer;padding:0;text-align:left;display:inline-flex;max-width:100%;}
.client-row-name:hover{text-decoration:underline;color:var(--accent);}
.client-row-sub{font-size:11px;color:var(--ink-3);}
.exp-summary-stat{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--ink-2);padding:4px 10px;border-radius:999px;background:var(--paper-2);}
.exp-summary-stat .mono{font-size:12px;}
.exp-summary-meta{font-size:11px;color:var(--ink-3);display:inline-flex;gap:4px;align-items:center;}

.activity-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);}
.activity-item:last-child{border-bottom:none;}
.activity-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent-light);color:var(--accent);font-size:13px;flex-shrink:0;}
.activity-meta{font-size:11px;color:var(--ink-3);margin-top:2px;}
.activity-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:0.4px;text-transform:uppercase;}
.activity-badge.planned{background:var(--gold-light);color:var(--gold);}
.activity-badge.completed{background:var(--accent-light);color:var(--accent);}
.activity-empty{font-size:12px;color:var(--ink-4);padding:6px 0;}
.detail-stage-control{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px;padding-top:12px;border-top:1px solid var(--border);}
.detail-stage-select{min-width:180px;max-width:240px;}
.pipeline-card-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px;font-size:11px;color:var(--ink-3);}
.pipeline-card-next{margin-top:8px;padding:8px 9px;border-radius:8px;background:var(--paper-2);font-size:11px;color:var(--ink-2);line-height:1.45;}
.pipeline-card-contact{font-size:11px;color:var(--ink-3);margin-top:4px;}
.pipeline-card:hover .pipeline-card-name{color:var(--accent);}
.storage-status{font-size:12px;color:var(--ink-3);line-height:1.6;}
.brand-note{color:var(--ink-3);font-size:12px;}
.login-panel{border:1px solid rgba(0,70,128,0.08);}

@media (max-width: 768px) {
  .sidebar-brand{padding:16px 16px 14px;}
  .sidebar-logo{width:150px;}
  .page{padding:12px 10px;}
  .card,.dash-widget,.detail-hero,.pipeline-col{border-radius:14px;}
  .card-header{align-items:flex-start;}
  .card-header .btn{margin-top:2px;}
  .detail-back{margin-bottom:10px;}
  .detail-hero{padding:14px 12px;}
  .detail-stage-control{gap:8px;}
  .detail-stage-select{min-width:0;width:100%;max-width:none;}
  .steward-actions .btn{flex:1 1 calc(50% - 8px);justify-content:center;}
  .pipeline-cols{grid-template-columns:repeat(4, 260px);gap:10px;}
  .pipeline-col{padding:10px;}
  .pipeline-card{padding:10px;}
  .invoice-preview{padding:14px 10px;}
  .topbar{padding-left:10px;padding-right:10px;}
  .topbar-status-region{order:3;width:100%;justify-content:flex-start;}
  .topbar-context-actions,.topbar-utility-actions{width:100%;justify-content:flex-start;flex-wrap:wrap;}
  .table-wrap table{min-width:640px;}
  #page-client-detail .card{margin-bottom:12px;}
}

@media (max-width: 480px) {
  .steward-actions .btn{flex-basis:100%;}
  .sidebar-footer{padding-bottom:20px;}
  .topbar-title{font-size:14px !important;}
  .status-meta{display:none;}
}


/* v4.9 data-hardening controls */
.client-filter-bar, .pipeline-filter-bar, .invoice-filter-bar, .expense-filter-bar { display:flex; gap:8px; flex-wrap:wrap; }
.exp-commitments {
  display:none;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--paper-2);
  padding:10px 12px;
  margin:0 0 10px;
}
.exp-commitments.show { display:block; }
.exp-commitments-header { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:8px; flex-wrap:wrap; }
.exp-commitments-title { font-size:11px; font-weight:700; letter-spacing:0.7px; text-transform:uppercase; color:var(--ink-2); }
.exp-commitments-sub { font-size:12px; color:var(--ink-3); }
.exp-commit-list { display:flex; flex-direction:column; gap:8px; }
.exp-commit-row { display:grid; grid-template-columns:minmax(0,1.4fr) auto; gap:10px; align-items:flex-start; padding:9px 10px; background:var(--white); border:1px solid var(--border); border-radius:var(--radius); }
.exp-commit-name { font-weight:600; font-size:13px; color:var(--ink); }
.exp-commit-meta { font-size:11px; color:var(--ink-3); margin-top:3px; line-height:1.5; }
.exp-commit-amount { font-family:var(--font-mono); font-size:13px; color:var(--accent); font-weight:600; white-space:nowrap; }
.exp-summary-stat { font-size:12px; color:var(--ink-2); }
.exp-summary-meta { font-size:11px; color:var(--ink-3); }
.pipeline-card-next { font-size:11px; color:var(--ink-2); margin-top:4px; }
@media (max-width:768px) {
  .exp-commit-row { grid-template-columns:minmax(0,1fr); }
}

/* v5.0 business cards */
.biz-board-item-link{align-items:flex-start;gap:10px;}
.biz-board-item-link .link-label{text-decoration:none;}
.biz-board-item-link .link-label:hover{text-decoration:underline;}
#biz-widget-grid .dash-widget[data-biz-custom="true"] .widget-actions{flex-wrap:wrap;justify-content:flex-end;}
#biz-widget-grid .dash-widget[data-biz-custom="true"] .widget-handle{align-items:flex-start;gap:10px;}
@media (max-width: 768px) {
  #biz-widget-grid .dash-widget[data-biz-custom="true"] .widget-actions{width:100%;justify-content:flex-start;}
}


/* v5.1 production foundation */
.foundation-list{display:flex;flex-direction:column;gap:8px;}
.foundation-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);}
.foundation-row.warn{border-color:rgba(184,134,11,0.24);background:var(--gold-light);}
.foundation-row.good{border-color:rgba(0,70,128,0.12);}
.foundation-label{font-size:12px;font-weight:700;color:var(--ink);margin-bottom:2px;}
.foundation-detail{font-size:12px;color:var(--ink-3);line-height:1.55;}
.foundation-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px;}
.foundation-metric{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--paper-2);}
.foundation-metric-label{font-size:10px;font-weight:700;letter-spacing:0.6px;text-transform:uppercase;color:var(--ink-3);margin-bottom:4px;}
.foundation-metric-value{font-family:var(--font-display);font-size:22px;color:var(--ink);line-height:1;}
.foundation-issues-list{display:flex;flex-direction:column;gap:8px;}
.foundation-issue-row{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--paper-2);}
.foundation-issue-head{font-size:11px;font-weight:700;color:var(--ink);margin-bottom:3px;}
.foundation-issue-body{font-size:12px;color:var(--ink-2);line-height:1.55;}
.foundation-issue-meta{font-size:10px;color:var(--ink-4);margin-top:4px;}
@media (max-width: 768px) {
  .foundation-row{flex-direction:column;align-items:flex-start;}
  .foundation-points{grid-template-columns:1fr 1fr;}
}
@media (max-width: 480px) {
  .foundation-points{grid-template-columns:1fr;}
}
