/* ===========================================================
   El Cocedero de la Playa — estilos globales del sitio
   Paleta marca: azul marino #0b2030 + oro #d4a853
   =========================================================== */
:root{
  --bg:#0b2030;--bg-2:#081a27;--bg-3:#061521;--bg-soft:#0e2638;
  --gold:#d4a853;--gold-light:#e8c47e;--gold-deep:#b8923f;
  --ink:#f3ead7;--muted:rgba(243,234,215,.66);--line:rgba(212,168,83,.26);
  --serif:'Cormorant Garamond',Georgia,'Noto Serif SC',serif;
  --body:Georgia,'Noto Serif SC','Times New Roman',serif;
  --sans:'Jost','Helvetica Neue',Arial,sans-serif;
  --maxw:1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--bg);color:var(--ink);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:2}
.gold{color:var(--gold)}
::selection{background:rgba(212,168,83,.3);color:#fff}
::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg-3)}::-webkit-scrollbar-thumb{background:var(--gold-deep);border-radius:5px}

.kicker{font-family:var(--sans);font-size:11.5px;color:var(--gold);letter-spacing:.32em;text-transform:uppercase;font-weight:400}
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- NAV ---------- */
.nav{position:fixed;inset:0 0 auto 0;z-index:90;height:80px;display:flex;align-items:center;transition:.4s}
.nav.scrolled{height:62px;background:rgba(6,21,33,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
.brand{font-family:var(--serif);font-size:23px;letter-spacing:.04em;color:var(--gold);font-weight:600;line-height:1}
.brand small{display:block;font-family:var(--sans);font-size:8.5px;letter-spacing:.4em;color:var(--gold-light);text-transform:uppercase;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:30px;font-family:var(--sans);font-size:12.5px;letter-spacing:.12em;text-transform:uppercase}
.nav-links a{color:var(--muted);transition:.25s;position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--gold);transition:.3s}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--ink)}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-cta{border:1px solid var(--gold);color:var(--gold)!important;padding:10px 20px;border-radius:1px}
.nav-cta::after{display:none!important}.nav-cta:hover{background:var(--gold);color:var(--bg)!important}
.nav-toggle{display:none;background:none;border:0;color:var(--gold);font-size:26px;cursor:pointer}
@media(max-width:940px){
  .nav{height:62px;background:rgba(6,21,33,.9);backdrop-filter:blur(14px)}
  .nav-links{position:fixed;inset:62px 0 auto 0;flex-direction:column;gap:0;background:var(--bg-3);border-top:1px solid var(--line);padding:6px 0;display:none}
  .nav-links.open{display:flex}.nav-links a{padding:16px 28px;width:100%}
  .nav-toggle{display:block}
}

/* ---------- BUTTONS ---------- */
.btn{font-family:var(--sans);letter-spacing:.16em;text-transform:uppercase;font-size:12px;padding:16px 32px;transition:.3s;display:inline-block;cursor:pointer;border-radius:1px;text-align:center}
.btn-solid{background:linear-gradient(135deg,var(--gold-light),var(--gold));color:#0b2030;font-weight:500;box-shadow:0 10px 30px rgba(212,168,83,.22)}
.btn-solid:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(212,168,83,.32)}
.btn-ghost{border:1px solid var(--gold);color:var(--gold)}.btn-ghost:hover{background:rgba(212,168,83,.1);transform:translateY(-3px)}
.cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ---------- DECOR ---------- */
.divider{display:flex;align-items:center;justify-content:center;gap:13px;margin:24px 0 6px}
.divider .l{width:56px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.divider .r{width:56px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}
.divider .d{width:8px;height:8px;border:1px solid var(--gold);transform:rotate(45deg)}

/* ---------- HERO (interior pages) ---------- */
.phero{position:relative;padding:160px 24px 90px;text-align:center;overflow:hidden;
  background:radial-gradient(120% 80% at 50% 0%,rgba(212,168,83,.12),transparent 55%),linear-gradient(175deg,#10334b,var(--bg) 60%)}
.phero h1{font-family:var(--serif);font-size:clamp(40px,6vw,68px);color:var(--gold);font-weight:600;line-height:1.02}
.phero p{margin-top:14px;color:var(--muted);font-size:17px;max-width:580px;margin-inline:auto;font-style:italic}

/* ---------- SECTIONS ---------- */
section{padding:110px 0;position:relative}
.sec-head{text-align:center;margin-bottom:58px}
.sec-head h2{font-family:var(--serif);font-size:clamp(30px,4.4vw,48px);color:var(--ink);font-weight:500;margin-top:12px}
.sec-head .rule{display:flex;align-items:center;justify-content:center;gap:11px;margin-top:18px}
.sec-head .rule .l,.sec-head .rule .r{width:46px;height:1px;background:var(--gold)}
.sec-head .rule .d{width:7px;height:7px;border:1px solid var(--gold);transform:rotate(45deg)}
.lead{max-width:760px;margin:0 auto;text-align:center;font-family:var(--serif);font-size:clamp(20px,2.6vw,26px);line-height:1.7}

/* split (texto + imagen) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split.alt .txt{order:2}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:34px}.split.alt .txt{order:0}}
.split h3{font-family:var(--serif);font-size:32px;color:var(--gold);font-weight:500;margin-bottom:14px}
.split p{color:var(--muted);margin-bottom:14px}
.ph{position:relative;border:1px solid var(--line);min-height:340px;border-radius:3px;overflow:hidden;
  background:linear-gradient(135deg,var(--bg-soft),var(--bg-3));display:flex;align-items:center;justify-content:center}
.ph img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.ph .tag{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(212,168,83,.5)}

/* pilares */
.pillars{display:grid;grid-template-columns:repeat(3,1fr)}
@media(max-width:760px){.pillars{grid-template-columns:1fr;gap:46px}}
.pillar{text-align:center;padding:0 28px;position:relative}
.pillar+.pillar::before{content:"";position:absolute;left:0;top:10%;height:80%;width:1px;background:var(--line)}
@media(max-width:760px){.pillar+.pillar::before{display:none}}
.pillar .big{font-family:var(--serif);font-size:52px;color:var(--gold);line-height:1;font-weight:500}
.pillar h3{font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;margin:14px 0 8px}
.pillar p{color:var(--muted);font-size:14.5px;font-style:italic}

/* cards especialidades */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}
.card{position:relative;border:1px solid var(--line);padding:42px 28px;text-align:center;background:linear-gradient(180deg,rgba(255,255,255,.022),transparent);transition:.35s;overflow:hidden}
.card:hover{border-color:var(--gold);transform:translateY(-8px)}
.card .ico{font-size:34px}
.card h3{font-family:var(--serif);color:var(--gold);font-size:25px;font-weight:500;margin:16px 0 10px}
.card p{font-size:14.5px;color:var(--muted);font-style:italic}

/* galería */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:860px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.gallery{grid-template-columns:1fr}}
.gallery .ph{min-height:260px}
.gallery .ph.tall{grid-row:span 2;min-height:auto}

/* info / contacto */
.info-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:54px;align-items:stretch}
@media(max-width:860px){.info-grid{grid-template-columns:1fr}}
.info-block{margin-bottom:30px}.info-block:last-child{margin-bottom:0}
.info-block h3{font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.info-block p,.info-block a{color:var(--ink);font-size:17px}
.map{border:1px solid var(--line);min-height:380px;width:100%;height:100%;border-radius:3px;filter:saturate(.82) contrast(.92) brightness(.95)}
.hours{list-style:none}
.hours li{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px dashed var(--line);color:var(--muted)}
.hours li span:last-child{color:var(--ink)}

/* bloque reservas */
.resv{max-width:720px;margin:0 auto;text-align:center}
.resv .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:44px 0}
@media(max-width:680px){.resv .steps{grid-template-columns:1fr;gap:30px}}
.resv .step{text-align:center}
.resv .step .n{font-family:var(--serif);font-size:40px;color:var(--gold)}
.resv .step h4{font-family:var(--sans);font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin:8px 0 6px}
.resv .step p{color:var(--muted);font-size:14px}
.qr-note{margin-top:14px;font-style:italic;color:var(--gold-light);font-size:14px}

/* ---------- FOOTER ---------- */
.footer{background:#04101a;padding:64px 0 40px;border-top:1px solid var(--line);position:relative;z-index:2}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr;gap:30px;text-align:center}}
.footer .brand{font-size:26px}
.footer .ftag{font-family:var(--sans);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-light);margin-top:10px}
.footer h4{font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.footer ul{list-style:none}.footer li{margin:9px 0}
.footer a{color:var(--muted);transition:.2s}.footer a:hover{color:var(--gold)}
.footer .legal{border-top:1px solid var(--line);padding-top:24px;text-align:center;font-size:11.5px;color:rgba(243,234,215,.4)}

/* WhatsApp flotante */
.wa{position:fixed;right:24px;bottom:24px;z-index:80;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-light),var(--gold));color:var(--bg);display:flex;align-items:center;justify-content:center;font-size:27px;box-shadow:0 10px 30px rgba(0,0,0,.45);transition:.3s}
.wa:hover{transform:scale(1.1)}

/* ---------- HOME HERO ---------- */
.home-hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:140px 24px 120px;overflow:hidden;
  background:radial-gradient(140% 90% at 50% -10%,rgba(212,168,83,.16),transparent 50%),radial-gradient(100% 70% at 50% 120%,rgba(212,168,83,.10),transparent 55%),linear-gradient(175deg,#10334b 0%,var(--bg) 42%,var(--bg-2) 100%)}
.home-hero .halo{position:absolute;top:6%;left:50%;width:680px;height:680px;transform:translateX(-50%);background:radial-gradient(circle,rgba(212,168,83,.16),transparent 62%);filter:blur(20px);animation:breathe 7s ease-in-out infinite;pointer-events:none}
@keyframes breathe{0%,100%{opacity:.55;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.08)}}
.home-hero .frame{position:relative;z-index:3;border:1px solid var(--line);padding:70px 54px;max-width:860px;background:linear-gradient(180deg,rgba(8,23,34,.3),rgba(8,23,34,.12))}
.home-hero .frame::before,.home-hero .frame::after{content:"";position:absolute;width:18px;height:18px;border:1px solid var(--gold);transform:rotate(45deg)}
.home-hero .frame::before{top:-9px;left:-9px}.home-hero .frame::after{bottom:-9px;right:-9px}
.home-hero .eyebrow{font-family:var(--sans);font-size:12px;color:var(--gold-light);letter-spacing:.4em;text-transform:uppercase}
.home-hero h1{font-family:var(--serif);font-size:clamp(48px,9vw,104px);line-height:.98;color:var(--gold);margin:18px 0 8px;font-weight:500;letter-spacing:.01em}
.home-hero .tagline{font-family:var(--sans);font-size:clamp(12px,2vw,15px);letter-spacing:.42em;text-transform:uppercase;color:var(--gold-light)}
.home-hero .sub{margin-top:22px;font-size:clamp(17px,2.4vw,21px);color:var(--ink);max-width:540px;margin-inline:auto;font-style:italic;line-height:1.6}
.home-hero .cta-row{margin-top:40px}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:var(--gold);font-size:20px;z-index:3;opacity:.7;animation:bob 2s infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- LANG SWITCHER ---------- */
.lang{position:relative;font-family:var(--sans)}
.lang-btn{display:flex;align-items:center;gap:8px;background:none;border:1px solid var(--line);color:var(--ink);padding:8px 13px;cursor:pointer;font-size:12px;border-radius:1px}
.lang-btn:hover{border-color:var(--gold)}.lang-btn .flag{font-size:16px}
.lang-menu{position:absolute;right:0;top:calc(100% + 10px);background:var(--bg-3);border:1px solid var(--line);min-width:172px;padding:6px;display:none;box-shadow:0 18px 40px rgba(0,0,0,.55);z-index:95}
.lang-menu.open{display:block}
.lang-menu button{display:flex;align-items:center;gap:11px;width:100%;background:none;border:0;color:var(--ink);padding:10px 13px;cursor:pointer;font-size:13px;text-align:left;font-family:var(--sans)}
.lang-menu button:hover{background:rgba(212,168,83,.12)}.lang-menu button.active{color:var(--gold)}.lang-menu .flag{font-size:17px}
.nav-right{display:flex;align-items:center;gap:14px}

/* ---------- CARTA ---------- */
.catnav{position:sticky;top:62px;z-index:40;background:rgba(8,26,39,.92);backdrop-filter:blur(12px);border-block:1px solid var(--line)}
.catnav-inner{display:flex;gap:8px;overflow-x:auto;padding:12px 28px;max-width:var(--maxw);margin:0 auto;scrollbar-width:none}
.catnav-inner::-webkit-scrollbar{display:none}
.chip{flex:none;font-family:var(--sans);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);padding:8px 15px;border-radius:999px;cursor:pointer;background:none;white-space:nowrap;transition:.25s}
.chip:hover{color:var(--ink);border-color:var(--gold)}
.chip.active{background:var(--gold);color:var(--bg);border-color:var(--gold);font-weight:500}
.menu-cat{margin:0 0 22px;break-inside:avoid;scroll-margin-top:130px}
.cat-title{font-family:var(--serif);font-size:30px;color:var(--gold);font-weight:600;padding-bottom:10px;margin-bottom:8px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}
.cat-title::before{content:"";width:6px;height:6px;border:1px solid var(--gold);transform:rotate(45deg);flex:none}
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 60px}
@media(max-width:780px){.cat-grid{grid-template-columns:1fr}}
.dish{display:flex;align-items:baseline;gap:12px;padding:13px 0;border-bottom:1px dashed rgba(212,168,83,.16)}
.dish .info{min-width:0}.dish .name{color:var(--ink);font-size:17.5px}.dish .star{color:var(--gold)}
.dish .desc{display:block;font-style:italic;font-size:13px;color:var(--muted);margin-top:2px;font-family:var(--serif)}
.dish .dots{flex:1 1 auto;align-self:flex-end;border-bottom:1px dotted rgba(212,168,83,.3);min-width:14px;transform:translateY(-5px)}
.dish .price{color:var(--gold);font-family:var(--sans);font-size:14.5px;white-space:nowrap;letter-spacing:.02em}
.menu-note{text-align:center;margin:46px auto 0;font-style:italic;color:var(--gold-light);font-family:var(--serif);font-size:18px;max-width:660px}

@media print{
  .nav,.catnav,.wa,.cta-row,.footer{display:none!important}
  body{background:#fff;color:#111}body::before{display:none}
  .cat-title,.dish .price,.menu-note,.phero h1{color:#7a5a16}
  .dish .name{color:#111}.dish .desc{color:#444}.reveal{opacity:1;transform:none}
}
