﻿/* ═══════════════════════════════════════════════════════
   GastroExperience — TEMA CLARO (Light & Modern)
   ═══════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Outfit:wght@300;400;500;600;700&display=swap');

:root {
  --gold:        #b8893a;
  --gold-light:  #d4a855;
  --gold-dim:    rgba(184,137,58,0.10);
  --gold-glow:   rgba(184,137,58,0.25);
  --bg:          #f8f6f2;
  --bg-hero:     #1a1208;
  --surface:     #ffffff;
  --surface-2:   #f3f0eb;
  --border:      rgba(0,0,0,0.08);
  --border-gold: rgba(184,137,58,0.30);
  --text:        #1c1a17;
  --text-dim:    #6b6560;
  --text-muted:  #a8a29e;
  --font-display:'Cormorant Garamond', Georgia, serif;
  --font-body:   'Outfit', sans-serif;
  --transition:  cubic-bezier(0.23,1,0.32,1);
  --radius:      18px;
  --shadow:      0 2px 16px rgba(0,0,0,0.07), 0 0 0 1px rgba(0,0,0,0.04);
  --shadow-hover:0 8px 32px rgba(0,0,0,0.12), 0 0 0 1px rgba(184,137,58,0.2);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--border-gold);border-radius:4px;}

/* ── HERO (oscuro, con imagen) ───────────────────────── */
.hero{
  position:relative; min-height:92svh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:100px 24px 60px; overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0;
  background-image:url('images/hero.png');
  background-size:cover; background-position:center;
  transform:scale(1.05); transition:transform 8s ease; will-change:transform;
}
.hero-bg::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(20,14,4,0.5) 0%, rgba(20,14,4,0.35) 40%, rgba(20,14,4,0.80) 80%, rgba(20,14,4,1) 100%);
}
.hero-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.particle{position:absolute;border-radius:50%;background:var(--gold);opacity:0;animation:float-p var(--dur,8s) var(--delay,0s) infinite ease-in-out;}
@keyframes float-p{0%{opacity:0;transform:translateY(0) scale(0);}30%{opacity:0.5;}80%{opacity:0.2;}100%{opacity:0;transform:translateY(-100px) scale(1.5);}}

.hero-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;animation:hero-in 1.2s var(--transition) both;}
@keyframes hero-in{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}

.hero-logo{width:clamp(200px,50vw,360px);height:auto;filter:drop-shadow(0 4px 24px rgba(0,0,0,0.4));}
.hero-tagline{font-family:var(--font-display);font-size:clamp(0.9rem,2vw,1.1rem);font-weight:300;font-style:italic;color:rgba(255,255,255,0.75);letter-spacing:4px;text-transform:uppercase;}
.hero-divider{display:flex;align-items:center;gap:14px;opacity:0.4;margin:4px 0;}
.hero-divider span{width:36px;height:1px;background:var(--gold);display:block;}
.hero-divider i{color:var(--gold);font-size:0.5rem;}
.hero-address{font-size:0.78rem;color:rgba(255,255,255,0.5);letter-spacing:2px;text-transform:uppercase;}
.hero-contacts{display:flex;gap:20px;flex-wrap:wrap;justify-content:center;margin-top:4px;}
.hero-contacts a{display:flex;align-items:center;gap:7px;font-size:0.88rem;color:var(--gold-light);text-decoration:none;font-weight:500;letter-spacing:0.5px;transition:all 0.3s;}
.hero-contacts a:hover{color:#fff;transform:translateY(-2px);}

/* Botón Reservar */
.reservation-btn{
  position:fixed;top:20px;right:20px;z-index:200;
  display:flex;align-items:center;gap:8px;padding:10px 20px;
  background:rgba(255,255,255,0.92);backdrop-filter:blur(16px);
  border:1px solid rgba(184,137,58,0.3);color:var(--gold);
  text-decoration:none;border-radius:50px;font-size:0.78rem;
  font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  transition:all 0.35s var(--transition);
  box-shadow:0 4px 20px rgba(0,0,0,0.12);
}
.reservation-btn:hover{background:var(--gold);color:#fff;border-color:var(--gold);box-shadow:0 8px 28px var(--gold-glow);transform:translateY(-2px);}
.reservation-btn i.fa-arrow-right{font-size:0.7rem;transition:transform 0.3s;}
.reservation-btn:hover i.fa-arrow-right{transform:translateX(3px);}

/* ── SECCIÓN CARTA (fondo claro) ─────────────────────── */
.section-label{text-align:center;padding:52px 24px 24px;background:var(--bg);}
.section-label h2{font-family:var(--font-display);font-size:clamp(1.6rem,4vw,2.2rem);font-weight:300;letter-spacing:8px;text-transform:uppercase;color:var(--text);}
.section-label .line{width:48px;height:2px;background:var(--gold);margin:14px auto 0;border-radius:2px;}

/* ── SOCIAL STRIP ────────────────────────────────────── */
.social-strip{display:flex;justify-content:center;gap:8px;padding:20px 24px;background:var(--bg);}
.social-strip a{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);font-size:0.95rem;text-decoration:none;transition:all 0.3s;box-shadow:var(--shadow);}
.social-strip a:hover{color:var(--gold);border-color:var(--border-gold);transform:translateY(-2px);box-shadow:var(--shadow-hover);}

/* ── GRID DE CATEGORÍAS ──────────────────────────────── */
.menu-sections{max-width:580px;margin:0 auto;padding:8px 20px 100px;display:flex;flex-direction:column;gap:12px;background:var(--bg);}

.category-card{
  display:flex;align-items:center;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;text-decoration:none;
  transition:all 0.4s var(--transition);
  box-shadow:var(--shadow);
  animation:card-in 0.5s var(--transition) both;
  animation-delay:calc(var(--i,0)*0.06s);
}
@keyframes card-in{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}
.category-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover);border-color:var(--border-gold);}
.category-info{flex:1;padding:0 26px;}
.category-info h2{font-size:1rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:2px;transition:color 0.3s;}
.category-card:hover .category-info h2{color:var(--gold);}
.category-arrow{display:flex;align-items:center;gap:6px;font-size:0.68rem;color:var(--text-muted);margin-top:4px;letter-spacing:1px;text-transform:uppercase;transition:all 0.3s;}
.category-card:hover .category-arrow{color:var(--gold);transform:translateX(4px);}
.category-image{width:130px;height:110px;object-fit:cover;clip-path:polygon(18% 0,100% 0,100% 100%,0% 100%);transition:transform 0.6s var(--transition),filter 0.4s;filter:brightness(0.95);}
.category-card:hover .category-image{transform:scale(1.08);filter:brightness(1.05);}

/* ── FOOTER ──────────────────────────────────────────── */
footer{padding:48px 24px 36px;text-align:center;background:var(--surface-2);border-top:1px solid var(--border);}
.footer-brand{font-family:var(--font-display);font-size:1.4rem;font-weight:300;letter-spacing:6px;color:var(--gold);text-transform:uppercase;opacity:0.8;}
.copyright{font-size:0.7rem;color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase;margin-top:14px;}

/* ── HERO SCROLL HINT ────────────────────────────────── */
.hero-scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,0.4);font-size:1.1rem;animation:bounce-down 2s infinite;}
@keyframes bounce-down{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(6px);}}

/* ── SKELETON LOADER ─────────────────────────────────── */
.loading-skeleton{display:flex;flex-direction:column;gap:12px;}
.skeleton-card{height:110px;border-radius:var(--radius);background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3,#edeae4) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}

/* ── CATEGORY IMAGE PLACEHOLDER ─────────────────────── */
.category-image-placeholder{width:130px;height:110px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:2rem;clip-path:polygon(18% 0,100% 0,100% 100%,0% 100%);}

/* ── ALÉRGENOS BTN ───────────────────────────────────── */
.toggle-allergens-btn{
  position:fixed;bottom:26px;right:26px;width:52px;height:52px;border-radius:50%;
  background:var(--surface);color:var(--gold);border:1.5px solid var(--border-gold);
  display:flex;justify-content:center;align-items:center;font-size:1.2rem;
  cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,0.12);z-index:9999;
  transition:all 0.35s var(--transition);
}
.toggle-allergens-btn:hover{transform:scale(1.08) rotate(15deg);background:var(--gold);color:#fff;box-shadow:0 8px 24px var(--gold-glow);}
.toggle-allergens-btn.active{background:var(--gold);color:#fff;box-shadow:0 0 20px var(--gold-glow);}

/* ── RESPONSIVE ──────────────────────────────────────── */
@media(max-width:480px){
  .reservation-btn{top:14px;right:14px;padding:8px 14px;font-size:0.7rem;}
  .category-image{width:105px;height:95px;}
  .category-info{padding:0 16px;}
  .category-info h2{font-size:0.9rem;}
}