/* =========================================================
   BAKERS DAUGHTER · Vaughan, Ontario
   Seven generations of Southern Italian pastry
   ---------------------------------------------------------
   Direction: WARM BAKERY — flour-cream light, honey & crust
   accents, real photography, soft "rising" motion.
   ========================================================= */

:root{
  --cream:#F8F1E3;       /* page background — warm flour */
  --flour:#FCF8EF;       /* lifted cards */
  --toast:#EFE0C6;       /* warm band */
  --crust:#B5641F;       /* burnished crust (primary accent) */
  --crust-deep:#8A4716;
  --honey:#D89A3E;       /* golden honey */
  --jam:#9C2B33;         /* berry / preserve, used sparingly */
  --cocoa:#3B2A1B;       /* primary warm-dark text */
  --cocoa-soft:#7C6450;  /* muted body text */
  --deep:#241510;        /* footer / craft base, warm near-black */
  --line:rgba(59,42,27,.14);
  --line-soft:rgba(59,42,27,.09);
  --line-cream:rgba(248,241,227,.16);

  --f-display:"Fraunces", "Hoefler Text", Georgia, serif;
  --f-body:"Manrope", "Helvetica Neue", Arial, sans-serif;
  --f-mono:"Space Mono", "SFMono-Regular", ui-monospace, monospace;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --pad:clamp(20px,5vw,80px);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  background:var(--cream);
  color:var(--cocoa);
  line-height:1.6;
  overflow-x:hidden;
  font-weight:380;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.is-locked{overflow:hidden;height:100vh}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--crust);color:var(--cream)}

h1,h2,h3{font-family:var(--f-display);font-weight:400;line-height:1.02;letter-spacing:-.02em}
.it{font-style:italic;font-variation-settings:"opsz" 144}

/* ---------- photo reveal helper ---------- */
.ph{position:relative;overflow:hidden}
.ph img{width:100%;height:100%;object-fit:cover;transform:scale(1.14);transition:transform 1.9s var(--ease), filter 1.2s var(--ease)}
.ph.in-view img,[data-reveal].in-view .ph img,.in-view.ph img{transform:scale(1)}

/* ======================================================
   WARM INTRO
   ====================================================== */
.intro{
  position:fixed; inset:0; z-index:1000;
  background:radial-gradient(120% 95% at 50% 38%, #FBF3E4 0%, #F3E4CB 45%, #E7CFA6 100%);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
  color:var(--crust);
}
.intro__flour{position:absolute;inset:0;width:100%;height:100%}
.intro__glow{
  position:absolute; left:50%; top:40%; transform:translate(-50%,-50%);
  width:70vmax; height:70vmax;
  background:radial-gradient(circle, rgba(216,154,62,.28) 0%, rgba(181,100,31,.12) 32%, transparent 64%);
  filter:blur(6px); animation:breathe 6s var(--ease) infinite;
}
@keyframes breathe{0%,100%{opacity:.7;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}}

.intro__inner{position:relative;z-index:3;text-align:center;padding:0 24px}
.intro__eyebrow{
  font-family:var(--f-mono); font-size:.72rem; letter-spacing:.4em;
  text-transform:uppercase; color:var(--crust-deep); margin-bottom:1.4rem;
  display:flex; gap:.9em; justify-content:center; align-items:center;
}
.intro__eyebrow .dot{color:var(--honey)}
.intro__wheat{width:46px;height:46px;color:var(--crust);margin:0 auto 1rem;display:block;opacity:.9}
.intro__title{font-size:clamp(3.2rem,13vw,12rem); line-height:.86; color:var(--cocoa); letter-spacing:-.03em}
.intro__word{display:block;overflow:hidden}
.intro__word--it{font-style:italic;color:var(--crust);font-variation-settings:"opsz" 144;margin-top:-.04em}
.intro__gen{display:flex;align-items:center;justify-content:center;gap:1.1rem;margin-top:1.8rem}
.intro__gen .rule{height:1px;width:clamp(24px,7vw,70px);background:linear-gradient(90deg,transparent,var(--crust),transparent)}
.intro__gen .lbl{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--crust-deep)}
.intro__counter{position:absolute;bottom:6vh;left:50%;transform:translateX(-50%);font-family:var(--f-mono);font-size:.8rem;letter-spacing:.2em;color:var(--crust-deep);z-index:3}
.intro__counter .pct{opacity:.6}

[data-intro]{opacity:0;transform:translateY(18px);filter:blur(5px)}
.intro.is-playing [data-intro]{opacity:1;transform:none;filter:none;transition:opacity 1s var(--ease-out), transform 1.1s var(--ease-out), filter 1s var(--ease-out)}
.intro.is-playing [data-intro="1"]{transition-delay:.1s}
.intro.is-playing [data-intro="2"]{transition-delay:.3s}
.intro.is-playing [data-intro="3"]{transition-delay:.5s}
.intro.is-playing [data-intro="4"]{transition-delay:.66s}
.intro.is-playing [data-intro="5"]{transition-delay:.95s}
.intro.is-playing [data-intro="6"]{transition-delay:1.15s}

.intro__curtain{position:absolute;left:0;width:100%;height:51%;background:var(--cream);z-index:5;transform:scaleY(0)}
.intro__curtain--t{top:0;transform-origin:top}
.intro__curtain--b{bottom:0;transform-origin:bottom}
.intro.is-leaving .intro__inner,.intro.is-leaving .intro__glow,.intro.is-leaving .intro__flour{opacity:0;transition:opacity .5s ease}
.intro.is-leaving .intro__curtain{transform:scaleY(1);transition:transform .9s var(--ease)}
.intro.is-done{opacity:0;pointer-events:none;transition:opacity .5s ease .55s}

/* ======================================================
   NAV
   ====================================================== */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:900;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  transition:transform .5s var(--ease), background .5s var(--ease), padding .5s var(--ease), border-color .5s var(--ease);
  border-bottom:1px solid transparent;
  transform:translateY(-110%);
}
.nav.is-ready{transform:translateY(0)}
.nav.is-scrolled{
  background:rgba(248,241,227,.82);
  backdrop-filter:blur(14px) saturate(1.3);
  -webkit-backdrop-filter:blur(14px) saturate(1.3);
  padding-top:12px;padding-bottom:12px;border-color:var(--line);
}
.nav.is-hidden{transform:translateY(-110%)}

.nav__brand{display:flex;align-items:center;gap:.7rem}
.nav__mark{font-family:var(--f-display);font-style:italic;font-size:1.4rem;color:var(--crust);letter-spacing:.02em;line-height:1}
.nav__mark-d{color:var(--honey);padding:0 .04em}
.nav__name{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cocoa);opacity:.78}
.nav__links{display:flex;align-items:center;gap:clamp(14px,2vw,34px)}
.nav__link{position:relative;font-size:.82rem;letter-spacing:.02em;color:var(--cocoa);opacity:.8;padding:6px 0;font-weight:500}
.nav__link span{position:relative;display:inline-block}
.nav__link span::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1.5px;background:var(--crust);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.nav__link:hover{opacity:1}
.nav__link:hover span::after{transform:scaleX(1);transform-origin:left}
.nav__link--cta{border:1px solid var(--crust);border-radius:40px;padding:7px 18px;background:transparent;opacity:1;color:var(--crust);transition:background .4s,color .4s}
.nav__link--cta:hover{background:var(--crust);color:var(--cream)}
.nav__link--cta span::after{display:none}

.nav__toggle{display:none;width:34px;height:34px;flex-direction:column;justify-content:center;gap:6px}
.nav__toggle span{display:block;height:2px;width:100%;background:var(--cocoa);transition:transform .4s var(--ease),opacity .3s}
.nav.is-open .nav__toggle span:nth-child(1){transform:translateY(4px) rotate(45deg)}
.nav.is-open .nav__toggle span:nth-child(2){transform:translateY(-4px) rotate(-45deg)}

/* ======================================================
   REVEAL (in & out)
   ====================================================== */
[data-reveal]{
  opacity:0;transform:translateY(34px);
  transition:opacity .9s var(--ease-out), transform 1s var(--ease-out);
  transition-delay:calc(var(--i,0) * .08s);
  will-change:opacity,transform;
}
[data-reveal].in-view{opacity:1;transform:none}
[data-reveal].out-view{opacity:0;transform:translateY(-22px)}

/* ======================================================
   BUTTONS
   ====================================================== */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:.6em;
  font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;
  padding:15px 28px;border-radius:46px;overflow:hidden;
  transition:transform .5s var(--ease), color .45s var(--ease);
}
.btn span,.btn i{position:relative;z-index:2}
.btn::before{content:"";position:absolute;inset:0;z-index:1;transition:transform .55s var(--ease)}
.btn--solid{color:var(--cream);background:var(--crust)}
.btn--solid::before{background:var(--crust-deep);transform:translateY(101%)}
.btn--solid:hover::before{transform:translateY(0)}
.btn--ghost{color:var(--cocoa);border:1px solid var(--line)}
.btn--ghost::before{background:var(--cocoa);transform:translateY(101%)}
.btn--ghost:hover{color:var(--cream);border-color:var(--cocoa)}
.btn--ghost:hover::before{transform:translateY(0)}
.btn .arr{transition:transform .5s var(--ease)}
.btn:hover .arr{transform:translateY(3px)}
.btn--full{width:100%;justify-content:center}

/* ======================================================
   HERO — full-bleed photo + warm scrim
   ====================================================== */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;padding:120px var(--pad) clamp(60px,9vh,110px);overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);animation:kenburns 18s var(--ease) forwards}
@keyframes kenburns{to{transform:scale(1)}}
.hero__scrim{position:absolute;inset:0;z-index:1;background:
  linear-gradient(to top, rgba(28,16,8,.86) 0%, rgba(36,21,12,.45) 34%, rgba(40,24,14,.12) 60%, rgba(40,24,14,.28) 100%),
  linear-gradient(105deg, rgba(28,16,8,.55) 0%, transparent 55%);}
.hero__flour{position:absolute;inset:0;z-index:2;width:100%;height:100%;opacity:.7}
.hero__inner{position:relative;z-index:3;max-width:1000px}
.hero__eyebrow{display:inline-flex;align-items:center;gap:.8em;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--honey);margin-bottom:1.4rem}
.hero__eyebrow-line{width:42px;height:1px;background:var(--honey)}
.hero__title{font-size:clamp(2.8rem,8.5vw,7rem);color:#FCF6EA;letter-spacing:-.025em;text-shadow:0 2px 40px rgba(0,0,0,.35)}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line--it{font-style:italic;color:var(--honey);font-variation-settings:"opsz" 144}
.hero__lede{max-width:60ch;margin:1.8rem 0 0;font-size:clamp(1rem,1.5vw,1.22rem);color:#f0e3cf;font-weight:380;line-height:1.7;text-shadow:0 1px 20px rgba(0,0,0,.4)}
.hero__lede em{font-family:var(--f-display);font-style:italic;color:#fff;font-size:1.05em}
.hero__cta{display:flex;gap:1rem;margin-top:2.2rem;flex-wrap:wrap}
.hero .btn--ghost{color:#FCF6EA;border-color:rgba(252,246,234,.5)}
.hero .btn--ghost::before{background:#FCF6EA}
.hero .btn--ghost:hover{color:var(--cocoa)}

.hero__badge{
  position:absolute;top:clamp(90px,14vh,140px);right:var(--pad);z-index:3;
  width:clamp(96px,13vw,138px);height:clamp(96px,13vw,138px);border-radius:50%;
  border:1px solid rgba(252,246,234,.45);display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:#FCF6EA;text-align:center;background:rgba(28,16,8,.28);backdrop-filter:blur(3px);
  animation:spinbadge 1.2s var(--ease) both;
}
@keyframes spinbadge{from{opacity:0;transform:rotate(-30deg) scale(.7)}to{opacity:1;transform:none}}
.hero__badge-est{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;opacity:.8}
.hero__badge-yr{font-family:var(--f-display);font-style:italic;font-size:clamp(1.7rem,3.5vw,2.4rem);color:var(--honey);line-height:1}
.hero__badge-sub{font-family:var(--f-mono);font-size:.56rem;letter-spacing:.22em;text-transform:uppercase;opacity:.7;margin-top:.2rem}

.hero__scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--f-mono);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(252,246,234,.8)}
.hero__scroll-line{position:relative;width:1px;height:46px;background:rgba(252,246,234,.3);overflow:hidden}
.hero__scroll-line i{position:absolute;top:-40%;left:0;width:100%;height:40%;background:var(--honey);animation:scrolldot 2.2s var(--ease) infinite}
@keyframes scrolldot{0%{top:-45%}60%,100%{top:105%}}

/* ======================================================
   MARQUEE
   ====================================================== */
.marquee{background:var(--crust);color:var(--cream);overflow:hidden;padding:16px 0}
.marquee__track{display:flex;align-items:center;gap:2.5rem;width:max-content;animation:marq 38s linear infinite}
.marquee__track span{font-family:var(--f-display);font-style:italic;font-size:clamp(1.3rem,3vw,2.1rem);white-space:nowrap}
.marquee__track .star{font-style:normal;font-size:.8rem;color:var(--honey);opacity:.9}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marq{to{transform:translateX(-50%)}}

/* ======================================================
   SECTION HEADS
   ====================================================== */
.section-head{max-width:760px;margin:0 auto}
.section-head--center{text-align:center}
.section-head__eyebrow{display:inline-block;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--crust);margin-bottom:1.3rem}
.section-head__eyebrow--light{color:var(--honey)}
.section-head__title{font-size:clamp(2rem,5.5vw,4.2rem);color:inherit}
.section-head__sub{margin-top:1.5rem;font-size:clamp(1rem,1.4vw,1.15rem);max-width:60ch;color:var(--cocoa-soft)}
.section-head--center .section-head__sub{margin-left:auto;margin-right:auto}

/* ======================================================
   LINEAGE
   ====================================================== */
.lineage{background:var(--cream);color:var(--cocoa);padding:clamp(90px,12vw,170px) var(--pad)}
.band{max-width:1200px;margin:clamp(46px,6vw,80px) auto 0;border-radius:14px;aspect-ratio:21/9;box-shadow:0 40px 80px -50px rgba(59,42,27,.6)}
.band__cap{position:absolute;left:0;bottom:0;width:100%;padding:40px 30px 22px;background:linear-gradient(to top,rgba(28,16,8,.72),transparent);color:#FCF6EA;font-family:var(--f-display);font-style:italic;font-size:clamp(1.1rem,2vw,1.6rem)}

.timeline{list-style:none;max-width:880px;margin:clamp(50px,7vw,100px) auto 0;position:relative}
.timeline::before{content:"";position:absolute;left:clamp(38px,8vw,90px);top:8px;bottom:60px;width:1px;background:linear-gradient(180deg,transparent,var(--line) 8%,var(--line) 80%,transparent)}
.tl{position:relative;display:grid;grid-template-columns:clamp(80px,18vw,180px) 1fr;gap:clamp(16px,3vw,40px);padding:clamp(22px,3vw,38px) 0}
.tl__num{font-family:var(--f-display);font-style:italic;font-size:clamp(1.5rem,4vw,2.6rem);color:var(--crust);text-align:right;line-height:1;position:relative}
.tl__num::after{content:"";position:absolute;right:-1px;top:50%;width:9px;height:9px;border-radius:50%;background:var(--cream);border:1px solid var(--crust);transform:translate(50%,-50%)}
.tl--mark .tl__num{color:var(--jam)}
.tl__num--big{font-size:clamp(2.4rem,7vw,4.4rem);color:var(--jam)}
.tl--mark .tl__num::after{background:var(--jam);border-color:var(--jam);width:13px;height:13px}
.tl__num--next{font-style:normal;color:var(--crust)}
.tl__era{display:block;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--crust);margin-bottom:.6rem}
.tl__title{font-size:clamp(1.4rem,2.6vw,2rem);margin-bottom:.7rem;color:var(--cocoa)}
.tl__body p{color:var(--cocoa-soft);max-width:52ch}
.tl__body strong{color:var(--cocoa);font-weight:600}
.tl--mark .tl__body{background:rgba(156,43,51,.06);border-left:2px solid var(--jam);margin-left:-18px;padding:18px 22px;border-radius:0 8px 8px 0}
.tl--future .tl__title{color:var(--crust)}

/* ======================================================
   FATHER & DAUGHTER  (warm toast scene)
   ====================================================== */
.family{background:var(--toast);padding:clamp(90px,12vw,170px) var(--pad);position:relative}
.family__intro{max-width:1300px;margin:0 auto}
.family__title{font-size:clamp(2.4rem,7vw,5.4rem);color:var(--cocoa)}
.people{max-width:1300px;margin:clamp(50px,7vw,90px) auto 0;display:flex;flex-direction:column;gap:clamp(60px,9vw,120px)}
.person{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:clamp(30px,5vw,80px);align-items:center}
.person--rev{grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr)}
.person--rev .person__photo{order:2}
.person__photo{aspect-ratio:4/5;border-radius:10px;box-shadow:0 40px 80px -45px rgba(59,42,27,.7);border:6px solid var(--flour)}
.person__cap{position:absolute;bottom:14px;left:14px;font-family:var(--f-mono);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:#FCF6EA;background:rgba(28,16,8,.5);padding:6px 12px;border-radius:30px;backdrop-filter:blur(3px)}
.person__role{display:block;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--crust);margin-bottom:1rem}
.person__name{font-size:clamp(2rem,4.5vw,3.4rem);color:var(--cocoa);margin-bottom:1.3rem}
.person__text p{color:var(--cocoa-soft);max-width:54ch;margin-bottom:1.4rem}
.person__quote{font-family:var(--f-display);font-style:italic;font-size:clamp(1.2rem,2.4vw,1.7rem);color:var(--crust-deep);line-height:1.35;border-left:2px solid var(--crust);padding-left:1.2rem;max-width:34ch}

/* ======================================================
   THE COUNTER  (cream scene, photo cards)
   ====================================================== */
.counter{background:var(--cream);color:var(--cocoa);padding:clamp(90px,12vw,170px) var(--pad)}
.menu{max-width:1300px;margin:clamp(50px,7vw,80px) auto 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:clamp(18px,2vw,28px)}
.card{position:relative;background:var(--flour);border:1px solid var(--line-soft);border-radius:14px;overflow:hidden;transition:transform .6s var(--ease), box-shadow .6s var(--ease), border-color .6s var(--ease)}
.card:hover{transform:translateY(-8px);box-shadow:0 34px 64px -34px rgba(59,42,27,.5);border-color:var(--crust)}
.card__media{aspect-ratio:1/1;border-radius:0}
.card__media img{transition:transform 1.1s var(--ease)}
.card:hover .card__media img{transform:scale(1.07)}
.card__body{padding:22px 24px 26px}
.card__row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}
.card__name{font-size:1.45rem;color:var(--cocoa)}
.card__price{font-family:var(--f-mono);font-size:.9rem;color:var(--crust);font-weight:700}
.card__price::before{content:"$";opacity:.6;font-size:.8em}
.card__desc{padding-top:.7rem;color:var(--cocoa-soft);font-size:.95rem}
.card__tag{display:inline-block;margin-top:1.1rem;font-family:var(--f-mono);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--crust);border:1px solid var(--line);border-radius:30px;padding:5px 12px}
.counter__note{max-width:680px;margin:clamp(40px,6vw,70px) auto 0;text-align:center}
.counter__note p{color:var(--cocoa-soft);font-size:1.05rem}
.counter__note a{color:var(--jam);border-bottom:1px solid currentColor;padding-bottom:1px}

/* ======================================================
   THE CRAFT  (photo scene, warm overlay)
   ====================================================== */
.craft{position:relative;padding:clamp(90px,12vw,170px) var(--pad);overflow:hidden;color:#FCF6EA}
.craft__media{position:absolute;inset:0;z-index:0}
.craft__media img{width:100%;height:100%;object-fit:cover}
.craft__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(28,16,8,.9),rgba(33,18,10,.82))}
.craft__flour{position:absolute;inset:0;z-index:2;width:100%;height:100%;opacity:.45}
.craft__inner{position:relative;z-index:3;max-width:1300px;margin:0 auto}
.craft__title{font-size:clamp(2.4rem,7vw,5.2rem);color:#FCF6EA}
.craft__sub{margin-top:1.3rem;color:#e7d6bd;max-width:50ch}
.craft__list{margin:clamp(50px,7vw,80px) auto 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1px;background:var(--line-cream);border:1px solid var(--line-cream);border-radius:12px;overflow:hidden}
.craft__item{background:rgba(28,16,8,.42);backdrop-filter:blur(2px);padding:clamp(28px,3vw,42px);transition:background .5s var(--ease)}
.craft__item:hover{background:rgba(181,100,31,.22)}
.craft__no{font-family:var(--f-mono);font-size:.8rem;color:var(--honey);letter-spacing:.1em}
.craft__item h3{font-size:1.7rem;color:var(--honey);margin:1.2rem 0 .8rem}
.craft__item p{color:#dcc9af;font-size:.95rem;max-width:32ch}
.craft__stats{margin:clamp(50px,7vw,80px) auto 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:clamp(20px,3vw,40px);border-top:1px solid var(--line-cream);padding-top:clamp(40px,5vw,56px)}
.stat{text-align:center}
.stat__num{display:block;font-family:var(--f-display);font-size:clamp(2.6rem,6vw,4.6rem);color:#FCF6EA;line-height:1}
.stat__lbl{display:block;margin-top:.7rem;font-family:var(--f-mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--honey)}

/* ======================================================
   VISIT  (cream scene)
   ====================================================== */
.visit{background:var(--cream);color:var(--cocoa);padding:clamp(90px,12vw,170px) var(--pad)}
.visit__grid{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,6vw,90px);align-items:start}
.visit__title{font-size:clamp(2.4rem,6vw,4.6rem);color:var(--cocoa)}
.visit__lede{margin:1.5rem 0 2.4rem;color:var(--cocoa-soft);font-size:1.1rem;max-width:42ch}
.visit__info{display:grid;grid-template-columns:1fr 1fr;gap:clamp(22px,3vw,40px)}
.info__lbl{display:block;font-family:var(--f-mono);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--crust);margin-bottom:.7rem;padding-bottom:.7rem;border-bottom:1px solid var(--line)}
.info__val{color:var(--cocoa);font-size:.98rem;line-height:1.9}
.info__val a{border-bottom:1px solid var(--line);transition:border-color .3s}
.info__val a:hover{border-color:var(--crust)}
.info__val span{display:inline-block}
.info__val .muted{color:var(--cocoa-soft);font-style:italic}
.info:nth-child(2) .info__val{display:grid;grid-template-columns:auto 1fr;gap:.1rem 1.2rem;font-family:var(--f-mono);font-size:.82rem}
.info:nth-child(2) .info__val span:nth-child(odd){color:var(--cocoa-soft)}
.info:nth-child(2) .info__val span:nth-child(even){text-align:right}

.visit__card{position:sticky;top:100px;background:var(--flour);border:1px solid var(--line-soft);border-radius:16px;overflow:hidden;box-shadow:0 40px 80px -55px rgba(59,42,27,.6)}
.visit__photo{height:210px}
.visit__coord{position:absolute;bottom:12px;left:14px;font-family:var(--f-mono);font-size:.62rem;letter-spacing:.14em;color:#FCF6EA;background:rgba(28,16,8,.5);padding:5px 10px;border-radius:20px}
.visit__form{padding:clamp(24px,3vw,34px)}
.visit__form-lbl{display:block;font-family:var(--f-display);font-style:italic;font-size:1.5rem;color:var(--cocoa);margin-bottom:1.4rem}
.field{position:relative;margin-bottom:1.1rem}
.field input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);padding:14px 2px 8px;color:var(--cocoa);font-size:1rem;font-family:var(--f-body);transition:border-color .4s}
.field input:focus{outline:none;border-color:var(--crust)}
.field label{position:absolute;left:2px;top:14px;color:var(--cocoa-soft);pointer-events:none;transition:transform .35s var(--ease),color .35s;transform-origin:left}
.field input:focus+label,.field input:not(:placeholder-shown)+label{transform:translateY(-20px) scale(.78);color:var(--crust)}
.visit__form .btn{margin-top:.8rem}
.visit__form-msg{margin-top:1rem;font-size:.85rem;color:var(--jam);min-height:1.2em;font-family:var(--f-mono);letter-spacing:.04em}

/* ======================================================
   FOOTER
   ====================================================== */
.footer{background:var(--deep);color:#e7d6bd;padding:clamp(70px,9vw,120px) var(--pad) 40px;overflow:hidden}
.footer__big{text-align:center;line-height:.82;margin-bottom:clamp(50px,7vw,80px)}
.footer__big span{display:block;font-family:var(--f-display);font-size:clamp(3.4rem,17vw,15rem);letter-spacing:-.03em}
.footer__big-1{color:var(--cream)}
.footer__big-2{font-style:italic;color:var(--honey)}
.footer__row{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;padding-bottom:clamp(40px,5vw,60px);border-bottom:1px solid var(--line-cream)}
.footer__col{color:#cbb89f;font-size:.95rem;line-height:1.8}
.footer__col a{border-bottom:1px solid var(--line-cream);transition:border-color .3s}
.footer__col a:hover{border-color:var(--honey)}
.footer__lbl{display:block;font-family:var(--f-mono);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--honey);margin-bottom:1rem}
.footer__base{max-width:1100px;margin:30px auto 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.1em;color:#b39a7e;text-transform:uppercase}
.footer__sig{opacity:.8}
.footer__top:hover{color:var(--honey)}

/* ======================================================
   RESPONSIVE
   ====================================================== */
@media(max-width:880px){
  .person,.person--rev{grid-template-columns:1fr;gap:24px}
  .person--rev .person__photo{order:0}
  .person__photo{aspect-ratio:4/3;max-height:420px}
  .visit__grid{grid-template-columns:1fr}
  .visit__card{position:relative;top:0}
  .footer__row{grid-template-columns:1fr;text-align:center}
  .footer__lbl{margin-top:.5rem}
  .band{aspect-ratio:16/10}
  .hero__badge{display:none}
}
@media(max-width:720px){
  .nav__links{position:fixed;inset:0;top:0;flex-direction:column;justify-content:center;gap:1.6rem;background:rgba(248,241,227,.98);backdrop-filter:blur(10px);transform:translateY(-100%);transition:transform .6s var(--ease);z-index:-1}
  .nav.is-open .nav__links{transform:translateY(0)}
  .nav__link{font-size:1.4rem}
  .nav__link--cta{margin-top:1rem}
  .nav__toggle{display:flex}
  .nav__name{display:none}
  .visit__info{grid-template-columns:1fr}
  .footer__base{flex-direction:column;text-align:center}
  .hero{justify-content:flex-end}
}

/* ======================================================
   REDUCED MOTION
   ====================================================== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  html{scroll-behavior:auto}
  [data-reveal]{opacity:1!important;transform:none!important}
  .ph img{transform:none!important}
  .hero__media img{animation:none;transform:none}
  .intro{display:none}
  .nav{transform:none}
}
