/* ============================================================
   stephenmcanulla.com - BASE STYLES
   Shared reset, type, buttons, header, footer, lightbox, and the
   reusable page sections. All colours/spacing/fonts come from tokens.css.
   Built mobile-friendly; the look matches the approved mockups.
   ============================================================ */

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-weight:var(--w-regular);
  background:var(--cream);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
img{display:block;width:100%;height:100%;object-fit:cover}
a{color:inherit}

/* shared bits ---------------------------------------------------------- */
.eyebrow{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--sg-deep)}
.wrap{max-width:1320px;margin:0 auto}

/* ----- glass buttons (sage, the locked look) ----- */
.btn{
  display:inline-block;font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  padding:13px 28px;border-radius:999px;text-decoration:none;cursor:pointer;
  border:1px solid transparent;
  transition:background .2s ease,border-color .2s ease,transform .2s ease;
  backdrop-filter:blur(12px) saturate(1.3);-webkit-backdrop-filter:blur(12px) saturate(1.3);
}
.btn:hover{transform:translateY(-1px)}
/* light glass = over photos (white text) */
.glass-light{background:rgba(var(--sg-rgb),.30);border-color:rgba(255,255,255,.5);color:#fff;box-shadow:0 4px 18px rgba(0,0,0,.14)}
.glass-light:hover{background:rgba(var(--sg-rgb),.44)}
.glass-light.primary{background:rgba(var(--sg-rgb),.46);border-color:rgba(255,255,255,.72)}
.glass-light.primary:hover{background:rgba(var(--sg-rgb),.58)}
/* dark glass = on cream (sage-deep text) */
.glass-dark{background:rgba(var(--sg-rgb),.16);border-color:rgba(var(--sg-deep-rgb),.45);color:var(--sg-deep)}
.glass-dark:hover{background:rgba(var(--sg-rgb),.26)}
.glass-dark.primary{background:rgba(var(--sg-rgb),.28);border-color:rgba(var(--sg-deep-rgb),.6)}
.glass-dark.primary:hover{background:rgba(var(--sg-rgb),.40)}

/* ============================================================
   HEADER (sticky, cream, galleries dropdown + mobile menu)
   ============================================================ */
/* header is near-solid cream (no backdrop-filter on purpose: a blurred ancestor
   would steal the backdrop from the .drop submenu nested inside it). The
   show/hide transform is driven inline by site.js: it scrolls off ATTACHED to
   the page on the way down, and slides back in on the way up. */
.site-header{position:sticky;top:0;z-index:200;background:rgba(241,239,232,.95);border-bottom:var(--hair) solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px var(--edge);max-width:1320px;margin:0 auto}
.wordmark{display:flex;align-items:center;line-height:1;text-decoration:none;color:var(--ink);flex-shrink:0}
.wordmark img{height:48px;width:auto;display:block}
.navlinks{display:flex;align-items:center;gap:26px;font-size:13px;letter-spacing:.06em}
.navlinks a{color:var(--nav-link);text-decoration:none;transition:color .18s ease}
.navlinks a:hover{color:var(--nav-link-hover)}
/* galleries dropdown */
.has-drop{position:relative}
.has-drop>a{display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.has-drop>a::after{content:'';width:5px;height:5px;border-right:1.4px solid currentColor;border-bottom:1.4px solid currentColor;transform:rotate(45deg) translateY(-1px);opacity:.7}
.drop{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(6px);min-width:210px;background:rgba(241,239,232,.72);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border:var(--hair) solid rgba(29,27,24,.12);border-radius:12px;padding:8px;box-shadow:0 18px 44px rgba(29,27,24,.16);opacity:0;visibility:hidden;transition:opacity .18s ease,transform .18s ease}
.has-drop.open .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.has-drop.open>a::after{transform:rotate(-135deg) translateY(1px)}
.drop a{display:block;padding:10px 14px;border-radius:8px;font-size:13px;letter-spacing:.04em;color:var(--nav-link);text-decoration:none}
.drop a:hover{background:rgba(255,255,255,.5);color:var(--ink)}
.drop a small{display:block;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--sg-deep);margin-top:2px;opacity:.85}
.nav-cta{flex-shrink:0}
/* burger (mobile) */
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:0}
.burger span{width:24px;height:1.6px;background:var(--ink);transition:transform .25s ease,opacity .2s ease}
body.menu-open .burger span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}
/* mobile menu panel */
.mobile-menu{display:none;position:fixed;inset:0 0 0 0;top:0;z-index:190;background:var(--cream);padding:96px 30px 40px;flex-direction:column;gap:4px;opacity:0;visibility:hidden;transition:opacity .26s ease,visibility .26s ease;overflow-y:auto}
body.menu-open .mobile-menu{opacity:1;visibility:visible}
.mobile-menu a{font-family:var(--font-display);font-size:30px;font-weight:500;color:var(--ink);text-decoration:none;padding:12px 0;border-bottom:var(--hair) solid var(--line)}
.mobile-menu a.sub{font-family:var(--font-body);font-size:15px;letter-spacing:.05em;padding-left:18px;color:var(--ink-soft)}
.mobile-menu .mm-cta{margin-top:24px;text-align:center}

/* ============================================================
   HERO (rotating, homepage)
   ============================================================ */
.hero{position:relative;height:660px;overflow:hidden}
.hero .slides{position:absolute;inset:0}
.hero .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease;transform:scale(1.04)}
.hero .slide.active{opacity:1;transform:scale(1);transition:opacity 1.4s ease,transform 7s ease}
.hero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.16) 0%,rgba(0,0,0,.12) 45%,rgba(0,0,0,.5) 100%)}
.hero .htext{position:absolute;left:0;right:0;bottom:0;padding:0 var(--section-pad-x) 60px;color:#fff;max-width:1320px;margin:0 auto}
.hero .htext .eyebrow{color:#fff;opacity:.95}
.hero h1{font-family:var(--font-display);font-weight:500;font-size:66px;line-height:1.0;max-width:660px;margin:14px 0 0;letter-spacing:.005em}
.hero .sub{font-weight:var(--w-regular);font-size:17px;margin-top:18px;max-width:460px;opacity:.94;line-height:1.55}
.hero .cta{margin-top:28px;display:flex;gap:14px;flex-wrap:wrap}
.hero .dots{position:absolute;right:var(--section-pad-x);top:40px;display:flex;gap:9px}
.hero .dots button{width:9px;height:9px;border-radius:50%;border:1px solid rgba(255,255,255,.85);background:transparent;cursor:pointer;padding:0}
.hero .dots button.on{background:#fff}

/* ============================================================
   SHARED SECTIONS
   ============================================================ */
.section{padding:var(--section-pad-y) var(--section-pad-x)}
.lead{text-align:center;max-width:700px;margin:0 auto}
.lead h2{font-family:var(--font-display);font-weight:500;font-size:40px;line-height:1.15;margin:14px 0}
.lead p{color:var(--ink-soft);font-weight:var(--w-regular);font-size:16px;line-height:1.75}

/* genre tiles (home) */
.genres{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:0 var(--edge)}
.genre{position:relative;height:460px;overflow:hidden;text-decoration:none}
.genre img{transition:transform .9s ease}
.genre:hover img{transform:scale(1.05)}
.genre .glabel{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:28px;background:linear-gradient(180deg,rgba(0,0,0,0) 45%,rgba(0,0,0,.58));color:#fff}
.genre .glabel span{font-size:11px;letter-spacing:.28em;text-transform:uppercase;opacity:.82}
.genre .glabel h3{font-family:var(--font-display);font-weight:500;font-size:32px;margin-top:4px}
.genre .glabel em{font-style:normal;font-size:12px;letter-spacing:.1em;margin-top:10px;opacity:.95;border-bottom:1px solid var(--sg-light);padding-bottom:3px;width:fit-content}

/* meet (home) */
.meet{display:grid;grid-template-columns:0.9fr 1.1fr;background:var(--cream-2)}
.meet .mpic{position:relative;min-height:560px;overflow:hidden}
.meet .mtext{padding:72px 56px;display:flex;flex-direction:column;justify-content:center}
.meet .mtext h2{font-family:var(--font-display);font-weight:500;font-size:42px;margin:12px 0 18px}
.meet .mtext p{color:var(--ink-soft);font-weight:var(--w-regular);font-size:16.5px;line-height:1.8;margin-bottom:16px;max-width:560px}
.meet .sign{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:30px;margin-top:8px}
.meet .role{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--sg-deep);margin-top:4px}
.meet .mbtn{margin-top:26px}

/* stats (home) */
.stats{display:grid;grid-template-columns:repeat(4,1fr);background:var(--ink);color:var(--cream)}
.stat{padding:48px 24px;text-align:center;border-right:var(--hair) solid rgba(255,255,255,.12)}
.stat:last-child{border-right:0}
.stat .num{font-family:var(--font-display);font-size:42px;color:var(--sg-light);line-height:1}
.stat .lbl{font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-top:10px;opacity:.72}

/* quote / featured review */
.quote{padding:84px var(--section-pad-x);text-align:center;background:var(--cream)}
.quote p{font-family:var(--font-display);font-weight:500;font-style:italic;font-size:31px;line-height:1.4;max-width:880px;margin:0 auto}
.quote .who{font-size:12px;letter-spacing:.22em;text-transform:uppercase;margin-top:24px;color:var(--sg-deep)}

/* latest blog (home) */
.blog-band{padding:var(--section-pad-y) var(--section-pad-x);background:var(--cream-2)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:32px}
.post-card{text-decoration:none;color:inherit}
.post-card .pimg{height:240px;overflow:hidden;margin-bottom:16px;border-radius:6px}
.post-card .pimg img{transition:transform .8s ease}
.post-card:hover .pimg img{transform:scale(1.05)}
.post-card .pdate{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--sg-deep)}
.post-card h4{font-family:var(--font-display);font-weight:500;font-size:24px;margin-top:6px;line-height:1.25}

/* cta band (shared) */
.ctaband{position:relative;height:440px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff}
.ctaband img{position:absolute;inset:0}
.ctaband .scrim{position:absolute;inset:0;background:rgba(0,0,0,.46)}
.ctaband .inner{position:relative;padding:0 24px}
.ctaband h2{font-family:var(--font-display);font-weight:500;font-size:48px;line-height:1.08;max-width:680px;margin:0 auto}
.ctaband .btn{margin-top:26px}

/* ============================================================
   GALLERY PAGE SECTIONS
   ============================================================ */
.crumb{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--sg-deep);padding:20px var(--edge) 0;max-width:1320px;margin:0 auto}
.crumb a{color:inherit;text-decoration:none;opacity:.85}
.crumb a:hover{opacity:1}
.phero{position:relative;height:520px;overflow:hidden;margin:18px auto 0;width:calc(100% - var(--edge)*2);max-width:calc(1320px - var(--edge)*2);border-radius:10px}
.phero img{position:absolute;inset:0}

/* ----- blog post (rendered server-side from D1 by functions/blog/[slug].js) ----- */
.page-post .post{margin:0 auto;padding:34px var(--edge) 80px}
.post-crumb{font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:22px}
.post-crumb a{color:var(--sg-deep);text-decoration:none}
.post .post-head{text-align:center;margin-bottom:30px}
.post .post-head .meta{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--sg-deep);margin-bottom:10px}
.post .post-head h1{font-family:var(--font-display);font-weight:500;font-size:46px;line-height:1.08;margin:0 0 16px}
.post .post-head .lead{font-size:18px;line-height:1.7;color:var(--ink-soft);margin:0}
.post img.cover{width:100%;border-radius:14px;display:block;margin:6px 0 34px}
.post h2{font-family:var(--font-display);font-weight:500;font-size:30px;line-height:1.2;margin:38px 0 14px}
.post p{font-size:17px;line-height:1.85;color:var(--ink);margin:0 0 22px}
.post p a{color:var(--sg-deep)}
.post figure{margin:32px 0}
.post figure img{width:100%;border-radius:12px;display:block}
.post figcaption{font-size:13px;color:var(--ink-soft);text-align:center;margin-top:10px;font-style:italic}
.post blockquote{font-family:var(--font-display);font-weight:500;font-size:25px;line-height:1.4;color:var(--sg-deep);border-left:3px solid rgba(var(--sg-rgb),.5);padding-left:24px;margin:32px 0}
.post .post-end{margin-top:48px;padding-top:30px;border-top:var(--hair) solid var(--line);text-align:center}
.post .post-end p{font-family:var(--font-display);font-size:22px;color:var(--ink);margin-bottom:16px}
@media (max-width:760px){
  .page-post .post{padding-top:24px}
  .post .post-head h1{font-size:34px}
  .post p{font-size:16px}
  .post h2{font-size:25px}
  .post blockquote{font-size:22px}
}
/* only the bottom strip is darkened (for the title); the rest of the photo stays bright + punchy */
.phero .scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6) 0,rgba(0,0,0,.3) 80px,rgba(0,0,0,0) 180px)}
.phero .pt{position:absolute;left:0;right:0;bottom:0;padding:0 38px 36px;color:#fff;text-shadow:0 1px 16px rgba(0,0,0,.55)}
.phero h1{font-family:var(--font-display);font-weight:500;font-size:52px;line-height:1.02}
.phero p{font-weight:var(--w-regular);font-size:15.5px;margin-top:10px;max-width:520px;opacity:.95;line-height:1.5}
.intro{padding:50px var(--edge) 26px;text-align:center;max-width:760px;margin:0 auto}
.intro .eyebrow{margin-bottom:10px}
.intro p{color:var(--ink-soft);font-weight:var(--w-regular);font-size:16px;line-height:1.7}

/* masonry gallery (columns + gaps come from tokens, admin-controllable) */
.galwrap{padding:14px var(--edge) 10px;max-width:1320px;margin:0 auto}
.gallery{column-count:var(--gal-cols-d);column-gap:var(--gal-gap-d)}
.gallery .ph{display:block;width:100%;margin:0 0 var(--gal-gap-d);break-inside:avoid;overflow:hidden;cursor:zoom-in;background:var(--cream-2);border-radius:4px}
.gallery .ph img{width:100%;height:auto;display:block;transition:transform .7s ease}
.gallery .ph:hover img{transform:scale(1.05)}
/* dynamically-rendered galleries: explicit columns filled round-robin = left-to-right reading order */
.gallery.galdyn{display:flex;column-count:auto;gap:var(--g,6px);align-items:flex-start}
.gallery.galdyn .gcol{display:flex;flex-direction:column;gap:var(--g,6px);flex:1 1 0;min-width:0}
.gallery.galdyn .ph{margin:0;width:100%}
/* fade each photo in as it decodes (boxes are pre-sized, so nothing shifts) */
.gallery.galdyn .ph img{opacity:0;transition:opacity .5s ease,transform .7s ease}
.gallery.galdyn .ph img.rdy{opacity:1}
/* single-column galleries: photos are already full width, so no zoom cursor or hover */
.gallery.gal1 .ph{cursor:default}
.gallery.gal1 .ph:hover img{transform:none}

/* what to expect (gallery) */
.expect{padding:60px var(--edge);text-align:center;background:var(--cream-2);margin-top:30px}
.expect h2{font-family:var(--font-display);font-weight:500;font-size:34px;margin:12px 0 14px}
.expect p{color:var(--ink-soft);font-weight:var(--w-regular);font-size:16px;line-height:1.75;max-width:680px;margin:0 auto}

/* price teaser (gallery) */
.price-teaser{padding:60px var(--edge);text-align:center}
.price-teaser .card{display:inline-block;border:var(--hair) solid var(--line);background:var(--surface);border-radius:16px;padding:34px 46px;max-width:420px}
.price-teaser .lab{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--sg-deep)}
.price-teaser .amt{font-family:var(--font-display);font-size:46px;margin:8px 0 4px;font-weight:500;font-variant-numeric:lining-nums;font-feature-settings:"lnum" 1}
.price-teaser .sm{font-size:13px;color:var(--ink-soft);font-weight:var(--w-regular);line-height:1.6}
.price-teaser .btn{margin-top:22px}

/* ============================================================
   FOOTER (links, FAQ, signup, socials, NAP for local SEO)
   ============================================================ */
.site-foot{background:var(--ink);color:var(--cream)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:40px;padding:56px var(--edge) 40px;max-width:1320px;margin:0 auto}
.foot-brand .fmark{font-family:var(--font-display);font-weight:500;font-size:26px;line-height:1.1}
.foot-brand p{font-size:13px;line-height:1.7;opacity:.78;margin-top:14px;max-width:300px}
.foot-brand .nap{font-size:13px;line-height:1.8;opacity:.85;margin-top:16px}
.foot-brand .nap a{color:var(--sg-light);text-decoration:none}
.foot-col h5{font-size:11px;letter-spacing:.22em;text-transform:uppercase;opacity:.6;margin-bottom:16px}
.foot-col a{display:block;color:var(--cream);text-decoration:none;opacity:.82;font-size:14px;padding:5px 0;transition:opacity .15s ease,color .15s ease}
.foot-col a:hover{opacity:1;color:var(--sg-light)}
.foot-signup p{font-size:13px;opacity:.78;line-height:1.6;margin-bottom:14px}
.foot-signup form{display:flex;gap:8px}
.foot-signup input{flex:1;min-width:0;background:rgba(255,255,255,.07);border:var(--hair) solid rgba(255,255,255,.2);border-radius:999px;padding:11px 16px;color:#fff;font-family:var(--font-body);font-size:13px}
.foot-signup input::placeholder{color:rgba(255,255,255,.5)}
.foot-signup button{flex-shrink:0;background:rgba(var(--sg-rgb),.5);border:var(--hair) solid rgba(255,255,255,.4);color:#fff;border-radius:999px;padding:11px 18px;font-family:var(--font-body);font-size:12px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}
.foot-socials{display:flex;gap:14px;margin-top:18px}
.foot-socials a{opacity:.8}
.foot-socials a:hover{opacity:1}
.foot-socials svg{width:20px;height:20px;display:block}
.foot-bottom{border-top:var(--hair) solid rgba(255,255,255,.12);padding:20px var(--edge);max-width:1320px;margin:0 auto;display:flex;justify-content:space-between;gap:14px;font-size:12px;opacity:.7;flex-wrap:wrap}

/* ============================================================
   LIGHTBOX (root-level, shared site-wide) - cream glass, scale-in
   ============================================================ */
.lb{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;
  background:rgba(241,239,232,.55);backdrop-filter:blur(22px) saturate(1.15);-webkit-backdrop-filter:blur(22px) saturate(1.15);
  opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s ease}
.lb.show{opacity:1;visibility:visible}
.lbstage{position:relative;width:86vw;height:84vh;transform:scale(.93);transition:transform .42s cubic-bezier(.2,.8,.2,1)}
.lb.show .lbstage{transform:scale(1)}
.lbstage img{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);max-width:86vw;max-height:84vh;
  width:auto;height:auto;object-fit:contain;border-radius:8px;box-shadow:0 30px 80px rgba(29,27,24,.32);
  opacity:0;transition:opacity .3s ease}
.lbstage img.on{opacity:1}
.lb .x,.lb .lba{position:absolute;color:var(--ink);cursor:pointer;user-select:none;
  background:rgba(255,255,255,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:var(--hair) solid rgba(29,27,24,.12);display:flex;align-items:center;justify-content:center;transition:background .15s ease}
.lb .x:hover,.lb .lba:hover{background:rgba(255,255,255,.9)}
.lb .x{top:22px;right:22px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;padding:11px 17px;border-radius:999px}
.lb .lba{top:50%;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;font-size:26px;line-height:1}
.lb .prev{left:18px}
.lb .next{right:18px}

/* ============================================================
   RESPONSIVE (mobile)
   ============================================================ */
@media (max-width:880px){
  .meet{grid-template-columns:1fr}
  .meet .mpic{min-height:380px}
  .foot-top{grid-template-columns:1fr 1fr;gap:32px}
  .foot-signup{grid-column:1 / -1}
}
@media (max-width:760px){
  :root{--section-pad-x:22px;--edge:18px;--section-pad-y:50px}
  .navlinks{display:none}
  .nav-cta{display:none}
  .burger{display:flex}
  .mobile-menu{display:flex}
  .wordmark img{height:38px}
  .hero{height:564px}
  .hero h1{font-size:40px}
  .hero .sub{font-size:15px}
  .hero .cta{flex-direction:column;align-items:flex-start}
  .hero .dots{top:24px}
  .lead h2{font-size:29px}
  .genres{grid-template-columns:1fr}
  .genre{height:320px}
  .meet .mtext{padding:44px 24px}
  .meet .mtext h2{font-size:32px}
  .stats{grid-template-columns:1fr 1fr}
  .stat{border-right:0;border-bottom:var(--hair) solid rgba(255,255,255,.12)}
  .quote{padding:52px 22px}
  .quote p{font-size:23px}
  .blog-grid{grid-template-columns:1fr}
  .ctaband h2{font-size:31px}
  .phero{height:320px;border-radius:8px}
  .phero h1{font-size:34px}
  .gallery{column-count:var(--gal-cols-m);column-gap:var(--gal-gap-m)}
  .gallery .ph{margin-bottom:var(--gal-gap-m)}
  .expect h2{font-size:27px}
  .price-teaser .card{width:100%;padding:28px 26px}
  .price-teaser .amt{font-size:38px}
  .foot-top{grid-template-columns:1fr;gap:30px;padding:44px 22px 30px}
  .foot-bottom{flex-direction:column;text-align:center}
  .lbstage{width:94vw;height:80vh}
  .lbstage img{max-width:94vw;max-height:80vh}
}
