/* Unificar el estilo del botón de reserva con el botón primario */
.btn-reserve {
  display: inline-block;
  padding: 1rem 2.8rem;
  background: var(--gold);
  color: var(--white);
  border: 1px solid var(--gold);
  font-size: 0.75rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 400;
  cursor: pointer;
  transition: all var(--transition);
  margin-top: 1rem;
  width: 100%; /* Si quieres que ocupe el ancho del grid */
}

.btn-reserve:hover {
  background: transparent;
  color: var(--gold);
}

.btn-reserve:disabled {
  background: #2d6a4f !important;
  border-color: #2d6a4f !important;
  cursor: default;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#1a1410;
  --ink2:#3d3028;
  --ink3:#6b5c50;
  --cream:#f5f0e8;
  --cream2:#ede5d4;
  --cream3:#faf7f2;
  --gold:#b8975a;
  --gold2:#8a6e3c;
  --red:#8b1a1a;
  --white:#fff;
  --ff-serif:'Cormorant Garamond',serif;
  --ff-jp:'Noto Serif JP',serif;
  --ff-sans:'Inter',sans-serif;
  --max:1200px;
  --transition:0.4s cubic-bezier(0.4,0,0.2,1);
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff-sans);background:var(--cream3);color:var(--ink);overflow-x:hidden;line-height:1.7}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.25rem 2rem;display:flex;align-items:center;justify-content:space-between;transition:background var(--transition),box-shadow var(--transition)}
nav.scrolled{background:rgba(250,247,242,0.97);box-shadow:0 1px 0 rgba(184,151,90,0.2)}
.nav-logo{font-family:var(--ff-serif);font-size:1.6rem;font-weight:300;letter-spacing:0.12em;color:var(--white);text-decoration:none;transition:color var(--transition)}
nav.scrolled .nav-logo{color:var(--ink)}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{font-size:0.78rem;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.85);text-decoration:none;transition:color var(--transition);font-weight:400}
nav.scrolled .nav-links a{color:var(--ink3)}
.nav-links a:hover{color:var(--gold)}
nav.scrolled .nav-links a:hover{color:var(--gold)}
.nav-cta{font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;padding:0.6rem 1.4rem;border:1px solid rgba(255,255,255,0.6);color:var(--white);text-decoration:none;transition:all var(--transition);font-weight:400}
nav.scrolled .nav-cta{border-color:var(--gold);color:var(--gold)}
.nav-cta:hover{background:var(--gold);border-color:var(--gold);color:var(--white)!important}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.nav-burger span{display:block;width:24px;height:1px;background:var(--white);transition:background var(--transition)}
nav.scrolled .nav-burger span{background:var(--ink)}

/* HERO */
.hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero-img{position:absolute;inset:0;background:url('assets/hero/hero.webp') center/cover no-repeat;filter:brightness(0.55)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,6,3,0.3) 0%,rgba(10,6,3,0.15) 50%,rgba(10,6,3,0.55) 100%)}
.hero-content{position:relative;z-index:2;max-width:780px;padding:2rem}
.hero-jp{font-family:var(--ff-jp);font-size:1rem;letter-spacing:0.4em;color:var(--gold);margin-bottom:1.2rem;font-weight:300;opacity:0.9}
.hero-title{font-family:var(--ff-serif);font-size:clamp(3.5rem,8vw,7rem);font-weight:300;color:var(--white);line-height:1;letter-spacing:0.06em;margin-bottom:1.5rem}
.hero-title em{font-style:italic;color:rgba(255,255,255,0.75)}
.hero-sub{font-size:0.9rem;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-bottom:2.8rem;font-weight:300}
.hero-line{width:60px;height:1px;background:var(--gold);margin:0 auto 2.8rem}
.btn-primary{display:inline-block;padding:1rem 2.8rem;background:var(--gold);color:var(--white);text-decoration:none;font-size:0.75rem;letter-spacing:0.22em;text-transform:uppercase;font-weight:400;transition:all var(--transition);border:1px solid var(--gold)}
.btn-primary:hover{background:transparent;color:var(--white)}
.btn-ghost{display:inline-block;padding:1rem 2.8rem;background:transparent;color:var(--white);text-decoration:none;font-size:0.75rem;letter-spacing:0.22em;text-transform:uppercase;font-weight:400;transition:all var(--transition);border:1px solid rgba(255,255,255,0.5);margin-left:1rem}
.btn-ghost:hover{border-color:var(--white);background:rgba(255,255,255,0.08)}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:0.5rem;z-index:2;color:rgba(255,255,255,0.5);font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase}
.scroll-line{width:1px;height:40px;background:rgba(255,255,255,0.3);animation:scrollAnim 2s ease-in-out infinite}
@keyframes scrollAnim{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* SECTIONS general */
section{padding:7rem 2rem}
.container{max-width:var(--max);margin:0 auto}
.section-label{font-size:0.68rem;letter-spacing:0.35em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;font-family:var(--ff-sans);font-weight:400}
.section-title{font-family:var(--ff-serif);font-size:clamp(2.2rem,4vw,3.4rem);font-weight:300;color:var(--ink);line-height:1.1;margin-bottom:1.5rem}
.section-title em{font-style:italic;color:var(--gold2)}
.divider{width:40px;height:1px;background:var(--gold);margin:0 auto 2rem}
.divider.left{margin:0 0 2rem}

/* FILOSOFIA */
.filosofia{background:var(--ink);padding:6rem 2rem}
.filosofia-inner{max-width:860px;margin:0 auto;text-align:center}
.filosofia .section-label{color:var(--gold)}
.filosofia .section-title{color:var(--white)}
.filosofia-text{font-family:var(--ff-serif);font-size:clamp(1.1rem,2.2vw,1.4rem);color:rgba(255,255,255,0.65);font-weight:300;line-height:1.9;font-style:italic;max-width:680px;margin:0 auto 3rem}
.filosofia-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid rgba(255,255,255,0.1)}
.stat{padding:2.5rem 1rem;border-right:1px solid rgba(255,255,255,0.1);text-align:center}
.stat:last-child{border-right:none}
.stat-num{font-family:var(--ff-serif);font-size:2.8rem;font-weight:300;color:var(--gold);line-height:1}
.stat-label{font-size:0.72rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-top:0.5rem;font-weight:300}

/* MENU */
.menu-section{background:var(--cream3)}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2px;margin-top:4rem}
.menu-card{position:relative;overflow:hidden;aspect-ratio:3/4;cursor:pointer}
.menu-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s cubic-bezier(0.4,0,0.2,1);display:block}
.menu-card:hover img{transform:scale(1.06)}
.menu-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,6,3,0.85) 0%,rgba(10,6,3,0.1) 60%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:2rem 1.8rem}
.menu-card-tag{font-size:0.65rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--gold);margin-bottom:0.5rem}
.menu-card-title{font-family:var(--ff-serif);font-size:1.9rem;font-weight:300;color:var(--white);line-height:1.1}
.menu-card-desc{font-size:0.82rem;color:rgba(255,255,255,0.65);margin-top:0.5rem;font-weight:300}
.menu-card-price{font-family:var(--ff-serif);font-size:1.1rem;color:var(--gold);margin-top:0.8rem;font-weight:400}

/* EXPERIENCIA */
.experiencia{background:var(--cream2)}
.exp-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;margin-top:3rem}
.exp-img-wrap{position:relative}
.exp-img{width:100%;aspect-ratio:4/5;object-fit:cover;display:block}
.exp-img-accent{position:absolute;bottom:-2rem;right:-2rem;width:55%;aspect-ratio:1;object-fit:cover;border:6px solid var(--cream2)}
.exp-content .section-label{text-align:left}
.exp-content .section-title{text-align:left}
.exp-list{list-style:none;margin:2rem 0 3rem}
.exp-list li{display:flex;align-items:flex-start;gap:1rem;padding:1.2rem 0;border-bottom:1px solid rgba(184,151,90,0.2)}
.exp-list li:first-child{border-top:1px solid rgba(184,151,90,0.2)}
.exp-icon{width:32px;height:32px;background:var(--gold);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--ff-jp);font-size:0.75rem;color:var(--white)}
.exp-item-title{font-size:0.9rem;font-weight:500;color:var(--ink);letter-spacing:0.05em}
.exp-item-desc{font-size:0.82rem;color:var(--ink3);font-weight:300;margin-top:0.2rem}

/* OMAKASE */
.omakase{background:var(--ink);padding:8rem 2rem;position:relative;overflow:hidden}
.omakase::before{content:'公園';position:absolute;right:-2rem;top:50%;transform:translateY(-50%);font-family:var(--ff-jp);font-size:18rem;color:rgba(255,255,255,0.02);line-height:1;pointer-events:none}
.omakase-inner{max-width:900px;margin:0 auto;text-align:center;position:relative}
.omakase .section-label{color:var(--gold)}
.omakase .section-title{color:var(--white)}
.omakase-text{color:rgba(255,255,255,0.55);font-size:0.95rem;max-width:580px;margin:0 auto 3.5rem;font-weight:300;line-height:1.9}
.courses{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1px;background:rgba(255,255,255,0.06);margin-bottom:4rem}
.course{background:var(--ink);padding:2rem 1.2rem;text-align:center;transition:background var(--transition)}
.course:hover{background:rgba(184,151,90,0.08)}
.course-num{font-family:var(--ff-serif);font-size:2rem;color:var(--gold);font-weight:300;line-height:1;opacity:0.6}
.course-name{font-family:var(--ff-serif);font-size:1rem;color:var(--white);margin-top:0.5rem;font-weight:300}
.course-jp{font-family:var(--ff-jp);font-size:0.7rem;color:rgba(255,255,255,0.3);margin-top:0.3rem;letter-spacing:0.1em}
.price-card{display:inline-flex;align-items:center;gap:3rem;border:1px solid rgba(184,151,90,0.3);padding:2.5rem 4rem;margin-bottom:3rem}
.price-label{font-size:0.68rem;letter-spacing:0.25em;text-transform:uppercase;color:rgba(255,255,255,0.4)}
.price-num{font-family:var(--ff-serif);font-size:3rem;color:var(--white);font-weight:300;line-height:1}
.price-divider{width:1px;height:50px;background:rgba(184,151,90,0.3)}

/* GALERIA */
/* --- Galería Estilo Restaurante --- */
.galeria {
    background: var(--cream3);
    padding: 7rem 0 7rem 2rem;
    width: 100%;
}

.galeria .container {
    max-width: calc(var(--max) + 4rem);
    margin: 0 auto; /* Centra el contenedor si el ancho es menor a la pantalla */
}

.galeria-header {
    text-align: center;
    margin-bottom: 4rem;
    padding-right: 2rem;
}

.galeria-scroll {
    display: flex;
    flex-wrap: nowrap; /* Fuerza la fila única */
    gap: 20px;
    overflow-x: auto;
    scroll-behavior: smooth;
    padding-bottom: 2rem;
    padding-right: 2rem;
    cursor: grab;
    scrollbar-width: none;
    width: 100%;       /* Asegura que ocupe todo el ancho disponible */
    min-width: 100%;   /* Evita que se encoja aunque los elementos pesen poco */
    -webkit-overflow-scrolling: touch; /* Suavidad en móviles */
}

.galeria-scroll::-webkit-scrollbar {
    display: none;
}

.galeria-item {
    flex: 0 0 320px; 
    aspect-ratio: 4/5;
    overflow: hidden;
    position: relative;
    border-radius: 8px;
    flex-shrink: 0; /* Evita que los items se compriman */
}

.galeria-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.galeria-item:hover img {
    transform: scale(1.06);
}

.galeria-item:first-child {
    flex: 0 0 420px;
    aspect-ratio: 3/4;
}

/* RESERVAS */
.reservas{background:var(--cream2);padding:7rem 2rem}
.reservas-inner{max-width:640px;margin:0 auto;text-align:center}
.reservas .section-title{margin-bottom:0.5rem}
.reservas-sub{color:var(--ink3);font-size:0.9rem;margin-bottom:3rem;font-weight:300}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-group{display:flex;flex-direction:column;gap:0.4rem;text-align:left}
.form-group.full{grid-column:1/-1}
label{font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink3);font-weight:400}
input,select,textarea{padding:0.85rem 1rem;border:1px solid rgba(184,151,90,0.25);background:var(--white);color:var(--ink);font-family:var(--ff-sans);font-size:0.9rem;transition:border-color var(--transition);outline:none;width:100%;-webkit-appearance:none;border-radius:0}
input:focus,select:focus,textarea:focus{border-color:var(--gold)}
textarea{resize:vertical;min-height:100px}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23b8975a' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.btn-reserve{width:100%;padding:1.1rem;background:var(--ink);color:var(--white);border:none;font-family:var(--ff-sans);font-size:0.75rem;letter-spacing:0.25em;text-transform:uppercase;cursor:pointer;transition:all var(--transition);margin-top:0.5rem}
.btn-reserve:hover{background:var(--gold)}
.form-note{font-size:0.75rem;color:var(--ink3);margin-top:1rem;font-weight:300}

/* UBICACION */
.ubicacion{background:var(--ink);padding:6rem 2rem}
.ubi-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.ubi-content .section-label{color:var(--gold)}
.ubi-content .section-title{color:var(--white)}
.ubi-info{margin-top:2.5rem;display:flex;flex-direction:column;gap:1.5rem}
.ubi-item{display:flex;gap:1.2rem;align-items:flex-start}
.ubi-dot{width:6px;height:6px;background:var(--gold);border-radius:50%;margin-top:0.55rem;flex-shrink:0}
.ubi-item-title{font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:0.3rem}
.ubi-item-text{color:rgba(255,255,255,0.6);font-size:0.9rem;font-weight:300;line-height:1.7}
.ubi-map{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.map-placeholder{text-align:center}
.map-jp{font-family:var(--ff-jp);font-size:4rem;color:rgba(184,151,90,0.15);line-height:1;display:block}
.map-text{font-size:0.75rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-top:0.5rem}
.map-link{display:inline-block;margin-top:1.5rem;font-size:0.72rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);text-decoration:none;border-bottom:1px solid rgba(184,151,90,0.4);padding-bottom:2px;transition:border-color var(--transition)}
.map-link:hover{border-color:var(--gold)}

/* FOOTER */
footer{background:#0d0b08;padding:4rem 2rem 2rem;color:rgba(255,255,255,0.4)}
.footer-inner{max-width:var(--max);margin:0 auto}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,0.06)}
.footer-brand-logo{font-family:var(--ff-serif);font-size:2rem;font-weight:300;color:var(--white);letter-spacing:0.1em;display:block;margin-bottom:0.5rem}
.footer-brand-jp{font-family:var(--ff-jp);font-size:0.7rem;color:var(--gold);letter-spacing:0.3em;display:block;margin-bottom:1rem}
.footer-brand-desc{font-size:0.82rem;font-weight:300;line-height:1.8;max-width:280px}
.footer-col-title{font-size:0.68rem;letter-spacing:0.25em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-bottom:1.2rem;font-weight:400}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:0.7rem}
.footer-links a{font-size:0.82rem;color:rgba(255,255,255,0.4);text-decoration:none;font-weight:300;transition:color var(--transition)}
.footer-links a:hover{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;font-size:0.72rem;letter-spacing:0.05em}
.footer-bottom-links{display:flex;gap:1.5rem}
.footer-bottom-links a{color:rgba(255,255,255,0.3);text-decoration:none;transition:color var(--transition)}
.footer-bottom-links a:hover{color:var(--gold)}
.social-links{display:flex;gap:1rem;margin-top:1.5rem}
.social-link{width:34px;height:34px;border:1px solid rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.4);font-size:0.7rem;text-decoration:none;transition:all var(--transition)}
.social-link:hover{border-color:var(--gold);color:var(--gold)}

/* RESPONSIVE */
@media(max-width:900px){
  .exp-grid,.ubi-grid{grid-template-columns:1fr;gap:3rem}
  .exp-img-accent{display:none}
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
  .price-card{padding:2rem;gap:2rem}
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:flex}
  .footer-brand-logo{font-size:1.6rem}
}
@media(max-width:600px){
  nav{padding:1rem}
  section{padding:5rem 1.25rem}
  .filosofia-stats{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid rgba(255,255,255,0.1)}
  .form-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:1rem;text-align:center}
  .hero-content{padding:1rem}
  .btn-ghost{display:none}
  .courses{grid-template-columns:repeat(2,1fr)}
  .price-card{flex-direction:column;gap:1rem;padding:2rem 1.5rem}
  .price-divider{width:50px;height:1px}
}

/* MOBILE MENU */
.mobile-menu{position:fixed;inset:0;background:var(--ink);z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;transform:translateX(100%);transition:transform 0.45s cubic-bezier(0.4,0,0.2,1)}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{font-family:var(--ff-serif);font-size:2.2rem;font-weight:300;color:var(--white);text-decoration:none;letter-spacing:0.05em;transition:color var(--transition)}
.mobile-menu a:hover{color:var(--gold)}
.mobile-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:var(--white);font-size:1.5rem;cursor:pointer;padding:0.5rem;line-height:1}

/* ANIM */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}