/* ===========================================================
   AUTOVAPE — DESIGN SYSTEM
   Shared stylesheet across all pages
   =========================================================== */

:root{
  --bg:#0a0b0d;
  --bg-2:#101216;
  --bg-3:#15171c;
  --ink:#f5f5f0;
  --ink-dim:#9a9a93;
  --ink-muted:#6a6a63;
  --lime:#c8ff2e;
  --lime-dark:#a8de00;
  --magenta:#ff2bd6;
  --magenta-2:#ff6ae0;
  --cyan:#5af0ff;
  --line:rgba(245,245,240,.08);
  --line-2:rgba(245,245,240,.14);
  --line-3:rgba(245,245,240,.22);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Manrope',sans-serif;
  font-weight:400;
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}

/* Grain overlay */
body::before{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
  opacity:.05;mix-blend-mode:overlay;
}

/* ----------- TYPOGRAPHY ----------- */
.mono{
  font-family:'JetBrains Mono',monospace;
  font-size:.78rem;
  letter-spacing:.04em;
  text-transform:uppercase;
}
h1,h2,h3,h4,h5{
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:700;
  line-height:.95;
  letter-spacing:-.03em;
}
a{color:inherit;text-decoration:none}
.italic{font-style:italic;font-weight:500}
.stroke{-webkit-text-stroke:2px var(--ink);color:transparent}
.lime{color:var(--lime)}
.magenta{color:var(--magenta)}

.container{max-width:1320px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
section{position:relative;z-index:2}

/* ----------- WORDMARK LOGO ----------- */
.logo{
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:1.4rem;
  letter-spacing:-.04em;
  display:inline-flex;
  align-items:baseline;
  gap:0;
  user-select:none;
}
.logo .l-auto{
  color:var(--ink);
  font-weight:500;
  font-style:italic;
}
.logo .l-sep{
  color:var(--lime);
  font-weight:800;
  padding:0 3px;
  text-shadow:0 0 12px rgba(200,255,46,.5);
  animation:logoPulse 2.4s ease-in-out infinite;
}
.logo .l-vape{
  color:var(--ink);
  font-weight:800;
}
@keyframes logoPulse{
  0%,100%{opacity:1}
  50%{opacity:.55}
}
.logo:hover .l-sep{animation-duration:.8s}

/* ----------- NAV ----------- */
nav.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  backdrop-filter:blur(12px);
  background:rgba(10,11,13,.7);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;max-width:1400px;margin:0 auto;
}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:.9rem;color:var(--ink-dim);transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active{position:relative}
.nav-links a.active::after{
  content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;
  background:var(--lime);
}
.nav-cta{
  background:var(--lime)!important;color:#0a0b0d!important;
  padding:11px 22px;border-radius:100px;font-weight:600;font-size:.85rem;
  transition:all .25s;
}
.nav-cta:hover{background:#fff!important;transform:translateY(-1px)}
.nav-cta::after{display:none!important}
@media(max-width:860px){
  .nav-links a:not(.nav-cta){display:none}
  .nav-inner{padding:14px 20px}
}

/* ----------- BUTTONS ----------- */
.btn{
  padding:18px 32px;border-radius:100px;
  font-weight:600;font-size:1rem;
  display:inline-flex;align-items:center;gap:10px;
  transition:all .3s ease;cursor:pointer;border:none;
  font-family:'Manrope',sans-serif;
  text-align:center;
  white-space:nowrap;
}
.btn-primary{background:var(--lime);color:#0a0b0d}
.btn-primary:hover{background:#fff;transform:translateY(-2px);box-shadow:0 20px 40px -10px rgba(200,255,46,.4)}
.btn-ghost{
  background:transparent;color:var(--ink);
  border:1px solid var(--line-2);backdrop-filter:blur(10px);
}
.btn-ghost:hover{background:rgba(255,255,255,.05);border-color:var(--ink-dim)}
.btn-magenta{background:var(--magenta);color:#fff}
.btn-magenta:hover{background:var(--magenta-2);transform:translateY(-2px);box-shadow:0 20px 40px -10px rgba(255,43,214,.4)}
.arrow{display:inline-block;transition:transform .3s}
.btn:hover .arrow{transform:translateX(4px)}

/* ----------- BADGES ----------- */
.badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;border:1px solid var(--line-2);
  border-radius:100px;background:rgba(255,255,255,.02);
  color:var(--ink-dim);font-family:'JetBrains Mono',monospace;
  font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;
}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--lime);box-shadow:0 0 10px var(--lime);animation:logoPulse 2s ease-in-out infinite}

/* ----------- SECTION HEADERS ----------- */
.section{padding:120px 0}
.section-head{margin-bottom:80px;max-width:900px}
.section-head .mono{color:var(--lime);margin-bottom:20px;display:block}
.section-head h2{font-size:clamp(2.2rem,5vw,4rem);margin-bottom:24px}
.section-head p{color:var(--ink-dim);font-size:1.1rem;max-width:640px;line-height:1.6}
@media(max-width:700px){
  .section{padding:80px 0}
  .section-head{margin-bottom:50px}
}

/* ----------- PAGE HERO (non-home) ----------- */
.page-hero{
  position:relative;padding:170px 0 80px;
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.page-hero .blob{
  position:absolute;border-radius:50%;
  filter:blur(120px);opacity:.3;z-index:0;
}
.page-hero h1{
  font-size:clamp(2.5rem,7vw,5.6rem);
  margin:24px 0 28px;letter-spacing:-.04em;
}
.page-hero p.lead{
  color:var(--ink-dim);font-size:1.2rem;max-width:680px;line-height:1.55;
}

/* ----------- AGE GATE ----------- */
.age-gate{
  position:fixed;inset:0;z-index:1000;
  background:rgba(10,11,13,.92);backdrop-filter:blur(20px);
  display:flex;align-items:center;justify-content:center;
  padding:24px;
}
.age-card{
  max-width:480px;background:var(--bg-2);
  border:1px solid var(--line-2);
  border-radius:20px;padding:40px 36px;text-align:center;
  position:relative;overflow:hidden;
}
.age-card::before{
  content:'';position:absolute;inset:-2px;border-radius:20px;
  background:linear-gradient(135deg,var(--lime),transparent 30%,transparent 70%,var(--magenta));
  z-index:-1;opacity:.5;
}
.age-card .mono{color:var(--lime);margin-bottom:14px}
.age-card h3{font-size:1.8rem;margin-bottom:14px}
.age-card p{color:var(--ink-dim);font-size:.9rem;margin-bottom:24px}
.age-buttons{display:flex;gap:12px;justify-content:center}
.age-buttons button{
  padding:14px 26px;border:none;border-radius:100px;cursor:pointer;
  font-family:'Manrope',sans-serif;font-weight:600;font-size:.9rem;
  transition:all .25s ease;
}
.age-yes{background:var(--lime);color:#0a0b0d}
.age-yes:hover{background:#fff;transform:translateY(-2px)}
.age-no{background:transparent;color:var(--ink-dim);border:1px solid var(--line-2)}

/* ----------- FOOTER ----------- */
footer.site-footer{
  border-top:1px solid var(--line);padding:80px 0 40px;
  background:var(--bg-2);position:relative;z-index:2;
}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr;gap:40px}}
.foot-brand .logo{font-size:1.8rem;margin-bottom:16px}
.foot-brand p{color:var(--ink-dim);max-width:340px;font-size:.95rem;line-height:1.6;margin-top:16px}
.foot-col h5{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:18px;font-family:'JetBrains Mono',monospace;font-weight:500}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{font-size:.95rem;color:var(--ink);opacity:.7;transition:opacity .2s}
.foot-col a:hover{opacity:1}
.foot-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:32px;border-top:1px solid var(--line);
  color:var(--ink-dim);font-size:.85rem;flex-wrap:wrap;gap:16px;
}
.warning-strip{
  background:#1a0f1d;border:1px solid rgba(255,43,214,.3);
  color:var(--magenta-2);padding:16px 24px;border-radius:12px;
  text-align:center;font-size:.85rem;margin-top:40px;
  font-family:'JetBrains Mono',monospace;letter-spacing:.03em;
  line-height:1.5;
}

/* ----------- REVEAL ANIMATION ----------- */
.reveal{opacity:0;transform:translateY(40px);transition:all .9s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ----------- FORM STYLES ----------- */
.form-wrap{
  background:var(--bg-2);
  border:1px solid var(--line-2);
  border-radius:24px;
  padding:48px;
  position:relative;
  overflow:hidden;
}
@media(max-width:600px){.form-wrap{padding:32px 24px}}
.form-wrap::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--lime),transparent);
}
.form-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
}
@media(max-width:600px){.form-grid{grid-template-columns:1fr}}
.form-field{display:flex;flex-direction:column;gap:8px}
.form-field.full{grid-column:1/-1}
.form-field label{
  font-family:'JetBrains Mono',monospace;
  font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-dim);
}
.form-field label .req{color:var(--magenta)}
.form-field input,
.form-field select,
.form-field textarea{
  background:var(--bg);
  border:1px solid var(--line-2);
  color:var(--ink);
  padding:14px 16px;
  border-radius:12px;
  font-family:'Manrope',sans-serif;
  font-size:.95rem;
  transition:border-color .2s,background .2s;
  width:100%;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline:none;
  border-color:var(--lime);
  background:rgba(200,255,46,.03);
}
.form-field textarea{resize:vertical;min-height:120px;font-family:'Manrope',sans-serif}
.form-field select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239a9a93' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 16px center;
  padding-right:42px;
  cursor:pointer;
}
.form-consent{
  margin-top:20px;display:flex;gap:12px;align-items:flex-start;
  color:var(--ink-dim);font-size:.85rem;line-height:1.5;
}
.form-consent input[type="checkbox"]{
  margin-top:3px;width:18px;height:18px;accent-color:var(--lime);flex-shrink:0;cursor:pointer;
}
.form-submit{margin-top:24px}
.form-status{
  margin-top:16px;padding:14px 18px;border-radius:12px;
  font-size:.9rem;display:none;
}
.form-status.success{display:block;background:rgba(200,255,46,.08);border:1px solid rgba(200,255,46,.3);color:var(--lime)}
.form-status.error{display:block;background:rgba(255,43,214,.08);border:1px solid rgba(255,43,214,.3);color:var(--magenta-2)}
