/* ============================================================
   THE FEE DOCTOR — styles.css
   Mobile-first. Black / Red #D62828 / Gold #C9A961.
   Anton (display) · Fraunces (serif) · JetBrains Mono (data)
   ============================================================ */
:root{
  --black:#0a0a0a; --ink:#121212; --panel:#161616; --line:#262626;
  --red:#D62828; --gold:#C9A961; --paper:#f4f1ea; --muted:#8f8f89;
  --green:#3a9d5d; --yellow:#d9a521;
  --display:'Anton',sans-serif; --serif:'Fraunces',serif; --mono:'JetBrains Mono',monospace;
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:74px;-webkit-text-size-adjust:100%}
body{
  background:var(--black);color:var(--paper);font-family:var(--serif);
  font-weight:400;line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(circle at 15% 6%,rgba(214,40,40,.06),transparent 42%),
                   radial-gradient(circle at 92% 88%,rgba(201,169,97,.05),transparent 46%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px;position:relative;z-index:1}

/* ---------- type ---------- */
.eyebrow{font-family:var(--mono);font-size:11.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);font-weight:500}
h1,h2,h3,h4{font-family:var(--display);font-weight:400;line-height:.98;letter-spacing:.5px;text-transform:uppercase}
.lead{font-size:clamp(17px,4.6vw,21px);color:#d9d6cf}
.red{color:var(--red)} .gold{color:var(--gold)}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--mono);font-size:13px;letter-spacing:.05em;text-transform:uppercase;font-weight:500;
  padding:14px 22px;border-radius:2px;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  cursor:pointer;transition:.22s;border:1px solid transparent;white-space:nowrap;
}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:#b51f1f}
.btn-ghost{border-color:var(--gold);color:var(--gold);background:transparent}
.btn-ghost:hover{background:var(--gold);color:var(--black)}
.btn-block{width:100%}

/* ---------- nav ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(10,10,10,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:46px;width:46px;border-radius:7px;background:#000}
.brand .bn{font-family:var(--display);font-size:17px;letter-spacing:.8px;line-height:1}
.brand .bn small{display:block;font-family:var(--mono);font-size:8px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;font-weight:400;margin-top:3px}
.navlinks{display:flex;align-items:center;gap:26px}
.navlinks a{font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;color:#cfccc4;transition:color .2s}
.navlinks a:hover,.navlinks a.active{color:var(--gold)}
.menu-toggle{display:none;background:none;border:none;color:var(--paper);font-size:25px;cursor:pointer;line-height:1}

/* ---------- sections ---------- */
section{padding:clamp(54px,11vw,104px) 0;position:relative}
.sec-head{max-width:60ch;margin-bottom:clamp(34px,6vw,52px)}
.sec-head h2{font-size:clamp(32px,8.5vw,60px);margin-top:13px}
.sec-head p{margin-top:18px;font-size:clamp(16px,4.4vw,18px);color:#cbc8c0}

/* ---------- hero ---------- */
.hero{padding:clamp(48px,12vw,108px) 0 clamp(44px,9vw,84px)}
.hero h1{font-size:clamp(38px,11vw,86px)}
.hero h1 .br{display:block}
.hero .sub{margin-top:24px;max-width:40ch;font-size:clamp(17px,4.8vw,21px);color:#d6d3cb}
.hero .cta-row{margin-top:34px;display:flex;gap:12px;flex-wrap:wrap}
.hero .cta-row .btn{flex:1;min-width:200px}
.hero .micro{margin-top:24px;font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.04em;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.hero .micro b{color:var(--gold);font-weight:500}

/* ---------- strip ---------- */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink);overflow:hidden;padding:14px 0}
.strip-track{display:flex;gap:40px;white-space:nowrap;animation:scroll 36s linear infinite;font-family:var(--mono);font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);width:max-content}
.strip-track b{color:var(--gold);font-weight:500}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- personal trust (eddie) ---------- */
.eddie{background:var(--ink);border-bottom:1px solid var(--line)}
.eddie-in{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.eddie-in img{width:104px;height:104px;border-radius:12px;background:#000;border:1px solid var(--line);flex-shrink:0}
.eddie-txt{flex:1;min-width:260px}
.eddie .role{font-family:var(--mono);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.eddie h2{font-size:clamp(24px,6vw,34px);letter-spacing:.4px}
.eddie p{margin-top:14px;font-size:16.5px;color:#cbc8c0;max-width:66ch}
.eddie .meta{margin-top:16px;font-family:var(--mono);font-size:12.5px;letter-spacing:.03em;color:var(--muted);line-height:1.9}
.eddie .meta a{color:var(--gold)}

/* ---------- how it works ---------- */
.steps{display:grid;gap:14px;grid-template-columns:1fr}
.step{background:var(--panel);border:1px solid var(--line);border-radius:4px;padding:24px}
.step .n{font-family:var(--mono);font-size:12px;color:var(--gold);letter-spacing:.18em}
.step h3{font-size:18px;margin:12px 0 9px;letter-spacing:.4px}
.step p{font-size:15px;color:#bdbab2}

/* ---------- verdict ---------- */
.verdict-cards{display:grid;gap:16px;grid-template-columns:1fr;margin-top:32px}
.vc{border:1px solid var(--line);border-radius:4px;padding:28px 26px;background:var(--panel);position:relative;overflow:hidden;transition:transform .25s,border-color .25s}
.vc:hover{transform:translateY(-4px)}
.vc .bar{position:absolute;top:0;left:0;right:0;height:5px}
.vc.g .bar{background:var(--green)} .vc.g:hover{border-color:var(--green)}
.vc.y .bar{background:var(--yellow)} .vc.y:hover{border-color:var(--yellow)}
.vc.r .bar{background:var(--red)} .vc.r:hover{border-color:var(--red)}
.vc .tag{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}
.vc.g .tag{color:var(--green)} .vc.y .tag{color:var(--yellow)} .vc.r .tag{color:var(--red)}
.vc h3{font-size:23px;margin-bottom:11px}
.vc p{font-size:15px;color:#bdbab2}

/* ---------- industries ---------- */
.industries{background:var(--ink);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ind-cards{display:grid;gap:14px;grid-template-columns:1fr}
.ind{border:1px solid var(--line);background:var(--black);border-radius:4px;padding:26px;transition:border-color .2s}
.ind:hover{border-color:var(--gold)}
.ind .ico{font-family:var(--display);font-size:26px;color:var(--red);line-height:1}
.ind h3{font-size:17px;margin:14px 0 8px;letter-spacing:.4px}
.ind p{font-size:14.5px;color:#bdbab2}

/* feature block (auto + medical) */
.feature{border:1px solid var(--line);border-radius:6px;background:var(--panel);padding:clamp(26px,5vw,42px);margin-top:24px}
.feature .ftag{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.feature h3{font-size:clamp(26px,6.4vw,40px);line-height:1.02}
.feature h3 .red{color:var(--red)}
.feature .fsub{margin-top:16px;font-size:16.5px;color:#cbc8c0;max-width:62ch}
.feature ul{list-style:none;margin-top:20px;display:grid;gap:9px}
.feature li{font-size:15.5px;color:#cbc8c0;padding-left:24px;position:relative}
.feature li::before{content:"\2192";position:absolute;left:0;color:var(--gold)}
.feature .fnote{margin-top:18px;font-style:italic;font-family:var(--serif);font-size:14.5px;color:var(--muted)}
.callout{border-left:3px solid var(--red);background:rgba(214,40,40,.06);border-radius:0 4px 4px 0;padding:18px 22px;margin-top:22px}
.callout-q{font-family:var(--display);font-size:clamp(17px,4.6vw,21px);letter-spacing:.4px;text-transform:uppercase;color:var(--paper);line-height:1.1}
.callout-a{margin-top:10px;font-size:15.5px;color:#d6d3cb}
.tagrow{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.tagrow span{font-family:var(--mono);font-size:12px;letter-spacing:.03em;color:#cfccc4;border:1px solid var(--line);border-radius:2px;padding:8px 13px;background:var(--black)}

/* ---------- reviews ---------- */
.reviews-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:30px}
.rating-badge{display:flex;align-items:center;gap:14px;border:1px solid var(--line);background:var(--panel);border-radius:4px;padding:16px 22px}
.rating-badge .score{font-family:var(--display);font-size:40px;color:var(--gold);line-height:1}
.rating-badge .stars{color:var(--gold);font-size:15px;letter-spacing:2px}
.rating-badge .lbl{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-top:3px}
.rev-grid{display:grid;gap:14px;grid-template-columns:1fr}
.rev{background:var(--black);border:1px solid var(--line);border-radius:4px;padding:26px}
.rev .stars{color:var(--gold);font-size:14px;letter-spacing:3px;margin-bottom:13px}
.rev p{font-family:var(--serif);font-size:16px;color:#e6e3db;line-height:1.55}
.rev .who{margin-top:16px;font-family:var(--mono);font-size:12px;letter-spacing:.05em;color:var(--muted)}
.rev .who b{color:var(--gold);font-weight:500}
.reviews-cta{margin-top:28px;text-align:center}

/* ---------- partners ---------- */
.partners{background:var(--ink);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.who-row{display:flex;flex-wrap:wrap;gap:8px;margin:22px 0}
.who-row span{font-family:var(--mono);font-size:12.5px;color:#cfccc4;border:1px solid var(--line);border-radius:2px;padding:9px 14px;background:var(--black)}
.promise-box{border-left:3px solid var(--gold);padding:6px 0 6px 20px;margin-top:24px}
.promise-box p{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--paper)}

/* ---------- faq ---------- */
.faqwrap{max-width:820px}
.faq{border:1px solid var(--line);border-radius:4px;background:var(--panel);margin-bottom:12px;overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:20px 22px;font-family:var(--display);font-size:clamp(16px,4.6vw,20px);letter-spacing:.3px;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:color .2s}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--gold)}
.faq summary .pm{font-family:var(--serif);font-size:28px;color:var(--red);line-height:1;flex-shrink:0;transition:transform .25s}
.faq[open] summary .pm{transform:rotate(45deg)}
.faq .ans{padding:0 22px 22px;font-size:16px;color:#cbc8c0;line-height:1.62}
.faq .ans b{color:var(--gold);font-weight:500}

/* ---------- final cta ---------- */
.final{text-align:center}
.final .eyebrow{display:flex;justify-content:center}
.final h2{font-size:clamp(32px,9vw,76px);margin:16px 0 8px}
.final .lead{max-width:50ch;margin:14px auto 0}
.final .cta-row{margin-top:32px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.final .cta-row .btn{flex:1;min-width:220px;max-width:340px}
.final .promise{margin-top:24px;font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.04em}

/* ---------- footer ---------- */
footer{background:var(--ink);border-top:1px solid var(--line);padding:46px 0 36px}
.foot-grid{display:flex;justify-content:space-between;gap:34px;flex-wrap:wrap}
.foot-brand{max-width:34ch}
.foot-brand p{margin-top:14px;color:#bdbab2;font-size:15px}
.foot-soc{display:flex;gap:14px;margin-top:16px}
.foot-soc a{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:var(--gold);border:1px solid var(--line);border-radius:2px;padding:7px 11px;transition:.2s}
.foot-soc a:hover{border-color:var(--gold)}
.foot-contact{font-family:var(--mono);font-size:14px;color:#cfccc4;line-height:1.9}
.foot-contact a:hover{color:var(--gold)}
.foot-contact .lbl{color:var(--muted);font-size:11px;letter-spacing:.16em;text-transform:uppercase;display:block;margin-top:14px;margin-bottom:3px}
.foot-bottom{margin-top:36px;padding-top:22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.04em}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .65s cubic-bezier(.2,.7,.2,1),transform .65s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.strip-track{animation:none}html{scroll-behavior:auto}}

/* ============================================================
   BREAKPOINTS — mobile-first scale-ups
   ============================================================ */
@media(min-width:680px){
  .wrap{padding:0 28px}
  .hero .cta-row .btn{flex:0 1 auto}
  .steps{grid-template-columns:repeat(2,1fr)}
  .verdict-cards{grid-template-columns:repeat(3,1fr)}
  .ind-cards{grid-template-columns:repeat(2,1fr)}
  .rev-grid{grid-template-columns:repeat(2,1fr)}
  .feature ul{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:980px){
  .steps{grid-template-columns:repeat(4,1fr)}
  .ind-cards{grid-template-columns:repeat(3,1fr)}
  .rev-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:860px){
  .menu-toggle{display:block}
  .navlinks{position:fixed;inset:72px 0 auto 0;background:var(--ink);flex-direction:column;gap:0;border-bottom:1px solid var(--line);max-height:0;overflow:hidden;transition:max-height .32s ease}
  .navlinks.open{max-height:560px}
  .navlinks a{padding:16px 24px;width:100%;border-bottom:1px solid var(--line)}
  .navlinks .btn{margin:14px 24px;width:calc(100% - 48px)}
}
