
:root{
  --bg:#02060d;
  --panel:#07111d;
  --panel2:#0a1624;
  --blue:#00a7ff;
  --blue2:#005dff;
  --cyan:#60d6ff;
  --steel:#d8e4f2;
  --muted:#a9b7c7;
  --warning:#ffd166;
  --line:rgba(80,190,255,.24);
  --shadow:0 30px 80px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html{
  scrollbar-width:auto;
  scrollbar-color:var(--cyan) rgba(0,167,255,.18);
}
html::-webkit-scrollbar{width:16px;height:16px}
html::-webkit-scrollbar-track{
  background:linear-gradient(180deg,rgba(0,167,255,.18),rgba(2,6,13,.92));
  border-left:1px solid rgba(96,214,255,.24);
  box-shadow:inset 0 0 16px rgba(0,167,255,.22);
}
html::-webkit-scrollbar-thumb{
  border:4px solid rgba(2,6,13,.92);
  border-radius:999px;
  background:linear-gradient(180deg,var(--cyan),var(--blue2));
  box-shadow:0 0 18px rgba(96,214,255,.62);
}
body{
  margin:0;
  background:
    radial-gradient(circle at 20% 0%,rgba(0,119,255,.28),transparent 34%),
    radial-gradient(circle at 80% 20%,rgba(0,183,255,.16),transparent 28%),
    linear-gradient(180deg,#02050a 0%,#07111d 42%,#02050a 100%);
  color:white;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.site-shell{overflow:hidden}
.age-gate{
  position:fixed; inset:0; z-index:9999; display:grid; place-items:center;
  background:radial-gradient(circle at center,rgba(0,75,150,.35),rgba(0,0,0,.94));
  padding:24px;
}
.age-card{
  max-width:620px; width:100%; background:rgba(5,14,25,.96); border:1px solid var(--line);
  border-radius:26px; padding:32px; text-align:center; box-shadow:var(--shadow);
}
.age-card img{width:150px;margin:0 auto 14px;border-radius:20px}
.age-card h1{font-size:clamp(2rem,6vw,4rem);line-height:.95;margin:0 0 12px;letter-spacing:0}
.age-card p{color:var(--muted);margin:0 auto 20px;max-width:470px}
.age-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
button,.btn{
  cursor:pointer;border:none;border-radius:999px;padding:13px 20px;font-weight:900;
  color:white;background:linear-gradient(135deg,var(--blue),var(--blue2));
  box-shadow:0 0 25px rgba(0,135,255,.35);
}
.btn.secondary,button.secondary{background:rgba(255,255,255,.08);border:1px solid var(--line)}
.notice{
  color:#b9c8d8;font-size:.9rem;padding:10px 14px;border:1px solid var(--line);
  border-radius:999px;background:rgba(3,11,20,.7);display:inline-flex;gap:8px;align-items:center;
}
.topbar{
  position:sticky;top:0;z-index:90;backdrop-filter:blur(18px);
  background:rgba(2,6,12,.82);border-bottom:1px solid var(--line)
}
.nav{max-width:1240px;margin:0 auto;padding:12px 18px;display:flex;align-items:center;gap:16px;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px;font-weight:1000;letter-spacing:.03em}
.brand img{width:52px;height:52px;object-fit:cover;border-radius:14px;box-shadow:0 0 24px rgba(0,174,255,.35)}
.navlinks{display:flex;gap:18px;align-items:center;color:#c8d7e8;font-size:.92rem}
.navlinks a:hover{color:var(--cyan)}
.mobile-note{display:none;color:var(--muted);font-size:.86rem}
.hero{
  min-height:92vh;display:grid;align-items:end;position:relative;padding:120px 18px 60px;
  background:
    linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.86)),
    url("assets/banners/storefront-hero-banner.png") center/cover no-repeat;
}
.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,transparent,rgba(0,0,0,.55))}
.hero-inner{position:relative;max-width:1240px;width:100%;margin:0 auto}
.hero-topline,.app-landing{display:grid;grid-template-columns:minmax(0,.95fr) minmax(380px,1.05fr);gap:24px;align-items:end}
.kicker{color:var(--cyan);font-weight:1000;letter-spacing:.22em;text-transform:uppercase;font-size:.78rem}
h1,h2,h3{margin:0;line-height:1}
.hero h1,.subhero h1{
  font-size:clamp(2.7rem,8.5vw,7.2rem);letter-spacing:0;text-transform:uppercase;
  text-shadow:0 0 36px rgba(0,145,255,.6)
}
.hero p{font-size:clamp(1.05rem,2.2vw,1.5rem);color:#d7e7f8;max-width:760px;margin:18px 0 26px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-walkthrough{
  margin:0;
  border:1px solid rgba(96,214,255,.48);
  border-radius:28px;
  overflow:hidden;
  background:#000;
  box-shadow:0 0 54px rgba(0,167,255,.32),var(--shadow);
}
.hero-walkthrough video{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;background:#000}
.hero-walkthrough figcaption{padding:16px 18px;background:linear-gradient(180deg,rgba(4,12,24,.96),rgba(2,5,10,.98));display:grid;gap:4px}
.hero-walkthrough strong{font-size:1.1rem;color:white}
.hero-walkthrough span{color:#bfd2e7;font-size:.92rem}
.offer-ribbon{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  margin:18px 0 0;
}
.offer-ribbon div{
  border:1px solid rgba(255,209,102,.36);
  border-radius:18px;
  padding:14px;
  background:linear-gradient(135deg,rgba(255,209,102,.16),rgba(0,167,255,.10)),rgba(2,6,13,.74);
}
.offer-ribbon strong{display:block;font-size:1rem;color:#fff}
.offer-ribbon span{display:block;color:#d7e7f8;font-size:.82rem;line-height:1.25;margin-top:4px}
.offer-ribbon.compact{grid-template-columns:repeat(2,1fr);margin:20px 0}
.login-card{
  border:1px solid rgba(96,214,255,.42);
  border-radius:20px;
  padding:16px;
  margin:18px 0;
  background:linear-gradient(135deg,rgba(96,214,255,.14),rgba(255,255,255,.06)),rgba(2,6,13,.78);
  box-shadow:0 18px 40px rgba(0,0,0,.22);
}
.login-card p{margin:6px 0;color:#d7e7f8;font-size:.98rem}
.login-card strong{color:white}
.compact-login{margin:18px 0 0}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:1240px;margin:28px auto 0}
.stat{background:rgba(4,12,24,.72);border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:var(--shadow)}
.stat strong{display:block;font-size:1.4rem;color:white}.stat span{color:var(--muted);font-size:.88rem}
.section{padding:86px 18px}
.wrap{max-width:1240px;margin:0 auto}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center}
.panel,.copy-block{
  background:linear-gradient(180deg,rgba(8,20,34,.88),rgba(3,8,16,.86));
  border:1px solid var(--line);border-radius:30px;padding:28px;box-shadow:var(--shadow)
}
.panel h2,.section h2{font-size:clamp(2rem,5vw,4.4rem);letter-spacing:0;margin-bottom:18px}
.panel p,.section p{color:var(--muted);font-size:1.02rem}
.glow-img{border-radius:30px;overflow:hidden;border:1px solid var(--line);box-shadow:0 0 60px rgba(0,129,255,.26)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:28px}
.card,.blog-card{
  background:linear-gradient(180deg,rgba(9,22,38,.86),rgba(2,8,15,.94));
  border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow);
  transition:transform .2s ease,border-color .2s ease;
}
.card:hover,.blog-card:hover{transform:translateY(-4px);border-color:rgba(96,214,255,.6)}
.card img{aspect-ratio:1/1;object-fit:cover;width:100%}
.card-body{padding:18px}.card h3{font-size:1.25rem;margin-bottom:8px}.card p{font-size:.94rem;margin:0}
.bands{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:28px}
.banner-card{position:relative;border-radius:30px;overflow:hidden;border:1px solid var(--line);min-height:320px;background:#000;box-shadow:var(--shadow)}
.banner-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;opacity:.78}
.banner-card div{position:absolute;inset:auto 0 0 0;padding:26px;background:linear-gradient(transparent,rgba(0,0,0,.86))}
.banner-card h3{font-size:1.8rem;margin-bottom:8px}
.reel-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;margin-top:28px;align-items:start}
.reel-stage,.reel-stack figure{
  margin:0;
  border:1px solid var(--line);
  border-radius:28px;
  overflow:hidden;
  background:#000;
  box-shadow:var(--shadow);
}
.reel-stage{position:relative}
.reel-stage video,.reel-stack video{width:100%;height:auto;display:block;background:#000}
.reel-stage video,.reel-stack video{aspect-ratio:16/9;object-fit:cover}
.reel-stack figure:last-child video{width:auto;height:min(520px,70vh);max-width:100%;margin:0 auto;aspect-ratio:9/16;object-fit:cover}
.reel-caption{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:22px;
  background:linear-gradient(transparent,rgba(0,0,0,.82));
}
.reel-caption h3,.reel-stack h3{font-size:1.35rem;margin:0 0 6px;text-shadow:0 0 18px rgba(96,214,255,.42)}
.reel-caption p,.reel-stack p{margin:0;color:#d7e7f8;font-size:.95rem}
.reel-stack{display:grid;grid-template-columns:1fr;gap:18px}
.reel-stack figcaption{padding:16px;background:rgba(3,11,20,.92)}
.callout{
  border:1px solid rgba(255,209,102,.35);background:linear-gradient(135deg,rgba(255,209,102,.11),rgba(0,136,255,.08));
  border-radius:26px;padding:24px;margin-top:24px;color:#fff
}
.hours{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-top:22px}
.day{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:16px;padding:12px;text-align:center}
.day b{display:block;color:white}.day span{color:var(--cyan);font-size:.82rem;font-weight:800}
.footer{padding:46px 18px;border-top:1px solid var(--line);background:#02050a;color:var(--muted)}
.footer .wrap{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer-links{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.footer-links a:hover{color:white}
.subhero{
  padding:110px 18px 54px;
  background:
    linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.9)),
    radial-gradient(circle at 20% 10%,rgba(0,166,255,.24),transparent 34%),
    #02050a;
  border-bottom:1px solid var(--line);
}
.subhero .wrap{max-width:1240px}
.subhero p{max-width:900px;color:#d7e7f8;font-size:1.05rem}
.page-grid{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:start}
.sidebar{position:sticky;top:92px;background:rgba(5,15,27,.76);border:1px solid var(--line);border-radius:24px;padding:18px}
.sidebar a{display:block;color:#bfd2e7;padding:10px 12px;border-radius:14px}
.sidebar a:hover{background:rgba(0,166,255,.14);color:white}
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:22px}
.feature-box,.seo-card{background:rgba(255,255,255,.055);border:1px solid var(--line);border-radius:22px;padding:20px}
.service-strip,.badge-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.service-pill,.badge{border:1px solid var(--line);background:rgba(0,145,255,.10);border-radius:999px;padding:10px 14px;color:#dcecff;font-weight:800;font-size:.9rem}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:24px}
.gallery-grid a{border-radius:20px;overflow:hidden;border:1px solid var(--line);background:#000;min-height:180px}
.gallery-grid img{width:100%;height:100%;object-fit:cover;aspect-ratio:1/1;transition:transform .22s ease}
.gallery-grid a:hover img{transform:scale(1.04)}
.map-card{
  min-height:360px;border-radius:30px;border:1px solid var(--line);overflow:hidden;
  background:linear-gradient(135deg,rgba(0,132,255,.22),rgba(0,0,0,.8)),url("assets/banners/storefront-hero-banner.png") center/cover no-repeat;
  display:grid;place-items:center;text-align:center;padding:28px;
}
.map-card div{background:rgba(0,0,0,.66);border:1px solid var(--line);border-radius:24px;padding:24px;backdrop-filter:blur(10px)}
.form{display:grid;gap:12px;margin-top:16px}
.form label{display:grid;gap:6px;color:#d7e7f8;font-weight:800}
.form input,.form textarea,.form select{width:100%;border:1px solid var(--line);border-radius:16px;background:rgba(0,0,0,.35);color:white;padding:13px 14px;font:inherit;outline:none}
.form small{color:var(--muted)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}
.blog-card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.blog-card div{padding:18px}.blog-card h3{font-size:1.35rem;line-height:1.08;margin-bottom:8px}.blog-card p{color:var(--muted);font-size:.95rem}
.faq{display:grid;gap:12px;margin-top:22px}
.faq details{border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.045);padding:16px}
.faq summary{cursor:pointer;font-weight:900;color:white}
.faq p{color:#c6d6e8;margin:12px 0 0}
.local-list{columns:2;column-gap:40px;color:#c9d9ec}
.local-list li{break-inside:avoid;margin:0 0 8px}
@media(max-width:950px){
  .navlinks{display:none}.mobile-note{display:block}
  .stats,.grid,.bands,.split,.page-grid,.feature-row,.blog-grid,.reel-grid{grid-template-columns:1fr}
  .hours{grid-template-columns:repeat(2,1fr)}
  .hero{min-height:86vh}
  .sidebar{position:relative;top:auto}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .reel-stack figure:last-child video{width:100%;height:auto;max-height:none;object-fit:contain}
}


/* Place the four cards on the exact bottom edge of the hero divider. */
.hero .stats {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  margin: 0 auto !important;
  padding: 0 !important;
  transform: none !important;
  z-index: 2;
}

.hero .stat {
  text-align: center;
}

/* This is the blue section directly under the hero divider. */
.post-hero-section {
  padding-top: 0 !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(0,166,255,.16), transparent 42%),
    linear-gradient(180deg, #06111e 0%, #07111d 100%);
}

.divider-caption {
  padding: 18px 18px 0;
  text-align: center;
}

.divider-caption p {
  max-width: 980px;
  margin: 0 auto;
  color: #d7e7f8;
  font-size: clamp(1rem, 1.8vw, 1.2rem);
  line-height: 1.45;
}

.post-hero-section .wrap.split {
  padding-top: 52px;
}

@media(max-width:950px) {
  .hero,
  .hero-inner {
    min-height: 86vh;
  }

  .hero-inner {
    padding-top: 16px !important;
    padding-bottom: 0 !important;
  }

  .hero .stats {
    bottom: 0;
  }

  .post-hero-section .wrap.split {
    padding-top: 34px;
  }
}


/* BLACK DIVIDER RESTORE PATCH: 2026-05-07 */
.hero {
  min-height: 92vh;
  display: block;
  position: relative;
  padding: 0 18px !important;
  border-bottom: 0 !important;
  background:
    linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.16)),
    url("assets/banners/storefront-hero-banner.png") center/cover no-repeat !important;
}

.hero:before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 40%, rgba(0,0,0,0), rgba(0,0,0,.08)) !important;
}

.hero-inner {
  position: relative;
  z-index: 1;
  max-width: 1240px;
  width: 100%;
  min-height: 92vh;
  margin: 0 auto;
  text-align: center;
  padding-top: 18px !important;
  padding-bottom: 0 !important;
}

.hero-inner h1 {
  font-size: clamp(1.55rem, 4.2vw, 3.1rem);
  max-width: 900px;
  margin: 0 auto 8px !important;
  line-height: .94;
  letter-spacing: 0;
}

.hero-inner > .notice {
  margin: 0 auto !important;
}

/* The four stat cards stay seated on the bottom edge of the hero image. */
.hero .stats {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  margin: 0 auto !important;
  padding: 0 !important;
  transform: none !important;
  z-index: 2;
}

.hero .stat {
  text-align: center;
}

/* Restored black divider between hero image and blue Local Smoke Shop section. */
.hero-black-divider {
  height: 30px;
  background: #02050a;
  border-top: 1px solid rgba(80,190,255,.18);
  border-bottom: 1px solid rgba(80,190,255,.16);
}

/* Sentence stays under the black divider, on the blue background, before Local Smoke Shop. */
.post-hero-section {
  padding-top: 0 !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(0,166,255,.16), transparent 42%),
    linear-gradient(180deg, #06111e 0%, #07111d 100%);
}

.divider-caption {
  padding: 18px 18px 0;
  text-align: center;
}

.divider-caption p {
  max-width: 980px;
  margin: 0 auto;
  color: #d7e7f8;
  font-size: clamp(1rem, 1.8vw, 1.2rem);
  line-height: 1.45;
}

.post-hero-section .wrap.split {
  padding-top: 52px;
}

@media(max-width:950px) {
  .hero,
  .hero-inner {
    min-height: 86vh;
  }

  .hero-inner {
    padding-top: 16px !important;
    padding-bottom: 0 !important;
  }

  .hero .stats {
    bottom: 0;
  }

  .hero-black-divider {
    height: 26px;
  }

  .post-hero-section .wrap.split {
    padding-top: 34px;
  }
}

/* CARDS ABOVE BLACK BAR PATCH: 2026-05-07 */
.hero {
  overflow: visible !important;
}

.hero-inner {
  overflow: visible !important;
}

/* Cards sit on top of the black divider instead of being covered by it. */
.hero .stats {
  bottom: -30px !important;
  z-index: 50 !important;
  position: absolute !important;
  pointer-events: auto;
}

.hero .stat {
  position: relative;
  z-index: 51 !important;
}

.hero-black-divider {
  height: 30px !important;
  position: relative;
  z-index: 0 !important;
  pointer-events: none;
}

.post-hero-section {
  position: relative;
  z-index: 1;
}

@media(max-width:950px) {
  .hero .stats {
    bottom: -26px !important;
    z-index: 50 !important;
  }

  .hero-black-divider {
    height: 26px !important;
    z-index: 0 !important;
  }
}

.workspace-strip{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:22px;
  align-items:center;
  border:1px solid rgba(96,214,255,.34);
  border-radius:28px;
  padding:28px;
  background:linear-gradient(135deg,rgba(0,167,255,.14),rgba(255,209,102,.08)),rgba(3,11,20,.84);
  box-shadow:var(--shadow);
}
.workspace-strip h2{font-size:clamp(2rem,4.5vw,4rem);margin:8px 0 12px}
.workspace-meter{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  margin-top:22px;
}
.workspace-meter div,.qr-panel{
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(255,255,255,.055);
  padding:18px;
}
.workspace-meter strong{display:block;color:white;font-size:2rem}
.workspace-meter span{color:var(--cyan);font-weight:900;font-size:.88rem}
.qr-panel{text-align:center;box-shadow:var(--shadow)}
.qr-panel img{
  width:min(360px,100%);
  margin:0 auto 20px;
  border-radius:18px;
  background:white;
  padding:14px;
}
.qr-panel h2{font-size:clamp(1.9rem,4vw,3.4rem)}
.workspace-grid{grid-template-columns:repeat(4,1fr)}
.workspace-hero{background:radial-gradient(circle at 22% 0%,rgba(0,167,255,.28),transparent 38%),linear-gradient(180deg,#02050a,#07111d)}
.contact-stack{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
@media(max-width:950px){
  .hero-topline,.app-landing,.offer-ribbon,.offer-ribbon.compact{grid-template-columns:1fr}
  .workspace-strip,.workspace-meter,.workspace-grid{grid-template-columns:1fr}
}
