:root{
  --bg:        #161010;
  --bg-2:      #1d1514;
  --surface:   #221917;
  --surface-2: #2a201d;
  --line:      rgba(201,161,74,0.22);
  --line-soft: rgba(240,233,228,0.10);
  --text:      #f1e9e3;
  --muted:     #b6a79d;
  --muted-2:   #8d7e74;
  --red:       #b01e3c;
  --red-bright:#cf2b4c;
  --gold:      #c9a14a;
  --gold-soft: #d8be86;
  --nude:      #ead9cf;
  --nude-2:    #f3e7df;
  --nude-ink:  #3a2a24;
  --nude-muted:#7d6256;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Jost', system-ui, sans-serif;
  --maxw: 1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.6;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--red);color:#fff}

/* ---------- intro gate ---------- */
body.intro-active{overflow:hidden}
.intro-screen{
  position:fixed;inset:0;z-index:120;overflow-y:auto;
  background:
    radial-gradient(ellipse 90% 55% at 50% 8%,rgba(201,161,74,.18) 0%,transparent 55%),
    linear-gradient(180deg,#0d0808 0%,#170c0b 50%,#0a0606 100%);
  display:flex;align-items:flex-start;justify-content:center;padding:32px;
  transition:opacity .85s ease,visibility .85s ease}
.intro-screen.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.intro-veil{position:absolute;inset:0;opacity:.45;mix-blend-mode:soft-light;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E")}
.intro-scene{
  position:relative;z-index:1;max-width:740px;width:100%;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  margin:auto}
.intro-kicker{margin-bottom:2px}
.intro-title{font-family:var(--serif);font-size:clamp(42px,8.5vw,104px);font-weight:300;line-height:.95;letter-spacing:.01em}
.intro-copy{max-width:36ch;color:var(--muted);font-size:15.5px;line-height:1.6}
.intro-enter{min-width:210px}

/* gate wrapper */
.intro-gate{
  position:relative;width:min(72vw,490px);height:min(52vh,500px);
  display:flex;align-items:flex-end;justify-content:center;margin:8px 0 4px}

/* arch frame */
.intro-arch{
  position:absolute;inset:0;
  border:1px solid rgba(216,190,134,.30);border-bottom:none;
  border-radius:245px 245px 0 0;
  background:
    radial-gradient(85% 70% at 50% 12%,rgba(216,190,134,.09) 0%,transparent 55%),
    linear-gradient(180deg,rgba(255,255,255,.018) 0%,rgba(255,255,255,0) 100%);
  box-shadow:0 0 0 6px rgba(201,161,74,.04),0 30px 80px rgba(0,0,0,.5)}
.intro-arch::before,.intro-arch::after{
  content:"";position:absolute;top:10%;bottom:0;width:1px;
  background:linear-gradient(180deg,rgba(216,190,134,.55) 0%,rgba(216,190,134,.05) 100%)}
.intro-arch::before{left:19%}
.intro-arch::after{right:19%}

/* doors */
.intro-door{
  position:absolute;bottom:0;width:43%;height:76%;
  background:
    linear-gradient(170deg,rgba(36,24,20,.92) 0%,rgba(13,8,8,.97) 100%),
    repeating-linear-gradient(90deg,rgba(216,190,134,.07) 0 1px,transparent 1px 26px);
  border:1px solid rgba(216,190,134,.17);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.022),inset 0 24px 56px rgba(0,0,0,.32)}
.intro-door.left{left:6%;border-radius:200px 14px 0 0;transform:perspective(840px) rotateY(11deg);transform-origin:left center}
.intro-door.right{right:6%;border-radius:14px 200px 0 0;transform:perspective(840px) rotateY(-11deg);transform-origin:right center}
.intro-door::before{content:"";position:absolute;inset:10% 11% 7%;border:1px solid rgba(216,190,134,.09);border-radius:inherit}
.intro-door.left::after,.intro-door.right::after{
  content:"";position:absolute;bottom:36%;
  width:5px;height:5px;border-radius:50%;
  background:rgba(216,190,134,.58);box-shadow:0 0 7px rgba(216,190,134,.4)}
.intro-door.left::after{right:12%}
.intro-door.right::after{left:12%}

/* door open animation */
.intro-door{transition:transform .9s cubic-bezier(.4,0,.15,1)}
.intro-door.left.open{transform:perspective(840px) rotateY(-82deg)}
.intro-door.right.open{transform:perspective(840px) rotateY(82deg)}

/* aura glow from the gate */
.intro-gate::before{
  content:"";position:absolute;
  bottom:8%;left:50%;
  width:52%;height:58%;
  transform:translateX(-50%);
  background:radial-gradient(ellipse at 50% 72%,rgba(201,161,74,.55) 0%,rgba(216,190,134,.22) 32%,transparent 68%);
  pointer-events:none;
  animation:aura-pulse 3.2s ease-in-out infinite;
  z-index:0}

/* light burst when doors open */
.intro-gate.opening::after{
  content:"";position:absolute;
  inset:-5% -8%;
  background:radial-gradient(ellipse 55% 65% at 50% 56%,rgba(255,238,185,.92) 0%,rgba(201,161,74,.55) 24%,transparent 60%);
  pointer-events:none;
  animation:door-burst .95s cubic-bezier(.2,0,.6,1) forwards;
  z-index:9}

@keyframes aura-pulse{
  0%,100%{opacity:.55;transform:translateX(-50%) scaleY(1)}
  50%{opacity:1;transform:translateX(-50%) scaleY(1.12)}}

@keyframes door-burst{
  0%{opacity:0;transform:scale(.15)}
  28%{opacity:1}
  100%{opacity:0;transform:scale(1.25)}}

/* cheetah cat */
.intro-cat{
  position:absolute;bottom:0;left:50%;
  width:min(58vw,300px);
  transform:translateX(-50%);
  filter:drop-shadow(0 10px 40px rgba(201,161,74,.3));
  animation:cat-float 4.5s ease-in-out infinite;
  z-index:2}
.intro-cat img{width:100%;height:auto;display:block}

@keyframes cat-float{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(-7px)}}

@media(prefers-reduced-motion:reduce){
  .intro-cat,.intro-gate::before{animation:none}}

/* ---------- shared ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.eyebrow{
  font-family:var(--sans);
  font-weight:500;
  font-size:12px;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--gold);opacity:.7}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--gold);opacity:.7}
.eyebrow.center{justify-content:center}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.04;letter-spacing:.005em}
.display{font-size:clamp(52px,9vw,116px);font-weight:300}
.h2{font-size:clamp(38px,5.2vw,68px);font-weight:300}
.italic{font-style:italic}
section{position:relative}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:transform 1s cubic-bezier(.2,.7,.2,1),opacity .6s ease}
.reveal.in{opacity:1;transform:none}
/* Robustness: if transitions are paused (preview/print/export), reveal instantly */
.no-anim .reveal,.no-anim .reveal.in{opacity:1 !important;transform:none !important;transition:none !important}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- nav ---------- */
header.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .4s,border-color .4s,backdrop-filter .4s;border-bottom:1px solid transparent}
header.nav.scrolled{background:rgba(18,12,12,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:20px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .mark{font-family:var(--serif);font-size:25px;letter-spacing:.02em}
.brand .mark b{font-weight:500;font-style:italic;color:var(--gold-soft)}
.brand .sub{font-family:var(--sans);font-size:9px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted-2);margin-top:5px}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:400;transition:color .3s;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .35s}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:22px}
.lang{display:flex;align-items:center;gap:7px;font-size:12px;letter-spacing:.1em;color:var(--muted-2)}
.lang button{background:none;border:none;color:var(--muted-2);font-family:var(--sans);font-size:12px;letter-spacing:.1em;cursor:pointer;padding:2px;transition:color .3s}
.lang button.active{color:var(--gold)}
.lang .div{opacity:.4}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sans);font-weight:500;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;
  padding:15px 30px;border:1px solid var(--red);background:var(--red);color:#fff;cursor:pointer;
  transition:background .35s,border-color .35s,color .35s,transform .35s;
}
.btn:hover{color:#241405;border-color:#cf9f4a;transform:translateY(-2px)}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--text)}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold-soft);background:transparent}
.btn.gold{background:transparent;border-color:var(--gold);color:var(--gold-soft)}
.btn.gold:hover{background:var(--gold);color:#1a1310}
.btn.sm{padding:12px 22px;font-size:11px}
.burger{display:none;background:none;border:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.burger span{width:24px;height:1.5px;background:var(--text);display:block;transition:.3s}

/* ---------- hero ---------- */
.hero{min-height:100vh;display:flex;align-items:center;padding-top:120px;padding-bottom:60px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg image-slot{width:100%;height:100%}
.hero-layout{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:56px;width:100%}
.hero-layout .hero-inner{max-width:none}

/* ---------- compare slider ---------- */
.hero-compare{position:relative;height:520px;border-radius:22px;overflow:hidden;flex-shrink:0;
  box-shadow:0 0 0 1px var(--line),0 24px 64px rgba(0,0,0,.55);user-select:none}
.compare-after,.compare-before{position:absolute;inset:0}
.compare-before{clip-path:inset(0 50% 0 0);z-index:1}
.compare-after image-slot,.compare-before image-slot{width:100%;height:100%;display:block}
.compare-handle{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);
  z-index:2;width:44px;display:flex;align-items:center;justify-content:center;cursor:ew-resize;touch-action:none}
.compare-handle::before{content:"";position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);
  width:2px;background:rgba(255,255,255,.85);box-shadow:0 0 8px rgba(0,0,0,.4)}
.compare-btn{position:relative;z-index:1;width:44px;height:44px;border-radius:50%;
  background:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 12px rgba(0,0,0,.35),0 0 0 1.5px rgba(255,255,255,.6)}
.compare-lbl{position:absolute;top:16px;z-index:3;pointer-events:none;
  font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;
  background:rgba(22,16,16,.65);color:rgba(240,233,228,.9);padding:5px 11px;border-radius:100px;
  backdrop-filter:blur(6px)}
.lbl-before{left:16px}
.lbl-after{right:16px}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(16,11,11,.96) 0%,rgba(16,11,11,.82) 42%,rgba(16,11,11,.42) 100%),
  radial-gradient(120% 80% at 80% 20%,transparent 40%,rgba(16,11,11,.7) 100%);
  z-index:1}
.hero-grain{position:absolute;inset:0;z-index:2;opacity:.5;pointer-events:none;mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E")}
.hero .wrap{position:relative;z-index:3;width:100%}
.hero-inner{max-width:760px}
.hero .display{margin:24px 0 0}
.hero .display .ln2{display:block;color:var(--gold-soft);font-style:italic}
.hero p.lead{font-size:18px;color:var(--muted);max-width:480px;margin:26px 0 38px;font-weight:300}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-meta{position:absolute;right:32px;bottom:46px;z-index:3;text-align:right;display:flex;flex-direction:column;gap:5px}
.hero-meta .k{font-family:var(--serif);font-size:30px;font-style:italic;color:var(--gold-soft);line-height:1}
.hero-meta .l{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted-2)}
.scroll-hint{position:absolute;left:32px;bottom:40px;z-index:3;display:flex;align-items:center;gap:12px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted-2)}
.scroll-hint .bar{width:1px;height:40px;background:linear-gradient(var(--gold),transparent);animation:drop 2.4s infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- marquee strip ---------- */
.strip{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:var(--bg-2);padding:22px 0;overflow:hidden}
.marquee{display:flex;gap:60px;white-space:nowrap;animation:slide 26s linear infinite;width:max-content}
.marquee span{font-family:var(--serif);font-size:24px;font-style:italic;color:var(--muted);display:inline-flex;align-items:center;gap:60px}
.marquee span::after{content:"✦";color:var(--gold);font-style:normal;font-size:13px}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- section frame ---------- */
.section{padding:130px 0}
.section-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px;margin-bottom:70px}
.section-head p.intro{max-width:540px;color:var(--muted);font-size:16.5px}

/* ---------- services (editorial list) ---------- */
.svc-list{display:flex;flex-direction:column;margin-top:6px}
.svc-item{display:grid;grid-template-columns:100px 1fr auto;gap:48px;align-items:center;padding:36px 34px;border-radius:24px;position:relative;transition:background .45s}
.svc-item::after{content:"";position:absolute;left:34px;right:34px;bottom:0;height:1px;background:var(--line-soft);transition:opacity .35s}
.svc-item:last-child::after{display:none}
.svc-item:hover{background:var(--surface)}
.svc-item:hover::after{opacity:0}
.svc-idx{font-family:var(--serif);font-style:italic;font-weight:400;font-size:62px;line-height:.9;color:var(--muted-2);transition:color .4s}
.svc-main h3{font-size:31px;margin-bottom:8px}
.svc-main p{color:var(--muted);font-size:15.5px;max-width:54ch}
.svc-tag{justify-self:end;text-align:right;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2);max-width:180px;line-height:1.8}

/* ---------- softer edges ---------- */
.btn{border-radius:100px}
.quote{border-radius:22px}
.loc-grid{border-radius:26px;overflow:hidden}
.gal-grid image-slot,.insta-grid image-slot{border-radius:18px;overflow:hidden}
.svc-grid{border-radius:24px;overflow:hidden}

/* ---------- gallery ---------- */
.gallery{background:var(--bg-2)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gal-grid image-slot{width:100%;height:100%}
/* masonry columns — respecte l'orientation portrait de chaque photo */
.gal-cols{column-count:3;column-gap:14px}
.gal-img{break-inside:avoid;margin-bottom:14px;border-radius:18px;overflow:hidden}
.gal-img img{width:100%;height:auto;display:block;transition:transform .55s ease}
.gal-img:hover img{transform:scale(1.04)}

/* ---------- pricing (nude) ---------- */
.pricing{background:var(--nude-2);color:var(--nude-ink)}
.pricing .eyebrow{color:#a9733f}
.pricing .eyebrow::before,.pricing .eyebrow.center::after{background:#a9733f;opacity:.6}
.pricing h2{color:var(--nude-ink)}
.pricing .section-head p.intro{color:var(--nude-muted)}
.price-cols{display:grid;grid-template-columns:1fr 1fr;gap:64px}
.price-group h3{font-size:26px;font-style:italic;color:var(--nude-ink);padding-bottom:18px;margin-bottom:10px;border-bottom:1px solid rgba(58,42,36,.18);display:flex;align-items:baseline;gap:12px}
.price-group h3 .ic{font-size:13px;color:#a9733f;font-style:normal;letter-spacing:.2em;text-transform:uppercase}
.price-row{display:flex;align-items:baseline;gap:14px;padding:16px 0;border-bottom:1px solid rgba(58,42,36,.1)}
.price-row .nm{font-size:18px;color:var(--nude-ink);font-weight:400}
.price-row .nm small{display:block;font-size:12.5px;color:var(--nude-muted);letter-spacing:.02em;margin-top:3px;font-weight:300}
.price-row .dots{flex:1;border-bottom:1px dotted rgba(58,42,36,.35);transform:translateY(-4px)}
.price-row .amt{font-family:var(--serif);font-size:23px;font-style:italic;color:#a9733f;white-space:nowrap}
.price-foot{margin-top:48px;text-align:center;color:var(--nude-muted);font-size:13px;letter-spacing:.04em}

/* ---------- testimonials ---------- */
.testi{background:var(--bg)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.quote{border:1px solid var(--line-soft);padding:40px 34px;display:flex;flex-direction:column;gap:24px;transition:border-color .4s,background .4s}
.quote:hover{border-color:var(--line);background:var(--surface)}
.quote .stars{color:var(--gold);letter-spacing:.32em;font-size:13px}
.quote p{font-family:var(--serif);font-size:21px;font-style:italic;line-height:1.45;color:var(--text)}
.quote .by{display:flex;align-items:center;gap:14px;margin-top:auto}
.quote .by .mt{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);}

/* ---------- instagram ---------- */
.insta{background:var(--bg-2)}
.insta-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.insta-grid image-slot{width:100%;aspect-ratio:1;height:auto}
.insta-img{display:block;aspect-ratio:1;overflow:hidden;border-radius:12px}
.insta-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.insta-img:hover img{transform:scale(1.06)}
.insta-handle{display:inline-flex;align-items:center;gap:10px;margin-top:34px;color:var(--gold-soft);font-size:14px;letter-spacing:.1em}

/* ---------- location ---------- */
.loc{background:var(--bg)}
.loc-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border:1px solid var(--line-soft)}
.loc-map{position:relative;min-height:440px;background:var(--surface)}
.loc-map image-slot{width:100%;height:100%;position:absolute;inset:0}
.loc-info{padding:56px 50px;display:flex;flex-direction:column;gap:34px;background:var(--bg-2)}
.loc-block .lab{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.loc-block .val{font-family:var(--serif);font-size:22px;color:var(--text);line-height:1.35}
.loc-block .val.sm{font-size:17px;font-family:var(--sans);font-weight:300;color:var(--muted)}
.hours-row{display:flex;justify-content:space-between;font-size:14px;color:var(--muted);padding:7px 0;border-bottom:1px solid var(--line-soft)}
.hours-row span:last-child{color:var(--text)}

/* ---------- booking CTA ---------- */
.book{padding:150px 0;text-align:center;position:relative;overflow:hidden;background:#140d0c}
.book .wrap{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:30px}
.book h2{font-size:clamp(42px,6.5vw,86px);font-weight:300;max-width:13ch}
.book p{color:var(--muted);max-width:440px;font-size:17px}
.book .micro{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-2);margin-top:6px}

/* ---------- footer ---------- */
footer{background:#0f0a0a;border-top:1px solid var(--line-soft);padding:80px 0 36px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:44px;padding-bottom:56px;border-bottom:1px solid var(--line-soft)}
.foot-brand .mark{font-family:var(--serif);font-size:30px;letter-spacing:.02em}
.foot-brand .mark b{font-style:italic;font-weight:500;color:var(--gold-soft)}
.foot-brand p{color:var(--muted-2);font-size:14px;margin-top:16px;max-width:260px}
.foot-col h4{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;font-family:var(--sans);font-weight:500}
.foot-col a,.foot-col p{display:block;color:var(--muted);font-size:14px;margin-bottom:13px;transition:color .3s}
.foot-col a:hover{color:var(--text)}
.policy{font-size:13px;color:var(--muted-2);line-height:1.7;max-width:280px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;flex-wrap:wrap;gap:14px}
.foot-bottom p{font-size:12px;color:var(--muted-2);letter-spacing:.04em}
.socials{display:flex;gap:10px}
.socials a{width:38px;height:38px;border:1px solid var(--line-soft);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:.35s;border-radius:50%}
.socials a:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.socials svg{width:16px;height:16px}

/* ---------- mobile menu ---------- */
.mobile-menu{position:fixed;inset:0;z-index:49;background:rgba(14,9,9,.97);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;opacity:0;pointer-events:none;transition:opacity .4s}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu a{font-family:var(--serif);font-size:32px;color:var(--text)}
.mobile-menu a:hover{color:var(--gold-soft)}
.mobile-menu .btn{background:transparent;border:none;border-radius:0;color:var(--gold-soft);font-family:var(--serif);font-size:32px;font-weight:400;letter-spacing:normal;padding:0;text-transform:none}
.mobile-menu .btn:hover{background:transparent;border-color:transparent;color:var(--gold);transform:none}

/* ---------- cheetah print ---------- */
.cheetah,
.italic,
.btn:hover,
.svc-item:hover .svc-idx{
  background-color:#cf9f4a;
  background-image:
    radial-gradient(ellipse 17px 13px at 16% 20%, #241405 0 46%, transparent 48%),
    radial-gradient(ellipse 12px 16px at 38% 34%, #241405 0 46%, transparent 48%),
    radial-gradient(ellipse 16px 12px at 64% 18%, #241405 0 46%, transparent 48%),
    radial-gradient(ellipse 12px 15px at 86% 40%, #241405 0 46%, transparent 48%),
    radial-gradient(ellipse 15px 13px at 26% 58%, #241405 0 46%, transparent 48%),
    radial-gradient(ellipse 17px 12px at 52% 70%, #241405 0 46%, transparent 48%),
    radial-gradient(ellipse 12px 14px at 78% 64%, #241405 0 46%, transparent 48%),
    radial-gradient(ellipse 14px 16px at 90% 84%, #241405 0 46%, transparent 48%),
    radial-gradient(ellipse 13px 13px at 8% 86%, #241405 0 46%, transparent 48%),
    radial-gradient(ellipse 15px 12px at 44% 92%, #241405 0 46%, transparent 48%),
    radial-gradient(circle at 32% 36%, #e8c478, #bd8d3a);
  background-size:150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,100% 100%;
}

/* clip any cheetah background to the text itself */
.cheetah-clip,
.italic,
.svc-item:hover .svc-idx{-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* cheetah print inside the wordmark */
.cheetah-text{
  background-color:#d2a04a;
  background-image:
    radial-gradient(ellipse 6px 5px at 14% 20%, #241405 0 45%, transparent 47%),
    radial-gradient(ellipse 5px 6px at 36% 34%, #241405 0 45%, transparent 47%),
    radial-gradient(ellipse 6px 5px at 60% 18%, #241405 0 45%, transparent 47%),
    radial-gradient(ellipse 5px 6px at 84% 38%, #241405 0 45%, transparent 47%),
    radial-gradient(ellipse 6px 5px at 24% 56%, #241405 0 45%, transparent 47%),
    radial-gradient(ellipse 5px 5px at 50% 70%, #241405 0 45%, transparent 47%),
    radial-gradient(ellipse 6px 5px at 76% 62%, #241405 0 45%, transparent 47%),
    radial-gradient(ellipse 5px 6px at 90% 84%, #241405 0 45%, transparent 47%),
    radial-gradient(ellipse 5px 5px at 10% 84%, #241405 0 45%, transparent 47%),
    radial-gradient(ellipse 6px 5px at 44% 92%, #241405 0 45%, transparent 47%),
    radial-gradient(circle at 34% 34%, #efcd86, #bf8e39);
  background-size:42px 42px,42px 42px,42px 42px,42px 42px,42px 42px,42px 42px,42px 42px,42px 42px,42px 42px,42px 42px,100% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  font-weight:500;
}

/* cheetah divider band */
.cheetah-band{height:88px;position:relative;display:flex;align-items:center;justify-content:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background-size:150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,150px 150px,100% 100%}
.cheetah-band::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--bg) 0%,rgba(22,16,16,.15) 16%,rgba(22,16,16,.15) 84%,var(--bg) 100%),linear-gradient(rgba(18,12,11,.40),rgba(18,12,11,.50))}
.cheetah-band .dot{position:relative;z-index:1;width:50px;height:50px;border-radius:50%;background:var(--bg);border:1px solid var(--gold);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:16px}

/* booking cheetah texture */
.book-print{position:absolute;inset:0;z-index:0;background-size:175px 175px,175px 175px,175px 175px,175px 175px,175px 175px,175px 175px,175px 175px,175px 175px,175px 175px,175px 175px,100% 100%}
.book-print::after{content:"";position:absolute;inset:0;background:radial-gradient(78% 130% at 50% 0%,rgba(176,30,60,.30),transparent 55%),linear-gradient(180deg,rgba(18,12,11,.82),rgba(18,12,11,.92))}
.sign-line{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:19px;margin-top:2px}
.signature{font-family:'Pinyon Script',cursive;font-size:58px;color:var(--gold-soft);line-height:.9;margin:2px 0 6px}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .intro-gate{width:min(84vw,430px);height:min(48vh,400px)}
  .intro-cat{width:220px}
  .nav-links{display:none}
  .burger{display:flex}
  .lang{display:none}
  .hero-layout{grid-template-columns:1fr;gap:40px}
  .hero-compare{height:360px}
  .svc-item{grid-template-columns:1fr;gap:14px;padding:30px 22px}
  .svc-tag{justify-self:start;text-align:left;max-width:none}
  .svc-item::after{left:22px;right:22px}
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .gal-cols{column-count:2}
  .price-cols{grid-template-columns:1fr;gap:48px}
  .testi-grid{grid-template-columns:1fr}
  .insta-grid{grid-template-columns:repeat(3,1fr)}
  .loc-grid{grid-template-columns:1fr}
  .loc-map{min-height:320px}
  .section-head{margin-bottom:50px}
  .foot-top{grid-template-columns:1fr 1fr;gap:36px}
  .hero-meta{display:none}
  .nav-right .btn{display:none}
}
@media(max-width:560px){
  .intro-screen{padding:18px}
  .intro-scene{gap:12px}
  .intro-copy{font-size:14px}
  .intro-gate{height:min(44vh,300px)}
  .intro-door{height:74%}
  .intro-cat{width:160px}
  .wrap{padding:0 20px}
  .nav-inner{padding:14px 20px}
  .hero{padding-top:88px;padding-bottom:48px}
  .hero-compare{height:260px}
  .hero-cta{flex-direction:column;gap:12px}
  .hero-cta .btn{width:100%;justify-content:center}
  .scroll-hint{display:none}
  .section{padding:72px 0}
  .section-head{gap:14px;margin-bottom:36px}
  .h2{font-size:clamp(28px,8vw,38px)}
  .svc-idx{font-size:44px}
  .svc-item{padding:22px 16px;gap:10px}
  .svc-item::after{left:16px;right:16px}
  .gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:130px}
  .gal-cols{column-count:2}
  .insta-grid{grid-template-columns:repeat(2,1fr)}
  .loc-map{min-height:240px}
  .loc-info{padding:28px 20px;gap:22px}
  .book{padding:88px 0}
  .foot-top{grid-template-columns:1fr}
  .foot-brand .mark{font-size:26px}
}
