/* ============================================================
   Space Gas USA — site stylesheet
   Visual direction: warm cosmic editorial. Deep plum foundation
   with a warm coral accent. Bold display typography. No decorative
   star patterns. Imagery does the heavy lifting.
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* palette — warm cosmic */
  --bg:        #17102a;
  --bg-2:      #1e1637;
  --surface:   #261c44;
  --card:      #2d2150;
  --card-2:    #362760;
  --border:    #45346e;
  --border-2:  #5d4a8a;

  --accent:    #8fb8ff;   /* cornflower — clear, airy, cosmic */
  --accent-h:  #b3cfff;
  --accent-2:  #c9b6ff;   /* lavender support — ties to the purple bg */
  --accent-deep:#5d8fe8;

  --success:   #4bd092;
  --success-bg:#0e3a27;
  --warning:   #ffbd5c;
  --error:     #ff5680;
  --error-bg:  #3d1326;

  --white:     #faf3e7;
  --muted:     #b2a4c9;
  --dim:       #7d6da0;

  /* type */
  --font-display: 'Archivo Black','Inter',system-ui,sans-serif;
  --font-body:    'Inter','Helvetica Neue',Arial,sans-serif;
  --font-serif:   'Fraunces','Georgia',serif;
  --font-mono:    'JetBrains Mono','DM Mono','Courier New',monospace;

  /* layout */
  --container:   1440px;
  --container-narrow: 960px;
  --header-h:    76px;
}

html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--white);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
  min-height:100vh;
  font-feature-settings:"ss01","cv02","cv11";
  -webkit-font-smoothing:antialiased;
}

img{max-width:100%;display:block;height:auto}
a{color:var(--accent);text-decoration:none;transition:color .18s}
a:hover{color:var(--accent-h)}
button{font-family:inherit;cursor:pointer}

/* ---------- Ambient gradients (replace the starfield) ---------- */
.site-bg{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(1000px 700px at 85% -10%, rgba(143,184,255,.22), transparent 60%),
    radial-gradient(900px 600px at 10% 110%, rgba(201,182,255,.1), transparent 55%),
    radial-gradient(1200px 700px at 50% 50%, rgba(69,52,110,.25), transparent 70%);
}

/* ---------- Ticker ---------- */
.ticker{
  position:relative;z-index:2;
  background:var(--white);color:var(--bg);
  font-family:var(--font-mono);font-weight:500;font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;
  overflow:hidden;white-space:nowrap;padding:8px 0;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.ticker-inner{display:inline-block;animation:ticker 42s linear infinite;will-change:transform}
.ticker-inner span{padding:0 22px}
.ticker-inner span.dot{color:var(--accent-deep)}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ---------- Header ---------- */
/* NOTE: no backdrop-filter here — it creates a containing block that traps
   the mobile nav overlay on iOS Safari (and some Chrome variants). Use a
   fully opaque background instead. */
.site-header{
  position:sticky;top:0;z-index:50;
  background:#17102a;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 44px;height:var(--header-h);
}
.site-header .logo{display:flex;align-items:center}
.site-header .logo img{height:44px;width:auto}
nav{display:flex;align-items:center;gap:28px}
nav a{
  color:var(--muted);font-weight:500;font-size:13px;letter-spacing:.02em;
  text-transform:none;transition:color .18s;padding:6px 0;position:relative;
}
nav a:hover{color:var(--white)}
nav a.is-active{color:var(--accent)}
nav a.is-active::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--accent);
}

.nav-toggle{display:none;background:transparent;border:none;width:40px;height:40px;padding:10px;cursor:pointer}
.nav-toggle span{display:block;height:2px;background:var(--white);margin:4px 0;transition:.2s;border-radius:2px}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;padding:13px 24px;font-family:var(--font-body);
  font-weight:600;font-size:14px;letter-spacing:.01em;
  border:1px solid transparent;border-radius:2px;cursor:pointer;
  transition:all .18s;text-decoration:none;
}
.btn-primary{background:var(--accent);color:#1a0e18;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-h);color:#1a0e18;border-color:var(--accent-h);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--white);border-color:var(--white)}
.btn-outline:hover{background:var(--white);color:var(--bg)}
.btn-ghost{background:transparent;color:var(--muted);border-color:var(--border)}
.btn-ghost:hover{color:var(--white);border-color:var(--border-2)}
.btn-danger{background:var(--error);color:#fff;border-color:var(--error)}
.btn-lg{padding:16px 32px;font-size:15px}
.btn-sm{padding:8px 14px;font-size:12px}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}

/* ---------- Main + section ---------- */
#main{position:relative;z-index:1}
section{padding:96px 44px;position:relative}
.wrap{max-width:var(--container);margin:0 auto}
.wrap-narrow{max-width:var(--container-narrow);margin:0 auto}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);margin-bottom:16px;
}
.eyebrow::before{content:"";display:inline-block;width:22px;height:1px;background:var(--accent)}
.section-title{
  font-family:var(--font-display);font-size:clamp(38px,5.5vw,68px);
  letter-spacing:-.015em;line-height:1.02;margin-bottom:20px;color:var(--white);
}
.section-title .accent{color:var(--accent)}
.section-title .serif{font-family:var(--font-serif);font-weight:500;font-style:italic;letter-spacing:-.02em}
.section-sub{font-size:17px;color:var(--muted);max-width:660px;margin-bottom:52px;line-height:1.55}

/* ---------- HERO ---------- */
.hero{
  padding:72px 44px 88px;position:relative;overflow:hidden;
}
.hero-wrap{
  display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:center;
  min-height:520px;
}
.hero-text .eyebrow{margin-bottom:24px}
.hero h1{
  font-family:var(--font-display);font-size:clamp(52px,7vw,96px);
  letter-spacing:-.025em;line-height:1;color:var(--white);margin-bottom:22px;
}
.hero-sub{font-size:18px;color:var(--muted);max-width:520px;margin:0 0 32px;line-height:1.55}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}

/* hero product — rocketship with cosmic glow */
.hero-product{
  position:relative;display:flex;align-items:center;justify-content:center;
  height:100%;min-height:520px;
}
.hero-product .hero-rocket{
  max-width:620px;width:100%;height:auto;position:relative;z-index:2;
  filter:drop-shadow(0 20px 40px rgba(0,0,0,.4)) drop-shadow(0 0 100px rgba(143,184,255,.35));
  animation:rocketFloat 8s ease-in-out infinite;
}
.hero-product .hero-glow{
  position:absolute;width:90%;height:90%;top:5%;left:5%;z-index:1;
  background:
    radial-gradient(circle at 75% 40%, rgba(143,184,255,.4) 0%, transparent 55%),
    radial-gradient(circle at 30% 70%, rgba(201,182,255,.2) 0%, transparent 60%);
  filter:blur(60px);pointer-events:none;
}
@keyframes rocketFloat{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-14px) rotate(1deg)}}

/* ---------- Band (full-width colored strip) ---------- */
.band{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.final-cta{
  background:linear-gradient(180deg,var(--bg-2) 0%,var(--surface) 100%);
  border-top:1px solid var(--border);padding:96px 44px;position:relative;
}
.final-cta::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:300px;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);
}
.band-light{background:var(--white);color:var(--bg)}
.band-light .section-title,.band-light .eyebrow{color:var(--bg)}
.band-light .section-title .accent{color:var(--accent-deep)}
.band-light .section-sub{color:#5a4f6e}
.band-light .eyebrow{color:var(--accent-deep)}
.band-light .eyebrow::before{background:var(--accent-deep)}
.band-light .btn-outline{color:var(--bg);border-color:var(--bg)}
.band-light .btn-outline:hover{background:var(--bg);color:var(--white)}

/* ---------- Feature cards ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.feature-card{
  padding:38px 30px;background:var(--card);border:1px solid var(--border);border-radius:3px;
  transition:border-color .2s,transform .2s;position:relative;
}
.feature-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.feature-card .kicker{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.feature-card h3{font-family:var(--font-display);font-size:38px;letter-spacing:-.015em;line-height:1;margin-bottom:6px;color:var(--white)}
.feature-card .sub-heading{font-family:var(--font-mono);font-size:13px;color:var(--muted);letter-spacing:.04em;margin-bottom:14px}
.feature-card p{font-size:14px;color:var(--muted);line-height:1.6}

/* ---------- Product scroller + product cards ---------- */
.product-scroller{margin:64px 0;overflow:hidden;padding:20px 0;position:relative}
.product-scroller::before,.product-scroller::after{content:"";position:absolute;top:0;bottom:0;width:120px;pointer-events:none;z-index:3}
.product-scroller::before{left:0;background:linear-gradient(90deg,var(--bg) 0%,transparent 100%)}
.product-scroller::after{right:0;background:linear-gradient(270deg,var(--bg) 0%,transparent 100%)}
.band .product-scroller::before{background:linear-gradient(90deg,var(--bg-2) 0%,transparent 100%)}
.band .product-scroller::after{background:linear-gradient(270deg,var(--bg-2) 0%,transparent 100%)}

.product-track{display:flex;gap:20px;width:max-content;animation:autoscroll 110s linear infinite;padding:0 32px}
.product-track:hover{animation-play-state:paused}
@keyframes autoscroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

.product-card{
  flex:0 0 220px;background:var(--card);border:1px solid var(--border);padding:22px 16px 18px;
  text-align:center;border-radius:3px;position:relative;transition:all .2s;
}
.product-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.3)}
.product-card img{width:100%;height:180px;object-fit:contain;margin-bottom:14px;filter:drop-shadow(0 16px 24px rgba(0,0,0,.5))}
.product-card .size-tag{
  position:absolute;top:12px;right:12px;background:var(--accent);color:#1a0e18;
  font-family:var(--font-mono);font-size:10px;font-weight:600;padding:4px 8px;
  border-radius:2px;letter-spacing:.06em;
}
.product-card .name{font-family:var(--font-display);font-size:19px;letter-spacing:-.01em;color:var(--white);line-height:1.1}
.product-card .app{font-size:12px;color:var(--muted);margin-top:8px;line-height:1.45;min-height:34px}

/* product grid (products.php) */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px;margin-top:36px}
.product-grid .product-card{flex:unset}

/* ---------- Flavor pantry (homepage — now uses canister thumbs) ---------- */
.flavor-pantry{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin-top:52px;border:1px solid var(--border);background:var(--border)}
.flavor-chip{
  background:var(--surface);padding:22px 16px 20px;text-align:center;
  transition:background .2s,transform .2s;position:relative;
  display:flex;flex-direction:column;align-items:center;
}
.flavor-chip:hover{background:var(--card);transform:none}
.flavor-chip::after{
  content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--_swatch,var(--accent));opacity:.7;
}
.flavor-chip img{width:90px;height:90px;object-fit:contain;margin-bottom:10px;filter:drop-shadow(0 8px 14px rgba(0,0,0,.4))}
.flavor-chip .name{font-family:var(--font-display);font-size:15px;color:var(--white);line-height:1.1;letter-spacing:-.01em}
.flavor-chip .app{font-size:11px;color:var(--muted);line-height:1.4;margin-top:6px;min-height:32px}

/* ---------- Applications grid ---------- */
.apps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.app-tile{
  padding:32px 26px;background:var(--card);border:1px solid var(--border);border-radius:3px;
  transition:border-color .2s,transform .2s;
}
.app-tile:hover{border-color:var(--accent);transform:translateY(-3px)}
.app-tile .num{font-family:var(--font-mono);font-size:11px;color:var(--accent);letter-spacing:.14em;margin-bottom:14px}
.app-tile h4{font-family:var(--font-display);font-size:22px;letter-spacing:-.01em;margin-bottom:10px;color:var(--white);line-height:1.15}
.app-tile p{font-size:14px;color:var(--muted);line-height:1.6}

/* ---------- Spec strip ---------- */
.spec-section{padding:52px 44px!important}
.spec-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border:1px solid var(--border);background:var(--card);border-radius:3px;overflow:hidden;
}
.spec-strip .spec{padding:28px 22px;border-right:1px solid var(--border);text-align:center}
.spec-strip .spec:last-child{border-right:none}
.spec-strip .num{font-family:var(--font-display);font-size:44px;color:var(--accent);line-height:1;letter-spacing:-.02em}
.spec-strip .label{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;margin-top:10px}
.spec-strip .sub{font-size:12px;color:var(--dim);margin-top:6px;line-height:1.4}

/* ---------- Forms ---------- */
.form-stack{display:flex;flex-direction:column;gap:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{display:block;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);margin-bottom:8px}
.field-hint{font-size:12px;color:var(--dim);margin-top:4px}
input[type="text"],input[type="email"],input[type="tel"],input[type="number"],
input[type="password"],input[type="url"],input[type="search"],textarea,select{
  width:100%;padding:13px 14px;background:var(--bg-2);color:var(--white);
  border:1px solid var(--border);border-radius:2px;font-family:inherit;font-size:15px;transition:border-color .15s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(143,184,255,.22)}
textarea{min-height:110px;resize:vertical}
input[type="checkbox"]{accent-color:var(--accent);margin-right:8px;transform:scale(1.1)}
.cert-list{display:flex;flex-direction:column;gap:12px;background:var(--bg-2);border:1px solid var(--border);
  border-radius:2px;padding:22px}
.cert-item{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:var(--white);line-height:1.5;cursor:pointer}
.cert-item input{margin-top:4px;flex-shrink:0}
.flash{padding:14px 16px;border-radius:2px;font-size:14px;margin-bottom:18px;border-left:3px solid}
.flash-error{background:var(--error-bg);color:var(--error);border-left-color:var(--error)}
.flash-success{background:var(--success-bg);color:var(--success);border-left-color:var(--success)}
.flash-info{background:rgba(143,184,255,.1);color:var(--accent);border-left-color:var(--accent)}

/* ---------- Order builder ---------- */
.order-head{background:var(--card);border:1px solid var(--border);border-radius:3px;padding:26px;margin-bottom:24px;
  display:grid;grid-template-columns:1fr 1fr;gap:24px}
.order-head h1{font-family:var(--font-display);font-size:48px;letter-spacing:-.015em;line-height:1}
.order-head p{font-size:14px;color:var(--muted);max-width:520px}
.size-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:24px}
.size-column{background:var(--card);border:1px solid var(--border);border-radius:3px;padding:22px;display:flex;flex-direction:column}
.size-column h2{font-family:var(--font-display);font-size:52px;letter-spacing:-.02em;text-align:center;color:var(--accent);line-height:1}
.size-column .per-layer{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;color:var(--muted);
  text-transform:uppercase;text-align:center;margin:6px 0 14px}
.size-column .mix-btn{width:100%;padding:12px;margin-bottom:16px;background:transparent;color:var(--accent);
  border:1px solid var(--accent);border-radius:2px;cursor:pointer;font-size:12px;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;transition:all .15s;font-family:var(--font-body)}
.size-column .mix-btn:hover{background:var(--accent);color:#1a0e18}
.flavor-row{display:flex;align-items:center;gap:10px;padding:8px;border-radius:2px;transition:background .15s}
.flavor-row + .flavor-row{margin-top:2px}
.flavor-row:hover{background:rgba(255,255,255,.03)}
.flavor-row .thumb{width:44px;height:44px;flex-shrink:0;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.35))}
.flavor-row .info{flex:1;min-width:0}
.flavor-row .name{font-size:13px;font-weight:600;color:var(--white);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.flavor-row .app{font-size:10px;color:var(--dim);line-height:1.3;margin-top:2px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.count-group{display:flex;align-items:center;gap:3px;flex-shrink:0}
.count-group button{width:28px;height:28px;background:transparent;color:var(--white);border:1px solid var(--border);
  border-radius:2px;cursor:pointer;font-size:16px;line-height:0;padding:0;transition:all .15s;display:grid;place-items:center}
.count-group button:hover{background:var(--accent);color:#1a0e18;border-color:var(--accent)}
.count-group input{width:56px;padding:5px;text-align:center;background:var(--bg-2);color:var(--white);
  border:1px solid var(--border);border-radius:2px;font-family:var(--font-mono);font-size:13px}
.count-group input::-webkit-outer-spin-button,.count-group input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.count-group input[type="number"]{-moz-appearance:textfield}

.order-status{text-align:center;padding:16px 20px;border-radius:2px;font-weight:600;font-size:15px;
  background:var(--error-bg);color:var(--error);border-left:3px solid var(--error);margin-bottom:14px}
.order-status.valid{background:var(--success-bg);color:var(--success);border-left-color:var(--success)}
.order-summary{display:grid;gap:0;background:var(--card);border:1px solid var(--border);
  border-radius:3px;margin-bottom:16px}
.order-summary .cell{text-align:center;padding:16px;border-right:1px solid var(--border)}
.order-summary .cell:last-child{border-right:none}
.order-summary .cell .label{font-family:var(--font-mono);font-size:10px;color:var(--muted);
  letter-spacing:.16em;text-transform:uppercase;margin-bottom:6px}
.order-summary .cell .val{font-family:var(--font-display);font-size:30px;color:var(--white);letter-spacing:-.02em;line-height:1}
.order-summary .cell .val.muted{color:var(--dim)}
.order-summary .cell .sub{font-size:11px;color:var(--muted);margin-top:4px}

.order-cert{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:2px;padding:20px;margin-bottom:18px}
.order-cert label{font-family:inherit;font-size:14px;letter-spacing:0;text-transform:none;color:var(--white);
  display:flex;gap:10px;align-items:flex-start;cursor:pointer;line-height:1.5;margin-bottom:0}

/* ---------- Recipe rows ---------- */
.recipe-layout{display:grid;grid-template-columns:300px 1fr;gap:56px;align-items:start}
.recipe-canister{
  position:relative;text-align:center;padding:8px 0;
}
.recipe-canister a{display:block;background:transparent}
.recipe-canister img{
  max-width:240px;margin:0 auto 18px;background:transparent;
  filter:drop-shadow(0 18px 30px rgba(0,0,0,.45)) drop-shadow(0 0 40px rgba(143,184,255,.2));
  transition:transform .3s ease;
}
.recipe-canister:hover img{transform:translateY(-6px)}
.recipe-canister .flavor-name{
  font-family:var(--font-display);font-size:22px;letter-spacing:-.01em;
  color:var(--white);line-height:1.1;margin-bottom:6px;
}
.recipe-canister .flavor-meta{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;
  color:var(--accent);text-transform:uppercase;
}
.recipe-body h2{
  font-family:var(--font-display);font-size:42px;letter-spacing:-.015em;
  line-height:1.02;margin:8px 0 14px;color:var(--white);
}
.recipe-body .recipe-desc{color:var(--muted);margin-bottom:26px;font-size:15px;line-height:1.6}
.recipe-details{display:grid;grid-template-columns:1fr 1.15fr;gap:32px;margin-bottom:14px}
.recipe-details h3{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;
  color:var(--accent);text-transform:uppercase;margin-bottom:12px;
}
.recipe-details ul,.recipe-details ol{
  color:var(--muted);font-size:14px;line-height:1.7;padding-left:20px;
}
.recipe-details ol li{margin-bottom:8px}
.chef-note{
  margin-top:16px;padding:16px 18px;background:var(--card);
  border-left:3px solid var(--accent);border-radius:3px;
  font-size:13px;color:var(--muted);line-height:1.6;font-style:italic;
}
.chef-note strong{color:var(--accent);font-style:normal}

@media (max-width:900px){
  .recipe-row{padding:44px 22px!important}
  .recipe-layout{grid-template-columns:1fr;gap:28px}
  .recipe-canister{padding:24px 18px}
  .recipe-canister img{max-width:180px}
  .recipe-body h2{font-size:32px}
  .recipe-details{grid-template-columns:1fr;gap:22px}
}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(10,6,20,.88);z-index:200;display:none;
  align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(4px)}
.modal-overlay[aria-hidden="false"]{display:flex;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{
  background:var(--surface);border:1px solid var(--border-2);border-radius:3px;
  max-width:560px;width:100%;box-shadow:0 30px 90px rgba(0,0,0,.7);
  max-height:min(92vh, 780px);border-top:3px solid var(--accent);
  display:flex;flex-direction:column;overflow:hidden;
}
.modal-scroll{overflow-y:auto;padding:36px 34px 24px;-webkit-overflow-scrolling:touch}
.modal-header{text-align:center;margin-bottom:18px}
.modal-logo{height:48px;margin:0 auto}
.modal h2{font-family:var(--font-display);font-size:28px;letter-spacing:-.015em;text-align:center;margin-bottom:14px;line-height:1.1}
.modal p{font-size:14px;color:var(--muted);margin-bottom:12px;line-height:1.55}
.modal-cert-intro{color:var(--white);font-size:14px;margin-bottom:6px}
.modal-certs{list-style:none;margin:0 0 12px;padding:0}
.modal-certs li{font-size:13px;color:var(--muted);padding:5px 0 5px 22px;position:relative;line-height:1.45}
.modal-certs li::before{content:"→";position:absolute;left:0;top:5px;color:var(--accent);font-weight:700}
.modal-fine-print{font-size:11px;color:var(--dim);font-style:italic;padding:12px 14px;background:var(--bg);
  border-radius:2px;border-left:2px solid var(--border);margin-bottom:0}
.modal-actions{
  flex-shrink:0;padding:18px 24px;background:var(--bg-2);
  display:flex;gap:10px;justify-content:center;flex-wrap:wrap;
  border-top:1px solid var(--border);
}
.modal-actions .btn{min-width:0}

/* ---------- Footer ---------- */
.site-footer{background:var(--bg-2);border-top:1px solid var(--border);padding:72px 44px 0;margin-top:0;position:relative;z-index:1}
.footer-grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px}
.footer-col h4{font-family:var(--font-display);font-size:14px;letter-spacing:-.005em;color:var(--white);
  margin-bottom:18px;text-transform:none}
.footer-col a{display:block;color:var(--muted);font-size:13px;margin-bottom:10px;transition:color .18s}
.footer-col a:hover{color:var(--accent)}
.footer-logo{height:44px;margin-bottom:18px}
.footer-pitch{font-size:13px;color:var(--muted);max-width:340px;line-height:1.65}
.legal-strip{max-width:var(--container);margin:0 auto;padding:22px 0 26px;border-top:1px solid var(--border);
  font-size:11px;color:var(--dim);line-height:1.7;letter-spacing:.01em}

/* ---------- Cards / content pages ---------- */
.prose{max-width:var(--container-narrow);margin:0 auto}
.prose h1{font-family:var(--font-display);font-size:clamp(44px,6vw,78px);letter-spacing:-.02em;line-height:1;margin-bottom:22px}
.prose h2{font-family:var(--font-display);font-size:30px;letter-spacing:-.01em;margin-top:40px;margin-bottom:14px;color:var(--white)}
.prose h2 + p::first-letter{color:var(--accent)}
.prose h3{font-family:var(--font-display);font-size:20px;margin-top:28px;margin-bottom:10px;color:var(--accent)}
.prose p{margin-bottom:16px;color:var(--muted);line-height:1.7}
.prose ul,.prose ol{margin:0 0 16px 22px;color:var(--muted);line-height:1.7}
.prose li{margin-bottom:6px}
.prose strong{color:var(--white)}
.prose a:not(.btn){color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.prose .info-card{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:2px;padding:24px;margin:22px 0}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:3px;background:var(--card)}
table{width:100%;border-collapse:collapse;font-size:14px}
thead th{background:var(--bg-2);text-align:left;padding:14px 16px;font-family:var(--font-mono);font-size:11px;
  letter-spacing:.14em;color:var(--muted);text-transform:uppercase;border-bottom:1px solid var(--border);font-weight:500}
tbody td{padding:14px 16px;border-bottom:1px solid var(--border);color:var(--white)}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:rgba(255,255,255,.02)}
.status-pill{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;
  letter-spacing:.04em;text-transform:lowercase}
.status-pill.pending{background:rgba(255,189,92,.12);color:var(--warning)}
.status-pill.confirmed{background:rgba(143,184,255,.14);color:var(--accent)}
.status-pill.fulfilling{background:rgba(201,182,255,.15);color:var(--accent-2)}
.status-pill.shipped,.status-pill.delivered{background:rgba(75,208,146,.15);color:var(--success)}
.status-pill.closed{background:rgba(255,255,255,.08);color:var(--muted)}
.status-pill.cancelled{background:rgba(255,86,128,.12);color:var(--error)}

/* ---------- Admin layout ---------- */
.admin-shell{min-height:100vh;display:grid;grid-template-columns:240px 1fr}
.admin-sidebar{background:var(--bg-2);border-right:1px solid var(--border);padding:24px 0}
.admin-sidebar .brand{display:flex;align-items:center;gap:12px;padding:0 22px 22px;border-bottom:1px solid var(--border);margin-bottom:14px}
.admin-sidebar .brand img{height:36px}
.admin-sidebar .brand .name{font-family:var(--font-display);font-size:18px;letter-spacing:-.01em;color:var(--white)}
.admin-sidebar nav{flex-direction:column;gap:0;align-items:stretch}
.admin-sidebar nav a{display:block;padding:11px 22px;font-size:13px;letter-spacing:0;border-left:3px solid transparent;color:var(--muted);text-transform:none}
.admin-sidebar nav a::after{display:none}
.admin-sidebar nav a:hover{color:var(--white);background:rgba(255,255,255,.03)}
.admin-sidebar nav a.is-active{color:var(--accent);border-left-color:var(--accent);background:rgba(143,184,255,.1)}
.admin-sidebar .logout{margin:28px 22px 0;padding-top:20px;border-top:1px solid var(--border)}
.admin-main{padding:36px 44px}
.admin-main h1{font-family:var(--font-display);font-size:44px;letter-spacing:-.015em;margin-bottom:22px}
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:36px}
.admin-stat{background:var(--card);border:1px solid var(--border);border-radius:3px;padding:20px}
.admin-stat .label{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;color:var(--muted);
  text-transform:uppercase;margin-bottom:8px}
.admin-stat .val{font-family:var(--font-display);font-size:36px;letter-spacing:-.02em;color:var(--white);line-height:1}
.admin-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:12px;flex-wrap:wrap}
.admin-bar input[type="search"],.admin-bar select{max-width:260px}

/* ---------- Print (packing slip) ---------- */
@media print{
  .no-print,.ticker,.site-header,.site-footer,.modal-overlay,.admin-sidebar,.site-bg{display:none!important}
  body{background:#fff;color:#000}
  .admin-shell{display:block}
  .admin-main{padding:0}
  .packing-slip{padding:30px;color:#000}
  .packing-slip h1{color:#000}
  .packing-slip .banner{background:#000;color:#fff;padding:10px;text-align:center;font-family:var(--font-mono);
    font-size:11px;letter-spacing:.1em;margin-bottom:20px}
  .packing-slip table{border:1px solid #000}
  .packing-slip th,.packing-slip td{border:1px solid #000;padding:8px}
}

/* ---------- Responsive ---------- */
@media (max-width:1100px){
  .flavor-pantry{grid-template-columns:repeat(4,1fr)}
  .footer-grid{grid-template-columns:2fr 1fr 1fr;gap:36px}
}

@media (max-width:900px){
  .site-header{padding:0 20px}
  .nav-toggle{display:block;z-index:60}

  /* Mobile nav — fullscreen slide-in overlay.
     Scoped to #siteNav so it never conflicts with any other <nav>. */
  #siteNav{
    position:fixed;
    top:var(--header-h);left:0;right:0;bottom:0;width:100%;
    background:rgba(17,10,36,.98);
    -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
    display:flex;flex-direction:column;align-items:stretch;gap:0;
    padding:20px 24px 40px;
    transform:translateX(100%);transition:transform .28s ease-out;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    z-index:55;
  }
  #siteNav.is-open{transform:translateX(0)}
  #siteNav a{
    display:block;padding:18px 4px;
    border-bottom:1px solid var(--border);
    font-size:17px;font-weight:500;color:var(--white);
    text-transform:none;letter-spacing:0;
  }
  #siteNav a:hover,#siteNav a:active{color:var(--accent)}
  #siteNav a.is-active{color:var(--accent)}
  #siteNav a.is-active::after{display:none}
  #siteNav .btn{
    margin-top:24px;text-align:center;
    padding:16px 24px;font-size:15px;
    border-bottom:none;
  }
  #siteNav .btn.btn-outline{color:var(--white);border-color:var(--white)}
  #siteNav .btn.btn-outline:hover{background:var(--white);color:var(--bg)}

  /* Modal on mobile — fill more of the screen, less padding */
  .modal-overlay{padding:0}
  .modal{max-height:100vh;max-height:100dvh;height:100vh;height:100dvh;border-radius:0;border:none;border-top:3px solid var(--accent)}
  .modal-scroll{padding:28px 22px 18px}
  .modal h2{font-size:24px}
  .modal-actions{padding:16px 20px;gap:8px}
  .modal-actions .btn{flex:1;padding:14px 16px}
  section{padding:60px 22px}
  .spec-section{padding:40px 22px!important}
  .hero{padding:48px 22px 64px}
  .hero-wrap{grid-template-columns:1fr;gap:40px;min-height:auto;text-align:center}
  .hero-sub{margin-left:auto;margin-right:auto}
  .hero-ctas{justify-content:center}
  .hero-product{min-height:320px;order:-1}
  .hero-product .hero-rocket{max-width:420px}
  .feature-grid{grid-template-columns:1fr;gap:14px}
  .size-grid,.order-head{grid-template-columns:1fr;gap:14px}
  .flavor-pantry{grid-template-columns:repeat(3,1fr)}
  .apps-grid{grid-template-columns:1fr;gap:12px}
  .spec-strip{grid-template-columns:repeat(2,1fr)}
  .spec-strip .spec:nth-child(2n){border-right:none}
  .spec-strip .spec:nth-child(-n+2){border-bottom:1px solid var(--border)}
  .order-summary{grid-template-columns:repeat(2,1fr)}
  .order-summary .cell{border-right:1px solid var(--border)}
  .order-summary .cell:nth-child(2n){border-right:none}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .form-row{grid-template-columns:1fr}
  .admin-shell{grid-template-columns:1fr}
  .admin-sidebar{position:sticky;top:0;z-index:40;padding:12px 0}
  .admin-sidebar .brand{padding:0 16px 14px}
  .admin-sidebar nav{position:static;flex-direction:row;transform:none;padding:8px;overflow-x:auto;white-space:nowrap;background:var(--bg-2)}
  .admin-sidebar nav a{border-left:none;border-bottom:2px solid transparent;padding:8px 14px}
  .admin-sidebar nav a.is-active{border-bottom-color:var(--accent);border-left-color:transparent}
  .admin-sidebar .logout{margin:8px;padding-top:8px}
  .admin-main{padding:22px}
  .admin-stats{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:560px){
  .hero h1{font-size:clamp(40px,9vw,56px)}
  .hero-product{min-height:240px}
  .hero-product .hero-rocket{max-width:300px}
  .flavor-pantry{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .product-card{flex:0 0 180px}
  .order-head h1{font-size:34px}
  .spec-strip{grid-template-columns:1fr}
  .spec-strip .spec{border-right:none!important;border-bottom:1px solid var(--border)}
  .spec-strip .spec:last-child{border-bottom:none}
}
