/* ============================================================
   SEO Audit Tool — Shared Stylesheet
   websiteseoaudittools.com
   ============================================================ */

/* ── Variables ── */
:root{--bg:#f0f4f8;--bg2:#e8edf5;--bg3:#dde4ee;--surface:#ffffff;--surface2:#f5f7fa;--border:rgba(0,0,0,0.08);--border2:rgba(0,0,0,0.14);--accent:#0066ff;--accent2:#7c3aed;--accent3:#059669;--warn:#d97706;--danger:#dc2626;--text:#0f172a;--text2:#475569;--text3:#94a3b8}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;line-height:1.6;min-height:100vh;overflow-x:hidden}
body::before{content:'';position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,102,255,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,102,255,0.04) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0}
body::after{content:'';position:fixed;top:-20%;left:50%;transform:translateX(-50%);width:900px;height:600px;background:radial-gradient(ellipse,rgba(0,102,255,0.07) 0%,transparent 70%);pointer-events:none;z-index:0}

/* ── Navigation ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,0.97);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);height:64px;box-shadow:0 1px 8px rgba(0,0,0,0.05)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 40px;height:64px;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:20px;letter-spacing:-0.5px;color:var(--text);display:flex;align-items:center;gap:9px;cursor:pointer;text-decoration:none}
.logo-dot{width:9px;height:9px;background:var(--accent);border-radius:50%;box-shadow:0 0 10px var(--accent);animation:pulse 2s ease-in-out infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 10px var(--accent)}50%{opacity:.5;box-shadow:0 0 5px var(--accent)}}
.nav-right{display:flex;align-items:center;gap:8px}
.nav-links{display:flex;gap:4px;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--text);text-decoration:none;font-size:14px;font-weight:600;letter-spacing:.01em;transition:color .2s;padding:9px 18px;border-radius:24px}
.nav-links a:hover{color:var(--text);background:var(--bg2);border-radius:24px}
.nav-links a.nav-active{border-radius:24px}
.nav-badge{background:linear-gradient(135deg,var(--accent2),var(--accent));color:#fff;font-size:12px;font-weight:700;padding:7px 18px;border-radius:24px;letter-spacing:.03em;margin-left:8px}
.page-tabs{display:none}.page-tab{display:none}.page{display:none}.page.active{display:block}
main{position:relative;z-index:1;padding-top:64px}

/* ── Hero ── */
.hero{padding:70px 40px 60px;text-align:center;max-width:100%;margin:0 auto;background:linear-gradient(180deg,#eef2ff 0%,#f0f4f8 100%)}
.hero-label{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,0.85);border:1.5px solid rgba(0,102,255,0.18);color:var(--accent);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:7px 18px;border-radius:24px;margin-bottom:36px;box-shadow:0 1px 6px rgba(0,0,0,0.06)}
.hero-label::before{content:'';width:7px;height:7px;background:var(--accent);border-radius:50%;animation:pulse 1.5s ease-in-out infinite;flex-shrink:0}
h1{font-size:35px;font-weight:800;line-height:1.1;letter-spacing:normal;color:var(--text);margin-bottom:36px}
h1 span{background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:17px;color:var(--text2);font-weight:400;max-width:560px;margin:0 auto 44px;line-height:1.7}
.search-wrap{position:relative;max-width:740px;margin:0 auto 20px}
.search-box{display:flex;align-items:center;background:var(--surface);border:1.5px solid var(--border2);border-radius:10px;overflow:hidden;transition:border-color .3s,box-shadow .3s;box-shadow:0 2px 16px rgba(0,0,0,0.08)}
.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px rgba(0,102,255,0.08),0 4px 20px rgba(0,102,255,0.1)}
.search-prefix{display:none}
#url-input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:15px;font-family:'DM Mono',monospace;padding:20px 24px}
#url-input::placeholder{color:var(--text3)}
.search-btn{margin:8px;padding:14px 28px;background:var(--accent);color:#fff;font-weight:700;font-size:14px;letter-spacing:.02em;border:none;border-radius:7px;cursor:pointer;white-space:nowrap;transition:background .2s,transform .15s,box-shadow .2s}
.search-btn:hover{background:#0052d4;transform:translateY(-1px);box-shadow:0 4px 20px rgba(0,102,255,0.35)}
.search-btn:active{transform:translateY(0)}
.comp-inputs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;max-width:900px;margin:0 auto 16px}
.comp-input{background:var(--surface);border:1.5px solid var(--border2);border-radius:10px;padding:12px 16px;color:var(--text);font-family:'DM Mono',monospace;font-size:13px;outline:none;transition:border-color .3s;width:100%;box-shadow:0 1px 4px rgba(0,0,0,0.05)}
.comp-input::placeholder{color:var(--text3)}
.comp-input:focus{border-color:var(--accent)}
.hero-perks{display:flex;align-items:center;justify-content:center;gap:28px;font-size:13px;color:var(--text2);margin-top:4px;flex-wrap:wrap}
.perk{display:flex;align-items:center;gap:6px}
.perk::before{content:'✓';color:var(--accent3);font-weight:700;font-size:14px}

/* ── Feature Strip ── */
.features-strip{max-width:1200px;margin:50px auto;padding:0 48px;display:grid;grid-template-columns:repeat(auto-fit,minmax(440px,1fr));gap:16px}
.feat-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px 26px;display:flex;align-items:center;gap:18px;transition:border-color .2s,transform .2s,box-shadow .2s;box-shadow:0 1px 6px rgba(0,0,0,0.05)}
.feat-card:hover{border-color:rgba(0,102,255,0.2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,0.09)}
.feat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.feat-icon.cyan{background:rgba(0,102,255,0.08)}.feat-icon.purple{background:rgba(124,58,237,0.1)}.feat-icon.green{background:rgba(16,185,129,0.1)}.feat-icon.amber{background:rgba(245,158,11,0.1)}.feat-icon.rose{background:rgba(244,63,94,0.1)}
.feat-title{font-weight:700;font-size:15px;margin-bottom:4px;color:var(--text)}
.feat-desc{font-size:12px;color:var(--text3);line-height:1.5}

/* ── Home Content Sections ── */
.content-section{max-width:1200px;margin:0 auto;padding:64px 48px}
.content-heading{text-align:center;max-width:680px;margin:0 auto 44px}
.content-heading h2{font-size:30px;font-weight:800;letter-spacing:-0.5px;color:var(--text);margin-bottom:12px;line-height:1.25}
.content-heading p{font-size:15px;color:var(--text2);line-height:1.7}

/* How It Works */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.step-card{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:28px 24px;box-shadow:0 2px 12px rgba(0,0,0,0.04);transition:transform .2s,box-shadow .2s}
.step-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(0,0,0,0.08)}
.step-num{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;margin-bottom:18px;font-family:'Plus Jakarta Sans',sans-serif}
.step-card h3{font-size:15px;font-weight:700;margin-bottom:8px;color:var(--text)}
.step-card p{font-size:13px;color:var(--text3);line-height:1.65}

/* What Is an SEO Audit */
.audit-explain{display:grid;grid-template-columns:1.1fr 0.9fr;gap:44px;align-items:start;background:var(--surface);border:1px solid var(--border2);border-radius:20px;padding:48px;box-shadow:0 4px 20px rgba(0,0,0,0.05)}
.audit-explain-text h2{font-size:27px;font-weight:800;letter-spacing:-0.5px;color:var(--text);margin-bottom:16px;line-height:1.25}
.audit-explain-text p{font-size:14px;color:var(--text2);line-height:1.85;margin-bottom:14px}
.audit-explain-text p:last-child{margin-bottom:0}
.audit-explain-checks h3{font-size:15px;font-weight:700;color:var(--text);margin-bottom:18px}
.check-categories{display:flex;flex-direction:column;gap:12px;list-style:none;padding:0;margin:0}
.check-categories li{display:flex;gap:14px;align-items:flex-start;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px 16px}
.cc-icon{font-size:17px;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:8px}
.check-categories li strong{display:block;font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px}
.check-categories li span:last-child{font-size:12px;color:var(--text3);line-height:1.55}

/* Who Is This For */
.usecase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.usecase-card{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:26px 24px;box-shadow:0 2px 12px rgba(0,0,0,0.04);transition:border-color .2s,box-shadow .2s,transform .2s}
.usecase-card:hover{border-color:var(--accent);box-shadow:0 10px 28px rgba(0,102,255,0.08);transform:translateY(-3px)}
.usecase-icon{width:46px;height:46px;border-radius:12px;background:rgba(0,102,255,0.08);display:flex;align-items:center;justify-content:center;font-size:21px;margin-bottom:14px}
.usecase-card h3{font-size:15px;font-weight:700;margin-bottom:8px;color:var(--text)}
.usecase-card p{font-size:13px;color:var(--text3);line-height:1.6}

/* FAQ */
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--surface);border:1px solid var(--border2);border-radius:12px;overflow:hidden;transition:border-color .2s}
.faq-item[open]{border-color:rgba(0,102,255,0.25)}
.faq-item summary{padding:18px 22px;font-size:14px;font-weight:700;color:var(--text);cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:20px;font-weight:400;color:var(--accent);flex-shrink:0;transition:transform .25s;line-height:1}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-answer{padding:0 22px 18px}
.faq-answer p{font-size:13px;color:var(--text2);line-height:1.75;margin:0}

/* CTA Banner */
.cta-banner{max-width:1200px;margin:20px auto 64px;padding:56px 48px;text-align:center;background:linear-gradient(135deg,rgba(0,102,255,0.06),rgba(124,58,237,0.06));border:1px solid rgba(0,102,255,0.14);border-radius:24px}
.cta-banner h2{font-size:28px;font-weight:800;letter-spacing:-0.5px;color:var(--text);margin-bottom:10px}
.cta-banner p{font-size:15px;color:var(--text2);margin-bottom:26px}
.cta-banner .btn{font-size:14px;padding:14px 32px;display:inline-block}

/* ── Progress ── */
#progress-section{display:none;max-width:700px;margin:0 auto 40px;padding:0 40px}
.progress-card{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:32px;box-shadow:0 4px 20px rgba(0,0,0,0.06)}
.progress-title{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:18px;margin-bottom:24px;display:flex;align-items:center;gap:12px;color:var(--text)}
.spinner{width:20px;height:20px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.progress-steps{display:flex;flex-direction:column;gap:12px}
.step-row{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--text3);transition:color .3s}
.step-row.active{color:var(--text)}.step-row.done{color:var(--accent3)}
.step-icon{width:24px;height:24px;border-radius:50%;border:1.5px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;transition:all .3s}
.step-row.active .step-icon{border-color:var(--accent);background:rgba(0,102,255,0.08);color:var(--accent)}
.step-row.done .step-icon{background:rgba(5,150,105,0.1);border-color:var(--accent3)}
.progress-bar-wrap{margin-top:24px;height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px;transition:width .5s ease;width:0%}

/* ── Results ── */
#results-section{display:none;max-width:1200px;margin:0 auto;padding:0 40px 80px}
.score-header{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;gap:0;background:var(--surface);border:1px solid var(--border2);border-radius:20px;overflow:hidden;margin-bottom:28px;min-height:320px;box-shadow:0 4px 24px rgba(0,0,0,0.07)}
.score-header-left{display:flex;align-items:center;gap:32px;padding:40px 36px;border-right:1px solid var(--border);min-height:320px}
.big-score{position:relative;width:140px;height:140px;flex-shrink:0}
.score-svg{width:140px;height:140px}
.score-num{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:'Plus Jakarta Sans',sans-serif}
.score-num span:first-child{font-size:42px;font-weight:800;line-height:1}
.score-num span:last-child{font-size:10px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;margin-top:2px}
.score-info{flex:1;min-width:0}
.score-info h2{font-size:22px;font-weight:800;margin-bottom:8px;line-height:1.2;color:var(--text)}
.score-url{font-family:'DM Mono',monospace;font-size:12px;color:var(--accent);margin-bottom:16px;word-break:break-all}
.score-tags{display:flex;flex-wrap:wrap;gap:8px}
.tag{font-size:11px;font-weight:600;padding:5px 13px;border-radius:20px;letter-spacing:.04em}
.tag.pass{background:rgba(5,150,105,0.10);color:var(--accent3);border:1px solid rgba(5,150,105,0.2)}
.tag.warn{background:rgba(217,119,6,0.10);color:var(--warn);border:1px solid rgba(217,119,6,0.2)}
.tag.fail{background:rgba(220,38,38,0.10);color:var(--danger);border:1px solid rgba(220,38,38,0.2)}
.score-header-right{display:flex;flex-direction:column;background:var(--bg2);min-height:320px}
.score-preview-toolbar{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg3);border-bottom:1px solid var(--border);flex-shrink:0}
.preview-dots{display:flex;gap:5px}
.preview-dot{width:10px;height:10px;border-radius:50%}
.score-preview-addressbar{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-family:'DM Mono',monospace;font-size:10px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.score-preview-viewport{flex:1;position:relative;background:#f8f9fa;overflow:hidden}
.score-preview-iframe{width:100%;height:100%;border:none;display:none}
.score-preview-screenshot{width:100%;height:100%;object-fit:cover;object-position:top center;display:none}
.score-preview-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:var(--bg2);color:var(--text3);font-size:12px}
.score-preview-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:var(--bg2);color:var(--text3);font-size:12px;padding:20px;text-align:center}
.score-preview-statusbar{display:flex;align-items:center;justify-content:space-between;padding:7px 14px;border-top:1px solid var(--border);font-size:10px;color:var(--text3);flex-shrink:0;background:var(--bg2)}
.preview-status-ok{color:var(--accent3)}.preview-status-warn{color:var(--warn)}

/* ── Buttons ── */
.btn{padding:12px 24px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;font-family:'Plus Jakarta Sans',sans-serif;letter-spacing:.03em;text-align:center;border:none;white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--accent),#004fcc);color:#fff}
.btn-primary:hover{box-shadow:0 4px 20px rgba(0,102,255,0.35);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--text2);border:1px solid var(--border2)}
.btn-outline:hover{border-color:var(--text2);color:var(--text)}

/* ── Result Sections ── */
.result-section{display:block;margin-bottom:48px}
.section-heading{display:flex;align-items:center;gap:16px;padding:26px 30px;background:var(--surface);border:1px solid var(--border2);border-radius:16px;margin-bottom:24px;box-shadow:0 2px 12px rgba(0,0,0,0.05)}
.section-heading-icon{font-size:28px;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(0,102,255,0.08),rgba(124,58,237,0.08));border:1px solid rgba(0,102,255,0.12);border-radius:14px;flex-shrink:0}
.section-heading-title{font-size:22px;font-weight:800;color:var(--text);margin-bottom:4px;letter-spacing:-0.3px}
.section-heading-sub{font-size:13px;color:var(--text3);line-height:1.5;font-weight:400}
.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;margin-bottom:28px}
.cat-card{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:24px;transition:border-color .2s,box-shadow .2s;box-shadow:0 1px 8px rgba(0,0,0,0.04)}
.cat-card:hover{border-color:var(--accent);box-shadow:0 4px 16px rgba(0,102,255,0.08)}
.cat-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.cat-title-wrap{display:flex;align-items:center;gap:10px}
.cat-icon{font-size:20px}
.cat-title{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:15px}
.cat-score-badge{font-family:'DM Mono',monospace;font-size:13px;font-weight:500;padding:4px 12px;border-radius:8px}
.cat-score-badge.good{background:rgba(5,150,105,0.10);color:var(--accent3)}
.cat-score-badge.med{background:rgba(217,119,6,0.10);color:var(--warn)}
.cat-score-badge.bad{background:rgba(220,38,38,0.10);color:var(--danger)}
.mini-bar-wrap{height:3px;background:var(--bg3);border-radius:2px;margin-bottom:16px;overflow:hidden}
.mini-bar{height:100%;border-radius:2px;transition:width 1s ease}
.check-list{display:flex;flex-direction:column;gap:8px}
.check-item{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:8px;background:var(--bg2);border:1px solid var(--border);cursor:pointer;transition:all .2s;font-size:12px}
.check-item:hover{border-color:var(--border2);background:var(--bg3)}
.check-status{flex-shrink:0;margin-top:1px;font-size:14px;line-height:1}
.check-content{flex:1}
.check-name{font-weight:500;margin-bottom:2px;color:var(--text)}
.check-detail{color:var(--text3);font-size:11px}
.issues-panel{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:28px;margin-bottom:28px;box-shadow:0 2px 12px rgba(0,0,0,0.05)}
.panel-title{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:17px;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.issue-count{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:rgba(239,68,68,0.15);color:var(--danger);border-radius:6px;font-size:11px;font-weight:700}
.tabs{display:flex;gap:4px;background:var(--bg2);border-radius:10px;padding:4px;margin-bottom:20px;width:fit-content;border:1px solid var(--border)}
.tab{padding:8px 18px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;color:var(--text3);border:none;background:transparent;font-family:'Plus Jakarta Sans',sans-serif}
.tab.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 6px rgba(0,0,0,0.1)}
.issue-row{display:grid;grid-template-columns:24px 1fr auto;gap:14px;align-items:start;padding:14px 0;border-bottom:1px solid var(--border)}
.issue-row:last-child{border-bottom:none}
.sev-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
.sev-dot.critical{background:var(--danger);box-shadow:0 0 6px rgba(220,38,38,0.4)}
.sev-dot.warning{background:var(--warn)}
.sev-dot.info{background:var(--accent)}
.issue-title{font-weight:600;font-size:13px;margin-bottom:4px}
.issue-desc{color:var(--text3);font-size:12px;line-height:1.5}
.issue-badge{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 10px;border-radius:5px;white-space:nowrap}
.issue-badge.critical{background:rgba(220,38,38,0.10);color:var(--danger)}
.issue-badge.warning{background:rgba(217,119,6,0.10);color:var(--warn)}
.issue-badge.info{background:rgba(0,102,255,0.08);color:var(--accent)}
.ai-panel{background:linear-gradient(135deg,rgba(124,58,237,0.05),rgba(0,102,255,0.04));border:1px solid rgba(124,58,237,0.18);border-radius:16px;padding:28px;margin-bottom:28px;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.ai-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.ai-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--accent2),var(--accent));color:#fff;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 12px;border-radius:20px}
.ai-title{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:17px}
.ai-insight{background:rgba(0,0,0,0.02);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:12px;font-size:13px;line-height:1.7;color:var(--text2)}
.ai-insight strong{color:var(--text)}
.ai-insight:last-child{margin-bottom:0}
.ai-loading{display:flex;align-items:center;gap:10px;color:var(--text3);font-size:13px;padding:16px 0}
.metrics-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(125px,1fr));gap:14px;margin-bottom:28px}
.metric-card{background:var(--surface);border:1px solid var(--border2);border-radius:12px;padding:18px 16px;box-shadow:0 1px 6px rgba(0,0,0,0.04)}
.metric-label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:8px;font-weight:600}
.metric-val{font-family:'DM Mono',monospace;font-size:20px;font-weight:500;line-height:1;margin-bottom:4px}
.metric-sub{font-size:11px;color:var(--text3)}
.metric-good{color:var(--accent3)}.metric-warn{color:var(--warn)}.metric-bad{color:var(--danger)}
.radar-panel{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:28px;margin-bottom:28px;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.radar-panel h3{font-weight:700;font-size:16px;margin-bottom:20px}
.rec-list{display:flex;flex-direction:column;gap:14px}
.rec-item{display:flex;gap:16px;align-items:flex-start;padding:16px;background:var(--bg2);border:1px solid var(--border2);border-radius:12px;transition:border-color .2s,box-shadow .2s}
.rec-item:hover{border-color:var(--accent);box-shadow:0 2px 10px rgba(0,102,255,0.08)}
.rec-priority{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.rec-priority.p1{background:rgba(220,38,38,0.10);color:var(--danger)}
.rec-priority.p2{background:rgba(217,119,6,0.10);color:var(--warn)}
.rec-priority.p3{background:rgba(0,102,255,0.08);color:var(--accent)}
.rec-body h4{font-size:13px;font-weight:600;margin-bottom:4px}
.rec-body p{font-size:12px;color:var(--text3);line-height:1.5}
.serp-section{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:28px;margin-bottom:28px;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.serp-section h3{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:16px;margin-bottom:20px}
.serp-device-tabs{display:flex;gap:8px;margin-bottom:20px}
.serp-device-btn{padding:6px 16px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border2);background:transparent;color:var(--text3);transition:all .2s}
.serp-device-btn.active{background:var(--surface2);color:var(--text);border-color:var(--border2)}
.serp-preview{background:#fff;border-radius:12px;padding:20px 24px;max-width:600px}
.serp-url-bar{font-size:12px;color:#006621;margin-bottom:2px;font-family:'Plus Jakarta Sans',sans-serif}
.serp-title-preview{font-size:18px;color:#1558d6;font-family:'Plus Jakarta Sans',sans-serif;font-weight:400;margin-bottom:4px;line-height:1.3;cursor:pointer}
.serp-title-preview:hover{text-decoration:underline}
.serp-desc-preview{font-size:13px;color:#3c4043;font-family:'Plus Jakarta Sans',sans-serif;line-height:1.5}
.serp-mobile-preview{background:#fff;border-radius:12px;padding:16px;max-width:380px}
.serp-mobile-source{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.serp-mobile-favicon{width:18px;height:18px;background:var(--surface);border-radius:50%;flex-shrink:0}
.serp-mobile-domain{font-size:13px;color:#3c4043;font-family:'Plus Jakarta Sans',sans-serif}
.serp-mobile-title{font-size:17px;color:#1558d6;font-family:'Plus Jakarta Sans',sans-serif;font-weight:400;line-height:1.3;margin-bottom:6px}
.serp-mobile-desc{font-size:13px;color:#3c4043;font-family:'Plus Jakarta Sans',sans-serif;line-height:1.4}
.char-counter{font-size:11px;margin-top:8px}
.char-counter span{font-family:'DM Mono',monospace;font-weight:600}
.char-ok{color:var(--accent3)}.char-warn{color:var(--warn)}.char-bad{color:var(--danger)}
.serp-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.serp-field label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:6px}
.serp-field textarea,.serp-field input{width:100%;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-size:13px;padding:10px 12px;outline:none;transition:border-color .2s;font-family:'Plus Jakarta Sans',sans-serif;resize:none}
.serp-field textarea:focus,.serp-field input:focus{border-color:var(--accent)}
.social-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}
.social-card{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:24px;box-shadow:0 2px 10px rgba(0,0,0,0.04)}
.social-card h4{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:14px;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.fb-card{border:1px solid #dddfe2;border-radius:4px;overflow:hidden;background:#fff;max-width:500px}
.fb-img{height:260px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-family:'Plus Jakarta Sans',sans-serif;opacity:.6}
.fb-meta{padding:12px;background:#f2f3f5}
.fb-domain{font-size:11px;color:#606770;text-transform:uppercase;font-family:'Plus Jakarta Sans',sans-serif;margin-bottom:4px}
.fb-title{font-size:14px;font-weight:700;color:#1c1e21;font-family:'Plus Jakarta Sans',sans-serif;line-height:1.3;margin-bottom:2px}
.fb-desc{font-size:12px;color:#606770;font-family:'Plus Jakarta Sans',sans-serif;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.tw-card{border:1px solid #cfd9de;border-radius:16px;overflow:hidden;background:#fff;max-width:500px}
.tw-img{height:250px;background:linear-gradient(135deg,#00c6ff,#0072ff);display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-family:'Plus Jakarta Sans',sans-serif;opacity:.7}
.tw-meta{padding:12px}
.tw-domain{font-size:13px;color:#536471;font-family:'Plus Jakarta Sans',sans-serif;margin-bottom:4px}
.tw-title{font-size:15px;font-weight:700;color:#0f1419;font-family:'Plus Jakarta Sans',sans-serif;line-height:1.3;margin-bottom:4px}
.tw-desc{font-size:13px;color:#536471;font-family:'Plus Jakarta Sans',sans-serif;line-height:1.4}
.keyword-section{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:28px;margin-bottom:28px;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.keyword-section h3{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:16px;margin-bottom:20px}
.kw-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.kw-table{width:100%;border-collapse:collapse}
.kw-table th{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-weight:600;padding:0 0 12px;text-align:left}
.kw-table td{font-size:13px;padding:10px 0;border-top:1px solid var(--border)}
.kw-density-bar{height:4px;background:var(--bg3);border-radius:2px;margin-top:4px;overflow:hidden}
.kw-density-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px}
.kw-tag{display:inline-block;background:rgba(0,102,255,0.07);color:var(--accent);border:1px solid rgba(0,102,255,0.15);font-size:11px;padding:3px 10px;border-radius:20px;margin:3px}
.kw-cloud{line-height:2;padding:12px 0}
.comp-section{padding:40px}
.comp-section h2{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:32px;letter-spacing:-1px;margin-bottom:8px}
.comp-section .sub{color:var(--text2);font-size:15px;font-weight:300;margin-bottom:40px}
.comp-table-wrap{overflow-x:auto;margin-bottom:28px}
.comp-table{width:100%;border-collapse:collapse;min-width:600px}
.comp-table th{background:var(--bg2);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-weight:600;padding:14px 20px;text-align:left;border-bottom:1px solid var(--border2)}
.comp-table td{padding:14px 20px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
.comp-table tr:hover td{background:rgba(0,0,0,0.02)}
.comp-score{font-family:'DM Mono',monospace;font-weight:600;font-size:15px}
.win-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px;margin-left:6px;letter-spacing:.05em;text-transform:uppercase}
.win-badge.win{background:rgba(5,150,105,0.10);color:var(--accent3)}.win-badge.lose{background:rgba(220,38,38,0.10);color:var(--danger)}
.comp-chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}
.comp-chart-card{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:24px;box-shadow:0 2px 10px rgba(0,0,0,0.04)}
.comp-chart-card h4{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:15px;margin-bottom:20px}
.comp-domains-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:22px;margin-bottom:28px}
.comp-domains-grid>div{min-width:0}
.history-section{padding:40px}
.history-section h2{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:32px;letter-spacing:-1px;margin-bottom:8px}
.history-section .sub{color:var(--text2);font-size:15px;font-weight:300;margin-bottom:32px}
.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.history-card{background:var(--surface);border:1px solid var(--border2);border-radius:14px;padding:20px;transition:border-color .2s,transform .2s,box-shadow .2s;cursor:pointer}
.history-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,102,255,0.1)}
.history-url{font-family:'DM Mono',monospace;font-size:12px;color:var(--accent);margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.history-score-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.history-score{font-family:'Plus Jakarta Sans',sans-serif;font-size:28px;font-weight:800}
.history-date{font-size:11px;color:var(--text3)}
.history-bar{height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.history-bar-fill{height:100%;border-radius:2px}
.empty-history{text-align:center;padding:60px 20px;color:var(--text3);font-size:14px}
.empty-history .empty-icon{font-size:48px;margin-bottom:16px;opacity:.4}

/* ── PDF Button ── */
.pdf-btn-wrap{margin-top:24px;display:flex;flex-direction:column;gap:10px}
.pdf-download-btn{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#7c3aed 0%,#4f46e5 60%,#0066ff 100%);color:#fff;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:15px;padding:16px 28px;border-radius:50px;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s,opacity .2s;box-shadow:0 6px 24px rgba(79,70,229,0.42);letter-spacing:.01em;position:relative;overflow:hidden}
.pdf-download-btn::before{content:'';position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,0.15) 0%,transparent 60%);border-radius:inherit}
.pdf-download-btn:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(79,70,229,0.55)}
.pdf-download-btn:active{transform:translateY(0)}
.pdf-download-btn:disabled{opacity:0.6;cursor:not-allowed;transform:none;box-shadow:none}
.pdf-download-btn svg{flex-shrink:0}
.pdf-report-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text3);padding-left:4px}
.pdf-report-meta span{display:inline-flex;align-items:center;gap:4px}
.pdf-report-meta span::before{content:'';display:inline-block;width:3px;height:3px;background:var(--text3);border-radius:50%}
.pdf-report-meta span:first-child::before{display:none}

/* ── PDF Progress Overlay ── */
#pdf-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,0.55);backdrop-filter:blur(6px);z-index:9999;align-items:center;justify-content:center}
#pdf-overlay.visible{display:flex}
.pdf-overlay-card{background:var(--surface);border-radius:20px;padding:40px 48px;text-align:center;box-shadow:0 24px 60px rgba(0,0,0,0.18);min-width:320px}
.pdf-overlay-icon{font-size:48px;margin-bottom:16px}
.pdf-overlay-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:6px}
.pdf-overlay-sub{font-size:13px;color:var(--text3);margin-bottom:24px}
.pdf-overlay-bar-wrap{height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}
.pdf-overlay-bar{height:100%;background:linear-gradient(90deg,#7c3aed,#4f46e5);border-radius:3px;transition:width .4s ease;width:0%}

/* ── Animations ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeUp .5s ease forwards}
#error-msg{display:none;background:rgba(220,38,38,0.08);border:1px solid rgba(220,38,38,0.2);border-radius:10px;padding:14px 18px;font-size:13px;color:var(--danger);max-width:700px;margin:0 auto 16px;text-align:left}
#error-msg.checking{background:rgba(0,102,255,0.08);border:1px solid rgba(0,102,255,0.2);color:var(--accent)}

/* ── Footer ── */
footer{position:relative;z-index:1;border-top:1px solid var(--border2);background:var(--surface)}
.footer-inner{max-width:1200px;margin:0 auto;padding:32px 40px;display:flex;align-items:center;justify-content:space-between;color:var(--text3);font-size:12px}
footer a{color:var(--text3);text-decoration:none}
footer a:hover{color:var(--accent)}
.footer-links{display:flex;gap:24px;flex-wrap:wrap}

/* ─────────────────────────────────────────────
   POLICY & INFO PAGES
   ───────────────────────────────────────────── */

/* Policy Hero */
.policy-hero {
  padding: 72px 40px 56px;
  text-align: center;
  background: linear-gradient(180deg, #eef2ff 0%, #f0f4f8 100%);
}
.policy-hero .hero-label { margin-bottom: 28px; }
.policy-hero h1 { font-size: 40px; margin-bottom: 16px; }
.policy-hero .policy-meta {
  font-size: 13px;
  color: var(--text3);
  margin-top: 16px;
}

/* Policy Content Wrapper */
.policy-wrap {
  max-width: 860px;
  margin: 0 auto;
  padding: 60px 40px 80px;
  position: relative;
  z-index: 1;
}

/* Policy Article */
.policy-article h2 {
  font-size: 19px;
  font-weight: 700;
  color: var(--text);
  margin: 40px 0 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border2);
  display: flex;
  align-items: center;
  gap: 10px;
}
.policy-article h2:first-child { margin-top: 0; }
.policy-article h3 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin: 24px 0 10px;
}
.policy-article p {
  font-size: 14px;
  color: var(--text2);
  line-height: 1.85;
  margin-bottom: 14px;
}
.policy-article ul, .policy-article ol {
  padding-left: 22px;
  margin-bottom: 14px;
}
.policy-article li {
  font-size: 14px;
  color: var(--text2);
  line-height: 1.8;
  margin-bottom: 6px;
}
.policy-article a { color: var(--accent); text-decoration: none; }
.policy-article a:hover { text-decoration: underline; }

/* Info Card (callout box) */
.info-card {
  background: rgba(0,102,255,0.04);
  border: 1px solid rgba(0,102,255,0.14);
  border-radius: 12px;
  padding: 18px 22px;
  margin: 20px 0;
  font-size: 13px;
  color: var(--text2);
  line-height: 1.7;
}
.info-card strong { color: var(--text); }

/* Cookie table */
.cookie-table {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0 24px;
  font-size: 13px;
}
.cookie-table th {
  background: var(--bg2);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text3);
  font-weight: 700;
  padding: 12px 16px;
  text-align: left;
  border-bottom: 2px solid var(--border2);
}
.cookie-table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  color: var(--text2);
  vertical-align: top;
}
.cookie-table tr:last-child td { border-bottom: none; }
.cookie-table tr:hover td { background: var(--bg2); }

/* About page */
.about-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 40px 0;
}
.about-stat {
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 16px;
  padding: 28px 24px;
  text-align: center;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}
.about-stat-num {
  font-size: 36px;
  font-weight: 800;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin-bottom: 8px;
}
.about-stat-label {
  font-size: 13px;
  color: var(--text3);
  font-weight: 500;
}
.about-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 24px 0;
}
.about-feature {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 20px 22px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
  transition: border-color .2s, box-shadow .2s;
}
.about-feature:hover { border-color: rgba(0,102,255,.2); box-shadow: 0 4px 16px rgba(0,102,255,.07); }
.about-feature-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: rgba(0,102,255,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.about-feature h4 { font-size: 14px; font-weight: 700; margin-bottom: 4px; color: var(--text); }
.about-feature p { font-size: 12px; color: var(--text3); line-height: 1.5; margin: 0; }

/* Contact Page */
.contact-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 60px 40px 80px;
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 48px;
  align-items: start;
}
.contact-info h2 {
  font-size: 22px;
  font-weight: 800;
  margin-bottom: 12px;
  color: var(--text);
}
.contact-info p {
  font-size: 14px;
  color: var(--text2);
  line-height: 1.8;
  margin-bottom: 28px;
}
.contact-method {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 18px;
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 12px;
  margin-bottom: 14px;
  transition: border-color .2s;
}
.contact-method:hover { border-color: rgba(0,102,255,.2); }
.contact-method-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: rgba(0,102,255,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  flex-shrink: 0;
}
.contact-method-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text3);
  margin-bottom: 3px;
}
.contact-method-value {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}
.contact-form-card {
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 20px;
  padding: 36px 40px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.07);
}
.contact-form-card h3 {
  font-size: 20px;
  font-weight: 800;
  margin-bottom: 24px;
  color: var(--text);
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
.form-group {
  margin-bottom: 16px;
}
.form-group label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text3);
  margin-bottom: 7px;
}
.form-group input,
.form-group textarea,
.form-group select {
  width: 100%;
  background: var(--bg2);
  border: 1.5px solid var(--border2);
  border-radius: 9px;
  padding: 12px 14px;
  font-size: 14px;
  color: var(--text);
  font-family: 'Plus Jakarta Sans', sans-serif;
  outline: none;
  transition: border-color .25s, box-shadow .25s;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(0,102,255,.08);
}
.form-group textarea { resize: vertical; min-height: 130px; }
.form-submit {
  width: 100%;
  padding: 15px 24px;
  background: linear-gradient(135deg, var(--accent), #004fcc);
  color: #fff;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  font-size: 15px;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: transform .2s, box-shadow .2s;
  letter-spacing: .02em;
  margin-top: 6px;
}
.form-submit:hover { transform: translateY(-1px); box-shadow: 0 6px 24px rgba(0,102,255,.35); }
.form-submit:active { transform: translateY(0); }
.form-success {
  display: none;
  text-align: center;
  padding: 32px 0;
}
.form-success-icon { font-size: 48px; margin-bottom: 16px; }
.form-success h4 { font-size: 18px; font-weight: 700; margin-bottom: 8px; color: var(--text); }
.form-success p { font-size: 13px; color: var(--text3); }

/* ── Responsive ── */
@media(max-width:900px){
  .nav-inner{padding:0 20px}.nav-links{display:none}
  .hero{padding:60px 20px 40px}
  h1{font-size:36px;letter-spacing:-0.5px}
  .features-strip,#results-section,.comp-section,.history-section{padding:0 20px 40px}
  .score-header{grid-template-columns:1fr}
  .score-header-left{border-right:none;border-bottom:1px solid var(--border);padding:28px 24px}
  .score-header-right{min-height:280px}
  .radar-panel,.social-grid,.kw-grid,.comp-chart-grid,.serp-edit-grid{grid-template-columns:1fr}
  .categories-grid{grid-template-columns:1fr}
  .comp-inputs{grid-template-columns:1fr}
  .footer-inner{padding:24px 20px;flex-direction:column;gap:16px;text-align:center}
  .policy-hero h1{font-size:28px}
  .policy-wrap{padding:40px 20px 60px}
  .about-stats{grid-template-columns:1fr 1fr}
  .about-features{grid-template-columns:1fr}
  .contact-wrap{grid-template-columns:1fr;padding:40px 20px 60px;gap:32px}
  .form-row{grid-template-columns:1fr}
  .contact-form-card{padding:24px 20px}
  .content-section{padding:44px 20px}
  .content-heading h2{font-size:24px}
  .steps-grid,.usecase-grid{grid-template-columns:1fr 1fr}
  .audit-explain{grid-template-columns:1fr;padding:28px 24px;gap:32px}
  .audit-explain-text h2{font-size:22px}
  .cta-banner{padding:40px 24px;border-radius:18px;margin:0 20px 48px}
  .cta-banner h2{font-size:22px}
}
@media(max-width:540px){
  .about-stats{grid-template-columns:1fr}
  .steps-grid,.usecase-grid{grid-template-columns:1fr}
}

/* ── Cookie Consent Banner ── */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:1000;background:var(--surface);border:1px solid var(--border2);border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,0.18);padding:18px 22px;display:none;align-items:center;gap:20px;flex-wrap:wrap;max-width:760px;margin:0 auto}
.cookie-banner.show{display:flex}
.cookie-banner p{font-size:12px;color:var(--text2);line-height:1.6;flex:1;min-width:220px;margin:0}
.cookie-banner p a{color:var(--accent)}
.cookie-banner-actions{display:flex;gap:10px;flex-shrink:0}
.cookie-banner-actions button{font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:700;padding:10px 18px;border-radius:8px;cursor:pointer;white-space:nowrap;transition:transform .15s,box-shadow .15s}
.cookie-banner-actions button:hover{transform:translateY(-1px)}
.cookie-btn-accept{background:var(--accent);color:#fff;border:none}
.cookie-btn-accept:hover{box-shadow:0 4px 16px rgba(0,102,255,0.3)}
.cookie-btn-reject{background:transparent;color:var(--text2);border:1px solid var(--border2)}
@media(max-width:540px){
  .cookie-banner{padding:16px;gap:12px}
  .cookie-banner-actions{width:100%}
  .cookie-banner-actions button{flex:1}
}
/* ── Hamburger Menu & Mobile Nav ── */
.hamburger{display:none;flex-direction:column;justify-content:space-between;width:28px;height:20px;background:transparent;border:none;cursor:pointer;padding:0;margin-left:12px;flex-shrink:0}
.hamburger span{display:block;height:2px;width:100%;background:var(--text);border-radius:2px;transition:all .3s ease}
.hamburger.open span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}
.mobile-nav{position:fixed;top:64px;right:-280px;width:260px;height:calc(100vh - 64px);background:var(--surface);z-index:200;box-shadow:-4px 0 24px rgba(0,0,0,0.12);transition:right .3s ease;overflow-y:auto;padding:20px 0}
.mobile-nav.open{right:0}
.mobile-nav ul{list-style:none;padding:0;margin:0}
.mobile-nav ul li a{display:block;padding:14px 24px;color:var(--text);text-decoration:none;font-weight:600;font-size:15px;border-bottom:1px solid var(--border);transition:background .15s,color .15s}
.mobile-nav ul li a:hover{background:var(--bg2);color:var(--accent)}
.mobile-nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,0.4);z-index:199;display:none;top:64px}
.mobile-nav-overlay.open{display:block}
@media(max-width:900px){
  .hamburger{display:flex}
  .nav-links{display:none!important}
  .search-box{flex-direction:column;border-radius:12px}
  #url-input{padding:16px 18px;width:100%;font-size:14px;border-bottom:1px solid var(--border2)}
  .search-btn{margin:0 8px 8px!important;width:calc(100% - 16px);padding:14px;border-radius:7px}
  .hero-perks{gap:12px;font-size:12px}
  h1{font-size:28px!important}
  .page-tabs{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .page-tab{min-width:fit-content;padding:10px 16px!important;font-size:13px!important}
  .issues-panel .tabs{overflow-x:auto;white-space:nowrap}
  .score-preview-viewport{min-height:220px}
  .result-section{padding:24px 16px}
  .section-heading{flex-direction:column;gap:10px}
  .metrics-strip{grid-template-columns:repeat(2,1fr)!important}
  .pdf-btn-wrap{flex-direction:column;gap:8px}
  .pdf-report-meta{font-size:10px}
}
@media(max-width:480px){
  .metrics-strip{grid-template-columns:1fr 1fr!important}
  .hero{padding:50px 16px 36px!important}
  h1{font-size:24px!important}
  .hero-label{font-size:10px;padding:6px 14px}
}

/* ── Core Web Vitals: reduce layout shift ── */
img{height:auto;max-width:100%}
.logo img{width:24px;height:24px}
canvas{max-width:100%}
iframe{border:0}

/* ── Core Web Vitals & Mobile improvements ── */
img{height:auto;max-width:100%}
.logo img{display:inline-block;width:24px;height:24px;flex-shrink:0}
canvas{max-width:100%}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
.content-section,.faq-list{content-visibility:auto;contain-intrinsic-size:0 400px}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ── Hamburger & Mobile Nav ── */
.hamburger{display:none;flex-direction:column;justify-content:space-between;width:28px;height:20px;background:transparent;border:none;cursor:pointer;padding:0;margin-left:12px;flex-shrink:0}
.hamburger span{display:block;height:2px;width:100%;background:var(--text);border-radius:2px;transition:all .3s ease}
.hamburger.open span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}
.mobile-nav{position:fixed;top:64px;right:-280px;width:260px;height:calc(100vh - 64px);background:var(--surface);z-index:200;box-shadow:-4px 0 24px rgba(0,0,0,.12);transition:right .3s ease;overflow-y:auto;padding:20px 0}
.mobile-nav.open{right:0}
.mobile-nav ul{list-style:none;padding:0;margin:0}
.mobile-nav ul li a{display:block;padding:14px 24px;color:var(--text);text-decoration:none;font-weight:600;font-size:15px;border-bottom:1px solid var(--border);transition:background .15s,color .15s}
.mobile-nav ul li a:hover{background:var(--bg2);color:var(--accent)}
.mobile-nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.4);z-index:199;display:none;top:64px}
.mobile-nav-overlay.open{display:block}

/* ── Mobile breakpoints ── */
@media(max-width:900px){
  .hamburger{display:flex}
  .nav-links{display:none!important}
  .nav-inner{padding:0 16px}
  .hero{padding:52px 18px 40px!important}
  h1{font-size:26px!important}
  .search-box{flex-direction:column;border-radius:12px}
  #url-input{width:100%;padding:16px 18px;border-bottom:1px solid var(--border2)}
  .search-btn{width:calc(100% - 16px);margin:0 8px 8px!important;padding:14px}
  .hero-perks{gap:10px;font-size:12px}
  .page-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .page-tabs::-webkit-scrollbar{display:none}
  .result-section{padding:20px 16px!important}
  .score-header{grid-template-columns:1fr!important}
  .score-header-left{border-right:none!important;border-bottom:1px solid var(--border)}
  .score-header-right{min-height:220px!important}
  .radar-panel,.kw-grid,.serp-edit-grid,.social-grid,.comp-chart-grid{grid-template-columns:1fr!important}
  .categories-grid{grid-template-columns:1fr!important}
  .metrics-strip{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}
  .features-strip{padding:0 16px!important;grid-template-columns:1fr!important}
  .footer-inner{flex-direction:column;gap:14px;text-align:center;padding:20px 16px!important}
  .footer-links{justify-content:center;flex-wrap:wrap;gap:10px}
  .comp-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .content-section{padding:40px 18px}
  .steps-grid,.usecase-grid{grid-template-columns:1fr 1fr}
  .cta-banner{margin:0 16px 40px;padding:32px 20px}
}
@media(max-width:480px){
  h1{font-size:22px!important}
  .hero-label{font-size:10px;padding:5px 12px}
  .nav-inner{padding:0 12px}
  .metrics-strip{grid-template-columns:1fr 1fr!important}
  .steps-grid,.usecase-grid{grid-template-columns:1fr}
}
@media(max-width:480px){.pdf-download-btn{width:100%;justify-content:center;font-size:13px;padding:14px 18px}.pdf-report-meta{flex-wrap:wrap}.score-tags{justify-content:flex-start}}
.cookie-banner-actions{flex-wrap:wrap}
.cookie-btn-customize{background:transparent;color:var(--accent);border:1px solid rgba(0,102,255,0.3);font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:700;padding:10px 16px;border-radius:8px;cursor:pointer;white-space:nowrap;transition:background .15s,transform .15s}
.cookie-btn-customize:hover{background:rgba(0,102,255,0.06);transform:translateY(-1px)}
#cookie-prefs-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,0.55);backdrop-filter:blur(6px);z-index:1100;align-items:center;justify-content:center;padding:20px}
#cookie-prefs-overlay.show{display:flex}
.cookie-prefs-modal{background:var(--surface);border-radius:20px;max-width:520px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 24px 60px rgba(0,0,0,0.2);padding:32px}
.cookie-prefs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.cookie-prefs-header h3{font-size:19px;font-weight:800;color:var(--text)}
.cookie-prefs-close{background:transparent;border:none;cursor:pointer;color:var(--text3);font-size:22px;line-height:1;padding:4px;border-radius:6px}
.cookie-prefs-close:hover{color:var(--text);background:var(--bg2)}
.cookie-prefs-sub{font-size:13px;color:var(--text3);line-height:1.6;margin-bottom:24px}
.cookie-pref-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px 0;border-top:1px solid var(--border)}
.cookie-pref-row:first-of-type{border-top:none}
.cookie-pref-info strong{display:block;font-size:14px;font-weight:700;color:var(--text);margin-bottom:4px}
.cookie-pref-info p{font-size:12px;color:var(--text3);line-height:1.6;margin:0}
.cookie-toggle{position:relative;width:44px;height:26px;flex-shrink:0;margin-top:2px}
.cookie-toggle input{opacity:0;width:0;height:0;position:absolute}
.cookie-toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border2);border-radius:26px;cursor:pointer;transition:background .2s}
.cookie-toggle-slider::before{content:'';position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,0.25);color:transparent}
.cookie-toggle input:checked+.cookie-toggle-slider{background:var(--accent)}
.cookie-toggle input:checked+.cookie-toggle-slider::before{transform:translateX(18px)}
.cookie-toggle input:disabled+.cookie-toggle-slider{opacity:.6;cursor:not-allowed}
.cookie-prefs-footer{display:flex;gap:10px;margin-top:28px;flex-wrap:wrap}
.cookie-prefs-footer button{flex:1;min-width:140px;font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;padding:12px 18px;border-radius:9px;cursor:pointer;transition:transform .15s,box-shadow .15s}
.cookie-prefs-footer button:hover{transform:translateY(-1px)}
.cookie-prefs-save{background:var(--accent);color:#fff;border:none;box-shadow:0 4px 16px rgba(0,102,255,0.3)}
.cookie-prefs-reject{background:transparent;color:var(--text2);border:1px solid var(--border2)}
@media(max-width:480px){.cookie-prefs-modal{padding:24px 20px}.cookie-prefs-footer{flex-direction:column}.cookie-prefs-footer button{width:100%}}

.progress-tip-card{max-width:700px;margin:16px auto 0;background:linear-gradient(135deg,rgba(0,102,255,0.05),rgba(124,58,237,0.04));border:1px solid rgba(0,102,255,0.14);border-radius:14px;padding:18px 22px;display:flex;flex-direction:column;gap:6px;transition:opacity .3s ease}
.progress-tip-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.progress-tip-text{font-size:13px;color:var(--text2);line-height:1.6}
@media(max-width:900px){.progress-tip-card{margin:14px 16px 0;padding:16px 18px}}
