/* ============================================================
   MODERN CANNABIS — site.css
   Concept: "Monochrome house, colorful rooms."
   The MC frame is strictly black / white / graphite.
   Each brand carries ONE accent var, applied per-page or on hover.
   ------------------------------------------------------------
   BRAND ACCENT SWAP POINTS: replace the hex values below with
   exact colors from packaging files as they become available.
   Frozen Farms cyan (#0ABFDF) is exact (extracted from packaging).
   ============================================================ */

:root{
  /* House tokens */
  --ink:#0a0a0a;
  --paper:#ffffff;
  --smoke:#f5f5f3;
  --graphite:#6f6f6f;     /* carried over from current moderncannabis.com theme */
  --line:#e4e4e1;
  --line-dark:#222222;

  /* Brand accents — PLACEHOLDERS except --ff (exact) */
  --ot:#d99b2b;   /* Oil Traderz — amber / oil drip      [SWAP] */
  --rc:#2e5bff;   /* Rumble Club — storm blue            [SWAP] */
  --ff:#0abfdf;   /* Frozen Farms — exact cyan           [EXACT] */
  --ff-green:#98c93c; /* Frozen Farms sativa green        [EXACT] */
  --bt:#3e9b4f;   /* Bud Traderz — flower green          [SWAP] */
  --okc:#9b1b30;  /* Oklahoma Kush Co. — OK crimson      [SWAP] */
  --ec:#7b3fe4;   /* Exotic Collective — exotic violet   [SWAP] */
  --oc:#b87333;   /* Oil & Co — copper                   [SWAP] */

  --display:'Archivo Black','Arial Black',Impact,sans-serif;
  --body:'Archivo',Helvetica,Arial,sans-serif;
  --mono:'IBM Plex Mono','Courier New',monospace;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1280px;margin:0 auto;padding:0 24px}

/* ---------- utility type ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--graphite);
}
.display{
  font-family:var(--display);
  text-transform:uppercase;
  line-height:.95;
  letter-spacing:-.01em;
}

/* ---------- age gate ---------- */
#agegate{
  position:fixed;inset:0;z-index:1000;
  background:var(--ink);color:var(--paper);
  display:flex;align-items:center;justify-content:center;
  text-align:center;padding:24px;
}
#agegate.hidden{display:none}
#agegate .gate-mark{font-family:var(--display);font-size:1rem;letter-spacing:.3em;text-transform:uppercase;margin-bottom:2.2rem}
#agegate h1{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.6rem,4.5vw,2.8rem);line-height:1.05;margin-bottom:1rem}
#agegate p{color:#bdbdbd;max-width:46ch;margin:0 auto 2.2rem;font-size:.95rem}
#agegate .gate-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn{
  display:inline-block;
  font-family:var(--mono);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;
  padding:1rem 2.2rem;border:1px solid currentColor;cursor:pointer;background:transparent;color:inherit;
  transition:background .18s ease,color .18s ease;
}
.btn:hover,.btn:focus-visible{background:var(--paper);color:var(--ink)}
.btn:focus-visible{outline:2px solid var(--ff);outline-offset:3px}
.btn.solid{background:var(--paper);color:var(--ink)}
.btn.solid:hover{background:transparent;color:var(--paper)}
/* buttons on white sections */
.on-light .btn:hover,.on-light .btn:focus-visible{background:var(--ink);color:var(--paper)}
.on-light .btn.solid{background:var(--ink);color:var(--paper)}
.on-light .btn.solid:hover{background:transparent;color:var(--ink)}

/* ---------- header ---------- */
header.site{
  position:sticky;top:0;z-index:500;
  background:var(--paper);
  border-bottom:1px solid var(--line);
}
header.site .bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;max-width:1280px;margin:0 auto;
}
.logo{
  font-family:var(--display);
  font-size:1rem;letter-spacing:.26em;text-transform:uppercase;white-space:nowrap;
}
.logo span{color:var(--graphite)}
nav.main{display:flex;gap:28px}
nav.main a{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  padding:4px 0;border-bottom:1px solid transparent;
}
nav.main a:hover,nav.main a:focus-visible{border-bottom-color:var(--ink)}
@media(max-width:720px){
  nav.main{gap:16px}
  nav.main a.hide-m{display:none}
}
/* phones (portrait): stack the header into two rows so the full
   logo and nav are always visible */
@media(max-width:560px){
  header.site .bar{flex-direction:column;align-items:flex-start;gap:10px;padding:14px 20px}
  .logo{font-size:.9rem;letter-spacing:.22em}
  nav.main{width:100%;justify-content:space-between;gap:12px}
}

/* ---------- split hero (equal-weight: patients | dispensaries) ---------- */
.split-hero{display:grid;grid-template-columns:1fr 1fr;min-height:72vh;border-bottom:1px solid var(--line)}
.split-hero>a{
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(28px,5vw,64px);
  position:relative;overflow:hidden;
  transition:background .25s ease,color .25s ease;
}
.split-hero .half-label{margin-bottom:auto;padding-top:8px}
.split-hero h2{font-family:var(--display);text-transform:uppercase;font-size:clamp(2rem,4.6vw,4.2rem);line-height:.95;margin:2rem 0 1rem}
.split-hero p{max-width:42ch;color:var(--graphite);margin-bottom:1.6rem}
.split-hero .go{font-family:var(--mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase}
.half-patients{background:var(--paper);color:var(--ink)}
.half-wholesale{background:var(--ink);color:var(--paper);border-left:1px solid var(--line)}
.half-wholesale p{color:#a8a8a8}
.half-wholesale .eyebrow{color:#a8a8a8}
.half-patients:hover{background:var(--smoke)}
.half-wholesale:hover{background:#161616}
@media(max-width:860px){
  .split-hero{grid-template-columns:1fr;min-height:0}
  .split-hero>a{min-height:46vh}
  .half-wholesale{border-left:none;border-top:1px solid var(--line)}
}

/* ---------- statement strip ---------- */
.statement{padding:clamp(56px,9vw,120px) 0;border-bottom:1px solid var(--line)}
.statement h2{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.5rem,3.4vw,2.6rem);line-height:1.1;max-width:24ch}
.statement .chain{
  margin-top:2.6rem;display:flex;flex-wrap:wrap;gap:0;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite);
}
.statement .chain span{padding:.6rem 1rem;border:1px solid var(--line);border-right:none}
.statement .chain span:last-child{border-right:1px solid var(--line)}

/* ---------- brand index (signature element) ---------- */
.brand-index{border-bottom:1px solid var(--line)}
.brand-index .index-head{padding:40px 24px 8px;max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:8px}
.brand-row{
  --accent:var(--graphite);
  display:flex;align-items:center;gap:20px;
  padding:clamp(22px,3.6vw,40px) 24px;
  border-top:1px solid var(--line);
  position:relative;
  transition:background .22s ease,color .22s ease;
}
.brand-row .inner{max-width:1280px;margin:0 auto;width:100%;display:flex;align-items:center;gap:clamp(14px,3vw,40px)}
.brand-row .num{font-family:var(--mono);font-size:.72rem;color:var(--graphite);min-width:2.4em}
.brand-row .name{
  font-family:var(--display);text-transform:uppercase;
  font-size:clamp(1.5rem,5.4vw,3.6rem);line-height:1;flex:1;
  border-left:4px solid var(--accent);padding-left:clamp(12px,2vw,28px);
}
.brand-row .meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;text-align:right}
.brand-row .cat{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--graphite)}
.brand-row .dest{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase}
.brand-row:hover,.brand-row:focus-visible{background:var(--accent);color:var(--paper)}
.brand-row:hover .num,.brand-row:hover .cat,.brand-row:focus-visible .num,.brand-row:focus-visible .cat{color:rgba(255,255,255,.75)}
.brand-row:hover .name,.brand-row:focus-visible .name{border-left-color:var(--paper)}
.brand-row .badge{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  border:1px solid currentColor;padding:.3rem .6rem;margin-left:.8rem;vertical-align:middle;white-space:nowrap;
}
@media(max-width:640px){
  .brand-row .meta{display:none}
  .brand-row .name{font-size:1.45rem}
}

/* ---------- wholesale section (home) ---------- */
.wholesale{background:var(--ink);color:var(--paper);padding:clamp(56px,9vw,110px) 0}
.wholesale .grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,6vw,80px)}
.wholesale h2{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.8rem,3.8vw,3rem);line-height:1;margin:.8rem 0 1.2rem}
.wholesale p{color:#a8a8a8;max-width:48ch}
.wholesale .eyebrow{color:#8a8a8a}
.stat-list{display:grid;gap:0;border-top:1px solid var(--line-dark)}
.stat{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:1.1rem 0;border-bottom:1px solid var(--line-dark)}
.stat b{font-family:var(--display);font-size:1.05rem;text-transform:uppercase;letter-spacing:.02em}
.stat span{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:#8a8a8a;text-align:right}
.wholesale .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:2rem}
@media(max-width:860px){.wholesale .grid{grid-template-columns:1fr}}

/* ---------- footer ---------- */
footer.site{background:var(--ink);color:#8a8a8a;border-top:1px solid var(--line-dark);padding:48px 0 32px;font-size:.85rem}
footer.site .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;margin-bottom:2.4rem}
footer.site h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paper);margin-bottom:.9rem}
footer.site a:hover{color:var(--paper)}
footer.site ul{list-style:none}
footer.site li{margin-bottom:.45rem}
footer.site .legal{border-top:1px solid var(--line-dark);padding-top:1.4rem;font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;line-height:1.8}
@media(max-width:720px){footer.site .cols{grid-template-columns:1fr}}

/* ============================================================
   BRAND LANDING PAGE TEMPLATE
   Each brand page sets --accent on <body data-brand>
   ============================================================ */
body[data-brand]{--accent:var(--graphite)}
body[data-brand="bt"]{--accent:var(--bt)}
body[data-brand="okc"]{--accent:var(--okc)}
body[data-brand="ec"]{--accent:var(--ec)}
body[data-brand="ff"]{--accent:var(--ff)}
body[data-brand="oc"]{--accent:var(--oc)}

.brand-hero{
  background:var(--ink);color:var(--paper);
  padding:clamp(72px,12vw,150px) 0 clamp(48px,8vw,90px);
  border-bottom:6px solid var(--accent);
}
.brand-hero .eyebrow{color:var(--accent)}
.brand-hero h1{font-family:var(--display);text-transform:uppercase;font-size:clamp(2.6rem,8vw,6.4rem);line-height:.92;margin:1rem 0 1.2rem}
.brand-hero .tagline{font-size:clamp(1rem,2vw,1.25rem);color:#bdbdbd;max-width:52ch}
.brand-hero .hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:2.2rem}
.brand-hero .btn.accent{background:var(--accent);border-color:var(--accent);color:var(--paper)}
.brand-hero .btn.accent:hover{background:transparent;color:var(--accent)}

.brand-facts{border-bottom:1px solid var(--line);background:var(--paper)}
.brand-facts .row{display:grid;grid-template-columns:repeat(3,1fr)}
.brand-facts .cell{padding:clamp(22px,3.4vw,40px) 24px;border-right:1px solid var(--line)}
.brand-facts .cell:last-child{border-right:none}
.brand-facts .cell .k{font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--graphite);margin-bottom:.5rem}
.brand-facts .cell .v{font-family:var(--display);text-transform:uppercase;font-size:clamp(1rem,1.8vw,1.4rem);line-height:1.1}
@media(max-width:720px){.brand-facts .row{grid-template-columns:1fr}.brand-facts .cell{border-right:none;border-bottom:1px solid var(--line)}}

.lineup{padding:clamp(56px,8vw,100px) 0;border-bottom:1px solid var(--line)}
.lineup h2{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.6rem,3.2vw,2.4rem);margin:.6rem 0 2rem}
.strains{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.strain{padding:1.4rem;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.strain .type{font-family:var(--mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:.4rem}
.strain .nm{font-family:var(--display);text-transform:uppercase;font-size:1.02rem;line-height:1.15;margin-bottom:.35rem}
.strain .fmt{font-family:var(--mono);font-size:.7rem;color:var(--graphite)}

.find{background:var(--smoke);padding:clamp(56px,8vw,100px) 0;border-bottom:1px solid var(--line)}
.find h2{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.6rem,3.2vw,2.4rem);margin:.6rem 0 1rem}
.find p{color:var(--graphite);max-width:52ch;margin-bottom:1.8rem}
.find .cta-row{display:flex;gap:14px;flex-wrap:wrap}

.crumb{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
}
.crumb a{border-bottom:1px solid var(--line)}
.crumb a:hover{border-bottom-color:var(--ink)}

/* coming soon page */
.soon{min-height:64vh;display:flex;align-items:center;background:var(--ink);color:var(--paper)}
.soon h1{font-family:var(--display);text-transform:uppercase;font-size:clamp(2.4rem,7vw,5.6rem);line-height:.95;margin:1rem 0}
.soon .tagline{color:#bdbdbd;max-width:50ch;margin-bottom:2rem}

/* wholesale page extras */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.cat{padding:1.8rem;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.cat h3{font-family:var(--display);text-transform:uppercase;font-size:1.1rem;margin-bottom:.5rem}
.cat p{color:var(--graphite);font-size:.92rem}
.page-head{padding:clamp(56px,9vw,110px) 0 clamp(32px,5vw,56px);border-bottom:1px solid var(--line)}
.page-head h1{font-family:var(--display);text-transform:uppercase;font-size:clamp(2.2rem,6vw,4.6rem);line-height:.95;margin-top:.8rem}
.page-head p{color:var(--graphite);max-width:54ch;margin-top:1rem}
.section{padding:clamp(48px,7vw,90px) 0;border-bottom:1px solid var(--line)}
.section h2{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.5rem,3vw,2.2rem);margin:.6rem 0 1.6rem}
