/* Student Housing Solutions brand palette */
@import url('https://fonts.googleapis.com/css2?family=Besley:wght@500;600;700&family=Work+Sans:wght@300;400;500;600;700&display=swap');
:root{
  --navy:#112337;
  --navy-2:#1c3050;
  --navy-soft:#243b5c;
  --gold:#be9b63;
  --gold-light:#d8b96f;
  --gold-soft:#f4ecdc;
  --red:#dc4551;
  --bg:#f5f5f5;
  --panel:#ffffff;
  --line:#e3e6ec;
  --line-strong:#cfd4dd;
  --text:#112337;
  --muted:#586272;
  --muted-2:#8a93a3;
  --good:#3f9d6b;
  --warn:#c98a1b;
  --bad:#dc4551;
  --shadow:0 1px 2px rgba(17,35,55,.04), 0 4px 16px rgba(17,35,55,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:'Work Sans',-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Besley','Times New Roman',serif;font-weight:600;letter-spacing:-.01em}

/* ---------- Topbar ---------- */
.topbar{display:flex;align-items:center;gap:28px;padding:16px 32px;background:var(--navy);color:#fff;border-bottom:3px solid var(--gold);position:sticky;top:0;z-index:20}
.brand{display:flex;align-items:center;gap:12px}
.logo{width:40px;height:40px;border-radius:6px;background:var(--gold);display:grid;place-items:center;font-family:'Besley',serif;font-weight:700;color:var(--navy);font-size:20px}
.logo-img{width:44px;height:44px;display:block;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}
.brand h1{font-size:20px;margin:0;color:#fff;font-weight:600}
.brand h1 small{display:block;font-family:'Work Sans',sans-serif;font-size:10px;font-weight:500;letter-spacing:.18em;color:var(--gold-light);text-transform:uppercase;margin-top:2px}
.tabs{display:flex;gap:2px;flex:1;margin-left:12px}
.tab{background:transparent;color:rgba(255,255,255,.7);border:0;padding:10px 16px;border-radius:0;cursor:pointer;font:inherit;font-size:13px;font-weight:500;border-bottom:2px solid transparent;font-family:'Work Sans',sans-serif}
.tab:hover{color:#fff}
.tab.active{color:var(--gold-light);border-bottom-color:var(--gold)}
.actions{display:flex;gap:8px}
.btn{background:var(--gold);color:var(--navy);border:0;padding:9px 16px;border-radius:4px;cursor:pointer;font-weight:600;font-size:13px;font-family:'Work Sans',sans-serif;letter-spacing:.02em;transition:background .15s}
.btn:hover{background:var(--gold-light)}
.btn.ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3)}
.btn.ghost:hover{background:rgba(255,255,255,.08);border-color:var(--gold-light)}
.btn.danger{background:transparent;color:#ffb8be;border:1px solid rgba(220,69,81,.5)}
.btn.danger:hover{background:rgba(220,69,81,.15)}

main{max-width:1500px;margin:0 auto;padding:28px 32px}
.view{display:none}
.view.active{display:block}

/* ---------- LAR Header ---------- */
.lar-header{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:24px 28px;margin-bottom:20px;box-shadow:var(--shadow)}
.title-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.title-row h2{margin:0;font-size:32px;color:var(--navy);font-weight:700}
.title-row h2[contenteditable]{outline:none;border-bottom:1px dashed transparent;padding-bottom:2px}
.title-row h2[contenteditable]:hover,.title-row h2[contenteditable]:focus{border-bottom-color:var(--gold)}
.dayName{color:var(--muted);font-size:14px;margin-left:auto}
input[type=date],input[type=number],input[type=text],select{background:#fff;border:1px solid var(--line-strong);color:var(--text);padding:7px 11px;border-radius:4px;font:inherit;font-family:'Work Sans',sans-serif}
input[type=date]:focus,input[type=number]:focus,select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(190,155,99,.2)}
input[type=number]{width:80px}
.meta-row{display:flex;gap:28px;align-items:center;margin-top:18px;color:var(--muted);padding-top:18px;border-top:1px solid var(--line)}
.meta-row label{display:flex;gap:10px;align-items:center;font-size:13px;font-weight:500}
.badge{padding:4px 12px;border-radius:99px;background:#eef0f4;color:var(--navy);font-weight:600;font-size:11px;letter-spacing:.04em;text-transform:uppercase}
.badge.good{background:#e3f3eb;color:var(--good)}
.badge.warn{background:#fbf0d9;color:var(--warn)}
.badge.bad{background:#fce3e5;color:var(--bad)}

/* ---------- Leaderboard ---------- */
.leaderboard{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:24px 28px;margin-bottom:20px;box-shadow:var(--shadow)}
.leaderboard h3{margin:0 0 18px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-family:'Work Sans',sans-serif;font-weight:700}
.podium{display:grid;grid-template-columns:1fr 1.2fr 1fr;gap:16px;align-items:end}
.rank{background:#fafbfc;border:1px solid var(--line);border-radius:8px;padding:22px;text-align:center;position:relative}
.rank1{background:linear-gradient(180deg,#fff 0%, var(--gold-soft) 100%);border-color:var(--gold);transform:translateY(-10px);box-shadow:0 10px 30px -10px rgba(190,155,99,.5)}
.rank2{border-color:var(--line-strong)}
.rank3{border-color:#d4b89a}
.medal{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;margin:0 auto 10px;font-family:'Besley',serif;font-weight:700;color:#fff;font-size:16px}
.rank1 .medal{background:var(--gold)}
.rank2 .medal{background:#9aa3b3}
.rank3 .medal{background:#b88a4f}
.rank .name{font-family:'Besley',serif;font-size:22px;font-weight:600;color:var(--navy)}
.rank .score{color:var(--muted);font-size:12px;margin-top:6px;font-weight:500}

/* ---------- Table ---------- */
.table-wrap{background:var(--panel);border:1px solid var(--line);border-radius:8px;overflow:auto;margin-bottom:20px;box-shadow:var(--shadow)}
.lar-table{width:100%;border-collapse:collapse;min-width:1100px;table-layout:auto}
.lar-table th,.lar-table td{padding:10px 6px;text-align:center;border-bottom:1px solid var(--line);font-size:13px}
.lar-table td{white-space:nowrap}
.lar-table thead th{background:var(--navy);color:#fff;position:sticky;top:0;font-weight:500;z-index:1;font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;padding:10px 6px;line-height:1.25;white-space:normal;vertical-align:bottom;max-width:110px}
.lar-table thead th:nth-child(2){min-width:140px}
.lar-table th.editable-h{background:var(--navy-soft);color:var(--gold-light)}
.lar-table tbody tr:hover{background:#fafbfc}
.lar-table tbody tr.row-leader{background:rgba(190,155,99,.05)}
.lar-table tbody tr.row-leader:hover{background:rgba(190,155,99,.1)}
.lar-table td input{width:62px;background:#fff;border:1px solid var(--line-strong);color:var(--text);padding:5px 7px;border-radius:4px;text-align:center;font:inherit;font-family:'Work Sans',sans-serif}
.lar-table td input.wide{width:78px}
.lar-table td input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 2px rgba(190,155,99,.2)}
.lar-table td.computed{color:var(--navy);font-weight:500}
.lar-table td.pct{font-weight:700;color:var(--navy)}
.lar-table tfoot td{background:var(--gold-soft);font-weight:700;border-top:2px solid var(--gold);color:var(--navy)}
.lar-table tbody td:nth-child(2){text-align:left;color:var(--navy);font-weight:600;padding-left:14px}

/* Highlight editable cells (input columns) like the spreadsheet's blue cells */
.lar-table tbody td:nth-child(1),
.lar-table tbody td:nth-child(3),
.lar-table tbody td:nth-child(4),
.lar-table tbody td:nth-child(10),
.lar-table tbody td:nth-child(11),
.lar-table tbody td:nth-child(12){background:#fafbfd}

/* ---------- Email block ---------- */
.email-block{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:24px 28px;box-shadow:var(--shadow)}
.email-block-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.email-block-header h3{margin:0;font-size:18px;color:var(--navy)}
.email-actions{display:flex;gap:8px}
.email-actions .btn.ghost{background:#fff;color:var(--navy);border:1px solid var(--line-strong)}
.email-actions .btn.ghost:hover{background:#f4ecdc;border-color:var(--gold)}
.email-preview{background:#fff;border:1px solid var(--line);border-radius:6px;padding:24px;max-height:600px;overflow:auto}

/* The actual rendered email — these styles match what gets copied */
.eml{font-family:'Work Sans','Segoe UI',Arial,sans-serif;color:#112337;max-width:780px;margin:0 auto}
.eml-head{background:#112337;color:#fff;padding:18px 22px;border-bottom:3px solid #be9b63;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.eml-head h1{font-family:'Besley',Georgia,serif;font-size:20px;margin:0;color:#fff;font-weight:600}
.eml-head h1 small{display:block;font-size:10px;letter-spacing:.18em;color:#d8b96f;font-weight:500;text-transform:uppercase;margin-top:3px;font-family:'Work Sans',Arial,sans-serif}
.eml-date{color:#d8b96f;font-size:13px;font-weight:500}
.eml-body{padding:22px;background:#f5f5f5}
.eml-section{background:#fff;border:1px solid #e3e6ec;border-radius:6px;padding:18px;margin-bottom:16px}
.eml-section h2{font-family:'Besley',Georgia,serif;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:#be9b63;margin:0 0 14px;font-weight:600}
.eml-podium{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.eml-rank{border:1px solid #e3e6ec;border-radius:6px;padding:14px;text-align:center;background:#fafbfc}
.eml-rank.r1{background:linear-gradient(180deg,#fff,#f4ecdc);border-color:#be9b63}
.eml-rank .pos{display:inline-block;width:28px;height:28px;line-height:28px;border-radius:50%;color:#fff;font-weight:700;font-family:'Besley',Georgia,serif;font-size:13px;margin-bottom:6px}
.eml-rank.r1 .pos{background:#be9b63}
.eml-rank.r2 .pos{background:#9aa3b3}
.eml-rank.r3 .pos{background:#b88a4f}
.eml-rank .nm{font-family:'Besley',Georgia,serif;font-size:18px;font-weight:600;color:#112337}
.eml-rank .sc{font-size:11px;color:#586272;margin-top:2px}
.eml-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.eml-stat{text-align:center;padding:10px}
.eml-stat .k{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#586272;font-weight:600}
.eml-stat .v{font-family:'Besley',Georgia,serif;font-size:24px;color:#112337;font-weight:700;margin-top:4px}
.eml-stat .v.gold{color:#be9b63}
.eml-table{width:100%;border-collapse:collapse;font-size:12px}
.eml-table th,.eml-table td{padding:8px 10px;text-align:center;border-bottom:1px solid #e3e6ec}
.eml-table thead th{background:#112337;color:#fff;font-weight:500;font-size:10.5px;letter-spacing:.05em;text-transform:uppercase}
.eml-table td.prop{text-align:left;color:#112337;font-weight:600;padding-left:12px}
.eml-table td.pct{font-weight:700}
.eml-table td.pct.high{color:#3f9d6b}
.eml-table td.pct.mid{color:#c98a1b}
.eml-table td.pct.low{color:#dc4551}
.eml-table tfoot td{background:#f4ecdc;color:#112337;font-weight:700;border-top:2px solid #be9b63}
.eml-foot{text-align:center;color:#586272;font-size:11px;padding:12px}

/* ---------- Auth Gate ---------- */
.auth-gate{position:fixed;inset:0;background:radial-gradient(ellipse at top,#1c3050,#0a1424);z-index:100;display:grid;place-items:center;padding:20px}
.auth-gate[hidden]{display:none}
.auth-card{background:#fff;border-radius:10px;padding:36px 32px;width:100%;max-width:400px;box-shadow:0 30px 80px rgba(0,0,0,.5);text-align:center}
.auth-logo{margin-bottom:14px}
.auth-logo img{width:72px;height:72px;display:inline-block;filter:drop-shadow(0 4px 12px rgba(17,35,55,.25))}
.auth-card h2{font-family:'Besley',serif;color:var(--navy);font-size:26px;margin:0 0 4px}
.auth-sub{color:var(--muted);font-size:12px;letter-spacing:.06em;text-transform:uppercase;margin:0 0 22px}
#authForm{display:flex;flex-direction:column;gap:14px;text-align:left}
#authForm label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
#authForm input{padding:11px 13px;border:1px solid var(--line-strong);border-radius:6px;font-size:14px;font-family:'Work Sans',sans-serif;text-transform:none;letter-spacing:0;color:var(--text);font-weight:400;background:#fff}
#authForm input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(190,155,99,.2)}
.auth-error{background:#fce3e5;color:var(--bad);padding:9px 12px;border-radius:6px;font-size:12px;text-align:center}
.auth-submit{width:100%;padding:12px;font-size:14px;margin-top:4px}
.auth-hint{color:var(--muted-2);font-size:11px;margin:18px 0 0}
.auth-hint code{background:#f4ecdc;color:var(--navy);padding:1px 6px;border-radius:3px;font-family:ui-monospace,monospace}

/* ---------- Modal ---------- */
.modal{position:fixed;inset:0;background:rgba(17,35,55,.6);z-index:50;display:grid;place-items:center;padding:20px;backdrop-filter:blur(4px)}
.modal[hidden]{display:none}
.modal-card{background:#fff;border-radius:10px;padding:28px;width:100%;max-width:480px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal-card h3{font-family:'Besley',serif;color:var(--navy);font-size:22px;margin:0 0 6px}
.modal-card .muted{color:var(--muted);font-size:12.5px;margin:0 0 18px}
.modal-card label{display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-bottom:14px}
.modal-card textarea,.modal-card input{font-family:'Work Sans',sans-serif;font-size:13px;color:var(--text);text-transform:none;letter-spacing:0;font-weight:400;padding:9px 11px;border:1px solid var(--line-strong);border-radius:6px;background:#fff;resize:vertical}
.modal-card textarea:focus,.modal-card input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(190,155,99,.2)}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}
.modal-actions .btn.ghost{background:#fff;color:var(--navy);border:1px solid var(--line-strong)}

/* ---------- Flash report ---------- */
.flash-controls{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:24px 28px;margin-bottom:20px;display:flex;gap:24px;align-items:flex-end;flex-wrap:wrap;box-shadow:var(--shadow)}
.flash-controls h2{width:100%;margin:0 0 6px;color:var(--navy);font-size:24px}
.flash-controls label{display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.flash-controls select{min-width:220px;font-family:'Work Sans',sans-serif;text-transform:none;letter-spacing:0;color:var(--text);font-weight:400}
#flashContent{display:grid;gap:18px}
.flash-card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:22px 24px;overflow:auto;box-shadow:var(--shadow)}
.flash-card h3{margin:0 0 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--navy);font-size:20px}
.hide-btn{background:transparent;border:1px solid var(--line-strong);color:var(--muted);padding:5px 12px;border-radius:6px;font-size:12px;font-family:'Work Sans',sans-serif;font-weight:500;cursor:pointer}
.hide-btn:hover{background:#fce3e5;color:var(--bad);border-color:var(--bad)}
.hidden-note{background:#fafbfc;border:1px solid var(--line);border-radius:8px;padding:12px 18px;display:flex;align-items:center;gap:18px;color:var(--muted);font-size:13px;flex-wrap:wrap;margin-bottom:16px}
.hidden-note label{display:flex;align-items:center;gap:8px;cursor:pointer}
.hidden-note .btn{padding:5px 12px;font-size:11px}
.flash-card.archived{opacity:.65;border-left:3px solid var(--muted-2)}
.archived-tag{display:inline-block;padding:2px 8px;background:#eef0f4;color:var(--muted);border-radius:99px;font-size:10px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;font-family:'Work Sans',sans-serif;vertical-align:middle;margin-left:6px}
.lar-table .prop-code{font-size:10px;color:var(--muted-2);font-weight:500;letter-spacing:.04em;text-transform:uppercase;display:block;margin-top:1px}
.flash-card h3 .beds{font-size:12px;color:var(--muted);font-weight:500;font-family:'Work Sans',sans-serif;text-transform:uppercase;letter-spacing:.08em}
.flash-table{width:100%;border-collapse:collapse;font-size:12px;min-width:900px}
.flash-table th,.flash-table td{padding:7px 10px;text-align:center;border-bottom:1px solid var(--line)}
.flash-table thead th{background:var(--navy);color:#fff;position:sticky;top:0;font-weight:500;font-size:11px;letter-spacing:.04em;text-transform:uppercase}
.flash-table thead tr:nth-child(2) th{background:var(--navy-soft);color:var(--gold-light)}
.flash-table .month{text-align:left;font-weight:600;background:#fafbfc;color:var(--navy)}
.flash-table .pct{font-weight:700}
.flash-table .pct.high{color:var(--good)}
.flash-table .pct.mid{color:var(--warn)}
.flash-table .pct.low{color:var(--bad)}

/* ---------- Insights ---------- */
.insights-header{margin-bottom:18px}
.insights-header h2{color:var(--navy);font-size:28px;margin:0 0 4px}
.insights-header .muted{color:var(--muted);font-size:13px;margin:0}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:18px}
.kpi-card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:18px 20px;box-shadow:var(--shadow);border-top:3px solid var(--gold)}
.kpi-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600}
.kpi-val{font-family:'Besley',serif;font-size:30px;font-weight:700;color:var(--navy);margin:6px 0 4px}
.kpi-val small{font-family:'Work Sans',sans-serif;font-size:14px;color:var(--muted-2);font-weight:500;margin-left:4px}
.kpi-val.gold{color:var(--gold)}
.kpi-val.good{color:var(--good)}
.kpi-val.bad{color:var(--bad)}
.kpi-sub{color:var(--muted);font-size:12px}
.insight-card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:22px 24px;margin-bottom:18px;box-shadow:var(--shadow)}
.insight-card h3{margin:0 0 14px;color:var(--navy);font-size:18px}
.insight-card .muted{color:var(--muted);font-size:12.5px;margin:-6px 0 14px}
.insight-table{width:100%;border-collapse:collapse;font-size:13px}
.insight-table th,.insight-table td{padding:10px 12px;text-align:center;border-bottom:1px solid var(--line)}
.insight-table thead th{background:var(--navy);color:#fff;font-weight:500;font-size:11px;letter-spacing:.05em;text-transform:uppercase}
.insight-table td.prop{text-align:left;color:var(--navy);font-weight:600}
.insight-table td.good{color:var(--good)}
.insight-table td.bad{color:var(--bad)}
.insight-table td.mid{color:var(--muted)}
.spark{vertical-align:middle}
.best-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px}
.best-cell{background:#fafbfc;border:1px solid var(--line);border-radius:6px;padding:14px;text-align:center}
.best-name{color:var(--navy);font-weight:600;font-size:13px;margin-bottom:6px}
.best-pct{font-family:'Besley',serif;font-size:24px;color:var(--gold);font-weight:700}
.best-when{color:var(--muted);font-size:11px;margin-top:2px}

/* Detail panel */
.insights-detail-wrap .insight-card{padding:24px}
.detail-controls{display:flex;gap:18px;flex-wrap:wrap;align-items:flex-end;margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.detail-controls label{display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.detail-controls select{min-width:240px;padding:8px 11px;background:#fff;border:1px solid var(--line-strong);border-radius:6px;font:inherit;text-transform:none;letter-spacing:0;color:var(--text);font-weight:400}
.detail-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:14px}
.detail-header h3{margin:0 0 2px;color:var(--navy);font-size:22px}
.detail-header .muted{font-size:12px;margin:0}
.momentum{text-align:right}
.momentum-label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600}
.momentum-val{font-family:'Besley',serif;font-size:26px;font-weight:700;color:var(--navy)}
.momentum-val.good{color:var(--good)}.momentum-val.bad{color:var(--bad)}.momentum-val.mid{color:var(--muted)}
.chart-card{background:#fafbfc;border:1px solid var(--line);border-radius:8px;padding:14px 16px;margin-bottom:18px}
.chart{width:100%;height:auto;display:block}
.chart-legend{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:8px}
.chart-legend .leg{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);font-weight:500}
.chart-legend .leg i{width:14px;height:3px;border-radius:2px;display:inline-block}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.detail-grid h4{margin:0 0 10px;color:var(--navy);font-size:14px;font-family:'Work Sans',sans-serif;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.insight-table.compact th,.insight-table.compact td{padding:7px 10px;font-size:12px}
.insight-table tr.current{background:var(--gold-soft)}
.pill{padding:2px 9px;border-radius:99px;background:#eef0f4;font-weight:700;font-size:11px}
.pill.good{background:#e3f3eb;color:var(--good)}
.pill.mid{background:#fbf0d9;color:var(--warn)}
.pill.bad{background:#fce3e5;color:var(--bad)}
.advice-card{background:linear-gradient(135deg,#fffaf0,#fff);border:1px solid var(--gold);border-left:4px solid var(--gold);border-radius:8px;padding:18px 22px}
.advice-title{font-family:'Work Sans',sans-serif;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:8px}
.advice-card ul{margin:0;padding-left:20px;line-height:1.7;color:var(--text)}

/* Needs Help priority list */
.needs-help-card{background:linear-gradient(135deg,#fff5f6,#fff);border:1px solid var(--bad);border-left:4px solid var(--bad);border-radius:8px;padding:22px 24px;margin-bottom:18px;box-shadow:var(--shadow)}
.needs-help-card h3{margin:0 0 4px;color:var(--bad);font-size:18px}
.needs-help-card .muted{margin:0 0 14px;font-size:12.5px}
.help-list{display:grid;gap:10px}
.help-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:14px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:6px;padding:12px 16px}
.help-rank{width:26px;height:26px;border-radius:50%;background:var(--bad);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;font-family:'Besley',serif}
.help-name{color:var(--navy);font-weight:600;font-size:14px}
.help-detail{color:var(--muted);font-size:12px;margin-top:2px}
.help-stat{text-align:right}
.help-stat .v{font-family:'Besley',serif;font-size:18px;font-weight:700;color:var(--bad)}
.help-stat .k{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.help-actions{display:flex;flex-direction:column;gap:6px;min-width:160px}
.help-actions .btn{padding:7px 12px;font-size:11px;white-space:nowrap}
.help-actions .btn.ghost{background:#fff;color:var(--navy);border:1px solid var(--line-strong)}
.help-actions .btn.ghost:hover{background:var(--gold-soft);border-color:var(--gold);color:var(--navy)}
.competitor-result{margin-top:14px;padding:14px 16px;background:#fafbfc;border:1px solid var(--line);border-radius:6px;font-size:13px;line-height:1.7}
.competitor-result h4{margin:0 0 8px;font-size:13px;color:var(--navy);font-family:'Work Sans',sans-serif;text-transform:uppercase;letter-spacing:.06em}
.competitor-result.error{background:#fce3e5;color:var(--bad);border-color:var(--bad)}
.scan-progress{margin-top:14px}
.scan-bar{height:6px;background:#eef0f4;border-radius:99px;overflow:hidden;margin-bottom:14px}
.scan-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-light));width:0;transition:width .4s ease;border-radius:99px}
.scan-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:10px}
.scan-steps .step{font-size:10.5px;letter-spacing:.04em;color:var(--muted-2);text-align:center;padding:6px 4px;border-radius:6px;background:#fafbfc;border:1px solid var(--line);position:relative;font-weight:500}
.scan-steps .step.active{color:var(--navy);background:var(--gold-soft);border-color:var(--gold);font-weight:700}
.scan-steps .step.done{color:var(--good);background:#e9f7ef;border-color:#b8e0ca}
.scan-steps .step.done::before{content:'✓ ';font-weight:700}
.scan-elapsed{font-size:11px;color:var(--muted-2);text-align:center}

/* ---------- Instructions ---------- */
.instructions{display:grid;gap:18px;max-width:880px}
.instructions h2{color:var(--navy);font-size:28px;margin:0 0 6px}
.instr-card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:26px 30px;box-shadow:var(--shadow);border-left:4px solid var(--gold)}
.instr-card h3{margin:0 0 14px;color:var(--navy);font-size:18px}
.instr-card ol{margin:0;padding-left:22px;line-height:1.85;color:var(--muted)}
.instr-card ol li strong{color:var(--navy)}
.hint{color:var(--muted);font-style:italic;font-size:13px}

/* ============== RESPONSIVE ============== */
@media (max-width:960px){
  main{padding:18px 16px}
  .topbar{padding:10px 14px;gap:14px}
  .brand h1{font-size:16px}
  .brand h1 small{font-size:9px}
  .logo-img{width:36px;height:36px}
  .actions{gap:6px}
  .actions .btn{padding:7px 11px;font-size:12px}
  .tabs{margin-left:0}
  .tab{padding:8px 10px;font-size:12px}
  .lar-header{padding:16px}
  .title-row h2{font-size:22px}
  .meta-row{flex-direction:column;align-items:flex-start;gap:10px}
  .leaderboard{padding:18px}
  .table-wrap{border-radius:8px}
  .lar-table{min-width:900px}
  .email-block,.flash-controls,.flash-card,.insight-card,.kpi-card{padding:16px 18px}
  #copyEmailBtn{position:static;float:right}
  .email-block-header{flex-direction:column;align-items:flex-start}
  .email-actions{width:100%;justify-content:flex-end;flex-wrap:wrap}
}

@media (max-width:720px){
  .topbar{flex-wrap:wrap;padding:10px 12px;gap:10px}
  .brand{flex:1;min-width:160px}
  .brand h1{font-size:15px}
  .actions{order:2}
  .tabs{order:3;width:100%;overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px;-webkit-overflow-scrolling:touch}
  .tab{flex-shrink:0;padding:8px 12px;font-size:12px;border-bottom-width:2px}
  .podium{grid-template-columns:1fr;gap:10px}
  .rank1{transform:none}
  main{padding:14px 12px}
  .title-row{flex-direction:column;align-items:flex-start;gap:10px}
  .title-row h2{font-size:20px}
  .dayName{margin-left:0}
  .lar-table{min-width:760px;font-size:12px}
  .lar-table th,.lar-table td{padding:8px 5px}
  .lar-table thead th{font-size:9.5px;padding:8px 5px}
  .lar-table td input{width:54px;padding:5px 4px;font-size:12px}
  .table-wrap{margin:0 -12px 18px;border-radius:0;border-left:0;border-right:0}
  .leaderboard h3,.flash-controls h2,.insights-header h2{font-size:20px}
  .kpi-grid{grid-template-columns:1fr 1fr;gap:10px}
  .kpi-card{padding:14px}
  .kpi-val{font-size:24px}
  .help-row{grid-template-columns:auto 1fr;grid-template-rows:auto auto;row-gap:8px;padding:12px}
  .help-row > .help-stat,.help-row > .help-actions{grid-column:1 / -1}
  .help-stat{text-align:left}
  .help-actions{flex-direction:row;flex-wrap:wrap;min-width:0}
  .help-actions .btn{flex:1;min-width:130px}
  .detail-grid{grid-template-columns:1fr;gap:14px}
  .detail-controls{flex-direction:column;align-items:stretch}
  .detail-controls select{min-width:0;width:100%}
  .detail-header{flex-direction:column;align-items:flex-start}
  .momentum{text-align:left;width:100%}
  .chart{font-size:9px}
  .flash-controls{flex-direction:column;align-items:stretch;padding:16px}
  .flash-controls select{min-width:0;width:100%}
  .flash-card h3{flex-direction:column;align-items:flex-start;gap:8px;font-size:18px}
  .hide-btn{align-self:flex-end}
  .email-actions{flex-direction:column;width:100%}
  .email-actions .btn{width:100%}
  .auth-card{padding:28px 22px}
  .auth-card h2{font-size:22px}
  .modal-card{padding:22px 18px}
  /* Email preview at narrow widths — let stats stack 2x2 instead of 4 cols */
  .eml-stats{grid-template-columns:1fr 1fr}
  .eml-podium{grid-template-columns:1fr}
  .insight-table.compact th,.insight-table.compact td{padding:6px 6px;font-size:11px}
}

@media (max-width:480px){
  .brand h1 small{display:none}
  .actions .btn:not(.danger){display:none}
  .topbar{flex-wrap:nowrap}
  .tabs{order:5;margin-top:6px}
  .lar-table{min-width:680px}
  .kpi-grid{grid-template-columns:1fr}
  .best-grid{grid-template-columns:1fr 1fr}
  .help-actions .btn{min-width:100%}
  .insight-table th,.insight-table td{padding:8px 6px;font-size:11px}
  .flash-table{min-width:560px;font-size:10.5px}
  .flash-table th,.flash-table td{padding:5px 6px}
}
