/* ============================================================
   SEMPER PRO — shared brand system (hybrid black/gold tactical)
   Used by: apply (LP1), qualify (LP2), thank-you + not-qualified.
   ============================================================ */

:root{
  --ink:#0E0E0F;          /* base background */
  --ink-2:#16161A;        /* raised panel */
  --ink-3:#1E1E23;        /* card / input */
  --gold:#C8A24B;         /* primary accent */
  --gold-bright:#E4C36A;  /* hover / highlight */
  --gold-deep:#9E7E33;    /* pressed / borders */
  --bone:#F2EFE9;         /* primary text */
  --bone-dim:#C8C5BD;     /* secondary text */
  --steel:#8A8D91;        /* muted text */
  --line:rgba(200,162,75,.22); /* hairline gold */
  --line-soft:rgba(242,239,233,.10);
  --ok:#6FBF73;
  --maxw:1080px;
  --rad:14px;
  --shadow:0 18px 50px rgba(0,0,0,.5);
  --font-display:'Cinzel', Georgia, serif;
  --font-body:'Barlow', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--ink);
  color:var(--bone);
  font-family:var(--font-body);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--gold-bright);text-decoration:none}
a:hover{color:var(--gold)}

/* subtle tactical texture on the base */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(200,162,75,.08), transparent 60%),
    linear-gradient(180deg, #0c0c0d 0%, #0E0E0F 40%, #0b0b0c 100%);
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.narrow{max-width:760px;margin:0 auto;padding:0 22px}

/* ---- type ---- */
h1,h2,h3{font-family:var(--font-display);font-weight:700;line-height:1.12;margin:0 0 .4em;letter-spacing:.01em}
h1{font-size:clamp(2rem, 5.2vw, 3.5rem)}
h2{font-size:clamp(1.6rem, 3.6vw, 2.5rem)}
h3{font-size:clamp(1.15rem, 2vw, 1.4rem)}
.eyebrow{
  font-family:var(--font-body);font-weight:700;letter-spacing:.22em;
  text-transform:uppercase;font-size:.78rem;color:var(--gold);margin:0 0 14px
}
.lead{font-size:clamp(1.05rem,1.7vw,1.25rem);color:var(--bone-dim)}
.gold{color:var(--gold)}
.muted{color:var(--steel)}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--font-body);font-weight:800;letter-spacing:.04em;
  text-transform:uppercase;cursor:pointer;border:0;border-radius:12px;
  padding:18px 34px;font-size:1.05rem;line-height:1.1;text-align:center;
  transition:transform .12s ease, box-shadow .2s ease, background .2s ease;
}
.btn-gold{
  background:linear-gradient(180deg, var(--gold-bright), var(--gold));
  color:#1a1407;box-shadow:0 10px 30px rgba(200,162,75,.28);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(200,162,75,.4);color:#1a1407}
.btn-gold:active{transform:translateY(0)}
.btn-ghost{background:transparent;color:var(--bone);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-sub{display:block;font-size:.66rem;font-weight:700;letter-spacing:.16em;opacity:.8;margin-top:4px}
.btn-block{display:flex;width:100%}

/* ---- sections ---- */
section{padding:64px 0}
.section-tight{padding:44px 0}
.divider{height:1px;background:var(--line);max-width:var(--maxw);margin:0 auto}

/* ---- logo bar ---- */
.topbar{padding:22px 0;text-align:center;border-bottom:1px solid var(--line-soft)}
.topbar img{height:74px;margin:0 auto}

/* ---- hero ---- */
.hero{padding:54px 0 40px;text-align:center}
.hero h1{margin-bottom:.3em}
.hero .lead{max-width:720px;margin:0 auto 8px}

/* ---- qualifier strip ---- */
.qstrip{
  background:linear-gradient(180deg, var(--ink-2), var(--ink));
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  text-align:center;padding:16px 22px
}
.qstrip p{margin:0;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  font-size:.92rem;color:var(--bone)}
.qstrip .gold{color:var(--gold)}

/* ---- video ---- */
.video-shell{max-width:920px;margin:0 auto}
.video-frame{
  position:relative;width:100%;padding-top:56.25%;border-radius:var(--rad);
  overflow:hidden;border:1px solid var(--line);background:#000;box-shadow:var(--shadow)
}
.video-frame iframe,.video-frame video,.video-frame .video-ph{
  position:absolute;inset:0;width:100%;height:100%;border:0
}
.video-ph{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  background:radial-gradient(circle at 50% 40%, #1b1b1f, #0b0b0c);color:var(--bone-dim);
  cursor:pointer;text-align:center;padding:20px
}
.video-ph .play{
  width:84px;height:84px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(180deg,var(--gold-bright),var(--gold));box-shadow:0 10px 30px rgba(200,162,75,.4)
}
.video-ph .play svg{margin-left:5px}
.video-note{font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--steel)}
.placeholder-tag{
  display:inline-block;margin-top:10px;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);border:1px dashed var(--line);border-radius:8px;padding:6px 10px
}

/* ---- proof / credential band ---- */
.band{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cred{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center}
.cred img{border-radius:var(--rad);border:1px solid var(--line);box-shadow:var(--shadow)}
.cred-list{list-style:none;margin:18px 0 0;padding:0}
.cred-list li{position:relative;padding:8px 0 8px 30px;border-bottom:1px solid var(--line-soft);color:var(--bone-dim)}
.cred-list li::before{content:"";position:absolute;left:0;top:16px;width:12px;height:12px;
  background:var(--gold);clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%)}
.cred-list strong{color:var(--bone)}

/* ---- stats ---- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;text-align:center;margin-top:8px}
.stat{padding:24px 14px;background:var(--ink-3);border:1px solid var(--line);border-radius:var(--rad)}
.stat .n{font-family:var(--font-display);font-size:2.2rem;color:var(--gold);line-height:1}
.stat .l{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--bone-dim);margin-top:8px}

/* ---- traits 3-up ---- */
.traits{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.trait{background:var(--ink-3);border:1px solid var(--line);border-radius:var(--rad);padding:30px 26px}
.trait .step{font-family:var(--font-display);font-size:1rem;color:var(--gold);letter-spacing:.1em}
.trait h3{margin-top:6px}
.trait p{color:var(--bone-dim);margin:0;font-size:1rem}

/* ---- guarantee ---- */
.guarantee{
  text-align:center;border:1px solid var(--gold);border-radius:var(--rad);
  background:linear-gradient(180deg, rgba(200,162,75,.08), rgba(200,162,75,.02));
  padding:42px 30px;max-width:820px;margin:0 auto
}
.guarantee .seal{font-family:var(--font-display);color:var(--gold);letter-spacing:.16em;
  text-transform:uppercase;font-size:.9rem;margin-bottom:10px}

/* ---- CTA block ---- */
.cta-block{text-align:center;max-width:680px;margin:0 auto}
.cta-block h2{margin-bottom:.4em}

/* ---- footer ---- */
.footer{background:#0a0a0b;border-top:1px solid var(--line);padding:40px 0;font-size:.84rem;color:var(--steel)}
.footer .wrap{text-align:center}
.footer img{height:48px;margin:0 auto 16px;opacity:.85}
.footer a{color:var(--bone-dim)}
.footer .disclaimer{font-size:.76rem;line-height:1.6;max-width:760px;margin:16px auto 0;color:#6a6c70}
.footer .links{margin:10px 0}
.footer .links a{margin:0 10px}

/* ---- modal / popup ---- */
.modal-overlay{
  position:fixed;inset:0;background:rgba(5,5,6,.82);backdrop-filter:blur(4px);
  display:none;align-items:flex-start;justify-content:center;z-index:1000;
  padding:28px 16px;overflow-y:auto
}
.modal-overlay.open{display:flex}
.modal{
  background:var(--ink-2);border:1px solid var(--line);border-radius:18px;
  width:100%;max-width:560px;box-shadow:var(--shadow);position:relative;
  margin:auto;overflow:hidden
}
.modal-head{padding:26px 28px 0;text-align:center}
.modal-head .step-tag{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.modal-head h3{margin:8px 0 4px}
.modal-head p{color:var(--steel);font-size:.86rem;margin:0}
.modal-close{position:absolute;top:14px;right:16px;background:none;border:0;color:var(--steel);
  font-size:1.6rem;line-height:1;cursor:pointer;z-index:2}
.modal-close:hover{color:var(--gold)}
.modal-body{padding:22px 28px 30px}

/* ---- progress bar ---- */
.progress{height:6px;background:var(--ink-3);border-radius:99px;overflow:hidden;margin:18px 0 6px}
.progress .bar{height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-bright));
  transition:width .35s ease}
.progress-meta{display:flex;justify-content:space-between;font-size:.74rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--steel);margin-bottom:14px}

/* ---- form steps ---- */
.step-q{display:none;animation:fade .3s ease both}
.step-q.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.q-title{font-family:var(--font-display);font-size:1.3rem;margin:0 0 6px;color:var(--bone)}
.q-desc{color:var(--steel);font-size:.9rem;margin:0 0 16px}

/* option pills */
.opts{display:flex;flex-direction:column;gap:10px;margin:0 0 8px}
.opt{
  display:flex;align-items:center;gap:12px;padding:15px 16px;cursor:pointer;
  background:var(--ink-3);border:1px solid var(--line-soft);border-radius:12px;
  transition:border-color .15s, background .15s;color:var(--bone)
}
.opt:hover{border-color:var(--gold)}
.opt input{accent-color:var(--gold);width:18px;height:18px;flex:0 0 auto}
.opt.selected{border-color:var(--gold);background:rgba(200,162,75,.08)}
.opt .mark{
  width:22px;height:22px;border-radius:6px;border:1px solid var(--line);flex:0 0 auto;
  display:grid;place-items:center;color:var(--ink);font-weight:900;font-size:.85rem
}
.opt.radio .mark{border-radius:50%}
.opt.selected .mark{background:var(--gold);border-color:var(--gold)}

/* text inputs */
.field{margin:0 0 14px}
.field label{display:block;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--bone-dim);margin-bottom:6px}
.field input,.field textarea,.field select{
  width:100%;padding:14px 15px;background:var(--ink-3);border:1px solid var(--line-soft);
  border-radius:10px;color:var(--bone);font-family:var(--font-body);font-size:1rem
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.field textarea{min-height:96px;resize:vertical}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.86rem;color:var(--bone-dim);margin:6px 0 14px}
.consent input{margin-top:4px;accent-color:var(--gold);width:18px;height:18px;flex:0 0 auto}

/* nav buttons in form */
.step-nav{display:flex;gap:10px;margin-top:8px}
.step-nav .btn{flex:1}
.err{color:#E27d6a;font-size:.84rem;margin:4px 0 0;min-height:1.1em}

/* sticky mobile CTA */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:900;display:none;
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:linear-gradient(180deg, rgba(14,14,15,.4), var(--ink) 40%);
  border-top:1px solid var(--line)
}

/* ---- thank-you / status pages ---- */
.status-hero{text-align:center;padding:70px 0 30px}
.status-icon{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;margin:0 auto 22px;
  background:linear-gradient(180deg,var(--gold-bright),var(--gold));box-shadow:0 10px 30px rgba(200,162,75,.35)}
.cal-embed{max-width:900px;margin:0 auto;min-height:680px;border:1px solid var(--line);border-radius:var(--rad);overflow:hidden}
.cal-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  min-height:420px;background:var(--ink-2);text-align:center;padding:30px;color:var(--bone-dim)}

/* ---- responsive ---- */
@media (max-width:760px){
  body{font-size:17px}
  section{padding:48px 0}
  .cred{grid-template-columns:1fr;gap:26px}
  .cred img{max-width:380px;margin:0 auto}
  .traits{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr;gap:12px}
  .grid-2{grid-template-columns:1fr}
  .topbar img{height:60px}
  .sticky-cta{display:block}
  .hero{padding-bottom:84px}
}

/* ---- reduced motion: never leave content hidden (workspace P0 rule) ---- */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto !important;transition:none !important}
  .step-q{opacity:1 !important;transform:none !important}
}
