/* SEO Agency Pro v4 - app.css */
:root{
  --w:#fff;--bg:#f7f8fc;--bg2:#eef0f8;--bd:#e2e6f0;--bd2:#d0d5e8;
  --p:#2563eb;--pd:#1d4ed8;--ps:#eff4ff;
  --g:#16a34a;--gs:#f0fdf4;--r:#dc2626;--rs:#fef2f2;
  --y:#d97706;--ys:#fffbeb;--b:#2563eb;--bs:#eff6ff;
  --t1:#0f172a;--t2:#334155;--t3:#64748b;--t4:#94a3b8;
  --fh:'Plus Jakarta Sans',-apple-system,sans-serif;
  --fb:'Inter',-apple-system,sans-serif;
  --r1:8px;--r2:12px;--r3:16px;
  --s1:0 1px 4px rgba(0,0,0,.06);--s2:0 4px 16px rgba(0,0,0,.08);--s3:0 12px 40px rgba(0,0,0,.1);
}
.sap *,.sap *::before,.sap *::after,.sap-report-wrap *,.sap-report-wrap *::before,.sap-report-wrap *::after{box-sizing:border-box;margin:0;padding:0}
.sap,.sap-report-wrap{font-family:var(--fb);color:var(--t1);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.6}
.sap a{color:var(--p);text-decoration:none}
/* Buttons */
.sap-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:var(--r1);font-family:var(--fh);font-size:14px;font-weight:600;cursor:pointer;border:1.5px solid transparent;text-decoration:none;transition:all .18s;white-space:nowrap;line-height:1}
.sap-btn-primary{background:var(--p);color:#fff!important;border-color:var(--p)}
.sap-btn-primary:hover{background:var(--pd);transform:translateY(-1px);box-shadow:0 4px 14px rgba(37,99,235,.28)}
.sap-btn-outline{background:transparent;color:var(--p)!important;border-color:var(--p)}
.sap-btn-outline:hover{background:var(--ps)}
.sap-btn-ghost{background:var(--w);color:var(--t2)!important;border-color:var(--bd)}
.sap-btn-ghost:hover{background:var(--bg2)}
.sap-btn-sm{padding:7px 14px;font-size:13px}
.sap-btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}
/* Utilities */
.sap-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:100px;font-size:12px;font-weight:600}
.sap-badge-blue{background:var(--bs);color:var(--b)}
.sap-spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--bd);border-top-color:var(--p);border-radius:50%;animation:sap-spin .75s linear infinite;flex-shrink:0}
@keyframes sap-spin{to{transform:rotate(360deg)}}
.sap-skel{background:linear-gradient(90deg,var(--bd) 25%,var(--bd2) 50%,var(--bd) 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}}
/* Hero */
.sap-hero{background:var(--w);border-bottom:1px solid var(--bd);padding:72px 24px 56px;text-align:center}
.sap-hero-inner{max-width:760px;margin:0 auto}
.sap-eyebrow{display:inline-flex;align-items:center;gap:6px;background:var(--ps);color:var(--p);border:1px solid rgba(37,99,235,.2);border-radius:100px;padding:5px 14px;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
.sap-hero-title{font-family:var(--fh);font-size:clamp(28px,5vw,52px);font-weight:800;line-height:1.12;color:var(--t1);letter-spacing:-.025em;margin-bottom:16px}
.sap-hero-title em{font-style:normal;color:var(--p)}
.sap-hero-lead{font-size:18px;color:var(--t3);max-width:500px;margin:0 auto 36px;line-height:1.65}
/* Scanner form */
.sap-scan-form{max-width:680px;margin:0 auto}
.sap-input-wrap{display:flex;align-items:stretch;border:2px solid var(--bd);border-radius:var(--r2);background:var(--w);overflow:hidden;transition:border-color .18s,box-shadow .18s;box-shadow:var(--s1)}
.sap-input-wrap:focus-within{border-color:var(--p);box-shadow:0 0 0 4px rgba(37,99,235,.1)}
.sap-input-wrap.err{border-color:var(--r)}
.sap-input-prefix{display:flex;align-items:center;padding:0 14px 0 18px;font-size:14px;color:var(--t4);border-right:1px solid var(--bd);background:var(--bg);user-select:none;white-space:nowrap}
#sap-url{flex:1;border:none;outline:none;background:transparent;font-family:var(--fb);font-size:15px;color:var(--t1);padding:17px 14px}
#sap-url::placeholder{color:var(--t4)}
#sap-scan-btn{background:var(--p);color:#fff;border:none;font-family:var(--fh);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-btn:hover{background:var(--pd)}
#sap-scan-btn:disabled{opacity:.6;cursor:not-allowed}
.sap-hint{margin-top:12px;font-size:13px;color:var(--t4)}
.sap-err-msg{color:var(--r);font-size:13px;margin-top:8px;text-align:center;display:none}
.sap-chips{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:28px}
.sap-chip{display:inline-flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--bd);border-radius:100px;padding:6px 14px;font-size:12px;font-weight:500;color:var(--t3)}
/* Progress */
.sap-progress{max-width:600px;margin:32px auto 0;background:var(--w);border:1px solid var(--bd);border-radius:var(--r3);padding:28px 32px;box-shadow:var(--s2)}
.sap-progress-inner{}
.sap-progress-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}
.sap-progress-title{font-family:var(--fh);font-size:15px;font-weight:700;color:var(--t1)}
.sap-progress-sub{font-size:12px;color:var(--t4);margin-top:2px;word-break:break-all}
.sap-track{height:4px;background:var(--bd);border-radius:2px;overflow:hidden;margin-bottom:22px}
.sap-track-fill{height:100%;background:var(--p);border-radius:2px;width:0%;transition:width .4s ease}
.sap-steps{list-style:none;display:flex;flex-direction:column;gap:10px}
.sap-step{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--t4);transition:color .2s}
.sap-step-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--bd);background:var(--w);display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;transition:all .2s}
.sap-step.active .sap-step-dot{border-color:var(--p);background:var(--ps)}
.sap-step.active{color:var(--t2);font-weight:500}
.sap-step.done .sap-step-dot{border-color:var(--g);background:var(--g);color:#fff;font-size:11px}
.sap-step.done{color:var(--g)}
.sap-countdown{display:flex;align-items:center;gap:12px;margin-top:6px}
.sap-cd-bar-bg{flex:1;height:6px;background:var(--bd);border-radius:3px;overflow:hidden}
.sap-cd-bar{height:100%;background:var(--p);border-radius:3px;width:0%}
.sap-cd-num{font-family:var(--fh);font-size:13px;font-weight:700;color:var(--p);width:20px;text-align:right}
/* Results */
.sap-results-inner{max-width:1100px;margin:0 auto;padding:36px 24px 72px}
.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}}
.sap-score-card{background:var(--w);border:1px solid var(--bd);border-radius:var(--r3);padding:28px 20px;text-align:center;box-shadow:var(--s1)}
.sap-ring-wrap{position:relative;margin:0 auto 14px}
.sap-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.sap-ring-num{font-family:var(--fh);font-size:38px;font-weight:800;color:var(--t1);line-height:1}
.sap-ring-of{font-size:12px;color:var(--t4)}
.sap-grade-display{font-family:var(--fh);font-size:30px;font-weight:800;line-height:1}
.sap-grade-lbl{font-size:12px;color:var(--t4);margin-top:3px}
.sap-scanned-url{font-size:11px;color:var(--t4);margin-top:12px;word-break:break-all}
.sap-stats-panel{background:var(--w);border:1px solid var(--bd);border-radius:var(--r3);padding:26px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--s1)}
.sap-panel-label{font-family:var(--fh);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--t4);margin-bottom:16px}
.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(--bg);border:1px solid var(--bd);border-radius:var(--r1);padding:14px 10px;text-align:center}
.sap-stat-big{font-family:var(--fh);font-size:28px;font-weight:800;line-height:1;margin-bottom:4px}
.sap-stat-big.c{color:var(--r)}.sap-stat-big.w{color:var(--y)}.sap-stat-big.i{color:var(--b)}.sap-stat-big.p{color:var(--g)}
.sap-stat-lbl{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.04em}
.sap-panel-btns{display:flex;gap:10px;flex-wrap:wrap}
/* Analysis */
.sap-analysis-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.sap-section-title{font-family:var(--fh);font-size:19px;font-weight:700;color:var(--t1)}
.sap-filter-bar{display:flex;gap:5px;background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r1);padding:4px}
.sap-filter{padding:6px 14px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--t3);transition:all .15s}
.sap-filter.active{background:var(--w);color:var(--t1);box-shadow:var(--s1)}
.sap-filter[data-filter="critical"].active,.sap-filter[data-f="critical"].active{color:var(--r)}
.sap-filter[data-filter="warning"].active,.sap-filter[data-f="warning"].active{color:var(--y)}
.sap-filter[data-filter="passed"].active,.sap-filter[data-f="passed"].active{color:var(--g)}
/* Category cards */
.sap-cat-card{background:var(--w);border:1px solid var(--bd);border-radius:var(--r2);margin-bottom:10px;overflow:hidden;box-shadow:var(--s1);transition:border-color .18s}
.sap-cat-card:hover{border-color:var(--bd2)}
.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-ico{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.sap-cat-ico.bg-red{background:var(--rs)}.sap-cat-ico.bg-yellow{background:var(--ys)}.sap-cat-ico.bg-green{background:var(--gs)}.sap-cat-ico.bg-blue{background:var(--bs)}
.sap-cat-name{font-family:var(--fh);font-size:15px;font-weight:600;color:var(--t1)}
.sap-cat-sub{font-size:12px;color:var(--t4);margin-top:1px}
.sap-cat-right{display:flex;align-items:center;gap:8px}
.sap-pill-sm{font-size:11px;font-weight:700;padding:3px 9px;border-radius:100px}
.sap-pill-sm.c{background:var(--rs);color:var(--r)}.sap-pill-sm.w{background:var(--ys);color:var(--y)}.sap-pill-sm.i{background:var(--bs);color:var(--b)}.sap-pill-sm.p{background:var(--gs);color:var(--g)}
.sap-chevron{color:var(--t4);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(--bd);padding:12px 16px 16px;background:var(--bg)}
.sap-cat-card.open .sap-cat-body{display:block}
/* Issues */
.sap-issue{background:var(--w);border:1px solid var(--bd);border-left:3px solid transparent;border-radius:var(--r1);padding:14px 16px;margin-bottom:8px}
.sap-issue:last-child{margin-bottom:0}
.sap-issue.critical{border-left-color:var(--r)}.sap-issue.warning{border-left-color:var(--y)}.sap-issue.info{border-left-color:var(--b)}.sap-issue.passed{border-left-color:var(--g)}
.sap-issue-head{display:flex;align-items:flex-start;gap:10px;margin-bottom:7px}
.sap-sev{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.critical{background:var(--rs);color:var(--r)}.sap-sev.warning{background:var(--ys);color:var(--y)}.sap-sev.info{background:var(--bs);color:var(--b)}.sap-sev.passed{background:var(--gs);color:var(--g)}
.sap-issue-title{font-family:var(--fh);font-size:14px;font-weight:600;color:var(--t1);line-height:1.4}
.sap-issue-desc{font-size:13px;color:var(--t3);line-height:1.55;margin-bottom:8px}
.sap-issue-rec{display:flex;align-items:flex-start;gap:8px;background:var(--gs);border:1px solid #bbf7d0;border-radius:6px;padding:8px 12px;font-size:12px;color:#15803d;line-height:1.5}
.sap-issue-val{margin-top:8px;font-size:12px;color:var(--t3);background:var(--bg);border:1px solid var(--bd);border-radius:6px;padding:7px 10px;font-family:monospace;word-break:break-all}
/* AI / Keywords */
.sap-ai-card{background:var(--w);border:1px solid var(--bd);border-radius:var(--r3);padding:24px 28px;box-shadow:var(--s1)}
.sap-ai-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.sap-ai-ico{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,#6366f1,#0ea5e9);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.sap-ai-title{font-family:var(--fh);font-size:16px;font-weight:700;color:var(--t1)}
.sap-ai-sub{font-size:12px;color:var(--t4);margin-top:1px}
.sap-ai-output{background:var(--bg);border:1px solid var(--bd);border-radius:var(--r1);padding:16px 20px;font-size:13px;color:var(--t2);line-height:1.7;margin-top:16px}
.sap-ai-locked{text-align:center;padding:36px 28px}
.sap-ai-locked h3{font-family:var(--fh);font-size:18px;font-weight:700;color:var(--t1);margin:12px 0 8px}
.sap-ai-locked p{font-size:14px;color:var(--t3);margin-bottom:18px}
/* Keyword panel */
.sap-kw-output{margin-top:16px}
.sap-kw-panel{display:flex;flex-direction:column;gap:14px}
.sap-kw-primary{background:var(--ps);border:1px solid rgba(37,99,235,.2);border-radius:var(--r1);padding:14px 18px}
.sap-kw-main{display:block;font-family:var(--fh);font-size:20px;font-weight:800;color:var(--p);margin-top:4px}
.sap-kw-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--t3)}
.sap-kw-group{background:var(--bg);border:1px solid var(--bd);border-radius:var(--r1);padding:14px 18px}
.sap-kw-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.sap-kw-tag{background:var(--w);border:1px solid var(--bd2);border-radius:6px;padding:5px 12px;font-size:13px;color:var(--t2);font-weight:500}
.sap-kw-tag-lt{background:var(--gs);border-color:#bbf7d0;color:#15803d}
.sap-kw-meta{display:flex;gap:14px;flex-wrap:wrap}
.sap-kw-meta-item{background:var(--bg);border:1px solid var(--bd);border-radius:var(--r1);padding:12px 16px;flex:1;min-width:130px}
.sap-kw-val{display:block;font-family:var(--fh);font-size:15px;font-weight:700;color:var(--t1);margin-top:4px;text-transform:capitalize}
.sap-kw-suggestion{background:var(--w);border:1px solid var(--bd);border-radius:var(--r1);padding:14px 18px}
.sap-kw-suggest-text{font-size:14px;color:var(--t2);margin-top:6px;line-height:1.5}
.sap-kw-recs{margin-top:8px;padding-left:18px;display:flex;flex-direction:column;gap:6px}
.sap-kw-recs li{font-size:13px;color:var(--t2);line-height:1.5}
/* Report summary pills */
.sap-summary-pills{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:0}
.sap-pill{display:flex;flex-direction:column;align-items:center;background:var(--bg);border:1px solid var(--bd);border-radius:var(--r1);padding:12px 16px;min-width:68px;text-align:center}
.sap-pill-num{font-family:var(--fh);font-size:22px;font-weight:800;line-height:1;margin-bottom:4px}
.sap-pill-lbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--t4)}
.sap-pill-num.c,.sap-pill-lbl.c{color:var(--r)}.sap-pill-num.w,.sap-pill-lbl.w{color:var(--y)}.sap-pill-num.i,.sap-pill-lbl.i{color:var(--b)}.sap-pill-num.p,.sap-pill-lbl.p{color:var(--g)}
.sap-score-bar-row{display:flex;align-items:center;gap:12px;margin-top:18px}
.sap-score-bar-label{font-size:12px;font-weight:600;color:var(--t3);white-space:nowrap}
.sap-score-bar-bg{flex:1;height:8px;background:var(--bd);border-radius:4px;overflow:hidden}
.sap-score-bar-fill{height:100%;border-radius:4px;transition:width 1.2s ease}
.sap-score-bar-val{font-size:13px;font-weight:700;white-space:nowrap}
/* Report page */
.sap-report-wrap{background:var(--bg);min-height:100vh}
.sap-report-nav{background:var(--w);border-bottom:1px solid var(--bd);padding:13px 24px;position:sticky;top:0;z-index:100;box-shadow:0 1px 4px rgba(0,0,0,.05);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.sap-report-nav-right{display:flex;gap:8px;flex-wrap:wrap}
.sap-report-body{max-width:1100px;margin:0 auto;padding:32px 24px 72px}
.sap-report-hero{background:var(--w);border:1px solid var(--bd);border-radius:var(--r3);padding:32px;margin-bottom:22px;box-shadow:var(--s1);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-hero-left{}
.sap-report-meta-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--t4);margin-bottom:8px}
.sap-report-url{font-family:var(--fh);font-size:clamp(14px,2.5vw,20px);font-weight:700;color:var(--t1);word-break:break-all;margin-bottom:8px}
.sap-report-date{font-size:13px;color:var(--t4);margin-bottom:20px}
.sap-report-score-widget{text-align:center;flex-shrink:0}
.sap-report-grade{font-family:var(--fh);font-size:42px;font-weight:800;line-height:1;margin-top:8px}
.sap-report-grade-lbl{font-size:12px;color:var(--t4);margin-top:2px}
.sap-analysis-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}
/* Auth */
.sap-auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg)}
.sap-auth-card{background:var(--w);border:1px solid var(--bd);border-radius:var(--r3);padding:40px;width:100%;max-width:428px;box-shadow:var(--s3)}
.sap-auth-brand{font-family:var(--fh);font-size:21px;font-weight:800;color:var(--p);text-align:center;margin-bottom:6px}
.sap-auth-title{font-family:var(--fh);font-size:21px;font-weight:700;color:var(--t1);text-align:center;margin-bottom:6px}
.sap-auth-sub{font-size:14px;color:var(--t3);text-align:center;margin-bottom:26px}
.sap-tabs{display:flex;background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r1);padding:4px;margin-bottom:22px}
.sap-tab{flex:1;padding:9px;border-radius:6px;font-family:var(--fh);font-size:13px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--t3);transition:all .15s}
.sap-tab.active{background:var(--w);color:var(--t1);box-shadow:var(--s1)}
.sap-field{margin-bottom:14px}
.sap-field label{display:block;font-size:13px;font-weight:600;color:var(--t2);margin-bottom:6px}
.sap-field input{width:100%;background:var(--w);border:1.5px solid var(--bd);border-radius:var(--r1);color:var(--t1);font-family:var(--fb);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(--p);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.sap-field input::placeholder{color:var(--t4)}
.sap-submit-btn{width:100%;padding:13px;background:var(--p);color:#fff;border:none;border-radius:var(--r1);font-family:var(--fh);font-size:15px;font-weight:700;cursor:pointer;transition:background .18s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px}
.sap-submit-btn:hover{background:var(--pd)}.sap-submit-btn:disabled{opacity:.55;cursor:not-allowed}
.sap-or{display:flex;align-items:center;gap:12px;color:var(--t4);font-size:12px;margin:16px 0}
.sap-or::before,.sap-or::after{content:'';flex:1;height:1px;background:var(--bd)}
.sap-google-btn{width:100%;padding:11px;background:var(--w);color:var(--t1)!important;border:1.5px solid var(--bd);border-radius:var(--r1);font-family:var(--fh);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(--bg2);border-color:var(--bd2)}
.sap-form-msg{padding:10px 14px;border-radius:var(--r1);font-size:13px;margin-top:12px;display:none}
.sap-form-msg.err{background:var(--rs);border:1px solid #fecaca;color:#b91c1c;display:block}
.sap-form-msg.ok{background:var(--gs);border:1px solid #bbf7d0;color:#15803d;display:block}
/* Dashboard */
.sap-dash{background:var(--bg);min-height:100vh}
.sap-dash-topbar{background:var(--w);border-bottom:1px solid var(--bd);padding:16px 24px}
.sap-dash-topbar-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.sap-dash-greeting{font-family:var(--fh);font-size:19px;font-weight:700;color:var(--t1)}
.sap-dash-sub{font-size:13px;color:var(--t3);margin-top:2px}
.sap-dash-actions{display:flex;gap:8px;flex-wrap:wrap}
.sap-dash-body{max-width:1100px;margin:0 auto;padding:28px 24px 72px}
.sap-kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:24px}
.sap-kpi{background:var(--w);border:1px solid var(--bd);border-radius:var(--r2);padding:20px;box-shadow:var(--s1)}
.sap-kpi-num{font-family:var(--fh);font-size:30px;font-weight:800;color:var(--p);line-height:1}
.sap-kpi-lbl{font-size:12px;font-weight:600;color:var(--t3);margin-top:5px;text-transform:uppercase;letter-spacing:.04em}
.sap-table-card{background:var(--w);border:1px solid var(--bd);border-radius:var(--r3);overflow:hidden;box-shadow:var(--s1)}
.sap-table-top{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--bd)}
.sap-table-title{font-family:var(--fh);font-size:15px;font-weight:700;color:var(--t1)}
.sap-tbl-head{display:grid;grid-template-columns:1fr 90px 100px 100px;gap:12px;padding:10px 22px;background:var(--bg);border-bottom:1px solid var(--bd);font-size:11px;font-weight:600;color:var(--t4);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(--bd);align-items:center;transition:background .12s}
.sap-tbl-row:last-child{border-bottom:none}.sap-tbl-row:hover{background:var(--bg)}
@media(max-width:600px){.sap-tbl-head,.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(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sap-tbl-date{font-size:11px;color:var(--t4);margin-top:2px}
.sap-score-pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;border-radius:100px;font-family:var(--fh);font-size:13px;font-weight:700}
.sap-score-pill.hi{background:var(--gs);color:var(--g)}.sap-score-pill.md{background:var(--ys);color:var(--y)}.sap-score-pill.lo{background:var(--rs);color:var(--r)}
.sap-row-acts{display:flex;gap:6px}
.sap-ico-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid var(--bd);background:transparent;color:var(--t3);cursor:pointer;font-size:13px;transition:all .15s;text-decoration:none}
.sap-ico-btn:hover{border-color:var(--p);color:var(--p);background:var(--ps)}.sap-ico-btn.del:hover{border-color:var(--r);color:var(--r);background:var(--rs)}
.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(--fh);font-size:17px;font-weight:700;color:var(--t2);margin-bottom:6px}
.sap-empty-desc{font-size:13px;color:var(--t4)}
/* Profile */
.sap-profile-page{background:var(--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(--t3);text-decoration:none;transition:color .15s;margin-bottom:24px}
.sap-back-link:hover{color:var(--p)}
.sap-card{background:var(--w);border:1px solid var(--bd);border-radius:var(--r3);padding:28px;margin-bottom:16px;box-shadow:var(--s1)}
.sap-card-title{font-family:var(--fh);font-size:15px;font-weight:700;color:var(--t1);margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--bd)}
.sap-avatar-row{display:flex;align-items:center;gap:18px;margin-bottom:22px}
.sap-avatar{width:66px;height:66px;border-radius:50%;border:2px solid var(--bd);object-fit:cover}
.sap-avatar-name{font-family:var(--fh);font-size:19px;font-weight:700;color:var(--t1)}
.sap-avatar-email{font-size:13px;color:var(--t3);margin-top:2px}
.sap-lic-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border:1px solid var(--bd);border-radius:var(--r1);padding:14px 16px;margin-bottom:8px;flex-wrap:wrap;gap:8px}
.sap-lic-key{font-family:monospace;font-size:14px;color:var(--t2);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(--gs);color:var(--g)}.sap-lic-status.inactive{background:var(--bg2);color:var(--t4)}.sap-lic-status.expired{background:var(--rs);color:var(--r)}
/* Features */
.sap-features{background:var(--w);border-top:1px solid var(--bd);padding:64px 24px}
.sap-features-inner{max-width:1100px;margin:0 auto;text-align:center}
.sap-features-title{font-family:var(--fh);font-size:clamp(22px,3vw,32px);font-weight:700;color:var(--t1);letter-spacing:-.01em;margin-bottom:36px}
.sap-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;text-align:left}
.sap-feat{background:var(--bg);border:1px solid var(--bd);border-radius:var(--r2);padding:22px;transition:border-color .18s,box-shadow .18s}
.sap-feat:hover{border-color:var(--bd2);box-shadow:var(--s2)}
.sap-feat-ico{font-size:24px;margin-bottom:12px}
.sap-feat-name{font-family:var(--fh);font-size:14px;font-weight:700;color:var(--t1);margin-bottom:5px}
.sap-feat-desc{font-size:12px;color:var(--t3);line-height:1.55}
