/*
Theme Name: Good Measure
Theme URI: https://goodmeasure.site
Author: Good Measure
Author URI: https://goodmeasure.site
Description: A bespoke, editorial theme for Good Measure — a warm, timber-clad café-by-day, bar-by-night on Lygon Street, Carlton. Day-to-night design language, magpie brand motif, full schema and a mobile-first build.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: good-measure
*/

/* ============================================================
   0. TOKENS
   ============================================================ */
:root{
  --ink:#1a1613;          /* warm near-black (night base) */
  --ink-soft:#241f1a;
  --ink-2:#2e2820;
  --bone:#f4ecdd;         /* paper / day base */
  --bone-2:#ece0cd;
  --bone-3:#e2d3bb;
  --ember:#d85830;        /* exact brand vermilion */
  --ember-deep:#b8431f;
  --ember-glow:rgba(216,88,48,.16);
  --sage:#6e7257;         /* plants / La Marzocco green */
  --sage-deep:#545740;
  --timber:#8c5a3a;
  --cream-line:rgba(244,236,221,.16);
  --ink-line:rgba(26,22,19,.12);
  --muted-ink:rgba(26,22,19,.62);
  --muted-bone:rgba(244,236,221,.66);

  --display:'Fraunces',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  --pad:clamp(40px,8vw,100px);
  --wrap:1280px;
  --gut:clamp(20px,5vw,56px);
  --radius:14px;
  --radius-lg:22px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --shadow:0 22px 60px -28px rgba(26,22,19,.55);
  --shadow-soft:0 14px 40px -24px rgba(26,22,19,.4);
}

/* ============================================================
   1. RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--bone);
  color:var(--ink);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
ul{list-style:none;padding:0}
h1,h2,h3,h4{font-family:var(--display);font-weight:550;line-height:1.04;letter-spacing:-.01em;font-optical-sizing:auto}
::selection{background:var(--ember);color:var(--bone)}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:var(--pad)}
.eyebrow{
  font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.28em;
  text-transform:uppercase;color:var(--ember);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--ember);display:inline-block}
.section--night{background:var(--ink);color:var(--bone)}
.section--night .eyebrow{color:var(--ember)}
.section--ink2{background:var(--ink-soft);color:var(--bone)}

/* fluid display scale */
.d1{font-size:clamp(2.7rem,8.5vw,6.2rem)}
.d2{font-size:clamp(2.1rem,5.2vw,4rem)}
.d3{font-size:clamp(1.6rem,3.2vw,2.6rem)}
.lead{font-size:clamp(1.05rem,1.6vw,1.32rem);line-height:1.55}
.muted{color:var(--muted-ink)}
.section--night .muted,.section--ink2 .muted{color:var(--muted-bone)}
.serif-i{font-family:var(--display);font-style:italic;font-weight:400}
.ember{color:var(--ember)}

/* ============================================================
   2. BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:16px 30px;border-radius:100px;font-weight:600;font-size:14px;
  letter-spacing:.04em;line-height:1;transition:all .3s var(--ease);
  min-height:48px;white-space:nowrap;
}
.btn--primary{background:var(--ember);color:#fff;box-shadow:0 10px 30px -12px var(--ember)}
.btn--primary:hover{background:var(--ember-deep);transform:translateY(-2px);box-shadow:0 16px 34px -12px var(--ember)}
.btn--ghost{border:1.5px solid currentColor;color:inherit}
.btn--ghost:hover{background:var(--ink);color:var(--bone);transform:translateY(-2px)}
.section--night .btn--ghost:hover{background:var(--bone);color:var(--ink)}
.btn--light{background:var(--bone);color:var(--ink)}
.btn--light:hover{background:#fff;transform:translateY(-2px)}
.btn-arrow{transition:transform .3s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(4px)}

/* ============================================================
   3. HEADER
   ============================================================ */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:80;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
  padding-block:18px;
}
.site-header__bar{display:flex;align-items:center;justify-content:space-between;gap:24px}
.site-header.is-scrolled{
  background:rgba(26,22,19,.92);backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--cream-line);padding-block:10px;
}
.brand{display:flex;align-items:center;gap:12px;z-index:90}
.brand img{height:46px;width:auto;transition:height .3s var(--ease)}
.site-header.is-scrolled .brand img{height:38px}
.brand__txt{font-family:var(--display);font-weight:600;font-size:1.15rem;color:var(--bone);line-height:1;display:none}

.nav{display:flex;align-items:center;gap:34px}
.nav a{font-size:14px;font-weight:500;color:var(--bone);letter-spacing:.01em;position:relative;padding:6px 0;opacity:.9;transition:opacity .25s}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--ember);transition:width .3s var(--ease)}
.nav a:hover{opacity:1}
.nav a:hover::after{width:100%}
.header-cta{display:inline-flex}

/* transparent header text sits on dark hero, so default is bone; on light inner pages we force solid */
.header--solid{background:rgba(26,22,19,.96);backdrop-filter:blur(14px)}

/* hamburger */
.burger{display:none;flex-direction:column;gap:5px;width:46px;height:46px;align-items:center;justify-content:center;z-index:90}
.burger span{width:24px;height:2px;background:var(--bone);transition:transform .3s var(--ease),opacity .3s}
.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-open .burger span:nth-child(2){opacity:0}
.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile overlay */
.mobile-nav{
  position:fixed;inset:0;background:var(--ink);z-index:85;
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;
  opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s;
  padding:40px;
}
.menu-open .mobile-nav{opacity:1;visibility:visible}
.mobile-nav a{font-family:var(--display);font-size:clamp(2rem,9vw,3rem);color:var(--bone);padding:8px 0;opacity:0;transform:translateY(18px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.menu-open .mobile-nav a{opacity:1;transform:none}
.menu-open .mobile-nav a:nth-child(1){transition-delay:.08s}
.menu-open .mobile-nav a:nth-child(2){transition-delay:.14s}
.menu-open .mobile-nav a:nth-child(3){transition-delay:.2s}
.menu-open .mobile-nav a:nth-child(4){transition-delay:.26s}
.menu-open .mobile-nav a:nth-child(5){transition-delay:.32s}
.menu-open .mobile-nav a:nth-child(6){transition-delay:.38s}
.menu-open .mobile-nav a:nth-child(7){transition-delay:.44s}
.mobile-nav__meta{margin-top:30px;color:var(--muted-bone);font-size:13px;letter-spacing:.18em;text-transform:uppercase;opacity:0;transition:opacity .5s .5s}
.menu-open .mobile-nav__meta{opacity:1}

/* ============================================================
   4. HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;background:var(--ink);overflow:hidden;color:var(--bone)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 42%}
.hero__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(26,22,19,.55) 0%,rgba(26,22,19,.2) 32%,rgba(26,22,19,.78) 78%,rgba(26,22,19,.96) 100%);}
.hero__inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(90px,11vw,120px);padding-top:140px}
.hero__tag{display:inline-flex;align-items:center;gap:.7em;font-size:12.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--bone);
  border:1px solid var(--cream-line);padding:9px 18px;border-radius:100px;margin-bottom:28px;backdrop-filter:blur(4px)}
.hero__tag b{color:var(--ember);font-weight:700}
.hero h1{max-width:14ch;margin-bottom:22px;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.hero h1 em{font-style:italic;font-weight:300;color:var(--ember)}
.hero__sub{max-width:46ch;color:var(--muted-bone);margin-bottom:34px;font-size:clamp(1rem,1.5vw,1.2rem)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero__scroll{position:absolute;right:var(--gut);bottom:34px;z-index:3;writing-mode:vertical-rl;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted-bone);display:flex;align-items:center;gap:14px}
.hero__scroll span{display:block;width:1px;height:50px;background:linear-gradient(var(--ember),transparent);animation:scrolldot 2.2s infinite}
@keyframes scrolldot{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ============================================================
   5. PROOF STRIP / MARQUEE
   ============================================================ */
.proof{background:var(--ember);color:#fff;padding-block:0;overflow:hidden}
.proof__row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px 40px;padding-block:24px}
.proof__item{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500}
.proof__item b{font-family:var(--display);font-size:1.5rem;font-weight:600;line-height:1}
.proof__item .stars{letter-spacing:2px;font-size:13px}
.proof__divider{width:1px;height:32px;background:rgba(255,255,255,.3);display:none}

/* ============================================================
   6. GENERIC SECTION HEADER
   ============================================================ */
.sec-head{max-width:760px;margin-bottom:clamp(40px,5vw,64px)}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head .eyebrow{margin-bottom:18px}
.sec-head h2{margin-bottom:16px}

/* ============================================================
   7. INTRO / DAY-NIGHT SPLIT
   ============================================================ */
.daynight{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,32px)}
.dn-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:clamp(380px,46vw,560px);display:flex;align-items:flex-end;color:var(--bone);box-shadow:var(--shadow)}
.dn-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.dn-card:hover img{transform:scale(1.06)}
.dn-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,22,19,.05),rgba(26,22,19,.85))}
.dn-card__body{position:relative;z-index:2;padding:clamp(26px,3vw,42px)}
.dn-card__k{font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--ember);font-weight:700;margin-bottom:12px;display:block}
.dn-card h3{font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:10px}
.dn-card p{color:var(--muted-bone);max-width:38ch}
.dn-card .hours-min{margin-top:16px;font-size:13px;color:var(--bone);letter-spacing:.04em}

/* ============================================================
   8. MENU
   ============================================================ */
.menu-tabs{display:flex;gap:10px;margin-bottom:42px;flex-wrap:wrap}
.menu-tab{padding:12px 26px;border-radius:100px;border:1.5px solid var(--cream-line);color:var(--bone);font-weight:600;font-size:14px;letter-spacing:.02em;transition:all .3s var(--ease)}
.menu-tab[aria-selected="true"]{background:var(--ember);border-color:var(--ember);color:#fff}
.menu-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(28px,4vw,60px);align-items:start}
.menu-list{display:grid;gap:6px}
.menu-item{display:grid;grid-template-columns:1fr auto;gap:6px 18px;padding:20px 0;border-bottom:1px solid var(--cream-line);align-items:baseline}
.menu-item__top{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.menu-item h4{font-size:1.3rem;font-weight:600}
.menu-item .badge{font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ember);border:1px solid var(--ember);padding:3px 8px;border-radius:100px}
.menu-item .price{font-family:var(--display);font-size:1.25rem;color:var(--ember);white-space:nowrap;font-feature-settings:"tnum"}
.menu-item p{grid-column:1/2;color:var(--muted-bone);font-size:.96rem;max-width:52ch}
.menu-figure{position:sticky;top:100px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:3/4}
.menu-figure img{width:100%;height:100%;object-fit:cover}
.menu-panel[hidden]{display:none}

/* ============================================================
   9. STORY / ABOUT
   ============================================================ */
.story{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.story__media{position:relative}
.story__media .img-main{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5}
.story__media .img-main img{width:100%;height:100%;object-fit:cover}
.story__media .img-badge{position:absolute;bottom:-26px;right:-10px;background:var(--ember);color:#fff;border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow);max-width:200px}
.story__media .img-badge b{font-family:var(--display);font-size:2.2rem;display:block;line-height:1}
.story__media .img-badge span{font-size:12px;letter-spacing:.08em;opacity:.92}
.story__body h2{margin-bottom:22px}
.story__body p{margin-bottom:18px}
.story__sign{margin-top:26px;display:flex;align-items:center;gap:16px}
.story__sign .nm{font-family:var(--display);font-style:italic;font-size:1.3rem;color:var(--ember)}
.story__sign .ro{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-ink)}

/* ============================================================
   10. PILLARS
   ============================================================ */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,28px)}
.pillar{border:1px solid var(--cream-line);border-radius:var(--radius-lg);padding:clamp(26px,3vw,40px);transition:transform .4s var(--ease),background .4s var(--ease);position:relative;overflow:hidden}
.pillar:hover{transform:translateY(-6px);background:var(--ink-soft)}
.pillar__n{font-family:var(--display);font-size:1rem;color:var(--ember);letter-spacing:.1em;margin-bottom:auto}
.pillar h3{font-size:clamp(1.5rem,2.4vw,2rem);margin:22px 0 12px}
.pillar p{color:var(--muted-bone)}
.pillar::after{content:"";position:absolute;right:-30px;bottom:-30px;width:110px;height:110px;border-radius:50%;background:var(--ember-glow);opacity:0;transition:opacity .4s}
.pillar:hover::after{opacity:1}

/* ============================================================
   11. TESTIMONIALS
   ============================================================ */
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.4vw,26px)}
.quote{background:var(--bone);border:1px solid var(--ink-line);border-radius:var(--radius-lg);padding:clamp(26px,3vw,40px);position:relative;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.quote:hover{transform:translateY(-5px);box-shadow:var(--shadow-soft)}
.quote .stars{color:var(--ember);letter-spacing:2px;margin-bottom:16px;font-size:14px}
.quote p{font-family:var(--display);font-size:clamp(1.15rem,1.8vw,1.4rem);line-height:1.4;margin-bottom:22px}
.quote__by{display:flex;align-items:center;gap:12px}
.quote__av{width:42px;height:42px;border-radius:50%;background:var(--ember);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--display)}
.quote__by .nm{font-weight:600;font-size:14px}
.quote__by .src{font-size:12px;color:var(--muted-ink)}

/* ============================================================
   12. GALLERY (masonry)
   ============================================================ */
.gallery{columns:3;column-gap:16px}
.gallery a{display:block;margin-bottom:16px;border-radius:var(--radius);overflow:hidden;break-inside:avoid;position:relative}
.gallery img{width:100%;display:block;transition:transform .7s var(--ease)}
.gallery a::after{content:"";position:absolute;inset:0;background:var(--ember);opacity:0;mix-blend-mode:multiply;transition:opacity .4s}
.gallery a:hover img{transform:scale(1.05)}
.gallery a:hover::after{opacity:.18}

/* ============================================================
   13. FAQ
   ============================================================ */
.faq{max-width:840px;margin-inline:auto}
.faq-item{border-bottom:1px solid var(--ink-line)}
.section--night .faq-item{border-color:var(--cream-line)}
.faq-q{width:100%;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:26px 0;font-family:var(--display);font-size:clamp(1.15rem,2vw,1.5rem);font-weight:550;color:inherit}
.faq-icon{flex:0 0 auto;width:34px;height:34px;border-radius:50%;border:1.5px solid var(--ember);position:relative;transition:background .3s}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;background:var(--ember);transition:transform .3s var(--ease),background .3s;top:50%;left:50%}
.faq-icon::before{width:13px;height:2px;transform:translate(-50%,-50%)}
.faq-icon::after{width:2px;height:13px;transform:translate(-50%,-50%)}
.faq-item.open .faq-icon{background:var(--ember)}
.faq-item.open .faq-icon::before,.faq-item.open .faq-icon::after{background:#fff}
.faq-item.open .faq-icon::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a p{padding-bottom:26px;color:var(--muted-ink);max-width:70ch}
.section--night .faq-a p{color:var(--muted-bone)}

/* ============================================================
   14. LOCATION
   ============================================================ */
.locate{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);align-items:stretch}
.locate__map{border-radius:var(--radius-lg);overflow:hidden;min-height:420px;box-shadow:var(--shadow);border:1px solid var(--cream-line)}
.locate__map iframe{width:100%;height:100%;min-height:420px;border:0;filter:grayscale(.25) contrast(1.05)}
.locate__info h2{margin-bottom:24px}
.info-row{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--cream-line)}
.info-row__ic{flex:0 0 auto;width:44px;height:44px;border-radius:50%;background:var(--ember-glow);color:var(--ember);display:grid;place-items:center}
.info-row h4{font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ember);margin-bottom:6px}
.info-row p{font-size:1.02rem}
.hours-table{width:100%;border-collapse:collapse;margin-top:6px}
.hours-table td{padding:7px 0;font-size:.96rem;border-bottom:1px solid var(--cream-line)}
.hours-table td:last-child{text-align:right;color:var(--muted-bone)}
.hours-table tr.today td{color:var(--ember);font-weight:600}
.hours-table tr.today td:last-child{color:var(--ember)}

/* ============================================================
   15. FINAL CTA
   ============================================================ */
.finalcta{position:relative;text-align:center;color:var(--bone);overflow:hidden;background:var(--ink)}
.finalcta__bg{position:absolute;inset:0;z-index:0}
.finalcta__bg img{width:100%;height:100%;object-fit:cover;opacity:.34}
.finalcta::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,rgba(216,88,48,.22),transparent 60%)}
.finalcta__in{position:relative;z-index:2;max-width:760px;margin-inline:auto}
.finalcta h2{margin:18px 0 20px}
.finalcta p{color:var(--muted-bone);margin-bottom:34px;font-size:clamp(1rem,1.5vw,1.2rem)}
.finalcta .hero__cta{justify-content:center}

/* ============================================================
   16. FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:var(--bone);padding-top:clamp(60px,7vw,90px)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;padding-bottom:56px;border-bottom:1px solid var(--cream-line)}
.footer-brand img{height:64px;margin-bottom:20px}
.footer-brand p{color:var(--muted-bone);max-width:32ch;font-size:.96rem}
.footer-col h4{font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ember);margin-bottom:18px}
.footer-col a,.footer-col p{display:block;color:var(--muted-bone);font-size:.96rem;padding:5px 0;transition:color .25s}
.footer-col a:hover{color:var(--bone)}
.socials{display:flex;gap:12px;margin-top:8px}
.socials a{width:42px;height:42px;border-radius:50%;border:1px solid var(--cream-line);display:grid;place-items:center;color:var(--bone);transition:all .3s var(--ease)}
.socials a:hover{background:var(--ember);border-color:var(--ember);transform:translateY(-3px)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding-block:26px;font-size:13px;color:var(--muted-bone)}
.footer-bottom a:hover{color:var(--bone)}

/* ============================================================
   17. MOBILE BOTTOM ACTION BAR
   ============================================================ */
.action-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:70;height:64px;
  background:var(--ember);display:none;grid-template-columns:repeat(3,1fr);
  box-shadow:0 -8px 30px -12px rgba(0,0,0,.4);
}
.action-bar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:#fff;
  font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;height:100%;}
.action-bar a + a{border-left:1px solid rgba(255,255,255,.22)}
.action-bar a svg{width:22px;height:22px}
.action-bar a.primary{background:var(--ink)}

/* ============================================================
   18. PAGE HERO (inner pages)
   ============================================================ */
.page-hero{background:var(--ink);color:var(--bone);padding-top:160px;padding-bottom:clamp(50px,6vw,80px);position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:320px;height:320px;border-radius:50%;background:var(--ember-glow)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .crumbs{font-size:13px;color:var(--muted-bone);margin-bottom:18px;letter-spacing:.04em}
.page-hero .crumbs a:hover{color:var(--ember)}
.page-hero h1{font-size:clamp(2.4rem,6vw,4.2rem);max-width:18ch}
.page-hero p{color:var(--muted-bone);max-width:54ch;margin-top:18px;font-size:1.1rem}

.page-body{padding-block:clamp(50px,7vw,90px)}
.prose{max-width:780px;margin-inline:auto}
.prose h2{font-size:clamp(1.6rem,3vw,2.2rem);margin:40px 0 16px}
.prose h3{font-size:1.4rem;margin:30px 0 12px}
.prose p{margin-bottom:18px;color:var(--ink);opacity:.88}
.prose ul{list-style:disc;padding-left:22px;margin-bottom:18px}
.prose ul li{margin-bottom:8px}
.prose a{color:var(--ember);text-decoration:underline;text-underline-offset:3px}

/* contact form */
.gm-form{display:grid;gap:16px;max-width:560px}
.gm-form label{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-ink);font-weight:600;margin-bottom:6px;display:block}
.gm-form input,.gm-form textarea{width:100%;padding:14px 16px;border:1.5px solid var(--ink-line);border-radius:12px;background:#fff;font-family:inherit;font-size:16px;color:var(--ink);transition:border-color .25s}
.gm-form input:focus,.gm-form textarea:focus{outline:none;border-color:var(--ember)}
.gm-form textarea{min-height:130px;resize:vertical}
.form-note{font-size:13px;color:var(--muted-ink)}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:start}
@media(max-width:880px){.two-col{grid-template-columns:1fr}.two-col .order-first{order:-1}}

/* reveal animation */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   19. RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr}
  .pillars{grid-template-columns:1fr}
  .pillar{display:flex;flex-direction:column}
  .gallery{columns:2}
}
@media(max-width:880px){
  body{padding-bottom:64px}
  .nav,.header-cta{display:none}
  .burger{display:flex}
  .action-bar{display:grid}
  .daynight{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:1fr}
  .menu-figure{display:none}
  .story{grid-template-columns:1fr}
  .story__media{order:-1;max-width:460px}
  .quotes{grid-template-columns:1fr}
  .locate{grid-template-columns:1fr}
  .proof__row{justify-content:center;text-align:center;gap:18px 28px}
  .brand img{height:40px}
}
@media(max-width:560px){
  :root{--gut:20px}
  .gallery{columns:1}
  .hero__inner{padding-bottom:96px}
  .story__media .img-badge{right:0;bottom:-20px;padding:16px 18px}
  .footer-top{grid-template-columns:1fr;gap:34px}
  .footer-bottom{flex-direction:column;text-align:center}
  .menu-item h4{font-size:1.15rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
