
:root{
  --bg:#f6f7fb;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --ok:#16a34a;
  --warn:#d97706;
  --border:#e2e8f0;
  --shadow: 0 10px 30px rgba(15, 23, 42, .08);
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);}
.wrap{max-width:1100px;margin:24px auto;padding:0 16px;}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin:14px 0;box-shadow:var(--shadow);}
h1{margin:0 0 6px 0;font-size:24px;}
h2{margin:0;font-size:18px;}
p{margin:8px 0;}
.muted{color:var(--muted);}
.small{font-size:12px;}

.grid{display:grid;grid-template-columns: 1.2fr .6fr .6fr .5fr auto;gap:12px;align-items:end;margin-top:10px;}
label span{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;}
input{width:100%;padding:10px 10px;border-radius:10px;border:1px solid var(--border);background:#ffffff;color:var(--text);}

button{padding:10px 14px;border-radius:10px;border:1px solid #1d4ed8;background:#2563eb;color:white;font-weight:600;cursor:pointer;}
button:disabled{opacity:.6;cursor:not-allowed;}

/* Opportunities page form layout */
.oppTopRow{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;margin-top:10px;}
.oppMain{flex:1 1 50%;min-width:320px;}
.oppSettings{flex:1 1 50%;display:flex;gap:12px;align-items:flex-end;}
.oppSettings label{flex:1;min-width:140px;}
.oppCompRow{margin-top:12px;display:flex;}
.oppCompetitors{flex:1 1 50%;min-width:320px;}
.oppCompetitors textarea{width:100%;padding:10px 10px;border-radius:10px;border:1px solid var(--border);background:#ffffff;color:var(--text);}
.oppBtnRow{margin-top:12px;display:flex;justify-content:center;}
.oppBtnRow button{width:40%;min-width:220px;}

/* Anchor/button utilities */
.btnPrimary{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:10px;border:1px solid #1d4ed8;background:#2563eb;color:#fff;font-weight:600;text-decoration:none;cursor:pointer;}
.btnPrimary:hover{filter:brightness(.95);}
.btnPrimary:active{transform:translateY(1px);}
.btnSecondary{background:#ffffff;color:#1e293b;border:1px solid var(--border);}
.btnSecondary:hover{background:#f1f5f9;}

.status{margin-top:10px;font-size:13px;color:var(--muted);}
.hidden{display:none;}

.progressWrap{margin-top:12px;}
.progressRow{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.progressBar{height:10px;background:#e2e8f0;border:1px solid var(--border);border-radius:999px;overflow:hidden;}
.progressFill{height:100%;background:#22c55e;width:0%;}
.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:10px;}
.kpi{background:#ffffff;border:1px solid var(--border);border-radius:12px;padding:12px;}
.kpiNum{font-size:22px;font-weight:800;}
.list{display:flex;flex-direction:column;gap:10px;}
.item{background:#ffffff;border:1px solid var(--border);border-radius:12px;padding:12px;}
.row{display:flex;gap:12px;align-items:flex-start;}
.grow{flex:1;}
.url{font-size:13px;margin-bottom:6px;word-break:break-all;}
.url a{color:#1d4ed8;text-decoration:none;}
.url a:hover{text-decoration:underline;}
.meta{font-size:12px;color:var(--text);margin:3px 0;line-height:1.35;}
.scores{display:flex;flex-direction:column;gap:10px;min-width:82px;}
.scoreBox{width:82px;text-align:center;background:#f8fafc;border:1px solid var(--border);border-radius:12px;padding:10px;}
.scoreNum{font-size:22px;font-weight:900;}
.count{min-width:54px;text-align:center;background:#f8fafc;border:1px solid var(--border);border-radius:12px;padding:10px;font-weight:800;}
.pill{display:inline-block;padding:3px 8px;border-radius:999px;border:1px solid var(--border);font-size:11px;margin:2px 4px 2px 0;white-space:nowrap;}
.pill.ok{border-color:rgba(22,163,74,.35);color:#166534;background:rgba(22,163,74,.08);}
.pill.warn{border-color:rgba(217,119,6,.35);color:#92400e;background:rgba(217,119,6,.08);}
code{background:#f1f5f9;border:1px solid var(--border);padding:2px 6px;border-radius:8px;}

.rowHeader{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;}
.issueUrls{margin-top:8px;border-top:1px dashed var(--border);padding-top:8px;}
.issueUrl{font-size:12px;margin:3px 0;word-break:break-all;}
.issueUrl a{color:#1d4ed8;text-decoration:none;}
.issueUrl a:hover{text-decoration:underline;}

@media (max-width: 1050px){
  .grid{grid-template-columns:1fr;align-items:stretch;}
  .kpis{grid-template-columns:repeat(2,minmax(0,1fr));}
  .scores{flex-direction:row;}
  .oppTopRow{flex-direction:column;align-items:stretch;}
  .oppMain,.oppCompetitors{flex:1 1 auto;min-width:0;}
  .oppSettings{flex:1 1 auto;flex-direction:column;}
  .oppBtnRow button{width:100%;}
}


/* Added in v4 */
select{width:100%;padding:10px 10px;border-radius:10px;border:1px solid var(--border);background:#ffffff;color:var(--text);}
.colspan2{grid-column: span 2;}
.colspan3{grid-column: span 3;}
@media (max-width: 1050px){
  .colspan2,.colspan3{grid-column: auto;}
}

.scoreBox.good, .kpi.good{border-color: rgba(22,163,74,.35); background: rgba(22,163,74,.06);}
.scoreBox.mid,  .kpi.mid {border-color: rgba(217,119,6,.35); background: rgba(217,119,6,.06);}
.scoreBox.bad,  .kpi.bad {border-color: rgba(220,38,38,.35); background: rgba(220,38,38,.06);}

.kpiWide{grid-column: span 2; background:#ffffff;border:1px solid var(--border);border-radius:12px;padding:12px;}
.pillRow{margin-top:8px; line-height: 1.8;}
@media (max-width: 1050px){
  .kpiWide{grid-column: auto;}
}

.pill.suggest{border-color: rgba(29,78,216,.25); color:#1d4ed8; background: rgba(29,78,216,.06);}


/* Virtualized list to prevent Chrome crashes on large scans */
.virtualList{
  max-height: 70vh;
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 8px;
  background: #fff;
}
.virtualList .vItem{ margin-bottom: 12px; }

.btn-primary{background:#0b5ed7;color:#fff;padding:8px 14px;border-radius:8px;text-decoration:none;}
.btn-primary:hover{opacity:.9}


/* Opportunities page table */
.table{width:100%;border-collapse:collapse;margin-top:10px;}
.table th,.table td{border:1px solid var(--border);padding:10px 12px;vertical-align:top;font-size:14px;}
.table th{background:#f8fafc;text-align:left;font-weight:600;}
