/* =========================================================
   RIVERSIDE DISPENSARY — premium boutique cannabis stylesheet
   100% owned by Ploypailin Cunningham · Chiang Mai
   ========================================================= */
:root{
  --forest-deep:#0f1f17;
  --forest:#1f4233;
  --forest-soft:#2d5a44;
  --leaf:#5cb85c;       /* matches frog logo */
  --leaf-bright:#7ed47e;
  --gold:#c8a25a;
  --gold-soft:#e3c992;
  --gold-dark:#9b7836;
  --cream:#faf6ed;
  --cream-warm:#f1ead6;
  --paper:#fff;
  --ink:#14201a;
  --ink-soft:#4a5a4f;
  --rule:#dfd8c6;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter','Helvetica Neue',Arial,sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{
  font-family:'Cormorant Garamond','Playfair Display',Georgia,serif;
  font-weight:600;line-height:1.1;letter-spacing:-0.005em;
}
a{color:inherit}

/* NAV */
nav.site{
  position:sticky;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 32px;
  background:rgba(15,31,23,0.95);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  color:var(--cream);
  border-bottom:1px solid rgba(200,162,90,0.25);
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--cream)}
.brand .frog-mark{width:48px;height:48px;display:block}
.brand-name{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;line-height:1.05;font-weight:600;
}
.brand-name .green{color:var(--leaf)}
.brand-tagline{
  display:block;font-family:'Inter',sans-serif;font-size:10px;
  letter-spacing:0.25em;color:var(--gold-soft);text-transform:uppercase;
  font-weight:600;margin-top:2px;
}
.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{
  padding:8px 16px;border-radius:999px;text-decoration:none;
  font-size:14px;font-weight:500;color:var(--cream);
  transition:background .2s, color .2s;opacity:0.85;
}
.nav-links a:hover{background:rgba(255,255,255,0.06);opacity:1}
.nav-links a.active{color:var(--leaf-bright);opacity:1}
.nav-cta{
  background:var(--leaf) !important;color:var(--forest-deep) !important;
  font-weight:700 !important;opacity:1 !important;
}
.nav-cta:hover{background:var(--leaf-bright) !important}
@media(max-width:680px){
  .nav-links{gap:0}
  .nav-links a{padding:6px 10px;font-size:13px}
  .brand-tagline{display:none}
}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 32px;border-radius:6px;font-weight:700;text-decoration:none;
  font-size:15px;letter-spacing:0.04em;font-family:inherit;border:none;cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{
  background:var(--leaf);color:var(--forest-deep);
  box-shadow:0 8px 24px rgba(92,184,92,0.35);
}
.btn-primary:hover{background:var(--leaf-bright)}
.btn-gold{
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:var(--forest-deep);
  box-shadow:0 8px 24px rgba(200,162,90,0.4);
}
.btn-secondary{
  background:transparent;color:var(--cream);
  border:1.5px solid rgba(250,246,237,0.45);
}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold-soft)}
.btn-dark{background:var(--forest-deep);color:var(--cream)}
.btn-dark:hover{background:var(--forest)}

/* HERO */
.hero{
  position:relative;min-height:90vh;
  background:#000;color:var(--cream);
  overflow:hidden;
  display:flex;align-items:center;
  padding:80px 32px;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(0.55) saturate(1.05);
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(15,31,23,0.45) 0%, rgba(15,31,23,0.78) 70%, rgba(15,31,23,0.95) 100%);
}
.hero-inner{
  position:relative;z-index:2;max-width:1100px;margin:0 auto;width:100%;
}
.hero .eyebrow{
  display:inline-block;padding:7px 14px;
  background:rgba(200,162,90,0.18);
  border:1px solid rgba(200,162,90,0.55);
  color:var(--gold-soft);
  border-radius:999px;
  font-size:11px;letter-spacing:0.32em;text-transform:uppercase;font-weight:700;
  margin-bottom:24px;
}
.hero h1{
  font-size:clamp(48px,8vw,108px);line-height:0.98;
  margin-bottom:22px;color:var(--cream);
  font-weight:700;letter-spacing:-0.02em;
}
.hero h1 em{font-style:italic;color:var(--leaf-bright)}
.hero .tagline{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:clamp(18px,2.4vw,26px);
  max-width:700px;color:rgba(250,246,237,0.92);
  margin-bottom:36px;line-height:1.45;
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{
  margin-top:46px;
  display:flex;gap:20px;flex-wrap:wrap;align-items:center;
}
.trust-pill{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(0,0,0,0.45);
  border:1px solid rgba(200,162,90,0.45);
  color:var(--cream);
  padding:10px 16px;border-radius:999px;
  font-size:13px;font-weight:600;
  backdrop-filter:blur(8px);
}
.trust-pill .stars{color:var(--gold-soft);letter-spacing:1px;font-size:14px}
.trust-pill .num{color:var(--leaf-bright);font-weight:800;font-size:15px}
.trust-pill .lbl{opacity:0.75;font-size:12px;font-weight:500}
.trust-pill .cup{font-size:18px}

/* SECTIONS */
section{padding:100px 32px;position:relative}
.container{max-width:1100px;margin:0 auto}
.section-eyebrow{
  display:inline-block;font-size:11px;letter-spacing:0.32em;
  text-transform:uppercase;font-weight:700;color:var(--gold-dark);
  margin-bottom:14px;
}
h2.section-title{
  font-size:clamp(34px,4.5vw,56px);
  margin-bottom:18px;color:var(--ink);line-height:1.05;
}
h2.section-title em{font-style:italic;color:var(--forest-soft)}
.section-lede{
  font-size:18px;max-width:700px;color:var(--ink-soft);
  margin-bottom:50px;line-height:1.7;
}

/* TAGLINE STRIP — between hero and rest */
.tagline-strip{
  background:var(--forest-deep);color:var(--cream);
  text-align:center;padding:60px 32px;
  border-bottom:3px solid var(--gold);
}
.tagline-strip .quote{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:clamp(22px,3vw,34px);line-height:1.4;
  max-width:880px;margin:0 auto 16px;
}
.tagline-strip .quote .pop{color:var(--leaf-bright);font-weight:600;font-style:normal}
.tagline-strip .attr{
  font-size:11px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--gold-soft);font-weight:700;
}

/* FOUNDER */
.founder{background:var(--cream);position:relative}
.founder-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;
}
@media(max-width:880px){.founder-grid{grid-template-columns:1fr;gap:32px}}
.founder-text p{font-size:17px;color:var(--ink-soft);margin-bottom:16px;line-height:1.75}
.founder-text p strong{color:var(--ink)}
.founder-text .signature{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:22px;color:var(--forest);margin-top:14px;
}
.founder-text .signature .name{
  display:block;font-size:13px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--gold-dark);font-style:normal;
  margin-top:6px;font-weight:700;font-family:'Inter',sans-serif;
}
.founder-photos{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
.founder-photos .photo{
  position:relative;border-radius:6px;overflow:hidden;
  aspect-ratio:3/4;background:var(--forest);
  box-shadow:0 24px 50px rgba(15,31,23,0.18);
}
.founder-photos .photo:nth-child(2){margin-top:40px}
.founder-photos img{width:100%;height:100%;object-fit:cover;display:block}

/* CULTIVATION */
.cultivation{
  background:var(--forest-deep);color:var(--cream);
  padding:120px 32px;
}
.cultivation .section-eyebrow{color:var(--gold-soft)}
.cultivation h2.section-title{color:var(--cream)}
.cultivation h2.section-title em{color:var(--leaf-bright)}
.cultivation .section-lede{color:rgba(250,246,237,0.78)}
.cult-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  margin-top:50px;
}
@media(max-width:760px){.cult-grid{grid-template-columns:1fr 1fr;gap:10px}}
.cult-tile{
  position:relative;overflow:hidden;border-radius:6px;
  aspect-ratio:1/1;background:#000;
}
.cult-tile.tall{grid-row:span 2;aspect-ratio:1/2}
.cult-tile img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.6s ease;
}
.cult-tile:hover img{transform:scale(1.05)}
.cult-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;
  margin-top:60px;text-align:center;
}
@media(max-width:600px){.cult-stats{grid-template-columns:1fr;gap:24px}}
.cult-stat{
  border-top:1px solid rgba(200,162,90,0.4);padding-top:24px;
}
.cult-stat .num{
  font-family:'Cormorant Garamond',serif;
  font-size:48px;color:var(--leaf-bright);font-weight:600;line-height:1;
}
.cult-stat .lbl{
  font-size:12px;letter-spacing:0.25em;text-transform:uppercase;
  color:var(--gold-soft);margin-top:8px;font-weight:600;
}

/* TROPHY */
.trophy{
  background:linear-gradient(180deg,var(--cream) 0%, var(--cream-warm) 100%);
  text-align:center;
}
.trophy .crown{
  font-size:60px;line-height:1;margin-bottom:20px;
  filter:drop-shadow(0 6px 14px rgba(200,162,90,0.4));
}
.trophy h2.section-title{margin-bottom:22px}
.trophy .award-line{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:clamp(20px,2.6vw,28px);color:var(--forest);
  max-width:700px;margin:0 auto 50px;line-height:1.5;
}
.trophy-photos{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:920px;margin:0 auto;
}
@media(max-width:680px){.trophy-photos{grid-template-columns:1fr}}
.trophy-photos .photo{
  position:relative;border-radius:8px;overflow:hidden;
  box-shadow:0 24px 60px rgba(15,31,23,0.2);
  aspect-ratio:4/3;
}
.trophy-photos img{width:100%;height:100%;object-fit:cover;display:block}

/* MENU TEASER */
.menu-teaser{background:var(--cream)}
.menu-cats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:18px;margin-top:40px;
}
.menu-cat{
  background:var(--paper);border:1px solid var(--rule);
  border-radius:8px;padding:30px 24px;text-align:left;
  transition:border-color .2s, transform .2s;
  text-decoration:none;color:var(--ink);
  display:block;
}
.menu-cat:hover{border-color:var(--leaf);transform:translateY(-4px)}
.menu-cat .em{font-size:28px;margin-bottom:8px;display:block}
.menu-cat h3{font-size:22px;margin-bottom:6px;color:var(--ink);font-family:'Cormorant Garamond',serif}
.menu-cat p{font-size:14px;color:var(--ink-soft);line-height:1.5}
.menu-cat .arrow{
  display:block;margin-top:16px;font-size:12px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--forest);font-weight:700;
}

/* LOCATIONS */
.locations{
  background:var(--forest-deep);color:var(--cream);
}
.locations .section-eyebrow{color:var(--gold-soft)}
.locations h2.section-title{color:var(--cream)}
.locations h2.section-title em{color:var(--leaf-bright)}
.locations .section-lede{color:rgba(250,246,237,0.75)}
.loc-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  margin-top:36px;
}
@media(max-width:760px){.loc-grid{grid-template-columns:1fr}}
.loc-card{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(200,162,90,0.3);
  border-radius:10px;padding:36px 32px;
}
.loc-card .num{
  font-family:'Cormorant Garamond',serif;
  font-size:14px;letter-spacing:0.25em;text-transform:uppercase;
  color:var(--gold-soft);font-weight:600;margin-bottom:8px;
}
.loc-card h3{
  font-size:28px;color:var(--cream);margin-bottom:14px;
}
.loc-card .addr{
  font-size:15px;color:rgba(250,246,237,0.85);margin-bottom:18px;line-height:1.7;
}
.loc-card .hours{
  display:inline-block;background:rgba(92,184,92,0.18);color:var(--leaf-bright);
  padding:6px 14px;border-radius:999px;font-size:12px;font-weight:700;
  letter-spacing:0.06em;margin-bottom:20px;
}
.loc-card .hours.always{background:rgba(200,162,90,0.18);color:var(--gold-soft)}
.loc-card .contact{
  display:flex;gap:16px;flex-wrap:wrap;margin-top:20px;
  padding-top:20px;border-top:1px solid rgba(200,162,90,0.2);
}
.loc-card .contact a{
  color:var(--cream);text-decoration:none;font-size:14px;font-weight:600;
  display:inline-flex;align-items:center;gap:6px;
  border-bottom:1px solid var(--leaf);padding-bottom:2px;
}
.loc-card .contact a:hover{color:var(--leaf-bright);border-color:var(--leaf-bright)}
.loc-card .perks{
  margin-top:14px;font-size:13px;color:var(--gold-soft);font-style:italic;
}

/* COMMUNITY (songkran + cultivation team) */
.community{
  background:var(--cream-warm);
  text-align:center;
}
.community-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
  max-width:1000px;margin:40px auto 0;
}
@media(max-width:680px){.community-grid{grid-template-columns:1fr}}
.community-photo{
  position:relative;border-radius:8px;overflow:hidden;aspect-ratio:4/3;
  box-shadow:0 18px 40px rgba(15,31,23,0.15);
}
.community-photo img{width:100%;height:100%;object-fit:cover}
.community-photo .cap{
  position:absolute;left:18px;right:18px;bottom:14px;
  color:#fff;font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:15px;text-shadow:0 2px 8px rgba(0,0,0,0.7);
  z-index:2;
}
.community-photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%, rgba(0,0,0,0.55) 100%);
  pointer-events:none;
}

/* VISIT CTA — final */
.visit-cta{
  background:linear-gradient(135deg,var(--forest-deep) 0%, var(--forest) 100%);
  color:var(--cream);text-align:center;
}
.visit-cta h2{
  font-size:clamp(34px,4.5vw,52px);color:var(--cream);margin-bottom:18px;
}
.visit-cta h2 em{color:var(--leaf-bright);font-style:italic}
.visit-cta .lede{
  font-size:18px;color:rgba(250,246,237,0.85);max-width:660px;margin:0 auto 32px;
}
.visit-cta .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* FOOTER */
footer.site{
  background:#0a1410;color:rgba(250,246,237,0.6);
  padding:50px 32px 30px;
}
footer.site .container{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;
}
@media(max-width:760px){footer.site .container{grid-template-columns:1fr;gap:28px}}
footer.site .brand{margin-bottom:14px}
footer.site .brand-name{color:var(--cream)}
footer.site .brand-tagline{color:var(--gold-soft);display:block}
footer.site h4{
  font-family:'Inter',sans-serif;font-size:11px;letter-spacing:0.25em;
  text-transform:uppercase;color:var(--gold-soft);font-weight:700;margin-bottom:14px;
}
footer.site ul{list-style:none}
footer.site li{margin-bottom:8px;font-size:14px}
footer.site a{color:rgba(250,246,237,0.85);text-decoration:none}
footer.site a:hover{color:var(--leaf-bright)}
footer.site .legal{
  margin-top:30px;padding-top:24px;
  border-top:1px solid rgba(200,162,90,0.2);
  font-size:11px;color:rgba(250,246,237,0.4);
  text-align:center;line-height:1.7;max-width:780px;margin-left:auto;margin-right:auto;
  letter-spacing:0.05em;
}

/* AGE GATE MODAL */
.age-gate{
  position:fixed;inset:0;z-index:1000;
  background:rgba(15,31,23,0.97);
  display:flex;align-items:center;justify-content:center;
  padding:30px;
  backdrop-filter:blur(20px);
}
.age-gate.hidden{display:none}
.age-gate-card{
  background:var(--cream);
  max-width:480px;border-radius:12px;padding:48px 36px;
  text-align:center;box-shadow:0 30px 80px rgba(0,0,0,0.5);
}
.age-gate .frog-mark{width:72px;height:72px;margin:0 auto 18px;display:block}
.age-gate h2{font-size:32px;color:var(--ink);margin-bottom:10px}
.age-gate p{color:var(--ink-soft);font-size:15px;margin-bottom:28px;line-height:1.6}
.age-gate .gate-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.age-gate .small{font-size:11px;color:var(--ink-soft);margin-top:18px;line-height:1.6}
