/* =========================================================
   ROYAL LOOK UNISEX SALON — style.css
   Palette: deep aubergine/charcoal · royal purple · ivory · gold accent
   (extracted from the salon's own interiors, signage & decor)
   Display: Cormorant Garamond · Body: Jost
   ========================================================= */

:root{
  /* dark grounds — aubergine-tinted charcoal pulled from the salon walls/chairs */
  --ink:        #100b15;   /* near-black, faint purple */
  --ink-2:      #181020;   /* raised */
  --ink-3:      #241830;   /* card */

  /* royal purple — the salon's signature (feature walls, signage, balloons) */
  --purple:       #65187f; /* deep royal */
  --purple-soft:  #9a63db; /* lit lavender */
  --purple-mid:   #7f3fb1; /* balloon violet */
  --purple-deep:  #4d155d; /* shadowed wall */

  /* gold — secondary metallic, from the "ROYAL LOOK" reception lettering */
  --gold:       #c9a25b;
  --gold-soft:  #e3c98c;
  --gold-deep:  #a07c39;

  /* neutrals — marble/ivory from floors & flowers */
  --ivory:      #f5f1f7;   /* faint cool white */
  --ivory-dim:  #cabfd2;
  --muted:      #8a7e96;

  /* accent aliases: default "accent" is purple; gold used sparingly */
  --accent:       var(--purple-soft);
  --accent-strong:var(--purple);

  --line:       rgba(154,99,219,.26);
  --line-soft:  rgba(245,241,247,.10);
  --glass:      rgba(255,255,255,.055);
  --glass-brd:  rgba(255,255,255,.13);

  --maxw: 1240px;
  --pad: clamp(20px, 5vw, 64px);

  --f-display: "Cormorant Garamond", Georgia, serif;
  --f-body: "Jost", system-ui, sans-serif;

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

/* ---------- reset ---------- */
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--f-body);
  background:var(--ink);
  color:var(--ivory);
  line-height:1.65;
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul{ list-style:none; }
::selection{ background:var(--purple); color:#fff; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }

/* ---------- typography helpers ---------- */
.eyebrow{
  font-size:.72rem; letter-spacing:.32em; text-transform:uppercase;
  color:var(--purple-soft); font-weight:500; margin-bottom:1.1rem;
  display:flex; align-items:center; gap:.8rem;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--purple-soft); opacity:.8; }
.eyebrow--light{ color:var(--gold-soft); }

.section-title{
  font-family:var(--f-display);
  font-weight:500;
  font-size:clamp(2rem, 4.4vw, 3.6rem);
  line-height:1.06;
  letter-spacing:-.01em;
  color:var(--ivory);
}
.section-title--light{ color:#fff; }

p{ color:var(--ivory-dim); font-size:1.02rem; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.95rem 1.6rem; border-radius:999px;
  font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; font-weight:500;
  transition:transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease), box-shadow .4s var(--ease);
  will-change:transform;
}
.btn svg{ width:17px; height:17px; fill:currentColor; }
.btn--gold{
  background:linear-gradient(135deg,var(--purple-mid),var(--purple));
  color:#fff; box-shadow:0 10px 30px -10px rgba(101,24,127,.7);
}
.btn--gold:hover{ transform:translateY(-3px); box-shadow:0 16px 40px -12px rgba(101,24,127,.9); }
.btn--ghost{
  border:1px solid var(--glass-brd); background:var(--glass);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); color:var(--ivory);
}
.btn--ghost svg{ fill:var(--purple-soft); }
.btn--ghost:hover{ transform:translateY(-3px); border-color:var(--purple-soft); color:#fff; }
.btn--ghost-dark{ border-color:var(--line); background:transparent; color:var(--ink); }
.btn--ghost-dark:hover{ border-color:var(--purple); color:var(--purple); }

.link-arrow{
  display:inline-flex; align-items:center; gap:.55rem; margin-top:1.6rem;
  font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:var(--purple-soft);
  font-weight:500;
}
.link-arrow svg{ width:20px; height:20px; fill:none; stroke:var(--purple-soft); stroke-width:1.6;
  stroke-linecap:round; stroke-linejoin:round; transition:transform .4s var(--ease); }
.link-arrow:hover svg{ transform:translateX(6px); }

/* =========================================================
   PRELOADER
   ========================================================= */
.preloader{
  position:fixed; inset:0; z-index:9999; background:var(--ink);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.6rem;
  transition:opacity .7s var(--ease), visibility .7s var(--ease);
}
.preloader.is-done{ opacity:0; visibility:hidden; }
.preloader__mark{ text-align:center; }
.preloader__rl{
  font-family:var(--f-display); font-size:3.4rem; font-weight:600; color:var(--gold-soft);
  display:block; letter-spacing:.08em;
}
.preloader__name{
  font-size:.7rem; letter-spacing:.5em; color:var(--ivory-dim); text-transform:uppercase;
}
.preloader__bar{ width:160px; height:2px; background:var(--line-soft); overflow:hidden; border-radius:2px; }
.preloader__bar span{ display:block; height:100%; width:0; background:var(--purple-soft);
  animation:load 1.3s var(--ease) forwards; }
@keyframes load{ to{ width:100%; } }

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  transition:background .5s var(--ease), backdrop-filter .5s var(--ease), padding .5s var(--ease), border-color .5s var(--ease);
  padding:1.3rem 0; border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(16,11,21,.78); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  padding:.75rem 0; border-bottom:1px solid var(--line-soft);
}
.nav__inner{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.nav__brand{ display:flex; align-items:center; gap:.7rem; }
.nav__brand-rl{
  font-family:var(--f-display); font-weight:600; font-size:1.4rem; color:var(--ink);
  width:42px; height:42px; display:grid; place-items:center; border-radius:50%;
  background:linear-gradient(135deg,var(--gold-soft),var(--gold)); letter-spacing:.02em;
}
.nav__brand-text{ font-family:var(--f-display); font-size:1.32rem; font-weight:600; line-height:1; color:var(--ivory); }
.nav__brand-text small{ display:block; font-family:var(--f-body); font-size:.56rem; letter-spacing:.32em;
  text-transform:uppercase; color:var(--muted); margin-top:.28rem; font-weight:400; }

.nav__links{ display:flex; gap:2.1rem; margin-left:auto; }
.nav__links a{
  font-size:.84rem; letter-spacing:.06em; color:var(--ivory-dim); position:relative; padding:.2rem 0;
  transition:color .3s var(--ease);
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-3px; height:1px; width:0; background:var(--purple-soft);
  transition:width .35s var(--ease);
}
.nav__links a:hover{ color:#fff; } .nav__links a:hover::after{ width:100%; }

.nav__cta{
  border:1px solid var(--purple-soft); color:var(--purple-soft); padding:.6rem 1.25rem; border-radius:999px;
  font-size:.76rem; letter-spacing:.12em; text-transform:uppercase; font-weight:500;
  transition:background .35s var(--ease), color .35s var(--ease);
}
.nav__cta:hover{ background:var(--purple); color:#fff; border-color:var(--purple); }

.nav__toggle{ display:none; flex-direction:column; gap:5px; width:30px; height:24px; justify-content:center; }
.nav__toggle span{ height:2px; width:100%; background:var(--ivory); border-radius:2px; transition:transform .35s var(--ease), opacity .3s; }
.nav__toggle.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__toggle.is-open span:nth-child(2){ opacity:0; }
.nav__toggle.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.08);
  animation:heroZoom 9s var(--ease) forwards; }
@keyframes heroZoom{ to{ transform:scale(1); } }
.hero__veil{
  position:absolute; inset:0;
  background:
    linear-gradient(to top, rgba(16,11,21,.96) 4%, rgba(16,11,21,.55) 42%, rgba(16,11,21,.35) 100%),
    linear-gradient(to right, rgba(16,11,21,.74), rgba(16,11,21,.08)),
    radial-gradient(120% 90% at 82% 18%, rgba(101,24,127,.30), transparent 55%);
}
.hero__content{ padding-bottom:clamp(64px,11vh,130px); padding-top:140px; position:relative; }
.hero__title{
  font-family:var(--f-display); font-weight:500;
  font-size:clamp(2.8rem, 8vw, 6.4rem); line-height:.98; letter-spacing:-.02em;
  margin:.4rem 0 1.6rem; max-width:14ch;
}
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .line--accent{ font-style:italic; color:var(--gold-soft); }
.hero__sub{ max-width:46ch; font-size:clamp(1rem,1.4vw,1.18rem); color:var(--ivory-dim); }
.hero__actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.1rem; }
.hero__rating{ display:flex; align-items:center; gap:.9rem; margin-top:2.2rem; }
.stars{ color:var(--gold); letter-spacing:.16em; font-size:1.05rem; }
.hero__rating p{ font-size:.92rem; color:var(--ivory-dim); }
.hero__rating strong{ color:#fff; font-weight:500; }

.hero__scroll{ position:absolute; right:var(--pad); bottom:clamp(64px,11vh,130px); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.8rem;
  font-size:.66rem; letter-spacing:.26em; text-transform:uppercase; color:var(--ivory-dim);
  writing-mode:vertical-rl; }
.hero__scroll-line{ width:1px; height:60px; background:linear-gradient(var(--purple-soft),transparent);
  animation:scrollPulse 2s ease-in-out infinite; }
@keyframes scrollPulse{ 0%,100%{ transform:scaleY(.5); opacity:.5; } 50%{ transform:scaleY(1); opacity:1; } }

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{ background:var(--ink-2); border-block:1px solid var(--line-soft); overflow:hidden; padding:1.1rem 0; }
.marquee__track{ display:flex; align-items:center; gap:2.2rem; width:max-content;
  animation:marquee 32s linear infinite; }
.marquee__track span{ font-family:var(--f-display); font-style:italic; font-size:1.5rem; color:var(--ivory-dim); white-space:nowrap; }
.marquee__track .dot{ color:var(--purple-soft); font-style:normal; font-size:.8rem; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* =========================================================
   ABOUT
   ========================================================= */
.about{ padding:clamp(80px,12vh,150px) 0; background:var(--ink); }
.about__grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(40px,6vw,90px); align-items:center; }
.about__media{ position:relative; }
.about__img-main{ width:100%; aspect-ratio:3/4; object-fit:cover; border-radius:6px;
  border:1px solid var(--line); }
.about__badge{
  position:absolute; right:-14px; bottom:-26px; background:var(--ink-3);
  border:1px solid var(--line); border-radius:8px; padding:1.4rem 1.6rem; text-align:center;
  backdrop-filter:blur(8px); box-shadow:0 24px 50px -22px rgba(0,0,0,.8);
}
.about__badge-num{ font-family:var(--f-display); font-size:2.6rem; color:var(--gold); font-weight:600; display:block; line-height:1; }
.about__badge-label{ font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ivory-dim); }
.about__body p{ margin-bottom:1.1rem; }
.about__body .section-title{ margin:.4rem 0 1.4rem; }
.about__pillars{ margin-top:2rem; display:grid; gap:.2rem; }
.about__pillars li{
  display:flex; align-items:center; gap:1rem; padding:1rem 0; border-top:1px solid var(--line-soft);
  font-size:.98rem; color:var(--ivory); letter-spacing:.02em;
}
.about__pillars li:last-child{ border-bottom:1px solid var(--line-soft); }
.about__pillars span{ font-family:var(--f-display); font-style:italic; color:var(--purple-soft); font-size:1.1rem; min-width:26px; }

/* =========================================================
   SERVICES
   ========================================================= */
.services{ padding:clamp(80px,12vh,150px) 0; background:var(--ink-2); }
.services__head{ display:grid; grid-template-columns:1.3fr .9fr; gap:2.5rem; align-items:end; margin-bottom:3.5rem; }
.services__lead{ max-width:42ch; }
.services__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.1rem; }

.svc{
  position:relative; padding:1.9rem 1.6rem; border-radius:8px;
  background:var(--ink-3); border:1px solid var(--line-soft); overflow:hidden;
  transition:transform .5s var(--ease), border-color .5s var(--ease), background .5s var(--ease);
}
.svc::before{
  content:""; position:absolute; inset:0; opacity:0;
  background:radial-gradient(120% 100% at 50% 0%, rgba(154,99,219,.22), transparent 60%);
  transition:opacity .5s var(--ease);
}
.svc:hover{ transform:translateY(-6px); border-color:var(--line); background:#262229; }
.svc:hover::before{ opacity:1; }
.svc__num{ font-family:var(--f-display); font-style:italic; font-size:.95rem; color:var(--purple-soft); }
.svc__icon{ font-size:1.7rem; margin:.7rem 0 1rem; display:block; line-height:1;
  transition:transform .5s var(--ease); }
.svc:hover .svc__icon{ transform:translateY(-3px) scale(1.08); }
.svc h3{ font-family:var(--f-display); font-size:1.5rem; font-weight:600; color:var(--ivory); margin-bottom:.35rem; }
.svc p{ font-size:.86rem; color:var(--muted); line-height:1.55; }
.svc__cta{ margin-top:1.1rem; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--purple-soft); display:inline-flex; align-items:center; gap:.4rem; opacity:0;
  transform:translateY(6px); transition:opacity .4s var(--ease), transform .4s var(--ease); }
.svc:hover .svc__cta{ opacity:1; transform:translateY(0); }
.svc__link{ position:absolute; inset:0; }

/* =========================================================
   FEATURE SPLIT
   ========================================================= */
.feature{ background:var(--ink); padding:clamp(80px,12vh,150px) 0; }
.feature__band{ max-width:760px; margin-inline:auto; text-align:center; }
.eyebrow--center{ justify-content:center; }
.eyebrow--center::before{ display:none; }
.feature__quote{ margin:.4rem 0 1.4rem; }
.feature__lead{ max-width:54ch; margin-inline:auto; font-size:1.06rem; }
.link-arrow--center{ display:flex; width:fit-content; margin-inline:auto; }

/* =========================================================
   OUR WORK
   ========================================================= */
.work{ padding:clamp(80px,12vh,150px) 0; background:var(--ink-2); }
.work__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.work__item{
  position:relative; overflow:hidden; border-radius:8px; border:1px solid var(--line-soft);
  aspect-ratio:3/4; display:block;
}
.work__item img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.work__item::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(16,11,21,.78), transparent 55%); opacity:.2; transition:opacity .5s var(--ease); }
.work__cap{
  position:absolute; left:1rem; bottom:.95rem; z-index:2; font-family:var(--f-display); font-style:italic;
  font-size:1.15rem; color:#fff; text-shadow:0 2px 12px rgba(0,0,0,.8);
  opacity:0; transform:translateY(8px); transition:opacity .5s var(--ease), transform .5s var(--ease);
}
.work__item:hover img{ transform:scale(1.07); }
.work__item:hover::after{ opacity:1; }
.work__item:hover .work__cap{ opacity:1; transform:translateY(0); }

/* =========================================================
   WHY US
   ========================================================= */
.why{ position:relative; padding:clamp(90px,14vh,170px) 0; overflow:hidden; }
.why__bg{ position:absolute; inset:0; z-index:-2; }
.why__bg img{ width:100%; height:100%; object-fit:cover; }
.why__veil{ position:absolute; inset:0; background:linear-gradient(150deg, rgba(16,11,21,.92), rgba(77,21,93,.82) 55%, rgba(16,11,21,.94)); }
.why__content .eyebrow{ justify-content:center; }
.why__content .eyebrow::before{ display:none; }
.why__content{ text-align:center; }
.why__content .section-title{ margin-bottom:3.2rem; }
.why__grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:1.1rem; text-align:left; }
.why__card{
  background:var(--glass); border:1px solid var(--glass-brd); border-radius:10px; padding:1.7rem 1.4rem;
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  transition:transform .5s var(--ease), border-color .5s var(--ease), background .5s var(--ease);
}
.why__card:hover{ transform:translateY(-6px); border-color:var(--purple-soft); background:rgba(154,99,219,.12); }
.why__icon{ font-size:1.5rem; color:var(--purple-soft); display:block; margin-bottom:1rem; }
.why__card h3{ font-family:var(--f-display); font-size:1.4rem; font-weight:600; color:#fff; margin-bottom:.5rem; line-height:1.1; }
.why__card p{ font-size:.84rem; color:var(--ivory-dim); line-height:1.55; }

/* =========================================================
   STATS
   ========================================================= */
.stats{ background:var(--ink-2); border-block:1px solid var(--line-soft); padding:clamp(50px,8vh,90px) 0; }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; text-align:center; }
.stat__num{ font-family:var(--f-display); font-size:clamp(2.6rem,5vw,4rem); font-weight:600; color:var(--gold); line-height:1; display:block; }
.stat__label{ font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ivory-dim); margin-top:.6rem; display:block; }

/* =========================================================
   GALLERY
   ========================================================= */
.gallery{ padding:clamp(80px,12vh,150px) 0; background:var(--ink); }
.gallery__grid{
  display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:230px; gap:1rem; grid-auto-flow:dense;
}
.gallery__item{ position:relative; overflow:hidden; border-radius:8px; border:1px solid var(--line-soft);
  display:block; }
.gallery__item img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease), filter .6s var(--ease); }
.gallery__item--tall{ grid-row:span 2; }
.gallery__item--wide{ grid-column:span 2; }
.gallery__cap{
  position:absolute; left:1rem; bottom:1rem; font-family:var(--f-display); font-style:italic;
  font-size:1.2rem; color:#fff; opacity:0; transform:translateY(10px);
  transition:opacity .5s var(--ease), transform .5s var(--ease); text-shadow:0 2px 12px rgba(0,0,0,.7); z-index:2;
}
.gallery__item::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(16,11,21,.7), transparent 55%); opacity:0; transition:opacity .5s var(--ease); }
.gallery__item:hover img{ transform:scale(1.07); }
.gallery__item:hover::after{ opacity:1; }
.gallery__item:hover .gallery__cap{ opacity:1; transform:translateY(0); }

/* =========================================================
   REVIEWS
   ========================================================= */
.reviews{ padding:clamp(80px,12vh,150px) 0; background:var(--ink-2); text-align:center; }
.reviews .eyebrow{ justify-content:center; } .reviews .eyebrow::before{ display:none; }
.reviews .section-title{ margin-bottom:3rem; }
.reviews__viewport{ overflow:hidden; }
.reviews__track{ display:flex; transition:transform .7s var(--ease); }
.review{ min-width:100%; padding:0 clamp(0px,4vw,60px); }
.review__stars{ color:var(--gold); letter-spacing:.18em; font-size:1.1rem; margin-bottom:1.4rem; }
.review__quote{
  font-family:var(--f-display); font-size:clamp(1.4rem,2.8vw,2.2rem); font-style:italic;
  line-height:1.4; color:var(--ivory); max-width:24ch; margin:0 auto 1.8rem; font-weight:500;
}
.review__name{ font-size:.92rem; letter-spacing:.04em; color:#fff; font-weight:500; }
.review__meta{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-top:.25rem; }
.reviews__controls{ display:flex; align-items:center; justify-content:center; gap:1.4rem; margin-top:2.6rem; }
.reviews__btn{ width:46px; height:46px; border-radius:50%; border:1px solid var(--line);
  color:var(--purple-soft); font-size:1.4rem; line-height:1; transition:background .35s var(--ease), color .35s var(--ease); }
.reviews__btn:hover{ background:var(--purple); color:#fff; }
.reviews__dots{ display:flex; gap:.5rem; }
.reviews__dots button{ width:8px; height:8px; border-radius:50%; background:var(--line); transition:background .3s, width .3s; }
.reviews__dots button.is-active{ background:var(--purple-soft); width:22px; border-radius:5px; }

/* =========================================================
   CONTACT
   ========================================================= */
.contact{ padding:clamp(80px,12vh,150px) 0; background:var(--ivory); color:var(--ink); }
.contact .eyebrow{ color:var(--purple); } .contact .eyebrow::before{ background:var(--purple); }
.contact .section-title{ color:var(--ink); }
.contact__grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(40px,6vw,80px); align-items:center; }
.contact__list{ margin:2rem 0; }
.contact__list li{ padding:1.2rem 0; border-top:1px solid rgba(16,11,21,.1); display:grid;
  grid-template-columns:120px 1fr; gap:1rem; align-items:start; }
.contact__list li:last-child{ border-bottom:1px solid rgba(16,11,21,.1); }
.contact__k{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--purple); padding-top:.2rem; }
.contact__v{ color:#2b2730; font-size:1rem; line-height:1.6; }
.contact__v a{ color:var(--ink); border-bottom:1px solid var(--purple); }
.contact__actions{ display:flex; flex-wrap:wrap; gap:.9rem; }
.contact__map{ position:relative; display:block; border-radius:10px; overflow:hidden;
  border:1px solid rgba(16,11,21,.12); box-shadow:0 30px 60px -30px rgba(0,0,0,.4);
  min-height:440px; }
.contact__map img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transition:transform .8s var(--ease); }
.contact__map:hover img{ transform:scale(1.05); }
.contact__map-veil{ position:absolute; inset:0;
  background:linear-gradient(160deg, rgba(77,21,93,.62), rgba(16,11,21,.78)); }
.contact__map-card{ position:absolute; inset:0; z-index:2; display:flex; flex-direction:column;
  align-items:flex-start; justify-content:flex-end; gap:.5rem; padding:clamp(1.6rem,4vw,2.4rem); }
.contact__map-pin{ width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--purple-mid),var(--purple)); margin-bottom:.4rem;
  box-shadow:0 10px 26px -10px rgba(101,24,127,.8); }
.contact__map-pin svg{ width:24px; height:24px; fill:#fff; }
.contact__map-name{ font-family:var(--f-display); font-size:1.7rem; font-weight:600; color:#fff; line-height:1.1; }
.contact__map-addr{ font-size:.92rem; color:rgba(255,255,255,.85); max-width:30ch; margin-bottom:.6rem; }
.contact__map-btn{ display:inline-flex; align-items:center; gap:.55rem; padding:.8rem 1.4rem;
  border-radius:999px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.32);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; font-weight:500; color:#fff;
  transition:background .4s var(--ease), border-color .4s var(--ease); }
.contact__map-btn svg{ width:18px; height:18px; fill:none; stroke:#fff; stroke-width:1.8;
  stroke-linecap:round; stroke-linejoin:round; transition:transform .4s var(--ease); }
.contact__map:hover .contact__map-btn{ background:rgba(255,255,255,.22); border-color:#fff; }
.contact__map:hover .contact__map-btn svg{ transform:translateX(5px); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:var(--ink); padding:clamp(60px,9vh,100px) 0 2rem; border-top:1px solid var(--line-soft); }
.footer__grid{ display:grid; grid-template-columns:1.4fr .8fr 1fr; gap:3rem; padding-bottom:3rem;
  border-bottom:1px solid var(--line-soft); }
.footer__brand .nav__brand-rl{ margin-bottom:1rem; }
.footer__brand h3{ font-family:var(--f-display); font-size:1.7rem; font-weight:600; color:var(--ivory); line-height:1; }
.footer__brand h3 small{ display:block; font-family:var(--f-body); font-size:.62rem; letter-spacing:.28em;
  text-transform:uppercase; color:var(--muted); margin-top:.4rem; font-weight:400; }
.footer__brand p{ margin-top:1.1rem; max-width:38ch; font-size:.92rem; }
.footer h4{ font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--purple-soft); margin-bottom:1.2rem; font-weight:500; }
.footer__nav{ display:flex; flex-direction:column; gap:.7rem; }
.footer__nav a{ color:var(--ivory-dim); font-size:.92rem; transition:color .3s, padding-left .3s; width:fit-content; }
.footer__nav a:hover{ color:var(--purple-soft); padding-left:6px; }
.footer__contact a{ color:var(--ivory); font-size:1.05rem; border-bottom:1px solid var(--line); padding-bottom:2px; }
.footer__contact p{ font-size:.88rem; margin-top:.9rem; line-height:1.6; }
.footer__bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; padding-top:2rem; }
.footer__bottom p{ font-size:.78rem; letter-spacing:.04em; color:var(--muted); }

/* =========================================================
   LIGHTBOX
   ========================================================= */
.lightbox{ position:fixed; inset:0; z-index:9998; background:rgba(8,7,9,.95);
  display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden;
  transition:opacity .4s var(--ease), visibility .4s var(--ease); backdrop-filter:blur(6px); }
.lightbox.is-open{ opacity:1; visibility:visible; }
.lightbox img{ max-width:88vw; max-height:84vh; border-radius:6px; box-shadow:0 30px 80px -20px rgba(0,0,0,.8);
  transform:scale(.96); transition:transform .4s var(--ease); }
.lightbox.is-open img{ transform:scale(1); }
.lightbox__close{ position:absolute; top:24px; right:30px; font-size:2.6rem; color:var(--ivory); line-height:1; }
.lightbox__close:hover{ color:var(--purple-soft); }
.lightbox__nav{ position:absolute; top:50%; transform:translateY(-50%); font-size:3rem; color:var(--ivory);
  width:60px; height:60px; line-height:1; transition:color .3s; }
.lightbox__nav:hover{ color:var(--purple-soft); }
.lightbox__nav--prev{ left:2vw; } .lightbox__nav--next{ right:2vw; }

/* =========================================================
   FLOATING WHATSAPP
   ========================================================= */
.fab{ position:fixed; right:22px; bottom:22px; z-index:900; width:58px; height:58px; border-radius:50%;
  background:#25d366; display:grid; place-items:center; box-shadow:0 12px 30px -8px rgba(37,211,102,.6);
  transition:transform .4s var(--ease); }
.fab svg{ width:30px; height:30px; fill:#fff; }
.fab:hover{ transform:scale(1.1) rotate(4deg); }
.fab::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid #25d366;
  animation:fabPulse 2.4s ease-out infinite; }
@keyframes fabPulse{ 0%{ transform:scale(1); opacity:.7; } 100%{ transform:scale(1.7); opacity:0; } }

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
[data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
[data-reveal].is-in{ opacity:1; transform:none; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .services__grid{ grid-template-columns:repeat(3,1fr); }
  .why__grid{ grid-template-columns:repeat(3,1fr); }
  .work__grid{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:880px){
  .nav__links{
    position:fixed; inset:0 0 0 auto; width:min(80vw,340px); flex-direction:column; gap:0;
    background:var(--ink-2); padding:6rem 2rem 2rem; transform:translateX(100%);
    transition:transform .5s var(--ease); margin-left:0; border-left:1px solid var(--line-soft); justify-content:flex-start;
  }
  .nav__links.is-open{ transform:translateX(0); }
  .nav__links a{ font-size:1.05rem; padding:1rem 0; border-bottom:1px solid var(--line-soft); }
  .nav__toggle{ display:flex; z-index:1001; }
  .nav__cta{ display:none; }

  .about__grid{ grid-template-columns:1fr; }
  .about__media{ max-width:440px; }
  .services__head{ grid-template-columns:1fr; gap:1.2rem; }
  .why__grid{ grid-template-columns:repeat(2,1fr); }
  .stats__grid{ grid-template-columns:repeat(2,1fr); gap:2.5rem; }
  .contact__grid{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr 1fr; gap:2rem; }
}
@media (max-width:600px){
  .services__grid{ grid-template-columns:repeat(2,1fr); gap:.8rem; }
  .why__grid{ grid-template-columns:1fr; }
  .gallery__grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:170px; }
  .work__grid{ grid-template-columns:repeat(2,1fr); }
  .gallery__item--wide{ grid-column:span 2; }
  .gallery__item--tall{ grid-row:span 2; }
  .footer__grid{ grid-template-columns:1fr; }
  .hero__scroll{ display:none; }
  .about__badge{ right:0; padding:1.1rem 1.2rem; }
  .about__badge-num{ font-size:2rem; }
  .contact__list li{ grid-template-columns:1fr; gap:.3rem; }
  .footer__bottom{ flex-direction:column; }
}
@media (max-width:400px){
  .services__grid{ grid-template-columns:1fr; }
  .hero__actions .btn{ flex:1; justify-content:center; }
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.01ms !important; animation-iteration-count:1 !important;
     transition-duration:.01ms !important; scroll-behavior:auto !important; }
  [data-reveal]{ opacity:1; transform:none; }
  .hero__media img{ transform:none; }
}
