/* ============================================================
   SEO Agency Pro — Public Stylesheet v2.0
   Design: Clean professional SaaS — light, trustworthy
   Inspired by: SEMrush / Ahrefs minimalist precision
   Fonts: Plus Jakarta Sans + Inter
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --sap-white:        #ffffff;
  --sap-bg:           #f7f8fc;
  --sap-bg-alt:       #eef0f8;
  --sap-surface:      #ffffff;
  --sap-border:       #e2e6f0;
  --sap-border-light: #edf0f8;
  --sap-primary:      #2563eb;
  --sap-primary-dk:   #1d4ed8;
  --sap-primary-soft: #eff4ff;
  --sap-green:        #16a34a;
  --sap-green-soft:   #f0fdf4;
  --sap-red:          #dc2626;
  --sap-red-soft:     #fef2f2;
  --sap-yellow:       #d97706;
  --sap-yellow-soft:  #fffbeb;
  --sap-blue:         #2563eb;
  --sap-blue-soft:    #eff6ff;
  --sap-text:         #0f172a;
  --sap-text-2:       #334155;
  --sap-text-3:       #64748b;
  --sap-text-4:       #94a3b8;
  --font-head:        'Plus Jakarta Sans', -apple-system, sans-serif;
  --font-body:        'Inter', -apple-system, sans-serif;
  --sap-r:            8px;
  --sap-r-lg:         12px;
  --sap-r-xl:         16px;
  --sap-shadow-sm:    0 1px 4px rgba(0,0,0,0.06);
  --sap-shadow:       0 4px 16px rgba(0,0,0,0.08);
  --sap-shadow-lg:    0 12px 40px rgba(0,0,0,0.1);
}

.sap-wrap *, .sap-wrap *::before, .sap-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }
.sap-wrap { font-family: var(--font-body); color: var(--sap-text); background: var(--sap-bg); -webkit-font-smoothing: antialiased; line-height: 1.6; }
.sap-wrap a { color: var(--sap-primary); text-decoration: none; }

/* BUTTONS */
.sap-btn { display:inline-flex; align-items:center; gap:7px; padding:10px 20px; border-radius:var(--sap-r); font-family:var(--font-head); font-size:14px; font-weight:600; cursor:pointer; border:1.5px solid transparent; text-decoration:none; transition:all 0.18s; white-space:nowrap; line-height:1; }
.sap-btn-primary { background:var(--sap-primary); color:#fff !important; border-color:var(--sap-primary); }
.sap-btn-primary:hover { background:var(--sap-primary-dk); transform:translateY(-1px); box-shadow:0 4px 14px rgba(37,99,235,0.28); color:#fff !important; }
.sap-btn-outline { background:transparent; color:var(--sap-primary) !important; border-color:var(--sap-primary); }
.sap-btn-outline:hover { background:var(--sap-primary-soft); }
.sap-btn-ghost { background:var(--sap-white); color:var(--sap-text-2) !important; border-color:var(--sap-border); }
.sap-btn-ghost:hover { background:var(--sap-bg-alt); }
.sap-btn-lg { padding:13px 28px; font-size:16px; }
.sap-btn-sm { padding:7px 14px; font-size:13px; }
.sap-btn:disabled { opacity:.55; cursor:not-allowed; transform:none !important; box-shadow:none !important; }

/* BADGES / PILLS */
.sap-badge { display:inline-flex; align-items:center; gap:5px; padding:4px 12px; border-radius:100px; font-size:12px; font-weight:600; }
.sap-badge-primary { background:var(--sap-primary-soft); color:var(--sap-primary); }
.sap-badge-green  { background:var(--sap-green-soft);  color:var(--sap-green); }
.sap-badge-red    { background:var(--sap-red-soft);    color:var(--sap-red); }
.sap-badge-yellow { background:var(--sap-yellow-soft); color:var(--sap-yellow); }
.sap-badge-grey   { background:var(--sap-bg-alt);      color:var(--sap-text-3); }

/* SPINNER */
.sap-spinner { display:inline-block; width:17px; height:17px; border:2px solid var(--sap-border); border-top-color:var(--sap-primary); border-radius:50%; animation:sap-spin .75s linear infinite; flex-shrink:0; }
@keyframes sap-spin { to { transform:rotate(360deg); } }

/* ======================================================
   SCANNER HERO
   ====================================================== */
.sap-hero {
  background: var(--sap-white);
  border-bottom: 1px solid var(--sap-border);
  padding: 80px 24px 64px;
  text-align: center;
}

.sap-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--sap-primary-soft);
  color: var(--sap-primary);
  border: 1px solid rgba(37,99,235,0.2);
  border-radius: 100px;
  padding: 5px 14px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: 22px;
}

.sap-hero-eyebrow::before { content:''; width:6px; height:6px; background:var(--sap-primary); border-radius:50%; }

.sap-hero-h1 {
  font-family: var(--font-head);
  font-size: clamp(30px, 5vw, 54px);
  font-weight: 800;
  line-height: 1.13;
  color: var(--sap-text);
  letter-spacing: -0.025em;
  max-width: 680px;
  margin: 0 auto 18px;
}

.sap-hero-h1 em {
  font-style: normal;
  color: var(--sap-primary);
}

.sap-hero-lead {
  font-size: 18px;
  color: var(--sap-text-3);
  max-width: 500px;
  margin: 0 auto 40px;
  line-height: 1.65;
  font-weight: 400;
}

/* Scanner input */
.sap-scanner-wrap { max-width: 680px; margin: 0 auto; }

.sap-input-row {
  display: flex;
  align-items: stretch;
  border: 2px solid var(--sap-border);
  border-radius: var(--sap-r-lg);
  background: var(--sap-white);
  overflow: hidden;
  transition: border-color .18s, box-shadow .18s;
  box-shadow: var(--sap-shadow-sm);
}

.sap-input-row:focus-within {
  border-color: var(--sap-primary);
  box-shadow: 0 0 0 4px rgba(37,99,235,0.1), var(--sap-shadow-sm);
}

.sap-input-prefix {
  display: flex;
  align-items: center;
  padding: 0 14px 0 18px;
  font-size: 14px;
  font-family: var(--font-body);
  color: var(--sap-text-4);
  border-right: 1px solid var(--sap-border-light);
  white-space: nowrap;
  user-select: none;
  background: var(--sap-bg);
}

#sap-url-input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--sap-text);
  padding: 17px 16px 17px 14px;
}

#sap-url-input::placeholder { color: var(--sap-text-4); }

#sap-scan-submit {
  background: var(--sap-primary);
  color: #fff;
  border: none;
  font-family: var(--font-head);
  font-size: 15px;
  font-weight: 700;
  padding: 0 28px;
  cursor: pointer;
  transition: background .18s;
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  flex-shrink: 0;
}

#sap-scan-submit:hover { background: var(--sap-primary-dk); }
#sap-scan-submit:disabled { opacity:.6; cursor:not-allowed; }

.sap-input-hint { margin-top: 12px; font-size: 13px; color: var(--sap-text-4); }

/* Feature chips */
.sap-chips { display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-top:36px; }
.sap-chip { display:inline-flex; align-items:center; gap:6px; background:var(--sap-bg); border:1px solid var(--sap-border); border-radius:100px; padding:6px 14px; font-size:12px; font-weight:500; color:var(--sap-text-3); }

/* ======================================================
   PROGRESS
   ====================================================== */
#sap-progress {
  display: none;
  max-width: 600px;
  margin: 32px auto 0;
  background: var(--sap-white);
  border: 1px solid var(--sap-border);
  border-radius: var(--sap-r-xl);
  padding: 28px 32px;
  box-shadow: var(--sap-shadow);
}

.sap-prog-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}

.sap-prog-title { font-family:var(--font-head); font-size:15px; font-weight:700; color:var(--sap-text); }
.sap-prog-url   { font-size:12px; color:var(--sap-text-4); margin-top:2px; }

.sap-prog-track { height:4px; background:var(--sap-border); border-radius:2px; overflow:hidden; margin-bottom:24px; }
.sap-prog-fill  { height:100%; background:var(--sap-primary); border-radius:2px; width:0%; transition:width .4s ease; }

.sap-prog-steps { list-style:none; display:flex; flex-direction:column; gap:10px; }
.sap-prog-step  { display:flex; align-items:center; gap:10px; font-size:13px; color:var(--sap-text-4); }
.sap-step-dot   { width:20px; height:20px; border-radius:50%; border:2px solid var(--sap-border); background:var(--sap-white); display:flex; align-items:center; justify-content:center; font-size:10px; flex-shrink:0; transition:all .2s; }
.sap-prog-step.active .sap-step-dot { border-color:var(--sap-primary); background:var(--sap-primary-soft); }
.sap-prog-step.active { color:var(--sap-text-2); font-weight:500; }
.sap-prog-step.done .sap-step-dot  { border-color:var(--sap-green); background:var(--sap-green); color:#fff; font-size:11px; }
.sap-prog-step.done  { color:var(--sap-green); }

/* ======================================================
   RESULTS
   ====================================================== */
#sap-results { display:none; }

.sap-results-body {
  max-width: 1100px;
  margin: 0 auto;
  padding: 36px 24px 72px;
}

/* Summary row */
.sap-summary-row {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 18px;
  margin-bottom: 20px;
}
@media(max-width:800px) { .sap-summary-row { grid-template-columns:1fr; } }

/* Score card */
.sap-score-card {
  background: var(--sap-white);
  border: 1px solid var(--sap-border);
  border-radius: var(--sap-r-xl);
  padding: 28px 20px;
  text-align: center;
  box-shadow: var(--sap-shadow-sm);
}

.sap-score-ring { position:relative; width:130px; height:130px; margin:0 auto 14px; }
.sap-score-svg  { transform:rotate(-90deg); }
.sap-score-track { fill:none; stroke:var(--sap-border); stroke-width:9; }
.sap-score-fill  { fill:none; stroke-width:9; stroke-linecap:round; stroke-dasharray:340; stroke-dashoffset:340; transition:stroke-dashoffset 1.5s cubic-bezier(.22,1,.36,1), stroke .3s; }
.sap-score-center { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.sap-score-num { font-family:var(--font-head); font-size:38px; font-weight:800; line-height:1; color:var(--sap-text); }
.sap-score-of  { font-size:12px; color:var(--sap-text-4); margin-top:1px; }
.sap-grade { font-family:var(--font-head); font-size:30px; font-weight:800; line-height:1; }
.sap-grade-lbl { font-size:12px; color:var(--sap-text-4); margin-top:3px; }
.sap-scanned-url { font-size:11px; color:var(--sap-text-4); margin-top:12px; word-break:break-all; }

/* Stats panel */
.sap-stats-panel {
  background: var(--sap-white);
  border: 1px solid var(--sap-border);
  border-radius: var(--sap-r-xl);
  padding: 26px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  box-shadow: var(--sap-shadow-sm);
}

.sap-panel-label { font-family:var(--font-head); font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--sap-text-4); margin-bottom:18px; }

.sap-stats-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:22px; }
@media(max-width:560px) { .sap-stats-4 { grid-template-columns:repeat(2,1fr); } }

.sap-stat-box { background:var(--sap-bg); border:1px solid var(--sap-border); border-radius:var(--sap-r); padding:16px 12px; text-align:center; }
.sap-stat-big { font-family:var(--font-head); font-size:28px; font-weight:800; line-height:1; margin-bottom:4px; }
.sap-stat-big.crit  { color:var(--sap-red); }
.sap-stat-big.warn  { color:var(--sap-yellow); }
.sap-stat-big.info  { color:var(--sap-blue); }
.sap-stat-big.pass  { color:var(--sap-green); }
.sap-stat-lbl { font-size:11px; font-weight:600; color:var(--sap-text-3); text-transform:uppercase; letter-spacing:.04em; }

.sap-panel-btns { display:flex; gap:10px; flex-wrap:wrap; }

/* Analysis */
.sap-analysis { margin-top:8px; }

.sap-analysis-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  flex-wrap: wrap;
  gap: 10px;
}

.sap-analysis-title { font-family:var(--font-head); font-size:19px; font-weight:700; color:var(--sap-text); }

.sap-filter-bar { display:flex; gap:5px; background:var(--sap-bg-alt); border:1px solid var(--sap-border); border-radius:var(--sap-r); padding:4px; }
.sap-filter-btn { padding:6px 14px; border-radius:6px; font-size:12px; font-weight:600; cursor:pointer; border:none; background:transparent; color:var(--sap-text-3); transition:all .15s; }
.sap-filter-btn.active { background:var(--sap-white); color:var(--sap-text); box-shadow:var(--sap-shadow-sm); }
.sap-filter-btn[data-filter="critical"].active { color:var(--sap-red); }
.sap-filter-btn[data-filter="warning"].active  { color:var(--sap-yellow); }
.sap-filter-btn[data-filter="passed"].active   { color:var(--sap-green); }

/* Category card */
.sap-cat-card {
  background: var(--sap-white);
  border: 1px solid var(--sap-border);
  border-radius: var(--sap-r-lg);
  margin-bottom: 10px;
  overflow: hidden;
  box-shadow: var(--sap-shadow-sm);
  transition: border-color .18s;
}
.sap-cat-card:hover { border-color:#c5cde0; }

.sap-cat-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  cursor: pointer;
  user-select: none;
}

.sap-cat-left { display:flex; align-items:center; gap:12px; }

.sap-cat-icon { width:38px; height:38px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.sap-cat-icon.red    { background:var(--sap-red-soft); }
.sap-cat-icon.yellow { background:var(--sap-yellow-soft); }
.sap-cat-icon.green  { background:var(--sap-green-soft); }
.sap-cat-icon.neutral { background:var(--sap-bg-alt); }

.sap-cat-name { font-family:var(--font-head); font-size:15px; font-weight:600; color:var(--sap-text); }
.sap-cat-sub  { font-size:12px; color:var(--sap-text-4); margin-top:1px; }

.sap-cat-right { display:flex; align-items:center; gap:10px; }
.sap-cnt-pills { display:flex; gap:6px; }
.sap-cnt-pill { font-size:11px; font-weight:700; padding:3px 9px; border-radius:100px; }
.sap-cnt-pill.crit { background:var(--sap-red-soft);    color:var(--sap-red); }
.sap-cnt-pill.warn { background:var(--sap-yellow-soft); color:var(--sap-yellow); }
.sap-cnt-pill.info { background:var(--sap-blue-soft);   color:var(--sap-blue); }
.sap-cnt-pill.pass { background:var(--sap-green-soft);  color:var(--sap-green); }

.sap-chevron { color:var(--sap-text-4); font-size:11px; transition:transform .2s; }
.sap-cat-card.open .sap-chevron { transform:rotate(180deg); }

.sap-cat-body { display:none; border-top:1px solid var(--sap-border-light); padding:14px 16px 18px; background:var(--sap-bg); }
.sap-cat-card.open .sap-cat-body { display:block; }

/* Issue row */
.sap-issue {
  background: var(--sap-white);
  border: 1px solid var(--sap-border);
  border-left: 3px solid transparent;
  border-radius: var(--sap-r);
  padding: 14px 16px;
  margin-bottom: 8px;
}
.sap-issue:last-child { margin-bottom:0; }
.sap-issue.critical { border-left-color:var(--sap-red); }
.sap-issue.warning  { border-left-color:var(--sap-yellow); }
.sap-issue.info     { border-left-color:var(--sap-blue); }
.sap-issue.passed   { border-left-color:var(--sap-green); }

.sap-issue-top { display:flex; align-items:flex-start; gap:10px; margin-bottom:7px; }
.sap-sev-pill { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; padding:3px 8px; border-radius:4px; flex-shrink:0; margin-top:1px; }
.sap-sev-pill.critical { background:var(--sap-red-soft);    color:var(--sap-red); }
.sap-sev-pill.warning  { background:var(--sap-yellow-soft); color:var(--sap-yellow); }
.sap-sev-pill.info     { background:var(--sap-blue-soft);   color:var(--sap-blue); }
.sap-sev-pill.passed   { background:var(--sap-green-soft);  color:var(--sap-green); }

.sap-issue-title { font-family:var(--font-head); font-size:14px; font-weight:600; color:var(--sap-text); line-height:1.4; }
.sap-issue-desc  { font-size:13px; color:var(--sap-text-3); line-height:1.55; margin-bottom:8px; }
.sap-issue-rec   { display:flex; align-items:flex-start; gap:8px; background:var(--sap-green-soft); border:1px solid #bbf7d0; border-radius:6px; padding:8px 12px; font-size:12px; color:#15803d; line-height:1.5; }
.sap-issue-rec-ico { flex-shrink:0; margin-top:1px; }
.sap-issue-val   { margin-top:8px; font-size:12px; color:var(--sap-text-3); background:var(--sap-bg); border:1px solid var(--sap-border); border-radius:6px; padding:7px 10px; font-family:monospace; word-break:break-all; }

/* AI section */
.sap-ai-box {
  background: var(--sap-white);
  border: 1px solid var(--sap-border);
  border-radius: var(--sap-r-xl);
  padding: 28px 32px;
  margin-top: 20px;
  box-shadow: var(--sap-shadow-sm);
}
.sap-ai-head { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.sap-ai-icon { width:42px; height:42px; border-radius:10px; background:linear-gradient(135deg,#6366f1,#0ea5e9); display:flex; align-items:center; justify-content:center; font-size:19px; flex-shrink:0; }
.sap-ai-title { font-family:var(--font-head); font-size:16px; font-weight:700; color:var(--sap-text); }
.sap-ai-sub   { font-size:12px; color:var(--sap-text-4); margin-top:1px; }
#sap-ai-output { background:var(--sap-bg); border:1px solid var(--sap-border); border-radius:var(--sap-r); padding:16px 20px; font-size:14px; color:var(--sap-text-2); line-height:1.7; white-space:pre-wrap; display:none; margin-top:16px; }

/* ======================================================
   AUTH PAGE
   ====================================================== */
.sap-auth-page {
  min-height: 100vh;
  background: var(--sap-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
}

.sap-auth-card {
  background: var(--sap-white);
  border: 1px solid var(--sap-border);
  border-radius: var(--sap-r-xl);
  padding: 40px;
  width: 100%;
  max-width: 428px;
  box-shadow: var(--sap-shadow-lg);
}

.sap-auth-logo { font-family:var(--font-head); font-size:21px; font-weight:800; color:var(--sap-primary); text-align:center; margin-bottom:6px; }
.sap-auth-heading { font-family:var(--font-head); font-size:21px; font-weight:700; color:var(--sap-text); text-align:center; margin-bottom:6px; }
.sap-auth-sub { font-size:14px; color:var(--sap-text-3); text-align:center; margin-bottom:28px; }

.sap-tabs-row { display:flex; background:var(--sap-bg-alt); border:1px solid var(--sap-border); border-radius:var(--sap-r); padding:4px; margin-bottom:24px; }
.sap-tab-btn { flex:1; padding:9px; border-radius:6px; font-family:var(--font-head); font-size:13px; font-weight:600; cursor:pointer; border:none; background:transparent; color:var(--sap-text-3); transition:all .15s; }
.sap-tab-btn.active { background:var(--sap-white); color:var(--sap-text); box-shadow:var(--sap-shadow-sm); }

.sap-field { margin-bottom:15px; }
.sap-field label { display:block; font-size:13px; font-weight:600; color:var(--sap-text-2); margin-bottom:6px; }
.sap-field input { width:100%; background:var(--sap-white); border:1.5px solid var(--sap-border); border-radius:var(--sap-r); color:var(--sap-text); font-family:var(--font-body); font-size:14px; padding:11px 14px; outline:none; transition:border-color .15s, box-shadow .15s; box-sizing:border-box; }
.sap-field input:focus { border-color:var(--sap-primary); box-shadow:0 0 0 3px rgba(37,99,235,.1); }
.sap-field input::placeholder { color:var(--sap-text-4); }

.sap-submit-btn { width:100%; padding:13px; background:var(--sap-primary); color:#fff; border:none; border-radius:var(--sap-r); font-family:var(--font-head); font-size:15px; font-weight:700; cursor:pointer; transition:background .18s; display:flex; align-items:center; justify-content:center; gap:8px; margin-top:6px; }
.sap-submit-btn:hover { background:var(--sap-primary-dk); }
.sap-submit-btn:disabled { opacity:.55; cursor:not-allowed; }

.sap-divider { display:flex; align-items:center; gap:12px; color:var(--sap-text-4); font-size:12px; margin:18px 0; }
.sap-divider::before, .sap-divider::after { content:''; flex:1; height:1px; background:var(--sap-border); }

.sap-google-btn { width:100%; padding:11px; background:var(--sap-white); color:var(--sap-text) !important; border:1.5px solid var(--sap-border); border-radius:var(--sap-r); font-family:var(--font-head); font-size:14px; font-weight:600; cursor:pointer; transition:all .15s; display:flex; align-items:center; justify-content:center; gap:10px; text-decoration:none; }
.sap-google-btn:hover { background:var(--sap-bg-alt); border-color:#c5cfe0; }

.sap-form-msg { padding:10px 14px; border-radius:var(--sap-r); font-size:13px; margin-top:14px; display:none; }
.sap-form-msg.error   { background:var(--sap-red-soft);   border:1px solid #fecaca; color:#b91c1c; display:block; }
.sap-form-msg.success { background:var(--sap-green-soft); border:1px solid #bbf7d0; color:#15803d; display:block; }

/* ======================================================
   DASHBOARD
   ====================================================== */
.sap-dash-page { background:var(--sap-bg); min-height:100vh; }
.sap-dash-bar { background:var(--sap-white); border-bottom:1px solid var(--sap-border); padding:16px 24px; }
.sap-dash-bar-inner { max-width:1100px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.sap-dash-name { font-family:var(--font-head); font-size:19px; font-weight:700; color:var(--sap-text); }
.sap-dash-name-sub { font-size:13px; color:var(--sap-text-3); margin-top:2px; }
.sap-dash-bar-btns { display:flex; gap:8px; flex-wrap:wrap; }

.sap-dash-inner { max-width:1100px; margin:0 auto; padding:32px 24px 72px; }

.sap-dash-kpi { display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:14px; margin-bottom:28px; }
.sap-kpi-card { background:var(--sap-white); border:1px solid var(--sap-border); border-radius:var(--sap-r-lg); padding:20px; box-shadow:var(--sap-shadow-sm); }
.sap-kpi-num { font-family:var(--font-head); font-size:30px; font-weight:800; color:var(--sap-primary); line-height:1; }
.sap-kpi-label { font-size:12px; font-weight:600; color:var(--sap-text-3); margin-top:5px; text-transform:uppercase; letter-spacing:.04em; }

.sap-scans-card { background:var(--sap-white); border:1px solid var(--sap-border); border-radius:var(--sap-r-xl); overflow:hidden; box-shadow:var(--sap-shadow-sm); }
.sap-card-bar { display:flex; align-items:center; justify-content:space-between; padding:18px 22px; border-bottom:1px solid var(--sap-border); }
.sap-card-bar-title { font-family:var(--font-head); font-size:15px; font-weight:700; color:var(--sap-text); }

.sap-tbl-head { display:grid; grid-template-columns:1fr 90px 100px 100px; gap:12px; padding:10px 22px; background:var(--sap-bg); border-bottom:1px solid var(--sap-border-light); font-size:11px; font-weight:600; color:var(--sap-text-4); text-transform:uppercase; letter-spacing:.05em; }
.sap-tbl-row  { display:grid; grid-template-columns:1fr 90px 100px 100px; gap:12px; padding:14px 22px; border-bottom:1px solid var(--sap-border-light); align-items:center; transition:background .12s; }
.sap-tbl-row:last-child { border-bottom:none; }
.sap-tbl-row:hover { background:var(--sap-bg); }
@media(max-width:600px) {
  .sap-tbl-head { grid-template-columns:1fr 80px 80px; }
  .sap-tbl-row  { grid-template-columns:1fr 80px 80px; }
  .sap-tbl-head > *:nth-child(4), .sap-tbl-row > *:nth-child(4) { display:none; }
}

.sap-tbl-url { font-size:14px; font-weight:500; color:var(--sap-text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.sap-tbl-url-date { font-size:11px; color:var(--sap-text-4); margin-top:2px; }

.sap-score-pill { display:inline-flex; align-items:center; justify-content:center; padding:4px 12px; border-radius:100px; font-family:var(--font-head); font-size:13px; font-weight:700; }
.sap-score-pill.high   { background:var(--sap-green-soft);  color:var(--sap-green); }
.sap-score-pill.medium { background:var(--sap-yellow-soft); color:var(--sap-yellow); }
.sap-score-pill.low    { background:var(--sap-red-soft);    color:var(--sap-red); }

.sap-row-actions { display:flex; gap:6px; }
.sap-icon-btn { width:30px; height:30px; display:flex; align-items:center; justify-content:center; border-radius:6px; border:1px solid var(--sap-border); background:transparent; color:var(--sap-text-3); cursor:pointer; font-size:13px; transition:all .15s; text-decoration:none; }
.sap-icon-btn:hover { border-color:var(--sap-primary); color:var(--sap-primary); background:var(--sap-primary-soft); }
.sap-icon-btn.del:hover { border-color:var(--sap-red); color:var(--sap-red); background:var(--sap-red-soft); }

.sap-empty { text-align:center; padding:56px 20px; }
.sap-empty-ico   { font-size:44px; margin-bottom:14px; opacity:.35; }
.sap-empty-title { font-family:var(--font-head); font-size:17px; font-weight:700; color:var(--sap-text-2); margin-bottom:6px; }
.sap-empty-desc  { font-size:13px; color:var(--sap-text-4); }

/* ======================================================
   PROFILE
   ====================================================== */
.sap-profile-page { background:var(--sap-bg); min-height:100vh; padding:40px 24px 72px; }
.sap-profile-inner { max-width:720px; margin:0 auto; }
.sap-back-link { display:inline-flex; align-items:center; gap:6px; font-size:14px; color:var(--sap-text-3); text-decoration:none; transition:color .15s; margin-bottom:24px; }
.sap-back-link:hover { color:var(--sap-primary); }

.sap-card { background:var(--sap-white); border:1px solid var(--sap-border); border-radius:var(--sap-r-xl); padding:28px; margin-bottom:16px; box-shadow:var(--sap-shadow-sm); }
.sap-card-title { font-family:var(--font-head); font-size:15px; font-weight:700; color:var(--sap-text); margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--sap-border-light); }

.sap-avatar-row { display:flex; align-items:center; gap:18px; margin-bottom:24px; }
.sap-avatar { width:66px; height:66px; border-radius:50%; border:2px solid var(--sap-border); object-fit:cover; }
.sap-avatar-name { font-family:var(--font-head); font-size:19px; font-weight:700; color:var(--sap-text); }
.sap-avatar-email { font-size:13px; color:var(--sap-text-3); margin-top:2px; }

.sap-lic-row { display:flex; align-items:center; justify-content:space-between; background:var(--sap-bg); border:1px solid var(--sap-border); border-radius:var(--sap-r); padding:14px 16px; margin-bottom:8px; flex-wrap:wrap; gap:8px; }
.sap-lic-key { font-family:monospace; font-size:14px; color:var(--sap-text-2); letter-spacing:.04em; }
.sap-lic-status { font-size:11px; font-weight:700; text-transform:uppercase; padding:3px 10px; border-radius:4px; }
.sap-lic-status.active   { background:var(--sap-green-soft); color:var(--sap-green); }
.sap-lic-status.inactive { background:var(--sap-bg-alt);     color:var(--sap-text-4); }
.sap-lic-status.expired  { background:var(--sap-red-soft);   color:var(--sap-red); }

/* ======================================================
   REPORT PAGE
   ====================================================== */
.sap-report-wrap { background:var(--sap-bg); min-height:100vh; }

.sap-report-nav {
  background: var(--sap-white);
  border-bottom: 1px solid var(--sap-border);
  padding: 13px 24px;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 1px 4px rgba(0,0,0,0.05);
}

.sap-report-nav-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.sap-report-body { max-width:1100px; margin:0 auto; padding:32px 24px 72px; }

.sap-report-hero {
  background: var(--sap-white);
  border: 1px solid var(--sap-border);
  border-radius: var(--sap-r-xl);
  padding: 32px;
  margin-bottom: 22px;
  box-shadow: var(--sap-shadow-sm);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: start;
}
@media(max-width:640px) { .sap-report-hero { grid-template-columns:1fr; } }

.sap-report-meta { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--sap-text-4); margin-bottom:8px; }
.sap-report-url  { font-family:var(--font-head); font-size:clamp(15px,2.5vw,22px); font-weight:700; color:var(--sap-text); word-break:break-all; margin-bottom:8px; }
.sap-report-date { font-size:13px; color:var(--sap-text-4); margin-bottom:20px; }

.sap-summary-pills { display:flex; gap:10px; flex-wrap:wrap; }
.sap-sum-pill { display:flex; flex-direction:column; align-items:center; background:var(--sap-bg); border:1px solid var(--sap-border); border-radius:var(--sap-r); padding:12px 16px; min-width:72px; text-align:center; }
.sap-sum-num { font-family:var(--font-head); font-size:22px; font-weight:800; line-height:1; margin-bottom:4px; }
.sap-sum-num.crit { color:var(--sap-red); }
.sap-sum-num.warn { color:var(--sap-yellow); }
.sap-sum-num.info { color:var(--sap-blue); }
.sap-sum-num.pass { color:var(--sap-green); }
.sap-sum-lbl { font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--sap-text-4); }

.sap-report-score-widget { text-align:center; flex-shrink:0; }
.sap-report-grade { font-family:var(--font-head); font-size:42px; font-weight:800; line-height:1; margin-top:8px; }
.sap-report-grade-lbl { font-size:12px; color:var(--sap-text-4); margin-top:2px; }

.sap-score-bar-row { margin-top:18px; display:flex; align-items:center; gap:12px; }
.sap-score-bar-bg { flex:1; height:8px; background:var(--sap-border); border-radius:4px; overflow:hidden; }
.sap-score-bar-fill { height:100%; border-radius:4px; transition:width 1.4s ease; }

/* features section */
.sap-features-wrap { background:var(--sap-white); border-top:1px solid var(--sap-border); padding:64px 24px; text-align:center; }
.sap-features-eyebrow { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--sap-primary); margin-bottom:12px; }
.sap-features-h2 { font-family:var(--font-head); font-size:clamp(22px,3vw,32px); font-weight:700; color:var(--sap-text); letter-spacing:-.01em; margin-bottom:40px; }
.sap-features-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:16px; max-width:1100px; margin:0 auto; }
.sap-feat-box { background:var(--sap-bg); border:1px solid var(--sap-border); border-radius:var(--sap-r-lg); padding:22px; text-align:left; transition:border-color .18s, box-shadow .18s; }
.sap-feat-box:hover { border-color:#c5cde0; box-shadow:var(--sap-shadow); }
.sap-feat-ico  { font-size:24px; margin-bottom:12px; }
.sap-feat-name { font-family:var(--font-head); font-size:14px; font-weight:700; color:var(--sap-text); margin-bottom:5px; }
.sap-feat-desc { font-size:12px; color:var(--sap-text-3); line-height:1.55; }

/* misc */
.sap-login-required, .sap-already-logged-in { text-align:center; padding:60px 20px; color:var(--sap-text-3); font-size:15px; }
.sap-skeleton { background:linear-gradient(90deg,var(--sap-border-light) 25%,var(--sap-border) 50%,var(--sap-border-light) 75%); background-size:200% 100%; animation:sap-shimmer 1.4s infinite; border-radius:6px; }
@keyframes sap-shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
@keyframes sap-fade-up { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
.sap-fade-up { animation:sap-fade-up .45s ease both; }
.sap-d1 { animation-delay:.08s; }
.sap-d2 { animation-delay:.16s; }
.sap-d3 { animation-delay:.24s; }
