/* JoJo Vapes — redesign (black + orange, Anton/Barlow). Tokens per design handoff. */
@import url('https://fonts.googleapis.com/css2?family=Anton&family=Barlow:wght@400;500;600;700;800&family=Barlow+Semi+Condensed:wght@500;600;700&display=swap');

:root{
  --ink:#0B0B0C; --ink-2:#0F0F11; --offblack:#070708; --card:#141416;
  --bd-dark:#25252A; --bd-dark-2:#2C2C32; --bd-dark-3:#1E1E22; --bd-sec:#34343A;
  --accent:#FF6A21; --accent-hover:#E85A12;
  --cream:#FBF8F2; --cream-2:#F4F0E8; --warm-bd:#E8E2D6; --warm-bd-2:#EBE5D8;
  --tile-a:#F6F1E8; --tile-b:#EFE8DB;
  --on-dark-hi:#FFFFFF; --on-dark-mid:#9b9a96; --on-dark-low:#7d7d7d;
  --on-light-hi:#0B0B0C; --on-light-mid:#6B665C;
  --max:1200px; --pad:56px;
  --body:"Barlow",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --disp:"Anton",var(--body);
  --eye:"Barlow Semi Condensed",var(--body);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--on-light-hi);font-family:var(--body);font-weight:500;font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{font-family:var(--disp);font-weight:400;text-transform:uppercase;letter-spacing:.005em;line-height:1;margin:0}
.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

/* eyebrow / buttons */
.eyebrow{font-family:var(--eye);font-weight:700;text-transform:uppercase;letter-spacing:.28em;color:var(--accent);font-size:12px;margin:0 0 18px}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;padding:17px 30px;border-radius:6px;border:0;cursor:pointer;transition:background .15s,border-color .15s,color .15s}
.btn-primary{background:var(--accent);color:var(--ink)}
.btn-primary:hover{background:var(--accent-hover)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid var(--bd-sec)}
.btn-ghost:hover{border-color:var(--accent)}
.btn-row{display:flex;flex-wrap:wrap;gap:16px}

/* announce + header */
.topbar{background:var(--ink);color:var(--on-dark-mid);text-align:center;font-family:var(--eye);font-weight:600;text-transform:uppercase;letter-spacing:.22em;font-size:11px;padding:11px 10px}
.topbar .dot{color:var(--accent);margin-right:10px}
.site-header{background:var(--ink);position:sticky;top:0;z-index:60}
.site-header .wrap{display:flex;align-items:center;gap:24px;padding-top:18px;padding-bottom:18px}
.brand img{height:66px;width:auto}
.site-nav{margin-left:auto}
.site-nav>ul{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}
.site-nav a{font-family:var(--eye);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:14px;color:var(--on-dark-mid);padding:6px 0;border-bottom:2px solid transparent;transition:color .15s}
.site-nav a:hover{color:#fff}
.site-nav a.active,.site-nav .active>a{color:#fff;border-bottom-color:var(--accent)}
.site-nav .has-sub{position:relative}
.site-nav .has-sub>a::after{content:"▾";font-size:10px;margin-left:6px;color:var(--accent)}
.site-nav .sub{position:absolute;top:130%;left:0;background:var(--card);border:1px solid var(--bd-dark);border-radius:8px;padding:8px;min-width:230px;display:none;list-style:none;margin:0;box-shadow:0 14px 36px rgba(0,0,0,.5)}
.site-nav .has-sub:hover .sub{display:block}
.site-nav .sub a{display:block;padding:9px 12px;border:0;letter-spacing:.04em;font-size:13px}
.site-nav .sub a:hover{color:var(--accent)}
.nav-toggle{display:none;margin-left:auto;background:none;border:0;color:#fff;font-size:1.7rem;cursor:pointer;line-height:1}

/* hero */
.hero{background:var(--ink);border-bottom:3px solid var(--accent)}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding-top:70px;padding-bottom:70px}
.hero-copy .eyebrow{margin-bottom:22px}
.hero h1{color:#fff;font-size:54px;line-height:.96;margin-bottom:26px}
.hero h1 .accent{color:var(--accent)}
.hero-sub{color:var(--on-dark-mid);font-family:var(--eye);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:15px;margin:0 0 34px}
.hero-media{position:relative;border-radius:10px;overflow:hidden;min-height:430px;background:#000}
.hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 20%}

/* value strip */
.value-strip{background:var(--ink-2)}
.value-strip .wrap{display:grid;grid-template-columns:repeat(3,1fr);padding:0}
.value-cell{display:flex;gap:20px;align-items:flex-start;padding:34px 40px;border-left:1px solid var(--bd-dark-3)}
.value-cell:first-child{border-left:0;padding-left:0}
.value-num{font-family:var(--disp);color:var(--accent);font-size:40px;line-height:.8}
.value-cell h3{color:#fff;font-size:19px;margin-bottom:7px}
.value-cell p{color:var(--on-dark-mid);font-size:14px;margin:0}

/* store-hours strip */
.store-strip{background:var(--cream-2)}
.store-strip .wrap{padding-top:64px;padding-bottom:64px}
.store-strip h2{text-align:center;font-size:34px;margin-bottom:40px}
.store-grid{display:grid;grid-template-columns:repeat(3,1fr)}
.store-col{text-align:center;padding:8px 30px;border-left:1px solid var(--warm-bd)}
.store-col:first-child{border-left:0}
.store-col h3{font-size:21px;margin-bottom:16px}
.store-col p{color:var(--on-light-mid);font-size:15px;margin:.2em 0}

/* products */
.products{background:var(--cream)}
.products .wrap{padding-top:72px;padding-bottom:80px}
.products h2{text-align:center;font-size:34px;margin-bottom:12px}
.products .lead{text-align:center;color:var(--on-light-mid);margin:0 auto 40px}
.cards{display:grid;grid-template-columns:repeat(5,1fr);gap:22px}
.card{background:var(--cream);border:1px solid var(--warm-bd);border-radius:10px;overflow:hidden;box-shadow:0 6px 18px rgba(0,0,0,.05);transition:transform .15s,box-shadow .15s}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(0,0,0,.1)}
.card-tile{background:linear-gradient(var(--tile-a),var(--tile-b));aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;padding:18px}
.card-tile img{max-height:100%;width:auto;object-fit:contain}
.card-tile.lifestyle{padding:0;background:var(--ink)}
.card-tile.lifestyle img{width:100%;height:100%;object-fit:cover}
.card-foot{border-top:1px solid #F0EBE0;padding:18px 18px 20px}
.card-foot h3{font-size:16px;margin-bottom:9px}
.card-shop{font-family:var(--eye);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:var(--accent)}

/* contact CTA */
.contact{background:var(--ink);border-top:3px solid var(--accent)}
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:56px;padding-top:74px;padding-bottom:74px;align-items:start}
.contact h2{color:#fff;font-size:42px;line-height:1.02;margin-bottom:22px}
.contact-copy p{color:var(--on-dark-mid);max-width:46ch;margin:0 0 30px}
.form-panel{background:var(--card);border:1px solid var(--bd-dark);border-radius:10px;padding:32px}
.form-panel h3{color:#fff;font-size:24px;margin-bottom:6px}
.form-panel .hint{color:var(--on-dark-mid);font-size:14px;margin:0 0 22px}
.contact-form{display:grid;gap:18px}
.field{display:grid;gap:8px}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{font-family:var(--eye);font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--on-dark-low)}
.field input,.field select,.field textarea{background:#0E0E10;border:1px solid var(--bd-dark-2);border-radius:7px;padding:13px 14px;color:#fff;font:inherit;font-size:14px}
.field textarea{resize:vertical;min-height:104px}
.field input::placeholder,.field textarea::placeholder{color:#5b5b60}
.form-panel .btn{width:100%;justify-content:center;margin-top:4px}
.compliance{color:var(--on-dark-low);font-size:12px;text-align:center;margin:16px 0 0}
.form-success{color:#5fdc8d;font-size:14px}.form-error{color:#ff8a8a;font-size:14px}

/* footer */
.site-footer{background:var(--offblack);color:var(--on-dark-mid);padding:56px 0 26px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px}
.footer-col h4{font-family:var(--eye);font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:12px;color:#fff;margin:0 0 16px}
.footer-col img{height:46px;margin-bottom:16px}
.footer-col p,.footer-col li{font-size:14px;line-height:1.7}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid #1A1A1E;margin-top:40px;padding-top:22px;font-size:11px;letter-spacing:.04em;color:var(--on-dark-low)}
.footer-bottom .age{color:var(--on-dark-mid)}

/* ---- inner pages (re-skinned with same system) ---- */
.page-hero{background:var(--ink);border-bottom:3px solid var(--accent)}
.page-hero .wrap{padding-top:64px;padding-bottom:64px}
.page-hero h1{color:#fff;font-size:44px}
.page-hero .crumb{color:var(--on-dark-mid)}
.section-light{background:var(--cream)}
.section-light .wrap{padding-top:64px;padding-bottom:72px}
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:8px}
.product-card{background:var(--cream);border:1px solid var(--warm-bd);border-radius:10px;overflow:hidden;box-shadow:0 6px 18px rgba(0,0,0,.05);transition:transform .15s,box-shadow .15s;color:var(--on-light-hi)}
.product-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(0,0,0,.1)}
.product-card .pc-tile{background:linear-gradient(var(--tile-a),var(--tile-b));aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;padding:16px}
.product-card .pc-tile img{max-height:100%;object-fit:contain}
.product-card .pc-foot{border-top:1px solid #F0EBE0;padding:16px 18px}
.product-card h3{font-size:15px;margin-bottom:8px}
.product-card .price{color:var(--accent);font-family:var(--disp);font-size:18px}
.descriptor{color:var(--on-light-mid);font-size:13px}
.intro{color:var(--on-light-mid);max-width:62ch}
.product-detail{max-width:760px;margin:0 auto;text-align:center}
.product-detail .product-img{max-height:340px;margin:0 auto 22px;object-fit:contain}
.product-detail h1{font-size:40px;color:var(--on-light-hi);margin-bottom:14px}
.product-detail .price{color:var(--accent);font-family:var(--disp);font-size:30px}
.price-list{list-style:none;padding:0;display:flex;gap:22px;justify-content:center;color:var(--accent);font-family:var(--disp);font-size:20px;flex-wrap:wrap}
.crumb{font-family:var(--eye);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:12px;margin-bottom:14px}
.crumb a{color:var(--accent)}
.nic-note{color:var(--on-light-mid);font-size:13px;margin-top:18px}
.flavor-cats{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin:26px 0}
.flavor-cat-card{background:var(--ink);color:#fff;border-radius:10px;padding:32px 14px;text-align:center;font-family:var(--disp);text-transform:uppercase}
.flavor-cat-card:hover{background:var(--accent);color:var(--ink)}
.faq details{background:var(--cream);border:1px solid var(--warm-bd);border-radius:10px;padding:18px 22px;margin-bottom:12px}
.faq summary{cursor:pointer;font-family:var(--disp);text-transform:uppercase;font-size:18px;list-style:none;display:flex;justify-content:space-between;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-family:var(--body);font-weight:700}
.faq details[open] summary::after{content:"–"}
.faq p{color:var(--on-light-mid);margin:.8em 0 0}

/* responsive */
@media(max-width:960px){
  :root{--pad:24px}
  .hero .wrap{grid-template-columns:1fr;gap:30px}
  .hero-media{min-height:300px}
  .hero h1{font-size:42px}
  .value-strip .wrap,.store-grid,.contact .wrap,.footer-grid{grid-template-columns:1fr}
  .value-cell{border-left:0;border-top:1px solid var(--bd-dark-3);padding-left:0}
  .value-cell:first-child{border-top:0}
  .store-col{border-left:0;border-top:1px solid var(--warm-bd);padding:22px 0}
  .store-col:first-child{border-top:0}
  .cards{grid-template-columns:repeat(2,1fr)}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .flavor-cats{grid-template-columns:repeat(2,1fr)}
  .nav-toggle{display:block}
  .site-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--ink);padding:14px 24px;border-top:1px solid var(--bd-dark-3)}
  .site-nav.open{display:block}
  .site-nav>ul{flex-direction:column;align-items:flex-start;gap:10px}
  .site-nav .sub{position:static;display:block;border:0;box-shadow:none;background:transparent;padding:4px 0 4px 14px;min-width:0}
}
@media(max-width:560px){
  .cards,.product-grid,.flavor-cats,.f-row{grid-template-columns:1fr}
  .hero h1{font-size:34px}
  .contact h2{font-size:32px}
}

/* ---- employee feedback fixes ---- */
html{scroll-padding-top:150px}
/* larger, more prominent nav */
.site-nav a{font-size:16px;font-weight:700;letter-spacing:.06em}
/* dropdowns: no gap (was 130%), bigger targets, hover bridge */
.site-nav .sub{top:100%;padding:10px;min-width:248px}
.site-nav .has-sub::after{content:"";position:absolute;left:0;right:0;top:100%;height:14px}
.site-nav .sub a{padding:11px 14px;font-size:14px;border-radius:6px}
/* nested submenu (Products -> E-Liquid -> flavors) */
.site-nav .sub2{position:absolute;top:-10px;left:100%;background:var(--card);border:1px solid var(--bd-dark);border-radius:8px;padding:10px;min-width:210px;display:none;list-style:none;margin:0;box-shadow:0 14px 36px rgba(0,0,0,.5)}
.site-nav .has-sub2{position:relative}
.site-nav .has-sub2:hover>.sub2{display:block}
.site-nav .has-sub2>a{display:flex;justify-content:space-between;align-items:center;gap:12px}
.site-nav .has-sub2 .arr{color:var(--accent);font-size:10px}
/* missing-image placeholder */
.pc-soon{font-family:var(--eye);font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:12px;color:#b4ab9b;text-align:center;line-height:1.5}
@media(max-width:960px){
  .site-nav .sub2{position:static;display:block;border:0;box-shadow:none;background:transparent;padding:4px 0 4px 14px;min-width:0}
  .site-nav .has-sub::after{display:none}
}

/* ---- locations with embedded maps ---- */
.locations-maps{position:relative;background:var(--ink);border-top:3px solid var(--accent);overflow:hidden}
.locations-maps::before{content:"";position:absolute;inset:0;background:url('/assets/img/hero/slide2.jpg') center/cover no-repeat;opacity:.14;z-index:0}
.locations-maps .wrap{position:relative;z-index:1;padding-top:64px;padding-bottom:72px}
.loc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.loc-card{text-align:center}
.loc-card h3{color:var(--accent);font-size:22px;margin-bottom:10px}
.loc-card .addr{color:#fff;font-size:15px;margin:0 0 6px}
.loc-card .hours{list-style:none;padding:0;margin:0 0 16px;color:var(--on-dark-mid);font-size:14px;line-height:1.7}
.loc-map{border-radius:10px;overflow:hidden;border:1px solid var(--bd-dark);margin-bottom:18px}
.loc-map iframe{display:block;width:100%;height:220px;border:0}
@media(max-width:960px){ .loc-grid{grid-template-columns:1fr} }
