/* ══════════════════════════════════════════════════
   EAAPass — Zero-scroll interactive experience
   ══════════════════════════════════════════════════ */

/* Fonts loaded in HTML head — no duplicate @import */

:root {
  --bg: #06060b;
  --bg2: #0c0c14;
  --bg3: #13131f;
  --border: #1e1e2e;
  --border2: #2a2a3f;
  --text: #f0f0f5;
  --text2: #9494a8;
  --text3: #8888a0;
  --accent: #635bff;
  --accent2: #7b73ff;
  --accent-g: rgba(99,91,255,.12);
  --green: #3ecf8e;
  --red: #ff5555;
  --amber: #f7b955;
  --cyan: #5ce1e6;
  --font: 'Inter',sans-serif;
  --mono: 'JetBrains Mono',monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}

/* A11Y */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:.75rem 1.25rem;z-index:9999;font-weight:600;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

h1,h2,h3{font-weight:800;letter-spacing:-.03em;line-height:1.1}
a{color:var(--accent2);text-decoration:underline;text-underline-offset:3px}
a:hover{color:#fff}

/* ════════════ HEADER ════════════ */
header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:rgba(6,6,11,.7);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
header nav{max-width:1100px;margin:0 auto;padding:.6rem 1.5rem;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:.4rem;text-decoration:none;color:var(--text);font-weight:900;font-size:1rem;letter-spacing:-.02em}
.logo:hover{color:#fff}
.logo-mark{width:24px;height:24px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:900;color:#fff}
.logo-mark::after{content:'E'}
.nav-right{display:flex;align-items:center;gap:1.25rem}
header ul{list-style:none;display:flex;gap:1.25rem}
header li a{color:var(--text2);text-decoration:none;font-size:.8125rem;font-weight:500}
header li a:hover{color:#fff}
header select{background:var(--bg2);color:var(--text2);border:1px solid var(--border);padding:.25rem .4rem;border-radius:5px;font-size:.75rem;cursor:pointer}

/* ════════════ APP / SCREENS ════════════ */
.app{position:fixed;inset:0;top:50px}

.s{
  position:absolute;inset:0;
  display:block;
  opacity:0;pointer-events:none;
  overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
}
.s.active{opacity:1;pointer-events:auto}
.s-inner{
  max-width:900px;width:100%;margin:0 auto;text-align:center;position:relative;z-index:2;
  min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:2rem 1.5rem;
}

/* ════════════ NAV DOTS ════════════ */
.nav-dots{
  position:fixed;right:1.5rem;top:50%;transform:translateY(-50%);z-index:300;
  display:flex;flex-direction:column;gap:.6rem;
}
.dot{
  width:10px;height:10px;border-radius:50%;border:1.5px solid var(--border2);
  background:transparent;cursor:pointer;transition:all .25s;padding:0;
}
.dot:hover{border-color:var(--accent)}
.dot.active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 12px var(--accent-g)}

/* ════════════ SCREEN 0: BOOT ════════════ */
.grid-bg{
  position:absolute;inset:0;z-index:0;
  background-image:
    linear-gradient(rgba(30,30,46,.4) 1px,transparent 1px),
    linear-gradient(90deg,rgba(30,30,46,.4) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at 50% 50%,black 20%,transparent 65%);
}

.boot-logo{position:relative;width:140px;height:140px;margin:0 auto 2rem}
.ring{position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--accent);opacity:.2}
.ring-1{animation:ring-spin 8s linear infinite}
.ring-2{inset:15px;border-color:var(--green);opacity:.15;animation:ring-spin 12s linear infinite reverse}
.ring-3{inset:30px;border-color:var(--cyan);opacity:.1;animation:ring-spin 6s linear infinite}
@keyframes ring-spin{to{transform:rotate(360deg)}}

.boot-mark{
  position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  width:60px;height:60px;background:var(--accent);border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;font-weight:900;color:#fff;
  box-shadow:0 0 40px var(--accent-g);
}

.boot-title{font-size:clamp(2.5rem,7vw,4.5rem);margin-bottom:.75rem;letter-spacing:-.05em}
.boot-sub{color:var(--text2);font-size:clamp(.9rem,2vw,1.15rem);max-width:480px;margin:0 auto 2.5rem;line-height:1.7}

.enter-btn{
  display:inline-flex;align-items:center;gap:1rem;
  padding:1rem 2.5rem;background:var(--accent);color:#fff;
  border:0;border-radius:14px;font-size:1.0625rem;font-weight:700;
  cursor:pointer;font-family:var(--font);
  box-shadow:0 4px 24px rgba(99,91,255,.3);
  transition:all .2s;
}
.enter-btn:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 8px 32px rgba(99,91,255,.4)}
.enter-btn:active{transform:translateY(0)}
.enter-arrow{font-size:1.25rem;transition:transform .2s}
.enter-btn:hover .enter-arrow{transform:translateX(4px)}

.boot-tags{display:flex;gap:.6rem;justify-content:center;margin-top:2.5rem;flex-wrap:wrap}
.bt{display:flex;align-items:center;gap:.35rem;font-size:.7rem;color:var(--text2);font-weight:500;background:var(--bg2);border:1px solid var(--border);padding:.35rem .75rem;border-radius:100px}
.bt-dot{width:6px;height:6px;border-radius:50%}
.bt-dot.green{background:var(--green)}
.bt-dot.blue{background:var(--cyan)}
.bt-dot.red{background:var(--red)}

/* ════════════ TERMINAL BADGE ════════════ */
.terminal-badge{
  display:inline-block;font-family:var(--mono);font-size:.65rem;font-weight:700;
  color:var(--green);letter-spacing:.15em;text-transform:uppercase;
  padding:.3rem .8rem;border:1px solid rgba(62,207,142,.2);border-radius:100px;
  background:rgba(62,207,142,.06);margin-bottom:1.25rem;
}
.terminal-badge.red{color:var(--red);border-color:rgba(255,85,85,.2);background:rgba(255,85,85,.06)}

/* ════════════ SCREEN 1: SCAN FORM ════════════ */
.term-form{max-width:520px;margin:2rem auto 0;text-align:left}
.term-line{
  display:flex;align-items:center;gap:.5rem;
  background:var(--bg2);border:1.5px solid var(--border);border-radius:10px;
  padding:.1rem .2rem;margin-bottom:.5rem;
  transition:border-color .2s;
}
.term-line:focus-within{border-color:var(--accent)}
.prompt{
  font-family:var(--mono);font-size:.875rem;font-weight:700;
  color:var(--green);padding-left:.75rem;
  user-select:none;
}
.term-line input{
  flex:1;padding:.8rem .5rem;border:0;outline:0;
  background:transparent;color:var(--text);
  font-family:var(--mono);font-size:.9rem;
}
.term-line input::placeholder{color:var(--text3)}

.launch-btn{
  width:100%;padding:.9rem;margin-top:.5rem;
  background:var(--accent);color:#fff;border:0;border-radius:10px;
  font-family:var(--mono);font-size:.875rem;font-weight:700;letter-spacing:.06em;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.6rem;
  transition:all .2s;
}
.launch-btn:hover{background:var(--accent2);box-shadow:0 4px 20px rgba(99,91,255,.3)}
.launch-icon{width:14px;height:14px;border:2.5px solid rgba(255,255,255,.6);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.term-hint{color:var(--text3);font-size:.75rem;margin-top:.75rem;text-align:center}
.t-error{background:rgba(255,85,85,.1);color:#fca5a5;border:1px solid rgba(255,85,85,.2);padding:.6rem .8rem;border-radius:8px;margin-bottom:.75rem;font-size:.85rem}

.scan-stats{
  display:flex;gap:1.5rem;justify-content:center;margin-top:2.5rem;flex-wrap:wrap;
}
.ss{display:flex;flex-direction:column;align-items:center;min-width:80px}
.ss-num{font-size:2rem;font-weight:900;color:var(--accent2);font-family:var(--mono)}
.ss-label{font-size:.6rem;color:var(--text3);font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-top:.15rem}

/* ════════════ SCREEN 2: TIMELINE ════════════ */
[data-i="2"] h2{margin-bottom:2rem}
.timeline{max-width:480px;margin:0 auto;text-align:left;position:relative}
.tl-item{display:flex;gap:1rem;align-items:flex-start;position:relative}
.tl-marker{
  width:36px;height:36px;min-width:36px;border-radius:10px;
  background:var(--bg3);border:1.5px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:.75rem;font-weight:700;color:var(--accent2);
  transition:all .3s;
}
.tl-item:hover .tl-marker{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 20px var(--accent-g)}
.tl-content h3{font-size:.95rem;margin-bottom:.2rem}
.tl-content p{color:var(--text2);font-size:.8rem;margin:0;line-height:1.5}
.tl-line{width:2px;height:20px;background:var(--border);margin:0 0 0 17px}

.s-nav-row{display:flex;gap:.75rem;justify-content:center;margin-top:2.5rem}
.nav-btn{
  padding:.6rem 1.25rem;border:1.5px solid var(--border2);border-radius:8px;
  background:transparent;color:var(--text2);font-size:.8rem;font-weight:600;
  cursor:pointer;font-family:var(--font);transition:all .15s;
}
.nav-btn:hover{border-color:var(--accent);color:#fff}
.nav-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.nav-btn.primary:hover{background:var(--accent2)}

/* ════════════ SCREEN 3: THREATS ════════════ */
.threat-sub{color:var(--text2);font-size:.95rem;max-width:520px;margin:0 auto 2rem;line-height:1.6}
.threat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;max-width:680px;margin:0 auto}
.threat-card{
  padding:1rem .75rem;text-align:center;
  background:var(--bg2);border:1px solid var(--border);border-radius:10px;
  transition:all .3s;
}
.threat-card:hover{border-color:var(--amber);transform:translateY(-2px)}
.threat-card.hot{border-color:rgba(255,85,85,.3);background:rgba(255,85,85,.04)}
.threat-card.hot:hover{border-color:var(--red)}
.tc-flag{font-size:1.5rem;margin-bottom:.3rem}
.tc-name{font-size:.65rem;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.2rem}
.tc-fine{font-size:1rem;font-weight:800}

.overlay-warn{
  max-width:520px;margin:2rem auto 0;text-align:left;
  padding:1rem 1.25rem;border-radius:10px;
  border:1px solid rgba(255,85,85,.15);background:rgba(255,85,85,.04);
  font-size:.8rem;color:var(--text2);
}
.overlay-warn strong{display:block;color:var(--red);margin-bottom:.3rem;font-size:.85rem}
.overlay-warn p{margin:0}

/* ════════════ SCREEN 4: PRICING ════════════ */
.p-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem;align-items:start;text-align:left}
.p-card{
  padding:1.5rem;border:1.5px solid var(--border);border-radius:16px;
  background:var(--bg2);position:relative;
  transition:border-color .3s;
}
.p-card:hover{border-color:var(--border2)}
.p-card.featured{border-color:var(--accent);box-shadow:0 0 40px var(--accent-g)}
.p-badge{
  position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#fff;font-size:.6rem;font-weight:700;
  padding:.2rem .7rem;border-radius:100px;letter-spacing:.08em;
}
.p-name{font-size:.85rem;font-weight:600;color:var(--text2);margin-bottom:.25rem}
.p-price{font-size:2.25rem;font-weight:900;letter-spacing:-.03em}
.p-period{font-size:.75rem;color:var(--text3);margin-bottom:1rem}
.p-card ul{list-style:none;margin-bottom:1.25rem}
.p-card li{padding:.25rem 0 .25rem 1.1rem;position:relative;font-size:.8rem;color:var(--text2)}
.p-card li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:700}

.p-btn{
  width:100%;padding:.65rem;border:1.5px solid var(--border2);border-radius:8px;
  background:transparent;color:var(--text);font-size:.8rem;font-weight:700;
  cursor:pointer;font-family:var(--font);transition:all .15s;
}
.p-btn:hover{border-color:var(--accent);color:#fff}
.p-btn.accent{background:var(--accent);border-color:var(--accent);color:#fff}
.p-btn.accent:hover{background:var(--accent2)}

.p-mon-form{display:flex;flex-direction:column;gap:.35rem}
.p-mon-form input{
  padding:.5rem .6rem;border:1px solid var(--border);border-radius:6px;
  background:var(--bg3);color:var(--text);font-size:.75rem;font-family:var(--mono);
}
.p-mon-form input:focus{border-color:var(--accent);outline:0}
.p-mon-form .p-btn{margin-top:.2rem}

/* ════════════ RESULTS / REPORT PAGES (scrollable) ════════════ */
body.page-scroll{overflow:auto}
body.page-scroll .app{position:static}
body.page-scroll .s{position:static;opacity:1;pointer-events:auto;min-height:auto;padding:6rem 1.5rem 3rem}
body.page-scroll .nav-dots{display:none}

.scores-grid{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;margin:2rem 0}
.score-card{
  display:inline-flex;flex-direction:column;align-items:center;
  padding:1.25rem 1rem;background:var(--bg2);border-radius:14px;
  border:1.5px solid var(--border);min-width:115px;
}
.score-value{font-size:2.25rem;font-weight:900;font-family:var(--mono);letter-spacing:-.02em}
.score-label{font-size:.7rem;color:var(--text3);margin-top:.2rem;text-transform:uppercase;letter-spacing:.06em}
.score-good{color:var(--green);border-color:rgba(62,207,142,.25)}
.score-warning{color:var(--amber);border-color:rgba(247,185,85,.25)}
.score-bad{color:var(--red);border-color:rgba(255,85,85,.25)}

.violations-summary{display:flex;gap:.4rem;flex-wrap:wrap;margin:1rem 0 2rem}
.violation-tag{display:inline-block;padding:.2rem .55rem;border-radius:5px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-family:var(--mono)}
.violations-summary .violation-tag{font-size:.75rem;padding:.3rem .7rem}
.tag-critical{background:rgba(255,85,85,.12);color:#ff8888}
.tag-serious{background:rgba(247,185,85,.1);color:#fcd08f}
.tag-moderate{background:rgba(247,185,85,.07);color:var(--amber)}
.tag-minor{background:rgba(255,255,255,.04);color:var(--text3)}

.violation{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:1.25rem;margin-bottom:.6rem;border-left:3px solid var(--red);text-align:left}
.violation.serious{border-left-color:var(--amber)}
.violation.moderate{border-left-color:#f59e0b80}
.violation.minor{border-left-color:var(--text3)}
.violation h3{margin-bottom:.4rem;font-size:.95rem}
.violation-meta{display:flex;gap:.75rem;font-size:.75rem;color:var(--text3);margin-bottom:.6rem}
.code-snippet{background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:.75rem;font-family:var(--mono);font-size:.75rem;overflow-x:auto;margin:.6rem 0;white-space:pre-wrap;word-break:break-all;color:var(--text2)}

.paywall{background:linear-gradient(180deg,transparent,var(--bg2) 50%);padding:3rem 1.5rem;text-align:center;border-radius:16px;margin:2rem 0;border:1px solid var(--border)}
.paywall h2{margin-bottom:.6rem}
.paywall p{color:var(--text2);max-width:440px;margin:0 auto 1.5rem;font-size:.9rem}

.upsell-card{
  margin:2rem 0;padding:1.5rem;border-radius:14px;text-align:left;
  border:1.5px solid rgba(91,91,214,.25);background:rgba(91,91,214,.05);
}
.upsell-card h3{font-size:1.1rem;margin-bottom:.5rem}
.upsell-card p{color:var(--text2);font-size:.9rem;margin-bottom:1rem}
.upsell-card .btn{font-size:.875rem}
.paid-header{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0}
.audit-status{text-align:center;padding:3rem 1.5rem}
.overlay-warning{background:rgba(247,185,85,.05);border:1.5px solid rgba(247,185,85,.25);border-radius:10px;padding:1rem 1.25rem;margin:1.25rem 0}

.spinner{display:inline-block;width:2rem;height:2rem;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}

/* Buttons on results/paywall */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:700;border:0;border-radius:10px;cursor:pointer;text-decoration:none;transition:all .15s;font-family:var(--font)}
.btn:active{transform:scale(.97)}
.btn-primary,.btn-accent{background:var(--accent);color:#fff;box-shadow:0 2px 12px var(--accent-g)}
.btn-primary:hover,.btn-accent:hover{background:var(--accent2);color:#fff}
.btn-secondary,.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--border2)}
.btn-secondary:hover,.btn-ghost:hover{border-color:var(--accent);color:#fff}
.btn:disabled{opacity:.4;cursor:not-allowed}

/* ════════════ ADMIN ════════════ */
.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-bottom:1.5rem}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:1.25rem;text-align:center}
.stat-value{font-size:1.75rem;font-weight:900;color:var(--accent2);font-family:var(--mono)}
.stat-label{font-size:.7rem;color:var(--text3);margin-top:.2rem;text-transform:uppercase;letter-spacing:.06em}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th,.admin-table td{padding:.6rem;border-bottom:1px solid var(--border);text-align:left;font-size:.8rem}
.admin-table th{font-weight:600;background:var(--bg2)}

/* ════════════ LEGAL ════════════ */
.legal-page{padding:5rem 0 4rem}
.legal-page .container{max-width:700px;margin:0 auto;padding:0 1.5rem}
.legal-page h1{font-size:1.75rem;margin-bottom:.4rem}
.legal-page .legal-date{color:var(--text3);font-size:.8rem;margin-bottom:2rem}
.legal-page h2{font-size:1.15rem;margin-top:2rem;margin-bottom:.6rem}
.legal-page p,.legal-page li{font-size:.9rem;color:var(--text2);line-height:1.75}
.legal-page ul,.legal-page ol{padding-left:1.5rem;margin-bottom:.75rem}
.legal-page li{margin-bottom:.3rem}

/* ════════════ BLOG ════════════ */
.blog-card{padding:1.5rem 0;border-bottom:1px solid var(--border)}
.blog-card:last-child{border-bottom:0}
.blog-card a{text-decoration:none}
.blog-card h2{font-size:1.25rem;color:var(--text);transition:color .15s;margin-bottom:.35rem}
.blog-card a:hover h2{color:var(--accent2)}
.blog-meta{font-size:.8rem;color:var(--text3);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.blog-tag{background:var(--accent-g);color:var(--accent2);padding:.1rem .5rem;border-radius:100px;font-size:.65rem;font-weight:600}
.blog-excerpt{color:var(--text2);font-size:.9rem;margin:0}
.blog-breadcrumb{font-size:.8rem;color:var(--text3);margin-bottom:1.5rem}
.blog-breadcrumb a{color:var(--accent2)}
.blog-content{margin-top:2rem;line-height:1.85}
.blog-content h2{font-size:1.35rem;margin-top:2.5rem;margin-bottom:.75rem}
.blog-content h3{font-size:1.1rem;margin-top:1.75rem;margin-bottom:.5rem}
.blog-content p{color:var(--text2);margin-bottom:1.25rem}
.blog-content ul,.blog-content ol{padding-left:1.5rem;margin-bottom:1.25rem;color:var(--text2)}
.blog-content li{margin-bottom:.35rem}
.blog-content strong{color:var(--text)}
.blog-content a{color:var(--accent2)}
.blog-content blockquote{border-left:3px solid var(--accent);padding:.75rem 1.25rem;margin:1.5rem 0;background:var(--bg2);border-radius:0 8px 8px 0;color:var(--text2);font-style:italic}
.blog-content code{background:var(--bg3);padding:.15rem .4rem;border-radius:4px;font-family:var(--mono);font-size:.85rem}
.blog-cta{margin-top:3rem;padding:2rem;border-radius:14px;border:1.5px solid rgba(91,91,214,.2);background:rgba(91,91,214,.04);text-align:center}
.blog-cta h3{margin-bottom:.5rem}
.blog-cta p{color:var(--text2);font-size:.9rem;margin-bottom:1rem}

/* ════════════ ERROR ════════════ */
.error-page{text-align:center;padding:5rem 1.5rem}
.error-page h1{font-size:5rem;color:var(--text3);font-weight:900}
.error-page p{color:var(--text2);font-size:1rem;margin:1rem 0 2rem}

/* ════════════ FOOTER ════════════ */
footer{background:var(--bg2);border-top:1px solid var(--border);color:var(--text2);padding:1.5rem 0;font-size:.75rem}
body:not(.page-scroll) footer{display:none}
.footer-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}
footer ul{list-style:none;display:flex;gap:1.25rem}
footer a{color:var(--text2);text-decoration:none}
footer a:hover{color:var(--text)}

/* ════════════ RESPONSIVE ════════════ */
@media(max-width:768px){
  .s-inner{padding:1.25rem 1rem;justify-content:flex-start}
  .app{top:44px}
  header nav{padding:.5rem 1rem}
  .nav-right{gap:.75rem}
  header ul{gap:.75rem}

  .boot-logo{width:100px;height:100px;margin-bottom:1.25rem}
  .boot-mark{width:44px;height:44px;font-size:1.1rem;border-radius:10px}
  .ring-2{inset:10px}
  .ring-3{inset:20px}
  .boot-title{font-size:2.25rem}
  .boot-sub{font-size:.85rem;margin-bottom:1.5rem}
  .enter-btn{padding:.75rem 1.5rem;font-size:.9rem}
  .boot-tags{gap:.35rem}
  .bt{font-size:.6rem;padding:.2rem .5rem}

  .scan-input-wrap{flex-direction:column}
  .scan-btn{justify-content:center}
  .scan-stats{gap:.75rem}
  .ss-num{font-size:1.5rem}
  .term-form{margin-top:1.25rem}

  .steps{grid-template-columns:1fr;gap:.6rem}
  .step{padding:1rem}
  .tl-line{height:10px;margin-left:17px}

  .card-grid{grid-template-columns:1fr}

  .threat-grid{grid-template-columns:repeat(2,1fr);gap:.4rem}
  .threat-card{padding:.7rem .5rem}
  .tc-flag{font-size:1.1rem;margin-bottom:.15rem}
  .tc-fine{font-size:.85rem}
  .threat-sub{font-size:.8rem;margin-bottom:1rem}
  .overlay-warn{font-size:.7rem;padding:.6rem .75rem;margin-top:1rem}
  .overlay-warn strong{font-size:.75rem}
  .s-nav-row{margin-top:1.25rem}
  .nav-btn{padding:.5rem 1rem;font-size:.75rem}

  [data-i="4"] h2{font-size:1.5rem;margin-bottom:.5rem}
  .p-grid{grid-template-columns:1fr;gap:.6rem;margin-top:1rem}
  .p-card{padding:1rem}
  .p-price{font-size:1.75rem}
  .p-period{margin-bottom:.75rem}
  .p-card ul{margin-bottom:1rem}
  .p-card li{font-size:.75rem;padding:.2rem 0 .2rem 1.1rem}
  .p-btn{padding:.5rem;font-size:.75rem}
  .p-mon-form input{font-size:.7rem;padding:.4rem .5rem}
  .p-badge{font-size:.55rem;top:-8px;padding:.15rem .6rem}

  .nav-dots{right:.5rem;gap:.4rem}
  .dot{width:7px;height:7px}

  .footer-inner{flex-direction:column;text-align:center}
  footer ul{justify-content:center;gap:.75rem}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
@media(forced-colors:active){.enter-btn,.launch-btn,.p-btn,.btn{border:2px solid ButtonText}.violation{border-left-width:3px}}
