/* =====================================================================
   EverStonepoint — Core Stylesheet
   Australian Caravanning, Camping & Grey Nomad Travel Platform
   Hand-built design system. No frameworks.
   ===================================================================== */

/* ----------  Design tokens  ---------- */
:root {
  --sandstone: #C57B4B;
  --sandstone-light: #E4B88C;
  --sandstone-pale: #F3E3D2;
  --eucalyptus: #5C6E52;
  --eucalyptus-deep: #3C4A37;
  --eucalyptus-soft: #8C9C7E;
  --ocean: #1C3D4C;
  --ocean-mid: #2E5C6E;
  --canvas: #FAF6EF;
  --sand: #F1E9DC;
  --charcoal: #2A2520;
  --clay: #9B4A2F;
  --bone: #FFFDF9;

  --ink: var(--charcoal);
  --muted: #6B6258;

  --ff-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --ff-body: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --maxw: 1240px;
  --gutter: clamp(20px, 4vw, 40px);

  --r-sm: 10px;
  --r-md: 18px;
  --r-lg: 28px;
  --r-xl: 40px;

  --shadow-soft: 0 18px 40px -24px rgba(28, 61, 76, 0.35);
  --shadow-lift: 0 30px 60px -30px rgba(28, 61, 76, 0.45);
  --ring: 0 0 0 3px rgba(197, 123, 75, 0.35);

  --t-fast: 180ms cubic-bezier(.4, 0, .2, 1);
  --t-med: 360ms cubic-bezier(.22, 1, .36, 1);
}

/* ----------  Reset / base  ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--ff-body);
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink);
  background: var(--canvas);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg, picture { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { padding: 0; list-style: none; }
button { font: inherit; cursor: pointer; border: none; background: none; }
:focus-visible { outline: none; box-shadow: var(--ring); border-radius: 6px; }

/* ----------  Typography  ---------- */
h1, h2, h3, h4 { font-family: var(--ff-display); font-weight: 600; line-height: 1.08; color: var(--ocean); letter-spacing: -0.015em; }
h1 { font-size: clamp(2.6rem, 6vw, 4.6rem); font-optical-sizing: auto; }
h2 { font-size: clamp(2rem, 4vw, 3rem); }
h3 { font-size: clamp(1.35rem, 2.2vw, 1.7rem); }
h4 { font-size: 1.15rem; }
p { color: var(--muted); }
.lead { font-size: clamp(1.1rem, 1.6vw, 1.3rem); color: #4d463d; line-height: 1.6; }
strong { color: var(--ink); font-weight: 600; }

/* ----------  Layout helpers  ---------- */
.wrap { width: min(100% - 2 * var(--gutter), var(--maxw)); margin-inline: auto; }
.section { padding-block: clamp(64px, 9vw, 130px); }
.section--tight { padding-block: clamp(48px, 6vw, 80px); }
.stack > * + * { margin-top: 1.1rem; }
.center { text-align: center; }
.grid { display: grid; gap: clamp(20px, 2.4vw, 34px); }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 940px) { .cols-3, .cols-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .cols-2, .cols-3, .cols-4 { grid-template-columns: 1fr; } }

/* ----------  Eyebrow / kicker  ---------- */
.kicker {
  display: inline-flex; align-items: center; gap: .55em;
  font-size: .76rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  color: var(--clay);
}
.kicker::before { content: ""; width: 28px; height: 2px; background: var(--sandstone); border-radius: 2px; }
.kicker--center { justify-content: center; }
.section-head { max-width: 64ch; }
.section-head--center { margin-inline: auto; text-align: center; }

/* ----------  Buttons  ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .6em;
  padding: .85em 1.5em; border-radius: 100px;
  font-weight: 600; font-size: .96rem; letter-spacing: .01em;
  transition: transform var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
  will-change: transform;
}
.btn svg { width: 1.1em; height: 1.1em; }
.btn--primary { background: var(--sandstone); color: #fff; box-shadow: 0 12px 24px -12px rgba(197,123,75,.8); }
.btn--primary:hover { background: #b96d3d; transform: translateY(-2px); box-shadow: 0 18px 30px -14px rgba(197,123,75,.9); }
.btn--dark { background: var(--ocean); color: #fff; }
.btn--dark:hover { background: #15303c; transform: translateY(-2px); }
.btn--ghost { background: rgba(255,255,255,.12); color: #fff; border: 1px solid rgba(255,255,255,.4); backdrop-filter: blur(6px); }
.btn--ghost:hover { background: rgba(255,255,255,.22); }
.btn--outline { border: 1.5px solid var(--eucalyptus); color: var(--eucalyptus-deep); }
.btn--outline:hover { background: var(--eucalyptus); color: #fff; }
.link-arrow { display: inline-flex; align-items: center; gap: .4em; font-weight: 600; color: var(--clay); }
.link-arrow svg { width: 1em; transition: transform var(--t-fast); }
.link-arrow:hover svg { transform: translateX(4px); }

/* ----------  Header / nav  ---------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  transition: background var(--t-med), box-shadow var(--t-med), padding var(--t-med);
  padding-block: 14px;
}
.site-header.is-scrolled {
  background: rgba(250, 246, 239, 0.82);
  backdrop-filter: saturate(140%) blur(14px);
  box-shadow: 0 1px 0 rgba(42,37,32,.08), 0 12px 30px -24px rgba(28,61,76,.5);
}
.nav { display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.brand { display: inline-flex; align-items: center; gap: .6em; font-family: var(--ff-display); font-weight: 600; font-size: 1.32rem; color: var(--ocean); letter-spacing: -.02em; }
.brand .mark { width: 38px; height: 38px; flex: none; }
.brand b { color: var(--sandstone); font-weight: 600; }
.nav-links { display: flex; align-items: center; gap: clamp(.6rem, 1.6vw, 1.5rem); }
.nav-links a { font-size: .95rem; font-weight: 500; color: #463f37; padding: .4em .1em; position: relative; transition: color var(--t-fast); }
.nav-links a::after { content: ""; position: absolute; left: 0; bottom: -2px; height: 2px; width: 0; background: var(--sandstone); transition: width var(--t-fast); border-radius: 2px; }
.nav-links a:hover, .nav-links a[aria-current="page"] { color: var(--ocean); }
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after { width: 100%; }
.nav-cta { display: flex; align-items: center; gap: .8rem; }
.nav-toggle { display: none; width: 46px; height: 46px; border-radius: 12px; align-items: center; justify-content: center; background: var(--ocean); color: #fff; }
.nav-toggle svg { width: 22px; height: 22px; }

@media (max-width: 1040px) {
  .nav-links, .nav-cta .btn { display: none; }
  .nav-toggle { display: inline-flex; }
}

/* mobile drawer */
.mobile-menu {
  position: fixed; inset: 0; z-index: 200; visibility: hidden;
}
.mobile-menu__scrim { position: absolute; inset: 0; background: rgba(28,61,76,.5); opacity: 0; transition: opacity var(--t-med); }
.mobile-menu__panel {
  position: absolute; top: 0; right: 0; height: 100%; width: min(86vw, 380px);
  background: linear-gradient(160deg, #fffdf9, #f1e9dc);
  padding: 28px 26px; display: flex; flex-direction: column; gap: 1.2rem;
  transform: translateX(100%); transition: transform var(--t-med);
  box-shadow: -30px 0 60px -30px rgba(28,61,76,.6);
}
.mobile-menu.is-open { visibility: visible; }
.mobile-menu.is-open .mobile-menu__scrim { opacity: 1; }
.mobile-menu.is-open .mobile-menu__panel { transform: translateX(0); }
.mobile-menu__head { display: flex; align-items: center; justify-content: space-between; }
.mobile-menu__close { width: 44px; height: 44px; border-radius: 12px; background: var(--sand); display: inline-flex; align-items: center; justify-content: center; }
.mobile-menu nav { display: flex; flex-direction: column; }
.mobile-menu nav a { font-family: var(--ff-display); font-size: 1.45rem; color: var(--ocean); padding: .5rem 0; border-bottom: 1px solid rgba(42,37,32,.08); display: flex; justify-content: space-between; align-items: center; }
.mobile-menu nav a span { color: var(--sandstone); font-family: var(--ff-body); font-size: .8rem; }
.mobile-menu__foot { margin-top: auto; }

/* ----------  Hero (home)  ---------- */
.hero { position: relative; padding-top: clamp(40px, 7vw, 90px); padding-bottom: clamp(60px, 9vw, 120px); overflow: hidden; }
.hero__bg { position: absolute; inset: 0; z-index: -2; }
.hero__bg svg, .hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.hero__veil { position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(250,246,239,.0) 0%, rgba(250,246,239,.65) 78%, var(--canvas) 100%); }
.hero__inner { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(30px, 5vw, 70px); align-items: center; }
.hero h1 { color: var(--ocean); }
.hero h1 em { font-style: italic; color: var(--sandstone); }
.hero__lead { max-width: 46ch; margin-top: 1.3rem; }
.hero__actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2rem; }
.hero__stats { display: flex; gap: 2.2rem; margin-top: 2.6rem; flex-wrap: wrap; }
.hero__stats div { }
.hero__stats b { font-family: var(--ff-display); font-size: 2rem; color: var(--ocean); display: block; line-height: 1; }
.hero__stats span { font-size: .82rem; color: var(--muted); letter-spacing: .04em; }
.hero__card {
  background: rgba(255,253,249,.55); backdrop-filter: blur(16px) saturate(140%);
  border: 1px solid rgba(255,255,255,.6); border-radius: var(--r-lg);
  padding: 26px; box-shadow: var(--shadow-lift);
}
.hero__card h3 { font-size: 1.2rem; }
.mini-route { display: flex; align-items: center; gap: .9rem; padding: .7rem 0; border-bottom: 1px dashed rgba(42,37,32,.16); }
.mini-route:last-child { border-bottom: 0; }
.mini-route .pin { width: 38px; height: 38px; border-radius: 12px; background: var(--sandstone-pale); display: grid; place-items: center; color: var(--clay); flex: none; }
.mini-route .pin svg { width: 20px; }
.mini-route b { display: block; font-size: .98rem; color: var(--ink); }
.mini-route small { color: var(--muted); }
.mini-route .km { margin-left: auto; font-weight: 600; color: var(--eucalyptus-deep); font-size: .85rem; }
@media (max-width: 880px) { .hero__inner { grid-template-columns: 1fr; } }

/* ----------  Cards  ---------- */
.card {
  background: var(--bone); border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--shadow-soft); border: 1px solid rgba(42,37,32,.06);
  transition: transform var(--t-med), box-shadow var(--t-med);
  display: flex; flex-direction: column;
}
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lift); }
.card__media { position: relative; aspect-ratio: 16/11; overflow: hidden; }
.card__media img, .card__media svg { width: 100%; height: 100%; object-fit: cover; transition: transform 700ms cubic-bezier(.22,1,.36,1); }
.card:hover .card__media img, .card:hover .card__media svg { transform: scale(1.06); }
.card__tag { position: absolute; top: 14px; left: 14px; background: rgba(28,61,76,.85); color: #fff; font-size: .72rem; font-weight: 600; letter-spacing: .04em; padding: .35em .8em; border-radius: 100px; backdrop-filter: blur(4px); }
.card__body { padding: 22px 24px 26px; display: flex; flex-direction: column; gap: .5rem; flex: 1; }
.card__body h3 { font-size: 1.3rem; }
.card__meta { display: flex; gap: 1rem; font-size: .8rem; color: var(--muted); margin-top: auto; padding-top: .6rem; }
.card__meta span { display: inline-flex; align-items: center; gap: .35em; }
.card__meta svg { width: 1em; color: var(--eucalyptus); }

/* destination interactive tiles */
.dest-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.dest-grid .dest:nth-child(1) { grid-column: span 2; grid-row: span 2; }
.dest {
  position: relative; border-radius: var(--r-md); overflow: hidden; min-height: 200px;
  display: flex; align-items: flex-end; color: #fff; isolation: isolate;
}
.dest svg, .dest img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; transition: transform var(--t-med); }
.dest::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(28,61,76,0) 30%, rgba(28,61,76,.82) 100%); }
.dest:hover svg, .dest:hover img { transform: scale(1.07); }
.dest__label { padding: 20px; }
.dest__label small { text-transform: uppercase; letter-spacing: .16em; font-size: .68rem; opacity: .85; }
.dest__label h3 { color: #fff; font-size: 1.3rem; margin-top: .15rem; }
@media (max-width: 880px) { .dest-grid { grid-template-columns: repeat(2,1fr); } .dest-grid .dest:nth-child(1){ grid-column: span 2; grid-row: auto;} }
@media (max-width: 520px) { .dest-grid { grid-template-columns: 1fr; } .dest-grid .dest:nth-child(1){ grid-column: span 1;} }

/* ----------  Feature split  ---------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 72px); align-items: center; }
.split--reverse .split__media { order: 2; }
.split__media { border-radius: var(--r-xl); overflow: hidden; box-shadow: var(--shadow-lift); position: relative; }
.split__media img, .split__media svg { width: 100%; aspect-ratio: 4/3.4; object-fit: cover; }
@media (max-width: 820px) { .split { grid-template-columns: 1fr; } .split--reverse .split__media { order: 0; } }

/* ----------  Stats strip  ---------- */
.stats-strip { background: var(--ocean); color: #fff; border-radius: var(--r-xl); padding: clamp(34px, 5vw, 60px); position: relative; overflow: hidden; }
.stats-strip::before { content:""; position:absolute; inset:0; background: radial-gradient(120% 100% at 12% 0%, rgba(197,123,75,.35), transparent 55%); }
.stats-strip .grid { position: relative; }
.stat b { font-family: var(--ff-display); font-size: clamp(2.2rem, 4vw, 3.2rem); display: block; line-height: 1; color: var(--sandstone-light); }
.stat span { font-size: .9rem; opacity: .82; }
.stats-strip h2 { color: #fff; }

/* ----------  Newsletter  ---------- */
.newsletter { position: relative; border-radius: var(--r-xl); overflow: hidden; background: linear-gradient(135deg, var(--eucalyptus-deep), var(--eucalyptus)); color: #fff; padding: clamp(40px, 6vw, 76px); }
.newsletter::after { content:""; position:absolute; right:-60px; bottom:-60px; width:280px; height:280px; border-radius:50%; background: radial-gradient(circle, rgba(228,184,140,.35), transparent 70%); }
.newsletter h2 { color: #fff; }
.newsletter .form-row { display: flex; gap: .7rem; max-width: 480px; margin-top: 1.6rem; }
.newsletter input { flex: 1; padding: .9em 1.2em; border-radius: 100px; border: 1px solid rgba(255,255,255,.4); background: rgba(255,255,255,.14); color: #fff; }
.newsletter input::placeholder { color: rgba(255,255,255,.7); }
.newsletter .form-note { font-size: .8rem; opacity: .75; margin-top: .8rem; }
@media (max-width: 520px){ .newsletter .form-row { flex-direction: column; } }

/* ----------  Editorial story grid  ---------- */
.story { display: grid; gap: .7rem; }
.story__media { border-radius: var(--r-md); overflow: hidden; aspect-ratio: 16/10; box-shadow: var(--shadow-soft); }
.story__media img, .story__media svg { width:100%; height:100%; object-fit: cover; transition: transform var(--t-med); }
.story:hover .story__media img, .story:hover .story__media svg { transform: scale(1.05); }
.story__cat { font-size:.74rem; letter-spacing:.14em; text-transform: uppercase; color: var(--clay); font-weight:600; }
.story h3 { font-size: 1.25rem; transition: color var(--t-fast); }
.story:hover h3 { color: var(--sandstone); }
.story p { font-size: .92rem; }
.story__byline { font-size: .8rem; color: var(--muted); }

/* ----------  Page hero (interior pages)  ---------- */
.page-hero { position: relative; padding-block: clamp(72px, 10vw, 140px); overflow: hidden; color: #fff; }
.page-hero__bg { position:absolute; inset:0; z-index:-2; }
.page-hero__bg svg, .page-hero__bg img { width:100%; height:100%; object-fit: cover; }
.page-hero::after { content:""; position:absolute; inset:0; z-index:-1; background: linear-gradient(110deg, rgba(28,61,76,.86), rgba(28,61,76,.45)); }
.page-hero h1 { color: #fff; max-width: 18ch; }
.page-hero .lead { color: rgba(255,255,255,.9); max-width: 56ch; }
.crumbs { display:flex; gap:.5rem; align-items:center; font-size:.82rem; color: rgba(255,255,255,.8); margin-bottom: 1.4rem; }
.crumbs a:hover { color:#fff; text-decoration: underline; }
.crumbs svg { width: .8em; opacity:.6; }
.page-hero--light { color: var(--ink); }
.page-hero--light::after { display:none; }
.page-hero--light h1 { color: var(--ocean); }
.page-hero--light .lead { color: var(--muted); }
.page-hero--light .crumbs { color: var(--muted); }

/* ----------  Route / itinerary list  ---------- */
.route-row {
  display: grid; grid-template-columns: 120px 1fr auto; gap: 1.4rem; align-items: center;
  background: var(--bone); border: 1px solid rgba(42,37,32,.07); border-radius: var(--r-md);
  padding: 18px; transition: transform var(--t-fast), box-shadow var(--t-fast);
}
.route-row:hover { transform: translateX(4px); box-shadow: var(--shadow-soft); }
.route-row__no { font-family: var(--ff-display); font-size: 2.4rem; color: var(--sandstone-light); text-align: center; }
.route-row__badges { display:flex; gap:.5rem; flex-wrap:wrap; margin-top:.5rem; }
.badge { font-size:.72rem; font-weight:600; padding:.3em .7em; border-radius:100px; background: var(--sand); color: var(--eucalyptus-deep); }
.badge--sand { background: var(--sandstone-pale); color: var(--clay); }
.badge--ocean { background: rgba(46,92,110,.14); color: var(--ocean); }
.route-row__km { text-align:right; }
.route-row__km b { font-family: var(--ff-display); font-size:1.5rem; color: var(--ocean); display:block; }
.route-row__km span { font-size:.78rem; color: var(--muted); }
@media (max-width:640px){ .route-row { grid-template-columns: 64px 1fr; } .route-row__no{font-size:1.8rem;} .route-row__km{ grid-column: 2; text-align:left; } }

/* ----------  Checklists / tips  ---------- */
.tip-card { background: var(--bone); border-radius: var(--r-md); padding: 28px; border: 1px solid rgba(42,37,32,.07); box-shadow: var(--shadow-soft); transition: transform var(--t-med); }
.tip-card:hover { transform: translateY(-5px); }
.tip-card .ic { width: 54px; height: 54px; border-radius: 16px; display:grid; place-items:center; margin-bottom: 1rem; }
.tip-card .ic svg { width: 26px; }
.ic--sand { background: var(--sandstone-pale); color: var(--clay); }
.ic--euc { background: rgba(140,156,126,.25); color: var(--eucalyptus-deep); }
.ic--ocean { background: rgba(46,92,110,.16); color: var(--ocean); }
.tip-card h3 { font-size: 1.2rem; }
.checklist { display: grid; gap: .75rem; }
.checklist li { display:flex; gap:.75rem; align-items:flex-start; color: #4d463d; }
.checklist li svg { width: 22px; flex:none; color: var(--eucalyptus); margin-top:.1em; }

/* ----------  Gear / spec cards  ---------- */
.spec { display:flex; justify-content:space-between; padding:.7rem 0; border-bottom:1px solid rgba(42,37,32,.1); font-size:.92rem; }
.spec:last-child{border-bottom:0;}
.spec span{ color: var(--muted);} .spec b{ color: var(--ink);}
.price-tag { display:inline-flex; align-items:baseline; gap:.3em; }
.price-tag b { font-family: var(--ff-display); font-size:1.6rem; color: var(--clay); }
.rating { display:inline-flex; gap:.15em; color: var(--sandstone); }
.rating svg { width: 1em; }

/* ----------  Recipe (camp kitchen)  ---------- */
.recipe-card { background: var(--bone); border-radius: var(--r-lg); overflow:hidden; box-shadow: var(--shadow-soft); border:1px solid rgba(42,37,32,.06); transition: transform var(--t-med); }
.recipe-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lift); }
.recipe-card__media { aspect-ratio: 3/2; overflow:hidden; position:relative; }
.recipe-card__media img, .recipe-card__media svg { width:100%; height:100%; object-fit:cover; }
.recipe-card__time { position:absolute; bottom:12px; left:12px; background: rgba(255,253,249,.9); color: var(--ocean); font-weight:600; font-size:.78rem; padding:.35em .8em; border-radius:100px; }
.recipe-card__body { padding: 22px; }
.recipe-card__body h3 { font-size:1.2rem; }
.pill-row { display:flex; gap:.5rem; flex-wrap:wrap; margin-top:.8rem; }
.pill { font-size:.74rem; padding:.3em .8em; border-radius:100px; background: var(--sand); color: var(--eucalyptus-deep); }

/* ----------  Quote / callout  ---------- */
.callout { background: var(--sandstone-pale); border-radius: var(--r-lg); padding: clamp(28px,4vw,48px); border-left: 5px solid var(--sandstone); }
.callout--euc { background: rgba(140,156,126,.18); border-left-color: var(--eucalyptus); }
.callout--ocean { background: rgba(46,92,110,.1); border-left-color: var(--ocean); }
.pull-quote { font-family: var(--ff-display); font-size: clamp(1.4rem,3vw,2.2rem); line-height:1.3; color: var(--ocean); }
.pull-quote span { color: var(--sandstone); }

/* ----------  Timeline (itinerary days)  ---------- */
.timeline { position: relative; padding-left: 34px; }
.timeline::before { content:""; position:absolute; left: 9px; top:6px; bottom:6px; width:2px; background: linear-gradient(var(--sandstone), var(--eucalyptus)); }
.timeline li { position: relative; padding-bottom: 1.8rem; }
.timeline li::before { content:""; position:absolute; left:-34px; top:3px; width:20px; height:20px; border-radius:50%; background:#fff; border:4px solid var(--sandstone); }
.timeline h4 { color: var(--ocean); }
.timeline small { color: var(--clay); font-weight:600; letter-spacing:.08em; text-transform:uppercase; font-size:.72rem; }

/* ----------  Forms  ---------- */
.field { display:flex; flex-direction:column; gap:.4rem; }
.field label { font-size:.85rem; font-weight:600; color: var(--ink); }
.field input, .field textarea, .field select {
  padding:.85em 1em; border-radius: var(--r-sm); border:1.5px solid rgba(42,37,32,.16);
  background:#fff; font: inherit; color: var(--ink); transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.field input:focus, .field textarea:focus, .field select:focus { border-color: var(--sandstone); box-shadow: var(--ring); outline:none; }
.field textarea { min-height: 150px; resize: vertical; }
.form-card { background: var(--bone); border-radius: var(--r-lg); padding: clamp(26px,4vw,44px); box-shadow: var(--shadow-soft); border:1px solid rgba(42,37,32,.06); }
.form-msg { margin-top:1rem; padding:.9em 1.1em; border-radius: var(--r-sm); font-size:.9rem; display:none; }
.form-msg.show { display:block; }
.form-msg--ok { background: rgba(140,156,126,.22); color: var(--eucalyptus-deep); }

/* ----------  FAQ / accordion  ---------- */
.acc { border-bottom: 1px solid rgba(42,37,32,.12); }
.acc__q { width:100%; display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:1.2rem 0; text-align:left; font-family: var(--ff-display); font-size:1.15rem; color: var(--ocean); }
.acc__q svg { width:22px; flex:none; transition: transform var(--t-fast); color: var(--sandstone); }
.acc.is-open .acc__q svg { transform: rotate(45deg); }
.acc__a { max-height:0; overflow:hidden; transition: max-height var(--t-med); }
.acc__a p { padding-bottom: 1.2rem; }

/* ----------  Prose (legal pages)  ---------- */
.prose { max-width: 74ch; }
.prose h2 { font-size: 1.7rem; margin-top: 2.4rem; }
.prose h3 { font-size: 1.25rem; margin-top: 1.6rem; }
.prose p, .prose li { color: #4d463d; }
.prose ul { margin:1rem 0; display:grid; gap:.55rem; }
.prose ul li { position:relative; padding-left:1.4rem; }
.prose ul li::before { content:""; position:absolute; left:0; top:.65em; width:7px; height:7px; border-radius:2px; background: var(--sandstone); }
.prose a { color: var(--clay); text-decoration: underline; text-underline-offset:3px; }
.prose hr { border:0; height:1px; background: rgba(42,37,32,.12); margin:2.2rem 0; }
.toc { background: var(--sand); border-radius: var(--r-md); padding: 22px 26px; }
.toc a { color: var(--ocean); display:block; padding:.3rem 0; font-size:.92rem; }
.toc a:hover { color: var(--clay); }

/* ----------  Footer  ---------- */
.site-footer { background: var(--ocean); color: rgba(255,255,255,.82); margin-top: clamp(60px,8vw,110px); }
.site-footer a:hover { color: #fff; }
.footer-top { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 2.5rem; padding-block: clamp(50px,7vw,80px); }
.footer-brand .brand { color:#fff; }
.footer-brand p { color: rgba(255,255,255,.7); max-width: 34ch; margin-top:1rem; }
.footer-col h4 { color:#fff; font-family: var(--ff-body); font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:1rem; }
.footer-col a { display:block; padding:.32rem 0; font-size:.94rem; color: rgba(255,255,255,.78); transition: color var(--t-fast); }
.socials { display:flex; gap:.6rem; margin-top:1.2rem; }
.socials a { width:40px; height:40px; border-radius:12px; background: rgba(255,255,255,.1); display:grid; place-items:center; transition: background var(--t-fast); }
.socials a:hover { background: var(--sandstone); }
.socials svg { width:18px; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.14); padding-block:24px; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.84rem; color: rgba(255,255,255,.62); }
.footer-bottom nav { display:flex; gap:1.2rem; flex-wrap:wrap; }
@media (max-width: 820px){ .footer-top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px){ .footer-top { grid-template-columns: 1fr; } }

/* ----------  Scroll reveal  ---------- */
[data-reveal] { opacity: 0; transform: translateY(26px); transition: opacity .7s ease, transform .7s cubic-bezier(.22,1,.36,1); }
[data-reveal].is-in { opacity: 1; transform: none; }
[data-reveal-delay="1"]{ transition-delay:.08s;} [data-reveal-delay="2"]{ transition-delay:.16s;}
[data-reveal-delay="3"]{ transition-delay:.24s;} [data-reveal-delay="4"]{ transition-delay:.32s;}

/* ----------  Cookie banner  ---------- */
.cookie-bar {
  position: fixed; left: 50%; bottom: 22px; transform: translateX(-50%) translateY(140%);
  width: min(94vw, 720px); background: var(--bone); border:1px solid rgba(42,37,32,.1);
  border-radius: var(--r-md); box-shadow: var(--shadow-lift); padding: 20px 22px; z-index:300;
  display:flex; gap:1.2rem; align-items:center; flex-wrap:wrap; transition: transform var(--t-med);
}
.cookie-bar.show { transform: translateX(-50%) translateY(0); }
.cookie-bar p { font-size:.88rem; flex:1; min-width: 220px; }
.cookie-bar .actions { display:flex; gap:.6rem; }
.cookie-bar a { color: var(--clay); text-decoration: underline; }

/* ----------  Misc decorative  ---------- */
.bg-blob { position:absolute; border-radius:50%; filter: blur(60px); opacity:.5; z-index:-1; }
.divider-wave { display:block; width:100%; height:auto; color: var(--canvas); }
.tape { display:inline-block; transform: rotate(-2deg); background: var(--sandstone); color:#fff; font-weight:600; font-size:.78rem; padding:.3em .9em; border-radius: 6px; }
.eyebrow-num { font-family: var(--ff-display); color: var(--sandstone-light); font-size: 1.1rem; }

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  [data-reveal]{ opacity:1; transform:none; }
}

/* ----------  Utilities  ---------- */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.page-hero--light { background: linear-gradient(180deg, var(--sand), var(--canvas)); }
