*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --brand:#E55531;--brand-dk:#c4431f;--brand-lt:#fef0ec;
  --ink:#1a1a1a;--mid:#555;--light:#888;--rule:#e8e4df;
  --bg:#f7f6f4;--card:#fff;
  --good:#2d7a5f;--good-lt:#e6f5ef;
  --warn:#c4960a;--warn-lt:#fef8e6;
  --bad:#c0392b;--bad-lt:#fdecea;
  --radius:6px;--shadow:0 1px 3px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.04);
}
body{font-family:'DM Sans',-apple-system,sans-serif;font-size:15px;line-height:1.6;color:var(--ink);background:var(--bg)}

/* ── Layout ── */
.app-wrap{display:flex;min-height:100vh}
.sidebar{width:220px;height:100vh;background:#fff;border-right:1px solid var(--rule);display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:100;overflow:hidden}
.main-content{margin-left:220px;flex:1;min-height:100vh}

/* ── Sidebar ── */
.sidebar-logo{padding:20px 16px;border-bottom:1px solid var(--rule);display:flex;align-items:center;gap:10px}
.sidebar-logo img{height:32px;width:auto;mix-blend-mode:multiply}
.sidebar-logo span{font-size:15px;font-weight:600;color:var(--brand)}
.sidebar-section{padding:12px 10px 4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--light)}
.sidebar-nav{padding:8px 10px;flex:1;overflow-y:auto;overflow-x:hidden}
.sidebar-nav::-webkit-scrollbar{width:4px}
.sidebar-nav::-webkit-scrollbar-thumb{background:var(--rule);border-radius:4px}
.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--light)}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:var(--radius);cursor:pointer;color:var(--mid);font-size:13.5px;border:none;background:none;width:100%;text-align:left;transition:all .15s;margin-bottom:1px}
.nav-item:hover{background:var(--bg);color:var(--ink)}
.nav-item.active{background:var(--brand-lt);color:var(--brand);font-weight:500}
.nav-item .icon{font-size:15px;width:18px;text-align:center;flex-shrink:0}
.nav-item .badge{margin-left:auto;background:var(--rule);color:var(--mid);font-size:10px;padding:1px 6px;border-radius:10px}
.nav-item.active .badge{background:var(--brand);color:#fff}

/* Client switcher */
.client-switcher{padding:10px;border-bottom:1px solid var(--rule)}
.client-select{width:100%;padding:8px 10px;border:1px solid var(--rule);border-radius:var(--radius);font-size:13px;color:var(--ink);background:#fff;cursor:pointer;outline:none}
.client-select:focus{border-color:var(--brand)}
.btn-new-client{width:100%;margin-top:6px;padding:7px;border:1px dashed var(--rule);border-radius:var(--radius);background:none;color:var(--light);font-size:12px;cursor:pointer;transition:all .15s}
.btn-new-client:hover{border-color:var(--brand);color:var(--brand)}

.sidebar-footer{padding:12px 16px;border-top:1px solid var(--rule);font-size:11px;color:var(--light)}

/* ── Topbar ── */
.topbar{background:#fff;border-bottom:1px solid var(--rule);padding:0 28px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.topbar-left{display:flex;align-items:center;gap:12px}
.topbar-title{font-size:15px;font-weight:500;color:var(--ink)}
.topbar-client{font-size:13px;color:var(--light)}
.topbar-actions{display:flex;align-items:center;gap:10px}

/* ── Pages ── */
.page{padding:28px 32px;display:none}
.page.active{display:block}
.page-header{margin-bottom:24px}
.page-header h1{font-size:22px;font-weight:500;margin-bottom:3px}
.page-header p{color:var(--light);font-size:13.5px}

/* ── Cards ── */
.card{background:var(--card);border:1px solid var(--rule);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.card-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--light);margin-bottom:14px}
.card+.card{margin-top:16px}

/* ── KPI Grid ── */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.kpi-card{background:var(--card);border:1px solid var(--rule);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--brand)}
.kpi-value{font-size:30px;font-weight:300;color:var(--ink);line-height:1;margin-bottom:4px;font-variant-numeric:tabular-nums}
.kpi-label{font-size:11px;color:var(--light);text-transform:uppercase;letter-spacing:.1em}
.kpi-note{font-size:11px;color:var(--light);margin-top:5px}

/* ── Grids ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* ── Tables ── */
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{text-align:left;padding:9px 12px;font-size:10px;font-weight:600;color:var(--light);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--rule);background:var(--bg);white-space:nowrap}
.data-table td{padding:9px 12px;border-bottom:1px solid var(--rule);color:var(--ink);vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--bg)}
.data-table .num{font-variant-numeric:tabular-nums;font-weight:500}

.pos-chip{display:inline-block;padding:2px 7px;border-radius:3px;font-size:11px;font-weight:600}
.pos-top{background:var(--good-lt);color:var(--good)}
.pos-mid{background:var(--warn-lt);color:var(--warn)}
.pos-low{background:var(--bad-lt);color:var(--bad)}

/* ── Gap type badges ── */
.gap-badge{display:inline-block;padding:2px 8px;border-radius:3px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.gap-missing{background:#fdecea;color:var(--bad)}
.gap-weak{background:var(--warn-lt);color:var(--warn)}
.gap-quick_win{background:var(--good-lt);color:var(--good)}

/* ── Opportunity Cards ── */
.opp-card{background:var(--card);border:1px solid var(--rule);border-left:4px solid var(--brand);border-radius:var(--radius);padding:18px 20px;margin-bottom:12px;box-shadow:var(--shadow)}
.opp-card.high{border-left-color:var(--bad)}
.opp-card.medium{border-left-color:var(--warn)}
.opp-card.low{border-left-color:var(--good)}
.opp-title{font-size:14px;font-weight:500;margin-bottom:6px}
.opp-tags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:8px}
.tag{font-size:10px;padding:2px 7px;border-radius:3px;background:var(--bg);color:var(--mid);text-transform:uppercase;letter-spacing:.06em;font-weight:500}
.tag.high{background:var(--bad-lt);color:var(--bad)}
.tag.medium{background:var(--warn-lt);color:var(--warn)}
.tag.low{background:var(--good-lt);color:var(--good)}
.opp-desc{font-size:13px;color:var(--mid);line-height:1.6;margin-bottom:10px}
.opp-action{background:#fdf7f5;border-top:1px solid var(--rule);margin:0 -20px -18px;padding:11px 20px;border-radius:0 0 var(--radius) var(--radius)}
.opp-action-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--brand);margin-bottom:3px}
.opp-action p{font-size:13px;color:var(--ink)}

/* ── Competitor card ── */
.competitor-card{background:var(--card);border:1px solid var(--rule);border-radius:var(--radius);padding:16px;margin-bottom:10px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow)}
.competitor-card .comp-info{flex:1}
.competitor-card .comp-name{font-weight:500;font-size:14px}
.competitor-card .comp-meta{font-size:12px;color:var(--light);margin-top:2px}
.competitor-card .comp-actions{display:flex;gap:8px}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:500;cursor:pointer;border:none;transition:all .15s;text-decoration:none;white-space:nowrap}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-dk)}
.btn-outline{background:#fff;color:var(--ink);border:1px solid var(--rule)}
.btn-outline:hover{background:var(--bg)}
.btn-ghost{background:none;color:var(--mid);border:none;padding:6px 10px}
.btn-ghost:hover{color:var(--ink);background:var(--bg)}
.btn-danger{background:#fff;color:var(--bad);border:1px solid var(--rule)}
.btn-danger:hover{background:var(--bad-lt)}
.btn-sm{padding:5px 11px;font-size:12.5px}
.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}

/* ── Upload ── */
.upload-zone{border:2px dashed var(--rule);border-radius:var(--radius);padding:36px 24px;text-align:center;cursor:pointer;transition:all .2s;background:#fff}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--brand);background:var(--brand-lt)}
.upload-icon{font-size:36px;margin-bottom:10px}
.upload-zone h3{font-size:15px;font-weight:500;margin-bottom:4px}
.upload-zone p{font-size:12px;color:var(--light)}

/* ── Connect banner ── */
.connect-banner{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-radius:var(--radius);padding:22px 24px;display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;color:#fff}
.connect-banner h3{font-size:15px;font-weight:500;margin-bottom:3px}
.connect-banner p{font-size:12px;color:rgba(255,255,255,.55)}
.connect-banner.connected{background:linear-gradient(135deg,#1a3a2a,#2d5a3d)}

/* ── Score ── */
.score-circle{width:72px;height:72px;border-radius:50%;background:var(--brand);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:26px;font-weight:300;flex-shrink:0}
.score-circle small{font-size:10px;opacity:.8}

/* ── Bar charts ── */
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.bar-label{width:72px;font-size:12.5px;color:var(--mid)}
.bar-track{flex:1;height:7px;background:var(--rule);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px;background:var(--brand);transition:width .5s ease}
.bar-val{width:130px;font-size:12px;color:var(--mid);text-align:right}

/* ── Alerts ── */
.alert{padding:11px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:14px;display:flex;align-items:center;gap:9px}
.alert-info{background:#e8f4fd;color:#1a5f8a;border:1px solid #b8d9f0}
.alert-success{background:var(--good-lt);color:#1a5a3a;border:1px solid #a8d9be}
.alert-error{background:var(--bad-lt);color:#8a1a1a;border:1px solid #f0b8b8}
.alert-warning{background:var(--warn-lt);color:#6a4a00;border:1px solid #e8d080}

/* ── Loading ── */
.loading-overlay{position:fixed;inset:0;background:rgba(255,255,255,.88);display:none;flex-direction:column;align-items:center;justify-content:center;z-index:999}
.spinner{width:38px;height:38px;border:3px solid var(--rule);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:14px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Tabs ── */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--rule);margin-bottom:20px}
.tab-btn{padding:9px 16px;font-size:13.5px;border:none;background:none;color:var(--light);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}
.tab-btn:hover{color:var(--ink)}
.tab-btn.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:500}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* ── Forms ── */
.form-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-bottom:16px}
.form-group{display:flex;flex-direction:column;gap:4px}
.form-group label{font-size:11.5px;color:var(--mid);font-weight:500}
.form-group input,.form-group select,.form-group textarea{padding:8px 11px;border:1px solid var(--rule);border-radius:var(--radius);font-size:13.5px;color:var(--ink);background:#fff;outline:none;transition:border-color .15s;font-family:inherit}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--brand)}

/* ── Empty state ── */
.empty-state{text-align:center;padding:56px 24px;color:var(--light)}
.empty-state .empty-icon{font-size:44px;margin-bottom:12px}
.empty-state h3{font-size:16px;font-weight:500;color:var(--ink);margin-bottom:6px}
.empty-state p{font-size:13px;margin-bottom:18px}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:500;display:none;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:8px;padding:28px;width:440px;max-width:90vw;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.modal h3{font-size:17px;font-weight:500;margin-bottom:18px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}

/* ── Priority indicator ── */
.priority-bar{height:4px;border-radius:2px;background:var(--rule);margin-top:6px;overflow:hidden}
.priority-fill{height:100%;border-radius:2px;background:var(--brand)}

/* ── Responsive ── */
@media(max-width:900px){
  .sidebar{display:none}
  .main-content{margin-left:0}
  .sidebar{width:220px}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .grid-2,.grid-3{grid-template-columns:1fr}
}

/* ── Accordion ── */
.accordion-card .accordion-header:hover { background: var(--bg); }
.accordion-card .accordion-header { border-radius: var(--radius); transition: background .15s; }
#acc-icon-all, [id^="acc-icon-"] { display:inline-block; transition: transform .2s; }

/* ── Utility ── */
.hidden { display: none !important; }

/* ── Asana buttons: hidden until Asana is configured ── */
.enh-asana-btn { display: none !important; }
body.asana-connected .enh-asana-btn { display: inline-flex !important; }

/* ── Print / PDF ── */
@media print {
  .sidebar, .topbar, #report-controls, #report-actions,
  #page-report .page-header, #report-empty { display: none !important; }
  .main-content { margin-left: 0 !important; }
  .page { padding: 0 !important; }
  body { background: #fff !important; }
  #report-print-header { display: block !important; }
}
