/* =========================================================================
   GREEDY COW BAKES — main.css
   Artisan doughnut counter · Hackney Road, London
   Palette pulled from the brand mark: espresso cocoa + warm cream + gold
   ========================================================================= */

:root{
  --cocoa:#1C1410;
  --cocoa-deep:#120C09;
  --cocoa-80:rgba(18,12,9,.80);
  --cream:#F6F0E4;
  --cream-soft:#FBF7EE;
  --paper:#EFE7D6;
  --gold:#C99A3F;
  --gold-soft:#D9B566;
  --caramel:#A9762A;
  --berry:#B8455A;
  --ink:#2A1E17;
  --ink-soft:#6A5849;
  --line:rgba(42,30,23,.12);
  --line-light:rgba(246,240,228,.16);
  --serif:'Fraunces', Georgia, 'Times New Roman', serif;
  --sans:'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --shadow:0 24px 60px -24px rgba(18,12,9,.45);
  --shadow-soft:0 14px 40px -20px rgba(18,12,9,.35);
  --maxw:1280px;
  --pad:clamp(40px,8vw,100px);
  --radius:18px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --header-h:74px;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  padding-top:var(--header-h);   /* solid fixed header — reserve its space so nothing sits under it */
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--gold);color:var(--cocoa-deep)}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.05;letter-spacing:-.01em}
.display{font-family:var(--serif);font-weight:600}
.eyebrow{
  font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.32em;
  text-transform:uppercase;color:var(--caramel);display:inline-block;
}
.eyebrow.on-dark{color:var(--gold-soft)}
.section-title{font-size:clamp(2rem,5.2vw,3.6rem);line-height:1.04;letter-spacing:-.02em}
.lead{font-size:clamp(1.05rem,2vw,1.3rem);color:var(--ink-soft);line-height:1.6}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:clamp(20px,5vw,40px);padding-right:clamp(20px,5vw,40px)}
.section{padding-top:var(--pad);padding-bottom:var(--pad)}
.section--dark{background:var(--cocoa);color:var(--cream)}
.section--deep{background:var(--cocoa-deep);color:var(--cream)}
.section--paper{background:var(--paper)}
.section--cream{background:var(--cream-soft)}
.center{text-align:center}
.mt-s{margin-top:14px}.mt-m{margin-top:26px}.mt-l{margin-top:46px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:.06em;
  text-transform:uppercase;padding:16px 30px;border-radius:100px;
  min-height:52px;transition:all .3s var(--ease);will-change:transform;
}
.btn--gold{background:var(--gold);color:var(--cocoa-deep);box-shadow:0 10px 30px -10px rgba(201,154,63,.6)}
.btn--gold:hover{background:var(--gold-soft);transform:translateY(-3px);box-shadow:0 16px 38px -10px rgba(201,154,63,.75)}
.btn--ghost{border:1.5px solid currentColor;color:inherit}
.btn--ghost:hover{background:var(--cream);color:var(--cocoa);transform:translateY(-3px)}
.btn--ghost.on-dark:hover{background:var(--gold);border-color:var(--gold);color:var(--cocoa-deep)}
.btn--ink{background:var(--cocoa);color:var(--cream)}
.btn--ink:hover{background:var(--cocoa-deep);transform:translateY(-3px)}
.btn .ico{width:18px;height:18px;flex:0 0 auto}

/* =========================================================================
   HEADER
   ========================================================================= */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:120;
  display:flex;align-items:center;justify-content:space-between;
  min-height:var(--header-h);padding:0 clamp(20px,5vw,46px);
  background:var(--cocoa);                       /* SOLID — never transparent over hero */
  box-shadow:0 1px 0 var(--line-light);
  transition:box-shadow .4s var(--ease);
}
.site-header.scrolled{box-shadow:0 12px 34px -18px rgba(0,0,0,.65)}
.brand{display:flex;align-items:center;gap:12px;z-index:122}
.brand img{height:38px;width:auto}
.brand .brand-txt{font-family:var(--serif);font-size:1.35rem;color:var(--cream);font-weight:600;letter-spacing:-.01em}
.nav{display:flex;align-items:center;gap:34px}
.nav a{
  font-size:14px;font-weight:500;letter-spacing:.04em;color:rgba(246,240,228,.86);
  position:relative;padding:4px 0;transition:color .25s;
}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--gold);transition:width .3s var(--ease)}
.nav a:hover{color:var(--cream)}
.nav a:hover::after{width:100%}
.header-cta{display:inline-flex}
.burger{display:none;z-index:122;width:46px;height:46px;flex-direction:column;justify-content:center;align-items:center;gap:5px}
.burger span{display:block;width:24px;height:2px;background:var(--cream);border-radius:2px;transition:transform .35s var(--ease),opacity .25s}
.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 nav */
.mobile-nav{
  position:fixed;inset:0;z-index:121;background:var(--cocoa-deep);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;
  opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s;
}
.menu-open .mobile-nav{opacity:1;visibility:visible}
.mobile-nav a{
  font-family:var(--serif);font-size:clamp(2rem,9vw,2.8rem);color:var(--cream);
  font-weight:500;transform:translateY(18px);opacity:0;transition:all .4s var(--ease);
}
.menu-open .mobile-nav a{transform:none;opacity:1}
.menu-open .mobile-nav a:nth-child(1){transition-delay:.08s}
.menu-open .mobile-nav a:nth-child(2){transition-delay:.13s}
.menu-open .mobile-nav a:nth-child(3){transition-delay:.18s}
.menu-open .mobile-nav a:nth-child(4){transition-delay:.23s}
.menu-open .mobile-nav a:nth-child(5){transition-delay:.28s}
.menu-open .mobile-nav a:nth-child(6){transition-delay:.33s}
.mobile-nav a:hover{color:var(--gold)}
.mobile-nav .m-meta{margin-top:30px;font-family:var(--sans);font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);opacity:.9}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{
  position:relative;min-height:calc(100svh - var(--header-h));display:flex;align-items:flex-end;
  color:var(--cream);overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 38%}
.hero__bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(18,12,9,.55) 0%,rgba(18,12,9,.18) 32%,rgba(18,12,9,.65) 78%,rgba(18,12,9,.95) 100%);
}
.hero__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,40px) clamp(48px,8vh,96px)}
.hero__inner{padding-bottom:max(clamp(48px,8vh,96px),calc(env(safe-area-inset-bottom) + 48px))}
.hero h1{
  font-size:clamp(2.6rem,8.5vw,5.6rem);line-height:.98;letter-spacing:-.025em;max-width:14ch;
  text-shadow:0 2px 30px rgba(0,0,0,.35);
}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero__sub{margin-top:22px;font-size:clamp(1.05rem,2.4vw,1.35rem);max-width:46ch;color:rgba(246,240,228,.9)}
.hero__cta{margin-top:34px;display:flex;flex-wrap:wrap;gap:14px}
.hero__badges{margin-top:34px;display:flex;flex-wrap:wrap;gap:22px 30px;align-items:center}
.hero__badge{display:flex;align-items:center;gap:9px;font-size:13.5px;letter-spacing:.04em;color:rgba(246,240,228,.85)}
.hero__badge b{color:var(--cream)}
.hero__badge .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.hero__scroll{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:2;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:rgba(246,240,228,.6);writing-mode:vertical-rl;animation:floaty 2.4s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* =========================================================================
   SOCIAL PROOF STRIP
   ========================================================================= */
.proof{background:var(--cocoa-deep);color:var(--cream);padding:26px 0;border-top:1px solid var(--line-light);border-bottom:1px solid var(--line-light)}
.proof__row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:22px 48px}
.proof__item{display:flex;align-items:center;gap:12px}
.proof__stars{color:var(--gold);font-size:18px;letter-spacing:2px}
.proof__num{font-family:var(--serif);font-size:1.5rem;line-height:1}
.proof__lbl{font-size:12.5px;letter-spacing:.06em;color:rgba(246,240,228,.72);text-transform:uppercase}
.proof__sep{width:1px;height:34px;background:var(--line-light)}
@media(max-width:640px){.proof__sep{display:none}}

/* =========================================================================
   MENU
   ========================================================================= */
.menu-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:24px}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(24px,3vw,44px);margin-top:54px}
.menu-card{position:relative;background:var(--cream-soft);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.menu-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.menu-card__media{position:relative;aspect-ratio:16/10;overflow:hidden}
.menu-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.menu-card:hover .menu-card__media img{transform:scale(1.07)}
.menu-card__tag{position:absolute;top:14px;left:14px;background:var(--cocoa-deep);color:var(--gold-soft);font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:7px 13px;border-radius:100px}
.menu-card__body{padding:26px clamp(22px,2.4vw,30px) 30px}
.menu-card h3{font-size:1.5rem}
.menu-card__items{margin-top:16px;display:flex;flex-direction:column;gap:11px}
.menu-card__items li{display:flex;justify-content:space-between;gap:14px;align-items:baseline;font-size:15.5px;color:var(--ink);padding-bottom:11px;border-bottom:1px dashed var(--line)}
.menu-card__items li:last-child{border-bottom:none;padding-bottom:0}
.menu-card__items b{font-weight:600}
.menu-card__items span{color:var(--ink-soft);font-size:13.5px;text-align:right;font-style:italic}
.menu-note{margin-top:30px;font-size:14px;color:var(--ink-soft);font-style:italic}

/* =========================================================================
   ABOUT / STORY  (asymmetric overlap)
   ========================================================================= */
.story{position:relative}
.story__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,80px);align-items:center}
.story__media{position:relative}
.story__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;aspect-ratio:4/5;object-fit:cover}
.story__media .stamp{
  position:absolute;bottom:-26px;right:-18px;background:var(--gold);color:var(--cocoa-deep);
  width:142px;height:142px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;box-shadow:var(--shadow-soft);transform:rotate(-8deg);
}
.story__media .stamp b{font-family:var(--serif);font-size:1.9rem;line-height:1}
.story__media .stamp span{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;margin-top:4px}
.story__body h2{font-size:clamp(1.9rem,4.6vw,3.1rem);max-width:16ch}
.story__sign{margin-top:28px;font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--caramel)}
.story__sign small{display:block;font-family:var(--sans);font-style:normal;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px}

/* =========================================================================
   PROCESS / DIFFERENTIATORS
   ========================================================================= */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,40px);margin-top:54px}
.step{padding:34px 30px;border-radius:var(--radius);background:rgba(246,240,228,.04);border:1px solid var(--line-light);transition:transform .4s var(--ease),background .4s var(--ease)}
.section--paper .step,.section--cream .step{background:var(--cream-soft);border-color:var(--line)}
.step:hover{transform:translateY(-6px)}
.section--dark .step:hover,.section--deep .step:hover{background:rgba(201,154,63,.08)}
.step__n{font-family:var(--serif);font-size:2.6rem;color:var(--gold);line-height:1}
.step h3{font-size:1.4rem;margin-top:16px}
.step p{margin-top:12px;color:var(--ink-soft);font-size:15.5px}
.section--dark .step p,.section--deep .step p{color:rgba(246,240,228,.74)}

/* =========================================================================
   TESTIMONIALS
   ========================================================================= */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,34px);margin-top:54px}
.testi{background:var(--cream-soft);border:1px solid var(--line);border-radius:var(--radius);padding:32px 30px;display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.testi:hover{transform:translateY(-6px);box-shadow:var(--shadow-soft)}
.testi__stars{color:var(--gold);letter-spacing:2px;font-size:16px}
.testi__quote{font-family:var(--serif);font-size:1.2rem;line-height:1.5;margin-top:16px;color:var(--ink)}
.testi__by{margin-top:auto;padding-top:22px;display:flex;align-items:center;gap:13px}
.testi__av{width:42px;height:42px;border-radius:50%;background:var(--gold);color:var(--cocoa-deep);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:600;font-size:1.1rem}
.testi__by b{display:block;font-size:14.5px}
.testi__by span{font-size:12.5px;color:var(--ink-soft)}

/* =========================================================================
   GALLERY (masonry)
   ========================================================================= */
.gallery{columns:3;column-gap:16px}
.gallery a{display:block;margin-bottom:16px;border-radius:14px;overflow:hidden;position:relative;break-inside:avoid}
.gallery img{width:100%;display:block;transition:transform .7s var(--ease),filter .5s}
.gallery a::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(18,12,9,.5));opacity:0;transition:opacity .4s}
.gallery a:hover img{transform:scale(1.06)}
.gallery a:hover::after{opacity:1}

/* =========================================================================
   FAQ accordion
   ========================================================================= */
.faq{max-width:820px;margin:46px auto 0}
.faq__item{border-bottom:1px solid var(--line)}
.section--dark .faq__item,.section--deep .faq__item{border-color:var(--line-light)}
.faq__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px;text-align:left;padding:26px 4px;font-family:var(--serif);font-size:clamp(1.1rem,2.4vw,1.4rem);color:inherit}
.faq__q .pm{flex:0 0 auto;width:30px;height:30px;border-radius:50%;border:1.5px solid currentColor;position:relative;opacity:.6;transition:.3s}
.faq__q .pm::before,.faq__q .pm::after{content:"";position:absolute;background:currentColor;top:50%;left:50%;transition:.3s var(--ease)}
.faq__q .pm::before{width:12px;height:1.5px;transform:translate(-50%,-50%)}
.faq__q .pm::after{width:1.5px;height:12px;transform:translate(-50%,-50%)}
.faq__item.open .pm{opacity:1;background:var(--gold);border-color:var(--gold);color:var(--cocoa-deep)}
.faq__item.open .pm::after{transform:translate(-50%,-50%) scaleY(0)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq__a p{padding:0 4px 26px;color:var(--ink-soft);font-size:16px;max-width:64ch}
.section--dark .faq__a p,.section--deep .faq__a p{color:rgba(246,240,228,.76)}

/* =========================================================================
   LOCATION
   ========================================================================= */
.loc__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,64px);align-items:stretch}
.loc__info h2{font-size:clamp(1.9rem,4.6vw,3rem)}
.loc__rows{margin-top:30px;display:flex;flex-direction:column;gap:22px}
.loc__row{display:flex;gap:16px;align-items:flex-start}
.loc__row .ico{flex:0 0 auto;width:44px;height:44px;border-radius:50%;background:rgba(201,154,63,.14);display:flex;align-items:center;justify-content:center;color:var(--gold)}
.section--dark .loc__row .ico{background:rgba(201,154,63,.16)}
.loc__row b{display:block;font-family:var(--serif);font-size:1.15rem}
.loc__row span,.loc__row a{display:block;color:var(--ink-soft);font-size:15.5px;margin-top:3px}
.section--dark .loc__row span,.section--dark .loc__row a{color:rgba(246,240,228,.76)}
.loc__row a:hover{color:var(--gold)}
.loc__hours{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.loc__hours li{display:flex;justify-content:space-between;gap:18px;font-size:15px;padding-bottom:8px;border-bottom:1px dashed var(--line)}
.section--dark .loc__hours li{border-color:var(--line-light)}
.loc__hours li.today{color:var(--gold)}
.loc__hours li.closed{opacity:.55}
.loc__map{border-radius:var(--radius);overflow:hidden;min-height:420px;box-shadow:var(--shadow);background:var(--cocoa)}
.loc__map iframe{width:100%;height:100%;min-height:420px;border:0;display:block;filter:grayscale(.2) contrast(1.05)}

/* =========================================================================
   FINAL CTA
   ========================================================================= */
.finalcta{position:relative;overflow:hidden;text-align:center;background:var(--cocoa-deep);color:var(--cream)}
.finalcta::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(201,154,63,.22),transparent 60%)}
.finalcta__in{position:relative;z-index:2;max-width:780px;margin:0 auto}
.finalcta h2{font-size:clamp(2.2rem,6vw,4.2rem);line-height:1.02}
.finalcta p{margin-top:20px;font-size:1.15rem;color:rgba(246,240,228,.84)}
.finalcta__cta{margin-top:36px;display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{background:var(--cocoa);color:var(--cream);padding:72px 0 40px}
.foot__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(30px,5vw,70px)}
.foot__brand img{height:46px;width:auto;margin-bottom:18px}
.foot__brand p{color:rgba(246,240,228,.7);font-size:15px;max-width:34ch}
.foot__social{display:flex;gap:12px;margin-top:22px}
.foot__social a{width:42px;height:42px;border-radius:50%;border:1px solid var(--line-light);display:flex;align-items:center;justify-content:center;transition:.3s var(--ease)}
.foot__social a:hover{background:var(--gold);border-color:var(--gold);color:var(--cocoa-deep);transform:translateY(-3px)}
.foot__social svg{width:18px;height:18px}
.foot__col h4{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);font-family:var(--sans);font-weight:600;margin-bottom:18px}
.foot__col ul{display:flex;flex-direction:column;gap:11px}
.foot__col a,.foot__col li{color:rgba(246,240,228,.72);font-size:15px;transition:color .25s}
.foot__col a:hover{color:var(--gold)}
.foot__bottom{margin-top:54px;padding-top:24px;border-top:1px solid var(--line-light);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;font-size:13px;color:rgba(246,240,228,.55)}
.foot__bottom a:hover{color:var(--gold)}

/* =========================================================================
   MOBILE BOTTOM ACTION BAR
   ========================================================================= */
.actionbar{
  position:fixed;left:0;right:0;bottom:0;z-index:115;display:none;
  height:64px;background:var(--gold);
  box-shadow:0 -8px 30px -12px rgba(18,12,9,.5);
  padding-bottom:env(safe-area-inset-bottom);
}
.actionbar a{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  color:var(--cocoa-deep);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  min-height:64px;position:relative;
}
.actionbar a+a::before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:1px;background:rgba(18,12,9,.18)}
.actionbar a.primary{background:var(--cocoa-deep);color:var(--gold)}
.actionbar svg{width:22px;height:22px}

/* =========================================================================
   GENERIC PAGE (sub-pages)
   ========================================================================= */
.page-hero{padding:clamp(54px,8vw,90px) 0 clamp(50px,7vw,80px);background:var(--cocoa);color:var(--cream);text-align:center;position:relative}
.page-hero h1{font-size:clamp(2.4rem,6.5vw,4rem)}
.page-hero p{margin-top:16px;color:rgba(246,240,228,.8);max-width:60ch;margin-left:auto;margin-right:auto}
.page-hero .crumbs{font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:18px}
.page-hero .crumbs a:hover{color:var(--cream)}
.entry{max-width:780px;margin:0 auto}
.entry h2{font-size:1.9rem;margin:38px 0 14px}
.entry h3{font-size:1.4rem;margin:28px 0 10px}
.entry p{margin-bottom:18px;color:var(--ink);line-height:1.75}
.entry ul{list-style:disc;padding-left:22px;margin-bottom:18px;color:var(--ink)}
.entry ul li{margin-bottom:8px}
.entry a{color:var(--caramel);text-decoration:underline;text-underline-offset:3px}
.contact-form{display:flex;flex-direction:column;gap:16px;margin-top:30px}
.contact-form label{font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft)}
.contact-form input,.contact-form textarea{
  width:100%;padding:15px 18px;border:1px solid var(--line);border-radius:12px;
  font-family:var(--sans);font-size:16px;background:var(--cream-soft);color:var(--ink);
}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--gold);border-color:var(--gold)}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media(max-width:1024px){
  .nav{gap:24px}
  .menu-grid{gap:24px}
  .gallery{columns:2}
}
@media(max-width:900px){
  .story__grid{grid-template-columns:1fr;gap:48px}
  .story__media{max-width:480px}
  .story__media .stamp{width:120px;height:120px}
  .loc__grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr 1fr}
  .foot__grid{grid-template-columns:1fr 1fr}
  .foot__brand{grid-column:1/-1}
}
@media(max-width:760px){
  body{padding-bottom:64px}            /* room for action bar */
  .nav,.header-cta{display:none}
  .burger{display:flex}
  .actionbar{display:flex}
  .menu-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .gallery{columns:2;column-gap:12px}
  .gallery a{margin-bottom:12px}
  .hero{min-height:calc(90svh - var(--header-h))}
  .hero h1{font-size:clamp(2.4rem,11vw,3.4rem)}
  .proof__row{gap:14px 26px}
  .foot__grid{grid-template-columns:1fr}
  .foot__bottom{justify-content:center;text-align:center}
}
@media(max-width:430px){
  :root{--pad:clamp(40px,12vw,56px)}
  .gallery{columns:1}
  .menu-card__items span{display:none}
  .story__media .stamp{right:8px;bottom:-20px;width:104px;height:104px}
  .hero__badges{gap:12px 18px}
}
