@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Lato:wght@300;400;700&display=swap');

:root {
  /* ---- Colores extraídos del logotipo ---- */
  --terracota:   #a5420b;   /* Texto "Jud" — color principal del logo  */
  --terracota-d: #7a3008;   /* Versión oscura para hover               */
  --terracota-l: #c45a1e;   /* Versión clara / acento                  */
  --gris-logo:   #3c3c3c;   /* Cúpula / texto "La Cocina de"           */
  --gris-logo-d: #282828;   /* Gris muy oscuro del logo                */
  --crema:       #F5EDD8;
  --crema-d:     #EAD9BC;
  --arena:       #C9A96E;
  --arena-d:     #9E7A44;
  --marron:      #694934;   /* Marrón exacto del texto "La Cocina de"  */
  --marron-d:    #3c2010;   /* Versión oscura navbar / footer          */
  --verde:       #6B7C44;
  --blanco:      #FDFAF4;
  --texto:       #4A3728;
  --sombra:      rgba(59,32,10,.15);
  --sombra-m:    rgba(59,32,10,.28);
  --r:           10px;
  --r-lg:        18px;
  --t:           .25s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Lato',sans-serif;background:var(--blanco);color:var(--texto);font-size:16px;line-height:1.65}
h1,h2,h3,h4{font-family:'Playfair Display',serif;color:var(--marron);line-height:1.25}
a{color:var(--terracota);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--terracota-d)}
img{max-width:100%;height:auto;display:block}

/* ---- Botones ---- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:11px 24px;border-radius:var(--r);font-family:'Lato',sans-serif;font-weight:700;font-size:.9rem;cursor:pointer;border:2px solid transparent;transition:all var(--t);text-decoration:none}
.btn-primary{background:var(--terracota);color:#fff;border-color:var(--terracota)}
.btn-primary:hover{background:var(--terracota-d);border-color:var(--terracota-d);color:#fff}
.btn-secondary{background:transparent;color:var(--terracota);border-color:var(--terracota)}
.btn-secondary:hover{background:var(--terracota);color:#fff}
.btn-dark{background:var(--marron);color:var(--crema);border-color:var(--marron)}
.btn-dark:hover{background:var(--marron-d);color:var(--crema)}
.btn-verde{background:var(--verde);color:#fff;border-color:var(--verde)}
.btn-verde:hover{background:#4f5e30;color:#fff}
.btn-sm{padding:6px 14px;font-size:.82rem}
.btn-full{width:100%;justify-content:center}

/* ---- Navbar ---- */
.navbar{position:sticky;top:0;z-index:1000;background:linear-gradient(135deg,var(--marron-d) 0%,var(--marron) 60%,#7a3a20 100%);box-shadow:0 2px 14px rgba(60,32,10,.45)}
.navbar-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:70px}
.navbar-logo{display:flex;align-items:center;gap:10px}
.navbar-logo img{height:54px;width:auto;border-radius:6px;background:#fff;padding:3px}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{color:rgba(245,237,216,.8);font-weight:400;font-size:.9rem;padding:6px 12px;border-radius:6px;transition:all var(--t)}
.nav-links a:hover,.nav-links a.active{background:rgba(255,255,255,.12);color:var(--crema)}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-cart{position:relative;cursor:pointer;color:var(--crema);padding:8px 14px;border-radius:8px;background:rgba(165,66,11,.55);display:flex;align-items:center;gap:7px;font-weight:700;font-size:.9rem;transition:background var(--t);border:none}
.nav-cart:hover{background:var(--terracota)}
.cart-badge{position:absolute;top:-5px;right:-5px;background:var(--arena);color:var(--marron-d);border-radius:50%;width:20px;height:20px;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--marron)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.hamburger span{width:24px;height:2px;background:var(--crema);border-radius:2px;transition:all var(--t);display:block}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---- Oferta Banner ---- */
.oferta-banner{background:linear-gradient(90deg,var(--gris-logo-d) 0%,var(--gris-logo) 50%,#4a4a4a 100%);color:var(--crema);text-align:center;padding:9px 20px;font-size:.88rem;font-weight:700;letter-spacing:.4px;border-bottom:2px solid var(--terracota)}
.oferta-banner a{color:#fff;text-decoration:underline}

/* ---- Hero ---- */
.hero{background:linear-gradient(135deg,var(--marron-d) 0%,var(--marron) 40%,var(--gris-logo-d) 75%,var(--gris-logo) 100%);padding:88px 20px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E")}
.hero-logo{height:120px;width:auto;margin:0 auto 20px;filter:drop-shadow(0 4px 16px rgba(0,0,0,.4))}
.hero h1{font-size:clamp(1.8rem,5vw,3rem);color:var(--crema);margin-bottom:14px}
.hero p{color:rgba(245,237,216,.85);font-size:1.05rem;margin-bottom:28px;max-width:560px;margin-left:auto;margin-right:auto}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ---- Sección ---- */
.section{padding:64px 20px}
.section-alt{background:var(--crema)}
.container{max-width:1200px;margin:0 auto}
.section-title{text-align:center;margin-bottom:44px}
.section-title h2{font-size:clamp(1.5rem,3vw,2.3rem);margin-bottom:8px}
.section-title p{color:var(--arena-d);font-size:.97rem}
.divider{width:56px;height:3px;background:var(--terracota);margin:12px auto 0;border-radius:2px}

/* ---- Filtros ---- */
.cat-filters{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:32px}
.cat-btn{padding:7px 18px;border-radius:20px;font-size:.86rem;font-weight:700;cursor:pointer;border:2px solid var(--arena);color:var(--marron);background:transparent;transition:all var(--t)}
.cat-btn:hover,.cat-btn.active{background:var(--terracota);border-color:var(--terracota);color:#fff}

/* ---- Platos grid ---- */
.platos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:26px}
.plato-card{background:#fff;border-radius:var(--r-lg);box-shadow:0 3px 16px var(--sombra);overflow:hidden;transition:transform var(--t),box-shadow var(--t);display:flex;flex-direction:column}
.plato-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px var(--sombra-m)}
.plato-card.no-disponible{opacity:.55;pointer-events:none}
.plato-img{height:195px;overflow:hidden;background:var(--crema-d);display:flex;align-items:center;justify-content:center;position:relative}
.plato-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.plato-card:hover .plato-img img{transform:scale(1.04)}
.plato-img .ph{font-size:4rem;opacity:.35}
.badge-dest{position:absolute;top:10px;left:10px;background:var(--terracota);color:#fff;font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}
.badge-agot{position:absolute;top:10px;right:10px;background:#777;color:#fff;font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:12px}
.plato-body{padding:16px 18px;flex:1;display:flex;flex-direction:column}
.plato-body h3{font-size:1.05rem;margin-bottom:5px}
.plato-desc{color:#7a6050;font-size:.85rem;margin-bottom:10px;flex:1}
.plato-alerg{font-size:.76rem;color:var(--arena-d);margin-bottom:10px}
.plato-footer{display:flex;align-items:flex-end;justify-content:space-between;padding-top:12px;border-top:1px solid var(--crema-d);flex-wrap:wrap;gap:8px}
.plato-precio{font-size:1.3rem;font-weight:700;color:var(--terracota);font-family:'Playfair Display',serif}
.envase-sel{width:100%;margin-top:8px}
.envase-sel label{font-size:.78rem;font-weight:700;color:var(--marron);display:block;margin-bottom:5px}
.envase-btns{display:flex;gap:5px;flex-wrap:wrap}
.e-btn{padding:4px 10px;font-size:.76rem;font-weight:700;border-radius:6px;cursor:pointer;border:1.5px solid;transition:all var(--t);background:transparent}
.e-btn[data-e="comprar"]{border-color:var(--terracota);color:var(--terracota)}
.e-btn[data-e="alquilar"]{border-color:var(--arena-d);color:var(--arena-d)}
.e-btn[data-e="propio"]{border-color:var(--verde);color:var(--verde)}
.e-btn.sel,.e-btn:hover{color:#fff}
.e-btn[data-e="comprar"].sel,.e-btn[data-e="comprar"]:hover{background:var(--terracota)}
.e-btn[data-e="alquilar"].sel,.e-btn[data-e="alquilar"]:hover{background:var(--arena-d)}
.e-btn[data-e="propio"].sel,.e-btn[data-e="propio"]:hover{background:var(--verde)}

/* ---- Menus semanales ---- */
.menus-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px}
.menu-card{background:#fff;border-radius:var(--r-lg);box-shadow:0 3px 16px var(--sombra);overflow:hidden;border:2px solid transparent;transition:all var(--t)}
.menu-card:hover{border-color:var(--terracota);transform:translateY(-3px)}
.menu-head{background:linear-gradient(135deg,var(--marron),var(--terracota));padding:22px 24px 16px;color:#fff}
.menu-head h3{font-size:1.25rem;color:#fff;margin-bottom:6px}
.menu-head p{font-size:.88rem;opacity:.9}
.menu-body{padding:20px 24px}
.menu-precios{margin-bottom:14px}
.precio-big{font-size:2rem;font-weight:700;color:var(--terracota);font-family:'Playfair Display',serif}
.precio-lbl{font-size:.82rem;color:var(--arena-d)}
.precio-mes{font-size:.9rem;color:var(--marron);margin-top:3px}
.suscribir-form select{width:100%;padding:8px 12px;border:1.5px solid var(--crema-d);border-radius:var(--r);font-size:.88rem;margin-bottom:10px}

/* ---- Carrito ---- */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;opacity:0;pointer-events:none;transition:opacity var(--t)}
.cart-overlay.open{opacity:1;pointer-events:all}
.cart-drawer{position:fixed;top:0;right:-440px;width:420px;max-width:96vw;height:100vh;background:var(--blanco);z-index:2001;display:flex;flex-direction:column;box-shadow:-4px 0 30px var(--sombra-m);transition:right .35s cubic-bezier(.4,0,.2,1)}
.cart-drawer.open{right:0}
.cart-hd{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;background:linear-gradient(135deg,var(--marron-d),var(--marron));color:var(--crema)}
.cart-hd h3{font-size:1.15rem;color:var(--crema)}
.cart-close{background:none;border:none;color:var(--crema);font-size:1.4rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background var(--t)}
.cart-close:hover{background:rgba(255,255,255,.15)}
.cart-items{flex:1;overflow-y:auto;padding:14px 16px}
.cart-empty{text-align:center;padding:40px 20px;color:var(--arena-d)}
.cart-empty .ei{font-size:3.5rem;margin-bottom:12px}
.cart-item{display:flex;gap:10px;padding:11px 0;border-bottom:1px solid var(--crema-d)}
.cart-item-info{flex:1;min-width:0}
.c-name{font-weight:700;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.c-sub{font-size:.78rem;color:var(--arena-d)}
.c-price{font-weight:700;color:var(--terracota);white-space:nowrap;font-size:.92rem}
.cart-qty{display:flex;align-items:center;gap:7px;margin-top:5px}
.q-btn{width:25px;height:25px;border-radius:50%;border:1.5px solid var(--arena);background:transparent;cursor:pointer;font-size:.95rem;font-weight:700;color:var(--marron);display:flex;align-items:center;justify-content:center;transition:all var(--t)}
.q-btn:hover{background:var(--terracota);border-color:var(--terracota);color:#fff}
.q-num{font-weight:700;min-width:18px;text-align:center;font-size:.9rem}
.cart-ft{padding:18px 22px;border-top:2px solid var(--crema-d)}
.coupon-row{display:flex;gap:8px;margin-bottom:14px}
.coupon-row input{flex:1;padding:8px 12px;border:1.5px solid var(--crema-d);border-radius:8px;font-size:.86rem;background:var(--crema)}
.cart-totals{margin-bottom:14px}
.ct-line{display:flex;justify-content:space-between;font-size:.88rem;margin-bottom:3px}
.ct-line.total{font-weight:700;font-size:1.1rem;color:var(--marron);border-top:1px solid var(--crema-d);padding-top:8px;margin-top:8px}
.ct-desc{color:var(--verde);font-weight:700}

/* ---- Modales ---- */
.m-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:3000;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity var(--t)}
.m-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--blanco);border-radius:var(--r-lg);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.3);transform:translateY(20px);transition:transform var(--t)}
.m-overlay.open .modal{transform:translateY(0)}
.modal-hd{background:linear-gradient(135deg,var(--marron-d),var(--marron));padding:18px 22px;display:flex;align-items:center;justify-content:space-between;border-radius:var(--r-lg) var(--r-lg) 0 0}
.modal-hd h3{color:var(--crema);font-size:1.15rem}
.m-close{background:none;border:none;color:var(--crema);font-size:1.4rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background var(--t)}
.m-close:hover{background:rgba(255,255,255,.15)}
.modal-bd{padding:26px 22px}
.modal-ft{padding:14px 22px;border-top:1px solid var(--crema-d);display:flex;gap:10px;justify-content:flex-end}

/* ---- Formularios ---- */
.fg{margin-bottom:16px}
.fg label{display:block;font-weight:700;font-size:.86rem;margin-bottom:5px;color:var(--marron)}
.fg input,.fg select,.fg textarea{width:100%;padding:10px 13px;border:1.5px solid var(--crema-d);border-radius:var(--r);font-family:'Lato',sans-serif;font-size:.9rem;background:#fff;color:var(--texto);transition:border-color var(--t)}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--terracota);box-shadow:0 0 0 3px rgba(184,84,42,.1)}
.fg textarea{resize:vertical;min-height:80px}
.fg-hint{font-size:.76rem;color:var(--arena-d);margin-top:3px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ---- Pago ---- */
.pago-opts{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.pago-opt{border:2px solid var(--crema-d);border-radius:var(--r);padding:16px;text-align:center;cursor:pointer;transition:all var(--t);position:relative}
.pago-opt:hover{border-color:var(--terracota)}
.pago-opt.sel{border-color:var(--terracota);background:rgba(184,84,42,.05)}
.pago-opt input[type=radio]{position:absolute;opacity:0;width:0;height:0}
.pago-icon{font-size:2.2rem;margin-bottom:7px}
.pago-lbl{font-weight:700;font-size:.9rem;color:var(--marron)}
.pago-desc{font-size:.78rem;color:var(--arena-d);margin-top:3px}

/* ---- Confirmacion ---- */
.conf-box{text-align:center;padding:32px 20px}
.conf-box .check{font-size:4rem;margin-bottom:12px}
.conf-box h3{font-size:1.5rem;margin-bottom:8px;color:var(--verde)}
.cod-pedido{font-size:2.4rem;font-weight:700;letter-spacing:6px;color:var(--terracota);background:var(--crema);border:3px dashed var(--arena);padding:14px 28px;border-radius:var(--r);display:inline-block;margin:14px 0;font-family:'Playfair Display',serif}
.bizum-box{background:linear-gradient(135deg,#0096c7,#023e8a);color:#fff;border-radius:var(--r-lg);padding:20px 24px;margin-top:18px;text-align:center}
.bizum-box .b-num{font-size:1.7rem;font-weight:700;letter-spacing:2px;margin:8px 0}
.bizum-box p{font-size:.88rem;opacity:.9}

/* ---- Newsletter ---- */
.nl-section{background:linear-gradient(135deg,var(--gris-logo-d),var(--marron-d),var(--terracota-d));padding:56px 20px;text-align:center}
.nl-section h2{color:var(--crema);margin-bottom:10px}
.nl-section p{color:rgba(245,237,216,.85);margin-bottom:24px}
.nl-form{display:flex;max-width:460px;margin:0 auto;gap:10px;flex-wrap:wrap}
.nl-form input{flex:1;min-width:180px;padding:11px 16px;border:none;border-radius:var(--r);font-size:.92rem;background:rgba(255,255,255,.15);color:#fff;backdrop-filter:blur(4px)}
.nl-form input::placeholder{color:rgba(255,255,255,.6)}
.nl-form input:focus{outline:2px solid var(--arena)}

/* ---- Alertas ---- */
.alert{padding:11px 16px;border-radius:var(--r);margin-bottom:14px;font-size:.88rem;font-weight:600;display:flex;align-items:center;gap:9px}
.alert-ok{background:#e8f5e9;color:#2e7d32;border-left:4px solid #4caf50}
.alert-err{background:#fdecea;color:#b71c1c;border-left:4px solid #f44336}
.alert-info{background:#e3f2fd;color:#0d47a1;border-left:4px solid #2196f3}

/* ---- Footer ---- */
footer{background:var(--marron-d);color:rgba(245,237,216,.75);padding:50px 20px 18px}
.footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;margin-bottom:32px}
.footer-col h4{color:var(--crema);font-size:1rem;margin-bottom:14px}
.footer-col p,.footer-col a{font-size:.86rem;color:rgba(245,237,216,.7);line-height:1.9;display:block}
.footer-col a:hover{color:var(--arena)}
.footer-logo{height:65px;border-radius:8px;margin-bottom:12px;background:#fff;padding:4px}
.footer-bottom{max-width:1200px;margin:0 auto;border-top:1px solid rgba(255,255,255,.08);padding-top:18px;text-align:center;font-size:.8rem;color:rgba(255,255,255,.3)}

/* ---- Mi cuenta tabs ---- */
.tabs{display:flex;gap:2px;border-bottom:2px solid var(--crema-d);margin-bottom:22px}
.tab-btn{padding:9px 18px;background:none;border:none;font-family:'Lato',sans-serif;font-weight:700;font-size:.88rem;color:var(--arena-d);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all var(--t)}
.tab-btn.active{color:var(--terracota);border-bottom-color:var(--terracota)}
.tab-c{display:none}
.tab-c.active{display:block}

/* ---- Estado pedido ---- */
.estado-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.76rem;font-weight:700;text-transform:uppercase}
.est-pendiente{background:#fff3cd;color:#856404}
.est-confirmado{background:#cce5ff;color:#004085}
.est-en_preparacion{background:#d4edda;color:#155724}
.est-listo{background:#d1ecf1;color:#0c5460}
.est-entregado{background:#e2e3e5;color:#383d41}
.est-cancelado{background:#f8d7da;color:#721c24}

/* ---- Responsive ---- */
@media(max-width:768px){
  .nav-links{display:none;flex-direction:column;position:fixed;top:70px;left:0;right:0;background:var(--marron);padding:14px;gap:2px;box-shadow:0 8px 20px rgba(0,0,0,.3)}
  .nav-links.open{display:flex}
  .nav-links li{width:100%}
  .nav-links a{display:block;padding:10px 16px}
  .hamburger{display:flex}
  .form-row{grid-template-columns:1fr}
  .pago-opts{grid-template-columns:1fr}
  .platos-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
  .hero{padding:48px 20px}
  .hero-logo{height:90px}
}
@media(max-width:480px){
  .platos-grid{grid-template-columns:1fr}
  .menus-grid{grid-template-columns:1fr}
  .cart-drawer{width:100%;max-width:100%}
}

/* ---- Utils ---- */
.text-c{text-align:center}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}
.hidden{display:none!important}
