/* ============================================================
   ENIGMA — Hidden Cocktail Bar · La Reina, Santiago
   Built on the Enigma Bar Design System
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700&family=Cinzel+Decorative:wght@400;700;900&family=Cormorant:wght@300;400;500&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600&family=Inter:wght@400;500&display=swap');

:root{
  /* core palette */
  --teal-900:#061F23; --teal-800:#0B373C; --teal-700:#124249; --teal-600:#1A525A;
  --gold-700:#8A6A32; --gold-600:#A38142; --gold-500:#C4A15A; --gold-400:#D9BE7C; --gold-300:#EBD6A0;
  --ink-900:#0A0A0B; --ink-800:#1A1A1C;
  --crimson-900:#2A0609; --crimson-800:#4A0E13; --crimson-700:#6B1119; --crimson-600:#8A1A22; --crimson-500:#A83039;
  --amber-500:#B87A2E; --amber-400:#D99A4A; --copper-500:#9C5A2C;
  --parchment-50:#F5EEDD;
  --fg-1:#F2E9D0; --fg-2:#C9BFA6; --fg-3:#8C8675; --fg-muted:#5E5A4F;

  --font-display:'Cinzel Decorative','Trajan Pro',serif;
  --font-heading:'Cinzel',serif;
  --font-serif:'Cormorant Garamond','Garamond',serif;
  --font-ui:'Inter',system-ui,sans-serif;

  --container:1320px;
  --gutter:clamp(20px,5vw,72px);

  /* tweakable atmosphere */
  --grain-opacity:0.05;
  --atmos-opacity:1;
  --accent:var(--gold-500);

  --ease-soft:cubic-bezier(.22,1,.36,1);
  --ease-mech:cubic-bezier(.65,.05,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; background:var(--teal-900); color:var(--fg-1);
  font-family:var(--font-serif); font-size:18px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block; max-width:100%;}
a{color:inherit; text-decoration:none;}
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;}

/* ---------- bilingual ---------- */
[data-lang]{display:none;}
body.lang-es [data-lang="es"]{display:revert;}
body.lang-en [data-lang="en"]{display:revert;}

/* ---------- film grain ---------- */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:900;
  opacity:var(--grain-opacity); mix-blend-mode:overlay;
  background-image:
    radial-gradient(rgba(255,255,255,.55) 1px,transparent 1px),
    radial-gradient(rgba(0,0,0,.55) 1px,transparent 1px);
  background-size:3px 3px,3px 3px; background-position:0 0,1.5px 1.5px;
}
/* tungsten atmosphere */
body::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1;
  opacity:var(--atmos-opacity);
  background:
    radial-gradient(ellipse 60% 32% at 50% 0%, rgba(184,122,46,.12), transparent 70%),
    radial-gradient(ellipse 72% 24% at 50% 100%, rgba(107,17,25,.16), transparent 72%);
}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--container); margin:0 auto; padding-inline:var(--gutter); position:relative; z-index:2;}
.section{padding-block:clamp(80px,12vh,150px); position:relative; z-index:2;}
.section-tight{padding-block:clamp(56px,8vh,96px);}

/* ---------- type ---------- */
.wordmark{
  font-family:var(--font-display); font-weight:900; text-transform:uppercase;
  letter-spacing:.16em; line-height:1; color:var(--fg-1);
}
.eyebrow{
  font-family:var(--font-heading); font-weight:500; font-size:clamp(10px,1.1vw,12px);
  letter-spacing:.34em; text-transform:uppercase; color:var(--accent);
  display:inline-flex; align-items:center; gap:14px;
}
.eyebrow::before,.eyebrow::after{content:""; width:34px; height:1px; background:currentColor; opacity:.55;}
.eyebrow.solo::after{display:none;}
.eyebrow.solo::before{display:none;}
.numeral{
  font-family:var(--font-heading); font-weight:500; font-size:13px; letter-spacing:.3em;
  color:var(--gold-600); text-transform:uppercase;
}
.t-display{
  font-family:var(--font-heading); font-weight:500; text-transform:uppercase;
  font-size:clamp(64px,15vw,210px); line-height:.92; letter-spacing:.2em; color:var(--fg-1);
  text-indent:.2em;
  background:linear-gradient(180deg,#F2E9D0 0%,#EBD6A0 55%,#C4A15A 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
h1,h2,h3{margin:0; font-weight:400;}
.h-xl{
  font-family:var(--font-heading); font-weight:600; text-transform:uppercase;
  font-size:clamp(34px,5vw,68px); line-height:1.06; letter-spacing:.08em; color:var(--fg-1);
}
.h-lg{
  font-family:var(--font-heading); font-weight:600; text-transform:uppercase;
  font-size:clamp(26px,3.4vw,44px); line-height:1.1; letter-spacing:.09em; color:var(--fg-1);
}
.h-md{
  font-family:var(--font-heading); font-weight:500; text-transform:uppercase;
  font-size:clamp(18px,2vw,24px); line-height:1.15; letter-spacing:.12em; color:var(--fg-1);
}
.italic{
  font-family:var(--font-serif); font-style:italic; font-weight:500; text-transform:none;
  letter-spacing:.01em; color:var(--gold-400);
}
.lede{font-family:var(--font-serif); font-style:italic; font-weight:300; font-size:clamp(20px,2.4vw,30px); line-height:1.5; color:var(--fg-2);}
.body{font-family:var(--font-serif); font-size:clamp(17px,1.3vw,19px); line-height:1.66; color:var(--fg-2);}
.body.dim{color:var(--fg-3);}
.cap{font-family:var(--font-heading); font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:var(--fg-3);}
.measure{max-width:46ch;}

/* ---------- ornamental rule ---------- */
.rule{display:flex; align-items:center; justify-content:center; gap:16px; color:var(--gold-600); max-width:340px; margin-inline:auto;}
.rule::before,.rule::after{content:""; flex:1; height:1px; background:linear-gradient(90deg,transparent,currentColor,transparent);}
.rule .dot{width:5px; height:5px; background:currentColor; transform:rotate(45deg);}
.rule .dot::before,.rule .dot::after{content:""; position:absolute;}

/* draw-in gold rule used in reveals */
.draw-rule{height:1px; background:linear-gradient(90deg,transparent,var(--gold-500),transparent); transform:scaleX(0); transform-origin:center; transition:transform 1100ms var(--ease-soft);}
.reveal.in .draw-rule{transform:scaleX(1);}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--font-heading); font-weight:500; font-size:12px; letter-spacing:.24em; text-transform:uppercase;
  padding:17px 30px; border:1px solid transparent; cursor:pointer; display:inline-flex; align-items:center; gap:10px;
  transition:all 260ms var(--ease-soft); background:transparent; border-radius:1px;
}
.btn-primary{background:var(--gold-600); color:var(--teal-900); border-color:var(--gold-600);}
.btn-primary:hover{background:var(--gold-500); border-color:var(--gold-400); box-shadow:0 0 0 1px rgba(196,161,90,.35),0 0 30px rgba(196,161,90,.28);}
.btn-primary:active{transform:scale(.985); background:var(--gold-700);}
.btn-ghost{color:var(--gold-400); border-color:var(--gold-600);}
.btn-ghost:hover{color:var(--fg-1); border-color:var(--gold-400); letter-spacing:.27em;}
.link{
  font-family:var(--font-heading); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-500);
  border-bottom:1px solid var(--gold-700); padding-bottom:3px; transition:all 200ms; display:inline-block;
}
.link:hover{color:var(--gold-300); border-color:var(--gold-400);}

/* ---------- reveal animation ---------- */
.reveal{opacity:0; transform:translateY(26px); transition:opacity 900ms var(--ease-soft), transform 1100ms var(--ease-soft);}
.reveal.in{opacity:1; transform:none;}
.reveal.d1{transition-delay:.12s;} .reveal.d2{transition-delay:.24s;} .reveal.d3{transition-delay:.36s;} .reveal.d4{transition-delay:.48s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1; transform:none; transition:none;} .draw-rule{transform:scaleX(1);}}

/* ---------- framed image ---------- */
.framed{position:relative;}
.framed::before{content:""; position:absolute; inset:-16px -16px 16px 16px; border:1px solid rgba(196,161,90,.28); z-index:0; pointer-events:none;}
.framed img{position:relative; z-index:1;}
.img-cover{width:100%; height:100%; object-fit:cover;}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:800; height:84px;
  display:flex; align-items:center; justify-content:space-between; padding-inline:var(--gutter);
  transition:background 400ms var(--ease-soft), border-color 400ms, height 400ms;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  height:70px; background:rgba(6,31,35,.72); backdrop-filter:blur(18px) saturate(130%);
  -webkit-backdrop-filter:blur(18px) saturate(130%); border-bottom:1px solid rgba(196,161,90,.16);
}
.nav-logo{display:flex; align-items:center; gap:12px;}
.nav-logo img{height:38px; width:auto; transition:height 400ms;}
.nav.scrolled .nav-logo img{height:32px;}
.nav-logo .wm{font-family:var(--font-heading); font-weight:600; font-size:16px; letter-spacing:.4em; color:var(--fg-1); padding-left:4px;}
.nav-links{display:flex; gap:34px; align-items:center;}
.nav-links a{font-family:var(--font-heading); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--fg-2); transition:color 200ms; position:relative; padding-block:6px;}
.nav-links a::after{content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--gold-500); transition:width 280ms var(--ease-soft);}
.nav-links a:hover{color:var(--fg-1);} .nav-links a:hover::after{width:100%;}
.nav-right{display:flex; align-items:center; gap:20px;}
.lang{display:inline-flex; align-items:center; gap:2px; font-family:var(--font-ui); font-size:11px; letter-spacing:.08em; color:var(--fg-3);}
.lang button{background:none; border:none; color:var(--fg-3); cursor:pointer; font:inherit; padding:4px 5px; transition:color 200ms;}
.lang button.active{color:var(--gold-400);}
.lang button:hover{color:var(--fg-1);}
.lang .sep{opacity:.4;}
.nav-cta{font-family:var(--font-heading); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--teal-900); background:var(--gold-500); padding:11px 20px; transition:all 240ms var(--ease-soft); border:1px solid var(--gold-500);}
.nav-cta:hover{background:var(--gold-400); box-shadow:0 0 24px rgba(196,161,90,.28);}
.nav-burger{display:none; background:none; border:none; color:var(--fg-1); cursor:pointer; padding:8px;}

@media(max-width:980px){
  .nav-links{display:none;}
  .nav-burger{display:block;}
}
@media(max-width:560px){
  .nav-logo .wm{display:none;}
  .nav-right{gap:10px;}
  .nav-cta{padding:9px 13px; font-size:10px; letter-spacing:.12em;}
  .lang{gap:0;}
  .lang button{padding:4px 3px;}
  .nav-burger{padding:6px 0 6px 2px;}
}
@media(max-width:380px){
  .nav-cta{display:none;}
}

/* mobile menu */
.mobile-menu{position:fixed; inset:0; z-index:790; background:rgba(6,31,35,.97); backdrop-filter:blur(8px); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:26px; opacity:0; pointer-events:none; transition:opacity 360ms var(--ease-soft);}
.mobile-menu.open{opacity:1; pointer-events:auto;}
.mobile-menu a{font-family:var(--font-heading); font-size:18px; letter-spacing:.2em; text-transform:uppercase; color:var(--fg-1);}

/* ============================================================
   LOCATION PUZZLE (Fibonacci → address + map)
   ============================================================ */
.loc-riddle{font-family:var(--font-serif); font-style:italic; font-size:15px; color:var(--fg-3); line-height:1.5; margin:0 0 14px;}
.loc-seq{display:flex; align-items:center; gap:7px; flex-wrap:wrap;}
.loc-seq .sq{font-family:var(--font-heading); font-weight:500; font-size:18px; color:var(--fg-1); font-variant-numeric:tabular-nums;}
.loc-seq .dt{color:var(--gold-600); font-size:13px;}
.loc-seq .sq-in{width:50px; background:rgba(6,31,35,.5); border:1px solid var(--gold-600); border-radius:2px; color:var(--gold-300); padding:7px 4px; text-align:center; outline:none; font-family:var(--font-heading); font-size:18px; -moz-appearance:textfield; transition:border-color 200ms, box-shadow 200ms;}
.loc-seq .sq-in::placeholder{color:var(--gold-700);}
.loc-seq .sq-in:focus{border-color:var(--gold-400); box-shadow:0 0 0 1px rgba(196,161,90,.3);}
.loc-go{margin-left:4px; background:var(--gold-600); color:var(--teal-900); border:none; border-radius:2px; width:34px; height:34px; cursor:pointer; font-size:16px; line-height:1; transition:background 200ms;}
.loc-go:hover{background:var(--gold-500);}
.loc-puzzle.shake{animation:shake 460ms var(--ease-mech);}
@keyframes shake{10%,90%{transform:translateX(-2px);}20%,80%{transform:translateX(3px);}30%,50%,70%{transform:translateX(-6px);}40%,60%{transform:translateX(6px);}}
.loc-puzzle.wrong .sq-in{border-color:var(--crimson-500); box-shadow:0 0 0 1px rgba(168,48,57,.4);}
.loc-hintbtn{background:none; border:none; cursor:pointer; font-family:var(--font-heading); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--fg-3); padding:12px 0 0; transition:color 200ms;}
.loc-hintbtn:hover{color:var(--gold-400);}
.loc-hint{font-family:var(--font-serif); font-style:italic; font-size:14px; color:var(--gold-400); margin:8px 0 0; max-height:0; opacity:0; overflow:hidden; transition:max-height 500ms var(--ease-soft), opacity 500ms;}
.loc-hint.show{max-height:60px; opacity:1;}
.loc-reveal{animation:locFade 800ms var(--ease-soft);}
@keyframes locFade{from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:none;}}
.map-reveal{margin-top:clamp(34px,5vh,60px); border:1px solid rgba(196,161,90,.22); overflow:hidden; position:relative; z-index:2; animation:locFade 900ms var(--ease-soft);}
.map-reveal iframe{display:block; width:100%; height:380px; border:0; filter:grayscale(.35) contrast(1.05) brightness(.92);}
@media(max-width:680px){.map-reveal iframe{height:300px;}}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden;}
.hero-bg{position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; animation:kenburns 24s ease-in-out infinite alternate;}
@keyframes kenburns{from{transform:scale(1.04) translateY(0);} to{transform:scale(1.14) translateY(-2%);}}
.hero-scrim{position:absolute; inset:0; z-index:1; background:
  linear-gradient(180deg, rgba(6,31,35,.55) 0%, rgba(6,31,35,.22) 32%, rgba(6,31,35,.62) 78%, rgba(6,31,35,.95) 100%),
  radial-gradient(ellipse 80% 60% at 50% 42%, transparent 0%, rgba(6,31,35,.55) 100%);}
.hero-inner{position:relative; z-index:3; text-align:center; width:100%; padding-top:84px; padding-bottom:140px;}
.hero .eyebrow{justify-content:center;}
.hero-supp{font-family:var(--font-serif); font-style:italic; font-weight:300; font-size:clamp(17px,1.7vw,22px); color:var(--fg-2); max-width:30ch; margin:22px auto 0;}
.hero-cta{display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin-top:42px;}
.hero-strip{position:absolute; bottom:0; left:0; right:0; z-index:4; display:flex; justify-content:space-between; gap:18px; align-items:center;
  padding:18px var(--gutter); font-family:var(--font-heading); font-size:10px; letter-spacing:.26em; text-transform:uppercase; color:var(--gold-500);
  background:linear-gradient(0deg, rgba(6,31,35,.92), transparent);}
.hero-strip .mid{color:var(--fg-3);}
.scroll-cue{position:absolute; left:50%; bottom:54px; transform:translateX(-50%); z-index:4; display:flex; flex-direction:column; align-items:center; gap:10px; color:var(--gold-500);}
.scroll-cue .line{width:1px; height:46px; background:linear-gradient(180deg,var(--gold-500),transparent); animation:cue 2.6s ease-in-out infinite;}
@keyframes cue{0%,100%{opacity:.3; transform:scaleY(.7);} 50%{opacity:1; transform:scaleY(1);}}
@media(max-width:760px){.hero-strip{flex-direction:column; gap:6px; font-size:9px; text-align:center; padding-bottom:14px;} .scroll-cue{display:none;} .hero-inner{padding-bottom:170px;}}

/* ============================================================
   SECTION HEADER
   ============================================================ */
.shead{display:flex; flex-direction:column; align-items:center; text-align:center; gap:18px; margin-bottom:clamp(48px,7vh,84px);}
.shead .numeral{margin-bottom:2px;}

/* ---------- The Experience ---------- */
.exp-intro{display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,96px); align-items:end; margin-bottom:clamp(60px,9vh,110px);}
.exp-grid{display:grid; gap:1px; background:rgba(196,161,90,.16); border:1px solid rgba(196,161,90,.16);}
.exp-card{background:var(--teal-900); padding:0; display:flex; flex-direction:column;}
.exp-card .ph{position:relative; aspect-ratio:4/3; overflow:hidden;}
.exp-card .ph img{width:100%; height:100%; object-fit:cover; transition:transform 1.4s var(--ease-soft); filter:brightness(.86);}
.exp-card:hover .ph img{transform:scale(1.06);}
.exp-card .ph .tag{position:absolute; top:18px; left:18px; z-index:2;}
.exp-card .bd{padding:clamp(26px,3vw,40px); display:flex; flex-direction:column; gap:16px;}
.exp-card .idx{font-family:var(--font-display); font-weight:700; font-size:15px; color:var(--gold-600); letter-spacing:.1em;}
@media(max-width:860px){.exp-intro{grid-template-columns:1fr;} .exp-grid{grid-template-columns:1fr !important;}}

/* ============================================================
   HOUSE OF ENIGMA (full-bleed crimson)
   ============================================================ */
.house{position:relative; overflow:hidden; background:linear-gradient(180deg,var(--teal-900),rgba(74,14,19,.42) 50%,var(--teal-900));}
.house-grid{display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(40px,6vw,90px); align-items:center;}
.house-stats{display:flex; gap:clamp(24px,4vw,56px); flex-wrap:wrap; margin-top:40px; padding-top:32px; border-top:1px solid rgba(196,161,90,.2);}
.stat .n{font-family:var(--font-display); font-weight:900; font-size:clamp(40px,4.6vw,60px); color:var(--gold-400); line-height:1;}
.stat .l{font-family:var(--font-heading); font-size:10px; letter-spacing:.26em; text-transform:uppercase; color:var(--fg-3); margin-top:10px;}
@media(max-width:860px){.house-grid{grid-template-columns:1fr;}}

/* quote band */
.quote-band{position:relative; padding-block:clamp(110px,18vh,190px); overflow:hidden; text-align:center;}
.quote-band .qbg{position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; filter:brightness(.42);}
.quote-band .qscrim{position:absolute; inset:0; z-index:1; background:radial-gradient(ellipse at center, rgba(6,31,35,.3), rgba(6,31,35,.92));}
.quote-band .qinner{position:relative; z-index:2; max-width:880px; margin-inline:auto;}
.qmark{font-family:var(--font-serif); font-style:italic; font-weight:300; font-size:clamp(26px,3.6vw,46px); line-height:1.42; color:var(--fg-1);}

/* ============================================================
   SIGNATURE MENU
   ============================================================ */
.menu-feature{display:grid; grid-template-columns:0.6fr 1.4fr; gap:0; align-items:stretch; border:1px solid rgba(196,161,90,.2);}
.menu-feature .mf-img{position:relative; min-height:210px; overflow:hidden;}
.menu-feature .mf-img img{width:100%; height:100%; object-fit:cover;}
.menu-feature .mf-bd{padding:clamp(18px,2.4vw,34px); display:flex; flex-direction:column; justify-content:center; gap:9px; background:var(--teal-800);}
.menu-feature .mf-bd .body{font-size:clamp(15px,1.25vw,17px); line-height:1.55;}
.menu-feature .mf-bd .cap{margin-bottom:2px;}
.menu-list{display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(24px,4vw,56px); margin-top:clamp(48px,7vh,80px);}
.mrow{display:flex; flex-direction:column; gap:14px;}
.mitem{display:grid; grid-template-columns:1fr auto; align-items:baseline; gap:14px; padding-bottom:18px; border-bottom:1px solid rgba(196,161,90,.14);}
.mitem .nm{font-family:var(--font-serif); font-style:italic; font-weight:600; font-size:clamp(20px,1.7vw,24px); color:var(--fg-1); line-height:1.2;}
.mitem .fl{font-family:var(--font-heading); font-style:normal; font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-500); border:1px solid rgba(196,161,90,.32); padding:3px 7px; margin-left:10px; vertical-align:middle; white-space:nowrap;}
.mitem .ds{font-family:var(--font-serif); font-size:15px; color:var(--fg-3); line-height:1.45; margin-top:4px;}
.mitem .pr{font-family:var(--font-heading); font-size:15px; letter-spacing:.06em; color:var(--gold-400); font-variant-numeric:tabular-nums; white-space:nowrap;}
.mitem.incognito .nm{color:var(--fg-2); font-style:italic;}
.mitem.incognito .fl{color:var(--fg-3); border-color:rgba(196,161,90,.22);}
.mitem .seal{display:inline-flex; align-items:center; justify-content:center; width:24px; height:24px; border:1px solid var(--gold-600); border-radius:50%; font-family:var(--font-display); font-weight:700; font-size:12px; color:var(--gold-500); margin-right:12px; vertical-align:middle; flex:0 0 auto;}
.mitem.incognito{opacity:.92;}
.mitem.incognito .nmwrap{display:flex; align-items:center;}
.mcat-head{font-family:var(--font-heading); font-weight:600; font-size:13px; letter-spacing:.26em; text-transform:uppercase; color:var(--gold-500); padding-bottom:18px; border-bottom:1px solid rgba(196,161,90,.3); margin-bottom:6px; display:flex; align-items:center; justify-content:space-between;}
.mcat-head .ct{font-family:var(--font-serif); font-style:italic; letter-spacing:0; text-transform:none; color:var(--fg-3); font-size:14px;}
@media(max-width:860px){.menu-feature{grid-template-columns:1fr;} .menu-feature .mf-img{min-height:200px;} .menu-list{grid-template-columns:1fr;}}

/* signature gallery (Galería de Autor) */
.autor-gal{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:clamp(36px,5vh,56px);}
.agc{display:flex; flex-direction:column; border:1px solid rgba(196,161,90,.18); background:var(--teal-800); transition:border-color 400ms var(--ease-soft), transform 400ms var(--ease-soft);}
.agc:hover{border-color:var(--gold-500); transform:translateY(-5px);}
.agc .ph{position:relative; aspect-ratio:3/4; overflow:hidden;}
.agc .ph img{width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.4s var(--ease-soft); filter:brightness(.92);}
.agc:hover .ph img{transform:scale(1.06); filter:brightness(1);}
.agc .ph image-slot{width:100%; height:100%; display:block;}
.agc-fl{position:absolute; top:14px; left:14px; z-index:2; font-family:var(--font-heading); font-size:9px; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-300); border:1px solid rgba(196,161,90,.42); padding:4px 9px; background:rgba(6,31,35,.5); backdrop-filter:blur(4px);}
.agc .bd{padding:22px 20px 26px; display:flex; flex-direction:column; gap:10px;}
.agc-nm{font-family:var(--font-serif); font-style:italic; font-weight:600; font-size:clamp(19px,1.4vw,23px); color:var(--fg-1); line-height:1.22; margin:0;}
.agc-ds{font-size:15px !important; color:var(--fg-2); line-height:1.5;}
.agc-fin{font-family:var(--font-heading); font-size:9.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-500); margin:2px 0 0;}
@media(max-width:980px){.autor-gal{grid-template-columns:1fr 1fr;}}
@media(max-width:540px){.autor-gal{grid-template-columns:1fr;}}

/* Tangata Manu — Tiki feature */
.tiki-feature{display:grid; grid-template-columns:1.5fr .85fr; gap:0; align-items:stretch; border:1px solid rgba(196,161,90,.22); margin-top:clamp(36px,5vh,56px); background:var(--teal-800);}
.tiki-feature .tf-bd{padding:clamp(30px,4vw,58px); display:flex; flex-direction:column; justify-content:center; gap:14px;}
.tiki-feature .tf-img{position:relative; overflow:hidden; background:var(--ink-900); display:flex; align-items:center; justify-content:center; padding:clamp(20px,2.5vw,40px);}
.tiki-feature .tf-img img{width:auto; max-width:100%; max-height:360px; height:auto; object-fit:contain;}
.tiki-ing{font-family:var(--font-serif); font-style:italic; font-size:clamp(15px,1.3vw,18px); line-height:1.6; color:var(--gold-300); margin:8px 0 0; padding-top:16px; border-top:1px solid rgba(196,161,90,.2);}
@media(max-width:860px){.tiki-feature{grid-template-columns:1fr;} .tiki-feature .tf-img{order:-1; padding:24px;} .tiki-feature .tf-img img{max-height:300px;}}

/* ============================================================
   LA CARTA — teaser (home)
   ============================================================ */
.carta-teaser{display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:center; margin-top:clamp(40px,6vh,72px);}
.carta-teaser .ct-img{aspect-ratio:4/5;}
.carta-teaser .ct-img img{width:100%; height:100%; object-fit:cover;}
.carta-teaser .ct-bd{display:flex; flex-direction:column; gap:18px;}
@media(max-width:860px){.carta-teaser{grid-template-columns:1fr; gap:30px;} .carta-teaser .ct-img{aspect-ratio:16/10;}}

/* ============================================================
   ORIGEN DE LOS ENIGMAS — carousel
   ============================================================ */
.origen{position:relative; overflow:hidden; background:linear-gradient(180deg,var(--teal-900),rgba(74,14,19,.22) 50%,var(--teal-900));}
.origen-viewport{position:relative;}
.origen-track{display:flex; gap:0; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; -ms-overflow-style:none; border:1px solid rgba(196,161,90,.22);}
.origen-track::-webkit-scrollbar{display:none;}
.origen-slide{flex:0 0 100%; scroll-snap-align:center; display:grid; grid-template-columns:1.08fr 1fr; min-height:540px; background:var(--teal-800);}
.origen-slide .os-img{position:relative; overflow:hidden; background:var(--ink-900);}
.origen-slide .os-img img{width:100%; height:100%; object-fit:cover; filter:brightness(.9);}
.origen-slide .os-img::after{content:""; position:absolute; inset:0; background:linear-gradient(90deg,transparent 60%,rgba(11,55,60,.55));}
.origen-slide .os-bd{padding:clamp(34px,4.4vw,72px); display:flex; flex-direction:column; justify-content:center; gap:18px;}
.os-eyebrow{font-family:var(--font-heading); font-weight:500; font-size:clamp(10px,1.1vw,12px); letter-spacing:.3em; text-transform:uppercase; color:var(--gold-500); display:flex; align-items:center; gap:12px;}
.os-eyebrow::before{content:""; width:30px; height:1px; background:currentColor; opacity:.55;}
.os-title{font-family:var(--font-serif); font-style:italic; font-weight:600; font-size:clamp(30px,3.6vw,50px); line-height:1.08; color:var(--fg-1);}
.os-story{font-family:var(--font-serif); font-size:clamp(16px,1.35vw,19px); line-height:1.62; color:var(--fg-2); max-width:46ch;}
.os-story + .os-story{color:var(--fg-3); font-size:clamp(15px,1.25vw,17.5px);}
.os-sign{font-family:var(--font-serif); font-style:italic; font-size:clamp(15px,1.4vw,18px); color:var(--gold-400); padding-top:16px; border-top:1px solid rgba(196,161,90,.2); display:flex; align-items:center; gap:12px;}
.os-sign::before{content:"❦"; font-style:normal; color:var(--gold-600);}
/* atmospheric panel (no photo) */
.os-img.os-atmos{display:flex; align-items:center; justify-content:center; background:
  radial-gradient(ellipse 80% 60% at 50% 40%, rgba(26,82,90,.6), transparent 70%),
  radial-gradient(circle at 50% 120%, rgba(107,17,25,.35), transparent 60%),
  var(--teal-900);}
.os-atmos .os-glyph{font-family:var(--font-display); font-weight:900; font-size:clamp(120px,20vw,260px); line-height:1; color:rgba(196,161,90,.12); letter-spacing:.05em; user-select:none;}
.os-atmos .os-glyph-sub{position:absolute; bottom:clamp(24px,4vh,48px); left:0; right:0; text-align:center; font-family:var(--font-heading); font-size:10px; letter-spacing:.34em; text-transform:uppercase; color:var(--gold-600);}
.origen-slide .os-img::after{pointer-events:none;}
/* controls */
.origen-nav{display:flex; align-items:center; justify-content:center; gap:clamp(20px,3vw,40px); margin-top:clamp(28px,4vh,44px);}
.origen-arrow{width:50px; height:50px; border:1px solid var(--gold-600); background:transparent; color:var(--gold-400); cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 240ms var(--ease-soft); border-radius:1px; flex:0 0 auto;}
.origen-arrow:hover{background:var(--gold-600); color:var(--teal-900); box-shadow:0 0 24px rgba(196,161,90,.28);}
.origen-arrow:active{transform:scale(.96);}
.origen-arrow:disabled{opacity:.32; cursor:not-allowed; box-shadow:none; background:transparent; color:var(--gold-600);}
.origen-counter{font-family:var(--font-heading); font-size:13px; letter-spacing:.28em; text-transform:uppercase; color:var(--fg-3); font-variant-numeric:tabular-nums; min-width:84px; text-align:center;}
.origen-counter .cur{color:var(--gold-400);}
.origen-dots{display:flex; gap:10px; justify-content:center; margin-top:22px;}
.origen-dots button{width:8px; height:8px; padding:0; border:1px solid var(--gold-600); background:transparent; transform:rotate(45deg); cursor:pointer; transition:all 240ms var(--ease-soft);}
.origen-dots button.active{background:var(--gold-500); border-color:var(--gold-400);}
.origen-dots button:hover{border-color:var(--gold-400);}
@media(max-width:860px){
  .origen-slide{grid-template-columns:1fr; min-height:0;}
  .origen-slide .os-img{order:-1; aspect-ratio:4/3;}
  .origen-slide .os-img::after{background:linear-gradient(180deg,transparent 55%,rgba(11,55,60,.6));}
  .os-atmos{aspect-ratio:4/3;}
}

/* ============================================================
   SPACES gallery
   ============================================================ */
.spaces-grid{display:grid; grid-template-columns:repeat(12,1fr); gap:14px; grid-auto-rows:200px;}
.sp{position:relative; overflow:hidden; border:1px solid rgba(196,161,90,.16);}
.sp img{width:100%; height:100%; object-fit:cover; transition:transform 1.5s var(--ease-soft); filter:brightness(.82);}
.sp:hover img{transform:scale(1.07); filter:brightness(1);}
.sp .cap2{position:absolute; left:0; right:0; bottom:0; padding:22px 18px 14px; z-index:2; background:linear-gradient(0deg,rgba(6,31,35,.92),transparent); font-family:var(--font-heading); font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-400); opacity:0; transform:translateY(8px); transition:all 420ms var(--ease-soft);}
.sp:hover .cap2{opacity:1; transform:none;}
.sp-a{grid-column:span 5; grid-row:span 2;}
.sp-b{grid-column:span 7; grid-row:span 2;}
.sp-c{grid-column:span 4; grid-row:span 2;}
.sp-d{grid-column:span 4; grid-row:span 2;}
.sp-e{grid-column:span 4; grid-row:span 2;}
@media(max-width:860px){.spaces-grid{grid-template-columns:1fr 1fr; grid-auto-rows:160px;} .sp-a,.sp-b,.sp-c,.sp-d,.sp-e{grid-column:span 1; grid-row:span 1;} .sp-a{grid-column:span 2; grid-row:span 2;}}

/* named salones */
.salon-feature{position:relative; overflow:hidden; border:1px solid rgba(196,161,90,.22); margin-bottom:22px;}
.salon-feature img{width:100%; height:clamp(360px,58vh,660px); object-fit:cover; display:block;}
.salon-feature .lbl{position:absolute; left:0; bottom:0; padding:30px clamp(24px,4vw,48px); z-index:2; background:linear-gradient(0deg,rgba(6,31,35,.92),transparent);}
.salones{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
.salon{display:flex; flex-direction:column; border:1px solid rgba(196,161,90,.16); background:var(--teal-800); transition:border-color 360ms var(--ease-soft), transform 360ms var(--ease-soft);}
.salon:hover{border-color:var(--gold-500); transform:translateY(-4px);}
.salon .ph{position:relative; aspect-ratio:4/5; overflow:hidden;}
.salon .ph img{width:100%; height:100%; object-fit:cover; transition:transform 1.5s var(--ease-soft); filter:brightness(.9);}
.salon:hover .ph img{transform:scale(1.06); filter:brightness(1);}
.salon .ph .num{position:absolute; top:16px; left:16px; z-index:2; font-family:var(--font-display); font-weight:700; font-size:14px; color:var(--gold-300); letter-spacing:.1em; text-shadow:0 1px 6px rgba(0,0,0,.7);}
.salon .bd{padding:22px clamp(18px,2vw,26px) 26px; display:flex; flex-direction:column; gap:10px;}
.coming{position:relative; overflow:hidden; margin-top:22px; border:1px solid rgba(196,161,90,.3); padding:clamp(34px,5vw,60px) clamp(24px,4vw,48px); text-align:center; background:linear-gradient(180deg,rgba(74,14,19,.3),rgba(6,31,35,.5));}
.coming::after{content:""; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 120%, rgba(196,161,90,.12), transparent 60%); pointer-events:none;}

/* countdown */
.countdown{display:flex; align-items:flex-start; justify-content:center; gap:clamp(10px,2vw,22px); margin:34px 0 8px;}
.cd-unit{display:flex; flex-direction:column; align-items:center; gap:8px; min-width:clamp(56px,9vw,92px);}
.cd-n{font-family:var(--font-display); font-weight:700; font-size:clamp(34px,5.4vw,64px); line-height:1; color:var(--gold-400); font-variant-numeric:tabular-nums;}
.cd-l{font-family:var(--font-heading); font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--fg-3);}
.cd-sep{font-family:var(--font-display); font-weight:700; font-size:clamp(28px,4.4vw,52px); line-height:1; color:var(--gold-700); padding-top:2px;}
@media(max-width:560px){.cd-sep{display:none;} .countdown{gap:14px 18px; flex-wrap:wrap;}}

/* waitlist form */
.wait-form{margin-top:30px;}
.wait-row{display:flex; gap:10px; justify-content:center; flex-wrap:wrap; max-width:480px; margin-inline:auto;}
.wait-input{flex:1; min-width:220px; background:rgba(6,31,35,.5); border:1px solid var(--gold-700); border-radius:2px; color:var(--fg-1); font-family:var(--font-serif); font-size:17px; padding:14px 16px; outline:none; transition:border-color 220ms, box-shadow 220ms;}
.wait-input::placeholder{color:var(--fg-muted);}
.wait-input:focus{border-color:var(--gold-400); box-shadow:0 0 0 1px rgba(196,161,90,.3);}
.wait-msg{font-family:var(--font-serif); font-style:italic; font-size:16px; color:var(--gold-400); margin:16px 0 0; min-height:1.2em; opacity:0; transition:opacity 400ms var(--ease-soft);}
.wait-msg.show{opacity:1;}
@media(max-width:760px){.salones{grid-template-columns:1fr;}}

/* ============================================================
   PHILOSOPHY pillars
   ============================================================ */
.pillars{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(196,161,90,.16); border:1px solid rgba(196,161,90,.16);}
.pillar{background:var(--teal-900); padding:clamp(32px,3.2vw,48px) clamp(24px,2.4vw,34px); display:flex; flex-direction:column; gap:16px; transition:background 400ms;}
.pillar:hover{background:var(--teal-800);}
.pillar .pn{font-family:var(--font-display); font-weight:700; font-size:14px; color:var(--gold-600); letter-spacing:.16em;}
@media(max-width:860px){.pillars{grid-template-columns:1fr 1fr;}}
@media(max-width:520px){.pillars{grid-template-columns:1fr;}}

/* ============================================================
   EVENTS
   ============================================================ */
.events{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(12px,1.4vw,16px);}
.ev{position:relative; padding:clamp(18px,1.8vw,26px); border:1px solid rgba(196,161,90,.2); background:linear-gradient(180deg,rgba(18,66,73,.4),rgba(6,31,35,.2)); display:flex; flex-direction:column; gap:8px; transition:border-color 360ms var(--ease-soft), transform 360ms var(--ease-soft);}ap:14px; transition:all 360ms var(--ease-soft); overflow:hidden;}
.ev:hover{border-color:var(--gold-500); transform:translateY(-4px);}
.ev .evn{font-family:var(--font-heading); font-size:11px; letter-spacing:.24em; color:var(--gold-600);}
.ev .evt{font-family:var(--font-heading); font-weight:600; font-size:clamp(15px,1.4vw,18px); letter-spacing:.05em; text-transform:uppercase; color:var(--fg-1);}
.ev .body{font-size:14px !important; line-height:1.45; color:var(--fg-3);}
@media(max-width:780px){.events{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.events{grid-template-columns:1fr;}}

/* private events / quotes */
.privat{margin-top:clamp(28px,4vh,48px); display:grid; grid-template-columns:1.4fr 1fr; gap:0; border:1px solid rgba(196,161,90,.3); background:linear-gradient(180deg,rgba(18,66,73,.45),rgba(6,31,35,.3));}
.privat-bd{padding:clamp(32px,4vw,56px);}
.privat-cta{padding:clamp(32px,4vw,56px); display:flex; flex-direction:column; justify-content:center; align-items:flex-start; border-left:1px solid rgba(196,161,90,.2); background:rgba(6,31,35,.35);}
.privat-tags{display:flex; flex-wrap:wrap; gap:10px; margin-top:26px;}
.privat-tags span{font-family:var(--font-heading); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-400); border:1px solid rgba(196,161,90,.32); padding:8px 14px;}
@media(max-width:680px){.privat{grid-template-columns:1fr;} .privat-cta{border-left:none; border-top:1px solid rgba(196,161,90,.2);}}

/* ============================================================
   RESERVE teaser
   ============================================================ */
.reserve{text-align:center;}
.contact-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,3vw,48px); margin-top:clamp(40px,6vh,64px); text-align:center;}
.cblock .cl{font-family:var(--font-heading); font-size:10px; letter-spacing:.28em; text-transform:uppercase; color:var(--gold-500); margin-bottom:14px;}
.cblock .cv{font-family:var(--font-serif); font-size:18px; line-height:1.5; color:var(--fg-1);}
.cblock .cv .sm{font-size:14px; color:var(--fg-3); font-style:italic;}
@media(max-width:680px){.contact-grid{grid-template-columns:1fr; gap:32px;}}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{position:relative; z-index:2; border-top:1px solid rgba(196,161,90,.18); padding-block:clamp(60px,9vh,96px) 40px; text-align:center; background:var(--teal-900);}
.foot-logo{height:clamp(96px,12vw,128px); width:auto; margin-inline:auto; opacity:.95;}
.hero-crest{display:block; margin:clamp(10px,2vh,24px) auto 0; height:clamp(108px,17vh,205px); width:auto; filter:drop-shadow(0 8px 30px rgba(0,0,0,.6));}
.foot-hidden{font-family:var(--font-serif); font-style:italic; font-weight:300; font-size:clamp(22px,3vw,34px); color:var(--gold-400); margin-top:28px;}
.foot-meta{display:flex; gap:30px; justify-content:center; flex-wrap:wrap; margin-top:36px; font-family:var(--font-heading); font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--fg-3);}
.foot-meta a:hover{color:var(--gold-400);}
.foot-base{margin-top:40px; font-family:var(--font-heading); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--fg-muted);}

/* ============================================================
   TWEAKS panel
   ============================================================ */
#tweaks{position:fixed; right:18px; bottom:18px; z-index:1000; width:260px; background:rgba(8,38,42,.94); backdrop-filter:blur(14px); border:1px solid rgba(196,161,90,.3); padding:18px 18px 20px; box-shadow:0 24px 60px rgba(0,0,0,.6); font-family:var(--font-ui); display:none;}
#tweaks.show{display:block;}
#tweaks h4{margin:0 0 4px; font-family:var(--font-heading); font-size:12px; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-400); font-weight:600;}
#tweaks .sub{font-size:11px; color:var(--fg-3); margin-bottom:16px; font-family:var(--font-ui);}
#tweaks .tw{margin-bottom:16px;}
#tweaks label{display:flex; justify-content:space-between; font-size:11px; color:var(--fg-2); letter-spacing:.04em; margin-bottom:7px;}
#tweaks input[type=range]{width:100%; accent-color:var(--gold-500);}
#tweaks .swatches{display:flex; gap:8px;}
#tweaks .sw{width:28px; height:28px; border-radius:50%; cursor:pointer; border:1px solid rgba(255,255,255,.2); transition:transform 160ms;}
#tweaks .sw.active{outline:2px solid var(--fg-1); outline-offset:2px;}
#tweaks .sw:hover{transform:scale(1.1);}
#tweaks .close{position:absolute; top:12px; right:12px; background:none; border:none; color:var(--fg-3); cursor:pointer; font-size:16px; line-height:1;}
