/* ThreatMate Firewall Pentest — brand design system
   Palette + type per ThreatMate Brand Guidelines: midnight #19142A base, orange
   #FFB152 highlight (sparing), violet #6B3CEC / deep purple #38226B, signature
   orange→purple gradient. Wordmark = Michroma (Conthrax substitute), body = Onest. */
:root{
  --bg:#19142A; --bg2:#1e1838; --panel:#241d42; --panel2:#1c1633;
  --line:#332a52; --line2:#46396b;
  --text:#F4F2FA; --dim:#b3a9cf; --faint:#7e7499;
  --orange:#FFB152; --orange-l:#FFCD94; --violet:#6B3CEC; --violet-l:#8b63f2; --purple-d:#38226B;
  --grad:linear-gradient(120deg,#FFB152 0%,#FF9d6b 32%,#6B3CEC 78%,#38226B 100%);
  --grad-r:linear-gradient(90deg,#FFB152,#6B3CEC);
  --high:#E2574A; --med:#FFB152; --low:#8b63f2; --ok:#36c08a;
  --mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
  --disp:"Michroma",sans-serif;
  --sans:"Onest",system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1100px 540px at 86% -10%, rgba(255,177,82,.12), transparent 60%),
    radial-gradient(950px 560px at -8% 6%, rgba(107,60,236,.16), transparent 58%),
    var(--bg);
  background-attachment:fixed;
  color:var(--text); font-family:var(--sans);
  -webkit-font-smoothing:antialiased; line-height:1.55; min-height:100vh;
}
a{color:var(--orange)}
.wrap{max-width:1000px;margin:0 auto;padding:0 22px}
.disp{font-family:var(--disp);text-transform:uppercase;letter-spacing:.06em}

/* nav */
.nav{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(25,20,42,.84);backdrop-filter:blur(10px);z-index:40}
.brand{display:flex;align-items:center;gap:12px;cursor:pointer;text-decoration:none}
.brand .mark{width:34px;height:34px;flex-shrink:0;display:block}
.brand .wm{font-family:var(--disp);font-size:16px;letter-spacing:.16em;color:#fff;line-height:1}
.brand .tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;color:var(--orange);margin-top:3px}
.nav-r{display:flex;align-items:center;gap:22px;font-size:14px;color:var(--dim)}
.nav-r a{color:var(--dim);text-decoration:none;cursor:pointer;transition:.15s}
.nav-r a:hover,.nav-r a.is-active{color:#fff}
.nav-cta{font-family:var(--sans);border:none;background:var(--orange);color:#19142A;padding:9px 17px;border-radius:9px;font-size:13.5px;font-weight:600;cursor:pointer;text-decoration:none}

.screen{display:none;animation:fade .4s ease}
.screen.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.kicker{font-family:var(--mono);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);display:inline-flex;align-items:center;gap:9px}
.livedot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 0 rgba(255,177,82,.6);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,177,82,.5)}70%{box-shadow:0 0 0 9px rgba(255,177,82,0)}100%{box-shadow:0 0 0 0 rgba(255,177,82,0)}}

/* hero */
.hero{padding:70px 0 56px}
.hero-grid{display:grid;grid-template-columns:1.22fr .92fr;gap:42px;align-items:center}
.hero h1{font-family:var(--sans);font-size:52px;line-height:1.05;font-weight:700;letter-spacing:-1.4px;margin:20px 0 0}
.hero h1 .g{background:var(--grad-r);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.sub{font-size:18px;color:var(--dim);max-width:600px;margin:20px 0 0;line-height:1.6}
.btn{font-family:var(--sans);cursor:pointer;border:none;border-radius:11px;font-weight:600;transition:transform .12s,filter .12s;text-decoration:none;display:inline-block}
.btn:hover{filter:brightness(1.04);transform:translateY(-1px)}
.btn-primary{background:var(--orange);color:#19142A;padding:15px 26px;font-size:16px}
.hero .cta-row{margin-top:30px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.cta-note{font-size:13px;color:var(--faint);font-family:var(--mono)}
.trust{margin-top:32px;display:flex;gap:22px;flex-wrap:wrap;font-size:13.5px;color:var(--dim)}
.trust span{display:flex;align-items:center;gap:8px}
.tdot{width:7px;height:7px;border-radius:50%;background:var(--orange)}
.vendors{margin-top:44px;border-top:1px solid var(--line);padding-top:22px}
.vendors .vl{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:14px}
.vendor-row{display:flex;gap:10px;flex-wrap:wrap}
.vpill{font-family:var(--mono);font-size:12.5px;color:var(--dim);border:1px solid var(--line2);border-radius:7px;padding:7px 12px;background:var(--panel2)}

.hcard{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line2);border-radius:16px;overflow:hidden;font-family:var(--mono);font-size:12.5px}
.hcard .bar{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--line)}
.cdot{width:11px;height:11px;border-radius:50%}
.cdot.r{background:#ff5f57}.cdot.y{background:#febc2e}.cdot.g{background:#28c840}
.hcard .bar .t{margin-left:8px;color:var(--faint);font-size:11.5px}
.hcard .body{padding:16px;line-height:1.85}
.c-dim{color:var(--faint)}.c-or,.c-warn{color:var(--orange)}.c-hi{color:#ff7d72}.c-info{color:var(--violet-l)}.c-ok{color:var(--ok)}

/* survey */
.pad{padding:48px 0 70px}
.progress-top{display:flex;justify-content:space-between;font-family:var(--mono);font-size:12px;color:var(--dim);margin-bottom:9px;letter-spacing:.03em}
.pbar{height:5px;background:var(--line);border-radius:99px;overflow:hidden}
.pbar i{display:block;height:100%;background:var(--grad-r);border-radius:99px;transition:width .5s ease}
.step h2{font-family:var(--sans);font-size:30px;font-weight:700;letter-spacing:-.6px;margin:30px 0 6px}
.step .help{color:var(--dim);font-size:15px;max-width:600px;margin:0 0 26px}
.grid-v{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:11px}
.opt{border:1px solid var(--line2);background:var(--panel2);border-radius:11px;padding:15px 14px;cursor:pointer;display:flex;flex-direction:column;gap:6px;text-align:left;color:var(--text);font-family:var(--sans);transition:.14s}
.opt:hover{border-color:var(--orange);background:rgba(255,177,82,.06)}
.opt.sel{border-color:var(--orange);background:rgba(255,177,82,.13);box-shadow:inset 0 0 0 1px var(--orange)}
.opt .ic{font-family:var(--mono);font-size:17px;color:var(--orange)}
.opt .nm{font-weight:600;font-size:14.5px}
.opt .ds{font-size:12px;color:var(--faint)}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{border:1px solid var(--line2);background:var(--panel2);border-radius:99px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--text);font-family:var(--sans);transition:.14s}
.chip:hover{border-color:var(--orange)}
.chip.sel{border-color:var(--orange);background:rgba(255,177,82,.14);color:var(--orange)}
.field-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}
.field{flex:1;min-width:240px}
.field label{display:block;font-family:var(--mono);font-size:11.5px;color:var(--dim);margin-bottom:7px;letter-spacing:.05em}
.inp{display:flex;align-items:center;border:1px solid var(--line2);background:var(--panel2);border-radius:10px;overflow:hidden}
.inp:focus-within{border-color:var(--orange)}
.inp .pre{padding:0 0 0 14px;color:var(--faint);font-family:var(--mono);font-size:14px}
.inp input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-family:var(--mono);font-size:15px;padding:13px 14px;min-width:0}
.err{color:#ff8a80;font-size:13px;font-family:var(--mono);margin-top:10px}
.nav-btns{display:flex;justify-content:space-between;margin-top:34px;gap:12px}
.btn-ghost{background:transparent;border:1px solid var(--line2);color:var(--dim);padding:13px 20px;border-radius:11px;font-size:14.5px;cursor:pointer;font-family:var(--sans)}
.btn-ghost:hover{border-color:var(--violet-l);color:#fff}
.btn-next{background:var(--orange);color:#19142A;padding:13px 24px;font-size:15px;border:none;border-radius:11px;cursor:pointer;font-weight:600;font-family:var(--sans)}
.btn-next:disabled{opacity:.4;cursor:not-allowed}

/* scan */
.scanhead{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:14px;gap:16px;flex-wrap:wrap}
.scanhead .tg{font-family:var(--mono);font-size:13px;color:var(--dim)}
.scanhead .tg b{color:var(--text)}
.scanhead .st{font-family:var(--mono);font-size:13px;color:var(--orange);display:flex;align-items:center;gap:9px}
.spin{width:13px;height:13px;border:2px solid var(--purple-d);border-top-color:var(--orange);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.console{background:#120c22;border:1px solid var(--line2);border-radius:14px;overflow:hidden;margin-bottom:18px}
.console .bar{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11.5px;color:var(--faint)}
.console .body{padding:15px 17px;font-family:var(--mono);font-size:12.8px;line-height:1.95;height:320px;overflow-y:auto}
.console .body::-webkit-scrollbar{width:8px}.console .body::-webkit-scrollbar-thumb{background:var(--line2);border-radius:4px}
.ln{white-space:pre-wrap;word-break:break-word}
.ln .pfx{color:var(--orange);margin-right:8px}
.findings{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px}
.fcard{border:1px solid var(--line2);background:var(--panel2);border-radius:11px;padding:14px;animation:fade .3s}
.fcard .sev{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:5px;display:inline-block;margin-bottom:9px}
.sev.high{background:rgba(226,87,74,.16);color:#f08a80}
.sev.med{background:rgba(255,177,82,.16);color:var(--orange)}
.sev.low{background:rgba(139,99,242,.18);color:#b49bf7}
.sev.ok{background:rgba(54,192,138,.16);color:var(--ok)}
.fcard .ti{font-size:14px;font-weight:600;margin-bottom:4px}
.fcard .de{font-size:12.5px;color:var(--dim);line-height:1.5}

/* gate */
.scrim{position:fixed;inset:0;background:rgba(12,8,22,.82);backdrop-filter:blur(5px);display:none;align-items:center;justify-content:center;z-index:80;padding:22px;overflow-y:auto}
.scrim.show{display:flex;animation:fade .25s}
.gate{width:100%;max-width:480px;background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line2);border-radius:16px;padding:28px;position:relative;overflow:hidden}
.gate::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-r)}
.gate .gk{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);display:flex;align-items:center;gap:8px}
.gate h3{font-family:var(--sans);font-size:22px;font-weight:700;margin:13px 0 7px;letter-spacing:-.4px}
.gate p{font-size:13.5px;color:var(--dim);margin:0 0 18px;line-height:1.55}
.gate p b{color:var(--text)}
.gate input.g{width:100%;background:var(--panel2);border:1px solid var(--line2);border-radius:10px;color:var(--text);font-family:var(--mono);font-size:14px;padding:12px 14px;margin-bottom:11px;outline:none}
.gate input.g:focus{border-color:var(--orange)}
.authbox{display:flex;gap:11px;align-items:flex-start;background:var(--panel2);border:1px solid var(--line2);border-radius:10px;padding:13px 14px;margin:4px 0 16px;cursor:pointer}
.authbox input{margin-top:3px;width:17px;height:17px;accent-color:var(--orange);flex-shrink:0}
.authbox label{font-size:12.5px;color:var(--dim);line-height:1.5;cursor:pointer}
.gate .btn-next{width:100%;justify-content:center;padding:14px}
.gate .fine{font-size:11.5px;color:var(--faint);margin:13px 0 0;text-align:center;font-family:var(--mono)}
.progmini{height:4px;background:var(--line);border-radius:99px;margin-bottom:18px;overflow:hidden}
.progmini i{display:block;height:100%;width:72%;background:var(--grad-r)}

/* results */
.verdict{display:flex;gap:20px;align-items:center;background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line2);border-radius:16px;padding:24px;margin:8px 0 22px}
.gauge{width:96px;height:96px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;position:relative}
.gauge::after{content:"";position:absolute;inset:9px;border-radius:50%;background:var(--panel)}
.gauge .lvl{position:relative;text-align:center;font-family:var(--mono)}
.gauge .lvl b{display:block;font-size:30px;line-height:1}
.gauge .lvl small{font-size:9px;color:var(--faint);letter-spacing:.12em}
.verdict .vt h2{font-family:var(--sans);margin:0 0 5px;font-size:23px;font-weight:700}
.verdict .vt p{margin:0;color:var(--dim);font-size:14px;line-height:1.55}
.sec-h{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin:26px 0 13px}
.email-banner{display:flex;align-items:center;gap:13px;background:rgba(255,177,82,.08);border:1px solid rgba(255,177,82,.35);border-radius:12px;padding:16px 18px;font-size:14px;color:var(--dim)}
.email-banner .ic{font-family:var(--mono);color:var(--orange);font-size:20px}
.email-banner b{color:var(--orange)}
.convert{margin-top:30px;border-radius:16px;padding:30px;text-align:center;background:var(--grad);position:relative;overflow:hidden}
.convert h3{font-family:var(--sans);font-size:23px;font-weight:700;margin:0 0 8px;color:#19142A}
.convert p{color:#2a1c4d;font-size:14.5px;max-width:520px;margin:0 auto 18px;font-weight:500}
.convert .btn{background:#19142A;color:#fff}

/* blog */
.blog-head{padding:46px 0 8px}
.blog-head h1{font-family:var(--sans);font-size:38px;font-weight:700;letter-spacing:-.8px;margin:14px 0 8px}
.blog-head p{color:var(--dim);font-size:16px;max-width:620px;margin:0}
.auto-pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--violet-l);border:1px solid var(--line2);background:var(--panel2);border-radius:99px;padding:6px 13px;margin-bottom:22px}
.posts{display:grid;gap:14px;padding-bottom:60px}
.post{display:block;text-decoration:none;color:inherit;border:1px solid var(--line2);background:var(--panel2);border-radius:14px;padding:20px 22px;transition:.15s;cursor:pointer}
.post:hover{border-color:var(--orange);background:rgba(255,177,82,.05)}
.post .meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px;font-family:var(--mono);font-size:11.5px}
.post .date{color:var(--faint)}
.post .vtag{color:var(--violet-l);border:1px solid var(--line2);border-radius:5px;padding:2px 8px}
.post .cve{color:var(--orange)}
.post .sevtag{padding:2px 8px;border-radius:5px;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase}
.post h3{font-family:var(--sans);font-size:20px;font-weight:600;margin:0 0 7px;letter-spacing:-.3px}
.post p{margin:0;color:var(--dim);font-size:14px;line-height:1.55}
.post .more{display:inline-block;margin-top:12px;font-family:var(--mono);font-size:12.5px;color:var(--orange)}

/* article */
.article{max-width:760px;margin:0 auto;padding:46px 22px 70px}
.article__meta{font-family:var(--mono);font-size:12.5px;color:var(--faint);margin-bottom:14px;letter-spacing:.04em}
.article h1{font-family:var(--sans);font-size:34px;font-weight:700;letter-spacing:-.7px;line-height:1.12;margin:0 0 22px}
.article h2{font-family:var(--sans);font-size:21px;font-weight:600;margin:30px 0 10px}
.article p{color:var(--dim);font-size:16.5px;line-height:1.75;margin:0 0 16px}
.article strong{color:var(--text)}
.article a{color:var(--orange)}
.article__sources{margin-top:30px;border-top:1px solid var(--line);padding-top:18px;font-size:14px;display:flex;flex-direction:column;gap:6px}
.article__sources b{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:4px}
.cta-band{margin-top:36px;border-radius:16px;padding:28px;text-align:center;background:var(--grad)}
.cta-band h3{font-family:var(--sans);color:#19142A;font-size:21px;font-weight:700;margin:0 0 8px}
.cta-band p{color:#2a1c4d;font-weight:500;font-size:14.5px;margin:0 auto 16px;max-width:480px}
.cta-band .btn{background:#19142A;color:#fff}

.footer{border-top:1px solid var(--line);margin-top:40px;padding:26px 22px;color:var(--faint);font-size:12px;font-family:var(--mono);text-align:center;letter-spacing:.04em;line-height:1.8}
.footer a{color:var(--dim)}

@media(max-width:780px){
  .hero-grid{grid-template-columns:1fr}
  .hero h1{font-size:37px}
  .hcard{display:none}
  .nav-r a:not(.nav-cta){display:none}
  .verdict{flex-direction:column;text-align:center}
}
