/* =========================================================
   SKYLINE · Open Air Lounge
   Paleta inspirada en el cielo:
   noche → tramonto → alba
   ========================================================= */
:root{
  /* sky / night */
  --night-deep:#040912;
  --night:#0a1628;
  --night-soft:#142844;
  --twilight:#1f3a63;
  --blue-mid:#2a4a78;
  --dawn:#5a7fa8;

  /* sunset */
  --sunset-deep:#b04a2a;
  --sunset:#e26a3b;
  --sunset-soft:#f0945a;
  --amber:#f4b765;
  --gold:#e9c46a;
  --cream:#f5e7cf;
  --paper:#f7efe1;

  /* base */
  --text:#f0ebe0;
  --text-soft:#c5cdd9;
  --muted:#8a96aa;
  --line:rgba(255,255,255,.14);

  --maxw:1400px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--night-deep);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,sans-serif;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  height:100svh;
  min-height:560px;
  width:100%;
  overflow:hidden;
  background:var(--night-deep);
}
.hero .hero-img,
.hero .hero-img img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center;
}
.hero .hero-day{display:none}
[data-theme="day"] .hero .hero-night{display:none}
[data-theme="day"] .hero .hero-day{display:block}
.hero-scroll{
  position:absolute;
  bottom:34px;left:50%;
  transform:translateX(-50%);
  color:rgba(255,255,255,.85);
  z-index:3;
  animation:floaty 2.4s ease-in-out infinite;
}
@keyframes floaty{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(8px)}
}

/* hamburger (mobile only) */
.hamburger{
  display:none;
  position:absolute;
  top:38px;right:22px;
  z-index:30;
  width:46px;height:46px;
  border-radius:999px;
  background:rgba(10,22,40,.55);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.22);
  align-items:center;justify-content:center;
  flex-direction:column;gap:5px;
}
.hamburger span{
  display:block;
  width:18px;height:1.5px;
  background:#fff;
  transition:transform .3s, opacity .3s;
}

/* ---------- HEADER (appears after hero) ---------- */
.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:25;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 5vw;
  background:linear-gradient(180deg,
    rgba(4,9,18,.92) 0%,
    rgba(4,9,18,.75) 70%,
    rgba(4,9,18,0) 100%);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  transform:translateY(-100%);
  transition:transform .45s cubic-bezier(.5,0,.2,1);
}
.site-header.visible,
.site-header.no-hide{transform:translateY(0)}
.site-header.no-hide{transition:none}
.carta-page{padding-top:90px}
.menu-back{max-width:var(--maxw);margin:60px auto 0;text-align:center}
.menu-back a{
  display:inline-block;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--amber);
  padding:14px 24px;
  border:1px solid var(--line);
  border-radius:999px;
  transition:border-color .25s,color .25s;
}
.menu-back a:hover{border-color:var(--amber)}
[data-theme="day"] .menu-back a{color:#ffffff;border-color:rgba(255,255,255,.4)}
[data-theme="day"] .menu-back a:hover{border-color:#ffffff;background:rgba(255,255,255,.08)}
/* mobile: float hamburger on carta page (no hero present) */
.floating-hamburger{position:fixed;top:38px;right:22px;z-index:30}
.floating-theme{
  position:fixed;
  top:38px;left:22px;
  z-index:30;
  width:46px;height:46px;
  border-radius:999px;
  background:rgba(10,22,40,.55);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
  display:none; /* hidden on desktop, shown on mobile */
  align-items:center;justify-content:center;
  transition:background .25s,border-color .25s,transform .3s;
}
@media (max-width:760px){
  .floating-theme{display:inline-flex}
}
.floating-theme:hover{background:rgba(255,255,255,.1);transform:rotate(15deg)}
.floating-theme .ico-sun{display:none}
.floating-theme .ico-moon{display:block}
[data-theme="day"] .floating-theme .ico-sun{display:block}
[data-theme="day"] .floating-theme .ico-moon{display:none}
[data-theme="day"] .floating-theme{
  background:rgba(255,250,240,.7);
  border-color:rgba(12,33,56,.22);
  color:var(--text);
}

/* ---------- CARTA cover & photo band ---------- */
.carta-page{padding-top:0}
.carta-cover{
  position:relative;
  height:62svh;
  min-height:420px;
  overflow:hidden;
}
.carta-cover-img,
.carta-cover-img img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 90%;
}
@media (min-width:761px){
  [data-theme="day"] .carta-cover-img img{object-position:center 70%}
}
@media (max-width:760px){
  /* dark mode (base): raised more + shifted left */
  .carta-cover-img img{
    object-position:65% 85%;
    transform:scale(1.35);
    transform-origin:65% 85%;
  }
  /* light mode overrides */
  [data-theme="day"] .carta-cover-img img{
    object-position:65% 70%;
    transform-origin:65% 65%;
  }
}
.carta-cover-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(4,9,18,.35) 0%,rgba(4,9,18,.55) 60%,var(--night-deep) 100%);
}
[data-theme="day"] .carta-cover-overlay{
  background:linear-gradient(180deg,rgba(184,216,239,.2) 0%,rgba(168,207,238,.45) 60%,#eaf6ff 100%);
}
.carta-cover-content{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  padding:0 7vw 60px;
  text-align:center;
}
.carta-cover-content h1{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(56px,9vw,128px);
  line-height:.95;
  margin:14px 0 0;
  color:#fff;
}
.carta-cover-content h1 em{
  font-style:italic;
  color:var(--amber);
}
[data-theme="day"] .carta-cover-content h1{color:#0c2138}
[data-theme="day"] .carta-cover-content h1 em{color:#1f3a63}

.menu-photo-band{
  display:grid;
  margin:60px 0;
}
.menu-photo,
.menu-photo img{
  width:100%;
  display:block;
}
.menu-photo img{
  max-height:480px;
  object-fit:cover;
  border-radius:6px;
}
@media (max-width:600px){
  .carta-cover{height:54svh;min-height:360px}
  .menu-photo img{max-height:300px}
}
.brand img{width:140px;height:auto;object-fit:contain;filter:drop-shadow(0 2px 12px rgba(0,0,0,.4))}

.nav{
  display:flex;gap:34px;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
}
.nav a{opacity:.78;transition:color .3s,opacity .3s;position:relative}
.nav a:hover{opacity:1;color:var(--amber)}
.nav a::after{
  content:"";
  position:absolute;left:0;bottom:-6px;
  width:0;height:1px;
  background:var(--amber);
  transition:width .3s;
}
.nav a:hover::after{width:100%}

.header-right{display:flex;align-items:center;gap:18px}
.lang{display:flex;gap:2px}
.lang button{
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:6px 9px;
  color:var(--muted);
  font-weight:600;
  transition:color .25s;
}
.lang button.active{color:var(--amber)}
.lang button:hover{color:#fff}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;
  align-items:center;justify-content:center;
  padding:14px 28px;
  border-radius:999px;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:600;
  background:linear-gradient(135deg,var(--amber),var(--sunset));
  color:#1a0e05;
  border:1px solid transparent;
  transition:transform .3s,box-shadow .3s,filter .3s;
  box-shadow:0 10px 30px -10px rgba(228,134,80,.55);
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.05);box-shadow:0 14px 40px -12px rgba(228,134,80,.7)}
.btn-small{padding:10px 18px;font-size:10px}
.btn-light{
  background:transparent;
  color:var(--night);
  border-color:var(--night);
  box-shadow:none;
}
.btn-light:hover{background:var(--night);color:var(--paper)}

/* ---------- MOBILE MENU OVERLAY ---------- */
.mobile-menu{
  position:fixed;inset:0;
  z-index:40;
  background:linear-gradient(180deg,var(--night-deep) 0%,var(--twilight) 60%,var(--sunset-deep) 100%);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  padding-top:140px;
  gap:34px;
  opacity:0;
  visibility:hidden;
  transition:opacity .4s ease,visibility .4s;
}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu nav{
  display:flex;
  flex-direction:column;
  gap:28px;
  text-align:center;
}
.mobile-menu nav a{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;
  letter-spacing:.04em;
  color:#fff;
}
.mobile-close{
  position:absolute;top:22px;right:22px;
  width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
}
.mobile-lang{display:flex;gap:18px;margin-top:8px}
.mobile-lang button{
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
  font-weight:500;
}
.mobile-lang button.active{color:var(--amber)}

/* ---------- TYPOGRAPHY HELPERS ---------- */
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:11px;
  font-weight:600;
  color:var(--amber);
  margin:0 0 14px;
}
h2,h3{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  line-height:1.05;
  margin:0;
  letter-spacing:.005em;
}
section h2{font-size:clamp(34px,5vw,64px)}

/* ---------- SECTION: INTRO (night sky gradient) ---------- */
.section{padding:120px 7vw;max-width:var(--maxw);margin:0 auto}
.intro{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:80px;
  background:
    radial-gradient(ellipse at 80% 0%,rgba(228,106,59,.18),transparent 55%),
    radial-gradient(ellipse at 0% 90%,rgba(90,127,168,.18),transparent 60%),
    linear-gradient(180deg,var(--night-deep) 0%,var(--night) 100%);
  max-width:none;
}
.intro-head{position:relative}
.intro-head::before{
  content:"";
  position:absolute;
  top:-10px;left:0;
  width:60px;height:1px;
  background:linear-gradient(90deg,var(--amber),transparent);
}
.intro-copy p{
  font-size:18px;
  line-height:1.75;
  color:var(--text-soft);
  font-weight:300;
}
.stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:44px;
}
.stats div{
  border-top:1px solid var(--line);
  padding-top:20px;
}
.stats strong{
  display:block;
  font-size:42px;
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  color:var(--amber);
  margin-bottom:4px;
}
.stats span{
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:10px;
  color:var(--muted);
}


/* ---------- DUO SECTION (Mixología | Sonido side-by-side) ---------- */
.duo{
  display:grid;
  grid-template-columns:1fr 1fr;
  max-width:var(--maxw);
  margin:0 auto;
  padding:80px 7vw;
  gap:20px;
  position:relative;
  text-align:center;
}
.duo::before{
  content:"";
  position:absolute;
  top:140px; bottom:140px;
  left:50%;
  width:1px;
  background:linear-gradient(180deg,transparent,var(--line) 20%,var(--line) 80%,transparent);
}
.duo-col{padding:0 60px}
.duo-col .eyebrow{margin-bottom:16px}
.duo-col h3{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(34px,4.2vw,54px);
  line-height:1.05;
  margin:0 0 22px;
  color:#fff;
}
.duo-col p{
  color:var(--text-soft);
  line-height:1.8;
  font-weight:300;
  font-size:17px;
  max-width:380px;
  margin:0 auto;
}
[data-theme="day"] .duo-col h3{color:var(--text)}
[data-theme="day"] .duo-col p{color:#3a4a64}
[data-theme="day"] .duo::before{background:linear-gradient(180deg,transparent,rgba(31,58,99,.2) 20%,rgba(31,58,99,.2) 80%,transparent)}

/* with-bg variant: column has a photo background + overlay */
.duo-col.with-bg{
  position:relative;
  min-height:560px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:6px;
  overflow:hidden;
  background-size:cover;
  background-position:center;
  padding:60px 48px;
}
.duo-col.duo-mixology{background-image:url('assets/barman-lady.png')}
.duo-col.duo-sound{background-image:url('assets/dj-dark.png');background-size:170%;background-position:72% 85%}
[data-theme="day"] .duo-col.duo-mixology{background-image:url('assets/barman-lady-light.png')}
[data-theme="day"] .duo-col.duo-sound{background-image:url('assets/dj-light.png');background-size:170%;background-position:center 85%}
@media (max-width:760px){
  .duo-col.duo-sound{background-size:280% !important;background-position:72% 72% !important}
  [data-theme="day"] .duo-col.duo-sound{background-position:62% 72% !important}
  [data-theme="day"] .duo-col.duo-mixology{background-position:42% center !important}
  /* invert Ambiente on mobile: title first, image after */
  .split-content{order:1}
  .split-image{order:2}
  /* zoom in on the carta/menu-teaser bg on mobile, raised */
  .menu-teaser-bg{transform:scale(1.6);transform-origin:center 75%;object-position:center 80%}
}
.duo-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(4,9,18,.15) 0%,rgba(4,9,18,.4) 40%,rgba(4,9,18,.82) 100%);
  pointer-events:none;
}
[data-theme="day"] .duo-overlay{
  background:linear-gradient(180deg,rgba(184,216,239,.05) 0%,rgba(127,182,227,.25) 40%,rgba(31,58,99,.82) 100%);
}
.duo-text{
  position:relative;
  z-index:1;
  text-align:center;
  max-width:380px;
}
.duo-text h3{color:#fff !important}
.duo-text p{color:rgba(255,255,255,.88) !important}
.duo-col.with-bg .eyebrow{color:var(--amber)}
[data-theme="day"] .duo-col.with-bg .eyebrow{color:var(--amber)}
/* hide the duo center divider when columns have bg */
.duo:has(.with-bg)::before{display:none}

@media (max-width:760px){
  .duo{grid-template-columns:1fr;padding:90px 24px;gap:60px}
  .duo::before{
    top:auto; bottom:auto;
    left:20%; right:20%;
    width:auto; height:1px;
    top:50%;
    background:linear-gradient(90deg,transparent,var(--line),transparent);
  }
  [data-theme="day"] .duo::before{background:linear-gradient(90deg,transparent,rgba(31,58,99,.2),transparent)}
  .duo-col{padding:0}
}

/* ---------- EDITORIAL SECTIONS (legacy) ---------- */
.editorial{
  position:relative;
  padding:130px 7vw;
  max-width:860px;
  margin:0 auto;
  text-align:center;
}
.editorial-index{
  position:absolute;
  top:30px;left:50%;
  transform:translateX(-50%);
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(140px,18vw,260px);
  line-height:1;
  color:rgba(255,255,255,.035);
  letter-spacing:.02em;
  pointer-events:none;
  user-select:none;
  z-index:0;
}
.editorial > *{position:relative;z-index:1}
.editorial .eyebrow{margin-bottom:18px}
.editorial h2{
  font-size:clamp(48px,7vw,92px);
  line-height:1;
  margin:0 0 28px;
}
.editorial-copy{
  font-size:18px;
  line-height:1.8;
  color:var(--text-soft);
  font-weight:300;
  max-width:620px;
  margin:0 auto;
}
.editorial-rule{
  border:0;
  height:1px;
  width:60px;
  margin:0 auto;
  background:linear-gradient(90deg,transparent,var(--amber),transparent);
  opacity:.7;
}

[data-theme="day"] .editorial-index{color:rgba(31,58,99,.05)}
[data-theme="day"] .editorial-copy{color:#3a4a64}
[data-theme="day"] .editorial-rule{background:linear-gradient(90deg,transparent,#1f3a63,transparent)}

@media (max-width:760px){
  .editorial{padding:90px 28px}
  .editorial-index{top:22px;font-size:160px}
}

/* ---------- FEATURES (legacy - kept hidden for safety) ---------- */
.features{
  padding:120px 7vw;
  background:
    radial-gradient(ellipse at 20% 0%,rgba(90,127,168,.22),transparent 55%),
    radial-gradient(ellipse at 100% 100%,rgba(31,58,99,.45),transparent 55%),
    linear-gradient(180deg,var(--night) 0%,var(--night-deep) 100%);
}
.features-inner{
  max-width:var(--maxw);
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
}
.f-card{
  position:relative;
  padding:60px 48px 54px;
  border:1px solid var(--line);
  border-radius:6px;
  background:linear-gradient(180deg,rgba(20,40,68,.45) 0%,rgba(10,22,40,.55) 100%);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  overflow:hidden;
  transition:transform .5s var(--ease, cubic-bezier(.22,1,.36,1)), border-color .4s;
}
.f-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--amber),transparent);
  opacity:.6;
}
.f-card::after{
  content:"";
  position:absolute;
  right:-80px; top:-80px;
  width:240px; height:240px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(233,196,106,.18),transparent 70%);
  pointer-events:none;
}
.f-card:hover{transform:translateY(-4px);border-color:rgba(233,196,106,.3)}
.f-num{
  position:absolute;
  top:24px; right:30px;
  font-family:'Cormorant Garamond',serif;
  font-size:64px;
  line-height:1;
  color:rgba(255,255,255,.06);
  letter-spacing:.02em;
  pointer-events:none;
}
.f-icon{
  width:46px;
  height:46px;
  color:var(--amber);
  margin-bottom:28px;
}
.f-card .eyebrow{margin-bottom:10px}
.f-card h3{
  font-size:clamp(30px,3.4vw,44px);
  color:#fff;
  margin:0 0 18px;
}
.f-card p{
  color:var(--text-soft);
  line-height:1.75;
  font-weight:300;
  max-width:460px;
  margin:0;
}

/* Day theme for features */
[data-theme="day"] .features{
  background:
    radial-gradient(ellipse at 20% 0%,rgba(127,182,227,.4),transparent 55%),
    radial-gradient(ellipse at 100% 100%,rgba(244,183,101,.25),transparent 55%),
    linear-gradient(180deg,#fffaf0 0%,#fff6e3 100%);
}
[data-theme="day"] .f-card{
  background:linear-gradient(180deg,rgba(255,255,255,.65),rgba(217,235,250,.5));
  border-color:rgba(12,33,56,.1);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
[data-theme="day"] .f-card h3{color:var(--text)}
[data-theme="day"] .f-card p{color:#3a4a64}
[data-theme="day"] .f-num{color:rgba(12,33,56,.07)}
[data-theme="day"] .f-card::before{background:linear-gradient(90deg,transparent,#1f3a63,transparent)}
[data-theme="day"] .f-icon{color:#1f3a63}
[data-theme="day"] .f-card::after{background:radial-gradient(circle,rgba(127,182,227,.4),transparent 70%)}
[data-theme="day"] .f-card:hover{border-color:rgba(31,58,99,.3)}

/* ---------- SPLIT (light section — dawn) ---------- */
.split{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:80px;
  align-items:center;
  background:
    radial-gradient(circle at 100% 0%,rgba(244,183,101,.22),transparent 50%),
    linear-gradient(180deg,var(--paper) 0%,var(--cream) 100%);
  color:var(--night);
  max-width:none;
}
.split .eyebrow{color:var(--sunset-deep)}
.split-image{
  border-radius:4px;
  overflow:hidden;
  box-shadow:0 40px 80px -30px rgba(31,58,99,.35);
}
.split-content p{
  font-size:18px;
  line-height:1.75;
  color:#3a4458;
  margin:18px 0 32px;
  font-weight:300;
}

/* ---------- HOURS STRIP (blue night, no orange) ---------- */
.sunset-band{
  background:
    radial-gradient(ellipse at 50% 0%,rgba(90,127,168,.18),transparent 55%),
    linear-gradient(180deg,var(--night-deep) 0%,var(--night) 100%);
  padding:80px 5vw;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.sunset-band-inner{
  max-width:var(--maxw);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  text-align:center;
}
.band-item{
  padding:14px 28px;
  border-right:1px solid var(--line);
  position:relative;
}
.band-item:last-child{border-right:0}
.band-item .eyebrow{color:var(--amber);margin-bottom:14px}
.band-item strong{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-size:32px;
  font-weight:400;
  color:#fff;
  letter-spacing:.04em;
}
[data-theme="day"] .sunset-band{
  background:
    radial-gradient(ellipse at 50% 0%,rgba(127,182,227,.3),transparent 55%),
    linear-gradient(180deg,#fff 0%,#eaf6ff 100%);
  border-color:rgba(12,33,56,.12);
}
[data-theme="day"] .band-item{border-right-color:rgba(12,33,56,.14)}
[data-theme="day"] .band-item .eyebrow{color:#1f3a63}
[data-theme="day"] .band-item strong{color:var(--text)}
@media (max-width:960px){
  .band-item{border-right:0;border-bottom:1px solid var(--line);padding-bottom:26px}
  .band-item:last-child{border-bottom:0}
  [data-theme="day"] .band-item{border-bottom-color:rgba(12,33,56,.14)}
}

/* ---------- RESERVATION ---------- */
.reservation{
  position:relative;
  padding:140px 7vw;
  background:
    linear-gradient(180deg,rgba(4,9,18,.55),rgba(4,9,18,.75)),
    url('assets/reservations-dark.png') center/cover fixed;
  overflow:hidden;
}
.reservation::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 100%,rgba(90,127,168,.2),transparent 55%);
  pointer-events:none;
}
.reservation-inner{
  position:relative;
  max-width:760px;
  margin:0 auto;
  text-align:center;
}
.reservation h2{margin-bottom:18px}
.reservation p{
  color:var(--text-soft);
  font-size:18px;
  line-height:1.75;
}
.form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:40px;
  text-align:left;
}
.form input,
.form select,
.form textarea{
  width:100%;
  padding:16px 20px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.05);
  color:#fff;
  border-radius:4px;
  font-family:inherit;
  font-size:14px;
  transition:border-color .25s,background .25s;
}
.form input:focus,
.form select:focus,
.form textarea:focus{
  outline:none;
  border-color:var(--amber);
  background:rgba(255,255,255,.08);
}
.form input::placeholder,
.form textarea::placeholder{color:rgba(255,255,255,.5)}
[data-theme="day"] .form input,
[data-theme="day"] .form textarea{background:rgba(255,255,255,.88)}

/* ---------- Custom select (drop-in replacement for <select>) ---------- */
.custom-select{position:relative;width:100%}
.cs-toggle{
  width:100%;
  padding:16px 20px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.05);
  color:#fff;
  border-radius:4px;
  font-family:inherit;
  font-size:14px;
  text-align:left;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  cursor:pointer;
  transition:border-color .25s,background .25s;
}
.cs-toggle:hover{border-color:rgba(255,255,255,.32)}
.custom-select.open .cs-toggle{border-color:var(--amber)}
.cs-chevron{transition:transform .25s;color:rgba(255,255,255,.6)}
.custom-select.open .cs-chevron{transform:rotate(180deg)}
.cs-list{
  position:absolute;
  left:0;right:0;top:calc(100% + 6px);
  z-index:20;
  list-style:none;
  margin:0;padding:6px;
  background:#0a1628;
  border:1px solid var(--line);
  border-radius:4px;
  box-shadow:0 20px 60px -10px rgba(0,0,0,.55);
  display:none;
  max-height:240px;
  overflow:auto;
}
.custom-select.open .cs-list{display:block}
.cs-list li{
  padding:10px 14px;
  font-size:14px;
  color:var(--text-soft);
  border-radius:3px;
  cursor:pointer;
  transition:background .15s,color .15s;
}
.cs-list li:hover{background:rgba(255,255,255,.05);color:#fff}
.cs-list li.selected{color:var(--amber)}

/* Light theme */
[data-theme="day"] .cs-toggle{
  background:#ffffff;
  color:#0c2138;
  border-color:rgba(12,33,56,.18);
}
[data-theme="day"] .cs-toggle:hover{border-color:rgba(12,33,56,.4)}
[data-theme="day"] .custom-select.open .cs-toggle{border-color:#1f3a63}
[data-theme="day"] .cs-chevron{color:rgba(12,33,56,.55)}
[data-theme="day"] .cs-list{
  background:#ffffff;
  border-color:rgba(12,33,56,.14);
  box-shadow:0 20px 60px -10px rgba(31,58,99,.25);
}
[data-theme="day"] .cs-list li{color:#3a4a64}
[data-theme="day"] .cs-list li:hover{background:rgba(12,33,56,.05);color:#0c2138}
[data-theme="day"] .cs-list li.selected{color:#1f3a63;font-weight:500}
.form textarea{grid-column:1/-1;resize:vertical;min-height:80px}
.form button{
  grid-column:1/-1;
  justify-self:center;
  margin-top:10px;
  min-width:240px;
}

/* ---------- FOOTER ---------- */
.footer{
  background:var(--night-deep);
  color:var(--muted);
  padding:70px 7vw 28px;
  font-size:13px;
}
.footer-cols{
  max-width:var(--maxw);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:50px;
  padding-bottom:50px;
  border-bottom:1px solid var(--line);
}
.footer-brand img{width:160px;margin-bottom:14px;opacity:.92}
.footer-brand p{font-size:12px;color:var(--muted);letter-spacing:.04em}
.footer-col{display:flex;flex-direction:column;gap:8px}
.footer-col a{
  color:var(--text-soft);
  font-size:13px;
  transition:color .25s;
}
.footer-col a:hover{color:var(--amber)}
.hours-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.hours-list li{
  display:flex;
  justify-content:flex-start;
  gap:10px;
  font-size:12.5px;
  color:var(--text-soft);
}
.hours-list li span{min-width:78px;display:inline-block}
.hours-list em{font-style:normal;color:var(--muted);font-variant-numeric:tabular-nums}
[data-theme="day"] .nrc-link{color:#ffffff}
.footer-bottom{
  max-width:var(--maxw);
  margin:0 auto;
  padding-top:28px;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:10px;
  font-size:11px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
}
.nrc-link{
  color:var(--amber);
  text-decoration:none;
  transition:color .25s;
  border-bottom:1px solid transparent;
}
.nrc-link:hover{border-bottom-color:var(--amber)}
.legal-links{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.legal-links a{color:var(--muted);transition:color .25s}
.legal-links a:hover{color:var(--amber)}
[data-theme="day"] .nrc-link{color:#ffffff}
[data-theme="day"] .nrc-link:hover{border-bottom-color:#ffffff}
[data-theme="day"] .legal-links a:hover{color:#1f3a63}

/* =========================================================
   COOKIE BANNER
   ========================================================= */
.cookie-banner{
  position:fixed;
  left:24px; right:24px; bottom:24px;
  max-width:520px;
  z-index:60;
  opacity:0;
  transform:translateY(20px);
  pointer-events:none;
  transition:opacity .35s, transform .35s;
}
.cookie-banner.open{opacity:1;transform:none;pointer-events:auto}
.cookie-card{
  background:rgba(10,22,40,.95);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid var(--line);
  border-radius:8px;
  padding:26px 28px;
  color:var(--text);
  box-shadow:0 30px 80px -20px rgba(0,0,0,.6);
}
[data-theme="day"] .cookie-card{
  background:rgba(255,255,255,.96);
  color:var(--text);
  border-color:rgba(12,33,56,.12);
  box-shadow:0 30px 80px -20px rgba(31,58,99,.25);
}
.cookie-card h3{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;
  font-weight:500;
  margin:0 0 10px;
  color:inherit;
}
.cookie-card p{
  font-size:13.5px;
  line-height:1.65;
  color:var(--text-soft);
  margin:0 0 18px;
}
[data-theme="day"] .cookie-card p{color:#3a4a64}
.cookie-card p a{
  color:var(--amber);
  border-bottom:1px solid transparent;
  transition:border-color .25s;
}
.cookie-card p a:hover{border-bottom-color:var(--amber)}
[data-theme="day"] .cookie-card p a{color:#1f3a63}
[data-theme="day"] .cookie-card p a:hover{border-bottom-color:#1f3a63}

.cookie-prefs{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin:0 0 18px;
  padding:14px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.cookie-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  cursor:pointer;
}
.cookie-row span{display:flex;flex-direction:column;gap:2px}
.cookie-row strong{font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:600}
.cookie-row em{font-style:normal;font-size:12px;color:var(--text-soft)}
[data-theme="day"] .cookie-row em{color:#5a6878}
.cookie-row input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  width:34px;height:20px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid var(--line);
  position:relative;
  cursor:pointer;
  flex-shrink:0;
}
.cookie-row input[type="checkbox"]::after{
  content:"";
  position:absolute;
  top:1px;left:1px;
  width:16px;height:16px;
  border-radius:999px;
  background:#fff;
  transition:transform .2s, background .2s;
}
.cookie-row input[type="checkbox"]:checked{background:var(--amber);border-color:var(--amber)}
.cookie-row input[type="checkbox"]:checked::after{transform:translateX(14px)}
.cookie-row input[type="checkbox"]:disabled{opacity:.6;cursor:not-allowed}
[data-theme="day"] .cookie-row input[type="checkbox"]{background:rgba(12,33,56,.1);border-color:rgba(12,33,56,.15)}
[data-theme="day"] .cookie-row input[type="checkbox"]:checked{background:#1f3a63;border-color:#1f3a63}

.cookie-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}
.cookie-actions .btn{padding:11px 16px;font-size:10px;letter-spacing:.18em}
.cookie-actions .btn-ghost{
  background:transparent;
  color:var(--text);
  border:1px solid var(--line-strong, rgba(255,255,255,.2));
  box-shadow:none;
}
[data-theme="day"] .cookie-actions .btn-ghost{
  color:#fff;
  border-color:rgba(255,255,255,.45);
}
.cookie-actions .btn-ghost:hover{
  background:rgba(255,255,255,.06);
  transform:none;
  filter:none;
}
[data-theme="day"] .cookie-actions .btn-ghost:hover{
  background:rgba(255,255,255,.12);
  border-color:#fff;
}

@media (max-width:600px){
  .cookie-banner{left:14px;right:14px;bottom:14px}
  .cookie-card{padding:20px 18px}
  .cookie-actions{flex-direction:column;align-items:stretch;gap:8px}
  .cookie-actions .btn{
    flex:0 0 auto;
    width:100%;
    padding:13px 14px;
    font-size:10px;
    letter-spacing:.14em;
    white-space:normal;
    word-break:break-word;
  }
}

/* =========================================================
   LEGAL PAGES
   ========================================================= */
.legal-page{
  padding:140px 7vw 100px;
  max-width:880px;
  margin:0 auto;
}
.legal-page h1{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(40px,5.5vw,72px);
  line-height:1;
  margin:18px 0 50px;
}
.legal-page h2{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:28px;
  margin:46px 0 14px;
}
.legal-page h3{
  font-family:Inter,system-ui,sans-serif;
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--amber);
  font-weight:600;
  margin:30px 0 10px;
}
[data-theme="day"] .legal-page h3{color:#1f3a63}
.legal-page p{
  font-size:15.5px;
  line-height:1.8;
  color:var(--text-soft);
  font-weight:300;
  margin:0 0 14px;
}
[data-theme="day"] .legal-page p{color:#3a4a64}
.legal-page ul{
  margin:8px 0 18px 22px;
  color:var(--text-soft);
  font-weight:300;
  line-height:1.8;
  font-size:15.5px;
}
[data-theme="day"] .legal-page ul{color:#3a4a64}
.legal-page table{
  width:100%;
  border-collapse:collapse;
  margin:18px 0 30px;
  font-size:14px;
}
.legal-page th,
.legal-page td{
  padding:12px 14px;
  text-align:left;
  border-bottom:1px solid var(--line);
  font-weight:400;
  color:var(--text-soft);
}
.legal-page th{
  color:var(--amber);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:600;
}
[data-theme="day"] .legal-page th{color:#1f3a63}
[data-theme="day"] .legal-page td{color:#3a4a64}
.legal-page a{
  color:var(--amber);
  border-bottom:1px solid transparent;
  transition:border-color .25s;
}
[data-theme="day"] .legal-page a{color:#1f3a63}
.legal-page a:hover{border-bottom-color:currentColor}

/* ---------- RESPONSIVE ---------- */
@media (max-width:960px){
  .site-header .nav{display:none}
  .site-header .header-right .lang{display:none}
  .intro,.split{grid-template-columns:1fr;gap:40px}
  .section{padding:90px 24px}
  .feature-grid{grid-template-columns:1fr}
  .feature-card{min-height:520px}
  .feature-text{left:28px;right:28px;bottom:32px}
  .form{grid-template-columns:1fr}
  .sunset-band-inner{grid-template-columns:1fr;gap:20px}
  .footer-cols{grid-template-columns:1fr 1fr;gap:30px}
  .reservation{padding:100px 24px;background-attachment:scroll}
}
@media (max-width:760px){
  .hamburger{display:flex;top:56px}
  .floating-hamburger{top:56px}
  .floating-theme{top:56px}
  .site-header{display:none}
  .hero-scroll{bottom:24px}
  .brand img{width:120px}
  /* MOBILE FOOTER LAYOUT */
  .footer-cols{
    grid-template-columns:1fr 1fr;
    gap:22px 14px;
    justify-items:center;
    text-align:center;
  }
  .footer-brand{
    grid-column:1 / -1;
    text-align:center;
  }
  .footer-brand img{margin:0 auto 12px}
  .footer-brand p{margin:0 auto}
  .footer-col{align-items:center}
  /* keep left-alignment of content WITHIN each column so it stays "aligned as before" */
  .footer-col .eyebrow{text-align:left;align-self:flex-start}
  .footer-col a,
  .footer-col span{text-align:left;align-self:flex-start}
  .hours-list{align-self:flex-start}
  /* Horarios goes full width below contacto/syguenos */
  .footer-col:has(.hours-list){grid-column:1 / -1;align-items:center}
  .footer-col:has(.hours-list) .eyebrow{align-self:auto;text-align:center}

  /* Mobile menu logo */
  .mobile-menu-logo{
    position:absolute;
    top:42px;left:50%;
    transform:translateX(-50%);
    z-index:1;
  }
  .mobile-menu-logo img{
    width:160px;
    height:auto;
    opacity:.85;
  }
  [data-theme="day"] .mobile-menu-logo img{
    content:url('assets/logo-black.png');
  }
  /* Copyright "Part of NRC Capital" goes on a new line */
  .copyright-nrc{display:block;margin-top:2px}
  /* Compact legal links centered */
  .footer-bottom .legal-links{
    font-size:10px;
    letter-spacing:.06em;
    justify-content:center;
    gap:6px;
  }
  .feature-text h3{font-size:32px}
  /* Stats on one row */
  .stats{grid-template-columns:repeat(3,1fr);gap:10px}
  .stats strong{font-size:30px}
  .stats span{font-size:9px;letter-spacing:.12em}
  .reservation{
    background-image:linear-gradient(180deg,rgba(4,9,18,.55),rgba(4,9,18,.75)),url('assets/reservations-dark.png');
    background-attachment:scroll;
  }
  .footer-bottom{flex-direction:column;text-align:center}
}

/* =========================================================
   THEME-AWARE IMAGES (show/hide by theme)
   ========================================================= */
.theme-day{display:none}
[data-theme="day"] .theme-night{display:none}
[data-theme="day"] .theme-day{display:block}

/* =========================================================
   MENU TEASER (con foto di sfondo)
   ========================================================= */
.menu-teaser{
  position:relative;
  padding:140px 7vw;
  text-align:center;
  overflow:hidden;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,var(--night) 0%,var(--night-deep) 100%);
}
.menu-teaser-bg{
  position:absolute;
  inset:0;
  width:100%;height:100%;
  object-fit:cover;
  opacity:.35;
  z-index:0;
}
.menu-teaser::before{
  content:"";
  position:absolute;inset:0;
  z-index:1;
  background:linear-gradient(180deg,
    rgba(4,9,18,.55) 0%,
    rgba(4,9,18,.25) 50%,
    rgba(4,9,18,.85) 100%);
}
[data-theme="day"] .menu-teaser::before{
  background:linear-gradient(180deg,
    rgba(184,216,239,.65) 0%,
    rgba(168,207,238,.4) 50%,
    rgba(146,190,224,.85) 100%);
}
[data-theme="day"] .menu-teaser-bg{opacity:.55}
.menu-teaser-inner{position:relative;z-index:2;max-width:760px;margin:0 auto}
.menu-teaser h2{
  font-size:clamp(48px,7vw,92px);
  margin:14px 0 24px;
  line-height:.95;
}
.menu-teaser em{font-style:italic;color:var(--amber);font-family:'Cormorant Garamond',serif}
.menu-teaser-copy{
  font-size:17px;
  line-height:1.75;
  color:var(--text-soft);
  font-weight:300;
  margin:0 auto 36px;
  max-width:560px;
}
[data-theme="day"] .menu-teaser{
  background:
    radial-gradient(ellipse at 50% 0%,rgba(236,139,61,.18),transparent 55%),
    linear-gradient(180deg,#fffaf0 0%,#fff6e3 100%);
  border-color:rgba(12,33,56,.12);
}
[data-theme="day"] .menu-teaser em{color:#1f3a63}
[data-theme="day"] .menu-teaser-copy{color:#3a4a64}

/* =========================================================
   MOMENTOS (lifestyle gallery)
   ========================================================= */
.moments{
  padding:120px 7vw;
  max-width:var(--maxw);
  margin:0 auto;
}
.moments-head{
  margin-bottom:60px;
  max-width:680px;
}
.moments-head h2{
  font-size:clamp(36px,5vw,68px);
  margin-top:14px;
}
.moments-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  align-items:start;
}
.moment{
  margin:0;
  position:relative;
  border-radius:6px;
  overflow:hidden;
  background:var(--night-soft);
}
.moment img{
  width:100%;
  height:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  display:block;
  transition:transform 1.2s ease;
}
.moment:hover img{transform:scale(1.04)}
.moment::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(4,9,18,.7));
  pointer-events:none;
}
.moment figcaption{
  position:absolute;
  left:20px; right:20px; bottom:18px;
  z-index:2;
  color:#fff;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
}
[data-theme="day"] .moment::after{
  background:linear-gradient(180deg,transparent 60%,rgba(31,58,99,.6));
}
@media (max-width:900px){
  .moments-grid{grid-template-columns:1fr 1fr;gap:14px}
}
@media (min-width:601px){
  /* raise Hora dorada (man-drink) only on desktop */
  .moment.tall img{object-position:center 15%}
}
@media (max-width:600px){
  .moments{padding:90px 0}
  .moments-head{padding:0 24px}
  /* horizontal scroll-snap carousel on mobile */
  .moments-grid{
    display:flex;
    grid-template-columns:none;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    gap:14px;
    padding:0 24px;
    scroll-padding-left:24px;
    scrollbar-width:none;
  }
  .moments-grid::-webkit-scrollbar{display:none}
  .moment{
    flex:0 0 82%;
    scroll-snap-align:start;
    margin:0;
  }
  .moment img{aspect-ratio:4/5}
}

/* =========================================================
   CARTA / MENU (pagina separata)
   ========================================================= */
.menu-section{
  background:
    radial-gradient(ellipse at 100% 0%,rgba(228,106,59,.12),transparent 55%),
    radial-gradient(ellipse at 0% 100%,rgba(90,127,168,.12),transparent 55%),
    linear-gradient(180deg,var(--night) 0%,var(--night-deep) 100%);
  max-width:none;
  padding:120px 7vw;
}
.menu-section .menu-head{
  max-width:var(--maxw);
  margin:0 auto 70px;
}
.menu-section .menu-head h2{
  font-size:clamp(48px,7vw,96px);
  line-height:.95;
  margin-top:14px;
}
.menu-section .menu-head em{
  font-style:italic;
  color:var(--amber);
  font-family:'Cormorant Garamond',serif;
}
.menu-section > .menu-group{
  max-width:var(--maxw);
  margin:0 auto;
}
.menu-group{
  padding:56px 0;
  border-top:1px solid var(--line);
}
.menu-group:first-of-type{border-top:0;padding-top:0}
.menu-group-title{
  font-family:Inter,system-ui,sans-serif;
  font-size:clamp(13px,1.4vw,16px);
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--amber);
  margin-bottom:42px;
  line-height:1.2;
}
.menu-list{
  display:flex;
  flex-direction:column;
  gap:28px;
}
.menu-item{display:flex;flex-direction:column;gap:8px}
.menu-row{
  display:flex;
  align-items:baseline;
  gap:14px;
  width:100%;
}
.menu-name{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(20px,1.9vw,26px);
  font-weight:500;
  letter-spacing:.01em;
  color:var(--text);
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  flex-shrink:1;
  max-width:60%;
  margin:0;
}
.menu-dots{
  flex:1;
  min-width:30px;
  align-self:flex-end;
  border-bottom:1px dotted rgba(255,255,255,.18);
  transform:translateY(-7px);
}
.menu-price{
  font-family:Inter,system-ui,sans-serif;
  font-size:clamp(14px,1.3vw,16px);
  font-weight:600;
  color:var(--amber);
  white-space:nowrap;
  letter-spacing:.04em;
}
.menu-desc{
  font-size:14px;
  color:var(--text-soft);
  line-height:1.65;
  font-weight:300;
  max-width:680px;
  margin:0;
}

/* Day theme adjustments */
[data-theme="day"] .menu-section{
  background:
    radial-gradient(ellipse at 100% 0%,rgba(236,139,61,.2),transparent 55%),
    radial-gradient(ellipse at 0% 100%,rgba(127,182,227,.25),transparent 55%),
    linear-gradient(180deg,#fffaf0 0%,#fff6e3 100%);
}
[data-theme="day"] .menu-name{color:var(--text)}
[data-theme="day"] .menu-group-title,
[data-theme="day"] .menu-price{color:#1f3a63}
[data-theme="day"] .menu-section .menu-head em{color:#1f3a63}
[data-theme="day"] .menu-dots{border-bottom-color:rgba(12,33,56,.22)}
[data-theme="day"] .menu-desc{color:#3a4a64}
[data-theme="day"] .menu-group{border-top-color:var(--line)}

@media (max-width:600px){
  .menu-name{max-width:55%;font-size:20px}
  .menu-price{font-size:14px}
  .menu-desc{font-size:13px}
  .menu-section{padding:90px 24px}
  .menu-group{padding:40px 0}
  .menu-group-title{margin-bottom:28px}
}

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

/* =========================================================
   THEME TOGGLE (sun/moon)
   ========================================================= */
.theme-toggle,
.hero-theme{
  display:inline-flex;
  align-items:center;justify-content:center;
  width:38px;height:38px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  background:rgba(255,255,255,.04);
  transition:background .25s,border-color .25s,transform .3s;
}
.theme-toggle:hover,
.hero-theme:hover{background:rgba(255,255,255,.1);transform:rotate(15deg)}
.hero-theme{
  position:absolute;
  top:38px; left:22px;
  z-index:30;
  background:rgba(10,22,40,.55);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  width:46px;height:46px;
  border:1px solid rgba(255,255,255,.22);
}
/* show only one icon at a time */
.theme-toggle .ico-sun,
.hero-theme .ico-sun{display:none}
.theme-toggle .ico-moon,
.hero-theme .ico-moon{display:block}
[data-theme="day"] .theme-toggle .ico-sun,
[data-theme="day"] .hero-theme .ico-sun{display:block}
[data-theme="day"] .theme-toggle .ico-moon,
[data-theme="day"] .hero-theme .ico-moon{display:none}

/* =========================================================
   DAY THEME — cielo di giorno
   ========================================================= */
[data-theme="day"]{
  /* override sky palette */
  --night-deep:#dff1ff;
  --night:#eaf6ff;
  --night-soft:#cfe6f8;
  --twilight:#a8cfee;
  --blue-mid:#7fb6e3;
  --dawn:#bcdcf3;

  --sunset-deep:#c46a2c;
  --sunset:#ec8b3d;
  --sunset-soft:#f4b06a;
  --amber:#e4a23f;
  --gold:#d99025;
  --cream:#fff6e3;
  --paper:#fffaf0;

  --text:#0c2138;
  --text-soft:#3a4a64;
  --muted:#6b7c93;
  --line:rgba(12,33,56,.16);
}
[data-theme="day"] body{
  background:transparent;
  color:var(--text);
}
/* Single continuous sky behind the whole page in light mode */
[data-theme="day"] main{
  position:relative;
}
[data-theme="day"] main::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:linear-gradient(180deg,
    #eaf6ff 0%,
    #dceffb 20%,
    #cce5f6 40%,
    #b8d8ef 60%,
    #a4cbe8 80%,
    #92bee0 100%);
  pointer-events:none;
}
html[data-theme="day"]{background:#92bee0}
/* In light mode, sections are transparent so the unified sky shows through */
[data-theme="day"] .intro,
[data-theme="day"] .features,
[data-theme="day"] .split,
[data-theme="day"] .sunset-band,
[data-theme="day"] .menu-teaser,
[data-theme="day"] .menu-section{
  background:transparent;
  border-color:transparent;
}
/* Soft blend between the hero photo and the first section */
[data-theme="day"] .hero::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:140px;
  background:linear-gradient(180deg,transparent,#eaf6ff);
  pointer-events:none;
  z-index:2;
}
/* Soft blend before the reservation (photo) section */
[data-theme="day"] .reservation{
  position:relative;
}
[data-theme="day"] .reservation::after{
  content:"";
  position:absolute;
  left:0;right:0;top:-1px;
  height:140px;
  background:linear-gradient(180deg,#92bee0,transparent);
  pointer-events:none;
}

/* HERO in day mode: invert overlay slightly */
[data-theme="day"] .hero{background:#bcdcf3}
[data-theme="day"] .hero picture img{
  filter:brightness(1.06) saturate(1.05);
}
[data-theme="day"] .hero-scroll{color:rgba(12,33,56,.7)}

/* HEADER in day mode */
[data-theme="day"] .site-header{
  background:linear-gradient(180deg,
    rgba(234,246,255,.92) 0%,
    rgba(217,235,250,.78) 70%,
    rgba(217,235,250,0) 100%);
  color:var(--text);
}
[data-theme="day"] .nav a{opacity:.78;color:var(--text)}
[data-theme="day"] .nav a:hover{color:#1f3a63;opacity:1}
[data-theme="day"] .nav a::after{background:#1f3a63}
[data-theme="day"] .brand img{content:url('assets/logo-black.png');filter:none}
[data-theme="day"] .lang button{color:var(--muted)}
[data-theme="day"] .lang button.active{color:#1f3a63}
[data-theme="day"] .lang button:hover{color:var(--text)}
[data-theme="day"] .theme-toggle{
  border-color:rgba(12,33,56,.18);
  color:var(--text);
  background:rgba(255,255,255,.5);
}
[data-theme="day"] .theme-toggle:hover{background:#fff}

/* HAMBURGER + hero-theme in day mode */
[data-theme="day"] .hamburger,
[data-theme="day"] .hero-theme{
  background:rgba(255,250,240,.7);
  border-color:rgba(12,33,56,.22);
  color:var(--text);
}
[data-theme="day"] .hamburger span{background:var(--text)}

/* BUTTONS */
[data-theme="day"] .btn{
  background:linear-gradient(135deg,#2a4a78,#1f3a63);
  color:#fff;
  box-shadow:0 12px 30px -10px rgba(31,58,99,.45);
}
[data-theme="day"] .btn-light{
  background:transparent;
  color:#0c2138;
  border-color:#0c2138;
}
[data-theme="day"] .btn-light:hover{background:#0c2138;color:#fffaf0}

/* SECTIONS in day mode */
[data-theme="day"] .intro{
  background:
    radial-gradient(ellipse at 80% 0%,rgba(236,139,61,.22),transparent 55%),
    radial-gradient(ellipse at 0% 90%,rgba(127,182,227,.32),transparent 60%),
    linear-gradient(180deg,#fffaf0 0%,#fff6e3 100%);
  color:var(--text);
}
[data-theme="day"] .intro-copy p{color:#3a4a64}
[data-theme="day"] .stats div{border-top-color:var(--line)}
[data-theme="day"] .stats strong{color:#1f3a63}
[data-theme="day"] .stats span{color:var(--muted)}
[data-theme="day"] .eyebrow{color:#1f3a63}
[data-theme="day"] .intro-head::before{
  background:linear-gradient(90deg,#1f3a63,transparent);
}

/* FEATURE cards: in day mode, keep images but soften overlay */
[data-theme="day"] .feature-grid{background:#fffaf0}
[data-theme="day"] .feature-card{background:#fff}
[data-theme="day"] .feature-card::after{
  background:linear-gradient(180deg,
    rgba(255,250,240,0) 0%,
    rgba(12,33,56,.2) 45%,
    rgba(12,33,56,.85) 100%);
}

/* SPLIT */
[data-theme="day"] .split{
  background:transparent;
  color:var(--text);
}
[data-theme="day"] .split-content p{color:#3a4a64}
[data-theme="day"] .split-image{box-shadow:0 40px 80px -30px rgba(12,33,56,.25)}

/* SUNSET BAND */
[data-theme="day"] .sunset-band{
  background:linear-gradient(90deg,
    #bcdcf3 0%,
    #a8cfee 25%,
    #f4b06a 60%,
    #ec8b3d 85%,
    #e4a23f 100%);
}

/* RESERVATION block keeps darker contrast even in day mode (cinematic) */
[data-theme="day"] .reservation{
  background:
    linear-gradient(180deg,rgba(158,199,232,.45),rgba(127,182,227,.7)),
    url('assets/reservations-light.png') center/cover fixed;
  color:#0c2138;
}
[data-theme="day"] .reservation::before{
  background:radial-gradient(ellipse at 50% 100%,rgba(127,182,227,.4),transparent 55%);
}
@media (max-width:760px){
  [data-theme="day"] .reservation{
    background:linear-gradient(180deg,rgba(158,199,232,.45),rgba(127,182,227,.7)),url('assets/reservations-light.png') center/cover;
  }
}
[data-theme="day"] .reservation p{color:rgba(12,33,56,.78)}
[data-theme="day"] .reservation .eyebrow{color:#fff}
[data-theme="day"] .reservation h2{color:#fff;text-shadow:0 2px 30px rgba(12,33,56,.4)}
[data-theme="day"] .form input,
[data-theme="day"] .form textarea{
  background:rgba(255,255,255,.7);
  color:var(--text);
  border-color:rgba(12,33,56,.18);
}
[data-theme="day"] .form input::placeholder,
[data-theme="day"] .form textarea::placeholder{color:rgba(12,33,56,.5)}

/* FOOTER */
[data-theme="day"] .footer{
  background:linear-gradient(180deg,#0c2138 0%,#040912 100%);
  color:var(--muted);
}

/* Mobile menu in day mode */
[data-theme="day"] .mobile-menu{
  background:linear-gradient(180deg,#eaf6ff 0%,#a8cfee 60%,#7fb6e3 100%);
}
[data-theme="day"] .mobile-menu nav a{color:var(--text)}
[data-theme="day"] .mobile-close{color:var(--text);border-color:rgba(12,33,56,.22)}
[data-theme="day"] .mobile-lang button{color:rgba(12,33,56,.55)}
[data-theme="day"] .mobile-lang button.active{color:#1f3a63}

@media (max-width:760px){
  .hero-theme{top:56px;right:78px}
}

/* ---------- 404 PAGE ---------- */
.page-404{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:90px 7vw 100px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.page-404-inner{
  max-width:640px;
  margin:0 auto;
  position:relative;
  z-index:2;
}
.page-404 .eyebrow{margin-bottom:18px}
.page-404 .code-404{
  font-family:'Cormorant Garamond',serif;
  font-weight:300;
  font-size:clamp(120px,22vw,260px);
  line-height:.95;
  letter-spacing:-.02em;
  margin:0 0 8px;
  background:linear-gradient(180deg,var(--amber) 0%,rgba(207,164,103,.35) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
[data-theme="day"] .page-404 .code-404{
  background:linear-gradient(180deg,#1f3a63 0%,rgba(31,58,99,.35) 100%);
  -webkit-background-clip:text;
  background-clip:text;
}
.page-404 h1{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(28px,4vw,46px);
  line-height:1.1;
  margin:0 0 18px;
}
.page-404 p{
  font-size:16px;
  line-height:1.75;
  color:var(--text-soft);
  font-weight:300;
  margin:0 auto 38px;
  max-width:480px;
}
[data-theme="day"] .page-404 p{color:#3a4a64}
.page-404-actions{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}
@media (max-width:520px){
  .page-404{padding:80px 7vw 80px}
  .page-404-actions .btn{width:100%}
}

