/* ===== Osmar Creations La Boutique ===== */
:root{
  --ink:#34141C;        /* warm near-black text */
  --vino:#6E1E38;       /* primary brand wine */
  --vino-deep:#4A1326;  /* hero / footer ground */
  --ivory:#FBF4EE;      /* main light bg */
  --ivory-2:#FFFBF6;    /* card light */
  --blush:#F3E0DC;      /* soft rose band */
  --gold:#8A5E15;       /* gold for TEXT on light (AA 5.2:1) */
  --gold-line:#B0822F;  /* gold for hairlines/strokes */
  --gold-lt:#CDA257;    /* gold on dark grounds */
  --champagne:#E8CF9E;  /* eyebrow on dark */
  --muted:#6B4048;      /* muted text on light (AA on ivory) */
  --muted-dk:#D8B9B6;   /* muted on wine */
  --soft-on-dark:#F2E1DB;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--ivory);color:var(--ink);
  font-family:"Mulish",system-ui,sans-serif;
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:"Cormorant Garamond",Georgia,serif;font-weight:600;line-height:1.08;margin:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

.skip{position:absolute;left:-999px;top:0;background:var(--vino);color:#fff;padding:10px 16px;z-index:200}
.skip:focus{left:8px;top:8px}

/* eyebrow / labels */
.eyebrow{
  font-family:"Mulish",sans-serif;font-weight:700;font-size:.74rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--vino);
  margin:0 0 18px;display:flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold-line)}
.eyebrow-on-dark{color:var(--champagne)}
.eyebrow-on-dark::before{background:var(--gold-lt)}

/* ===== buttons ===== */
.btn{
  display:inline-block;font-family:"Mulish",sans-serif;font-weight:600;
  font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
  padding:15px 30px;border:1px solid transparent;cursor:pointer;
  transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease);
}
.btn-gold{background:var(--gold-line);color:#2a1608;border-color:var(--gold-line)}
.btn-gold:hover,.btn-gold:focus-visible{background:#c79443;border-color:#c79443}
.btn-ghost{background:transparent;color:var(--soft-on-dark);border-color:rgba(232,207,158,.5)}
.btn-ghost:hover,.btn-ghost:focus-visible{border-color:var(--champagne);color:#fff;background:rgba(232,207,158,.08)}
.btn.full{width:100%;text-align:center}

/* ===== header ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;transition:background .4s var(--ease),padding .4s var(--ease),box-shadow .4s var(--ease);
}
.site-header::before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(46,12,24,.55),transparent);opacity:1;transition:opacity .4s;pointer-events:none}
.site-header.scrolled{background:var(--vino-deep);padding:12px 0;box-shadow:0 1px 0 rgba(205,162,87,.25)}
.site-header.scrolled::before{opacity:0}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ivory)}
.brand-crown{color:var(--gold-lt);flex:none}
.brand-name{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:1.42rem;line-height:1;display:flex;flex-direction:column}
.brand-sub{font-family:"Mulish",sans-serif;font-weight:600;font-size:.56rem;letter-spacing:.32em;text-transform:uppercase;color:var(--champagne);margin-top:3px}

.nav{display:flex;align-items:center}
.navlinks{list-style:none;display:flex;align-items:center;gap:30px;margin:0;padding:0}
.navlinks a{
  font-family:"Mulish",sans-serif;font-weight:600;font-size:.82rem;letter-spacing:.06em;
  color:var(--soft-on-dark);position:relative;padding:6px 0;transition:color .3s;
}
.navlinks a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold-lt);transition:width .3s var(--ease)}
.navlinks a:not(.nav-cta):hover,.navlinks a:not(.nav-cta):focus-visible{color:#fff}
.navlinks a:not(.nav-cta):hover::after,.navlinks a:not(.nav-cta):focus-visible::after{width:100%}
.navlinks a.nav-cta{
  border:1px solid var(--gold-lt);color:var(--champagne);
  padding:9px 20px;letter-spacing:.1em;transition:background .3s,color .3s;
}
.navlinks a.nav-cta:hover,.navlinks a.nav-cta:focus-visible{background:var(--gold-lt);color:#2a1608}
.nav-toggle{display:none}

/* ===== hero ===== */
.hero{
  position:relative;min-height:100svh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  background:
    radial-gradient(120% 80% at 50% 8%, #5e1830 0%, var(--vino-deep) 58%, #380e1d 100%);
  color:var(--ivory);padding:120px 0 90px;overflow:hidden;
}
.hero-grain{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:radial-gradient(1px 1px at 20% 30%,rgba(232,207,158,.18),transparent),
             radial-gradient(1px 1px at 70% 60%,rgba(232,207,158,.14),transparent),
             radial-gradient(1px 1px at 85% 22%,rgba(232,207,158,.16),transparent),
             radial-gradient(1px 1px at 40% 80%,rgba(232,207,158,.12),transparent);
  background-size:240px 240px,300px 300px,200px 200px,260px 260px}
.hero-inner{position:relative;z-index:2;max-width:760px}
.hero-crown{color:var(--gold-lt);margin:0 auto 26px}
.hero-eye{justify-content:center;color:var(--champagne)}
.hero-eye::before{display:none}
.hero-title{font-size:clamp(2.6rem,8vw,5.7rem);font-weight:500;letter-spacing:.005em}
.hero-title em{font-style:italic;color:var(--champagne);font-weight:500}
.hero-lead{font-size:clamp(1.05rem,2.2vw,1.28rem);color:var(--soft-on-dark);max-width:560px;margin:26px auto 36px;line-height:1.6}
.nb{white-space:nowrap;color:var(--champagne);font-style:italic}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--champagne);
  font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;font-weight:600;opacity:.85;transition:opacity .3s}
.scroll-cue:hover{opacity:1}
.scroll-cue svg{transition:transform .3s var(--ease)}
.scroll-cue:hover svg{transform:translateY(4px)}

/* ===== trust strip ===== */
.trust{background:var(--vino);color:var(--ivory)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.trust-item{padding:34px 22px;text-align:center;border-left:1px solid rgba(205,162,87,.22);
  display:flex;flex-direction:column;gap:4px;transition:background .35s}
.trust-item:first-child{border-left:none}
.trust-item:hover{background:rgba(205,162,87,.08)}
.t-k{font-family:"Cormorant Garamond",serif;font-size:1.55rem;font-weight:600;color:#fff}
.t-v{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--champagne);font-weight:600}

/* ===== sections ===== */
.section{padding:clamp(72px,9vw,124px) 0}
.sec-head{max-width:640px;margin-bottom:54px}
.sec-title{font-size:clamp(2.1rem,4.6vw,3.4rem);font-weight:600;letter-spacing:.004em}
.sec-title.light{color:#fff}
.sec-intro{color:var(--muted);font-size:1.08rem;margin:18px 0 0;max-width:560px}

/* offerings */
.offerings{background:var(--ivory)}
.offer-list{list-style:none;margin:0;padding:0;border-top:1px solid rgba(110,30,56,.16)}
.offer-row{display:flex;align-items:center;gap:26px;padding:30px 8px;
  border-bottom:1px solid rgba(110,30,56,.16);position:relative;transition:padding-left .35s var(--ease)}
.offer-tick{width:0;height:2px;background:var(--gold-line);flex:none;transition:width .35s var(--ease)}
.offer-text{flex:1}
.offer-row h3{font-size:clamp(1.5rem,3vw,2.05rem);font-weight:600;transition:color .3s}
.offer-row p{margin:6px 0 0;color:var(--muted);max-width:62ch}
.offer-tag{font-family:"Mulish",sans-serif;font-weight:700;font-size:.7rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--vino);border:1px solid rgba(110,30,56,.3);padding:7px 14px;flex:none;transition:background .3s,color .3s,border-color .3s}
.offer-row:hover{padding-left:22px}
.offer-row:hover .offer-tick{width:34px}
.offer-row:hover h3{color:var(--vino)}
.offer-row:hover .offer-tag{background:var(--vino);color:var(--ivory);border-color:var(--vino)}

/* lookbook / illustrations */
.lookbook{background:var(--blush);padding:clamp(64px,8vw,104px) 0}
.look-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.look-card{margin:0;text-align:center}
.gown-frame{aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;
  background:var(--ivory-2);border:1px solid rgba(110,30,56,.16);overflow:hidden;position:relative}
.gown-frame::after{content:"";position:absolute;inset:10px;border:1px solid rgba(176,130,47,.35);pointer-events:none}
.gown{width:62%;height:auto;transition:transform 1.1s var(--ease)}
.gf-1 .gown{color:var(--vino)}
.gf-2 .gown{color:#8a3050}
.gf-3 .gown{color:var(--gold-line)}
.look-card:hover .gown{transform:scale(1.035)}
.gown-crown{opacity:.9}
.look-card figcaption{font-family:"Cormorant Garamond",serif;font-size:1.5rem;font-weight:600;color:var(--vino);margin-top:18px;letter-spacing:.01em}
.look-note{text-align:center;color:var(--muted);font-size:.95rem;margin:36px 0 0;font-style:italic}

/* venue */
.venue{background:var(--vino-deep);color:var(--soft-on-dark)}
.venue-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:center}
.venue-lead{font-size:1.1rem;line-height:1.65;margin:18px 0 0;color:var(--soft-on-dark)}
.venue-quote{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:1.7rem;color:var(--champagne);
  border-left:2px solid var(--gold-lt);margin:30px 0;padding:4px 0 4px 22px;line-height:1.3}
.venue-points{list-style:none;margin:0 0 32px;padding:0;display:flex;flex-direction:column;gap:14px}
.venue-points li{display:flex;align-items:center;gap:14px;font-size:1.02rem;transition:color .3s}
.vp-mark{width:9px;height:9px;flex:none;border:1px solid var(--gold-lt);transform:rotate(45deg);transition:background .3s}
.venue-points li:hover{color:#fff}
.venue-points li:hover .vp-mark{background:var(--gold-lt)}
.venue-card{background:linear-gradient(160deg,#5a1830,#3d0f1f);border:1px solid rgba(205,162,87,.3);padding:38px 34px}
.vc-eye{font-family:"Mulish",sans-serif;font-weight:700;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--champagne)}
.vc-addr{font-family:"Cormorant Garamond",serif;font-size:1.55rem;line-height:1.3;color:#fff;margin:16px 0 12px}
.vc-line{margin:4px 0;font-size:1.05rem}
.vc-line a{color:var(--soft-on-dark);transition:color .3s}
.vc-line a:hover{color:var(--champagne)}
.muted-on-dark{color:var(--muted-dk);font-size:.92rem;letter-spacing:.04em}
.vc-map{display:inline-block;margin-top:22px;color:var(--gold-lt);font-weight:600;font-size:.86rem;letter-spacing:.05em;border-bottom:1px solid transparent;transition:border-color .3s,color .3s}
.vc-map:hover{color:var(--champagne);border-color:var(--champagne)}

/* steps */
.steps{background:var(--ivory)}
.step-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:0;counter-reset:none}
.step{padding:40px 34px 40px 0;border-top:2px solid var(--vino);position:relative;transition:background .35s}
.step + .step{padding-left:34px}
.step-n{font-family:"Cormorant Garamond",serif;font-size:1.4rem;font-weight:600;color:var(--gold-line);letter-spacing:.05em}
.step h3{font-size:1.5rem;font-weight:600;margin:14px 0 8px}
.step p{margin:0;color:var(--muted)}
.step::before{content:"";position:absolute;top:-2px;left:0;height:2px;width:0;background:var(--gold-line);transition:width .5s var(--ease)}
.step:hover::before{width:100%}

/* about */
.about{background:var(--blush)}
.about-grid{display:grid;grid-template-columns:auto 1fr;gap:54px;align-items:center}
.about-mark{color:var(--vino);opacity:.9}
.about-copy p{color:var(--ink);margin:18px 0 0;font-size:1.08rem;max-width:60ch}
.about-copy .sec-title{margin-top:8px}

/* faq */
.faq{background:var(--ivory)}
.faq-wrap{max-width:820px;margin:0 auto}
.faq-list{border-top:1px solid rgba(110,30,56,.16)}
.faq-item{border-bottom:1px solid rgba(110,30,56,.16)}
.faq-item summary{list-style:none;cursor:pointer;padding:24px 44px 24px 0;position:relative;
  font-family:"Cormorant Garamond",serif;font-size:1.4rem;font-weight:600;color:var(--ink);transition:color .3s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"";position:absolute;right:6px;top:50%;width:11px;height:11px;
  border-right:1.5px solid var(--gold-line);border-bottom:1.5px solid var(--gold-line);
  transform:translateY(-65%) rotate(45deg);transition:transform .3s}
.faq-item[open] summary::after{transform:translateY(-35%) rotate(-135deg)}
.faq-item summary:hover{color:var(--vino)}
.faq-item p{margin:0 0 24px;color:var(--muted);max-width:64ch}
.faq-item a{color:var(--vino);border-bottom:1px solid rgba(110,30,56,.4)}
.faq-item a:hover{color:var(--gold)}

/* request form */
.request{background:var(--vino);color:var(--soft-on-dark)}
.request-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px}
.request-lead{font-size:1.08rem;margin:18px 0 28px;color:var(--soft-on-dark)}
.request-lead a{color:var(--champagne);border-bottom:1px solid rgba(232,207,158,.5)}
.request-contacts{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px;border-top:1px solid rgba(205,162,87,.25);padding-top:22px}
.request-contacts li{display:flex;justify-content:space-between;align-items:baseline;gap:16px;border-bottom:1px solid rgba(205,162,87,.16);padding-bottom:12px}
.request-contacts span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--champagne);font-weight:700}
.request-contacts a{font-family:"Cormorant Garamond",serif;font-size:1.3rem;color:#fff;transition:color .3s}
.request-contacts a:hover{color:var(--champagne)}

.request-form{background:var(--ivory);color:var(--ink);padding:38px 36px;position:relative}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.field{margin-bottom:18px;display:flex;flex-direction:column}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field label{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--vino);margin-bottom:8px}
.field .opt{color:var(--muted);font-weight:600;letter-spacing:.06em;text-transform:none;font-size:.78rem}
.field input,.field select,.field textarea{
  font-family:"Mulish",sans-serif;font-size:1rem;color:var(--ink);
  background:var(--ivory-2);border:1px solid rgba(110,30,56,.28);padding:13px 14px;border-radius:0;
  transition:border-color .25s,box-shadow .25s;width:100%}
.field textarea{resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--gold-line);box-shadow:0 0 0 3px rgba(176,130,47,.22)}
.field.invalid input,.field.invalid select{border-color:#a32140;box-shadow:0 0 0 3px rgba(163,33,64,.16)}
.err{display:none;color:#a32140;font-size:.8rem;margin-top:6px;font-weight:600}
.field.invalid .err{display:block}
.form-note{text-align:center;color:var(--muted);font-size:.86rem;margin:14px 0 0}
.form-success{text-align:center;padding:20px 10px;color:var(--vino)}
.form-success svg{color:var(--gold-line);margin:0 auto 14px}
.form-success h3{font-size:1.9rem;font-weight:600;margin-bottom:8px}
.form-success p{color:var(--muted);margin:0}

/* visit / locations */
.visit{background:var(--ivory)}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.loc-card{border:1px solid rgba(110,30,56,.18);background:var(--ivory-2);overflow:hidden;transition:border-color .35s}
.loc-card:hover{border-color:var(--gold-line)}
.loc-panel{position:relative;height:160px;background:
   linear-gradient(135deg,#5e1830,var(--vino-deep));
   display:flex;align-items:flex-end;padding:20px;overflow:hidden}
.loc-panel::before{content:"";position:absolute;inset:0;opacity:.5;
  background:
   repeating-linear-gradient(45deg,rgba(205,162,87,.10) 0 1px,transparent 1px 22px),
   repeating-linear-gradient(-45deg,rgba(205,162,87,.07) 0 1px,transparent 1px 30px)}
.loc-pin{position:absolute;top:30px;left:50%;transform:translateX(-50%) rotate(45deg);
  width:20px;height:20px;border:2px solid var(--gold-lt);border-bottom-right-radius:0;border-top-left-radius:50%;border-top-right-radius:50%;border-bottom-left-radius:50%}
.loc-pin::after{content:"";position:absolute;inset:5px;background:var(--gold-lt);border-radius:50%}
.loc-label{position:relative;z-index:2;font-family:"Mulish",sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--champagne)}
.loc-body{padding:28px 26px 30px}
.loc-body h3{font-size:1.7rem;font-weight:600}
.loc-addr{margin:12px 0 10px;color:var(--ink);font-size:1.05rem;line-height:1.5}
.loc-line{margin:3px 0}
.loc-line a{color:var(--vino);font-weight:600;transition:color .3s}
.loc-line a:hover{color:var(--gold)}
.loc-line.muted{color:var(--muted);font-size:.9rem;letter-spacing:.04em}
.loc-map{display:inline-block;margin-top:18px;color:var(--gold);font-weight:700;font-size:.84rem;letter-spacing:.04em;border-bottom:1px solid transparent;transition:border-color .3s}
.loc-map:hover{border-color:var(--gold-line)}

/* footer */
.site-footer{background:var(--vino-deep);color:var(--soft-on-dark);padding:64px 0 28px}
.footer-inner{display:grid;grid-template-columns:1.1fr 1.4fr;gap:48px;align-items:start;padding-bottom:40px;border-bottom:1px solid rgba(205,162,87,.2)}
.footer-brand svg{color:var(--gold-lt)}
.footer-name{font-family:"Cormorant Garamond",serif;font-size:1.9rem;font-weight:600;color:#fff;margin:14px 0 4px}
.footer-name span{display:block;font-family:"Mulish",sans-serif;font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;color:var(--champagne);margin-top:4px}
.footer-tag{font-size:.9rem;color:var(--muted-dk)}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.fcol h4{font-family:"Mulish",sans-serif;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--champagne);font-weight:700;margin-bottom:14px}
.fcol p{margin:0 0 10px;font-size:.96rem;line-height:1.5}
.fcol a{transition:color .3s}
.fcol a:hover{color:var(--champagne)}
.footer-base{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:22px;font-size:.82rem;color:var(--muted-dk)}
.byline{color:var(--champagne)}

/* ===== reveals (gated by js-ready) ===== */
.js-ready .reveal{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js-ready .reveal.in{opacity:1;transform:none}

/* hero entrance */
.js-ready .hero-crown,.js-ready .hero-eye,.js-ready .hero-title,
.js-ready .hero-lead,.js-ready .hero-cta{opacity:0;transform:translateY(22px)}
.js-ready .hero.loaded .hero-crown{animation:rise .9s var(--ease) .1s forwards}
.js-ready .hero.loaded .hero-eye{animation:rise .9s var(--ease) .3s forwards}
.js-ready .hero.loaded .hero-title{animation:rise 1s var(--ease) .45s forwards}
.js-ready .hero.loaded .hero-lead{animation:rise 1s var(--ease) .65s forwards}
.js-ready .hero.loaded .hero-cta{animation:rise 1s var(--ease) .85s forwards}
@keyframes rise{to{opacity:1;transform:none}}

/* hero crown self-draw */
.js-ready .hc-line{stroke-dasharray:240;stroke-dashoffset:240}
.js-ready .hero.loaded .hc-line{animation:draw 1.7s var(--ease) .25s forwards}
.js-ready .hc-gem{opacity:0}
.js-ready .hero.loaded .hc-gem{animation:gem .5s ease 1.5s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes gem{to{opacity:1}}

/* gown draw on reveal */
.js-ready .gown-draw path{stroke-dasharray:1000;stroke-dashoffset:1000}
.js-ready .look-card.in .gown-draw path{animation:draw 2.2s var(--ease) forwards}
.js-ready .gown-crown{opacity:0}
.js-ready .look-card.in .gown-crown{animation:gem .6s ease 1.4s forwards}

/* ===== responsive ===== */
@media (max-width:880px){
  .venue-grid,.request-grid,.about-grid,.footer-inner{grid-template-columns:1fr;gap:40px}
  .about-grid{justify-items:start}
  .about-mark svg{width:84px;height:84px}
  .step-list{grid-template-columns:1fr}
  .step,.step + .step{padding:30px 0}
  .step{border-top:2px solid var(--vino)}
}
@media (max-width:760px){
  .nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;
    width:44px;height:44px;background:transparent;border:1px solid rgba(205,162,87,.5);cursor:pointer;padding:0 11px}
  .nav-toggle span{display:block;height:2px;background:var(--champagne);transition:transform .3s,opacity .3s}
  .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .navlinks{
    position:fixed;top:0;right:0;height:100svh;width:min(80vw,320px);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:22px;
    background:var(--vino-deep);padding:40px;transform:translateX(100%);
    transition:transform .4s var(--ease);box-shadow:-20px 0 60px rgba(0,0,0,.4)}
  .navlinks.open{transform:none}
  .navlinks a{font-size:1.05rem}
  .navlinks a.nav-cta{margin-top:8px}
  .trust-grid{grid-template-columns:1fr 1fr}
  .trust-item:nth-child(-n+2){border-bottom:1px solid rgba(205,162,87,.22)}
  .trust-item:nth-child(odd){border-left:none}
  .look-grid{grid-template-columns:1fr;max-width:360px;margin:0 auto}
  .loc-grid{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:1fr;gap:24px}
}
@media (max-width:480px){
  .wrap{padding:0 20px}
  .hero-title{font-size:clamp(2.2rem,10vw,2.8rem)}
  .hero{padding:108px 0 84px}
  .field-row{grid-template-columns:1fr}
  .request-form{padding:28px 22px}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{text-align:center}
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .js-ready .reveal{opacity:1;transform:none}
  .js-ready .hero-crown,.js-ready .hero-eye,.js-ready .hero-title,.js-ready .hero-lead,.js-ready .hero-cta{opacity:1;transform:none}
  .js-ready .hc-line,.js-ready .gown-draw path{stroke-dashoffset:0}
  .js-ready .hc-gem,.js-ready .gown-crown{opacity:1}
  .scroll-cue svg{animation:none}
}
