/* =========================================================================
   La Bottega al Castello 2.0 — Montemiletto (AV)
   Design system: Araldica moderna — Bordeaux + Ottone + Pietra
   Display: Fraunces · Body: Manrope · Utility/dati: Spline Sans Mono
   Firma visiva: merlatura (battlement) del castello
   ========================================================================= */

:root{
  /* Colore */
  --wine:        #6B1A2B;
  --wine-deep:   #46101D;
  --wine-darkest:#2C0A12;
  --brass:       #C2A14D;
  --brass-soft:  #DCC489;
  --parchment:   #F3ECDD;
  --parchment-2: #EAE0CC;
  --ink:         #2A211D;
  --ink-soft:    #5E544B;
  --line:        #DBCDB2;
  --line-dark:   rgba(220,196,137,.22);
  --white:       #FBF8F1;

  /* Tipografia */
  --display: "Fraunces", Georgia, "Times New Roman", serif;
  --body:    "Manrope", system-ui, -apple-system, sans-serif;
  --mono:    "Spline Sans Mono", ui-monospace, "SFMono-Regular", monospace;

  /* Misura */
  --wrap: 1160px;
  --gut: clamp(20px, 5vw, 64px);
  --r: 4px;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  font-family:var(--body);
  font-weight:400;
  font-size:clamp(16px,1.05vw,17.5px);
  line-height:1.65;
  color:var(--ink);
  background:var(--parchment);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; font-family:var(--display); font-weight:430; line-height:1.04; letter-spacing:-.01em; }
p{ margin:0 0 1em; }
::selection{ background:var(--wine); color:var(--brass-soft); }

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(64px,9vw,128px); }
.section--tight{ padding-block:clamp(48px,6vw,80px); }
.center{ text-align:center; }

.eyebrow{
  font-family:var(--mono);
  font-size:.74rem;
  font-weight:500;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--wine);
  display:inline-flex;
  align-items:center;
  gap:.7em;
  margin:0 0 1.1rem;
}
.eyebrow::before{
  content:"";
  width:26px; height:1px;
  background:var(--brass);
  opacity:.85;
}
.eyebrow--center{ justify-content:center; }
.eyebrow--center::after{
  content:""; width:26px; height:1px; background:var(--brass); opacity:.85;
}
.on-dark .eyebrow{ color:var(--brass-soft); }

.h-display{ font-size:clamp(2.3rem,5.4vw,4.2rem); }
.h-1{ font-size:clamp(2rem,4.4vw,3.4rem); }
.h-2{ font-size:clamp(1.6rem,3vw,2.4rem); }
.h-3{ font-size:clamp(1.25rem,2vw,1.55rem); }
.lead{ font-size:clamp(1.08rem,1.5vw,1.32rem); color:var(--ink-soft); line-height:1.55; }
.muted{ color:var(--ink-soft); }
em.q{ font-style:italic; color:var(--wine); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:var(--mono); font-size:.82rem; font-weight:500;
  letter-spacing:.12em; text-transform:uppercase;
  padding:.95em 1.6em; border:1px solid transparent; border-radius:var(--r);
  transition:transform .35s var(--ease), background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease);
}
.btn svg{ width:1em; height:1em; }
.btn--primary{ background:var(--wine); color:var(--brass-soft); border-color:var(--wine); }
.btn--primary:hover{ background:var(--wine-deep); transform:translateY(-2px); }
.btn--ghost{ background:transparent; color:var(--wine); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--wine); transform:translateY(-2px); }
.on-dark .btn--ghost{ color:var(--brass-soft); border-color:var(--line-dark); }
.on-dark .btn--ghost:hover{ border-color:var(--brass); }
.on-dark .btn--primary{ background:var(--brass); color:var(--wine-darkest); border-color:var(--brass); }
.on-dark .btn--primary:hover{ background:var(--brass-soft); }

/* ---------- Crest (SVG) ---------- */
.crest{ display:block; color:var(--brass); }
.crest .crest-mono{ font-family:var(--display); font-weight:500; fill:currentColor; }
.crest .crest-word{ font-family:var(--mono); font-weight:500; fill:currentColor; letter-spacing:.18em; }

/* ---------- Signature: merlatura (battlement divider) ---------- */
.battlement{ display:block; width:100%; height:18px; color:var(--wine); }
.battlement svg{ display:block; width:100%; height:100%; }

/* =========================================================================
   Top utility bar
   ========================================================================= */
.topbar{
  background:var(--wine-darkest); color:var(--brass-soft);
  font-family:var(--mono); font-size:.72rem; letter-spacing:.12em;
}
.topbar .wrap{ display:flex; justify-content:space-between; align-items:center; gap:1rem; padding-block:.55rem; }
.topbar a{ display:inline-flex; align-items:center; gap:.5em; transition:color .3s var(--ease); }
.topbar a:hover{ color:var(--white); }
.topbar .tb-left{ opacity:.85; }
@media (max-width:720px){ .topbar .tb-left{ display:none; } .topbar .wrap{ justify-content:center; } }

/* =========================================================================
   Header / nav
   ========================================================================= */
.site-head{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--parchment) 88%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.site-head .wrap{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding-block:.7rem; }
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand .crest{ width:34px; height:auto; color:var(--wine); }
.brand-name{ font-family:var(--display); font-size:1.18rem; font-weight:500; line-height:1; color:var(--wine); }
.brand-name span{ display:block; font-family:var(--mono); font-size:.58rem; letter-spacing:.34em; color:var(--ink-soft); margin-top:.25rem; text-transform:uppercase; }

.nav{ display:flex; align-items:center; gap:clamp(1rem,2.4vw,2.2rem); }
.nav a.navlink{
  font-family:var(--mono); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink); position:relative; padding-block:.4rem;
}
.nav a.navlink::after{
  content:""; position:absolute; left:0; bottom:0; width:0; height:1.5px; background:var(--brass);
  transition:width .35s var(--ease);
}
.nav a.navlink:hover::after, .nav a.navlink[aria-current="page"]::after{ width:100%; }
.nav a.navlink[aria-current="page"]{ color:var(--wine); }
.nav .btn{ padding:.7em 1.2em; }

.nav-toggle{
  display:none; width:44px; height:44px; border:1px solid var(--line); border-radius:var(--r);
  background:transparent; align-items:center; justify-content:center; color:var(--wine);
}
.nav-toggle svg{ width:20px; height:20px; }

@media (max-width:880px){
  .nav-toggle{ display:inline-flex; }
  /* backdrop-filter on an ancestor makes it the containing block for position:fixed
     children, which would trap the drawer inside the header. Drop it on mobile. */
  .site-head{ backdrop-filter:none; background:var(--parchment); }
  body.menu-open::after{
    content:""; position:fixed; inset:0; z-index:40;
    background:rgba(24,6,12,.5); animation:fade .3s var(--ease);
  }
  @keyframes fade{ from{ opacity:0; } to{ opacity:1; } }
  .nav{
    position:fixed; inset:0 0 0 auto; width:min(82vw,340px);
    flex-direction:column; align-items:flex-start; justify-content:flex-start; gap:1.4rem;
    background:var(--wine); color:var(--brass-soft); z-index:60;
    padding:5rem var(--gut) 2rem; transform:translateX(100%);
    transition:transform .45s var(--ease); box-shadow:-20px 0 60px rgba(0,0,0,.25);
  }
  .nav[data-open="true"]{ transform:translateX(0); }
  .nav a.navlink{ color:var(--white); font-size:1rem; }
  .nav a.navlink[aria-current="page"]{ color:var(--brass-soft); }
  .nav a.navlink::after{ background:var(--brass); }
  .nav .btn--primary{ background:var(--brass); color:var(--wine-darkest); border-color:var(--brass); }
  body.menu-open{ overflow:hidden; }
}

/* =========================================================================
   Hero
   ========================================================================= */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(120% 90% at 50% -10%, color-mix(in srgb,var(--wine) 80%, #000) 0%, var(--wine-deep) 45%, var(--wine-darkest) 100%);
  color:var(--white);
}
.hero::before{ /* subtle stone texture */
  content:""; position:absolute; inset:0; opacity:.06; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 30h60M30 0v60' stroke='%23d9c088' stroke-width='.5'/%3E%3C/svg%3E");
}
.hero::after{ /* vignette */
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(80% 60% at 50% 40%, transparent 50%, rgba(0,0,0,.35) 100%);
}
.hero-inner{ position:relative; z-index:2; padding-block:clamp(56px,9vw,104px); text-align:center; }
.hero .crest{ width:clamp(120px,16vw,168px); margin:0 auto 1.6rem; color:var(--brass); }
.hero .eyebrow{ color:var(--brass-soft); justify-content:center; }
.hero .eyebrow::after{ content:""; width:26px; height:1px; background:var(--brass); opacity:.85; }
.hero h1{ font-size:clamp(2.5rem,6.4vw,5rem); font-weight:400; max-width:18ch; margin:0 auto .5rem; }
.hero h1 .it{ font-style:italic; color:var(--brass-soft); }
.hero-sub{ font-size:clamp(1.05rem,1.6vw,1.32rem); color:color-mix(in srgb,var(--white) 82%, var(--wine)); max-width:46ch; margin:1.1rem auto 2rem; line-height:1.55; }
.hero-cta{ display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; }

.hero-chips{
  display:flex; flex-wrap:wrap; gap:.5rem .6rem; justify-content:center;
  margin-top:2.6rem;
}
.chip{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--brass-soft); border:1px solid var(--line-dark); border-radius:100px;
  padding:.5em 1em; background:rgba(0,0,0,.12);
}

/* =========================================================================
   Generic blocks
   ========================================================================= */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.split--reverse > :first-child{ order:2; }
@media (max-width:840px){ .split, .split--reverse{ grid-template-columns:1fr; } .split--reverse > :first-child{ order:0; } }

.statement{ max-width:34ch; }
.section-head{ max-width:60ch; }
.section-head--center{ margin-inline:auto; text-align:center; }

/* Two-tone framed media (logo medallion / texture panel) */
.medallion{
  position:relative; border:1px solid var(--line); border-radius:6px;
  background:linear-gradient(160deg,var(--white),var(--parchment-2));
  padding:clamp(1.6rem,4vw,3rem); display:grid; place-items:center;
  box-shadow:0 30px 60px -40px rgba(44,10,18,.5);
}
.medallion::after{
  content:""; position:absolute; inset:10px; border:1px solid var(--line); border-radius:3px; pointer-events:none;
}
.medallion img{ width:min(78%,300px); height:auto; mix-blend-mode:multiply; }

/* Feature list */
.flist{ list-style:none; margin:1.4rem 0 0; padding:0; display:grid; gap:1rem; }
.flist li{ display:flex; gap:.9rem; align-items:flex-start; }
.flist .ic{ flex:0 0 auto; width:22px; height:22px; color:var(--brass); margin-top:.2rem; }
.flist b{ font-weight:700; }

/* =========================================================================
   Cards grid (servizi / sapori)
   ========================================================================= */
.grid{ display:grid; gap:1.1rem; }
.grid--3{ grid-template-columns:repeat(3,1fr); }
.grid--4{ grid-template-columns:repeat(4,1fr); }
.grid--2{ grid-template-columns:repeat(2,1fr); }
@media (max-width:980px){ .grid--3,.grid--4{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .grid--3,.grid--4,.grid--2{ grid-template-columns:1fr; } }

.card{
  background:var(--white); border:1px solid var(--line); border-radius:6px;
  padding:1.6rem 1.5rem; position:relative; overflow:hidden;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
.card:hover{ transform:translateY(-4px); box-shadow:0 30px 50px -34px rgba(44,10,18,.45); border-color:var(--brass); }
.card .ic{ width:30px; height:30px; color:var(--wine); margin-bottom:1rem; }
.card .tag{ font-family:var(--mono); font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); }
.card h3{ font-size:1.28rem; margin:.15rem 0 .5rem; color:var(--wine); }
.card p{ margin:0; color:var(--ink-soft); font-size:.97rem; line-height:1.55; }
.card .num{
  position:absolute; top:1rem; right:1.2rem; font-family:var(--mono); font-size:.72rem;
  color:var(--line); letter-spacing:.1em;
}

/* Compact service rows */
.svc-rows{ display:grid; gap:0; border:1px solid var(--line); border-radius:6px; overflow:hidden; background:var(--white); }
.svc-row{ display:grid; grid-template-columns:auto 1fr auto; gap:1.2rem; align-items:center; padding:1.15rem 1.4rem; border-bottom:1px solid var(--line); }
.svc-row:last-child{ border-bottom:0; }
.svc-row .ic{ width:24px; height:24px; color:var(--brass); }
.svc-row h4{ font-family:var(--body); font-weight:700; font-size:1rem; margin:0; }
.svc-row p{ margin:.15rem 0 0; font-size:.9rem; color:var(--ink-soft); }
.svc-row .meta{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; color:var(--ink-soft); text-transform:uppercase; white-space:nowrap; }
@media (max-width:560px){ .svc-row{ grid-template-columns:auto 1fr; } .svc-row .meta{ display:none; } }

/* =========================================================================
   Bands (dark wine) — il borgo / castello, CTA
   ========================================================================= */
.band{ position:relative; background:var(--wine-deep); color:var(--white); overflow:hidden; }
.band::before{
  content:""; position:absolute; inset:0; opacity:.05; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cpath d='M40 0L80 40L40 80L0 40Z' fill='none' stroke='%23d9c088' stroke-width='.6'/%3E%3C/svg%3E");
  background-size:80px 80px;
}
.band .wrap{ position:relative; z-index:2; }
.band .eyebrow{ color:var(--brass-soft); }
.band h2{ color:var(--white); }
.band .lead{ color:color-mix(in srgb,var(--white) 80%, var(--wine)); }

/* CTA band */
.cta-band{ text-align:center; }
.cta-band .crest{ width:64px; margin:0 auto 1.4rem; color:var(--brass); }
.cta-band h2{ font-size:clamp(1.9rem,4vw,3rem); max-width:20ch; margin:0 auto .6rem; }
.cta-band .lead{ max-width:48ch; margin:0 auto 2rem; }

/* =========================================================================
   Reviews
   ========================================================================= */
.rating-head{ display:flex; align-items:center; gap:1rem; justify-content:center; margin-bottom:2.4rem; flex-wrap:wrap; }
.stars{ color:var(--brass); letter-spacing:.15em; font-size:1.2rem; }
.rating-head .score{ font-family:var(--display); font-size:1.6rem; color:var(--wine); }
.rating-head .src{ font-family:var(--mono); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); }

.quote{ background:var(--white); border:1px solid var(--line); border-radius:6px; padding:1.7rem 1.6rem; }
.quote .mark{ font-family:var(--display); font-size:2.6rem; line-height:.4; color:var(--brass); }
.quote p{ font-size:1.02rem; color:var(--ink); margin:.6rem 0 1rem; }
.quote .who{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); }

/* =========================================================================
   Info / orari / contatti
   ========================================================================= */
.info-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.1rem; }
@media (max-width:780px){ .info-grid{ grid-template-columns:1fr; } }
.info-card{ background:var(--white); border:1px solid var(--line); border-radius:6px; padding:1.6rem; }
.info-card .ic{ width:26px; height:26px; color:var(--brass); margin-bottom:.8rem; }
.info-card h3{ font-size:1.15rem; color:var(--wine); margin-bottom:.5rem; }
.info-card a{ color:var(--wine); border-bottom:1px solid var(--line); transition:border-color .3s; }
.info-card a:hover{ border-color:var(--wine); }

.hours{ list-style:none; margin:0; padding:0; font-family:var(--mono); font-size:.86rem; }
.hours li{ display:flex; justify-content:space-between; gap:1rem; padding:.45rem 0; border-bottom:1px dashed var(--line); }
.hours li:last-child{ border-bottom:0; }
.hours .day{ color:var(--ink); }
.hours .time{ color:var(--ink-soft); }
.hours li.today{ color:var(--wine); font-weight:500; }
.hours li.today .time{ color:var(--wine); }

.mapframe{ border:1px solid var(--line); border-radius:6px; overflow:hidden; box-shadow:0 30px 60px -44px rgba(44,10,18,.5); }
.mapframe iframe{ display:block; width:100%; height:100%; min-height:340px; border:0; filter:grayscale(.25) contrast(1.02); }

/* Form */
.form{ display:grid; gap:1rem; }
.form .row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media (max-width:560px){ .form .row{ grid-template-columns:1fr; } }
.field label{ display:block; font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:.4rem; }
.field input,.field textarea,.field select{
  width:100%; font-family:var(--body); font-size:1rem; color:var(--ink);
  background:var(--white); border:1px solid var(--line); border-radius:var(--r);
  padding:.8em .9em; transition:border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.field textarea{ min-height:130px; resize:vertical; }
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none; border-color:var(--wine); box-shadow:0 0 0 3px color-mix(in srgb,var(--wine) 14%, transparent);
}
.form-note{ font-size:.84rem; color:var(--ink-soft); }
.form-status{ font-family:var(--mono); font-size:.8rem; letter-spacing:.04em; padding:.85rem 1rem; border-radius:6px; display:none; }
.form-status.show{ display:block; }
.form-status.ok{ background:rgba(107,26,43,.07); color:var(--wine); border:1px solid var(--brass-soft); }

/* =========================================================================
   Page hero (interior pages)
   ========================================================================= */
.page-hero{ background:var(--wine-deep); color:var(--white); position:relative; overflow:hidden; }
.page-hero::before{
  content:""; position:absolute; inset:0; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cpath d='M40 0L80 40L40 80L0 40Z' fill='none' stroke='%23d9c088' stroke-width='.6'/%3E%3C/svg%3E");
  background-size:80px 80px;
}
.page-hero .wrap{ position:relative; z-index:2; padding-block:clamp(48px,8vw,92px); text-align:center; }
.page-hero .eyebrow{ color:var(--brass-soft); justify-content:center; }
.page-hero .eyebrow::after{ content:""; width:26px; height:1px; background:var(--brass); opacity:.85; }
.page-hero h1{ font-size:clamp(2.2rem,5.4vw,4rem); font-weight:400; color:var(--white); max-width:20ch; margin:0 auto; }
.page-hero h1 .it{ font-style:italic; color:var(--brass-soft); }
.page-hero p{ color:color-mix(in srgb,var(--white) 80%, var(--wine)); max-width:54ch; margin:1.1rem auto 0; font-size:1.1rem; }
.crumbs{ font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--brass-soft); margin-bottom:1.2rem; }
.crumbs a{ opacity:.8; } .crumbs a:hover{ opacity:1; } .crumbs span{ opacity:.45; margin-inline:.5em; }

/* Timeline (storia) */
.timeline{ display:grid; gap:0; }
.tl-item{ display:grid; grid-template-columns:120px 1fr; gap:2rem; padding:1.8rem 0; border-top:1px solid var(--line); }
.tl-item:last-child{ border-bottom:1px solid var(--line); }
.tl-year{ font-family:var(--display); font-size:2rem; color:var(--brass); line-height:1; }
.tl-body h3{ font-size:1.3rem; color:var(--wine); margin-bottom:.4rem; }
.tl-body p{ margin:0; color:var(--ink-soft); }
@media (max-width:600px){ .tl-item{ grid-template-columns:1fr; gap:.4rem; } }

/* =========================================================================
   Footer
   ========================================================================= */
.site-foot{ background:var(--wine-darkest); color:color-mix(in srgb,var(--white) 76%, var(--wine)); }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2rem; padding-block:clamp(48px,6vw,72px); }
@media (max-width:880px){ .foot-top{ grid-template-columns:1fr 1fr; gap:2.4rem; } }
@media (max-width:520px){ .foot-top{ grid-template-columns:1fr; } }
.foot-brand .crest{ width:48px; color:var(--brass); margin-bottom:1rem; }
.foot-brand .bn{ font-family:var(--display); font-size:1.4rem; color:var(--white); }
.foot-brand p{ font-size:.92rem; margin-top:.6rem; max-width:34ch; }
.foot-col h4{ font-family:var(--mono); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--brass-soft); margin-bottom:1rem; font-weight:500; }
.foot-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:.55rem; }
.foot-col a, .foot-col span{ font-size:.92rem; transition:color .3s var(--ease); }
.foot-col a:hover{ color:var(--brass-soft); }
.foot-bottom{ border-top:1px solid var(--line-dark); padding-block:1.3rem; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; color:color-mix(in srgb,var(--white) 55%, var(--wine)); }
.foot-bottom a:hover{ color:var(--brass-soft); }

/* =========================================================================
   Reveal animation
   ========================================================================= */
.reveal{ opacity:0; transform:translateY(22px); 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; }

/* crest draw-in */
.crest .draw{ stroke-dasharray:1; stroke-dashoffset:0; }
.hero .crest.animate .draw{
  stroke-dasharray:1400; stroke-dashoffset:1400; animation:draw 2.4s var(--ease) .2s forwards;
}
@keyframes draw{ to{ stroke-dashoffset:0; } }

@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .hero .crest.animate .draw{ animation:none; stroke-dashoffset:0; }
  .card:hover,.btn:hover{ transform:none; }
}
