/* =========================================================================
   Via Vitales — Fußpflege & Kosmetikpraxis Hannover-Kirchrode
   Design system · calm · premium · medical-wellness
   ========================================================================= */

/* ---------- Tokens ---------- */
:root{
  /* Palette */
  --ivory:        #F6F1E9;
  --ivory-2:      #FBF8F2;
  --paper:        #FFFFFF;
  --ink:          #2A2823;
  --ink-soft:     #55504733;
  --muted:        #6E685C;
  --line:         #E4DCCF;

  --sage:         #3E5147;   /* primary */
  --sage-deep:    #33413A;
  --sage-700:     #2C382F;
  --sage-tint:    #E9EDE7;

  --rose:         #B06B77;   /* brand accent */
  --rose-soft:    #C99AA2;
  --rose-tint:    #F3E7E9;

  --gold:         #BFA269;   /* fine detail */
  --gold-soft:    #D8C49A;

  /* Type */
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  /* Rhythm */
  --container: 1200px;
  --gutter: clamp(1.25rem, 4vw, 3rem);
  --radius: 18px;
  --radius-sm: 12px;
  --shadow-sm: 0 2px 10px rgba(42,40,35,.05);
  --shadow-md: 0 18px 50px -22px rgba(42,40,35,.28);
  --shadow-lg: 0 40px 90px -40px rgba(42,40,35,.40);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  font-family:var(--sans);
  font-size:clamp(1rem,.97rem + .2vw,1.08rem);
  line-height:1.7;
  color:var(--ink);
  background:var(--ivory);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ margin:0; font-family:var(--serif); font-weight:600; line-height:1.08; letter-spacing:-.01em; color:var(--ink); }
p{ margin:0; }
::selection{ background:var(--rose); color:#fff; }

/* ---------- Layout helpers ---------- */
.container{ width:min(100% - var(--gutter)*2, var(--container)); margin-inline:auto; }
.container-tight{ width:min(100% - var(--gutter)*2, 880px); margin-inline:auto; }
.section{ padding:clamp(4.5rem,9vw,8rem) 0; }
.section-sm{ padding:clamp(3rem,6vw,5rem) 0; }

.eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--sans); font-size:.74rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--rose);
  margin:0 0 1.1rem;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--gold); }
.eyebrow.center{ }
.eyebrow.on-dark{ color:var(--gold-soft); }

.h-display{ font-size:clamp(2.5rem,1.6rem + 4vw,4.6rem); font-weight:500; }
.h-section{ font-size:clamp(2rem,1.4rem + 2.6vw,3.2rem); font-weight:500; }
.lead{ font-size:clamp(1.12rem,1.05rem + .4vw,1.35rem); color:var(--muted); line-height:1.75; }
.muted{ color:var(--muted); }
.center{ text-align:center; }
.mx-auto{ margin-inline:auto; }
.measure{ max-width:62ch; }
.measure-sm{ max-width:48ch; }

.section-head{ max-width:720px; }
.section-head.center{ margin-inline:auto; text-align:center; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--sage); --fg:#fff;
  position:relative; display:inline-flex; align-items:center; gap:.6rem;
  padding:1rem 1.7rem; border-radius:100px; border:1px solid transparent;
  background:var(--bg); color:var(--fg);
  font-family:var(--sans); font-weight:600; font-size:.92rem; letter-spacing:.01em;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), background .3s var(--ease), color .3s var(--ease);
  box-shadow:var(--shadow-sm); will-change:transform;
}
.btn svg{ width:1.05em; height:1.05em; }
.btn:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); }
.btn:active{ transform:translateY(-1px); }
.btn--ghost{ --bg:transparent; --fg:var(--ink); border-color:var(--line); box-shadow:none; }
.btn--ghost:hover{ border-color:var(--sage); color:var(--sage); }
.btn--rose{ --bg:var(--rose); }
.btn--gold{ --bg:var(--gold); --fg:#3a2f16; }
.btn--light{ --bg:#fff; --fg:var(--sage-deep); }
.btn--outline-light{ --bg:transparent; --fg:#fff; border-color:rgba(255,255,255,.4); box-shadow:none; }
.btn--outline-light:hover{ background:rgba(255,255,255,.1); }
.btn--block{ width:100%; justify-content:center; }

.link-arrow{
  display:inline-flex; align-items:center; gap:.5rem; font-weight:600; font-size:.92rem;
  color:var(--sage); position:relative;
}
.link-arrow svg{ width:1em; transition:transform .35s var(--ease); }
.link-arrow:hover svg{ transform:translateX(5px); }

/* ---------- Top utility bar ---------- */
.topbar{
  background:var(--sage-deep); color:#eae5da;
  font-size:.8rem; letter-spacing:.02em;
}
.topbar__row{ display:flex; justify-content:space-between; align-items:center; gap:1rem; min-height:40px; padding-block:.35rem; }
.topbar a{ color:#f2ede2; }
.topbar__meta{ display:flex; align-items:center; gap:1.4rem; }
.topbar__meta span{ display:inline-flex; align-items:center; gap:.45rem; opacity:.9; }
.topbar__meta svg{ width:.95em; color:var(--gold-soft); }
.topbar__phone{ font-weight:600; }
@media (max-width:720px){ .topbar__meta span.hide-sm{ display:none; } }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(246,241,233,.82); backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:background .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.site-header.scrolled{ background:rgba(251,248,242,.92); border-color:var(--line); box-shadow:0 8px 30px -24px rgba(42,40,35,.5); }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; min-height:78px; transition:min-height .4s var(--ease); }
.scrolled .nav{ min-height:66px; }

.brand{ display:inline-flex; align-items:center; gap:.7rem; }
.brand__mark{ width:38px; height:38px; flex:none; }
.brand__text{ display:flex; flex-direction:column; line-height:1; }
.brand__name{ font-family:var(--serif); font-weight:600; font-size:1.5rem; letter-spacing:.01em; color:var(--sage-deep); }
.brand__name b{ color:var(--rose); font-weight:600; }
.brand__sub{ font-family:var(--sans); font-size:.62rem; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--muted); margin-top:.28rem; }

.nav__links{ display:flex; align-items:center; gap:2rem; }
.nav__links a{ font-size:.95rem; font-weight:500; color:var(--ink); position:relative; padding-block:.4rem; }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:0; width:100%; height:1.5px; background:var(--rose); transform:scaleX(0); transform-origin:right; transition:transform .4s var(--ease); }
.nav__links a:hover::after, .nav__links a[aria-current="page"]::after{ transform:scaleX(1); transform-origin:left; }
.nav__links a[aria-current="page"]{ color:var(--sage); }
.nav__cta{ display:flex; align-items:center; gap:1rem; }

.nav__toggle{ display:none; width:46px; height:46px; border:1px solid var(--line); border-radius:12px; background:var(--paper); align-items:center; justify-content:center; }
.nav__toggle span{ position:relative; width:20px; height:2px; background:var(--ink); border-radius:2px; transition:.3s var(--ease); }
.nav__toggle span::before,.nav__toggle span::after{ content:""; position:absolute; left:0; width:20px; height:2px; background:var(--ink); border-radius:2px; transition:.3s var(--ease); }
.nav__toggle span::before{ top:-6px; } .nav__toggle span::after{ top:6px; }
body.nav-open .nav__toggle span{ background:transparent; }
body.nav-open .nav__toggle span::before{ top:0; transform:rotate(45deg); }
body.nav-open .nav__toggle span::after{ top:0; transform:rotate(-45deg); }

@media (max-width:900px){
  .nav__toggle{ display:inline-flex; }
  .nav__links, .nav__cta .btn{ display:none; }
  .mobile-menu{ display:block; }
}

/* Mobile menu */
.mobile-menu{
  display:none; position:fixed; inset:0 0 0 auto; width:min(88vw,360px); z-index:70;
  background:var(--ivory-2); box-shadow:var(--shadow-lg);
  transform:translateX(100%); transition:transform .45s var(--ease);
  padding:6rem 2rem 2rem; overflow-y:auto;
}
body.nav-open .mobile-menu{ transform:translateX(0); }
.mobile-menu a{ display:block; font-family:var(--serif); font-size:1.6rem; padding:.7rem 0; border-bottom:1px solid var(--line); color:var(--sage-deep); }
.mobile-menu .btn{ margin-top:1.6rem; }
.mobile-menu__meta{ margin-top:2rem; font-size:.9rem; color:var(--muted); line-height:1.9; }
.scrim{ display:none; position:fixed; inset:0; background:rgba(42,40,35,.4); backdrop-filter:blur(2px); z-index:65; opacity:0; transition:opacity .4s; }
body.nav-open .scrim{ display:block; opacity:1; }

/* ---------- Hero ---------- */
.hero{ position:relative; padding:clamp(3rem,7vw,6rem) 0 clamp(4rem,8vw,7rem); overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:-2; background:
    radial-gradient(120% 90% at 85% 8%, var(--rose-tint) 0%, transparent 45%),
    radial-gradient(90% 80% at 8% 100%, var(--sage-tint) 0%, transparent 55%),
    linear-gradient(180deg,var(--ivory-2),var(--ivory)); }
.hero__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.hero__title{ margin:.4rem 0 1.4rem; }
.hero__title em{ font-style:italic; color:var(--rose); }
.hero__actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.2rem; }
.hero__chips{ display:flex; flex-wrap:wrap; gap:.6rem 1.4rem; margin-top:2.6rem; padding-top:1.8rem; border-top:1px solid var(--line); }
.hero__chip{ display:inline-flex; align-items:center; gap:.55rem; font-size:.86rem; font-weight:500; color:var(--ink); }
.hero__chip svg{ width:1.05em; color:var(--sage); flex:none; }

/* Hero visual card */
.hero__visual{ position:relative; }
.hero__card{
  position:relative; border-radius:24px; overflow:hidden; aspect-ratio:4/5;
  background:linear-gradient(160deg,var(--sage) 0%,var(--sage-deep) 100%);
  box-shadow:var(--shadow-lg); isolation:isolate;
}
.hero__card::after{ content:""; position:absolute; inset:0; background:radial-gradient(80% 60% at 70% 20%, rgba(191,162,105,.25), transparent 60%); }
.hero__botanical{ position:absolute; inset:0; width:100%; height:100%; opacity:.9; }
.hero__cardtext{ position:absolute; left:0; right:0; bottom:0; padding:2rem; color:#fff; z-index:2; }
.hero__cardtext .kicker{ font-family:var(--sans); font-size:.72rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-soft); }
.hero__cardtext .q{ font-family:var(--serif); font-size:1.6rem; line-height:1.3; margin-top:.6rem; font-weight:500; }
.hero__badge{
  position:absolute; top:1.4rem; left:1.4rem; z-index:2;
  display:inline-flex; align-items:center; gap:.5rem; background:rgba(255,255,255,.92);
  padding:.55rem .95rem; border-radius:100px; font-size:.78rem; font-weight:600; color:var(--sage-deep);
  box-shadow:var(--shadow-sm);
}
.hero__badge svg{ width:1em; color:var(--gold); }
.hero__float{
  position:absolute; right:-14px; top:38%; z-index:3; background:var(--paper);
  border-radius:16px; padding:1rem 1.1rem; box-shadow:var(--shadow-md);
  display:flex; align-items:center; gap:.8rem; max-width:220px;
}
.hero__float .n{ font-family:var(--serif); font-size:2rem; color:var(--sage); line-height:1; }
.hero__float small{ display:block; font-size:.76rem; color:var(--muted); line-height:1.4; }
@media (max-width:900px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero__visual{ max-width:440px; margin-inline:auto; width:100%; }
  .hero__float{ right:0; }
}

/* ---------- Marquee / trust strip ---------- */
.trust-strip{ background:var(--sage-deep); color:#e9e4d8; padding:1.1rem 0; overflow:hidden; }
.trust-strip__track{ display:flex; gap:3.5rem; align-items:center; white-space:nowrap; animation:marquee 34s linear infinite; }
.trust-strip:hover .trust-strip__track{ animation-play-state:paused; }
.trust-strip__item{ display:inline-flex; align-items:center; gap:.7rem; font-family:var(--serif); font-size:1.15rem; font-style:italic; color:#efe9dd; }
.trust-strip__item svg{ width:1.1em; color:var(--gold-soft); }
@keyframes marquee{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .trust-strip__track{ animation:none; } }

/* ---------- Pillars ---------- */
.pillars{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.pillar{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:2rem 1.6rem; transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s;
}
.pillar:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.pillar__ic{ width:52px; height:52px; border-radius:14px; display:grid; place-items:center; background:var(--sage-tint); color:var(--sage); margin-bottom:1.1rem; }
.pillar__ic svg{ width:26px; height:26px; }
.pillar h3{ font-size:1.32rem; margin-bottom:.4rem; }
.pillar p{ font-size:.94rem; color:var(--muted); line-height:1.65; }
@media (max-width:900px){ .pillars{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:540px){ .pillars{ grid-template-columns:1fr; } }

/* ---------- Split (Praxis) ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.split.reverse .split__media{ order:2; }
.split__media{ position:relative; }
.figure-card{
  position:relative; border-radius:22px; overflow:hidden; aspect-ratio:5/6;
  box-shadow:var(--shadow-lg); background:linear-gradient(155deg,#eef1ec,#e5e0d4);
}
.figure-card svg{ position:absolute; inset:0; width:100%; height:100%; }
.figure-tag{
  position:absolute; bottom:1.2rem; left:1.2rem; right:1.2rem; z-index:2;
  background:rgba(255,255,255,.9); backdrop-filter:blur(6px); border-radius:14px; padding:1rem 1.2rem;
  display:flex; align-items:center; gap:.9rem; box-shadow:var(--shadow-sm);
}
.figure-tag .sig{ font-family:var(--serif); font-size:1.5rem; font-style:italic; color:var(--sage); }
.figure-tag small{ font-size:.78rem; color:var(--muted); }
.stat-strip{ display:flex; gap:2rem; margin-top:2rem; padding-top:1.6rem; border-top:1px solid var(--line); }
.stat b{ display:block; font-family:var(--serif); font-size:2.3rem; color:var(--sage); line-height:1; }
.stat span{ font-size:.84rem; color:var(--muted); }
@media (max-width:820px){ .split{ grid-template-columns:1fr; } .split.reverse .split__media{ order:0; } }

.rich > * + *{ margin-top:1.2rem; }
.rich h2{ margin-bottom:.4rem; }
.checklist{ display:grid; gap:.75rem; margin-top:1.6rem; }
.checklist li{ display:flex; gap:.75rem; align-items:flex-start; font-size:.98rem; }
.checklist svg{ width:1.35em; height:1.35em; flex:none; color:var(--sage); margin-top:.15rem; }

/* ---------- Treatment cards ---------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.tcard{
  position:relative; background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:2rem; overflow:hidden; transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.tcard::before{ content:""; position:absolute; inset:0 0 auto 0; height:3px; background:linear-gradient(90deg,var(--rose),var(--gold)); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.tcard:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); }
.tcard:hover::before{ transform:scaleX(1); }
.tcard__ic{ width:56px; height:56px; border-radius:16px; display:grid; place-items:center; background:var(--rose-tint); color:var(--rose); margin-bottom:1.3rem; }
.tcard__ic svg{ width:28px; height:28px; }
.tcard h3{ font-size:1.5rem; margin-bottom:.6rem; }
.tcard p{ font-size:.95rem; color:var(--muted); line-height:1.65; }
.tcard ul{ margin-top:1.1rem; display:grid; gap:.5rem; }
.tcard ul li{ font-size:.9rem; color:var(--ink); display:flex; gap:.55rem; align-items:center; }
.tcard ul li::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--gold); flex:none; }
.tcard__more{ margin-top:1.4rem; }
@media (max-width:900px){ .cards{ grid-template-columns:1fr 1fr; } }
@media (max-width:620px){ .cards{ grid-template-columns:1fr; } }

/* ---------- Dark medical section ---------- */
.band-dark{ background:var(--sage-deep); color:#eef0ea; position:relative; overflow:hidden; }
.band-dark::before{ content:""; position:absolute; inset:0; background:radial-gradient(70% 90% at 90% 10%, rgba(191,162,105,.14), transparent 55%); }
.band-dark h2{ color:#fff; }
.band-dark .muted{ color:#c3c9bf; }
.band-dark .split__media .figure-card{ background:linear-gradient(155deg,#46584d,#33413a); }
.feature-list{ display:grid; gap:1.3rem; margin-top:1.8rem; }
.feature-list li{ display:flex; gap:1rem; align-items:flex-start; }
.feature-list .fi{ width:44px; height:44px; border-radius:12px; flex:none; display:grid; place-items:center; background:rgba(255,255,255,.08); color:var(--gold-soft); }
.feature-list .fi svg{ width:22px; height:22px; }
.feature-list h4{ font-family:var(--sans); font-size:1.02rem; font-weight:600; color:#fff; margin-bottom:.2rem; }
.feature-list p{ font-size:.92rem; color:#c3c9bf; line-height:1.6; }

/* ---------- Treatment menu (behandlungen page) ---------- */
.menu-block{ margin-top:clamp(2.5rem,5vw,4rem); }
.menu-block__head{ display:flex; align-items:flex-start; gap:1.2rem; margin-bottom:1.8rem; padding-bottom:1.4rem; border-bottom:1px solid var(--line); }
.menu-block__ic{ width:58px; height:58px; border-radius:16px; flex:none; display:grid; place-items:center; background:var(--sage-tint); color:var(--sage); }
.menu-block__ic svg{ width:30px; height:30px; }
.menu-block__head h2{ font-size:clamp(1.7rem,1.3rem+1.4vw,2.3rem); }
.menu-block__head p{ color:var(--muted); font-size:.98rem; margin-top:.35rem; }
.menu-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1rem 2.5rem; }
.menu-item{ padding:1.1rem 0; border-bottom:1px dashed var(--line); }
.menu-item:last-child{ border-bottom:none; }
.menu-item__row{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem; }
.menu-item__name{ font-family:var(--serif); font-size:1.32rem; font-weight:600; color:var(--ink); }
.menu-item__price{ font-family:var(--sans); font-size:.82rem; font-weight:600; color:var(--rose); letter-spacing:.02em; white-space:nowrap; }
.menu-item__desc{ font-size:.92rem; color:var(--muted); margin-top:.3rem; line-height:1.6; }
@media (max-width:720px){ .menu-grid{ grid-template-columns:1fr; gap:0; } }

/* ---------- Page hero (sub pages) ---------- */
.page-hero{ position:relative; padding:clamp(3rem,6vw,5.5rem) 0 clamp(3rem,6vw,5rem); overflow:hidden; }
.page-hero__bg{ position:absolute; inset:0; z-index:-1; background:
    radial-gradient(90% 120% at 90% 0%, var(--rose-tint), transparent 50%),
    linear-gradient(180deg,var(--ivory-2),var(--ivory)); }
.page-hero__inner{ max-width:760px; }
.breadcrumb{ display:flex; gap:.5rem; align-items:center; font-size:.82rem; color:var(--muted); margin-bottom:1.4rem; }
.breadcrumb a:hover{ color:var(--sage); }
.breadcrumb svg{ width:.9em; opacity:.6; }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
@media (max-width:900px){ .contact-grid{ grid-template-columns:1fr; } }
.info-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.8rem,3vw,2.6rem); box-shadow:var(--shadow-sm); }
.info-list{ display:grid; gap:1.4rem; }
.info-row{ display:flex; gap:1.1rem; align-items:flex-start; }
.info-row__ic{ width:48px; height:48px; border-radius:13px; flex:none; display:grid; place-items:center; background:var(--sage-tint); color:var(--sage); }
.info-row__ic svg{ width:23px; height:23px; }
.info-row__label{ font-size:.74rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:.2rem; }
.info-row__val{ font-family:var(--serif); font-size:1.35rem; color:var(--ink); line-height:1.3; }
.info-row__val a:hover{ color:var(--sage); }
.info-row small{ font-size:.9rem; color:var(--muted); }
.hours-card{ margin-top:1.4rem; background:var(--sage-deep); color:#eef0ea; border-radius:var(--radius); padding:clamp(1.6rem,3vw,2.2rem); }
.hours-card h3{ color:#fff; font-size:1.4rem; margin-bottom:.4rem; }
.hours-card p{ color:#c3c9bf; font-size:.94rem; }
.hours-note{ display:flex; gap:.7rem; align-items:center; margin-top:1.2rem; padding-top:1.2rem; border-top:1px solid rgba(255,255,255,.12); font-size:.92rem; }
.hours-note svg{ width:1.2em; color:var(--gold-soft); flex:none; }

/* Form */
.form{ display:grid; gap:1.1rem; }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
@media (max-width:560px){ .form__row{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:.4rem; }
.field label{ font-size:.82rem; font-weight:600; color:var(--ink); }
.field input,.field textarea,.field select{
  font:inherit; font-size:.95rem; padding:.85rem 1rem; border-radius:12px;
  border:1px solid var(--line); background:var(--ivory-2); color:var(--ink);
  transition:border-color .3s, box-shadow .3s, background .3s;
}
.field textarea{ min-height:140px; resize:vertical; }
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none; border-color:var(--sage); background:#fff; box-shadow:0 0 0 4px rgba(62,81,71,.1);
}
.consent{ display:flex; gap:.7rem; align-items:flex-start; font-size:.86rem; color:var(--muted); }
.consent input{ margin-top:.2rem; width:1.1rem; height:1.1rem; accent-color:var(--sage); flex:none; }
.consent a{ color:var(--sage); text-decoration:underline; text-underline-offset:2px; }
.form__note{ font-size:.82rem; color:var(--muted); }
.form-success{ display:none; padding:1rem 1.2rem; border-radius:12px; background:var(--sage-tint); color:var(--sage-deep); font-size:.92rem; font-weight:500; }
.form-success.show{ display:block; }

/* Map */
.map-wrap{ margin-top:clamp(3rem,6vw,4.5rem); border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-md); }
.map-wrap iframe{ width:100%; height:420px; border:0; display:block; filter:grayscale(.15) contrast(1.02); }

/* ---------- CTA band ---------- */
.cta{ position:relative; overflow:hidden; background:linear-gradient(150deg,var(--sage) 0%,var(--sage-700) 100%); color:#fff; border-radius:clamp(20px,3vw,32px); padding:clamp(3rem,6vw,5rem) clamp(1.6rem,5vw,4.5rem); text-align:center; }
.cta::before{ content:""; position:absolute; inset:0; background:radial-gradient(60% 90% at 15% 0%, rgba(191,162,105,.2), transparent 55%), radial-gradient(50% 80% at 90% 100%, rgba(176,107,119,.24), transparent 55%); }
.cta > *{ position:relative; }
.cta h2{ color:#fff; font-size:clamp(2rem,1.4rem+2.4vw,3rem); font-weight:500; }
.cta p{ color:#d8ddd4; max-width:52ch; margin:1rem auto 0; }
.cta__actions{ display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; margin-top:2.2rem; }

/* ---------- Footer ---------- */
.footer{ background:var(--sage-700); color:#cdd2c8; padding:clamp(3.5rem,6vw,5rem) 0 2rem; }
.footer__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2.5rem; }
.footer__brand .brand__name{ color:#fff; }
.footer__brand .brand__name b{ color:var(--rose-soft); }
.footer__brand .brand__sub{ color:#a7ad9f; }
.footer p{ font-size:.92rem; line-height:1.8; color:#b7bcb0; margin-top:1rem; }
.footer h4{ font-family:var(--sans); font-size:.78rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:#fff; margin-bottom:1.1rem; }
.footer a{ color:#c3c8bd; }
.footer li{ margin-bottom:.6rem; font-size:.94rem; }
.footer li a:hover{ color:#fff; }
.footer__contact li{ display:flex; gap:.6rem; align-items:flex-start; }
.footer__contact svg{ width:1.05em; margin-top:.28rem; color:var(--gold-soft); flex:none; }
.footer__bottom{ margin-top:3rem; padding-top:1.6rem; border-top:1px solid rgba(255,255,255,.1); display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; font-size:.84rem; color:#9ba192; }
.footer__bottom a:hover{ color:#fff; }
@media (max-width:820px){ .footer__grid{ grid-template-columns:1fr 1fr; gap:2rem; } }
@media (max-width:520px){ .footer__grid{ grid-template-columns:1fr; } }

/* ---------- Legal pages ---------- */
.legal{ max-width:820px; }
.legal h2{ font-size:1.7rem; margin:2.4rem 0 .8rem; padding-top:1.4rem; border-top:1px solid var(--line); }
.legal h2:first-of-type{ border-top:none; padding-top:0; }
.legal h3{ font-family:var(--sans); font-size:1.05rem; font-weight:600; margin:1.6rem 0 .5rem; }
.legal p, .legal li{ color:var(--muted); font-size:.96rem; line-height:1.8; }
.legal p{ margin-top:.7rem; }
.legal ul{ list-style:disc; padding-left:1.3rem; margin-top:.7rem; }
.legal li{ margin-bottom:.4rem; }
.legal a{ color:var(--sage); text-decoration:underline; text-underline-offset:2px; word-break:break-word; }
.legal strong{ color:var(--ink); }
.legal .lead{ margin-bottom:1rem; }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s 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){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ---------- Misc ---------- */
.divider-orn{ display:flex; align-items:center; justify-content:center; gap:1rem; color:var(--gold); margin:0 auto; }
.divider-orn::before,.divider-orn::after{ content:""; height:1px; width:60px; background:var(--gold-soft); }
.divider-orn svg{ width:22px; }
.skip{ position:absolute; left:-999px; top:0; background:var(--sage); color:#fff; padding:.7rem 1rem; z-index:100; border-radius:0 0 8px 0; }
.skip:focus{ left:0; }
