/* ============================================================
   SITE ANALYSIS — styles
   ============================================================ */

/* ---------- Step 1: weights & filters ---------- */
.row-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;margin-top:6px}
.row-grid .fl{display:flex;flex-direction:column;gap:4px}
.row-grid label{font-size:10.5px;color:var(--ink-3);font-weight:600;letter-spacing:.02em;
  display:flex;justify-content:space-between;align-items:center}
.row-grid .mn{font-size:10.5px;color:var(--ink);background:var(--paper-2);
  padding:1px 6px;border-radius:3px}
.row-grid select{height:30px;border:1px solid var(--line);border-radius:6px;padding:0 8px;
  font-family:inherit;font-size:12px;background:var(--panel);color:var(--ink)}
.row-grid input[type=range]{width:100%;accent-color:var(--ink)}

.wgt-list{display:flex;flex-direction:column;gap:4px;margin-top:6px}
.wgt{display:grid;grid-template-columns:26px 1fr 120px 40px;gap:10px;align-items:center;
  padding:7px 8px;border:1px solid var(--line-2);border-radius:6px;background:var(--paper)}
.wgt-ic{width:22px;height:22px;border:1px solid var(--line);border-radius:4px;
  display:grid;place-items:center;font-size:11px;background:var(--panel)}
.wgt-k{font-weight:600;font-size:12px;letter-spacing:-0.01em}
.wgt-d{font-size:10.5px;color:var(--ink-3);margin-top:1px}
.wgt-r{accent-color:var(--ink)}
.wgt-v{font-size:11px;text-align:right;color:var(--ink);font-weight:600}
.wgt-warn{font-size:10.5px;color:#B1580B;padding:5px 8px;background:#FDF2E0;
  border:1px solid #F2C488;border-radius:4px;margin-top:8px;letter-spacing:.02em}

.tog-list{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.tog{display:flex;align-items:center;gap:8px;font-size:12px;padding:6px 8px;
  border:1px solid var(--line-2);border-radius:5px;background:var(--paper);cursor:pointer}
.tog input{accent-color:var(--ink)}

/* ---------- Step 2: site list ---------- */
.site-list{display:flex;flex-direction:column;gap:6px;margin-top:4px}
.site-row{display:grid;grid-template-columns:34px 1fr 60px 26px;gap:10px;align-items:center;
  padding:10px;border:1.5px solid var(--line);border-radius:7px;background:var(--panel);
  cursor:pointer;transition:background .12s,border-color .12s}
.site-row:hover{background:var(--paper-2)}
.site-row.focus{border-color:var(--ink)}
.site-row.sel{background:#FDF6E3;border-color:#C9A961}
.sr-rank{font-size:13px;font-weight:700;color:var(--ink);text-align:center;
  background:var(--paper-2);height:30px;border-radius:5px;display:grid;place-items:center}
.site-row.sel .sr-rank{background:#C9A961;color:#2D2410}
.sr-top{display:flex;align-items:center;gap:6px;margin-bottom:5px}
.sr-name{font-weight:700;font-size:12.5px;letter-spacing:-0.01em}
.sr-id{font-size:10px;color:var(--ink-3);padding:0 4px;border:1px solid var(--line-2);
  border-radius:3px;background:var(--paper)}
.sr-warn{font-size:10px;color:#B1580B;padding:0 5px;background:#FDF2E0;border-radius:3px}
.sr-bars{display:grid;grid-template-columns:repeat(3,1fr);gap:4px 10px}
.sr-bar{display:grid;grid-template-columns:24px 1fr 20px;gap:4px;align-items:center;font-size:10px}
.sr-bk{color:var(--ink-3)}
.sr-bt{height:5px;background:var(--paper-2);border-radius:2px;overflow:hidden}
.sr-bf{height:100%;background:var(--ink);border-radius:2px}
.sr-bv{color:var(--ink);text-align:right;font-size:10px}
.sr-score{text-align:center}
.sr-sv{font-size:16px;font-weight:800;color:var(--ink);line-height:1}
.sr-sk{font-size:9px;color:var(--ink-3);letter-spacing:.08em;margin-top:2px}
.sr-pick input{width:16px;height:16px;accent-color:var(--ink);cursor:pointer}

/* ---------- Step 3: compare ---------- */
.cmp-grid{display:grid;gap:8px;margin-top:4px}
.cmp-empty{grid-column:1/-1;padding:40px;text-align:center;color:var(--ink-3);font-size:11px}
.cmp-card{border:1.5px solid var(--line);border-radius:8px;padding:10px;background:var(--panel)}
.cmp-h{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.cmp-medal{font-size:16px}
.cmp-id{font-size:10px;color:var(--ink-3);padding:0 5px;border:1px solid var(--line-2);
  border-radius:3px;background:var(--paper);flex:1}
.cmp-score{font-size:14px;font-weight:800;color:var(--ink)}
.cmp-n{font-size:13px;font-weight:700;letter-spacing:-0.01em;margin-bottom:8px}
.cmp-kv{display:grid;grid-template-columns:auto 1fr 24px;gap:4px 6px;align-items:center}
.cmp-k{font-size:10.5px;color:var(--ink-3)}
.cmp-bt{height:5px;background:var(--paper-2);border-radius:2px;overflow:hidden}
.cmp-bf{height:100%;background:var(--ink);border-radius:2px}
.cmp-bv{font-size:10px;text-align:right;color:var(--ink)}
.cmp-meta{margin-top:8px;padding-top:8px;border-top:1px dashed var(--line-2);
  display:flex;flex-direction:column;gap:3px;font-size:11px}
.cmp-meta .lbl{font-size:9px;color:var(--ink-3);letter-spacing:.08em;margin-right:6px}
.cmp-meta .warn{font-size:10px;color:#B1580B}

.lead-list{display:flex;flex-direction:column;gap:3px;margin-top:4px}
.lead-row{display:grid;grid-template-columns:80px auto 1fr;gap:10px;padding:6px 10px;
  border:1px solid var(--line-2);border-radius:5px;background:var(--paper);align-items:center;font-size:11.5px}
.lead-k{color:var(--ink-3);font-size:11px}
.lead-v{font-weight:700}
.lead-n{color:var(--ink-2);font-size:11px}

/* ---------- Step 4: report ---------- */
.rpt-hero{padding:18px;background:var(--ink);color:var(--panel);border-radius:8px;
  display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto auto;gap:2px 12px;
  align-items:baseline}
.rh-k{font-size:10px;letter-spacing:.12em;color:var(--paper-2);opacity:.7;grid-column:1/-1}
.rh-n{font-size:22px;font-weight:800;letter-spacing:-0.02em}
.rh-s{font-size:26px;font-weight:800;font-family:"JetBrains Mono",monospace;
  grid-row:2;grid-column:2;text-align:right}
.rh-sub{font-size:10.5px;color:var(--paper-2);opacity:.7;grid-column:1/-1}

.rpt-top{display:flex;flex-direction:column;gap:5px;margin-top:4px}
.rt-row{display:grid;grid-template-columns:32px 1fr 60px;gap:10px;align-items:center;
  padding:10px;border:1px solid var(--line-2);border-radius:6px;background:var(--paper)}
.rt-medal{font-size:18px;text-align:center}
.rt-n{font-size:13px;font-weight:700;letter-spacing:-0.01em;margin-bottom:2px}
.rt-m{font-size:10.5px;color:var(--ink-3)}
.rt-s{font-size:18px;font-weight:800;text-align:right;color:var(--ink)}

.act-list{display:flex;flex-direction:column;gap:6px;margin-top:4px}
.act-row{display:grid;grid-template-columns:36px 1fr 16px;gap:10px;align-items:center;
  padding:10px;border:1.5px solid var(--line);border-radius:7px;background:var(--panel);
  cursor:pointer;text-align:left;font-family:inherit}
.act-row:hover{background:var(--paper-2)}
.act-ic{width:32px;height:32px;border:1px solid var(--line);border-radius:5px;
  display:grid;place-items:center;font-size:11px;font-weight:700;background:var(--paper)}
.act-t{font-weight:700;font-size:12.5px;letter-spacing:-0.01em}
.act-d{font-size:10.5px;color:var(--ink-3);margin-top:1px}
.act-go{font-size:14px;color:var(--ink-3);text-align:right}

/* ---------- site toast ---------- */
.site-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(8px);
  padding:10px 16px;background:var(--ink);color:var(--panel);font-size:12px;
  border-radius:6px;box-shadow:3px 3px 0 rgba(0,0,0,.3);z-index:200;
  opacity:0;pointer-events:none;transition:opacity .18s,transform .18s;letter-spacing:.02em}
.site-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- map overlay (site pins) ---------- */
.site-pin{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;
  align-items:center;gap:3px;pointer-events:none}
.sp-dot{width:26px;height:26px;border-radius:50%;background:#6B6F76;color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:11px;
  border:2px solid #fff;box-shadow:0 2px 0 rgba(0,0,0,.2)}
.site-pin.t1 .sp-dot{background:#C9A961;color:#2D2410;width:32px;height:32px;font-size:13px}
.site-pin.t2 .sp-dot{background:#8A8D93}
.site-pin.t3 .sp-dot{background:#A2A5AB}
.site-pin.t4 .sp-dot{background:#BEBFC2;color:#2D2410;width:22px;height:22px;font-size:10px}
.site-pin.sel .sp-dot{outline:2px solid #C9A961;outline-offset:2px}
.site-pin.focus .sp-dot{outline:2px solid var(--ink);outline-offset:2px}
.sp-lbl{font-size:10px;padding:1px 5px;background:var(--panel);border:1px solid var(--line);
  border-radius:3px;color:var(--ink);font-weight:700;box-shadow:0 1px 0 rgba(0,0,0,.08)}
.site-rad{position:absolute;width:180px;height:180px;border-radius:50%;
  transform:translate(-50%,-50%);border:1.5px dashed #C9A961;
  background:radial-gradient(circle,rgba(201,169,97,.18) 0%,rgba(201,169,97,0) 70%);
  pointer-events:none}
