/* =====================================================
   TOKENS
===================================================== */
/* =====================================================
   FONT-FACE LOCAL
===================================================== */
@font-face { font-family: 'Azo Sans'; src: url('../../tipografia/fonnts.com-Azo_Sans_Uber_Regular.otf') format('opentype'); font-weight: normal; font-style: normal; font-display: swap; }
@font-face { font-family: 'Azo Sans'; src: url('../../tipografia/fonnts.com-Azo_Sans_Uber_Regular.otf') format('opentype'); font-weight: bold; font-style: normal; font-display: swap; }
@font-face { font-family: 'Azo Sans'; src: url('../../tipografia/fonnts.com-Azo_Sans_Uber_Regular.otf') format('opentype'); font-weight: 900; font-style: normal; font-display: swap; }
@font-face { font-family: 'Chillax'; src: url('../../tipografia/Chillax-Semibold.otf') format('opentype'); font-weight: 600; font-style: normal; font-display: swap; }
@font-face { font-family: 'Chillax'; src: url('../../tipografia/Chillax-Medium.otf') format('opentype'); font-weight: 500; font-style: normal; font-display: swap; }
@font-face { font-family: 'Chillax'; src: url('../../tipografia/Chillax-Regular.otf') format('opentype'); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: 'Chillax'; src: url('../../tipografia/Chillax-Light.otf') format('opentype'); font-weight: 300; font-style: normal; font-display: swap; }

:root {
  --black:  #0a0d0d;
  --pink:   #ee6792;
  --cream:  #FBF9E4;
  --pink-a: rgba(238,103,146,0.15);
  --glow:   0 0 24px rgba(238,103,146,0.5), 0 0 60px rgba(238,103,146,0.2);
  --fhead:  'Azo Sans', sans-serif;
  --falt:   'Barlow Condensed', sans-serif;
  --fbody:  'Chillax', sans-serif;
  --ease:   cubic-bezier(.4,0,.2,1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }

body {
  background: var(--black);
  color: var(--cream);
  font-family: var(--fbody);
  overflow-x: hidden;
  cursor: none;
}

/* custom cursor */
.cursor {
  position: fixed; width: 10px; height: 10px; border-radius: 50%;
  background: var(--pink); pointer-events: none; z-index: 9999;
  transform: translate(-50%,-50%);
  transition: width .2s var(--ease), height .2s var(--ease), opacity .2s;
  mix-blend-mode: difference;
}
.cursor-ring {
  position: fixed; width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid var(--pink); pointer-events: none; z-index: 9998;
  transform: translate(-50%,-50%);
  transition: transform .12s var(--ease), width .25s, height .25s, border-color .25s;
  opacity: 0.6;
}
body:hover .cursor { opacity: 1; }

a, button { cursor: none; }
img { display: block; width: 100%; }
a { color: inherit; text-decoration: none; }
button { border: none; background: none; font-family: inherit; cursor: none; }
ul { list-style: none; }

/* =====================================================
   NAV — minimal, Osaka-style
===================================================== */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 48px;
  transition: background .4s, padding .4s;
}
.nav.scrolled {
  background: rgba(10,13,13,0.92);
  backdrop-filter: blur(20px);
  padding: 14px 48px;
  border-bottom: 1px solid rgba(238,103,146,0.1);
}

/* Logo block con imagen */
.nav-logo-img {
  height: 79.01px;
  width: 236px;
  display: block;
  transition: transform .3s var(--ease), filter .3s;
}
.nav-logo-link:hover .nav-logo-img {
  transform: scale(1.04);
}

/* Logo block antiguo (deprecado) */
/* .nav-logo { display: flex; align-items: center; gap: 4px; }
.nchar {
  width: 28px; height: 28px;
  background: var(--cream); color: var(--black);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--fhead); font-size: 13px; border-radius: 4px;
  transition: background .3s;
}
.nchar.pk { background: var(--pink); }
.nav-logo:hover .nchar { background: var(--pink); }
.nav-logo:hover .nchar.pk { background: var(--cream); } */

/* Nav right */
.nav-r { display: flex; align-items: center; gap: 28px; }
.lang { display: flex; gap: 2px; }
.lang button {
  font-family: var(--fbody); font-size: 10px; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase;
  color: rgba(251,249,228,0.4); padding: 5px 8px; border-radius: 2px;
  transition: color .2s, background .2s;
}
.lang button.on { color: var(--pink); background: rgba(238,103,146,0.12); }
.nav-reserve {
  font-family: var(--fbody); font-size: 10px; font-weight: 700;
  letter-spacing: 3px; text-transform: uppercase;
  color: var(--black); background: var(--pink);
  padding: 11px 26px; border-radius: 3px;
  transition: box-shadow .25s, transform .2s;
}
.nav-reserve:hover { box-shadow: var(--glow); transform: translateY(-1px); }

/* hamburger — mobile */
.nav-burger { display: none; flex-direction: column; gap: 5px; padding: 4px; }
.nav-burger span { width: 22px; height: 1.5px; background: var(--cream); display: block; transition: all .3s; }

/* =====================================================
   HERO — full screen, cinematic
===================================================== */
.hero {
  position: relative; height: 100vh; min-height: 600px;
  display: flex; align-items: flex-end;
  overflow: hidden;
}
.hero-media {
  position: absolute; inset: 0;
  transform: scale(1.06);
  animation: zoomOut 14s ease-out forwards;
}
.hero-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.hero-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(to bottom, rgba(10,13,13,0.2) 0%, rgba(10,13,13,0.55) 50%, rgba(10,13,13,1) 100%),
    linear-gradient(to right, rgba(10,13,13,0.6) 0%, transparent 50%);
}
@keyframes zoomOut { to { transform: scale(1); } }

/* scanlines texture */
.hero-media::after {
  content: '';
  position: absolute; inset: 0;
  background: repeating-linear-gradient(0deg, rgba(0,0,0,0.03) 0, rgba(0,0,0,0.03) 1px, transparent 1px, transparent 3px);
  pointer-events: none;
}

/* neon horizontal lines */
.neon-h {
  position: absolute; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--pink) 40%, var(--pink) 60%, transparent 100%);
  opacity: 0; pointer-events: none;
}
.neon-h.top { top: 0; animation: neonFade 2s ease .4s forwards; }
.neon-h.bot { bottom: 0; animation: neonFade 2s ease .6s forwards; }
@keyframes neonFade { to { opacity: 0.4; } }

/* kanji ghost background */
.hero-kanji {
  position: absolute; right: 6vw; top: 50%; transform: translateY(-50%);
  font-family: var(--fhead); font-size: clamp(120px, 18vw, 280px);
  color: rgba(238,103,146,0.06);
  line-height: 1; writing-mode: vertical-rl;
  pointer-events: none; user-select: none;
  animation: fadeUp 1.2s ease .3s both;
}

.hero-content {
  position: relative; z-index: 2;
  padding: 0 72px 80px;
  animation: fadeUp .9s ease .1s both;
}
@keyframes fadeUp { from { opacity:0; transform: translateY(40px); } to { opacity:1; transform: none; } }

.hero-eyebrow {
  font-size: 10px; font-weight: 600; letter-spacing: 4px;
  text-transform: uppercase; color: var(--pink);
  margin-bottom: 20px; display: block;
}

.hero-title {
  font-family: var(--fhead);
  font-size: clamp(60px, 10vw, 160px);
  line-height: 0.88;
  letter-spacing: -2px;
  color: var(--cream);
  margin-bottom: 6px;
}
.hero-title .outline {
  -webkit-text-stroke: 2px var(--cream);
  color: transparent;
}
.hero-title .pink { color: var(--pink); -webkit-text-stroke: 0; }

.hero-sub-row {
  display: flex; align-items: center; gap: 20px;
  margin-top: 24px; margin-bottom: 40px;
}
.hero-sub-row .line { width: 40px; height: 1px; background: var(--pink); }
.hero-sub-row span {
  font-size: 11px; font-weight: 500; letter-spacing: 4px;
  text-transform: uppercase; color: rgba(251,249,228,0.55);
}

.hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; }
.cta-p {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--pink); color: var(--black);
  font-family: var(--fbody); font-size: 11px; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  padding: 16px 32px; border-radius: 3px;
  transition: box-shadow .25s, transform .2s;
}
.cta-p:hover { box-shadow: var(--glow); transform: translateY(-2px); }
.cta-o {
  display: inline-flex; align-items: center; gap: 10px;
  background: transparent; color: var(--cream);
  border: 1.5px solid rgba(251,249,228,0.3);
  font-family: var(--fbody); font-size: 11px; font-weight: 600;
  letter-spacing: 2.5px; text-transform: uppercase;
  padding: 16px 32px; border-radius: 3px;
  transition: border-color .25s, color .25s;
}
.cta-o:hover { border-color: var(--pink); color: var(--pink); }

/* scroll indicator */
.hero-scroll {
  position: absolute; right: 48px; bottom: 48px; z-index: 3;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  opacity: .45;
}
.hero-scroll span { font-size: 8px; letter-spacing: 3px; text-transform: uppercase; writing-mode: vertical-rl; }
.scroll-line { width: 1px; height: 48px; background: linear-gradient(var(--pink), transparent); animation: pulse 2s ease infinite; }
@keyframes pulse { 0%,100%{opacity:.3} 50%{opacity:1} }

/* =====================================================
   TICKER
===================================================== */
.ticker {
  overflow: hidden;
  border-top: 1px solid rgba(238,103,146,0.12);
  border-bottom: 1px solid rgba(238,103,146,0.12);
  background: rgba(238,103,146,0.03);
  padding: 13px 0;
}
.t-track { display: flex; width: max-content; animation: tick 30s linear infinite; }
@keyframes tick { to { transform: translateX(-50%); } }
.t-item { display: flex; align-items: center; gap: 20px; padding: 0 28px; white-space: nowrap; }
.t-item span { font-family: var(--falt); font-size: 13px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: rgba(251,249,228,0.35); }
.t-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--pink); flex-shrink:0; }

/* =====================================================
   GENERIC SECTION UTILITIES
===================================================== */
.s-label {
  display: inline-flex; align-items: center; gap: 12px; margin-bottom: 16px;
}
.s-label::before { content: ''; width: 28px; height: 2px; background: var(--pink); }
.s-label span { font-size: 9px; font-weight: 700; letter-spacing: 4px; text-transform: uppercase; color: var(--pink); }

.s-title {
  font-family: var(--fhead);
  font-size: clamp(40px, 6vw, 96px);
  line-height: 0.9; color: var(--cream);
}
.s-title .pk { color: var(--pink); }
.s-title .ol { -webkit-text-stroke: 2px var(--cream); color: transparent; }

.s-body { font-size: 14px; font-weight: 300; line-height: 1.75; color: rgba(251,249,228,0.5); max-width: 420px; }

/* =====================================================
   VIBE — split: text left, image right (full bleed)
===================================================== */
.vibe {
  display: grid; grid-template-columns: 1fr 1fr;
  min-height: 90vh;
}
.vibe-left {
  display: flex; flex-direction: column; justify-content: center;
  padding: 96px 72px;
  background: var(--black);
}
.vibe-left .s-title { margin-bottom: 24px; }
.vibe-left .s-body { margin-bottom: 40px; }

.vibe-right {
  position: relative; overflow: hidden;
}
.vibe-right-img {
  position: absolute; inset: 0;
  background:
    linear-gradient(to right, var(--black) 0%, transparent 30%),
    url('https://images.unsplash.com/photo-1617196034183-421b4040ed20?w=900&q=80') center/cover no-repeat;
}

/* floating stat cards */
.vibe-stat {
  position: absolute;
  background: rgba(10,13,13,0.88);
  border: 1px solid rgba(238,103,146,0.25);
  backdrop-filter: blur(12px);
  border-radius: 8px; padding: 18px 24px;
}
.vibe-stat.s1 { top: 12%; left: -20px; }
.vibe-stat.s2 { bottom: 18%; right: 32px; }
.vibe-stat .num { font-family: var(--falt); font-size: 36px; font-weight: 900; color: var(--pink); line-height: 1; }
.vibe-stat .lbl { font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: rgba(251,249,228,0.45); margin-top: 4px; }

/* adjetivos */
.adj-cloud { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 36px; }
.adj {
  font-family: var(--falt); font-size: 11px; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  padding: 6px 14px; border-radius: 2px;
  border: 1px solid rgba(238,103,146,0.25); color: rgba(251,249,228,0.5);
  transition: all .2s;
}
.adj:hover, .adj.on { background: var(--pink-a); border-color: var(--pink); color: var(--cream); }

/* =====================================================
   FOOD — editorial alternating blocks
===================================================== */
.food-intro {
  padding: 120px 72px 60px;
  display: flex; flex-direction: column; align-items: center; text-align: center;
}
.food-intro .s-title { font-size: clamp(56px,8vw,128px); }
.food-intro .s-body { text-align: center; max-width: 540px; margin: 24px 0 0; }

/* full-bleed image rows */
.food-row {
  display: grid; grid-template-columns: 1fr 1fr;
  min-height: 70vh;
}
.food-row.rev { direction: rtl; }
.food-row.rev > * { direction: ltr; }

.food-img {
  position: relative; overflow: hidden;
}
.food-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.food-row:hover .food-img img { transform: scale(1.04); }

.food-text {
  display: flex; flex-direction: column; justify-content: center;
  padding: 72px 64px;
  background: var(--black);
}
.food-text .s-label { margin-bottom: 20px; }
.food-text .dish-name {
  font-family: var(--fhead); font-size: clamp(32px, 4vw, 60px);
  color: var(--cream); margin-bottom: 8px; line-height: 1;
}
.food-text .dish-kanji { font-size: 14px; color: var(--pink); letter-spacing: 2px; margin-bottom: 20px; }
.food-text .dish-desc { font-size: 13px; color: rgba(251,249,228,0.5); line-height: 1.8; margin-bottom: 32px; max-width: 360px; }
.food-text .dish-price { font-family: var(--falt); font-size: 42px; font-weight: 900; color: var(--pink); }
.food-text .dish-units { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: rgba(251,249,228,0.35); }

/* carta CTA full strip */
.carta-strip {
  display: flex; align-items: center; justify-content: space-between;
  padding: 64px 72px;
  border-top: 1px solid rgba(238,103,146,0.1);
  border-bottom: 1px solid rgba(238,103,146,0.1);
  background: rgba(238,103,146,0.03);
}
.carta-strip h3 {
  font-family: var(--fhead); font-size: clamp(32px,5vw,72px);
  color: var(--cream); line-height: 0.9;
}
.carta-strip h3 .pk { color: var(--pink); }

/* =====================================================
   SOUNDS — inspired by Osaka: large album covers
===================================================== */
.sounds {
  padding: 120px 72px;
  background: var(--black);
}
.sounds-head {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 48px; margin-bottom: 72px; align-items: end;
}
.sounds-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.sound-card {
  position: relative; border-radius: 10px; overflow: hidden;
  aspect-ratio: 1;
  transition: transform .35s var(--ease);
}
.sound-card:hover { transform: scale(1.03); }
.sound-card:hover .sc-play { opacity: 1; transform: translate(-50%,-50%) scale(1); }

.sc-bg { position: absolute; inset: 0; }
.sc-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,13,13,0) 30%, rgba(10,13,13,0.88) 100%);
}
.sc-play {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%,-50%) scale(0.8);
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--pink);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; color: var(--black);
  box-shadow: var(--glow);
  opacity: 0; transition: opacity .3s, transform .3s;
}
.sc-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 22px; }
.sc-sp {
  display: inline-flex; align-items: center; gap: 7px;
  margin-bottom: 10px;
}
.sc-sp .sp-dot { width: 18px; height: 18px; border-radius: 50%; background: #1DB954; display: flex; align-items: center; justify-content: center; font-size: 10px; }
.sc-sp span { font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.6); }
.sc-genre { font-family: var(--fhead); font-size: clamp(20px,2.5vw,30px); color: var(--cream); line-height: 1; }
.sc-sub { font-size: 11px; color: rgba(255,255,255,0.45); margin-top: 5px; letter-spacing: 1px; }

/* playlist bg art – pure CSS */
.bg-citypop {
  background: linear-gradient(135deg, #1a0814 0%, #3d1030 40%, #7a1c46 70%, #ee6792 100%);
}
.bg-citypop::after {
  content: '東京';
  position: absolute; top: 10%; right: 8%;
  font-family: var(--fhead); font-size: 80px; color: rgba(255,255,255,0.07);
  pointer-events: none;
}
.bg-jpop {
  background: linear-gradient(135deg, #05091a 0%, #0d1f4a 50%, #1a3a7c 100%);
}
.bg-jpop::after {
  content: '音楽';
  position: absolute; top: 10%; right: 8%;
  font-family: var(--fhead); font-size: 80px; color: rgba(255,255,255,0.06);
  pointer-events: none;
}
.bg-electro {
  background: linear-gradient(135deg, #030d0d 0%, #073333 50%, #0d5555 100%);
}
.bg-electro::after {
  content: '未来';
  position: absolute; top: 10%; right: 8%;
  font-family: var(--fhead); font-size: 80px; color: rgba(255,255,255,0.06);
  pointer-events: none;
}
.bg-citypop, .bg-jpop, .bg-electro { position: relative; }

/* =====================================================
   NOVEDADES — horizontal scroll cards
===================================================== */
.nov-section { padding: 120px 0 120px 72px; overflow: hidden; }
.nov-head { margin-bottom: 48px; }
.nov-track {
  display: flex; gap: 16px;
  overflow-x: auto; padding-bottom: 16px; padding-right: 72px;
  scrollbar-width: none;
}
.nov-track::-webkit-scrollbar { display: none; }
.nov-card {
  flex: 0 0 340px; border-radius: 10px; overflow: hidden;
  position: relative; height: 420px;
  transition: transform .3s;
}
.nov-card:hover { transform: translateY(-6px); }
.nc-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
}
.nc-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,13,13,0) 20%, rgba(10,13,13,0.95) 100%);
}
.nc-tag {
  position: absolute; top: 20px; left: 20px;
  background: var(--pink); color: var(--black);
  font-size: 8px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  padding: 5px 12px; border-radius: 2px;
}
.nc-content {
  position: absolute; bottom: 0; left: 0; right: 0; padding: 28px;
}
.nc-emoji { font-size: 28px; margin-bottom: 12px; display: block; }
.nc-title { font-family: var(--falt); font-size: 26px; font-weight: 900; text-transform: uppercase; color: var(--cream); margin-bottom: 8px; line-height: 1.1; }
.nc-desc { font-size: 12px; color: rgba(251,249,228,0.5); line-height: 1.6; }

/* nc bg colors */
.nc-alleat .nc-bg { background: linear-gradient(135deg, #1a0820, #3d0a2a), url('https://images.unsplash.com/photo-1547592166-23ac45744acd?w=600&q=70') center/cover; background-blend-mode: multiply; }
.nc-makis .nc-bg  { background: linear-gradient(135deg, #0a1a0a, #1a3a1a), url('https://images.unsplash.com/photo-1553621042-f6e147245754?w=600&q=70') center/cover; background-blend-mode: multiply; }
.nc-fide .nc-bg   { background: linear-gradient(135deg, #1a1000, #3a2800), url('https://images.unsplash.com/photo-1579871494447-9811cf80d66c?w=600&q=70') center/cover; background-blend-mode: multiply; }
.nc-hana .nc-bg   { background: linear-gradient(135deg, #1a0010, #3a0020), url('https://images.unsplash.com/photo-1617196034183-421b4040ed20?w=600&q=70') center/cover; background-blend-mode: multiply; }

/* =====================================================
   LOCATION — full width split
===================================================== */
.loc {
  display: grid; grid-template-columns: 1fr 1fr;
  min-height: 70vh;
}
.loc-map {
  position: relative; overflow: hidden;
  background: #222;
}
.loc-map iframe {
  filter: invert(90%) hue-rotate(180deg) brightness(85%) contrast(110%);
  transition: filter 0.3s ease;
  width: 100%; height: 100%; border: none; min-height: 400px;
}
.loc-map iframe:hover {
  filter: invert(90%) hue-rotate(180deg) brightness(100%) contrast(120%);
}

.loc-info {
  display: flex; flex-direction: column; justify-content: center;
  padding: 80px 72px;
  background: var(--black);
  border-left: 1px solid rgba(238,103,146,0.1);
}
.loc-info .s-title { margin-bottom: 32px; }
.loc-data { display: flex; flex-direction: column; gap: 18px; margin-bottom: 40px; }
.loc-row { display: flex; gap: 16px; align-items: flex-start; }
.loc-icon { font-size: 18px; margin-top: 2px; flex-shrink: 0; }
.loc-row-content {}
.loc-row-label { font-size: 9px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--pink); margin-bottom: 4px; }
.loc-row-val { font-size: 14px; color: rgba(251,249,228,0.7); line-height: 1.5; }

/* =====================================================
   DELIVERY
===================================================== */
.delivery {
  position: relative; overflow: hidden;
  padding: 120px 72px;
  border-top: 1px solid rgba(238,103,146,0.1);
}
.delivery-ghost {
  position: absolute; right: -40px; top: 50%; transform: translateY(-50%);
  font-family: var(--fhead); font-size: clamp(100px, 20vw, 280px);
  color: rgba(238,103,146,0.04); line-height: 1; pointer-events: none; white-space: nowrap;
}
.delivery-inner { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; gap: 60px; }
.delivery-text .s-title { margin-bottom: 12px; }
.delivery-text p { font-size: 13px; color: rgba(251,249,228,0.45); }
.delivery-btns { display: flex; gap: 12px; flex-wrap: wrap; }
.dapp {
  padding: 14px 28px; border-radius: 6px;
  font-family: var(--fbody); font-size: 11px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase;
  transition: transform .2s, box-shadow .2s; white-space: nowrap;
}
.dapp:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(0,0,0,0.5); }
.dapp-r { background: #FF441B; color: #fff; }
.dapp-i { background: #EA1D2C; color: #fff; }
.dapp-p { background: #FFCC00; color: #000; }
.dapp-disabled {
  background: rgba(255,255,255,0.05) !important;
  color: rgba(251,249,228,0.25) !important;
  border: 1px dashed rgba(251,249,228,0.15);
  cursor: not-allowed !important;
  user-select: none;
}
.dapp-disabled:hover {
  transform: none !important;
  box-shadow: none !important;
}

/* =====================================================
   FOOTER
===================================================== */
footer {
  background: #060808;
  border-top: 1px solid rgba(238,103,146,0.1);
  padding: 80px 72px 40px;
}
.ft-top {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 48px; margin-bottom: 64px;
}
.ft-logo-img {
  height: 40px;
  width: auto;
  margin-bottom: 20px;
  display: block;
}
.ft-tagline { font-size: 12px; color: rgba(251,249,228,0.35); line-height: 1.8; max-width: 220px; margin-bottom: 24px; }

/* sub form */
.ft-sub { display: flex; gap: 0; border: 1px solid rgba(238,103,146,0.2); border-radius: 4px; overflow: hidden; }
.ft-sub input {
  flex: 1; background: rgba(255,255,255,0.03); border: none; outline: none;
  padding: 10px 14px; color: var(--cream); font-family: var(--fbody); font-size: 12px;
}
.ft-sub input::placeholder { color: rgba(251,249,228,0.25); }
.ft-sub button {
  background: var(--pink); color: var(--black); padding: 10px 16px;
  font-family: var(--fbody); font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
}

.ft-col-head { font-size: 9px; font-weight: 700; letter-spacing: 3.5px; text-transform: uppercase; color: var(--pink); margin-bottom: 20px; }
.ft-col ul { display: flex; flex-direction: column; gap: 10px; }
.ft-col ul a { font-size: 13px; color: rgba(251,249,228,0.45); transition: color .2s; }
.ft-col ul a:hover { color: var(--cream); }

.ft-soc { display: flex; gap: 10px; margin-bottom: 24px; }
.soc-btn {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid rgba(238,103,146,0.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; color: rgba(251,249,228,0.4);
  transition: all .2s;
}
.soc-btn:hover { border-color: var(--pink); color: var(--pink); }
.ft-hours { font-size: 11px; color: rgba(251,249,228,0.35); line-height: 1.9; }

.ft-bottom {
  border-top: 1px solid rgba(255,255,255,0.05);
  padding-top: 28px;
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
}
.ft-legal { display: flex; gap: 20px; flex-wrap: wrap; }
.ft-legal a { font-size: 10px; color: rgba(251,249,228,0.25); letter-spacing: 1px; text-transform: uppercase; transition: color .2s; }
.ft-legal a:hover { color: rgba(251,249,228,0.55); }
.ft-copy { font-size: 10px; color: rgba(251,249,228,0.15); letter-spacing: 1px; }

/* =====================================================
   MODAL — Reservar ahora
===================================================== */
.modal-overlay {
  position: fixed; inset: 0; z-index: 900;
  background: rgba(10,13,13,0.88);
  backdrop-filter: blur(16px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  opacity: 0; pointer-events: none;
  transition: opacity .3s var(--ease);
}
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal {
  background: #0e1212;
  border: 1px solid rgba(238,103,146,0.25);
  border-radius: 12px;
  padding: 52px 48px;
  width: 100%; max-width: 500px;
  position: relative;
  transform: translateY(20px);
  transition: transform .35s var(--ease);
}
.modal-overlay.open .modal { transform: translateY(0); }

/* Promo Modal (464x323) */
.promo-overlay {
  position: fixed; inset: 0; z-index: 910;
  background: rgba(10,13,13,0.85); backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px; opacity: 0; pointer-events: none;
  transition: opacity .4s var(--ease);
}
.promo-overlay.open { opacity: 1; pointer-events: all; }
.promo-modal {
  width: 464px; height: 323px;
  background: url('../img/bg-promo.jpg') center/cover;
  position: relative; border-radius: 12px; overflow: hidden;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 36px; box-shadow: var(--glow);
  transform: translateY(20px) scale(0.98);
  transition: transform .4s var(--ease);
}
.promo-modal::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(0deg, rgba(10,13,13,0.95) 0%, rgba(10,13,13,0.1) 80%);
}
.promo-overlay.open .promo-modal { transform: translateY(0) scale(1); }
.promo-content { position: relative; z-index: 2; }
.promo-eyebrow { font-size: 10px; font-weight: 700; letter-spacing: 3px; color: var(--pink); text-transform: uppercase; margin-bottom: 8px; }
.promo-title { font-family: var(--fhead); font-size: 38px; color: var(--cream); line-height: 1; margin-bottom: 24px; }
.promo-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 16px; background: var(--pink); color: var(--black);
  font-family: var(--fbody); font-size: 12px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; border-radius: 4px;
}
.promo-close {
  position: absolute; top: 16px; right: 16px; z-index: 3;
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(10,13,13,0.6); border: 1px solid rgba(238,103,146,0.3); color: var(--pink);
  display: flex; align-items: center; justify-content: center; font-size: 14px; transition: all .2s;
}
.promo-close:hover { background: var(--pink); color: var(--black); }
.modal-close {
  position: absolute; top: 18px; right: 20px;
  width: 32px; height: 32px; border-radius: 50%;
  border: 1px solid rgba(238,103,146,0.2);
  color: rgba(251,249,228,0.5);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; transition: all .2s;
}
.modal-close:hover { border-color: var(--pink); color: var(--pink); }
.modal-eyebrow {
  font-size: 9px; font-weight: 700; letter-spacing: 4px; text-transform: uppercase;
  color: var(--pink); margin-bottom: 12px;
}
.modal-title {
  font-family: var(--fhead);
  font-size: clamp(32px, 5vw, 52px);
  line-height: 0.9; color: var(--cream);
  margin-bottom: 8px;
}
.modal-title .pk { color: var(--pink); }
.modal-sub { font-size: 12px; color: rgba(251,249,228,0.4); line-height: 1.6; margin-bottom: 32px; }
.modal-field { margin-bottom: 14px; }
.modal-field label {
  display: block; font-size: 9px; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--pink); margin-bottom: 7px;
}
.modal-field input {
  width: 100%;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(238,103,146,0.2);
  border-radius: 4px; padding: 13px 16px;
  color: var(--cream); font-family: var(--fbody); font-size: 14px;
  outline: none; transition: border-color .2s;
}
.modal-field input:focus { border-color: var(--pink); }
.modal-field input::placeholder { color: rgba(251,249,228,0.25); }
.modal-submit {
  width: 100%; margin-top: 8px;
  background: var(--pink); color: var(--black);
  font-family: var(--fbody); font-size: 12px; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  padding: 16px; border-radius: 4px;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  transition: box-shadow .25s, transform .2s;
}
.modal-submit:hover { box-shadow: var(--glow); transform: translateY(-1px); }
.modal-divider {
  text-align: center; font-size: 10px;
  color: rgba(251,249,228,0.25); letter-spacing: 2px;
  margin: 14px 0;
}
.modal-wa {
  width: 100%;
  background: rgba(37,211,102,0.1);
  border: 1px solid rgba(37,211,102,0.3);
  color: #25D366;
  font-family: var(--fbody); font-size: 11px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase;
  padding: 13px; border-radius: 4px;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  transition: background .2s;
}
.modal-wa:hover { background: rgba(37,211,102,0.18); }

/* =====================================================
   QUIÉNES SOMOS
===================================================== */
.quienes {
  display: grid; grid-template-columns: 1fr 1fr;
  min-height: 70vh;
}
.quienes-img {
  position: relative; overflow: hidden;
  background:
    linear-gradient(to left, var(--black) 0%, transparent 30%),
    url('https://images.unsplash.com/photo-1579871494447-9811cf80d66c?w=900&q=80') center/cover no-repeat;
}
.quienes-text {
  display: flex; flex-direction: column; justify-content: center;
  padding: 80px 72px;
  background: var(--black);
  border-left: 1px solid rgba(238,103,146,0.1);
}
.quienes-text .s-title { margin-bottom: 28px; }
.quienes-quote {
  font-family: var(--falt);
  font-size: clamp(18px, 2.2vw, 26px);
  font-weight: 700; font-style: italic;
  color: var(--pink); letter-spacing: 1px;
  line-height: 1.4; margin-bottom: 28px;
  padding-left: 20px;
  border-left: 3px solid var(--pink);
}
.quienes-body {
  font-size: 14px; font-weight: 300; line-height: 1.85;
  color: rgba(251,249,228,0.55); max-width: 440px;
}

/* =====================================================
   SUSCRIPCIÓN — difusión comercial
===================================================== */
.suscripcion {
  padding: 96px 72px;
  background: rgba(238,103,146,0.04);
  border-top: 1px solid rgba(238,103,146,0.1);
  border-bottom: 1px solid rgba(238,103,146,0.1);
  display: flex; align-items: center; justify-content: center; gap: 64px;
}
.sus-text { flex: 0 1 440px; }
.sus-text .s-title { font-size: clamp(36px, 5vw, 72px); margin-bottom: 12px; }
.sus-text p { font-size: 13px; color: rgba(251,249,228,0.45); max-width: 380px; line-height: 1.7; }
.sus-form {
  flex: 0 0 420px;
  background: rgba(10,13,13,0.6);
  border: 1px solid rgba(238,103,146,0.2);
  border-radius: 10px; padding: 36px 32px;
}
.sus-form-label {
  font-size: 9px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase;
  color: var(--pink); margin-bottom: 20px; display: block;
}
.sus-input-row { display: flex; flex-direction: column; gap: 12px; margin-bottom: 16px; }
.sus-input {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(238,103,146,0.18);
  border-radius: 4px; padding: 13px 16px;
  color: var(--cream); font-family: var(--fbody); font-size: 13px;
  outline: none; transition: border-color .2s; width: 100%;
}
.sus-input:focus { border-color: var(--pink); }
.sus-input::placeholder { color: rgba(251,249,228,0.25); }
.sus-btn {
  width: 100%; background: var(--pink); color: var(--black);
  font-family: var(--fbody); font-size: 11px; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  padding: 14px; border-radius: 4px;
  transition: box-shadow .25s, transform .2s;
}
.sus-btn:hover { box-shadow: var(--glow); transform: translateY(-1px); }
.sus-disclaimer {
  font-size: 10px; color: rgba(251,249,228,0.25);
  line-height: 1.6; margin-top: 12px; text-align: center;
}

/* =====================================================
   FAB — WhatsApp sticky
===================================================== */
.fab {
  position: fixed; bottom: 32px; right: 32px; z-index: 800;
  width: 56px; height: 56px; border-radius: 50%;
  background: #25D366;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 24px rgba(37,211,102,0.4);
  transition: transform .25s, box-shadow .25s;
  animation: fabIn .5s ease .8s both;
}
@keyframes fabIn { from { transform: scale(0) rotate(-90deg); } to { transform: scale(1) rotate(0); } }
.fab:hover { transform: scale(1.12); box-shadow: 0 8px 32px rgba(37,211,102,0.6); }
.fab svg { width: 26px; height: 26px; fill: #fff; }
.fab-tip {
  position: absolute; right: 68px;
  background: rgba(10,13,13,0.95); color: var(--cream);
  border: 1px solid rgba(255,255,255,0.08);
  font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  padding: 8px 14px; border-radius: 4px; white-space: nowrap;
  opacity: 0; transform: translateX(6px); pointer-events: none;
  transition: all .2s;
}
.fab:hover .fab-tip { opacity: 1; transform: translateX(0); }

/* =====================================================
   RESPONSIVE
===================================================== */
@media (max-width: 980px) {
  body { cursor: auto; }
  .cursor, .cursor-ring { display: none; }
  .nav { padding: 16px 24px; }
  .nav.scrolled { padding: 12px 24px; }
  .nav-logo-img {
    height: 48px;
    width: 143px;
  }
  .hero-content { padding: 0 24px 64px; }
  .hero-kanji { display: none; }
  .vibe, .loc { grid-template-columns: 1fr; }
  .vibe-right { height: 50vw; min-height: 300px; }
  .vibe-right-img { background: url('https://images.unsplash.com/photo-1617196034183-421b4040ed20?w=900&q=80') center/cover no-repeat; }
  .food-row, .food-row.rev { grid-template-columns: 1fr; direction: ltr; }
  .food-row.rev .food-text { order: 2; }
  .food-img { height: 50vw; min-height: 280px; }
  .food-text { padding: 48px 24px; }
  .vibe-left, .loc-info, .sounds, .delivery { padding: 72px 24px; }
  .food-intro { padding: 72px 24px 40px; }
  .sounds-head { grid-template-columns: 1fr; }
  .sounds-grid { grid-template-columns: 1fr; }
  .delivery-inner { flex-direction: column; gap: 36px; }
  .carta-strip { flex-direction: column; gap: 32px; padding: 48px 24px; }
  .nov-section { padding: 72px 0 72px 24px; }
  .ft-top { grid-template-columns: 1fr 1fr; }
  .ft-bottom { flex-direction: column; text-align: center; }
  .fab { bottom: 20px; right: 20px; }
  .quienes { grid-template-columns: 1fr; }
  .quienes-img { height: 50vw; min-height: 260px; }
  .quienes-text { padding: 60px 24px; border-left: none; border-top: 1px solid rgba(238,103,146,0.1); }
  .suscripcion { flex-direction: column; padding: 60px 24px; }
  .sus-form { flex: 0 0 auto; width: 100%; }
  .modal { padding: 40px 24px; }
}
:root {
  --black: #0a0d0d;
  --pink:  #ee6792;
  --cream: #FBF9E4;
  --gray:  #141818;
  --glow:  0 0 20px rgba(238,103,146,0.45), 0 0 50px rgba(238,103,146,0.15);
  --fhead: 'Azo Sans', sans-serif;
  --falt:  'Barlow Condensed', sans-serif;
  --fbody: 'Chillax', sans-serif;
  --ease:  cubic-bezier(.4,0,.2,1);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--black); color: var(--cream);
  font-family: var(--fbody); overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
button { border: none; background: none; font-family: inherit; cursor: pointer; }
img { display: block; width: 100%; object-fit: cover; }

/* ── NAV ── */
.nav {
  position: sticky; top: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 56px;
  background: rgba(10,13,13,0.95);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(238,103,146,0.12);
}
.nav-logo { display: flex; gap: 3px; align-items: center; }
.nc { width: 26px; height: 26px; background: var(--cream); color: var(--black); display: flex; align-items: center; justify-content: center; font-family: var(--fhead); font-size: 12px; border-radius: 3px; }
.nc.p { background: var(--pink); }
.nav-logo span { margin-left: 10px; font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: var(--pink); font-weight: 600; }
.nav-back {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: rgba(251,249,228,0.5); transition: color .2s;
}
.nav-back:hover { color: var(--pink); }
.nav-reserve {
  background: var(--pink); color: var(--black);
  font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase;
  padding: 10px 22px; border-radius: 3px;
  transition: box-shadow .25s;
}
.nav-reserve:hover { box-shadow: var(--glow); }

/* ── PAGE HERO ── */
.page-hero {
  position: relative; overflow: hidden;
  padding: 80px 56px 64px;
  border-bottom: 1px solid rgba(238,103,146,0.1);
}
.page-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 80% 50%, rgba(238,103,146,0.08) 0%, transparent 60%),
    repeating-linear-gradient(0deg, rgba(238,103,146,0.025) 0, rgba(238,103,146,0.025) 1px, transparent 1px, transparent 48px),
    repeating-linear-gradient(90deg, rgba(238,103,146,0.025) 0, rgba(238,103,146,0.025) 1px, transparent 1px, transparent 48px);
}
.page-hero-kanji {
  position: absolute; right: 56px; top: 50%; transform: translateY(-50%);
  font-family: var(--fhead); font-size: clamp(100px,14vw,200px);
  color: rgba(238,103,146,0.05); line-height: 1;
  writing-mode: vertical-rl; pointer-events: none; user-select: none;
}
.page-hero-inner { position: relative; z-index: 1; }
.ph-eyebrow {
  font-size: 9px; font-weight: 700; letter-spacing: 4px; text-transform: uppercase;
  color: var(--pink); margin-bottom: 16px; display: flex; align-items: center; gap: 12px;
}
.ph-eyebrow::before { content: ''; width: 24px; height: 2px; background: var(--pink); }
.ph-title {
  font-family: var(--fhead);
  font-size: clamp(56px, 9vw, 140px);
  line-height: 0.88; color: var(--cream); margin-bottom: 24px;
}
.ph-title .ol { -webkit-text-stroke: 2px var(--cream); color: transparent; }
.ph-title .pk { color: var(--pink); }
.ph-desc { font-size: 14px; font-weight: 300; color: rgba(251,249,228,0.5); max-width: 480px; line-height: 1.75; }

/* ── STICKY FILTER BAR ── */
.filter-bar {
  position: sticky; top: 57px; z-index: 100;
  background: rgba(10,13,13,0.97);
  border-bottom: 1px solid rgba(238,103,146,0.1);
  backdrop-filter: blur(12px);
}
.filter-inner {
  display: flex; gap: 0; overflow-x: auto; padding: 0 56px;
  scrollbar-width: none;
}
.filter-inner::-webkit-scrollbar { display: none; }
.f-btn {
  flex-shrink: 0;
  display: flex; align-items: center; gap: 8px;
  padding: 18px 22px;
  font-family: var(--fbody); font-size: 11px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: rgba(251,249,228,0.4);
  border-bottom: 2px solid transparent;
  transition: color .2s, border-color .2s;
  white-space: nowrap;
}
.f-btn .kanji { font-size: 12px; opacity: .6; }
.f-btn:hover { color: var(--cream); }
.f-btn.active { color: var(--pink); border-bottom-color: var(--pink); }

/* ── MAIN LAYOUT ── */
.carta-layout {
  display: grid; grid-template-columns: 260px 1fr;
  min-height: 80vh;
}

/* sidebar */
.sidebar {
  position: sticky; top: 115px; align-self: start;
  padding: 48px 32px 48px 56px;
  border-right: 1px solid rgba(238,103,146,0.08);
  height: calc(100vh - 115px); overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: rgba(238,103,146,0.2) transparent;
}
.sidebar-title {
  font-size: 8px; font-weight: 700; letter-spacing: 4px; text-transform: uppercase;
  color: rgba(238,103,146,0.6); margin-bottom: 20px;
}
.sidebar-nav { display: flex; flex-direction: column; gap: 2px; }
.sb-link {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 12px; border-radius: 4px;
  font-size: 12px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase;
  color: rgba(251,249,228,0.45); transition: all .2s;
}
.sb-link:hover { background: rgba(238,103,146,0.08); color: var(--cream); }
.sb-link.active { background: rgba(238,103,146,0.12); color: var(--pink); }
.sb-count {
  font-size: 10px; font-weight: 700;
  background: rgba(238,103,146,0.15); color: var(--pink);
  padding: 2px 7px; border-radius: 10px;
}

/* main content */
.carta-main { padding: 56px 56px 96px 48px; }

/* search */
.search-row {
  display: flex; gap: 12px; align-items: center; margin-bottom: 48px;
}
.search-wrap {
  flex: 1; position: relative;
}
.search-icon {
  position: absolute; left: 16px; top: 50%; transform: translateY(-50%);
  color: rgba(238,103,146,0.5); font-size: 16px; pointer-events: none;
}
.search-input {
  width: 100%; background: rgba(255,255,255,0.04);
  border: 1px solid rgba(238,103,146,0.18); border-radius: 6px;
  padding: 13px 16px 13px 44px;
  color: var(--cream); font-family: var(--fbody); font-size: 13px;
  outline: none; transition: border-color .2s;
}
.search-input:focus { border-color: var(--pink); }
.search-input::placeholder { color: rgba(251,249,228,0.25); }
.sort-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 13px 18px; border-radius: 6px;
  border: 1px solid rgba(238,103,146,0.18);
  font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase;
  color: rgba(251,249,228,0.5); transition: all .2s;
}
.sort-btn:hover { border-color: var(--pink); color: var(--pink); }

/* category section */
.cat-section { margin-bottom: 80px; }
.cat-header {
  display: flex; align-items: baseline; gap: 16px; margin-bottom: 32px;
  padding-bottom: 16px; border-bottom: 1px solid rgba(238,103,146,0.1);
}
.cat-title {
  font-family: var(--fhead);
  font-size: clamp(28px, 3.5vw, 48px);
  color: var(--cream); line-height: 1;
}
.cat-kanji { font-size: 20px; color: var(--pink); opacity: .7; }
.cat-count { font-size: 11px; color: rgba(251,249,228,0.3); letter-spacing: 1px; margin-left: auto; }

/* grid */
.menu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
}

/* card */
.m-card {
  background: var(--gray);
  border: 1px solid rgba(238,103,146,0.1);
  border-radius: 10px; overflow: hidden;
  transition: transform .3s var(--ease), box-shadow .3s;
  display: flex; flex-direction: column;
}
.m-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.5), 0 0 0 1px rgba(238,103,146,0.2);
}
.m-card-img {
  position: relative; height: 200px; overflow: hidden;
}
.m-card-img img { height: 100%; transition: transform .5s var(--ease); }
.m-card:hover .m-card-img img { transform: scale(1.07); }
.m-card-badge {
  position: absolute; top: 12px; left: 12px;
  font-size: 8px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  padding: 4px 10px; border-radius: 2px;
}
.badge-rec { background: var(--pink); color: var(--black); }
.badge-new { background: #25D366; color: var(--black); }
.badge-hot { background: #FF441B; color: #fff; }
.badge-veg { background: #4CAF50; color: #fff; }
.m-card-units {
  position: absolute; bottom: 10px; right: 12px;
  font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase;
  background: rgba(10,13,13,0.8); color: rgba(251,249,228,0.6);
  padding: 3px 8px; border-radius: 2px;
}
.m-card-body {
  padding: 20px 20px 16px; flex: 1; display: flex; flex-direction: column;
}
.m-card-kanji { font-size: 11px; color: var(--pink); letter-spacing: 1px; margin-bottom: 5px; }
.m-card-name {
  font-family: var(--falt); font-size: 20px; font-weight: 900;
  text-transform: uppercase; color: var(--cream); line-height: 1.1;
  margin-bottom: 8px;
}
.m-card-desc {
  font-size: 12px; color: rgba(251,249,228,0.45); line-height: 1.65;
  flex: 1; margin-bottom: 16px;
}
.m-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 12px; border-top: 1px solid rgba(238,103,146,0.08);
}
.m-card-price { font-family: var(--falt); font-size: 26px; font-weight: 900; color: var(--pink); }
.m-card-unit { font-size: 9px; letter-spacing: 1px; text-transform: uppercase; color: rgba(251,249,228,0.3); }
.m-card-cta {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-radius: 4px;
  background: rgba(238,103,146,0.1); color: var(--pink);
  font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  border: 1px solid rgba(238,103,146,0.2);
  transition: all .2s;
}
.m-card-cta:hover { background: var(--pink); color: var(--black); }

/* featured card — wider */
.m-card.featured {
  grid-column: span 2;
  flex-direction: row;
}
.m-card.featured .m-card-img { height: auto; min-height: 240px; width: 45%; flex-shrink: 0; }
.m-card.featured .m-card-img img { height: 100%; }
.m-card.featured .m-card-name { font-size: 28px; }
.m-card.featured .m-card-desc { font-size: 13px; }

/* ── COCKTAIL CARD (horizontal minimal) ── */
.cocktail-list { display: flex; flex-direction: column; gap: 1px; }
.ckt-card {
  display: flex; align-items: center; gap: 0;
  padding: 20px 0;
  border-bottom: 1px solid rgba(238,103,146,0.07);
  transition: all .2s;
}
.ckt-card:hover .ckt-name { color: var(--pink); }
.ckt-img { width: 72px; height: 72px; border-radius: 6px; overflow: hidden; flex-shrink: 0; margin-right: 20px; }
.ckt-img img { height: 100%; }
.ckt-info { flex: 1; }
.ckt-kanji { font-size: 10px; color: var(--pink); letter-spacing: 1px; margin-bottom: 4px; }
.ckt-name { font-family: var(--falt); font-size: 18px; font-weight: 900; text-transform: uppercase; color: var(--cream); transition: color .2s; }
.ckt-desc { font-size: 12px; color: rgba(251,249,228,0.4); margin-top: 4px; line-height: 1.5; }
.ckt-price { font-family: var(--falt); font-size: 24px; font-weight: 900; color: var(--pink); margin-left: 24px; white-space: nowrap; }

/* ── DELIVERY STRIP ── */
.delivery-strip {
  margin: 0 56px 80px;
  padding: 32px 40px;
  border: 1px solid rgba(238,103,146,0.2);
  border-radius: 8px;
  background: rgba(238,103,146,0.04);
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.ds-text p { font-size: 12px; color: rgba(251,249,228,0.45); margin-top: 4px; }
.ds-text strong { font-family: var(--falt); font-size: 20px; color: var(--cream); letter-spacing: 1px; }
.ds-apps { display: flex; gap: 10px; }
.ds-app {
  padding: 10px 20px; border-radius: 4px;
  font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
}
.ds-app.r { background: #FF441B; color: #fff; }
.ds-app.i { background: #EA1D2C; color: #fff; }
.ds-app.p { background: #FFCC00; color: #000; }

/* ── FAB ── */
.fab {
  position: fixed; bottom: 28px; right: 28px; z-index: 500;
  display: flex; align-items: center; gap: 10px;
  background: var(--pink); color: var(--black);
  font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  padding: 14px 24px; border-radius: 50px;
  box-shadow: var(--glow);
  animation: fabIn .5s var(--ease) .3s both;
}
@keyframes fabIn { from{transform:translateY(20px);opacity:0} to{transform:none;opacity:1} }
.fab:hover { box-shadow: 0 0 32px rgba(238,103,146,0.7); }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .nav, .filter-inner, .carta-main, .page-hero, .delivery-strip { padding-left: 20px; padding-right: 20px; }
  .carta-layout { grid-template-columns: 1fr; }
  .sidebar { display: none; }
  .m-card.featured { grid-column: span 1; flex-direction: column; }
  .m-card.featured .m-card-img { width: 100%; }
  .menu-grid { grid-template-columns: 1fr; }
  .delivery-strip { flex-direction: column; margin: 0 20px 60px; }
}

/* =====================================================
   WORDPRESS — extras
===================================================== */
.page-hero {
  position: relative; overflow: hidden;
  padding: 120px 72px 80px;
  border-bottom: 1px solid rgba(238,103,146,0.1);
}
.page-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 80% 50%, rgba(238,103,146,0.08) 0%, transparent 60%),
    repeating-linear-gradient(0deg, rgba(238,103,146,0.025) 0, rgba(238,103,146,0.025) 1px, transparent 1px, transparent 48px),
    repeating-linear-gradient(90deg, rgba(238,103,146,0.025) 0, rgba(238,103,146,0.025) 1px, transparent 1px, transparent 48px);
}
.page-hero-kanji {
  position: absolute; right: 56px; top: 50%; transform: translateY(-50%);
  font-family: var(--fhead); font-size: clamp(100px,14vw,200px);
  color: rgba(238,103,146,0.05); line-height: 1;
  writing-mode: vertical-rl; pointer-events: none; user-select: none;
}
.page-hero-inner { position: relative; z-index: 1; }
.ph-eyebrow { font-size: 9px; font-weight: 700; letter-spacing: 4px; text-transform: uppercase; color: var(--pink); margin-bottom: 16px; display: flex; align-items: center; gap: 12px; }
.ph-eyebrow::before { content: ''; width: 24px; height: 2px; background: var(--pink); }
.ph-title { font-family: var(--fhead); font-size: clamp(56px,9vw,140px); line-height: 0.88; color: var(--cream); margin-bottom: 24px; }
.ph-title .pk { color: var(--pink); }
.ph-title .ol { -webkit-text-stroke: 2px var(--cream); color: transparent; }
.ph-desc { font-size: 14px; font-weight: 300; color: rgba(251,249,228,0.5); max-width: 480px; line-height: 1.75; }

/* filter bar */
.filter-bar { position: sticky; top: 57px; z-index: 100; background: rgba(10,13,13,0.97); border-bottom: 1px solid rgba(238,103,146,0.1); backdrop-filter: blur(12px); }
.filter-inner { display: flex; gap: 0; overflow-x: auto; padding: 0 56px; scrollbar-width: none; }
.filter-inner::-webkit-scrollbar { display: none; }
.f-btn { flex-shrink: 0; padding: 18px 22px; font-family: var(--fbody); font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(251,249,228,0.4); border-bottom: 2px solid transparent; transition: color .2s, border-color .2s; white-space: nowrap; border: none; background: none; cursor: pointer; }
.f-btn:hover { color: var(--cream); }
.f-btn.active { color: var(--pink); border-bottom-color: var(--pink); }

/* carta layout */
.carta-layout { display: grid; grid-template-columns: 260px 1fr; min-height: 80vh; }
.sidebar { position: sticky; top: 115px; align-self: start; padding: 48px 32px 48px 56px; border-right: 1px solid rgba(238,103,146,0.08); height: calc(100vh - 115px); overflow-y: auto; scrollbar-width: thin; scrollbar-color: rgba(238,103,146,0.2) transparent; }
.sidebar-title { font-size: 8px; font-weight: 700; letter-spacing: 4px; text-transform: uppercase; color: rgba(238,103,146,0.6); margin-bottom: 20px; }
.sidebar-nav { display: flex; flex-direction: column; gap: 2px; }
.sb-link { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; border-radius: 4px; font-size: 12px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; color: rgba(251,249,228,0.45); transition: all .2s; text-decoration: none; }
.sb-link:hover { background: rgba(238,103,146,0.08); color: var(--cream); }
.sb-link.active { background: rgba(238,103,146,0.12); color: var(--pink); }
.sb-count { font-size: 10px; font-weight: 700; background: rgba(238,103,146,0.15); color: var(--pink); padding: 2px 7px; border-radius: 10px; }
.carta-main { padding: 56px 56px 96px 48px; }
.search-row { display: flex; gap: 12px; align-items: center; margin-bottom: 48px; }
.search-wrap { flex: 1; position: relative; }
.search-icon { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: rgba(238,103,146,0.5); font-size: 16px; pointer-events: none; }
.search-input { width: 100%; background: rgba(255,255,255,0.04); border: 1px solid rgba(238,103,146,0.18); border-radius: 6px; padding: 13px 16px 13px 44px; color: var(--cream); font-family: var(--fbody); font-size: 13px; outline: none; transition: border-color .2s; }
.search-input:focus { border-color: var(--pink); }
.search-input::placeholder { color: rgba(251,249,228,0.25); }
.cat-section { margin-bottom: 80px; }
.cat-header { display: flex; align-items: baseline; gap: 16px; margin-bottom: 32px; padding-bottom: 16px; border-bottom: 1px solid rgba(238,103,146,0.1); }
.cat-title { font-family: var(--fhead); font-size: clamp(28px,3.5vw,48px); color: var(--cream); line-height: 1; }
.cat-kanji { font-size: 20px; color: var(--pink); opacity: .7; }
.cat-count { font-size: 11px; color: rgba(251,249,228,0.3); letter-spacing: 1px; margin-left: auto; }

/* delivery strip */
.delivery-strip { margin: 0 56px 80px; padding: 32px 40px; border: 1px solid rgba(238,103,146,0.2); border-radius: 8px; background: rgba(238,103,146,0.04); display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.ds-text p { font-size: 12px; color: rgba(251,249,228,0.45); margin-top: 4px; }
.ds-text strong { font-family: var(--falt); font-size: 20px; color: var(--cream); letter-spacing: 1px; }
.ds-apps { display: flex; gap: 10px; }
.ds-app { padding: 10px 20px; border-radius: 4px; font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; text-decoration: none; }
.ds-app.r { background: #FF441B; color: #fff; }
.ds-app.i { background: #EA1D2C; color: #fff; }
.ds-app.p { background: #FFCC00; color: #000; }

/* novedades archive */
.pills-bar { padding: 28px 56px; border-bottom: 1px solid rgba(238,103,146,0.08); display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.pills-label { font-size: 9px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: rgba(251,249,228,0.3); margin-right: 4px; }
.pill { padding: 7px 16px; border-radius: 50px; font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; border: 1px solid rgba(238,103,146,0.2); color: rgba(251,249,228,0.45); transition: all .2s; text-decoration: none; background: none; cursor: pointer; }
.pill:hover { border-color: rgba(238,103,146,0.5); color: var(--cream); }
.pill.on { background: var(--pink); color: var(--black); border-color: var(--pink); }

/* featured post */
.featured-post { margin: 56px 56px 0; display: grid; grid-template-columns: 1fr 1fr; border-radius: 12px; overflow: hidden; border: 1px solid rgba(238,103,146,0.15); min-height: 480px; cursor: pointer; transition: box-shadow .3s; text-decoration: none; color: inherit; }
.featured-post:hover { box-shadow: 0 0 0 2px var(--pink), 0 20px 60px rgba(0,0,0,0.5); }
.fp-img { position: relative; overflow: hidden; }
.fp-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.featured-post:hover .fp-img img { transform: scale(1.05); }
.fp-img-overlay { position: absolute; inset: 0; background: linear-gradient(to right, transparent 60%, #111515 100%); }
.fp-badge { position: absolute; top: 20px; left: 20px; font-size: 9px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; background: var(--pink); color: var(--black); padding: 5px 12px; border-radius: 2px; }
.fp-content { display: flex; flex-direction: column; justify-content: center; padding: 52px 48px; background: #111515; }
.fp-tag { font-size: 9px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--pink); margin-bottom: 16px; display: flex; align-items: center; gap: 10px; }
.fp-tag::before { content: ''; width: 20px; height: 2px; background: var(--pink); }
.fp-title { font-family: var(--fhead); font-size: clamp(28px,3.5vw,52px); color: var(--cream); line-height: 1; margin-bottom: 20px; }
.fp-excerpt { font-size: 14px; font-weight: 300; color: rgba(251,249,228,0.55); line-height: 1.75; margin-bottom: 32px; }
.fp-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.fp-date { font-size: 11px; color: rgba(251,249,228,0.35); letter-spacing: 1px; }
.fp-cta { display: inline-flex; align-items: center; gap: 8px; background: var(--pink); color: var(--black); font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 12px 22px; border-radius: 3px; transition: box-shadow .2s; margin-left: auto; }
.fp-cta:hover { box-shadow: var(--glow); }
.posts-section { padding: 56px 56px 40px; }
.posts-header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 40px; }
.posts-header h2 { font-family: var(--falt); font-size: 14px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: rgba(251,249,228,0.4); }
.posts-count { font-size: 11px; color: rgba(251,249,228,0.25); }
.posts-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 24px; }
.p-card { background: #111515; border: 1px solid rgba(238,103,146,0.08); border-radius: 10px; overflow: hidden; display: flex; flex-direction: column; transition: transform .3s, box-shadow .3s, border-color .3s; }
.p-card-link { display: flex; flex-direction: column; text-decoration: none; color: inherit; height: 100%; }
.p-card:hover { transform: translateY(-5px); border-color: rgba(238,103,146,0.25); box-shadow: 0 16px 40px rgba(0,0,0,0.4); }
.p-card-img { position: relative; height: 220px; overflow: hidden; }
.p-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.p-card:hover .p-card-img img { transform: scale(1.06); }
.p-card-img::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px; }
.cat-promo .p-card-img::after { background: var(--pink); }
.cat-evento .p-card-img::after { background: #FFD700; }
.cat-fide .p-card-img::after { background: #25D366; }
.cat-especial .p-card-img::after { background: #9B59B6; }
.cat-lanzamiento .p-card-img::after { background: #FF441B; }
.p-cat-badge { position: absolute; top: 14px; left: 14px; font-size: 8px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 4px 10px; border-radius: 2px; }
.cat-promo .p-cat-badge { background: var(--pink); color: var(--black); }
.cat-evento .p-cat-badge { background: #FFD700; color: var(--black); }
.cat-fide .p-cat-badge { background: #25D366; color: var(--black); }
.cat-especial .p-cat-badge { background: #9B59B6; color: #fff; }
.cat-lanzamiento .p-cat-badge { background: #FF441B; color: #fff; }
.p-card-body { padding: 24px 22px 20px; flex: 1; display: flex; flex-direction: column; }
.p-card-emoji { font-size: 24px; margin-bottom: 12px; display: block; }
.p-card-title { font-family: var(--falt); font-size: 22px; font-weight: 900; text-transform: uppercase; color: var(--cream); line-height: 1.1; margin-bottom: 10px; }
.p-card-excerpt { font-size: 12px; color: rgba(251,249,228,0.45); line-height: 1.65; flex: 1; margin-bottom: 20px; }
.p-card-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 14px; border-top: 1px solid rgba(238,103,146,0.07); }
.p-card-date { font-size: 10px; color: rgba(251,249,228,0.3); letter-spacing: 1px; }
.p-card-read { font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--pink); }

/* pagination */
.pagination { padding: 0 56px 40px; }
.pagination .nav-links { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.pagination .page-numbers { width: 40px; height: 40px; border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; border: 1px solid rgba(238,103,146,0.15); color: rgba(251,249,228,0.4); text-decoration: none; transition: all .2s; }
.pagination .page-numbers.current { background: var(--pink); color: var(--black); border-color: var(--pink); }
.pagination .page-numbers:hover:not(.current) { border-color: rgba(238,103,146,0.4); color: var(--cream); }

/* newsletter strip */
.newsletter-strip { margin: 0 56px 80px; padding: 48px 56px; border-radius: 10px; border: 1px solid rgba(238,103,146,0.2); background: rgba(238,103,146,0.04); display: flex; align-items: center; justify-content: space-between; gap: 40px; }
.ns-text h3 { font-family: var(--fhead); font-size: clamp(24px,3.5vw,42px); color: var(--cream); line-height: 1; margin-bottom: 8px; }
.ns-text h3 .pk { color: var(--pink); }
.ns-text p { font-size: 13px; color: rgba(251,249,228,0.4); }
.ns-form { display: flex; gap: 0; border: 1px solid rgba(238,103,146,0.2); border-radius: 5px; overflow: hidden; min-width: 340px; }
.ns-input { flex: 1; background: rgba(255,255,255,0.04); border: none; outline: none; padding: 14px 18px; color: var(--cream); font-family: var(--fbody); font-size: 13px; }
.ns-input::placeholder { color: rgba(251,249,228,0.25); }
.ns-btn { background: var(--pink); color: var(--black); font-family: var(--fbody); font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 14px 22px; transition: box-shadow .2s; border: none; cursor: pointer; }

/* site-footer */
.site-footer { background: #060808; border-top: 1px solid rgba(238,103,146,0.1); padding: 80px 72px 40px; }
.ft-top { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 64px; }
.ft-brand {}
.ft-tagline { font-size: 12px; color: rgba(251,249,228,0.35); line-height: 1.8; max-width: 220px; margin: 14px 0 24px; }
.ft-sub-label { font-size: 9px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--pink); display: block; margin-bottom: 10px; }
.ft-sub { display: flex; gap: 0; border: 1px solid rgba(238,103,146,0.2); border-radius: 4px; overflow: hidden; }
.ft-sub-input { flex: 1; background: rgba(255,255,255,0.03); border: none; outline: none; padding: 10px 14px; color: var(--cream); font-family: var(--fbody); font-size: 12px; }
.ft-sub-input::placeholder { color: rgba(251,249,228,0.25); }
.ft-sub-btn { background: var(--pink); color: var(--black); font-family: var(--fbody); font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 10px 16px; border: none; cursor: pointer; }
.ft-col-head { font-size: 9px; font-weight: 700; letter-spacing: 3.5px; text-transform: uppercase; color: var(--pink); margin-bottom: 20px; }
.ft-col ul { display: flex; flex-direction: column; gap: 10px; list-style: none; padding: 0; margin: 0; }
.ft-col ul a { font-size: 13px; color: rgba(251,249,228,0.45); transition: color .2s; text-decoration: none; }
.ft-col ul a:hover { color: var(--cream); }
.ft-soc { display: flex; gap: 10px; margin-bottom: 24px; }
.soc-btn { width: 36px; height: 36px; border-radius: 50%; border: 1px solid rgba(238,103,146,0.2); display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; color: rgba(251,249,228,0.4); transition: all .2s; text-decoration: none; }
.soc-btn:hover { border-color: var(--pink); color: var(--pink); }
.ft-hours { font-size: 11px; color: rgba(251,249,228,0.35); line-height: 1.9; }
.ft-bottom { border-top: 1px solid rgba(255,255,255,0.05); padding-top: 28px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.ft-legal { display: flex; gap: 20px; flex-wrap: wrap; }
.ft-legal a { font-size: 10px; color: rgba(251,249,228,0.25); letter-spacing: 1px; text-transform: uppercase; transition: color .2s; text-decoration: none; }
.ft-legal a:hover { color: rgba(251,249,228,0.55); }
.ft-copy { font-size: 10px; color: rgba(251,249,228,0.15); letter-spacing: 1px; }

/* admin bar offset */
.admin-bar .nav { top: 32px; }
.admin-bar .filter-bar { top: 89px; }

/* responsive */
@media (max-width: 980px) {
  body { cursor: auto; }
  .cursor, .cursor-ring { display: none; }
  .page-hero { padding: 80px 20px 60px; }
  .page-hero-kanji { display: none; }
  .filter-inner, .pills-bar, .posts-section, .newsletter-strip { padding-left: 20px; padding-right: 20px; }
  .featured-post { grid-template-columns: 1fr; margin: 32px 20px 0; min-height: auto; }
  .fp-img { height: 240px; }
  .fp-content { padding: 32px 24px; }
  .carta-layout { grid-template-columns: 1fr; }
  .sidebar { display: none; }
  .carta-main { padding: 40px 20px 60px; }
  .delivery-strip, .newsletter-strip { flex-direction: column; margin: 0 20px 60px; }
  .ns-form { min-width: auto; width: 100%; }
  .posts-grid { grid-template-columns: 1fr; }
  .site-footer { padding: 60px 24px 32px; }
  .ft-top { grid-template-columns: 1fr 1fr; gap: 32px; }
  .ft-bottom { flex-direction: column; text-align: center; }
  .pagination { padding-left: 20px; padding-right: 20px; }
}

/* =====================================================
   SIDE MENU (MUNDO NIKITA)
===================================================== */
.nav-menu-btn {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  display: block;
  transition: transform 0.3s var(--ease);
}
.nav-menu-btn:hover {
  transform: translateY(-1px);
}
.nav-menu-trigger-img {
  height: 48px;
  width: auto;
  display: block;
  border-radius: 4px;
  transition: box-shadow 0.3s var(--ease);
}
.nav-menu-btn:hover .nav-menu-trigger-img {
  box-shadow: var(--glow);
}

.side-menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 13, 13, 0.7);
  backdrop-filter: blur(4px);
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s var(--ease);
}
.side-menu-overlay.open {
  opacity: 1;
  pointer-events: all;
}

.side-menu {
  position: fixed;
  top: 0;
  right: -315px;
  width: 315px;
  height: 717px;
  background: rgba(28, 31, 31, 0.62); /* Tono oscuro original semitransparente */
  backdrop-filter: blur(20px); /* Desenfoque de fondo premium (glassmorphism) */
  -webkit-backdrop-filter: blur(20px);
  z-index: 1000;
  box-shadow: -10px 0 30px rgba(0, 0, 0, 0.5);
  transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  padding: 80px 40px;
  display: flex;
  flex-direction: column;
  border-left: 1px solid rgba(238, 103, 146, 0.2);
  border-bottom: 1px solid rgba(238, 103, 146, 0.2);
  max-height: 100vh;
  overflow-y: auto;
}
.side-menu.open {
  right: 0;
}

.side-menu-close {
  position: absolute;
  top: 24px;
  right: 24px;
  background: none;
  border: none;
  color: var(--cream);
  font-size: 24px;
  cursor: pointer;
  transition: color 0.3s var(--ease);
}
.side-menu-close:hover {
  color: var(--pink);
}

.side-menu-nav ul {
  display: flex;
  flex-direction: column;
  gap: 28px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.side-menu-nav a {
  font-family: var(--fhead);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 2px;
  color: var(--cream);
  text-decoration: none;
  transition: color 0.3s var(--ease), padding-left 0.3s var(--ease);
  display: inline-block;
}
.side-menu-nav a:hover {
  color: var(--pink);
  padding-left: 8px;
}

@media (max-width: 980px) {
  .nav-menu-trigger-img {
    height: 38px;
  }
  .side-menu {
    height: 100vh;
  }
}