:root{
  --bg:#f6f1e7;
  --bg-alt:#efe7d6;
  --paper:#fbf7ee;
  --ink:#2a231a;
  --ink-soft:#5b4f3e;
  --muted:#8a7c66;
  --line:#d9cdb3;
  --accent:#a8432a;
  --accent-ink:#fbf7ee;
  --warm:#e9c07a;
  --shadow: 0 1px 2px rgba(42,35,26,.06), 0 8px 24px rgba(42,35,26,.08);
  --radius:10px;
  --radius-sm:6px;
  --max:1120px;
  --font: ui-serif, Georgia, "Times New Roman", "Palatino Linotype", serif;
  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{animation:none!important;transition:none!important}
}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--ink);
  background:
    radial-gradient(1200px 500px at 10% -10%, rgba(233,192,122,.25), transparent 60%),
    radial-gradient(900px 400px at 100% 0%, rgba(168,67,42,.08), transparent 60%),
    var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  background-image:
    repeating-radial-gradient(circle at 20% 30%, rgba(90,70,40,.04) 0 1px, transparent 1px 3px),
    repeating-radial-gradient(circle at 70% 60%, rgba(90,70,40,.03) 0 1px, transparent 1px 4px);
  mix-blend-mode:multiply;
  z-index:0;
}
main,header,footer{position:relative;z-index:1}

/* Entrance animations (triggered by body.is-loaded) */
body.is-loading main > *:first-child{opacity:0}

body.is-loaded main > section:first-child .eyebrow{animation:fadeUp .7s cubic-bezier(.2,.7,.3,1) .15s both}
body.is-loaded main > section:first-child h1{animation:fadeUp .8s cubic-bezier(.2,.7,.3,1) .25s both}
body.is-loaded main > section:first-child .lede{animation:fadeUp .7s cubic-bezier(.2,.7,.3,1) .38s both}
body.is-loaded main > section:first-child .hero-ctas,
body.is-loaded main > section:first-child .hero-actions{animation:fadeUp .7s cubic-bezier(.2,.7,.3,1) .5s both}
body.is-loaded main > section:first-child .hero-media{animation:heroIn 1s cubic-bezier(.2,.7,.3,1) .35s both, heroFloat 7s ease-in-out 1.3s infinite}
body.is-loaded main > section:first-child .info-grid > *{animation:fadeUp .7s cubic-bezier(.2,.7,.3,1) both}
body.is-loaded main > section:first-child .info-grid > *:nth-child(1){animation-delay:.55s}
body.is-loaded main > section:first-child .info-grid > *:nth-child(2){animation-delay:.65s}
body.is-loaded main > section:first-child .info-grid > *:nth-child(3){animation-delay:.75s}
body.is-loaded main > section:first-child .info-grid > *:nth-child(4){animation-delay:.85s}
body.is-loaded .sitemap-grid > *{animation:fadeUp .8s cubic-bezier(.2,.7,.3,1) both}
body.is-loaded .sitemap-grid > *:nth-child(1){animation-delay:.55s}
body.is-loaded .sitemap-grid > *:nth-child(2){animation-delay:.7s}
body.is-loaded .sitemap-grid > *:nth-child(3){animation-delay:.85s}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(22px)}
  to{opacity:1;transform:none}
}
@keyframes heroIn{
  from{opacity:0;transform:translateY(24px) scale(.94) rotate(-1deg)}
  to{opacity:1;transform:none}
}

@media (prefers-reduced-motion: reduce){
  body.is-loading *{opacity:1!important}
  body.is-loaded *{animation:none!important}
}

/* Scroll progress bar */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:3px;
  background:transparent;z-index:30;pointer-events:none;
}
.scroll-progress-bar{
  height:100%;width:0;
  background:linear-gradient(90deg, var(--accent), var(--warm));
  transition:width .12s linear;
  box-shadow:0 0 10px rgba(168,67,42,.4);
}

/* Reveal on scroll */
.reveal{
  opacity:0;transform:translate3d(0,22px,0);
  transition:opacity .55s cubic-bezier(.22,.7,.3,1), transform .55s cubic-bezier(.22,.7,.3,1);
  will-change:opacity, transform;
  backface-visibility:hidden;
}
.reveal.is-visible{opacity:1;transform:translate3d(0,0,0)}

.stagger.is-visible > *.reveal:nth-child(1){transition-delay:.03s}
.stagger.is-visible > *.reveal:nth-child(2){transition-delay:.09s}
.stagger.is-visible > *.reveal:nth-child(3){transition-delay:.15s}
.stagger.is-visible > *.reveal:nth-child(4){transition-delay:.21s}
.stagger.is-visible > *.reveal:nth-child(5){transition-delay:.27s}
.stagger.is-visible > *.reveal:nth-child(6){transition-delay:.33s}

@media (prefers-reduced-motion: reduce){
  .reveal,.reveal-left,.reveal-right,.reveal-scale,.stagger > *{
    opacity:1!important;transform:none!important;
  }
  .scroll-progress-bar{display:none}
}
img{max-width:100%;display:block;height:auto}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:none}

/* Content link hover — soft color shift + animated brush underline */
main :where(p, li, summary) a:not(.btn){
  position:relative;
  color:var(--accent);
  background-image:linear-gradient(currentColor, currentColor);
  background-repeat:no-repeat;
  background-position:0 100%;
  background-size:0 1.5px;
  padding-bottom:1px;
  transition:background-size .4s ease, color .25s ease;
}
main :where(p, li, summary) a:not(.btn):hover{
  color:#8c3621;
  background-size:100% 1.5px;
}
.site-footer a,.footer-grid a{
  position:relative;
  transition:color .25s ease, transform .25s ease;
  display:inline-block;
}
.site-footer a:hover{color:var(--accent);transform:translateX(3px)}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:3px;
  border-radius:4px;
}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:.6rem 1rem;z-index:100}
.skip-link:focus{left:1rem;top:1rem}

.wrap{max-width:var(--max);margin:0 auto;padding:0 1.25rem}
.wrap.narrow{max-width:760px}

h1,h2,h3{font-family:var(--font);font-weight:600;line-height:1.2;color:var(--ink);letter-spacing:-.01em}
h1{font-size:clamp(2rem,4.5vw,3rem);margin:.2rem 0 1rem}
h2{
  font-size:clamp(1.5rem,2.6vw,2rem);margin:2rem 0 1rem;
  position:relative;display:inline-block;padding-left:0;
}
.section > .wrap > h2::before,
.section > .wrap .section > h2::before{
  content:"";display:inline-block;width:32px;height:3px;
  background:linear-gradient(90deg, var(--accent), var(--warm));
  vertical-align:middle;margin-right:.8rem;border-radius:3px;
  transform-origin:left center;transform:scaleX(0);
  transition:transform .7s cubic-bezier(.2,.7,.3,1) .15s;
}
.section.is-visible > .wrap > h2::before{transform:scaleX(1)}
h3{font-size:1.15rem;margin:1rem 0 .5rem}
p{margin:.6rem 0}
.lede{font-size:1.12rem;color:var(--ink-soft);max-width:62ch}
.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;color:var(--accent);margin:0 0 .5rem}
.muted{color:var(--muted)}
.section{padding:3.5rem 0}
.section-alt{background:linear-gradient(180deg,var(--bg-alt),transparent);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section-lede{max-width:70ch;color:var(--ink-soft)}

/* header */
.site-header{
  background:var(--paper);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:20;
  backdrop-filter:saturate(1.1);
}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1.25rem;position:relative}
.brand{display:inline-flex;align-items:center;gap:.6rem;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand-mark{
  display:inline-grid;place-items:center;
  width:34px;height:34px;
  border:1px solid var(--ink);
  border-radius:50%;
  font-family:var(--font);font-weight:700;font-size:.85rem;
  background:var(--paper);
  transition:transform .45s ease, background .35s ease, color .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.brand-name{
  font-family:var(--font);font-size:1.05rem;letter-spacing:.02em;
  position:relative;
  transition:color .3s ease, letter-spacing .3s ease;
}
.brand-name::after{
  content:"";
  position:absolute;left:0;right:0;bottom:-3px;
  height:1px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .35s ease;
}
.brand:hover .brand-mark{
  transform:rotate(-12deg) scale(1.06);
  background:var(--accent);
  color:var(--accent-ink);
  border-color:var(--accent);
  box-shadow:0 6px 18px rgba(168,67,42,.28);
}
.brand:hover .brand-name{color:var(--accent);letter-spacing:.04em}
.brand:hover .brand-name::after{transform:scaleX(1)}
.brand:focus-visible .brand-mark{
  background:var(--accent);color:var(--accent-ink);border-color:var(--accent);
}

.nav{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}
.nav a{
  position:relative;
  color:var(--ink);
  padding:.55rem .95rem;
  font-size:.96rem;
  border-radius:999px;
  transition:color .25s ease, background-color .3s ease;
}
.nav a:hover{color:var(--accent);background:rgba(168,67,42,.09)}
.nav a[aria-current]{color:var(--accent);background:rgba(168,67,42,.14)}

.nav-toggle{
  display:none;background:transparent;border:1px solid var(--ink);border-radius:var(--radius-sm);
  width:42px;height:42px;padding:0;cursor:pointer;position:relative;
}
.nav-toggle-icon, .nav-toggle-icon::before, .nav-toggle-icon::after{
  content:"";position:absolute;left:50%;top:50%;width:22px;height:2px;background:var(--ink);
  transform:translate(-50%,-50%);transition:transform .25s ease, opacity .2s ease, top .25s ease;
}
.nav-toggle-icon::before{top:-7px;left:0;transform:none}
.nav-toggle-icon::after{top:7px;left:0;transform:none}
.nav-toggle[aria-expanded="true"] .nav-toggle-icon{background:transparent}
.nav-toggle[aria-expanded="true"] .nav-toggle-icon::before{top:0;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle-icon::after{top:0;transform:rotate(-45deg)}

@media (max-width:860px){
  .nav-toggle{display:inline-block}
  .nav{
    position:absolute;left:0;right:0;top:100%;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--paper);
    padding:0 1.25rem;
    max-height:0;
    overflow:hidden;
    border-bottom:0 solid var(--line);
    transition:max-height .35s ease, padding .35s ease, border-bottom-width .35s ease;
    transition-delay:0s;
  }
  .nav.is-open{
    max-height:560px;
    padding:.5rem 1.25rem 1rem;
    border-bottom-width:1px;
  }
  .nav a{padding:.85rem 1rem;border-radius:var(--radius-sm)}
}

/* hero */
.hero{padding:3.5rem 0 2.5rem}
.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:2.5rem;align-items:center}
@media (max-width:780px){.hero-grid{grid-template-columns:1fr}}
.hero-copy{max-width:62ch}
.hero-ctas{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.25rem}
.btn{
  display:inline-block;padding:.8rem 1.4rem;border-radius:var(--radius-sm);
  font-weight:600;font-size:.98rem;cursor:pointer;border:1px solid transparent;
  position:relative;overflow:hidden;isolation:isolate;
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .3s ease;
}
.btn::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg, transparent 30%, rgba(255,255,255,.35) 50%, transparent 70%);
  transform:translateX(-120%);
  transition:transform .7s ease;
  z-index:-1;
}
.btn:hover{text-decoration:none;transform:translateY(-2px);box-shadow:0 10px 24px rgba(42,35,26,.18)}
.btn:hover::before{transform:translateX(120%)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.btn-primary:hover{background:#8c3621;box-shadow:0 10px 26px rgba(168,67,42,.35)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

.hero-media{
  border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;background:var(--paper);
  aspect-ratio:4/5;
  position:relative;
  transform-style:preserve-3d;
  perspective:900px;
  box-shadow:0 2px 4px rgba(42,35,26,.08), 0 30px 60px -20px rgba(42,35,26,.25);
  animation:heroFloat 7s ease-in-out infinite;
}
.hero-media::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg, rgba(255,255,255,.2), transparent 40%);
  mix-blend-mode:overlay;
}
.hero-media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;
}
.hero-media:hover img{transform:scale(1.05)}
@keyframes heroFloat{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-10px) rotate(.4deg)}
}
@media (prefers-reduced-motion: reduce){
  .hero-media{animation:none}
}

/* content images inline with text */
.media-card{
  width:100%;max-width:320px;
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  background:var(--paper);box-shadow:var(--shadow);margin:0 0 .9rem;
  position:relative;
}
.media-card img{
  width:100%;aspect-ratio:4/3;object-fit:cover;
  transition:transform .7s cubic-bezier(.2,.7,.3,1), filter .5s ease;
}
.media-card::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, transparent 55%, rgba(42,35,26,.3));
  opacity:0;transition:opacity .4s ease;
}
.card:hover .media-card img,
.media-inline:hover .media-card img{transform:scale(1.07)}
.card:hover .media-card::after,
.media-inline:hover .media-card::after{opacity:1}
.media-inline{
  display:grid;grid-template-columns:280px 1fr;gap:1.5rem;align-items:center;margin:1.5rem 0;
}
.media-inline .media-card{max-width:none;margin:0}
@media (max-width:720px){.media-inline{grid-template-columns:1fr}}

/* cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:1.25rem}
@media (max-width:860px){.cards{grid-template-columns:1fr}}
.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.25rem 1.25rem 1.1rem;
  box-shadow:var(--shadow);
  transition:transform .4s cubic-bezier(.2,.7,.3,1), box-shadow .4s ease, border-color .3s ease;
  position:relative;overflow:hidden;
}
.card::before{
  content:"";position:absolute;left:0;top:0;width:100%;height:3px;
  background:linear-gradient(90deg, var(--accent), var(--warm));
  transform:scaleX(0);transform-origin:left center;
  transition:transform .5s cubic-bezier(.2,.7,.3,1);
}
.card:hover{
  transform:translateY(-6px);
  box-shadow:0 2px 4px rgba(42,35,26,.08), 0 24px 48px rgba(42,35,26,.18);
  border-color:#c8b98e;
}
.card:hover::before{transform:scaleX(1)}
.card .media-card{max-width:none;margin:0 0 .9rem}
.card .media-card img{aspect-ratio:4/3}

/* steps */
.steps{list-style:none;padding:0;margin:1.25rem 0;counter-reset:s;display:grid;gap:.9rem}
.steps li{
  counter-increment:s;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.1rem 1.25rem 1.1rem 3.3rem;
  position:relative;
  box-shadow:var(--shadow);
}
.steps li{transition:transform .35s ease, box-shadow .35s ease}
.steps li:hover{transform:translateX(6px);box-shadow:0 2px 4px rgba(42,35,26,.08), 0 16px 32px rgba(42,35,26,.14)}
.steps li::before{
  content:counter(s);
  position:absolute;left:1rem;top:1.1rem;
  width:1.8rem;height:1.8rem;
  display:grid;place-items:center;
  border-radius:50%;
  background:var(--accent);color:var(--accent-ink);
  font-family:var(--font);font-weight:700;
  transition:transform .4s cubic-bezier(.5,1.6,.4,1), background .3s ease;
  box-shadow:0 4px 12px rgba(168,67,42,.35);
}
.steps li:hover::before{transform:rotate(360deg) scale(1.1)}
.steps h3{margin-top:0}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
@media (max-width:780px){.grid-2{grid-template-columns:1fr}}
.plain-list{padding-left:1.1rem;margin:.6rem 0;color:var(--ink-soft)}
.plain-list li{margin:.35rem 0}

/* package picker */
.package-picker{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  margin-top:1rem;
}
.picker-tabs{display:flex;border-bottom:1px solid var(--line);flex-wrap:wrap}
.picker-tab{
  flex:1;min-width:160px;
  background:transparent;border:0;border-bottom:2px solid transparent;
  padding:1rem;font:inherit;color:var(--ink-soft);cursor:pointer;
  transition:color .2s ease, border-color .2s ease, background .2s ease;
}
.picker-tab:hover{background:rgba(168,67,42,.06);color:var(--ink)}
.picker-tab.is-active{color:var(--accent);border-bottom-color:var(--accent);background:rgba(233,192,122,.2)}
.picker-panels{padding:1.5rem}
.picker-panel{animation:fade .25s ease}
.picker-panel[hidden]{display:none}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.price-line{
  display:flex;align-items:baseline;justify-content:space-between;
  padding:1rem 0 .2rem;border-top:1px dashed var(--line);margin-top:1rem;gap:1rem;
}
.price-line strong{font-size:1.2rem;color:var(--ink);font-family:var(--font)}
.price-line span{color:var(--muted)}

/* price grid */
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1rem}
@media (max-width:960px){.price-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.price-grid{grid-template-columns:1fr}}
.price-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem;box-shadow:var(--shadow)}
.price-card h3{margin-top:0}
.price-range{font-family:var(--font);font-size:1.3rem;color:var(--accent);margin:.2rem 0 .6rem}
.disclaimer{margin-top:1rem;color:var(--muted);font-size:.92rem;font-style:italic}

/* FAQ */
.faq{display:grid;gap:.7rem;margin-top:1rem}
.faq details{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:.9rem 1.1rem;
  box-shadow:var(--shadow);
}
.faq summary{
  cursor:pointer;font-weight:600;color:var(--ink);
  list-style:none;display:flex;justify-content:space-between;gap:1rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";color:var(--accent);font-size:1.4rem;line-height:1;
  transition:transform .3s ease;transform-origin:center;transition-delay:0s;
}
.faq details.is-open summary::after{transform:rotate(45deg)}
.faq-body{
  overflow:hidden;
  max-height:0;
  transition:max-height .35s ease;
  transition-delay:0s;
}
.faq-body-inner{padding-top:.6rem}
.faq-body p{margin:0;color:var(--ink-soft)}

/* CTA */
.cta-section{background:linear-gradient(180deg,rgba(168,67,42,.06),transparent)}
.cta-wrap{text-align:center}
.cta-wrap h2{margin-top:0}

/* Contact page */
.contact-hero{
  padding:4rem 0 2rem;
  background:
    radial-gradient(800px 300px at 85% 10%, rgba(233,192,122,.35), transparent 60%),
    radial-gradient(600px 260px at 10% 90%, rgba(168,67,42,.08), transparent 70%);
  border-bottom:1px solid var(--line);
}
.contact-hero .eyebrow{margin-bottom:.6rem}
.contact-hero h1{max-width:16ch}
.contact-hero .lede{max-width:58ch}
.contact-hero .hero-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.25rem}

.info-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
  margin-top:2rem;
}
@media (max-width:960px){.info-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.info-grid{grid-template-columns:1fr}}
.info-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.1rem 1.2rem 1.2rem;
  box-shadow:var(--shadow);
  position:relative;
  transition:transform .2s ease, box-shadow .25s ease;
}
.info-card:hover{transform:translateY(-2px);box-shadow:0 2px 4px rgba(42,35,26,.08), 0 14px 34px rgba(42,35,26,.12)}
.info-card::before{
  content:"";
  position:absolute;left:1.2rem;top:0;
  width:28px;height:3px;
  background:var(--accent);
  border-radius:0 0 3px 3px;
}
.info-card .info-label{
  display:block;text-transform:uppercase;letter-spacing:.14em;
  font-size:.72rem;color:var(--muted);margin:.6rem 0 .3rem;
}
.info-card .info-value{
  font-family:var(--font);font-size:1.08rem;color:var(--ink);
  word-break:break-word;
}
.info-card a.info-value{color:var(--ink)}
.info-card a.info-value:hover{color:var(--accent);text-decoration:none}

.notes-card{
  margin-top:2rem;
  background:var(--paper);
  border:1px solid var(--line);
  border-left:3px solid var(--accent);
  border-radius:var(--radius);
  padding:1.25rem 1.5rem;
  box-shadow:var(--shadow);
}
.notes-card h2{margin-top:0}

/* Form — stand-alone block */
.form-section{padding:3.5rem 0 4rem}
.form-wrap{max-width:760px;margin:0 auto}
.form-head{text-align:center;margin-bottom:1.5rem}
.form-head h2{margin-top:0}
.form-head .section-lede{margin:.4rem auto 0}
.form{
  display:grid;gap:1.1rem;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:2rem;
  box-shadow:0 1px 2px rgba(42,35,26,.06), 0 18px 44px rgba(42,35,26,.1);
  position:relative;
}
.form::before{
  content:"";
  position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg, var(--accent), var(--warm));
  border-radius:var(--radius) var(--radius) 0 0;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media (max-width:620px){.form-row{grid-template-columns:1fr}}
.field{display:grid;gap:.4rem}
.field label{font-weight:600;color:var(--ink);font-size:.92rem}
.field input,.field textarea{
  font:inherit;color:var(--ink);
  background:#fffdf6;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:.85rem .95rem;
  width:100%;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.field input:hover,.field textarea:hover{border-color:#c2b493}
.field input:focus,.field textarea:focus{
  outline:none;
  border-color:var(--accent);
  background:#fff;
  box-shadow:0 0 0 3px rgba(168,67,42,.12);
}
.field textarea{resize:vertical;min-height:150px}
.field-check{display:flex;align-items:flex-start;gap:.6rem;padding:.5rem 0}
.field-check input[type="checkbox"]{
  width:18px;height:18px;margin-top:.2rem;
  accent-color:var(--accent);cursor:pointer;flex-shrink:0;
}
.field-check label{font-weight:400;color:var(--ink-soft);line-height:1.5}
.req{color:var(--accent);font-weight:700}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form .btn-primary{justify-self:start;padding:.95rem 2rem}
.form-response{min-height:1.2em;margin:0;color:var(--ink-soft);font-size:.95rem}
.form-response.is-success{color:#2f6b2a}
.form-response.is-error{color:var(--accent)}

/* Footer */
.site-footer{
  margin-top:3rem;
  background:var(--paper);
  border-top:1px solid var(--line);
  padding:2rem 0 1rem;
  position:relative;z-index:1;
}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:1.5rem;padding-bottom:1.5rem}
@media (max-width:780px){.footer-grid{grid-template-columns:1fr}}
.site-footer nav{display:flex;flex-direction:column;gap:.35rem}
.site-footer nav a{color:var(--ink)}
.copyright{border-top:1px solid var(--line);padding-top:1rem;color:var(--muted);text-align:center}

/* Sitemap page */
.sitemap-hero{
  padding:4rem 0 2rem;
  background:
    radial-gradient(900px 320px at 50% 10%, rgba(233,192,122,.3), transparent 60%),
    radial-gradient(600px 260px at 10% 90%, rgba(168,67,42,.08), transparent 70%);
  border-bottom:1px solid var(--line);
  text-align:center;
}
.sitemap-hero h1{margin:0 auto .6rem}
.sitemap-hero .lede{margin:0 auto;max-width:56ch}

.sitemap-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
  margin-top:2rem;
}
@media (max-width:900px){.sitemap-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.sitemap-grid{grid-template-columns:1fr}}
.sitemap-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.4rem 1.5rem 1.5rem;
  box-shadow:var(--shadow);
  position:relative;overflow:hidden;
  transition:transform .4s cubic-bezier(.2,.7,.3,1), box-shadow .4s ease, border-color .3s ease;
}
.sitemap-card::before{
  content:"";position:absolute;left:0;top:0;width:100%;height:3px;
  background:linear-gradient(90deg, var(--accent), var(--warm));
  transform:scaleX(0);transform-origin:left center;
  transition:transform .5s cubic-bezier(.2,.7,.3,1);
}
.sitemap-card:hover{
  transform:translateY(-5px);
  box-shadow:0 2px 4px rgba(42,35,26,.08), 0 22px 44px rgba(42,35,26,.16);
  border-color:#c8b98e;
}
.sitemap-card:hover::before{transform:scaleX(1)}
.sitemap-card .sitemap-kicker{
  display:inline-block;
  font-family:var(--font);font-style:italic;color:var(--muted);
  font-size:.82rem;margin-bottom:.25rem;
}
.sitemap-card h2{
  margin:0 0 1rem;font-size:1.25rem;
  padding-left:0;display:block;
}
.sitemap-card h2::before{display:none}
.sitemap-list{list-style:none;padding:0;margin:0;display:grid;gap:.15rem}
.sitemap-list li{margin:0}
.sitemap-list a{
  display:flex;align-items:center;
  padding:.55rem .75rem;border-radius:var(--radius-sm);
  color:var(--ink);background:transparent;line-height:1.4;
  transition:background .25s ease, color .25s ease;
}
.sitemap-list a::before{
  content:"";
  flex:0 0 auto;
  width:0;height:2px;
  background:var(--accent);
  border-radius:2px;
  margin-right:0;
  opacity:0;
  transition:width .3s ease, margin-right .3s ease, opacity .25s ease;
}
.sitemap-list a:hover{background:rgba(168,67,42,.07);color:var(--accent)}
.sitemap-list a:hover::before{width:.7em;margin-right:.4rem;opacity:1}

/* Cookie banner */
.cookie-banner{
  position:fixed;left:1rem;right:1rem;bottom:1rem;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:0 12px 40px rgba(42,35,26,.18);
  z-index:50;
  max-width:640px;
  margin-left:auto;
}
.cookie-banner[hidden]{display:none}
.cookie-inner{padding:1.1rem 1.2rem}
.cookie-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem}
.cookie-settings{display:grid;gap:.45rem;margin-top:.9rem;padding-top:.9rem;border-top:1px solid var(--line)}
.cookie-settings[hidden]{display:none}
.cookie-settings label{display:flex;align-items:center;gap:.5rem;color:var(--ink-soft)}
