/* ==========================================================================
   RV Park of Odessa, style.css
   Theme: warm West-Texas road-trip, two-color system.
   White base + bold charcoal sections + vivid burnt-orange accent.
   Display: Fraunces (self-hosted). Body: Inter (self-hosted).
   ========================================================================== */

/* ---------- Fonts ---------- */
@font-face{font-family:'Fraunces';src:url('fonts/fraunces-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Fraunces';src:url('fonts/fraunces-900.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('fonts/inter-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('fonts/inter-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('fonts/inter-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --primary:#E03810;          /* vivid burnt-orange, brand accent */
  --primary-deep:#C83000;     /* hover / pressed */
  --primary-soft:#FCEDE7;     /* faint orange wash */
  --ink:#2A2A2A;              /* charcoal sections */
  --ink-deep:#1E1E1E;         /* deeper charcoal + body text */
  --paper:#FFFFFF;
  --sand:#F5F4F2;             /* alternating light band */
  --sand-2:#EFEDEA;
  --line:rgba(30,30,30,.12);
  --mute:#5B5B5B;             /* muted body text on white (AA) */
  --mute-light:rgba(255,255,255,.78);
  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --container-max:122rem;
  --radius:1.6rem;
  --radius-sm:1rem;
  --shadow:0 2.4rem 5rem -2rem rgba(30,30,30,.28);
  --shadow-sm:0 1.2rem 3rem -1.4rem rgba(30,30,30,.30);
  --fs-h1:clamp(3.8rem,6.4vw,7.2rem);
  --fs-h2:clamp(2.9rem,4.4vw,4.8rem);
  --fs-h3:clamp(2rem,2.6vw,2.6rem);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:62.5%;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-size:1.7rem;line-height:1.65;color:var(--ink-deep);
  background:var(--paper);-webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
img,svg,iframe{max-width:100%;display:block}
img{height:auto}
a{color:var(--primary);text-decoration:none;transition:color .18s ease}
a:hover{color:var(--primary-deep)}
h1,h2,h3,h4{line-height:1.08;font-weight:600;letter-spacing:-.01em}
.display{font-family:var(--font-display);font-weight:900;letter-spacing:-.02em;line-height:1.02}
strong{font-weight:600;color:var(--ink-deep)}
::selection{background:var(--primary);color:#fff}

.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--ink-deep);color:#fff;padding:1rem 1.6rem;border-radius:0 0 .8rem 0}
.skip-link:focus{left:0;color:#fff}
:focus-visible{outline:3px solid var(--primary);outline-offset:2px}

.container{max-width:var(--container-max);margin:0 auto;padding:0 2.4rem}

/* ---------- Section scaffolding ---------- */
.sec{padding:8rem 2.4rem;max-width:var(--container-max);margin:0 auto}
.sec--light{background:var(--sand);max-width:none;padding-left:0;padding-right:0}
.sec--light > *{max-width:var(--container-max);margin-left:auto;margin-right:auto;padding-left:2.4rem;padding-right:2.4rem}
@media(min-width:740px){.sec{padding:10rem 2.4rem}}

.label{display:inline-block;font-family:var(--font-body);font-weight:600;font-size:1.3rem;letter-spacing:.18em;text-transform:uppercase;color:var(--primary)}
.label--light{color:#FFB892}

.sec-head{display:grid;gap:1.6rem 5rem;margin-bottom:5rem}
@media(min-width:880px){.sec-head{grid-template-columns:.5fr 1fr;align-items:start}}
.sec-head h2{font-size:var(--fs-h2);margin-bottom:1.4rem}
.sec-head p{color:var(--mute);max-width:60ch}
.accent{color:var(--primary)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--font-body);font-weight:600;font-size:1.6rem;
  padding:1.4rem 2.6rem;border-radius:5rem;border:2px solid transparent;
  cursor:pointer;transition:transform .15s ease,background .18s ease,box-shadow .18s ease,color .18s ease;
  line-height:1;text-align:center;
}
.btn--lg{padding:1.7rem 3.2rem;font-size:1.7rem}
.btn--primary{background:var(--primary);color:#fff;box-shadow:0 1rem 2.4rem -.8rem rgba(224,56,16,.6)}
.btn--primary:hover{background:var(--primary-deep);color:#fff;transform:translateY(-2px)}
.btn--outline{background:transparent;color:var(--ink-deep);border-color:rgba(30,30,30,.25)}
.btn--outline:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}
.btn--light{background:#fff;color:var(--ink-deep)}
.btn--light:hover{background:#fff;color:var(--primary);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn--ghost:hover{background:rgba(255,255,255,.12);color:#fff;border-color:#fff;transform:translateY(-2px)}

.link-arrow{font-weight:600;color:var(--primary);border-bottom:2px solid rgba(224,56,16,.28);padding-bottom:.2rem}
.link-arrow:hover{border-color:var(--primary)}

/* ---------- Header / nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:linear-gradient(180deg,rgba(15,14,12,.5) 0%,rgba(15,14,12,0) 100%);border-bottom:1px solid transparent;transition:background .25s ease,box-shadow .25s ease,border-color .25s ease,backdrop-filter .25s ease}
.nav--scrolled{background:rgba(255,255,255,.95);backdrop-filter:saturate(1.4) blur(10px);box-shadow:0 .6rem 2.4rem -1rem rgba(30,30,30,.22);border-bottom-color:var(--line)}
/* Floating over the hero by default (white text); solid + dark text once scrolled. */
.nav--scrolled .brand__main{color:var(--ink-deep)}
.nav--scrolled .nav__links a{color:var(--ink-deep)}
.nav__inner{max-width:var(--container-max);margin:0 auto;padding:1.1rem 2.4rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{display:flex;align-items:center;gap:1.1rem;color:var(--ink-deep)}
.brand__badge{flex:0 0 auto;display:inline-flex;filter:drop-shadow(0 .4rem .8rem rgba(224,56,16,.3))}
.brand__words{display:flex;flex-direction:column;line-height:1}
.brand__top{font-family:var(--font-body);font-weight:600;font-size:1.15rem;letter-spacing:.22em;text-transform:uppercase;color:var(--primary)}
.brand__main{font-family:var(--font-display);font-weight:900;font-size:2.2rem;letter-spacing:-.01em;color:#fff}
.brand:hover .brand__main{color:var(--primary)}
/* Real badge logo: cream knockout over the hero, full-color once the nav goes solid */
.brand__logo{height:5.6rem;width:auto;display:block;transition:transform .2s ease}
.brand:hover .brand__logo{transform:scale(1.03)}
.brand__logo--onwhite{display:none}
.nav--scrolled .brand__logo--onhero{display:none}
.nav--scrolled .brand__logo--onwhite{display:block}
.brand--foot .brand__logo{height:9.5rem}

.nav__links{display:flex;align-items:center;gap:2.6rem}
.nav__links a{font-family:var(--font-body);font-weight:500;font-size:1.6rem;color:#fff}
.nav__links a:hover{color:var(--primary)}
.nav__phone{font-weight:600!important;color:var(--primary)!important}
.nav__cta{background:var(--primary);color:#fff!important;padding:1rem 2rem;border-radius:5rem;font-weight:600!important}
.nav__cta:hover{background:var(--primary-deep);color:#fff!important}
.nav__toggle,.nav__burger{display:none}

@media(max-width:920px){
  .nav__toggle{position:absolute;opacity:0;pointer-events:none}
  .nav__burger{display:flex;width:4.6rem;height:4.6rem;align-items:center;justify-content:center;cursor:pointer;border-radius:1rem;border:1px solid var(--line);background:#fff}
  .nav__burger span,.nav__burger span::before,.nav__burger span::after{content:'';display:block;width:2.2rem;height:2px;background:var(--ink-deep);transition:.25s}
  .nav__burger span{position:relative}
  .nav__burger span::before{position:absolute;top:-7px}
  .nav__burger span::after{position:absolute;top:7px}
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(82vw,34rem);flex-direction:column;align-items:flex-start;gap:2.2rem;background:var(--ink-deep);padding:9rem 3rem 3rem;opacity:0;visibility:hidden;transform:translateY(-1rem);transition:opacity .25s ease,transform .25s ease,visibility .25s;box-shadow:var(--shadow)}
  .nav__links a,.nav--scrolled .nav__links a{color:#fff;font-size:2rem}
  .nav__links a:hover{color:#FFB892}
  .nav__phone{color:#FFB892!important}
  .nav__cta{color:#fff!important}
  .nav__toggle:checked ~ .nav__links{opacity:1;visibility:visible;transform:translateY(0)}
  .nav__toggle:checked ~ .nav__burger span{background:transparent}
  .nav__toggle:checked ~ .nav__burger span::before{top:0;transform:rotate(45deg);background:var(--ink-deep)}
  .nav__toggle:checked ~ .nav__burger span::after{top:0;transform:rotate(-45deg);background:var(--ink-deep)}
}

/* ---------- Page-load reveal (staggered) ---------- */
.reveal{opacity:0;transform:translateY(2.4rem);animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}
.reveal:nth-child(1){animation-delay:.05s}
.reveal:nth-child(2){animation-delay:.16s}
.reveal:nth-child(3){animation-delay:.28s}
.reveal:nth-child(4){animation-delay:.40s}
.reveal:nth-child(5){animation-delay:.52s}
@keyframes rise{to{opacity:1;transform:none}}
.fade-up{opacity:0;transform:translateY(2.2rem);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.fade-up.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal,.fade-up{animation:none!important;opacity:1!important;transform:none!important;transition:none!important}
  html{scroll-behavior:auto}
}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:clamp(54rem,78vh,70rem);display:flex;align-items:flex-end;color:#fff;overflow:hidden;background:var(--ink-deep)}
.hero__photo{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04)}
.hero__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,18,16,.30) 0%,rgba(20,18,16,.20) 35%,rgba(24,16,12,.74) 78%,rgba(20,14,10,.92) 100%)}
.hero__inner{position:relative;max-width:var(--container-max);margin:0 auto;width:100%;padding:10rem 2.4rem 8rem;display:flex;flex-direction:column;gap:2rem}
.hero__eyebrow{font-family:var(--font-body);font-weight:600;font-size:1.35rem;letter-spacing:.2em;text-transform:uppercase;color:#FFC49E}
.hero__title{font-size:var(--fs-h1);max-width:18ch;text-shadow:0 .2rem 2rem rgba(0,0,0,.3)}
.hero__sub{font-size:clamp(1.7rem,2vw,2.1rem);max-width:56ch;color:rgba(255,255,255,.92)}
.hero__actions{display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:.6rem}
.hero .btn--outline{color:#fff;border-color:rgba(255,255,255,.55)}
.hero .btn--outline:hover{background:rgba(255,255,255,.12);color:#fff;border-color:#fff}
.hero__trust{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;margin-top:1rem;font-size:1.5rem;color:rgba(255,255,255,.9)}
.hero__stars{color:#FFB200;letter-spacing:.15em;font-size:1.8rem}
.hero__trust strong{color:#fff}

/* ---------- Marquee strip ---------- */
.strip{background:var(--primary);color:#fff;overflow:hidden;padding:1.3rem 0;white-space:nowrap}
.strip__row{display:inline-flex;animation:marq 34s linear infinite}
.strip__row span{font-family:var(--font-display);font-weight:600;font-size:1.7rem;letter-spacing:.01em;padding-right:1rem}
.strip .dot{font-size:1rem;opacity:.7;vertical-align:middle;margin:0 .4rem}
@keyframes marq{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.strip__row{animation:none}}

/* ---------- Intro / pillars ---------- */
.intro__head{max-width:64rem;margin:0 auto 5rem;text-align:center}
.intro__head--wide{max-width:80rem}
.intro__head h2{font-size:var(--fs-h2);margin:1.4rem 0 1.8rem}
.intro__head p{color:var(--mute);font-size:1.8rem}
.pillars{display:grid;gap:2.4rem;grid-template-columns:repeat(auto-fit,minmax(26rem,1fr))}
.pillar{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:3.2rem 2.8rem;text-align:center;transition:transform .2s ease,box-shadow .2s ease,border-color .2s}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:transparent}
.pillar__ico{display:inline-flex;align-items:center;justify-content:center;width:6.4rem;height:6.4rem;border-radius:50%;background:var(--primary-soft);color:var(--primary);margin-bottom:1.8rem}
.pillar__ico svg{width:3rem;height:3rem}
.pillar h3{font-family:var(--font-display);font-size:2.4rem;margin-bottom:1rem}
.pillar p{color:var(--mute);font-size:1.6rem}

/* ---------- Feature split ---------- */
.feature{display:grid;gap:0;align-items:stretch;background:var(--ink-deep);color:#fff}
.feature--alt{background:var(--sand);color:var(--ink-deep)}
@media(min-width:880px){.feature{grid-template-columns:1fr 1fr}.feature--alt .feature__media{order:2}}
.feature__media{position:relative;min-height:38rem}
.feature__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feature__stamp{position:absolute;left:2rem;bottom:2rem;background:var(--primary);color:#fff;font-family:var(--font-display);font-weight:600;font-size:1.5rem;padding:.7rem 1.6rem;border-radius:5rem;box-shadow:var(--shadow-sm)}
.feature__copy{padding:5.5rem clamp(2.4rem,5vw,6rem)}
.feature__copy h2{font-size:var(--fs-h2);margin:1.6rem 0 2rem}
.feature--alt .feature__copy p{color:var(--mute)}
.feature__copy p{margin-bottom:1.6rem;color:rgba(255,255,255,.85)}
.feature__copy p:last-child{margin-bottom:0;margin-top:2.4rem}

/* ---------- Amenities grid ---------- */
.amgrid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(27rem,1fr))}
.amcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:2.8rem 2.6rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s}
.amcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:var(--primary)}
.amcard__ico{display:inline-flex;align-items:center;justify-content:center;width:5.4rem;height:5.4rem;border-radius:1.4rem;background:var(--ink-deep);color:#FFB892;margin-bottom:1.6rem}
.amcard:hover .amcard__ico{background:var(--primary);color:#fff}
.amcard__ico svg{width:2.7rem;height:2.7rem}
.amcard h3{font-family:var(--font-display);font-size:2.1rem;margin-bottom:.8rem}
.amcard p{color:var(--mute);font-size:1.55rem;line-height:1.6}
.amgrid__cta{margin-top:4rem;text-align:center}

/* ---------- Location ---------- */
.loc{background:var(--ink-deep);color:#fff}
.loc__grid{max-width:var(--container-max);margin:0 auto;display:grid;gap:0}
@media(min-width:920px){.loc__grid{grid-template-columns:1fr 1fr}}
.loc__copy{padding:7rem clamp(2.4rem,5vw,6rem)}
.loc__copy h2{font-size:var(--fs-h2);margin:1.6rem 0 2rem}
.loc__copy p{color:rgba(255,255,255,.85);margin-bottom:1.6rem;max-width:52ch}
.loc__copy a{color:#FFB892}
.loc__facts{list-style:none;margin-top:3rem;display:grid;gap:1.6rem}
.loc__facts li{display:flex;flex-direction:column;gap:.2rem;font-size:1.7rem;border-left:3px solid var(--primary);padding-left:1.6rem}
.loc__facts strong{font-family:var(--font-body);font-size:1.2rem;letter-spacing:.16em;text-transform:uppercase;color:#FFB892}
.loc__facts a{color:#fff}
.loc__map{min-height:40rem}
.loc__map iframe{width:100%;height:100%;min-height:40rem;border:0;filter:grayscale(.1) contrast(1.02)}

/* ---------- FAQ ---------- */
.faq{padding:8rem 2.4rem;max-width:var(--container-max);margin:0 auto}
.faq__grid{display:grid;gap:3rem 5rem}
@media(min-width:880px){.faq__grid{grid-template-columns:.7fr 1fr;align-items:start}}
.faq__intro h2{font-size:var(--fs-h2);margin:1.4rem 0 1.6rem}
.faq__intro p{color:var(--mute)}
.faq__intro a{color:var(--primary)}
.faq__list{display:grid;gap:1.2rem}
.faq__item{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.4rem 2.2rem;transition:border-color .2s,box-shadow .2s}
.faq__item[open]{border-color:var(--primary);box-shadow:var(--shadow-sm)}
.faq__item summary{list-style:none;cursor:pointer;font-family:var(--font-display);font-weight:600;font-size:1.9rem;padding:1.8rem 0;display:flex;justify-content:space-between;align-items:center;gap:1.6rem}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:'+';color:var(--primary);font-size:2.6rem;font-weight:400;line-height:1;transition:transform .2s}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__a{padding:0 0 2rem;color:var(--mute);font-size:1.65rem}

/* ---------- CTA band ---------- */
.cta--band{background:var(--primary);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta--band::before{content:'';position:absolute;inset:0;background:radial-gradient(120rem 60rem at 50% -30%,rgba(255,255,255,.18),transparent 60%)}
.cta__inner{position:relative;max-width:74rem;margin:0 auto;padding:8rem 2.4rem}
.cta--band .label--light{color:#FFE0CE}
.cta--band h2{font-size:var(--fs-h2);margin:1.4rem 0 1.6rem}
.cta__sub{font-size:1.8rem;color:rgba(255,255,255,.92);margin-bottom:3rem;max-width:54ch;margin-left:auto;margin-right:auto}
.cta__actions{display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap}
.cta--band .btn--ghost{border-color:rgba(255,255,255,.6)}

/* ---------- Page hero (interior) ---------- */
.page-hero{position:relative;color:#fff;background:var(--ink-deep);overflow:hidden;display:flex;align-items:flex-end;min-height:46rem}
.page-hero__photo{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,18,16,.35),rgba(20,14,10,.86))}
.page-hero__inner{position:relative;max-width:var(--container-max);margin:0 auto;width:100%;padding:6rem 2.4rem 5rem;display:flex;flex-direction:column;gap:1.6rem}
.page-hero__title{font-size:clamp(3.4rem,5.2vw,6rem);max-width:18ch}
.page-hero__lead{font-size:clamp(1.7rem,1.9vw,2rem);max-width:60ch;color:rgba(255,255,255,.9)}
.page-hero__lead a{color:#FFB892}
.page-hero__actions{display:flex;gap:1.4rem;flex-wrap:wrap;margin-top:1rem}
.page-hero .btn--outline{color:#fff;border-color:rgba(255,255,255,.55)}
.page-hero .btn--outline:hover{background:rgba(255,255,255,.12);color:#fff;border-color:#fff}
.page-hero--short{min-height:auto;background:var(--ink-deep)}
.page-hero--short .page-hero__inner{padding:10rem 2.4rem 6rem}
.page-hero--center{text-align:center}
.page-hero--center .page-hero__inner{align-items:center}
.page-hero--center .page-hero__actions{justify-content:center}

/* ---------- Breadcrumb ---------- */
.breadcrumb{max-width:var(--container-max);margin:0 auto;padding:1.8rem 2.4rem}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.8rem;font-size:1.4rem;color:var(--mute)}
.breadcrumb li+li::before{content:'/';margin-right:.8rem;color:var(--line)}
.breadcrumb a{color:var(--mute)}
.breadcrumb a:hover{color:var(--primary)}

/* ---------- Prose ---------- */
.prose-sec__grid{display:grid;gap:3rem 6rem}
@media(min-width:920px){.prose-sec__grid{grid-template-columns:.7fr 1fr;align-items:start}}
.prose-sec__lead h2{font-size:var(--fs-h2);margin-top:1.4rem}
.prose{max-width:72ch}
.prose p{margin-bottom:1.8rem;color:var(--ink-deep)}
.prose p:has(+ h2),.prose>p{color:#33312f}
.prose h2{font-family:var(--font-display);font-size:2.6rem;margin:3.4rem 0 1.4rem;color:var(--ink-deep)}
.prose ul{margin:0 0 1.8rem 2rem}
.prose li{margin-bottom:.8rem}
.prose a{color:var(--primary);border-bottom:1px solid rgba(224,56,16,.3)}

/* ---------- Fact strip ---------- */
.factstrip{background:var(--ink-deep);max-width:none;padding:0}
.factstrip__grid{max-width:var(--container-max);margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:0}
@media(min-width:760px){.factstrip__grid{grid-template-columns:repeat(4,1fr)}}
.fact{padding:4.5rem 2.4rem;text-align:center;color:#fff;border-right:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1)}
.fact__v{display:block;font-family:var(--font-display);font-weight:900;font-size:clamp(3.2rem,5vw,4.6rem);color:var(--primary);line-height:1}
.fact__l{display:block;margin-top:.8rem;font-size:1.45rem;color:rgba(255,255,255,.78)}

/* ---------- Rates card ---------- */
.rates{max-width:var(--container-max)}
.rates__card{background:var(--ink-deep);color:#fff;border-radius:var(--radius);padding:clamp(3.4rem,5vw,5.5rem);text-align:center;box-shadow:var(--shadow)}
.rates__card h2{font-size:var(--fs-h2);margin:1.4rem 0 1.6rem;max-width:20ch;margin-left:auto;margin-right:auto}
.rates__card p{color:rgba(255,255,255,.85);max-width:60ch;margin:0 auto 3rem;font-size:1.75rem}
.rates__actions{display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap}
.rates .btn--outline{color:#fff;border-color:rgba(255,255,255,.5)}
.rates .btn--outline:hover{background:rgba(255,255,255,.12);color:#fff;border-color:#fff}

/* ---------- Places ---------- */
.places__head{display:flex;align-items:center;gap:1.8rem;margin-bottom:2.4rem}
.places__ico{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:6rem;height:6rem;border-radius:1.4rem;background:var(--primary);color:#fff}
.places__ico svg{width:2.8rem;height:2.8rem}
.places__head h2{font-size:clamp(2.6rem,3.6vw,3.8rem);margin-top:.4rem}
.places--alt{background:var(--sand);max-width:none}
.places--alt > *{max-width:var(--container-max);margin-left:auto;margin-right:auto}
.places__intro{max-width:84ch;color:var(--mute);font-size:1.75rem;margin-bottom:2.8rem}
.places__intro strong{color:var(--ink-deep)}
.places__note{margin-top:2.4rem;font-size:1.4rem;color:var(--mute);font-style:italic}
.placecards{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fill,minmax(24rem,1fr))}
.placecard{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--primary);border-radius:.8rem;padding:1.8rem 2rem;transition:transform .18s ease,box-shadow .18s ease}
.placecard:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.placecard__t{display:block;font-family:var(--font-display);font-weight:600;font-size:1.85rem;color:var(--ink-deep)}
.placecard__m{display:block;margin-top:.3rem;font-size:1.4rem;color:var(--mute)}

/* ---------- Contact ---------- */
.contact-grid{display:grid;gap:4rem}
@media(min-width:920px){.contact-grid{grid-template-columns:1.4fr .9fr;align-items:start}}
.contact-grid__h{font-size:var(--fs-h3);margin:1.2rem 0 2.6rem}
.contact-card{background:var(--ink-deep);color:#fff;border-radius:var(--radius);padding:3.4rem 3rem;display:grid;gap:2.4rem;box-shadow:var(--shadow)}
.contact-card h3{font-family:var(--font-body);font-size:1.2rem;letter-spacing:.16em;text-transform:uppercase;color:#FFB892;margin-bottom:.6rem}
.contact-card p{font-size:1.7rem;color:rgba(255,255,255,.9)}
.contact-card a{color:#fff}
.contact-card .big{font-family:var(--font-display);font-weight:900;font-size:3rem;color:#fff}
.contact-card .big:hover{color:#FFB892}
.contact-card .muted{color:rgba(255,255,255,.6);font-size:1.45rem}
.contact-map{height:42rem}
.contact-map iframe{width:100%;height:100%;border:0}

/* ---------- Lead form ---------- */
.leadform__hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.field-row{display:grid;gap:1.8rem}
.field-row--2{grid-template-columns:1fr}
@media(min-width:560px){.field-row--2{grid-template-columns:1fr 1fr}}
.field{margin-bottom:1.8rem;display:flex;flex-direction:column}
.field label,.field__lbl{font-weight:600;font-size:1.45rem;margin-bottom:.7rem;color:var(--ink-deep)}
.field label span{color:var(--primary)}
.field label .opt{color:var(--mute);font-weight:400;font-size:1.3rem}
.field input,.field textarea{
  font-family:var(--font-body);font-size:1.6rem;color:var(--ink-deep);
  padding:1.3rem 1.5rem;border:1.5px solid var(--line);border-radius:1rem;background:#fff;
  transition:border-color .18s,box-shadow .18s;width:100%;
}
.field input::placeholder,.field textarea::placeholder{color:#9a9a9a}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
.field textarea{min-height:13rem;resize:vertical}
.checkgroup{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(20rem,1fr))}
.checkopt{display:flex;align-items:center;gap:.9rem;font-weight:400;font-size:1.55rem;cursor:pointer;border:1.5px solid var(--line);border-radius:1rem;padding:1.1rem 1.4rem;transition:border-color .18s,background .18s}
.checkopt:hover{border-color:var(--primary)}
.checkopt input{accent-color:var(--primary);width:1.8rem;height:1.8rem;flex:0 0 auto}
.checkopt span{margin-bottom:0}
.submit{width:100%;margin-top:.6rem;background:var(--primary);color:#fff;border:none;font-family:var(--font-body);font-weight:600;font-size:1.8rem;padding:1.7rem;border-radius:5rem;cursor:pointer;transition:background .18s,transform .15s;box-shadow:0 1rem 2.4rem -.8rem rgba(224,56,16,.6)}
.submit:hover{background:var(--primary-deep);transform:translateY(-2px)}
.leadform__note{margin-top:1.4rem;font-size:1.4rem;color:var(--mute);text-align:center}
.form-error{background:var(--primary-soft);border:1px solid var(--primary);color:var(--primary-deep);padding:1.6rem 2rem;border-radius:1rem;font-size:1.55rem}

/* ---------- Footer ---------- */
.foot{background:var(--ink-deep);color:rgba(255,255,255,.78);padding:6.5rem 0 3rem}
.foot__grid{display:grid;gap:4rem;grid-template-columns:1fr}
@media(min-width:760px){.foot__grid{grid-template-columns:2fr 1fr 1fr}}
.foot__brand p{margin-top:1.8rem;max-width:48ch;font-size:1.55rem;color:rgba(255,255,255,.66)}
.brand--foot .brand__main{color:#fff}
.brand--foot{display:inline-flex}
.foot__social{list-style:none;display:flex;gap:1.6rem;margin-top:1.8rem}
.foot__social a{color:#FFB892}
.foot__col h3{font-family:var(--font-body);font-size:1.25rem;letter-spacing:.16em;text-transform:uppercase;color:#FFB892;margin-bottom:1.6rem}
.foot__col ul{list-style:none;display:grid;gap:1rem}
.foot__col a{color:rgba(255,255,255,.78);font-size:1.6rem}
.foot__col a:hover{color:#fff}
.foot__bottom{max-width:var(--container-max);margin:5rem auto 0;padding-top:2.6rem;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-wrap:wrap;gap:1.4rem;justify-content:space-between;align-items:center;font-size:1.4rem;color:rgba(255,255,255,.6)}
.foot__bottom a{color:rgba(255,255,255,.78)}
.foot__bottom a:hover{color:#fff}
.flag{display:inline-flex;align-items:center;gap:1rem}
.txflag{width:3rem;height:2rem;border-radius:.3rem;box-shadow:0 .2rem .6rem rgba(0,0,0,.3)}

/* ---------- Sticky mobile call bar ---------- */
.call-bar{display:none}
@media(max-width:760px){
  .call-bar{display:flex;align-items:center;justify-content:center;gap:.6rem;position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--primary);color:#fff;font-weight:600;font-size:1.6rem;padding:1.4rem;text-align:center;box-shadow:0 -.4rem 1.6rem rgba(0,0,0,.2)}
  .call-bar:hover{color:#fff}
  body{padding-bottom:5.6rem}
}

/* ---------- Footer/utility ---------- */
.muted{color:var(--mute)}
