/*
Theme Name: CannaBrandLab Child
Template: hello-elementor
Author: CannaBrandLab
Version: 2.0.0
Description: Editorial Engineer — Fraunces/Inter, asymmetric hero, dark strips, max-width prose, strict hierarchy.
*/

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,500;0,9..144,600;1,9..144,300;1,9..144,500&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@500&display=swap');

:root{
  --bone:#FAF7F2; --bone-2:#F2EEE5; --carbon:#0A0A0F; --ink:#0A0A0F;
  --hot:#FF2D87; --hot-text:#D9176C; --volt:#6E56FF;
  --concrete:#52525C; --line:rgba(10,10,15,.14); --line-dark:rgba(250,247,242,.16);
  --display:'Fraunces',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --grad:linear-gradient(120deg,#FF2D87 0%,#6E56FF 100%);
}

/* ========== BASE ========== */
html,body{background:var(--bone)!important;color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
*{box-sizing:border-box}
body{margin:0}
a{color:var(--hot-text);text-decoration:none;border-bottom:1px solid rgba(217,23,108,.22);transition:border-color .2s}
a:hover{border-color:var(--hot-text)}

/* ========== TYPOGRAPHY — OVERRIDE ELEMENTOR ========== */
h1,h2,h3,h4,
.elementor-widget-heading .elementor-heading-title{
  font-family:var(--display)!important;
  font-weight:300!important;
  color:var(--ink)!important;
  letter-spacing:-.025em;
  line-height:1.02;
  margin:0
}
.elementor-widget-heading h1.elementor-heading-title,
.cbl-h1 .elementor-heading-title{
  font-size:clamp(56px,8.5vw,128px)!important;
  font-weight:300!important;
  line-height:.92!important;
  letter-spacing:-.035em!important;
  margin:0 0 32px!important
}
.elementor-widget-heading h2.elementor-heading-title,
.cbl-h2 .elementor-heading-title{
  font-size:clamp(40px,5vw,72px)!important;
  font-weight:300!important;
  line-height:1.04!important;
  letter-spacing:-.025em!important;
  margin:0 0 28px!important;
  max-width:880px
}
.cbl-h2-dark .elementor-heading-title{color:var(--bone)!important}
.elementor-widget-heading h3.elementor-heading-title{font-size:clamp(24px,2.4vw,32px)!important;font-weight:500!important;letter-spacing:-.015em}

h1 em,h2 em,h3 em,
.elementor-heading-title em{font-style:italic;font-weight:300;color:var(--hot-text)}

/* Body text, max-width 640px per editorial measure rule */
.elementor-widget-text-editor{font-family:var(--sans);font-size:19px;line-height:1.65;color:#1a1a22;max-width:640px}
.elementor-widget-text-editor p{margin:0 0 20px}
.elementor-widget-text-editor strong{font-weight:600;color:var(--ink)}
.cbl-lede .elementor-widget-container p,
p.cbl-lede{font-size:22px!important;line-height:1.5;color:#2a2a36;max-width:600px;margin:0 0 36px}

/* Dark section text */
.cbl-dark .elementor-widget-text-editor,
.cbl-dark .elementor-widget-text-editor p{color:#c8c8d0}
.cbl-dark .elementor-widget-heading .elementor-heading-title{color:var(--bone)!important}
.cbl-lede-dark,.cbl-dark p.cbl-lede-dark{color:#c8c8d0!important}

/* ========== SECTIONS ========== */
.elementor-section,.e-con{max-width:none!important}
.e-con-inner,.elementor-container{max-width:1200px!important;width:100%;margin:0 auto}
.cbl-dark{background:var(--carbon)!important}

/* ========== HERO ========== */
.cbl-hero{min-height:86vh;display:flex;align-items:center;position:relative;overflow:hidden}
.cbl-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(1100px 600px at 88% -10%,rgba(110,86,255,.12),transparent 60%),
    radial-gradient(800px 500px at -5% 20%,rgba(255,45,135,.08),transparent 60%)
}
.cbl-hero > .e-con-inner,.cbl-hero .elementor-container{position:relative;z-index:1}
.cbl-hero-row{align-items:flex-start!important}

/* Stat card (right col of hero) */
.cbl-hero-right{align-self:stretch}
.cbl-stat-card{
  background:var(--carbon);color:var(--bone);
  padding:44px 36px;border-radius:20px;
  border:1px solid var(--line-dark);
  position:relative;overflow:hidden;height:100%;min-height:280px;
  display:flex;flex-direction:column;justify-content:space-between
}
.cbl-stat-card::after{
  content:'';position:absolute;top:-40%;right:-30%;width:400px;height:400px;
  background:var(--grad);filter:blur(80px);opacity:.35;z-index:0
}
.cbl-stat-card > *{position:relative;z-index:1}
.cbl-stat-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#ff7ab0;margin-bottom:20px}
.cbl-stat-body{font-family:var(--display);font-weight:300;font-size:28px;line-height:1.25;color:var(--bone);letter-spacing:-.01em}

/* ========== EYEBROW ========== */
.cbl-eyebrow{
  display:inline-block;font-family:var(--mono);font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--hot-text);
  padding:8px 16px;border:1px solid var(--line);border-radius:999px;
  background:#fff;margin:0 0 32px
}
.cbl-eyebrow-dark{background:transparent;color:#ff7ab0;border-color:var(--line-dark)}

/* ========== BUTTONS ========== */
.cbl-btn-row{flex-wrap:wrap}
.elementor-button,.elementor-button-link{
  font-family:var(--sans)!important;font-weight:600!important;
  font-size:14px!important;letter-spacing:.02em!important;
  padding:18px 32px!important;border-radius:999px!important;
  min-height:56px;display:inline-flex!important;align-items:center;justify-content:center;
  border:1.5px solid transparent!important;
  transition:all .25s cubic-bezier(.2,.8,.2,1)!important;
  text-decoration:none!important;border-bottom:1.5px solid transparent!important
}
.cbl-btn-primary .elementor-button{
  background:var(--grad)!important;color:#fff!important;
  box-shadow:0 10px 30px rgba(255,45,135,.28);border:none!important
}
.cbl-btn-primary .elementor-button:hover{
  transform:translateY(-2px);box-shadow:0 18px 44px rgba(255,45,135,.4);filter:brightness(1.08)
}
.cbl-btn-ghost .elementor-button{
  background:transparent!important;color:var(--ink)!important;
  border:1.5px solid var(--ink)!important;box-shadow:none
}
.cbl-btn-ghost .elementor-button:hover{background:var(--ink)!important;color:var(--bone)!important}
.cbl-dark .cbl-btn-ghost .elementor-button{color:var(--bone)!important;border-color:var(--bone)!important}
.cbl-dark .cbl-btn-ghost .elementor-button:hover{background:var(--bone)!important;color:var(--ink)!important}

/* ========== STAT STRIP ========== */
.cbl-stats{border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark)}
.cbl-stats .e-con-inner{gap:24px}
.cbl-stat-n{font-family:var(--display);font-weight:300;font-size:clamp(54px,6.5vw,88px);line-height:.95;color:var(--bone);letter-spacing:-.03em;margin-bottom:12px}
.cbl-stat-l{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#8a8a9a}

/* ========== PROSE ========== */
.cbl-prose{max-width:880px!important;margin:0 auto!important}
.cbl-prose .elementor-widget-heading h2.elementor-heading-title{margin-top:64px!important}
.cbl-prose .elementor-widget-heading:first-of-type h2.elementor-heading-title{margin-top:0!important}
.cbl-divider{height:1px;background:var(--line);margin:64px 0 0}
.cbl-ol{counter-reset:step;list-style:none;padding:0;margin:0}
.cbl-ol li{padding:20px 0;border-bottom:1px solid var(--line);font-size:18px;line-height:1.55;display:flex;gap:18px}
.cbl-ol li strong{font-family:var(--display);font-weight:500;color:var(--hot-text);font-size:22px;min-width:36px}
.cbl-h4{font-family:var(--display);font-weight:500;font-size:22px;margin:24px 0 8px}

.elementor-icon-list-items{display:grid;gap:14px;max-width:720px}
.elementor-icon-list-item{font-size:18px;line-height:1.55}
.elementor-icon-list-icon{color:var(--hot-text)!important}
.cbl-dark .elementor-icon-list-item,.cbl-dark .elementor-icon-list-text{color:var(--bone)!important}

/* ========== Q&A accordion ========== */
.cbl-qa-col{max-width:880px!important;margin:0 auto!important}
.cbl-qa{border-top:1px solid var(--line);padding:28px 0}
.cbl-qa:last-child{border-bottom:1px solid var(--line)}
.cbl-qa summary{font-family:var(--display);font-weight:500;font-size:24px;line-height:1.3;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:24px;color:var(--ink)}
.cbl-qa summary::-webkit-details-marker{display:none}
.cbl-qa summary::after{content:'+';font-family:var(--sans);font-weight:300;font-size:32px;color:var(--hot-text);transition:transform .3s}
.cbl-qa[open] summary::after{transform:rotate(45deg)}
.cbl-qa p{margin:20px 0 0;font-size:17px;line-height:1.65;max-width:680px;color:#3a3a46}

/* ========== PILLS / RELATED ========== */
.cbl-pills{display:flex;flex-wrap:wrap;gap:10px;margin:24px 0 0}
.cbl-pill{
  display:inline-flex;align-items:center;min-height:44px;padding:12px 20px;
  border:1px solid var(--line);border-radius:999px;background:#fff;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);text-decoration:none!important;transition:all .2s;border-bottom-width:1px
}
.cbl-pill:hover{background:var(--ink);color:var(--bone);border-color:var(--ink)}

/* ========== HEADER / FOOTER ========== */
.site-header,header.site-header,.elementor-location-header{
  background:rgba(250,247,242,.88)!important;backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);padding:16px 0;
  position:sticky;top:0;z-index:100
}
.site-header a{border:none}
footer,.site-footer,.elementor-location-footer{
  background:var(--carbon)!important;color:#8a8a9a;padding:88px 24px 56px;font-size:14px
}
footer a{color:#d0d0d8;border:none}
footer a:hover{color:var(--hot)}

/* ========== AGE GATE ========== */
.cbl-age-gate{position:fixed;inset:0;z-index:9999;background:rgba(10,10,15,.94);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(12px)}
.cbl-age-gate.hidden{display:none}
.cbl-age-gate .ag-card{background:var(--bone);border-radius:28px;max-width:480px;padding:56px 44px;text-align:center;box-shadow:0 40px 100px rgba(255,45,135,.28),0 0 0 2px rgba(110,86,255,.4);margin:20px}
.cbl-age-gate h2{font-family:var(--display);font-weight:300;font-size:38px;margin:0 0 14px;letter-spacing:-.02em}
.cbl-age-gate p{font-size:15px;color:#555;margin:0 0 30px}
.cbl-age-gate .ag-btns{display:flex;gap:14px;justify-content:center}
.cbl-age-gate .ag-btns button{padding:16px 32px;border-radius:999px;border:1.5px solid #555;background:transparent;color:#333;font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;font-weight:600;min-height:48px}
.cbl-age-gate .ag-btns .ag-yes{background:var(--grad);color:#fff;border:none}

/* ========== RESPONSIVE ========== */
@media(max-width:900px){
  .cbl-hero{min-height:auto;padding:96px 20px 64px!important}
  .cbl-hero-row{flex-direction:column!important;gap:48px!important}
  .cbl-hero-right,.cbl-hero-row > .e-con{width:100%!important}
  .cbl-stats .e-con-inner{flex-direction:row!important;flex-wrap:wrap}
  .cbl-stats .e-con-inner > .e-con{flex:1 1 calc(50% - 12px)!important;width:calc(50% - 12px)!important}
  .cbl-stat-n{font-size:48px}
  .elementor-widget-heading h1.elementor-heading-title{font-size:clamp(48px,12vw,72px)!important}
  .elementor-widget-heading h2.elementor-heading-title{font-size:clamp(32px,7vw,44px)!important}
}
@media(max-width:560px){
  .cbl-btn-row{flex-direction:column!important;align-items:stretch!important}
  .cbl-btn-row .elementor-button{width:100%}
  .cbl-stats .e-con-inner > .e-con{flex:1 1 100%!important;width:100%!important}
}

/* ========== ACCESSIBILITY ========== */
*:focus-visible{outline:2px solid var(--hot-text);outline-offset:3px;border-radius:4px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}
.skip-link{position:absolute;top:-40px;left:0;background:var(--carbon);color:#fff;padding:10px 18px;z-index:10000}
.skip-link:focus{top:0}
