/* =========================================================
   Hotel Peștera — sistem de design
   Alpine luxury · editorial · brass accent
   ========================================================= */

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
img,picture,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul{list-style:none}

/* ---- Tokens ---- */
:root{
  --ink:#181410;          /* warm near-black */
  --ink-2:#2a241c;
  --ink-soft:#544a3c;
  --paper:#fbf8f1;        /* warm off-white */
  --cream:#f3ecdf;        /* section tint */
  --cream-2:#e9d8;
  --cream-deep:#e7ddca;
  --stone:#d8cdb8;        /* hairline borders */
  --muted:#8c8270;        /* secondary text */
  --brass:#a97c2f;        /* primary accent */
  --brass-bright:#c89a4c; /* accent on dark */
  --pine:#26342b;         /* deep forest secondary dark */

  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-body:'Mulish',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  --maxw:1280px;
  --gutter:clamp(1.25rem,5vw,4.5rem);
  --radius:2px;
  --shadow:0 18px 50px -28px rgba(24,20,16,.45);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---- Base ---- */
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-weight:380;
  letter-spacing:.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ---- Typography ---- */
.display,h1,h2,h3{
  font-family:var(--font-display);
  font-weight:380;
  line-height:1.04;
  letter-spacing:-.012em;
  font-optical-sizing:auto;
}
h1{font-size:clamp(2.6rem,7vw,5.6rem)}
h2{font-size:clamp(2rem,4.6vw,3.6rem)}
h3{font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.12}
p{max-width:62ch}
.lead{font-size:clamp(1.05rem,1.5vw,1.35rem);line-height:1.6;color:var(--ink-soft);font-weight:380}

/* italic display flourish */
.fl{font-style:italic;font-variation-settings:"SOFT" 40}

/* eyebrow / kicker */
.eyebrow{
  font-family:var(--font-body);
  font-size:.74rem;
  font-weight:700;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--brass);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:2.4em;height:1px;background:var(--brass);opacity:.6}
.eyebrow.center::before{display:none}

/* section index number */
.index-num{
  font-family:var(--font-display);
  font-style:italic;
  font-size:.95rem;
  color:var(--brass);
  opacity:.8;
}

/* ---- Layout ---- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(4.5rem,11vw,9rem)}
.section--tight{padding-block:clamp(3rem,7vw,5.5rem)}
.dark{background:var(--ink);color:var(--paper)}
.dark h1,.dark h2,.dark h3{color:var(--paper)}
.dark .lead{color:#c8bfae}
.dark .eyebrow{color:var(--brass-bright)}
.dark .eyebrow::before{background:var(--brass-bright)}
.tint{background:var(--cream)}
.pine{background:var(--pine);color:#eef0e8}
.pine h2,.pine h3{color:#fff}
.pine .lead{color:#cdd4c5}
.pine .eyebrow{color:var(--brass-bright)}
.pine .eyebrow::before{background:var(--brass-bright)}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--font-body);font-weight:700;
  font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  padding:1.05em 2em;border-radius:var(--radius);
  background:var(--brass);color:#fff;
  transition:background .35s var(--ease),transform .35s var(--ease),box-shadow .35s var(--ease);
  position:relative;
}
.btn:hover{background:#946a26;transform:translateY(-2px);box-shadow:0 14px 30px -16px rgba(169,124,47,.7)}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--stone)}
.btn--ghost:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);box-shadow:none}
.dark .btn--ghost,.pine .btn--ghost{color:var(--paper);border-color:rgba(255,255,255,.28)}
.dark .btn--ghost:hover,.pine .btn--ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

.link-arrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink);padding-bottom:.35em;border-bottom:1px solid var(--stone);
  transition:gap .3s var(--ease),border-color .3s var(--ease),color .3s var(--ease);
}
.link-arrow .ar{transition:transform .3s var(--ease);color:var(--brass)}
.link-arrow:hover{gap:1em;border-color:var(--brass);color:var(--brass)}
.link-arrow:hover .ar{transform:translateX(4px)}
.dark .link-arrow,.pine .link-arrow{color:var(--paper);border-color:rgba(255,255,255,.25)}
.dark .link-arrow:hover,.pine .link-arrow:hover{color:var(--brass-bright);border-color:var(--brass-bright)}

/* =========================================================
   Header / Nav
   ========================================================= */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  padding-block:1.1rem;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.85rem;z-index:2}
.brand img{height:46px;width:auto;transition:height .4s var(--ease),filter .4s var(--ease)}
.brand .brand-txt{display:flex;flex-direction:column;line-height:1.05}
.brand .brand-txt b{font-family:var(--font-display);font-weight:500;font-size:1.18rem;letter-spacing:.01em}
.brand .brand-txt span{font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:var(--brass);font-weight:700}

.nav{display:flex;align-items:center;gap:clamp(1rem,2vw,2.1rem)}
.nav a{
  font-size:.78rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;
  position:relative;padding-block:.3em;color:var(--paper);
  transition:color .3s var(--ease);
}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--brass-bright);transition:width .35s var(--ease)}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.nav a[aria-current="page"]{color:var(--brass-bright)}

.header-cta{display:flex;align-items:center;gap:1.1rem}
.phone-link{font-size:.78rem;font-weight:700;letter-spacing:.08em;color:var(--paper);white-space:nowrap}
.btn--sm{padding:.8em 1.5em;font-size:.72rem}

/* scrolled / solid state */
.site-header.solid{background:var(--paper);box-shadow:0 1px 0 var(--stone),0 10px 30px -24px rgba(24,20,16,.4);padding-block:.7rem}
.site-header.solid .brand img{height:38px;filter:brightness(0) saturate(100%)}
.site-header.solid .brand .brand-txt b{color:var(--ink)}
.site-header.solid .nav a,.site-header.solid .phone-link{color:var(--ink)}
.site-header.solid .nav a[aria-current="page"]{color:var(--brass)}
.site-header.solid .nav a::after{background:var(--brass)}

/* burger */
.burger{display:none;flex-direction:column;gap:5px;width:30px;z-index:2}
.burger span{height:2px;width:100%;background:var(--paper);transition:.35s var(--ease)}
.solid .burger span{background:var(--ink)}
.nav-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-open .burger span:nth-child(2){opacity:0}
.nav-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =========================================================
   Hero
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:var(--paper);overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img{width:100%;height:100%;object-fit:cover;animation:heroZoom 16s var(--ease) forwards}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(90deg,rgba(20,16,12,.72) 0%,rgba(20,16,12,.34) 45%,rgba(20,16,12,.06) 75%,transparent 100%),
    linear-gradient(180deg,rgba(20,16,12,.55) 0%,rgba(20,16,12,.28) 40%,rgba(20,16,12,.82) 100%)}
.hero__inner{width:100%;padding-bottom:clamp(3rem,7vw,6rem);padding-top:9rem}
.hero .eyebrow{color:var(--brass-bright)}
.hero .eyebrow::before{background:var(--brass-bright)}
.hero .btn--ghost{color:#fff;border-color:rgba(255,255,255,.55);background:rgba(20,16,12,.18);backdrop-filter:blur(3px)}
.hero .btn--ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.hero h1{margin:.5rem 0 1.4rem;max-width:16ch;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero__lead{max-width:46ch;color:#ece6da;font-size:clamp(1.05rem,1.5vw,1.3rem)}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.2rem}
.hero__meta{display:flex;flex-wrap:wrap;gap:2.5rem;margin-top:3.4rem;padding-top:1.8rem;border-top:1px solid rgba(255,255,255,.2)}
.hero__meta div{display:flex;flex-direction:column;gap:.2rem}
.hero__meta b{font-family:var(--font-display);font-size:1.6rem;font-weight:400}
.hero__meta span{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:#c9c1b2}
.scroll-cue{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:1;
  font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:#cfc7b8;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.scroll-cue::after{content:"";width:1px;height:42px;background:linear-gradient(var(--brass-bright),transparent);animation:cue 2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* page hero (interior pages) */
.phero{position:relative;min-height:62vh;display:flex;align-items:flex-end;color:var(--paper);overflow:hidden}
.phero__bg{position:absolute;inset:0;z-index:-2}
.phero__bg img{width:100%;height:100%;object-fit:cover}
.phero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,16,12,.45),rgba(20,16,12,.7))}
.phero__inner{padding-block:clamp(3rem,6vw,5rem) clamp(2.5rem,5vw,4rem);padding-top:8rem}
.phero h1{font-size:clamp(2.4rem,6vw,4.6rem);margin-top:.6rem}
.phero .eyebrow{color:var(--brass-bright)}.phero .eyebrow::before{background:var(--brass-bright)}

/* =========================================================
   Generic content pieces
   ========================================================= */
.sec-head{max-width:760px;margin-bottom:clamp(2.5rem,5vw,4rem)}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head .eyebrow{margin-bottom:1.2rem}
.sec-head h2{margin-bottom:1.3rem}

/* two-column intro: text + image */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split--reverse .split__media{order:-1}
.split__media{position:relative}
.split__media img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--radius)}
.split__media .tag{position:absolute;bottom:0;left:0;background:var(--paper);color:var(--ink);
  padding:1rem 1.4rem;font-family:var(--font-display);font-style:italic;font-size:1.05rem;border-radius:0 var(--radius) 0 0}
.split__body p+p{margin-top:1.1rem}
.split__body .lead{margin-bottom:1.6rem}
.split__body .btn,.split__body .link-arrow{margin-top:2rem}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--stone);border:1px solid var(--stone);border-radius:var(--radius);overflow:hidden}
.stats div{background:var(--paper);padding:2rem 1.5rem;text-align:center}
.dark .stats,.pine .stats{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.14)}
.dark .stats div,.pine .stats div{background:var(--ink)}
.pine .stats div{background:var(--pine)}
.stats b{display:block;font-family:var(--font-display);font-size:clamp(2rem,3.5vw,2.9rem);color:var(--brass);font-weight:400;line-height:1}
.dark .stats b,.pine .stats b{color:var(--brass-bright)}
.stats span{display:block;margin-top:.6rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.dark .stats span,.pine .stats span{color:#b7ad9b}

/* Awards — diplome */
.award-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,230px));gap:1.8rem;margin-top:3rem;justify-content:center;max-width:1040px;margin-inline:auto}
.award-card{margin:0;text-align:center}
.award-card a{display:block;border-radius:6px;overflow:hidden;background:#fff;box-shadow:0 24px 60px -28px rgba(0,0,0,.8),0 2px 0 rgba(255,255,255,.06);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.award-card a:hover{transform:translateY(-6px);box-shadow:0 34px 70px -26px rgba(0,0,0,.85)}
.award-card img{display:block;width:100%;height:auto}

/* Live cams */
.livecam-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
.livecam{position:relative;margin:0}
.livecam img{display:block;width:100%;height:auto;border-radius:6px;background:var(--cream);box-shadow:0 18px 40px -28px rgba(24,20,16,.55)}
.live-badge{position:absolute;top:.7rem;left:.7rem;display:inline-flex;align-items:center;gap:.4rem;padding:.32rem .65rem;border-radius:100px;background:rgba(20,16,12,.62);backdrop-filter:blur(4px);color:#fff;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700}
.live-badge .dot{width:7px;height:7px;border-radius:50%;background:#e5484d;box-shadow:0 0 0 0 rgba(229,72,77,.7);animation:livePulse 2s infinite}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(229,72,77,.6)}70%{box-shadow:0 0 0 7px rgba(229,72,77,0)}100%{box-shadow:0 0 0 0 rgba(229,72,77,0)}}
@media(max-width:760px){.livecam-grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto}}

/* =========================================================
   Room cards
   ========================================================= */
.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:clamp(1.5rem,2.5vw,2.4rem)}
.room-card{position:relative;background:var(--paper);border:1px solid var(--stone);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.room-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.room-card__media{position:relative;overflow:hidden;aspect-ratio:3/2}
.room-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.room-card:hover .room-card__media img{transform:scale(1.06)}
.room-card__area{position:absolute;top:1rem;right:1rem;background:rgba(24,20,16,.78);color:#fff;backdrop-filter:blur(6px);
  font-size:.72rem;letter-spacing:.08em;padding:.45em .9em;border-radius:var(--radius)}
.room-card__body{padding:1.6rem 1.6rem 1.8rem;display:flex;flex-direction:column;flex:1;gap:.55rem}
.room-card__body .sub{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);font-weight:700}
.room-card__body h3{font-size:1.45rem}
.room-card__body p{font-size:.92rem;color:var(--ink-soft);flex:1;margin-top:.2rem}
.room-card__foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.1rem;padding-top:1.1rem;border-top:1px solid var(--stone)}
.room-card__foot .cap{font-size:.8rem;color:var(--muted);display:flex;align-items:center;gap:.45em}
.room-card__foot .go{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);display:inline-flex;gap:.4em;align-items:center;transition:gap .3s var(--ease),color .3s}
.room-card:hover .room-card__foot .go{color:var(--brass);gap:.7em}

/* =========================================================
   Feature grid (spa, amenities)
   ========================================================= */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1px;background:var(--stone);border:1px solid var(--stone);border-radius:var(--radius);overflow:hidden}
.feature{position:relative;min-height:340px;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .9s var(--ease)}
.feature::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,16,12,.05),rgba(20,16,12,.82))}
.feature:hover img{transform:scale(1.07)}
.feature__body{position:relative;z-index:2;padding:1.8rem}
.feature__body h3{color:#fff;margin-bottom:.5rem}
.feature__body p{font-size:.9rem;color:#e7e0d2;max-width:40ch}
.feature__body .ico{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-bright);font-weight:700;display:block;margin-bottom:.7rem}

/* =========================================================
   Editorial banner (full-bleed image + overlaid text)
   ========================================================= */
.banner{position:relative;min-height:78vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.banner__bg{position:absolute;inset:0;z-index:-2}
.banner__bg img{width:100%;height:100%;object-fit:cover}
.banner::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(20,16,12,.78) 0%,rgba(20,16,12,.35) 60%,transparent 100%)}
.banner__card{max-width:540px}
.banner h2{color:#fff;margin:1rem 0 1.2rem}
.banner p{color:#e7e0d2;margin-bottom:1.8rem}

/* =========================================================
   Offers
   ========================================================= */
.offers{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:clamp(1.5rem,2.5vw,2.2rem)}
.offer{border:1px solid var(--stone);border-radius:var(--radius);padding:2.2rem;background:var(--paper);display:flex;flex-direction:column;gap:1rem;transition:border-color .4s var(--ease),transform .4s var(--ease)}
.offer:hover{border-color:var(--brass);transform:translateY(-4px)}
.offer .season{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);font-weight:700}
.offer h3{font-size:1.7rem}
.offer ul{display:flex;flex-direction:column;gap:.6rem;margin-top:.4rem}
.offer li{position:relative;padding-left:1.5em;font-size:.94rem;color:var(--ink-soft)}
.offer li::before{content:"";position:absolute;left:0;top:.62em;width:.5em;height:.5em;border:1px solid var(--brass);transform:rotate(45deg)}
.offer .price{margin-top:auto;padding-top:1.2rem;border-top:1px solid var(--stone);font-family:var(--font-display)}
.offer .price b{font-size:1.9rem;font-weight:400}
.offer .price span{font-size:.85rem;color:var(--muted)}

/* =========================================================
   Gallery
   ========================================================= */
.gallery{columns:3;column-gap:14px}
.gallery a{display:block;margin-bottom:14px;break-inside:avoid;overflow:hidden;border-radius:var(--radius);position:relative}
.gallery img{width:100%;transition:transform .8s var(--ease),filter .8s var(--ease)}
.gallery a:hover img{transform:scale(1.05);filter:brightness(.92)}
@media(max-width:900px){.gallery{columns:2}}
@media(max-width:560px){.gallery{columns:1}}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(16,12,9,.94);display:none;align-items:center;justify-content:center;padding:3vw}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:90vh;object-fit:contain;border-radius:var(--radius);box-shadow:0 30px 80px -30px #000}
.lb__close{position:absolute;top:1.4rem;right:1.6rem;color:#fff;font-size:1.6rem;letter-spacing:0;width:44px;height:44px;border:1px solid rgba(255,255,255,.4);border-radius:50%}
.lb__nav{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:2rem;width:54px;height:54px;border:1px solid rgba(255,255,255,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .3s}
.lb__nav:hover{background:rgba(255,255,255,.12)}
.lb__prev{left:2vw}.lb__next{right:2vw}

/* =========================================================
   Contact
   ========================================================= */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem)}
.info-list{display:flex;flex-direction:column;gap:1.8rem;margin-top:2rem}
.info-list .row{display:flex;gap:1.1rem;align-items:flex-start}
.info-list .k{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);font-weight:700;margin-bottom:.25rem}
.info-list .v{font-size:1.05rem}
.info-list .ico{flex:0 0 auto;width:42px;height:42px;border:1px solid var(--stone);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--brass)}
.form{display:grid;gap:1.1rem}
.form .two{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field label{display:block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:.5rem}
.field input,.field textarea,.field select{
  width:100%;padding:.95em 1.1em;border:1px solid var(--stone);background:var(--paper);border-radius:var(--radius);
  font:inherit;color:var(--ink);transition:border-color .3s var(--ease),box-shadow .3s var(--ease)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(169,124,47,.12)}
.field textarea{resize:vertical;min-height:130px}
.note{padding:1.1em 1.3em;border-radius:var(--radius);font-size:.92rem;border:1px solid}
.note--ok{background:#eef3e9;border-color:#bcd0a8;color:#3f5630}
.note--err{background:#f6ebe7;border-color:#dcb6a8;color:#7a3a26}
.map-embed{width:100%;height:100%;min-height:340px;border:0;border-radius:var(--radius);filter:grayscale(.25) contrast(1.02)}

/* =========================================================
   Footer
   ========================================================= */
.site-footer{background:var(--ink);color:#c9c0b0;padding-block:clamp(3.5rem,7vw,5.5rem) 2rem}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.12)}
.site-footer .brand .brand-txt b{color:#fff}
.footer-col h4{font-family:var(--font-body);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-bright);font-weight:700;margin-bottom:1.3rem}
.footer-col a{display:block;padding:.35rem 0;font-size:.95rem;color:#c9c0b0;transition:color .3s,padding-left .3s}
.footer-col a:hover{color:#fff;padding-left:.3rem}
.footer-blurb{font-size:.95rem;color:#a99f8e;margin:1.4rem 0;max-width:34ch}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;padding-top:2rem;font-size:.82rem;color:#8d8473}
.footer-bottom a:hover{color:#fff}

/* =========================================================
   Reveal animation
   ========================================================= */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}

/* =========================================================
   Responsive
   ========================================================= */
@media(max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .nav,.header-cta .phone-link{display:none}
  .burger{display:flex}
  .nav{
    position:fixed;inset:0;background:var(--ink);flex-direction:column;justify-content:center;gap:1.6rem;
    transform:translateY(-100%);transition:transform .5s var(--ease);padding:2rem}
  .nav-open .nav{transform:none;display:flex}
  .nav a{color:var(--paper);font-size:1.1rem}
  .nav a::after{display:none}
  .split{grid-template-columns:1fr;gap:2rem}
  .split--reverse .split__media{order:0}
  .split__media img{aspect-ratio:4/3}
  .stats{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .form .two{grid-template-columns:1fr}
}
@media(max-width:560px){
  .hero__meta{gap:1.5rem}
  .stats{grid-template-columns:1fr}
  .offer{padding:1.6rem}
}
