/* ==========================================================================
   CMNY Cakes — design system
   Palette: white sections, bold deep-orange -> pink gradient signature panels,
   warm dark footer. Type: Bricolage Grotesque (display) + Hanken Grotesk (body).
   All internal asset/link paths are root-absolute (/assets/..., /birthday-cakes/)
   so they resolve at any URL depth on Cloudflare Pages.
   ========================================================================== */

:root{
  --white:#ffffff;
  --ink:#26191e;          /* body text, warm near-black */
  --ink-soft:#6f5c63;     /* muted text */
  --line:#efe4e8;         /* hairline borders */
  --blush:#fff5f1;        /* very light warm tint, used sparingly */
  --blush-2:#fdeef0;

  --orange:#e2481b;       /* deep orange */
  --orange-deep:#c1380f;
  --pink:#e23f79;         /* bold rose */
  --pink-deep:#c62e66;

  --footer:#1d1216;       /* dark footer */
  --footer-soft:#c9b6bd;  /* footer muted text */

  --grad:linear-gradient(118deg,var(--orange) 0%,#e0416a 55%,var(--pink) 100%);
  --grad-soft:linear-gradient(118deg,#fff1ec 0%,#ffeaf0 100%);

  --radius:16px;
  --radius-lg:26px;
  --radius-pill:999px;
  --shadow:0 10px 30px -14px rgba(50,12,24,.20);
  --shadow-lg:0 26px 64px -24px rgba(50,12,24,.32);
  --ring:0 0 0 3px rgba(226,63,121,.35);

  --maxw:1180px;
  --pad:clamp(1.1rem,4vw,2.5rem);
  --sec:clamp(3.5rem,8vw,7rem);

  --font-display:"Bricolage Grotesque",system-ui,-apple-system,Segoe UI,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,-apple-system,Segoe UI,sans-serif;

  --header-h:74px;
}

/* ---- reset ---- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
html:focus-within{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--white);
  font-size:1.0625rem;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.05;
  letter-spacing:-.02em;margin:0 0 .5em;color:var(--ink)}
h1{font-size:clamp(2.4rem,6vw,4.15rem)}
h2{font-size:clamp(1.95rem,4vw,3rem)}
h3{font-size:clamp(1.28rem,2.5vw,1.7rem);font-weight:700}
p{margin:0 0 1rem}
:focus-visible{outline:3px solid var(--pink);outline-offset:2px;border-radius:6px}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);width:100%}
.section{padding-block:var(--sec)}
.section.section--tight{padding-block:clamp(2.4rem,5vw,4rem)}
.section--blush{background:var(--blush)}
.section--grad{background:var(--grad);color:#fff}
.section--dark{background:var(--footer);color:#fff}
.eyebrow{font-family:var(--font-body);font-weight:700;font-size:.8rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--pink-deep);margin:0 0 .9rem}
.section--grad .eyebrow,.section--dark .eyebrow{color:#ffd9c9}
.lede{font-size:clamp(1.05rem,1.8vw,1.28rem);color:var(--ink-soft);max-width:60ch}
.section--grad .lede{color:rgba(255,255,255,.92)}
.center{text-align:center}
.center .lede{margin-inline:auto}
.stack>*+*{margin-top:1rem}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-body);
  font-weight:700;font-size:1rem;line-height:1;padding:.95rem 1.6rem;border-radius:var(--radius-pill);
  transition:transform .16s ease,box-shadow .16s ease,background .16s ease,color .16s ease;
  white-space:nowrap}
.btn svg{width:1.05em;height:1.05em}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-on-grad{background:#fff;color:var(--orange-deep)}
.btn-on-grad:hover{transform:translateY(-2px);box-shadow:0 18px 40px -18px rgba(0,0,0,.5)}
.btn-outline{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 2px var(--line)}
.btn-outline:hover{box-shadow:inset 0 0 0 2px var(--pink);color:var(--pink-deep)}
.btn-ghost-light{background:rgba(255,255,255,.14);color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.5)}
.btn-ghost-light:hover{background:rgba(255,255,255,.24)}
.btn-lg{padding:1.1rem 2rem;font-size:1.06rem}

/* ==========================================================================
   HEADER / MEGA MENU
   ========================================================================== */
.site-header{position:sticky;top:0;z-index:100;background:#fff;
  border-bottom:1px solid var(--line);transition:box-shadow .2s ease}
.site-header.is-stuck{box-shadow:0 6px 24px -16px rgba(50,12,24,.4)}
.nav{display:flex;align-items:center;gap:1.25rem;min-height:var(--header-h);
  max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.brand{display:flex;align-items:center;flex:0 0 auto;margin-right:auto}
.brand img{height:44px;width:auto}
.brand .brand-fallback{font-family:var(--font-display);font-weight:800;font-size:1.35rem;
  letter-spacing:-.02em}
.brand .brand-fallback b{color:var(--pink-deep)}

.nav-links{display:flex;align-items:center;gap:.35rem}
.nav-links>li{position:relative}
.nav-link{display:inline-flex;align-items:center;gap:.35rem;padding:.6rem .8rem;
  border-radius:10px;font-weight:600;color:var(--ink);transition:color .15s,background .15s}
.nav-link:hover,.nav-link[aria-expanded="true"]{color:var(--pink-deep);background:var(--blush)}
.nav-link .chev{width:.7em;height:.7em;transition:transform .2s}
.nav-link[aria-expanded="true"] .chev{transform:rotate(180deg)}

/* mega panel (desktop) */
.mega{position:absolute;left:50%;transform:translateX(-50%) translateY(8px);
  top:calc(100% + 10px);width:min(760px,88vw);background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:1.4rem;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:120}
.has-mega:hover .mega,.mega.is-open{opacity:1;visibility:visible;pointer-events:auto;
  transform:translateX(-50%) translateY(0)}
.mega-grid{display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:.4rem 1.2rem}
.mega h4{font-family:var(--font-body);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);margin:.2rem .7rem .5rem;font-weight:700}
.mega-col{display:flex;flex-direction:column}
.mega a{display:flex;align-items:center;gap:.6rem;padding:.55rem .7rem;border-radius:12px;
  font-weight:600;color:var(--ink);transition:background .14s,color .14s}
.mega a:hover{background:var(--blush);color:var(--pink-deep)}
.mega a .dot{width:.7rem;height:.7rem;border-radius:50%;flex:0 0 auto;background:var(--grad)}
.mega .feature{grid-column:1;background:var(--grad-soft);border-radius:var(--radius);
  padding:1rem;margin:0}
.mega .feature strong{font-family:var(--font-display);font-size:1.05rem;display:block;margin-bottom:.25rem}
.mega .feature span{color:var(--ink-soft);font-size:.92rem}

.nav-cta{flex:0 0 auto}
/* contact button always in the bar */
.nav-contact{display:inline-flex}
.hamburger{display:none}

/* mobile nav overlay */
.mobile-nav{position:fixed;inset:var(--header-h) 0 0;background:#fff;z-index:90;
  transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;padding:1.2rem var(--pad) 3rem;visibility:hidden}
.mobile-nav.is-open{transform:translateX(0);visibility:visible}
.mobile-nav a{display:block;padding:.9rem .4rem;font-family:var(--font-display);font-weight:700;
  font-size:1.35rem;border-bottom:1px solid var(--line);color:var(--ink)}
.mobile-nav a:hover{color:var(--pink-deep)}
.m-group summary{list-style:none;display:flex;align-items:center;justify-content:space-between;
  padding:.9rem .4rem;font-family:var(--font-display);font-weight:700;font-size:1.35rem;
  border-bottom:1px solid var(--line);cursor:pointer}
.m-group summary::-webkit-details-marker{display:none}
.m-group summary .chev{width:1rem;height:1rem;transition:transform .2s}
.m-group[open] summary .chev{transform:rotate(180deg)}
.m-sub a{font-family:var(--font-body);font-size:1.02rem;font-weight:600;padding-left:1rem;
  border-bottom:1px solid var(--line);color:var(--ink-soft)}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{position:relative;overflow:hidden}
.hero--grad{background:var(--grad);color:#fff}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3.5rem);
  align-items:center;padding-block:clamp(3rem,7vw,5.5rem)}
.hero--center .hero-inner{grid-template-columns:1fr;text-align:center;max-width:820px;
  margin-inline:auto;padding-block:clamp(3rem,7vw,5rem)}
.hero h1{color:inherit}
.hero--grad h1,.hero--grad p{color:#fff}
.hero p.hero-sub{font-size:clamp(1.08rem,1.9vw,1.35rem);max-width:46ch;margin-bottom:1.6rem}
.hero--grad p.hero-sub{color:rgba(255,255,255,.94)}
.hero--center p.hero-sub{margin-inline:auto}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}
.hero--center .hero-cta{justify-content:center}
.hero-phone{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;color:#fff}
.hero--grad .hero-phone{color:#fff}
.hero-media{position:relative}
.hero-media img{width:100%;aspect-ratio:4/3.4;object-fit:cover;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg)}
.hero-badge{position:absolute;bottom:-14px;left:-14px;background:#fff;color:var(--ink);
  border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:.85rem 1.1rem;max-width:220px}
.hero-badge strong{font-family:var(--font-display);display:block;font-size:1.5rem;color:var(--pink-deep)}
.hero-badge span{font-size:.82rem;color:var(--ink-soft);line-height:1.35;display:block}
/* decorative blobs on grad heroes */
.hero--grad::before,.hero--grad::after{content:"";position:absolute;border-radius:50%;
  filter:blur(2px);opacity:.16;background:#fff}
.hero--grad::before{width:340px;height:340px;top:-120px;right:-80px}
.hero--grad::after{width:220px;height:220px;bottom:-120px;left:35%;opacity:.1}

/* trust bar */
.trustbar{border-top:1px solid rgba(255,255,255,.25);margin-top:2rem;padding-top:1.4rem;
  display:flex;flex-wrap:wrap;gap:1.4rem 2.2rem}
.trustbar div{display:flex;align-items:center;gap:.55rem;font-weight:600;font-size:.95rem}
.trustbar svg{width:1.2rem;height:1.2rem;flex:0 0 auto}

/* ==========================================================================
   GENERIC CONTENT PIECES
   ========================================================================== */
.grid{display:grid;gap:clamp(1rem,2.5vw,1.6rem)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease;
  display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card-media{aspect-ratio:4/3;overflow:hidden;background:var(--blush-2)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card-media img{transform:scale(1.05)}
.card-body{padding:1.25rem 1.35rem 1.4rem}
.card-body h3{margin-bottom:.35rem}
.card-body p{color:var(--ink-soft);font-size:.97rem;margin-bottom:.9rem}
.card .badges{margin-top:auto}

/* icon feature */
.feature-row{display:flex;gap:1rem;align-items:flex-start}
.feature-ico{flex:0 0 auto;width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  background:var(--grad-soft);color:var(--pink-deep)}
.feature-ico svg{width:26px;height:26px}
.feature-row h3{font-size:1.18rem;margin-bottom:.25rem}
.feature-row p{color:var(--ink-soft);margin:0;font-size:.98rem}

/* occasion tiles */
.occasion{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:210px;
  display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow);isolation:isolate}
.occasion img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.occasion::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(38,10,20,0) 30%,rgba(38,10,20,.78) 100%)}
.occasion.no-img{background:var(--grad)}
.occasion.no-img::after{display:none}
.occasion .occasion-body{padding:1.15rem 1.25rem}
.occasion h3{color:#fff;margin:0 0 .15rem;font-size:1.3rem}
.occasion span{font-size:.9rem;color:rgba(255,255,255,.9)}
.occasion:hover{transform:translateY(-4px)}
.occasion{transition:transform .18s ease}

/* numbered process */
.steps{counter-reset:step;display:grid;gap:1.2rem}
.step{display:flex;gap:1rem;align-items:flex-start}
.step-num{counter-increment:step;flex:0 0 auto;width:44px;height:44px;border-radius:50%;
  background:var(--grad);color:#fff;font-family:var(--font-display);font-weight:800;
  display:grid;place-items:center;font-size:1.15rem}
.step-num::before{content:counter(step)}
.step h3{font-size:1.15rem;margin-bottom:.2rem}
.step p{margin:0;color:var(--ink-soft)}

/* badges / pills */
.badges{display:flex;flex-wrap:wrap;gap:.4rem}
.pill{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:700;
  padding:.32rem .7rem;border-radius:var(--radius-pill);background:var(--blush);color:var(--pink-deep);
  text-transform:capitalize}
.pill--type{background:#f2ecf7;color:#6c3fa0}

/* split feature (image + text) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.split.reverse .split-media{order:2}
.split-media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;
  aspect-ratio:4/3.2;object-fit:cover}
.split-body h2{margin-bottom:.6rem}

/* callout / CTA band */
.cta-band{border-radius:var(--radius-lg);background:var(--grad);color:#fff;
  padding:clamp(2rem,5vw,3.4rem);text-align:center;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.94);max-width:52ch;margin-inline:auto;margin-bottom:1.6rem}
.cta-band .hero-cta{justify-content:center}

/* ==========================================================================
   FILTER GALLERY (Shutterstock-style)
   ========================================================================== */
.gallery-layout{display:grid;grid-template-columns:250px 1fr;gap:clamp(1.4rem,3vw,2.4rem);
  align-items:start}
.filters{position:sticky;top:calc(var(--header-h) + 12px);background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:1.3rem;box-shadow:var(--shadow)}
.filters h3{font-size:1.05rem;margin-bottom:.9rem;display:flex;align-items:center;justify-content:space-between}
.filter-clear{font-size:.82rem;font-weight:700;color:var(--pink-deep);background:none}
.filter-clear:hover{text-decoration:underline}
.filter-group{border-top:1px solid var(--line);padding:1rem 0}
.filter-group:first-of-type{border-top:0;padding-top:0}
.filter-group>h4{font-family:var(--font-body);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:700;margin:0 0 .7rem}
.search-box{position:relative;margin-bottom:.4rem}
.search-box input{width:100%;padding:.75rem .9rem .75rem 2.4rem;border:1.5px solid var(--line);
  border-radius:12px;font:inherit;font-size:.95rem;background:#fff}
.search-box input:focus{outline:none;border-color:var(--pink);box-shadow:var(--ring)}
.search-box svg{position:absolute;left:.8rem;top:50%;transform:translateY(-50%);
  width:1.05rem;height:1.05rem;color:var(--ink-soft)}
.chip-list{display:flex;flex-wrap:wrap;gap:.45rem}
.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.42rem .8rem;border-radius:var(--radius-pill);
  background:#faf6f7;border:1.5px solid var(--line);font-size:.86rem;font-weight:600;color:var(--ink);
  transition:all .14s ease;text-transform:capitalize}
.chip:hover{border-color:var(--pink)}
.chip[aria-pressed="true"],a.chip.is-active{background:var(--grad);color:#fff;border-color:transparent}
.chip.count{color:var(--ink-soft);font-weight:500}
/* color swatches */
.swatches{display:flex;flex-wrap:wrap;gap:.55rem}
.swatch{width:34px;height:34px;border-radius:50%;border:2px solid var(--line);position:relative;
  transition:transform .12s ease,box-shadow .12s ease;background:#fff}
.swatch:hover{transform:scale(1.1)}
.swatch[aria-pressed="true"]{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--pink);border-color:#fff}
.swatch[aria-pressed="true"]::after{content:"✓";position:absolute;inset:0;display:grid;place-items:center;
  color:#fff;font-size:.85rem;text-shadow:0 1px 2px rgba(0,0,0,.5)}
.swatch[data-light="1"][aria-pressed="true"]::after{color:var(--ink);text-shadow:none}

/* results */
.results-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;
  gap:.8rem;margin-bottom:1.2rem}
.results-count{color:var(--ink-soft);font-weight:600}
.active-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.2rem}
.active-tag{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .5rem .35rem .8rem;
  border-radius:var(--radius-pill);background:var(--blush);color:var(--pink-deep);font-size:.85rem;font-weight:600}
.active-tag button{width:1.1rem;height:1.1rem;border-radius:50%;background:rgba(198,46,102,.15);
  display:grid;place-items:center;font-size:.8rem;line-height:1;color:var(--pink-deep)}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:clamp(1rem,2vw,1.5rem)}
.cake-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease;display:flex;flex-direction:column}
.cake-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.cake-card .card-media{aspect-ratio:1/1}
.cake-card .cc-body{padding:1rem 1.1rem 1.15rem}
.cake-card h3{font-size:1.06rem;margin-bottom:.5rem}
.empty-state{grid-column:1/-1;text-align:center;padding:3rem 1rem;background:var(--blush);
  border-radius:var(--radius-lg);border:1px dashed var(--line)}
.empty-state h3{color:var(--pink-deep)}
.filter-toggle{display:none}

/* filtered-by banner on category pages */
.cat-note{background:var(--blush);border:1px solid var(--line);border-radius:var(--radius);
  padding:.8rem 1.1rem;margin-bottom:1.2rem;font-size:.95rem;color:var(--ink-soft)}
.cat-note a{color:var(--pink-deep);font-weight:700}

/* ==========================================================================
   CAKE DETAIL PAGE
   ========================================================================== */
.crumbs{font-size:.88rem;color:var(--ink-soft);padding-top:1.2rem}
.crumbs a:hover{color:var(--pink-deep)}
.crumbs span{margin-inline:.4rem;opacity:.5}
.detail{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3rem);
  align-items:start;padding-block:clamp(1.5rem,4vw,2.5rem) var(--sec)}
.detail-media img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);object-fit:cover}
.detail-body h1{font-size:clamp(1.9rem,4vw,2.8rem)}
.detail-attrs{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:1.4rem 0}
.attr{background:var(--blush);border-radius:var(--radius);padding:.8rem 1rem}
.attr dt{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);
  font-weight:700;margin-bottom:.2rem}
.attr dd{margin:0;font-weight:700;text-transform:capitalize}

/* ==========================================================================
   FAQ
   ========================================================================== */
.faq-cat{margin-bottom:2.4rem}
.faq-cat>h2{margin-bottom:1rem}
.faq details{border:1px solid var(--line);border-radius:var(--radius);margin-bottom:.7rem;
  background:#fff;overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:1.05rem 1.3rem;font-weight:700;
  font-family:var(--font-display);font-size:1.08rem;display:flex;justify-content:space-between;
  align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .plus{flex:0 0 auto;width:1.4rem;height:1.4rem;position:relative;transition:transform .2s}
.faq summary .plus::before,.faq summary .plus::after{content:"";position:absolute;background:var(--pink-deep);
  border-radius:2px}
.faq summary .plus::before{inset:calc(50% - 1px) 15%;height:2px}
.faq summary .plus::after{inset:15% calc(50% - 1px);width:2px}
.faq details[open] summary .plus{transform:rotate(45deg)}
.faq details[open] summary{color:var(--pink-deep)}
.faq .faq-a{padding:0 1.3rem 1.2rem;color:var(--ink-soft)}
.faq .faq-a p{margin-bottom:.7rem}

/* ==========================================================================
   CONTACT SECTION (on every page, id=contact)
   ========================================================================== */
#contact{scroll-margin-top:calc(var(--header-h) + 8px)}
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(1.3rem,3vw,2.2rem);box-shadow:var(--shadow-lg)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1rem;display:flex;flex-direction:column}
.field.full{grid-column:1/-1}
.field label{font-weight:700;font-size:.9rem;margin-bottom:.35rem}
.field label .req{color:var(--pink-deep)}
.field input,.field select,.field textarea{width:100%;padding:.8rem .9rem;border:1.5px solid var(--line);
  border-radius:12px;font:inherit;font-size:.98rem;background:#fff;color:var(--ink)}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--pink);
  box-shadow:var(--ring)}
.field .hint{font-size:.8rem;color:var(--ink-soft);margin-top:.3rem}
.form-note{font-size:.86rem;color:var(--ink-soft);margin-top:.4rem}
.contact-info{background:var(--grad);color:#fff;border-radius:var(--radius-lg);padding:clamp(1.4rem,3vw,2rem)}
.contact-info h3{color:#fff}
.contact-big{display:flex;flex-direction:column;gap:.9rem;margin:1.2rem 0}
.contact-big a{display:flex;align-items:center;gap:.7rem;font-weight:700;font-size:1.12rem;color:#fff}
.contact-big a svg{width:1.3rem;height:1.3rem;flex:0 0 auto}
.contact-info .hours{border-top:1px solid rgba(255,255,255,.28);padding-top:1rem;margin-top:1rem;
  font-size:.95rem;color:rgba(255,255,255,.94)}
.contact-info .hours div{display:flex;justify-content:space-between;padding:.15rem 0}
.locs{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-top:1.4rem}
.loc{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.15rem}
.loc h4{font-family:var(--font-display);margin:0 0 .3rem;font-size:1.02rem}
.loc p{margin:0;font-size:.92rem;color:var(--ink-soft);line-height:1.5}
.loc a{color:var(--pink-deep);font-weight:700}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:var(--footer);color:var(--footer-soft);padding-block:clamp(2.8rem,6vw,4.5rem) 2rem;
  margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem}
.site-footer h4{color:#fff;font-family:var(--font-body);font-size:.82rem;letter-spacing:.12em;
  text-transform:uppercase;margin:0 0 1rem;font-weight:700}
.footer-brand img{height:46px;margin-bottom:1rem;filter:brightness(0) invert(1)}
.footer-brand p{font-size:.95rem;line-height:1.6;max-width:34ch}
.site-footer ul li{margin-bottom:.55rem}
.site-footer a{color:var(--footer-soft);font-size:.95rem}
.site-footer a:hover{color:#fff}
.footer-contact div{display:flex;align-items:center;gap:.55rem;margin-bottom:.6rem;font-size:.95rem}
.footer-contact svg{width:1.05rem;height:1.05rem;flex:0 0 auto;color:var(--pink)}
.socials{display:flex;gap:.6rem;margin-top:1rem}
.socials a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.08);color:#fff}
.socials a:hover{background:var(--grad)}
.socials svg{width:1.1rem;height:1.1rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.4rem;padding-top:1.5rem;
  display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;font-size:.86rem}
.footer-bottom a{text-decoration:underline;text-underline-offset:2px}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:1024px){
  .nav-links,.nav > .nav-cta.desktop-only{display:none}
  .hamburger{display:inline-grid;place-items:center;width:46px;height:46px;border-radius:12px;
    background:var(--blush);color:var(--ink)}
  .hamburger svg{width:24px;height:24px}
  .nav{gap:.7rem}
  .gallery-layout{grid-template-columns:1fr}
  .filters{position:static;display:none}
  .filters.is-open{display:block}
  .filter-toggle{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .hero-inner,.split,.detail,.contact-grid,.split.reverse .split-media{grid-template-columns:1fr}
  .hero-media{order:-1}
  .split.reverse .split-media{order:0}
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .mega-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .detail-attrs{grid-template-columns:1fr 1fr}
  .hero-badge{position:static;margin-top:1rem;max-width:none}
}
@media (max-width:560px){
  :root{--header-h:64px}
  .brand img{height:38px}
  .grid-3,.grid-4,.grid-2,.footer-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
  .footer-bottom{flex-direction:column}
  h1{font-size:clamp(2.1rem,9vw,2.7rem)}
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  html:focus-within{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* scroll reveal (progressive, JS adds .reveal-on then .in) */
.reveal-on{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal-on.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal-on{opacity:1;transform:none}}
