/* ===== StrainLeaf theme ===== */
:root{
  color-scheme:dark;
  --bg:#0d1f16;
  --bg-2:#12291d;
  --surface:#183725;
  --surface-2:#214631;
  --surface-3:#102a1d;
  --line:rgba(234,245,236,.1);
  --line-strong:rgba(234,245,236,.18);
  --emerald:#46d98a;
  --lime:#b8e650;
  --mint:#b8f3d0;
  --tan:#d7a676;
  --text:#f1f8f2;
  --muted:#aec6b7;
  --soft:#7fa18c;
  --ink:#07150f;
  --danger:#ffad9d;
  --ring:rgba(184,230,80,.42);
  --radius:8px;
  --radius-lg:16px;
  --shadow:0 24px 70px rgba(0,0,0,.36);
  --header-h:72px;
  --ease:cubic-bezier(.2,.8,.2,1);
}

*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  scroll-padding-top:calc(var(--header-h) + 18px);
  -webkit-text-size-adjust:100%;
}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",Roboto,Arial,sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,#0c1b14 0%,#143021 46%,#0d1f16 100%);
  line-height:1.62;
  letter-spacing:0;
  min-height:100vh;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.is-locked,
body.nav-open{overflow:hidden}

a{color:var(--lime);text-decoration:none;text-underline-offset:4px}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
button,input,select{font:inherit}

.wrap{
  width:min(100% - 36px,1080px);
  margin:0 auto;
}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* accessibility: skip link + focus + reduced motion */
.skip-link{
  position:absolute;
  left:-9999px;
  top:0;
  z-index:2000;
  background:var(--lime);
  color:var(--ink);
  font-weight:850;
  padding:12px 18px;
  border-radius:0 0 12px 0;
}
.skip-link:focus{left:0;text-decoration:none}
:focus-visible{
  outline:3px solid var(--lime);
  outline-offset:3px;
  border-radius:8px;
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    transition-duration:.001ms !important;
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
  }
}

/* ---- header ---- */
header.site{
  position:sticky;
  top:0;
  z-index:950;
  padding-top:env(safe-area-inset-top);
  background:rgba(9,27,18,.82);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(18px) saturate(130%);
  -webkit-backdrop-filter:blur(18px) saturate(130%);
}
.nav{
  min-height:var(--header-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  position:relative;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  min-height:48px;
  color:var(--text);
  font-weight:820;
  font-size:1.1rem;
  letter-spacing:0;
}
.brand:hover{text-decoration:none}
.brand img{
  width:40px;
  height:40px;
  border-radius:12px;
  box-shadow:0 10px 26px rgba(0,0,0,.24);
}
.brand b{color:var(--lime)}
.nav-links{
  display:flex;
  align-items:center;
  gap:6px;
}
.nav-links a{
  color:var(--muted);
  min-height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 13px;
  border-radius:999px;
  font-weight:720;
  font-size:.95rem;
  transition:background-color .2s var(--ease),color .2s var(--ease),transform .2s var(--ease);
}
.nav-links a:hover,
.nav-links a:focus-visible,
.nav-links a[aria-current="page"]{
  color:var(--text);
  text-decoration:none;
  background:rgba(255,255,255,.07);
}
.nav-links .nav-cta{
  margin-left:4px;
  color:var(--ink);
  background:linear-gradient(120deg,var(--emerald),var(--lime));
  box-shadow:0 10px 26px rgba(70,217,138,.22);
}
.nav-links .nav-cta:hover,
.nav-links .nav-cta:focus-visible,
.nav-links .nav-cta[aria-current="page"]{
  color:var(--ink);
  background:linear-gradient(120deg,#51e496,#c4f15a);
}
.nav-toggle{
  position:absolute;
  width:1px;
  height:1px;
  margin:-1px;
  padding:0;
  opacity:0;
  overflow:hidden;
  pointer-events:none;
  clip:rect(0,0,0,0);
}
.nav-burger{
  display:none;
  width:48px;
  height:48px;
  border:1px solid var(--line-strong);
  border-radius:16px;
  background:rgba(255,255,255,.06);
  color:var(--text);
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
  position:relative;
  transition:background-color .2s var(--ease),border-color .2s var(--ease),transform .2s var(--ease);
}
.nav-burger:hover{background:rgba(255,255,255,.1)}
.nav-burger:active{transform:scale(.96)}
.nav-burger span:not(.sr-only){
  position:absolute;
  left:13px;
  right:13px;
  height:2px;
  border-radius:2px;
  background:currentColor;
  transition:transform .24s var(--ease),opacity .18s var(--ease),top .24s var(--ease);
}
.nav-burger span:nth-child(1){top:16px}
.nav-burger span:nth-child(2){top:23px}
.nav-burger span:nth-child(3){top:30px}
.nav-burger[aria-expanded="true"] span:nth-child(1){top:23px;transform:rotate(45deg)}
.nav-burger[aria-expanded="true"] span:nth-child(2){opacity:0;transform:scaleX(.2)}
.nav-burger[aria-expanded="true"] span:nth-child(3){top:23px;transform:rotate(-45deg)}

/* ---- hero ---- */
.hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,.9fr);
  align-items:center;
  gap:46px;
  padding:56px 0 42px;
}
.hero-copy{min-width:0}
.hero img.mark{
  width:88px;
  height:88px;
  border-radius:22px;
  margin:0 0 22px;
  box-shadow:0 18px 42px rgba(0,0,0,.34);
}
.eyebrow{
  margin:0 0 12px;
  color:var(--mint);
  font-size:.78rem;
  font-weight:850;
  letter-spacing:0;
  text-transform:uppercase;
}
.hero h1{
  font-size:4.05rem;
  margin:0;
  line-height:.98;
  letter-spacing:0;
  max-width:720px;
}
.hero h1 .grad,
.grad{
  background:linear-gradient(120deg,var(--emerald),var(--lime));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero p.lead{
  font-size:1.22rem;
  color:var(--muted);
  max-width:620px;
  margin:22px 0 28px;
}
.hero-actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:12px;
}
.hero-pills{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:20px;
}
.hero-pills span{
  min-height:36px;
  display:inline-flex;
  align-items:center;
  border:1px solid var(--line);
  border-radius:999px;
  padding:7px 11px;
  color:var(--muted);
  background:rgba(255,255,255,.045);
  font-size:.88rem;
  font-weight:700;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:48px;
  padding:13px 24px;
  border-radius:999px;
  font-weight:850;
  background:linear-gradient(120deg,var(--emerald),var(--lime));
  color:var(--ink);
  border:1px solid transparent;
  cursor:pointer;
  font-size:1rem;
  line-height:1.1;
  box-shadow:0 14px 30px rgba(70,217,138,.25);
  transition:transform .18s var(--ease),box-shadow .18s var(--ease),background-color .18s var(--ease),border-color .18s var(--ease);
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}
.btn:hover{
  transform:translateY(-2px);
  text-decoration:none;
  box-shadow:0 18px 38px rgba(70,217,138,.34);
}
.btn:active{transform:translateY(0) scale(.98)}
.btn.ghost{
  background:rgba(255,255,255,.035);
  color:var(--lime);
  border-color:var(--line-strong);
  box-shadow:none;
}
.btn.ghost:hover{background:rgba(255,255,255,.07);box-shadow:none}

/* ---- product preview ---- */
.app-preview{
  justify-self:end;
  width:min(100%,360px);
  border:1px solid var(--line-strong);
  border-radius:36px;
  padding:12px;
  background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.03));
  box-shadow:var(--shadow);
}
.app-screen{
  min-height:500px;
  border-radius:28px;
  padding:14px;
  overflow:hidden;
  background:
    linear-gradient(180deg,rgba(14,45,31,.96),rgba(8,24,17,.98)),
    var(--surface-3);
  border:1px solid rgba(255,255,255,.08);
}
.app-topbar,
.app-row,
.scan-card,
.inventory-card{
  display:flex;
  align-items:center;
}
.app-topbar{
  justify-content:space-between;
  margin-bottom:14px;
}
.app-title{
  font-weight:850;
  letter-spacing:0;
}
.app-dot{
  width:36px;
  height:36px;
  border-radius:50%;
  background:linear-gradient(120deg,var(--emerald),var(--lime));
  box-shadow:0 10px 24px rgba(70,217,138,.25);
}
.scan-card,
.inventory-card,
.metric-card{
  border:1px solid rgba(255,255,255,.09);
  background:rgba(255,255,255,.06);
  border-radius:20px;
}
.scan-card{
  min-height:122px;
  justify-content:center;
  flex-direction:column;
  gap:10px;
  margin-bottom:12px;
}
.scan-focus{
  width:88px;
  height:58px;
  border:2px solid rgba(184,230,80,.72);
  border-radius:14px;
  position:relative;
}
.scan-focus::before,
.scan-focus::after{
  content:"";
  position:absolute;
  inset:50% 12px auto;
  height:2px;
  background:linear-gradient(90deg,transparent,var(--lime),transparent);
}
.scan-focus::after{
  inset:auto 18px 18px;
  opacity:.5;
}
.scan-card strong{font-size:.92rem}
.app-row{
  gap:10px;
  margin-bottom:12px;
}
.metric-card{
  flex:1;
  padding:11px;
}
.metric-card span,
.inventory-meta span,
.scan-card span{
  display:block;
  color:var(--soft);
  font-size:.72rem;
  font-weight:800;
  letter-spacing:0;
  text-transform:uppercase;
}
.metric-card strong{
  display:block;
  margin-top:4px;
  font-size:1.08rem;
}
.inventory-card{
  gap:12px;
  padding:11px;
  margin-bottom:10px;
}
.leaf-chip{
  flex:0 0 auto;
  width:42px;
  height:42px;
  border-radius:12px;
  background:linear-gradient(145deg,rgba(70,217,138,.9),rgba(215,166,118,.9));
}
.inventory-meta{min-width:0}
.inventory-meta strong,
.inventory-meta span{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.inventory-meta strong{display:block}

/* ---- sections / cards ---- */
section{padding:clamp(34px,6vw,62px) 0}
@supports(content-visibility:auto){
  main section:not(.hero){
    content-visibility:auto;
    contain-intrinsic-size:520px;
  }
}
.section-title{
  font-size:2.25rem;
  line-height:1.08;
  letter-spacing:0;
  margin:0 0 8px;
}
.section-sub{
  color:var(--muted);
  margin:0 0 26px;
  max-width:660px;
}
.grid{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(auto-fit,minmax(245px,1fr));
}
.card{
  background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.035));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px;
  box-shadow:0 16px 42px rgba(0,0,0,.12);
  transition:transform .22s var(--ease),border-color .22s var(--ease),background-color .22s var(--ease);
}
.card:hover{
  transform:translateY(-3px);
  border-color:rgba(184,230,80,.28);
  background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.045));
}
.card h3{
  margin:0 0 8px;
  font-size:1.12rem;
  line-height:1.2;
  letter-spacing:0;
}
.card p{margin:0;color:var(--muted)}

.steps{
  counter-reset:step;
  display:grid;
  gap:14px;
}
.step{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:14px;
  align-items:start;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
  background:rgba(255,255,255,.035);
}
.step .num{
  flex:0 0 auto;
  width:42px;
  height:42px;
  border-radius:50%;
  display:grid;
  place-items:center;
  font-weight:850;
  color:var(--ink);
  background:linear-gradient(120deg,var(--emerald),var(--lime));
  box-shadow:0 12px 28px rgba(70,217,138,.22);
}
.step h3{margin:0 0 4px;font-size:1.1rem;line-height:1.22}
.step p{margin:0;color:var(--muted)}

.cta{
  text-align:center;
  background:linear-gradient(135deg,rgba(70,217,138,.12),rgba(215,166,118,.08));
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(34px,7vw,56px) 22px;
  margin:10px 0 20px;
  box-shadow:0 20px 58px rgba(0,0,0,.16);
}
.cta .section-sub{margin-left:auto;margin-right:auto}

/* ---- legal pages ---- */
.legal{
  max-width:820px;
  margin:0 auto;
  padding:clamp(34px,7vw,64px) 0;
}
.legal h1{
  font-size:3.2rem;
  line-height:1;
  letter-spacing:0;
  margin:0 0 16px;
}
.legal h2{
  margin:36px 0 10px;
  color:var(--mint);
  font-size:1.5rem;
  line-height:1.2;
}
.legal p,.legal li{color:var(--muted)}
.legal p{margin:0 0 16px}
.legal ul{padding-left:1.2rem}
.legal li{margin:0 0 10px}
.legal .updated{
  color:var(--tan);
  font-style:normal;
  font-weight:750;
}
.callout{
  background:rgba(255,255,255,.055);
  border:1px solid var(--line);
  border-left:4px solid var(--lime);
  border-radius:8px;
  padding:16px 18px;
  margin:24px 0;
  color:var(--text);
}
.page-action{margin-top:30px}

/* ---- download / store badges ---- */
.download-hero{
  text-align:center;
  display:block;
}
.download-hero .hero-copy{margin:0 auto;max-width:760px}
.download-hero img.mark{margin-left:auto;margin-right:auto}
.download-hero .lead{margin-left:auto;margin-right:auto}
.store-badges{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  margin:30px 0 6px;
}
.store-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:56px;
  line-height:0;
  border-radius:12px;
  transition:transform .18s var(--ease),box-shadow .18s var(--ease),filter .18s var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.store-badge:hover{
  transform:translateY(-2px);
  filter:brightness(1.05);
  box-shadow:0 12px 28px rgba(0,0,0,.26);
}
.store-badge:active{transform:translateY(0) scale(.98)}
.store-badge img{height:56px;width:auto}
.platforms{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  margin-top:8px;
}
.dl-note{
  color:var(--soft);
  font-size:.92rem;
  font-weight:720;
  margin:14px 0 0;
}
.dl-platforms{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.dl-card{
  background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.035));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px;
  box-shadow:0 18px 46px rgba(0,0,0,.14);
}
.dl-card h2{
  margin:0 0 8px;
  line-height:1.12;
  letter-spacing:0;
}
.dl-card p{color:var(--muted);margin:0 0 14px}
.dl-list{
  display:grid;
  gap:8px;
  padding:0;
  margin:0 0 20px;
  list-style:none;
}
.dl-list li{
  color:var(--muted);
  padding-left:22px;
  position:relative;
}
.dl-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.65em;
  width:9px;
  height:9px;
  border-radius:50%;
  background:linear-gradient(120deg,var(--emerald),var(--lime));
}

/* ---- public share cards ---- */
.btn[disabled],
.btn[aria-disabled="true"]{
  cursor:not-allowed;
  opacity:.55;
  transform:none;
  box-shadow:none;
}
.share-page{min-height:62vh}
.share-shell{
  max-width:920px;
  padding:42px 0 56px;
}
.share-state{
  max-width:680px;
  margin:0 auto;
  text-align:center;
  padding:48px 20px;
}
.share-state h1{
  margin:0 0 14px;
  font-size:2.6rem;
  line-height:1.06;
}
.share-state p{
  color:var(--muted);
  margin:0 auto 24px;
  max-width:520px;
}
.share-card{
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:0 24px 70px rgba(0,0,0,.2);
  overflow:hidden;
}
.share-card-header{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(220px,320px);
  gap:24px;
  align-items:stretch;
  padding:28px;
}
.share-card-copy h1{
  margin:0;
  font-size:3rem;
  line-height:1.02;
}
.share-description{
  margin:18px 0 0;
  color:var(--muted);
  max-width:620px;
}
.share-card-media{
  min-height:240px;
  border-radius:var(--radius);
  overflow:hidden;
  background:rgba(0,0,0,.2);
  border:1px solid var(--line);
}
.share-card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.share-meta-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.share-meta-item{
  min-height:94px;
  padding:18px;
  border-right:1px solid var(--line);
}
.share-meta-item:nth-child(3n){border-right:none}
.share-meta-item span{
  display:block;
  color:var(--soft);
  font-size:.78rem;
  font-weight:800;
  text-transform:uppercase;
}
.share-meta-item strong{
  display:block;
  margin-top:5px;
  font-size:1.18rem;
  line-height:1.2;
}
.share-details{
  display:grid;
  gap:22px;
  padding:28px;
}
.share-detail-group h2{
  margin:0 0 10px;
  color:var(--mint);
  font-size:1rem;
}
.share-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.share-chips span{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  border-radius:999px;
  padding:7px 11px;
  color:var(--muted);
  background:rgba(255,255,255,.05);
  border:1px solid var(--line);
  font-weight:700;
}
.share-card-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:22px 28px 28px;
  border-top:1px solid var(--line);
}
.share-card-footer p{
  margin:0;
  color:var(--soft);
  font-weight:750;
}
.share-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:10px;
}

/* ---- footer ---- */
footer.site{
  border-top:1px solid var(--line);
  margin-top:20px;
  padding:36px 0 calc(36px + env(safe-area-inset-bottom));
  color:var(--muted);
  background:rgba(7,18,13,.18);
}
.foot{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);
  gap:28px;
  align-items:start;
}
.foot .links{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.foot .links a{
  min-height:38px;
  display:inline-flex;
  align-items:center;
  color:var(--muted);
  border-radius:999px;
  padding:7px 10px;
}
.foot a:hover{color:var(--lime)}
.foot small{
  display:block;
  margin-top:12px;
  color:var(--soft);
}
.badge21{
  display:inline-grid;
  place-items:center;
  width:38px;
  height:38px;
  border-radius:50%;
  border:2px solid var(--ring);
  font-weight:850;
  color:var(--lime);
  font-size:.8rem;
}

/* ===== Age gate ===== */
.agegate{
  position:fixed;
  inset:0;
  z-index:1000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:calc(18px + env(safe-area-inset-top)) 18px calc(18px + env(safe-area-inset-bottom));
  background:rgba(5,14,10,.82);
  backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .24s var(--ease),visibility .24s var(--ease);
  overflow:auto;
  overscroll-behavior:contain;
}
.agegate.show{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
.agegate .box{
  width:min(100%,440px);
  max-height:calc(100vh - 36px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
  overflow:auto;
  background:linear-gradient(180deg,rgba(30,69,45,.98),rgba(12,32,22,.98));
  border:1px solid var(--line-strong);
  border-radius:28px;
  padding:28px;
  text-align:center;
  box-shadow:var(--shadow);
  transform:translateY(12px) scale(.98);
  transition:transform .28s var(--ease);
}
.agegate.show .box{transform:translateY(0) scale(1)}
.agegate img{
  width:76px;
  height:76px;
  border-radius:20px;
  margin:0 auto 16px;
}
.agegate h2{margin:0 0 8px;font-size:1.45rem;line-height:1.16}
.agegate p{color:var(--muted);margin:0 0 20px}
.agegate .dob{
  display:grid;
  grid-template-columns:minmax(0,1fr) 78px 104px;
  gap:10px;
  align-items:end;
  margin-bottom:8px;
}
.agegate label{
  display:block;
  font-size:.75rem;
  color:var(--muted);
  font-weight:800;
  margin-bottom:5px;
  text-align:left;
}
.agegate input,
.agegate select{
  width:100%;
  min-height:50px;
  padding:12px;
  border-radius:14px;
  text-align:center;
  border:1px solid var(--line-strong);
  background:rgba(0,0,0,.24);
  color:var(--text);
  font-size:1rem;
}
.agegate select{text-align:left;text-align-last:left}
.agegate input:focus,
.agegate select:focus{
  outline:none;
  border-color:var(--lime);
  box-shadow:0 0 0 4px var(--ring);
}
.agegate .err{
  color:var(--danger);
  min-height:22px;
  font-size:.92rem;
  margin:6px 0 14px;
}
.agegate .btn{width:100%}
.agegate .fine{
  font-size:.78rem;
  color:var(--soft);
  margin:18px 0 0;
}

/* ===== Cookie banner ===== */
.cookiebar{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:900;
  display:block;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(16px);
  transition:opacity .24s var(--ease),visibility .24s var(--ease),transform .24s var(--ease);
  padding:0 0 calc(14px + env(safe-area-inset-bottom));
}
.cookiebar.show{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0);
}
.cookiebar .inner{
  display:flex;
  gap:16px;
  align-items:center;
  justify-content:space-between;
  width:min(100% - 28px,980px);
  padding:14px;
  border:1px solid var(--line-strong);
  border-radius:22px;
  background:rgba(10,30,21,.96);
  box-shadow:0 18px 56px rgba(0,0,0,.38);
  backdrop-filter:blur(18px) saturate(130%);
  -webkit-backdrop-filter:blur(18px) saturate(130%);
}
.cookiebar p{
  margin:0;
  color:var(--muted);
  max-width:660px;
  font-size:.93rem;
  line-height:1.45;
}
.cookiebar .btns{
  display:flex;
  gap:10px;
  flex:0 0 auto;
}
.cookiebar .btn{
  min-height:44px;
  padding:10px 18px;
  font-size:.92rem;
}

.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .52s var(--ease),transform .52s var(--ease);
}
.reveal.is-visible{
  opacity:1;
  transform:none;
}

@media(max-width:860px){
  :root{--header-h:64px}
  .wrap{width:min(100% - 30px,1080px)}
  .nav-burger{display:inline-flex;align-items:center;justify-content:center}
  .nav-links{
    position:absolute;
    top:calc(100% + 8px);
    left:0;
    right:0;
    display:grid;
    grid-template-columns:1fr;
    gap:4px;
    align-items:stretch;
    padding:10px;
    max-height:calc(100vh - var(--header-h) - 26px - env(safe-area-inset-bottom));
    overflow:auto;
    overscroll-behavior:contain;
    background:rgba(8,27,18,.96);
    border:1px solid var(--line-strong);
    border-radius:22px;
    box-shadow:0 24px 70px rgba(0,0,0,.42);
    backdrop-filter:blur(20px) saturate(140%);
    -webkit-backdrop-filter:blur(20px) saturate(140%);
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translateY(-8px) scale(.98);
    transform-origin:top right;
    transition:opacity .22s var(--ease),transform .22s var(--ease),visibility .22s var(--ease);
  }
  .nav-links.is-open{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateY(0) scale(1);
  }
  .nav-links a{
    justify-content:flex-start;
    width:100%;
    min-height:52px;
    padding:14px 14px;
    border-radius:14px;
    font-size:1rem;
  }
  .nav-links .nav-cta{
    justify-content:center;
    margin:6px 0 0;
  }
  .hero{
    grid-template-columns:1fr;
    text-align:center;
    gap:30px;
    padding:36px 0 30px;
  }
  .hero img.mark{margin-left:auto;margin-right:auto}
  .hero h1{font-size:3.2rem}
  .hero p.lead{margin-left:auto;margin-right:auto}
  .hero-actions{justify-content:center}
  .hero-pills{justify-content:center}
  .app-preview{
    justify-self:center;
    width:min(100%,330px);
  }
  .app-screen{min-height:auto}
  .foot{grid-template-columns:1fr}
}

@media(max-width:640px){
  .wrap{width:min(100% - 28px,1080px)}
  section{padding:34px 0}
  .brand{font-size:1.05rem}
  .brand img{width:38px;height:38px}
  .hero-actions .btn{
    width:100%;
    max-width:360px;
  }
  .hero h1{font-size:2.75rem}
  .hero p.lead{font-size:1.08rem}
  .section-title{font-size:1.85rem}
  .legal h1{font-size:2.3rem}
  .legal h2{font-size:1.28rem}
  .hero-pills span{flex:1 1 auto;justify-content:center}
  .grid{grid-template-columns:1fr;gap:14px}
  .card{padding:20px}
  .card:hover{transform:none}
  .cta{padding:32px 18px}
  .cta .btn,
  .legal .btn{width:100%}
  .legal{padding:30px 0}
  .store-badges{
    flex-direction:column;
    gap:12px;
  }
  .store-badge,
  .store-badge img{
    width:100%;
    max-width:230px;
    height:auto;
  }
  .platforms{grid-template-columns:1fr}
  .dl-platforms{grid-template-columns:1fr}
  .dl-card{padding:20px}
  .share-shell{padding:30px 0 42px}
  .share-state{padding:36px 0}
  .share-state h1,
  .share-card-copy h1{font-size:2.2rem}
  .share-card-header{grid-template-columns:1fr;padding:20px;gap:18px}
  .share-card-media{min-height:220px}
  .share-meta-grid{grid-template-columns:1fr}
  .share-meta-item{
    min-height:auto;
    border-right:none;
    border-bottom:1px solid var(--line);
  }
  .share-meta-item:last-child{border-bottom:none}
  .share-details{padding:20px;gap:18px}
  .share-card-footer{
    align-items:stretch;
    flex-direction:column;
    padding:20px;
  }
  .share-actions{display:grid;grid-template-columns:1fr;width:100%}
  .share-actions .btn{width:100%}
  .cookiebar .inner{
    width:min(100% - 22px,980px);
    flex-direction:column;
    align-items:stretch;
    gap:12px;
    padding:14px;
  }
  .cookiebar .btns{display:grid;grid-template-columns:1fr 1fr}
  .cookiebar .btn{width:100%;padding-left:12px;padding-right:12px}
}

@media(max-width:430px){
  .agegate{align-items:flex-start}
  .agegate .box{padding:24px 20px;border-radius:24px}
  .agegate .dob{grid-template-columns:1fr 1fr}
  .hero h1{font-size:2.48rem}
  .agegate .col-m{grid-column:1 / -1}
  .agegate .col-y{grid-column:auto}
  .foot .links{display:grid;grid-template-columns:1fr 1fr;width:100%}
  .foot .links a{justify-content:center;background:rgba(255,255,255,.035)}
}
