/* Estilos principales para CAÑITA&PASIÓN
   - Colores cálidos y degradados
   - Tipografías elegantes
   - Animaciones suaves y transiciones
*/
:root{
  --bg:#6b7a3a;
  --accent1:#ff6b35; /* naranja/rojo */
  --accent2:#ffbd59; /* amarillo */
  --muted:#6b6b6b;
  --card:#ffffff;
  --glass: rgba(255,255,255,0.7);
  --shadow: 0 8px 24px rgba(0,0,0,0.08);
}
*{box-sizing:border-box}
html,body{height:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background: linear-gradient(180deg,var(--bg), #3f4f24);
  color:#222;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
.container{max-width:1200px;margin:0 auto;padding:1.5rem}

/* Header & Nav */
.site-header{background:linear-gradient(135deg,#4d5f2a,#6b7a3a);color:white;padding-bottom:1rem}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}
.brand{font-family:"Playfair Display", serif;font-size:1.6rem;letter-spacing:1px}
.brand{display:flex;align-items:center;gap:0.6rem}
.site-logo{height:48px;width:auto;border-radius:6px;box-shadow:var(--shadow);background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(255,255,255,0.02));padding:4px}
.brand span{font-family:"Playfair Display", serif;font-size:1.4rem;color:white}
.nav-links{list-style:none;margin:0;padding:0;display:flex;gap:1rem}
.nav-links a{color:rgba(255,255,255,0.95);text-decoration:none;font-weight:700;position:relative;padding:6px 4px}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-3px;height:3px;width:100%;background:linear-gradient(90deg,#c3d197,#7e9150);transform:scaleX(0);transform-origin:left;transition:transform .28s cubic-bezier(.2,.9,.2,1)}
.nav-links a:hover::after{transform:scaleX(1)}
.btn-cta{background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);color:white;padding:0.5rem 0.9rem;border-radius:8px;cursor:pointer}
.btn-cta:hover{transform:translateY(-3px);box-shadow:var(--shadow)}

/* Mobile nav toggle */
.nav{position:relative}
.nav-toggle{display:none;background:transparent;border:none;color:white;font-size:1.6rem;padding:0.4rem;border-radius:8px;cursor:pointer}


/* Hero */
.hero{padding:4rem 0}
.hero-inner{display:flex;gap:2.2rem;align-items:center}
.hero-text{flex:1;color:#fff}
.hero-text h1{font-family:"Playfair Display", serif;font-size:2.4rem;margin:0 0 0.5rem}
.slogan{opacity:0.95;font-size:1.1rem;margin-bottom:1rem}
.hero-ctas .btn{margin-right:0.6rem}
.hero-photo{flex:1;padding:0.5rem}
.hero-photo img{width:100%;height:360px;object-fit:cover;border-radius:16px;box-shadow:var(--shadow);transform:translateY(0);transition:transform .9s cubic-bezier(.16,.84,.2,1),filter .4s ease}
.hero-photo img:hover{transform:translateY(-6px) scale(1.02);filter:brightness(.98) saturate(1.02)}

/* floating animation subtle */
@keyframes floatY{0%{transform:translateY(0)}50%{transform:translateY(-6px)}100%{transform:translateY(0)}}
.hero-photo img{animation:floatY 6s ease-in-out infinite}

/* Buttons */
.btn{display:inline-block;padding:0.8rem 1.1rem;border-radius:12px;text-decoration:none;font-weight:700;transition:all .28s ease}
.btn.primary{background:rgba(255,255,255,0.98);color:#8a2b0b;box-shadow:0 8px 24px rgba(138,43,11,0.06)}
.btn.primary:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(138,43,11,0.12)}
.btn.primary:active{transform:translateY(-2px);transition:transform .08s}
.btn.ghost{background:transparent;border:2px solid rgba(255,255,255,0.95);color:white}
.btn.ghost:hover{background:rgba(255,255,255,0.06)}

/* pulse for CTA */
.btn.primary::after{content:'';position:absolute;z-index:-1;left:0;right:0;top:0;bottom:0;border-radius:12px;opacity:0;transition:opacity .28s}
.btn.primary:hover::after{opacity:0.06}


/* Sections */
.section{padding:3rem 0}
.section-title{font-family:"Playfair Display", serif;font-size:1.8rem;margin:0 0 0.2rem;color:#fff4ee}
.section-sub{color:#ffd9cb;margin-bottom:1rem}

/* Menu grid */
.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}
.menu-category{background:var(--card);padding:1rem;border-radius:12px;box-shadow:var(--shadow);transition:transform .25s ease}
.menu-category:hover{transform:translateY(-6px)}
.menu-category h3{margin-top:0}
.menu-category ul{list-style:none;padding:0;margin:0}
.menu-category li{display:flex;gap:0.8rem;padding:0.6rem 0;border-bottom:1px dashed #eee;align-items:center}
.menu-category li:last-child{border-bottom:none}
.menu-category img{width:72px;height:72px;object-fit:cover;border-radius:8px;transition:transform .3s ease}
.menu-category img:hover{transform:scale(1.06)}
.menu-category h4{margin:0;font-size:1rem}
.menu-category p{margin:0.25rem 0 0;color:var(--muted);font-size:0.95rem}
.price{float:right;color:var(--accent1);font-weight:700;margin-left:6px}

/* Local carousel */
.local-carousel{position:relative}
.carousel-window{overflow:hidden;border-radius:14px;box-shadow:var(--shadow)}
.carousel-track{display:flex;transition:transform .45s cubic-bezier(.2,.9,.2,1)}
.carousel-slide{margin:0;min-width:100%;position:relative;background:var(--card)}
.carousel-slide img{width:100%;height:420px;object-fit:cover;display:block}
.carousel-caption{position:absolute;left:0;right:0;bottom:0;padding:0.9rem 1rem;color:#fff;font-weight:600;background:linear-gradient(180deg,transparent,rgba(0,0,0,0.55))}
.carousel-control{position:absolute;top:50%;transform:translateY(-50%);z-index:2;border:none;width:44px;height:44px;border-radius:999px;background:rgba(0,0,0,0.45);color:#fff;font-size:1.4rem;cursor:pointer;transition:background .25s ease,transform .25s ease}
.carousel-control:hover{background:rgba(0,0,0,0.65);transform:translateY(-50%) scale(1.06)}
.carousel-control.prev{left:0.8rem}
.carousel-control.next{right:0.8rem}
.carousel-dots{display:flex;gap:0.45rem;justify-content:center;margin-top:0.9rem}
.carousel-dot{width:10px;height:10px;border-radius:999px;border:none;background:#ffcbb8;cursor:pointer;padding:0;transition:transform .2s ease,background .2s ease}
.carousel-dot.is-active{background:var(--accent1);transform:scale(1.2)}

/* Featured */
.featured-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.featured-card{position:relative;border-radius:12px;overflow:hidden}
.featured-card img{width:100%;height:220px;object-fit:cover;display:block;transition:transform .6s ease,filter .45s ease}
.featured-card:hover img{transform:scale(1.06);filter:contrast(1.04) saturate(1.06)}
.featured-card .card-info{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(180deg,transparent,rgba(0,0,0,0.45));color:white}
.featured-card.highlight .card-info{background:linear-gradient(180deg,transparent,rgba(138,43,11,0.6))}

/* subtle entrance for cards */
.menu-category, .featured-card, .carta-gallery figure{transform:translateY(8px);opacity:0;transition:transform .6s cubic-bezier(.2,.9,.2,1),opacity .6s}
.menu-category.visible, .featured-card.visible, .carta-gallery.visible, .carta-gallery figure.visible{transform:none;opacity:1}

/* Wine slider */
.wine-slider{display:flex;align-items:center;gap:1rem;position:relative}
.slide-btn{background:var(--accent1);color:white;border:none;padding:0.5rem 0.6rem;border-radius:8px;cursor:pointer}
.slides{flex:1;overflow:hidden}
.slide{display:flex;gap:1rem;align-items:center;padding:1rem;background:var(--card);border-radius:12px;box-shadow:var(--shadow);transition:transform .4s ease}
.slide img{width:120px;height:120px;object-fit:cover;border-radius:8px}
.wine-meta h4{margin:0 0 0.4rem}
.wine-meta p{margin:0;color:var(--muted)}

/* Reservations */
.reserva-form{background:var(--card);padding:1.25rem;border-radius:12px;box-shadow:var(--shadow)}
.reserva-form .section-sub{color:var(--muted)}
.form-row{display:flex;gap:1rem;margin-bottom:0.8rem}
.form-row label{flex:1;display:block}
.form-row input,.form-row select{width:100%;padding:0.6rem;border-radius:8px;border:1px solid #e7e7e7}
.form-actions{display:flex;gap:1rem;align-items:center}
.reserva-feedback{margin-top:0.6rem;color:green}

/* Allergens table */
.alergenos-table table{width:100%;border-collapse:collapse;background:var(--card);border-radius:8px;overflow:hidden;box-shadow:var(--shadow)}
.alergenos-table th, .alergenos-table td{padding:0.8rem;border-bottom:1px solid #f1f1f1;text-align:left}
.alergenos-table thead th{background:linear-gradient(90deg,var(--accent1),var(--accent2));color:white}

/* Contact */
.contact-grid{display:flex;gap:1rem;align-items:start}
.contact-info{flex:1;padding:0.6rem}
.contact-info p{color:#ffe9df}
.contact-info a{color:#ffd8c9}
.contact-social{display:flex;gap:0.7rem;flex-wrap:wrap;margin-top:1rem}
.social-btn{display:inline-block;padding:0.65rem 1rem;border-radius:999px;text-decoration:none;color:#fff;font-weight:700;transition:transform .25s ease,box-shadow .25s ease}
.social-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.instagram-btn{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045)}
.tiktok-btn{background:#111}
.contact-media{flex:1;display:grid;gap:1rem}
.contact-photo{margin:0}
.contact-photo img{width:100%;height:180px;object-fit:cover;border-radius:10px;box-shadow:var(--shadow)}
.map iframe{width:100%;height:300px;border:0;border-radius:8px}

/* Footer */
.site-footer{padding:1rem 0;background:#fff3f0;color:#8a2b0b}

/* Modal */
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.45);opacity:0;pointer-events:none;transition:opacity .25s ease}
.modal[aria-hidden="false"]{opacity:1;pointer-events:auto}
.modal-content{background:white;padding:1.2rem;border-radius:12px;max-width:420px;text-align:center;box-shadow:var(--shadow);position:relative;transform:translateY(8px);transition:transform .28s ease,opacity .28s}
.modal[aria-hidden="false"] .modal-content{transform:none}
.modal-close{position:absolute;top:8px;right:8px;background:transparent;border:none;font-size:1.1rem;cursor:pointer}

/* Responsive */
@media (max-width:820px){
  .hero-inner{flex-direction:column}
  .form-row{flex-direction:column}
  .contact-grid{flex-direction:column}
  .hero-photo img{height:260px}
  .map iframe{height:220px}
  .carousel-slide img{height:260px}
  .carousel-control{width:40px;height:40px}

  /* Mobile navigation styles */
  .nav-toggle{display:block}
  .nav-links{position:fixed;top:68px;right:1rem;left:1rem;background:linear-gradient(135deg,#4d5f2a,#6b7a3a);flex-direction:column;padding:1rem;border-radius:12px;gap:0.6rem;transform:translateY(-10px);opacity:0;pointer-events:none;transition:all .28s ease;z-index:1000}
  .nav.open .nav-links{transform:none;opacity:1;pointer-events:auto}
  .nav-links a{padding:0.8rem;border-radius:8px}
  .nav-links{display:flex}
  .container{padding:1rem}
  .hero-text h1{font-size:1.6rem}
  .hero-photo img{height:220px}
}

/* Smooth appear animations for sections */
.section{opacity:0;transform:translateY(18px);transition:all .8s cubic-bezier(.2,.9,.2,1)}
.section.visible{opacity:1;transform:none}

/* Galería simple para la sección Carta */
.carta-gallery .gallery-inner{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;align-items:start}
.carta-gallery figure{background:var(--card);padding:0.6rem;border-radius:12px;box-shadow:var(--shadow);text-align:center}
.carta-gallery img{width:100%;height:auto;border-radius:8px;display:block;transition:transform .45s ease}
.carta-gallery img:hover{transform:scale(1.03)}
.carta-gallery figcaption{margin-top:0.6rem;color:var(--muted);font-size:0.95rem}

/* Historia section */
.hist-grid{display:grid;grid-template-columns:1fr 360px;gap:1.25rem;align-items:center}
.hist-text p{margin:0 0 0.8rem;color:#ffe9df;line-height:1.6}
.hist-photo img{width:100%;height:260px;object-fit:cover;border-radius:12px;box-shadow:var(--shadow);transition:transform .6s ease}
.hist-photo img:hover{transform:translateY(-6px) scale(1.02)}

@media (max-width:880px){
  .hist-grid{grid-template-columns:1fr}
  .hist-photo img{height:200px}
}
