/* ===== TOKENS ===== */
:root{
  --plum:#2b1a2e;
  --plum-2:#3d2542;
  --gold:#c9a14a;
  --gold-soft:#e3c980;
  --rose:#b67d6e;
  --cream:#f7f1e8;
  --cream-2:#efe6d6;
  --ink:#241a26;
  --muted:#7d7280;
  --white:#fffdf9;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 24px 60px -28px rgba(43,26,46,.45);
  --shadow-sm:0 10px 30px -16px rgba(43,26,46,.4);
  --ease:cubic-bezier(.2,.8,.2,1);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Jost",system-ui,sans-serif;
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.08;letter-spacing:.2px}

/* ===== UTILITIES ===== */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(64px,9vw,130px) 24px}
.eyebrow{
  font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);font-weight:600;margin-bottom:14px;
}
.section__head{text-align:center;max-width:680px;margin:0 auto 56px}
.section__head h2{font-size:clamp(2.1rem,5vw,3.4rem)}
.section__lead{color:var(--muted);margin-top:14px;font-size:1.05rem}
.muted{color:var(--muted)}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  background:linear-gradient(135deg,var(--gold),var(--rose));
  color:#fff;font-family:var(--sans);font-weight:600;font-size:.95rem;
  letter-spacing:.04em;padding:15px 30px;border:none;border-radius:999px;
  cursor:pointer;transition:transform .35s var(--ease),box-shadow .35s var(--ease),filter .3s;
  box-shadow:0 14px 30px -14px rgba(201,161,74,.8);
}
.btn:hover{transform:translateY(-3px);box-shadow:0 22px 40px -16px rgba(201,161,74,.9);filter:brightness(1.05)}
.btn:active{transform:translateY(-1px)}
.btn--ghost{
  background:transparent;color:var(--plum);
  border:1.5px solid rgba(43,26,46,.25);box-shadow:none;
}
.btn--ghost:hover{background:rgba(43,26,46,.05);box-shadow:none}
.btn--small{padding:10px 22px;font-size:.85rem}

/* ===== NAV ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
  padding:18px 0;
}
.nav.is-scrolled{background:rgba(247,241,232,.9);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(43,26,46,.06);padding:10px 0}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px}
.brand__mark{
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--plum),var(--plum-2));
  color:var(--gold-soft);font-family:var(--serif);font-weight:700;font-size:1.1rem;
  border:1px solid rgba(201,161,74,.4);
}
.brand__text{font-family:var(--serif);font-weight:600;font-size:1.15rem;line-height:1;color:var(--plum)}
.brand__text small{display:block;font-family:var(--sans);font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-top:3px}
.brand--light .brand__text{color:var(--cream)}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{font-size:.92rem;font-weight:500;color:var(--plum);transition:color .3s}
.nav__links a:not(.btn):hover{color:var(--gold)}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav__toggle span{width:26px;height:2px;background:var(--plum);transition:.3s}

/* ===== HERO ===== */
.hero{
  position:relative;min-height:100vh;display:grid;align-items:center;
  grid-template-columns:1.02fr .98fr;gap:48px;
  padding:140px clamp(24px,6vw,90px) 80px;overflow:hidden;
  background:
    radial-gradient(80% 70% at 88% 0%,rgba(182,125,110,.20),transparent 60%),
    radial-gradient(70% 70% at 0% 100%,rgba(201,161,74,.16),transparent 55%),
    linear-gradient(160deg,var(--cream) 0%,var(--cream-2) 100%);
}
.hero__bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(43,26,46,.05) 1px,transparent 1px);
  background-size:26px 26px;
  -webkit-mask:radial-gradient(70% 60% at 70% 40%,#000,transparent 75%);
          mask:radial-gradient(70% 60% at 70% 40%,#000,transparent 75%);
}
.hero__content{position:relative;z-index:3;max-width:600px}
.hero h1{font-size:clamp(2.9rem,5.4vw,4.8rem);color:var(--plum);letter-spacing:-.5px}
.hero h1 em{font-style:italic;color:var(--gold);background:linear-gradient(120deg,var(--gold),var(--rose));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero__sub{font-size:1.14rem;color:var(--muted);margin:24px 0 36px;max-width:520px}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap}
.hero__stats{display:flex;gap:38px;margin-top:52px;flex-wrap:wrap}
.hero__stats strong{font-family:var(--serif);font-size:2.1rem;color:var(--plum);display:block;line-height:1}
.hero__stats span{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* hero photo composition */
.hero__visual{position:relative;z-index:2;height:min(82vh,680px);align-self:center}
.hero__glow{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:118%;aspect-ratio:1;border-radius:50%;
  background:conic-gradient(from 120deg,var(--plum),var(--rose),var(--gold),var(--gold-soft),var(--plum));
  filter:blur(6px);opacity:.85;
  -webkit-mask:radial-gradient(closest-side,transparent 71%,#000 73%,#000 76%,transparent 78%);
          mask:radial-gradient(closest-side,transparent 71%,#000 73%,#000 76%,transparent 78%);
  animation:spin 26s linear infinite;
}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.hero__photo{position:absolute;background:var(--plum) center/cover no-repeat;box-shadow:var(--shadow)}
.hero__photo--main{
  inset:6% 8% 6% 8%;border-radius:240px 240px 26px 26px;
  background-image:url('images/braids-large.jpg');background-position:center 18%;
  border:6px solid var(--white);
}
.hero__photo--sub{
  width:42%;aspect-ratio:3/4;left:-4%;bottom:4%;border-radius:20px;
  background-image:url('images/color-braids.jpg');
  border:5px solid var(--white);
  animation:float 6s ease-in-out infinite;
}
@keyframes float{50%{transform:translateY(-14px)}}
.hero__badge{
  position:absolute;top:7%;right:-3%;z-index:4;
  background:rgba(255,253,249,.82);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.6);border-radius:16px;padding:14px 18px;
  box-shadow:var(--shadow-sm);text-align:left;
  animation:float 7s ease-in-out infinite;
}
.hero__badge-stars{color:var(--gold);letter-spacing:2px;font-size:.78rem;display:block}
.hero__badge strong{display:block;font-family:var(--serif);font-size:1.25rem;color:var(--plum);line-height:1.1;margin-top:2px}
.hero__badge small{color:var(--muted);font-size:.76rem}
.hero__chip{
  position:absolute;bottom:9%;right:2%;z-index:4;display:flex;align-items:center;gap:8px;
  background:var(--plum);color:var(--cream);font-size:.8rem;font-weight:500;
  padding:10px 16px;border-radius:999px;box-shadow:var(--shadow-sm);
}
.hero__chip-dot{width:8px;height:8px;border-radius:50%;background:#5fd07e;box-shadow:0 0 0 0 rgba(95,208,126,.6);animation:pulse 2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 7px rgba(95,208,126,0)}100%{box-shadow:0 0 0 0 rgba(95,208,126,0)}}

/* fade-in */
.hero__content>*,.hero__visual{opacity:0;transform:translateY(24px);animation:rise .9s var(--ease) forwards}
.hero__content>*:nth-child(1){animation-delay:.1s}
.hero__content>*:nth-child(2){animation-delay:.22s}
.hero__content>*:nth-child(3){animation-delay:.34s}
.hero__content>*:nth-child(4){animation-delay:.46s}
.hero__content>*:nth-child(5){animation-delay:.58s}
.hero__visual{animation-delay:.3s;transform:translateY(0) scale(.96)}
@keyframes rise{to{opacity:1;transform:none}}

/* ===== MARQUEE ===== */
.marquee{background:var(--plum);color:var(--cream);padding:18px 0;overflow:hidden;position:relative}
.marquee__track{display:flex;gap:34px;white-space:nowrap;width:max-content;animation:scroll 34s linear infinite;font-family:var(--serif);font-size:1.4rem;font-style:italic}
.marquee__track span:nth-child(even){color:var(--gold)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ===== SERVICES ===== */
.services__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:24px}
.svc{
  background:var(--white);border-radius:var(--radius);padding:30px;
  border:1px solid rgba(43,26,46,.07);box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
  display:flex;flex-direction:column;
}
.svc:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.svc__icon{
  width:58px;height:58px;border-radius:16px;display:grid;place-items:center;font-size:1.6rem;
  background:linear-gradient(135deg,rgba(201,161,74,.18),rgba(182,125,110,.18));margin-bottom:18px;
}
.svc h3{font-size:1.55rem;color:var(--plum)}
.svc__desc{color:var(--muted);font-size:.95rem;margin:10px 0 20px;flex:1}
.svc__meta{display:flex;justify-content:space-between;align-items:baseline;border-top:1px dashed rgba(43,26,46,.15);padding-top:16px;margin-bottom:18px}
.svc__price{font-family:var(--serif);font-size:1.5rem;color:var(--plum);font-weight:700}
.svc__price small{font-family:var(--sans);font-size:.75rem;color:var(--muted);font-weight:400}
.svc__time{font-size:.85rem;color:var(--muted)}
.svc__book{align-self:flex-start;background:none;border:none;color:var(--gold);font-weight:600;cursor:pointer;font-family:var(--sans);font-size:.95rem;display:inline-flex;gap:.4em;transition:gap .3s}
.svc__book:hover{gap:.8em}

/* ===== GALLERY ===== */
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px}
.gallery figure{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.gallery .ph{width:100%;height:100%;transition:transform .7s var(--ease)}
.gallery figure:hover .ph{transform:scale(1.08)}
.gallery figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:16px;color:#fff;font-weight:500;
  background:linear-gradient(transparent,rgba(43,26,46,.8));font-size:.95rem;
  transform:translateY(8px);opacity:0;transition:.4s var(--ease);
}
.gallery figure:hover figcaption{transform:none;opacity:1}
.g1{grid-column:span 2;grid-row:span 2}
.g4{grid-column:span 2}
.gallery__note{text-align:center;color:var(--muted);margin-top:20px;font-size:.85rem}
.gallery__note code{background:rgba(43,26,46,.08);padding:2px 7px;border-radius:6px;font-size:.85em}

/* photos (swap the url() to use your own shots) */
.ph{width:100%;height:100%;background:var(--plum) center/cover no-repeat}
.ph--1{background-image:url('images/braids-large.jpg');background-position:center 30%}
.ph--2{background-image:url('images/color-braids.jpg')}
.ph--3{background-image:url('images/twists-style.jpg')}
.ph--4{background-image:url('images/boho-detail.jpg')}
.ph--5{background-image:url('images/beads.jpg')}
.ph--portrait{background-image:url('images/portrait.jpg');background-position:center 25%}

/* ===== ABOUT ===== */
.about{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center}
.about__media{aspect-ratio:4/5;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);position:relative}
.about__media::after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.25);border-radius:24px}
.about__body h2{font-size:clamp(2rem,4.5vw,3rem);color:var(--plum);margin:6px 0 18px}
.about__body p{color:var(--muted);margin-bottom:16px}
.about__list{list-style:none;margin:22px 0 30px;display:grid;gap:12px}
.about__list li{padding-left:30px;position:relative;color:var(--ink)}
.about__list li::before{content:"✦";position:absolute;left:0;color:var(--gold)}

/* ===== REVIEWS ===== */
.reviews{background:linear-gradient(160deg,var(--plum),var(--plum-2));border-radius:36px;color:var(--cream);max-width:var(--maxw);margin-inline:auto}
.reviews .eyebrow{color:var(--gold-soft)}
.reviews h2{color:#fff}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.reviews blockquote{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:28px}
.stars{color:var(--gold);letter-spacing:3px;margin-bottom:14px}
.reviews blockquote p{font-family:var(--serif);font-size:1.2rem;font-style:italic;line-height:1.45;margin-bottom:18px}
.reviews cite{font-style:normal;font-size:.9rem;color:var(--gold-soft)}

/* ===== BOOKING ===== */
.booking{display:grid;grid-template-columns:1fr 320px;gap:32px;align-items:start;max-width:1040px;margin:0 auto}
.booking__form{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(24px,4vw,44px);grid-column:1;position:relative;min-height:520px}
.booking__steps{grid-column:1/-1;display:flex;list-style:none;gap:8px;margin-bottom:34px;counter-reset:s;flex-wrap:wrap;justify-content:center}
.booking__steps li{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--muted);font-weight:500;opacity:.55;transition:.3s}
.booking__steps li span{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:rgba(43,26,46,.08);font-weight:600;transition:.3s}
.booking__steps li.is-active,.booking__steps li.is-done{opacity:1;color:var(--plum)}
.booking__steps li.is-active span{background:linear-gradient(135deg,var(--gold),var(--rose));color:#fff}
.booking__steps li.is-done span{background:var(--plum);color:var(--gold-soft)}
.booking__steps li:not(:last-child)::after{content:"";width:24px;height:1px;background:rgba(43,26,46,.2)}

.step{display:none;animation:fade .5s var(--ease)}
.step.is-active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.step h3{font-size:1.7rem;color:var(--plum);margin-bottom:22px}
.step__nav{display:flex;justify-content:space-between;align-items:center;margin-top:30px;gap:12px}

/* service picker */
.service-picker{display:grid;gap:12px}
.svc-opt{
  display:flex;align-items:center;gap:16px;padding:16px 18px;border-radius:var(--radius-sm);
  border:1.5px solid rgba(43,26,46,.12);cursor:pointer;transition:.25s var(--ease);background:#fff;
}
.svc-opt:hover{border-color:var(--gold);background:rgba(201,161,74,.05)}
.svc-opt.is-selected{border-color:var(--gold);background:rgba(201,161,74,.1);box-shadow:0 0 0 3px rgba(201,161,74,.15)}
.svc-opt__emoji{font-size:1.5rem}
.svc-opt__main{flex:1}
.svc-opt__main strong{display:block;font-family:var(--serif);font-size:1.2rem;color:var(--plum);font-weight:600}
.svc-opt__main span{font-size:.82rem;color:var(--muted)}
.svc-opt__price{font-family:var(--serif);font-weight:700;color:var(--plum);font-size:1.15rem}
.svc-opt__radio{width:22px;height:22px;border-radius:50%;border:2px solid rgba(43,26,46,.25);flex-shrink:0;position:relative;transition:.25s}
.svc-opt.is-selected .svc-opt__radio{border-color:var(--gold);background:var(--gold)}
.svc-opt.is-selected .svc-opt__radio::after{content:"";position:absolute;inset:5px;background:#fff;border-radius:50%}

/* datetime */
.datetime{display:grid;grid-template-columns:1fr 240px;gap:28px}
.calendar__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.calendar__head strong{font-family:var(--serif);font-size:1.25rem;color:var(--plum)}
.calendar__head button{width:36px;height:36px;border-radius:50%;border:1px solid rgba(43,26,46,.15);background:#fff;cursor:pointer;font-size:1.2rem;color:var(--plum);transition:.25s}
.calendar__head button:hover{background:var(--plum);color:#fff}
.calendar__dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:8px}
.calendar__dow span{text-align:center;font-size:.72rem;letter-spacing:.08em;color:var(--muted);font-weight:600}
.calendar__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-day{aspect-ratio:1;border:none;background:transparent;border-radius:10px;cursor:pointer;font-family:var(--sans);font-size:.92rem;color:var(--ink);transition:.2s;position:relative}
.cal-day:hover:not(:disabled){background:rgba(201,161,74,.18)}
.cal-day:disabled{color:rgba(43,26,46,.22);cursor:not-allowed}
.cal-day.is-selected{background:linear-gradient(135deg,var(--gold),var(--rose));color:#fff;font-weight:600}
.cal-day.is-today::after{content:"";position:absolute;bottom:6px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--gold)}
.cal-day.is-selected.is-today::after{background:#fff}
.cal-empty{aspect-ratio:1}

.slots__label{font-weight:600;color:var(--plum);margin-bottom:6px}
.slots__hint{color:var(--muted);font-size:.88rem}
.slots__grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
.slot{padding:11px;border:1.5px solid rgba(43,26,46,.14);border-radius:10px;background:#fff;cursor:pointer;font-family:var(--sans);font-size:.88rem;color:var(--plum);transition:.2s}
.slot:hover{border-color:var(--gold)}
.slot.is-selected{background:var(--plum);color:#fff;border-color:var(--plum)}
.slot:disabled{opacity:.35;cursor:not-allowed;text-decoration:line-through}

/* fields */
.fields{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fields label{display:flex;flex-direction:column;gap:7px;font-size:.85rem;font-weight:600;color:var(--plum)}
.fields__full{grid-column:1/-1}
.fields input,.fields select,.fields textarea{
  font-family:var(--sans);font-size:.95rem;padding:13px 15px;border:1.5px solid rgba(43,26,46,.16);
  border-radius:12px;background:#fff;color:var(--ink);font-weight:400;transition:.25s;resize:vertical;
}
.fields input:focus,.fields select:focus,.fields textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,161,74,.15)}
.fields .invalid{border-color:#c0563f;box-shadow:0 0 0 3px rgba(192,86,63,.12)}

/* summary */
.summary{display:grid;gap:14px;background:var(--cream);border-radius:var(--radius-sm);padding:24px}
.summary__row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding-bottom:12px;border-bottom:1px dashed rgba(43,26,46,.15)}
.summary__row:last-child{border:none;padding-bottom:0}
.summary__row dt{color:var(--muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em}
.summary__row dd{font-weight:600;color:var(--plum);text-align:right}
.summary__total{font-family:var(--serif);font-size:1.4rem!important}
.consent{display:flex;gap:12px;align-items:flex-start;margin-top:20px;font-size:.85rem;color:var(--muted);cursor:pointer}
.consent input{margin-top:3px;width:18px;height:18px;accent-color:var(--gold);flex-shrink:0}

/* success */
.booking__done{text-align:center;padding:30px 0}
.check{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--rose));color:#fff;font-size:2.4rem;display:grid;place-items:center;margin:0 auto 24px;animation:pop .6s var(--ease)}
@keyframes pop{0%{transform:scale(0)}70%{transform:scale(1.15)}100%{transform:scale(1)}}
.booking__done h3{font-size:2rem}
.done__actions{display:flex;gap:12px;justify-content:center;margin:26px 0 16px;flex-wrap:wrap}
.done__note{color:var(--muted);font-size:.88rem}

/* cart */
.cart{position:sticky;top:90px;background:linear-gradient(160deg,var(--plum),var(--plum-2));color:var(--cream);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.cart h4{font-family:var(--serif);font-size:1.4rem;color:#fff;margin-bottom:20px}
.cart dl{display:grid;gap:14px;margin-bottom:20px}
.cart dl>div{display:flex;justify-content:space-between;gap:10px;font-size:.9rem}
.cart dt{color:var(--gold-soft)}
.cart dd{text-align:right;font-weight:500}
.cart__total{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid rgba(255,255,255,.15);padding-top:18px}
.cart__total span{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gold-soft)}
.cart__total strong{font-family:var(--serif);font-size:1.8rem;color:#fff}
.cart__fine{font-size:.74rem;color:rgba(247,241,232,.6);margin-top:14px;line-height:1.5}

/* ===== INFO ===== */
.info__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.info h3{font-size:1.5rem;color:var(--plum);margin-bottom:16px}
.info a{color:var(--gold);font-weight:500}
.hours{list-style:none;display:grid;gap:10px}
.hours li{display:flex;justify-content:space-between;border-bottom:1px dashed rgba(43,26,46,.15);padding-bottom:8px;font-size:.95rem}
.ticks{list-style:none;display:grid;gap:10px}
.ticks li{padding-left:26px;position:relative;color:var(--muted);font-size:.92rem}
.ticks li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}

/* ===== FOOTER ===== */
.footer{background:var(--plum);color:var(--cream);padding:56px 24px 40px}
.footer__inner{max-width:var(--maxw);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center}
.footer__social{display:flex;gap:28px}
.footer__social a{font-size:.9rem;letter-spacing:.05em;transition:color .3s}
.footer__social a:hover{color:var(--gold)}
.footer__copy{font-size:.82rem;color:rgba(247,241,232,.55)}

/* ===== FAB ===== */
.fab{display:none;position:fixed;bottom:22px;right:22px;z-index:40;background:linear-gradient(135deg,var(--gold),var(--rose));color:#fff;font-weight:600;padding:16px 26px;border-radius:999px;box-shadow:0 16px 30px -10px rgba(201,161,74,.8)}

/* ===== REVEAL ON SCROLL ===== */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ===== RESPONSIVE ===== */
@media(max-width:980px){
  .hero{grid-template-columns:1fr;text-align:center;padding-top:120px;gap:36px;min-height:auto}
  .hero__content{max-width:620px;margin:0 auto}
  .hero__sub{margin-left:auto;margin-right:auto}
  .hero__cta,.hero__stats{justify-content:center}
  .hero__visual{height:min(64vh,520px);width:min(90%,460px);margin:0 auto;order:2}
  .hero__photo--sub{left:-2%}
  .hero__badge{right:0}
  .booking{grid-template-columns:1fr}
  .cart{position:static;order:-1}
  .about{grid-template-columns:1fr;gap:36px}
  .reviews__grid,.info__grid{grid-template-columns:1fr}
  .gallery__grid{grid-template-columns:repeat(2,1fr)}
  .g1{grid-column:span 2}
}
@media(max-width:720px){
  .nav__links{position:fixed;inset:0 0 0 30%;background:var(--cream);flex-direction:column;justify-content:center;gap:26px;transform:translateX(100%);transition:transform .4s var(--ease);box-shadow:var(--shadow);padding:40px}
  .nav__links.open{transform:none}
  .nav__toggle{display:flex}
  .nav.is-open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.is-open .nav__toggle span:nth-child(2){opacity:0}
  .nav.is-open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .datetime{grid-template-columns:1fr}
  .fields{grid-template-columns:1fr}
  .hero__stats{gap:28px}
  .fab{display:block}
  .reviews{border-radius:0;margin-inline:0;width:100%}
  .gallery__grid{grid-auto-rows:160px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
}
