/* ── Bistrot 76 — shared R05 chrome (header/footer/tokens) ── */
:root{
  --cream:#FFFFFF;
  --cream-2:#F4ECDC;
  --cream-soft:#FAF4E8;
  --header-bg:#FAF4E8;
  --section-cream:#FAF4E8;
  --ink:#1a1714;
  --ink-2:#4a3f33;
  --ink-3:#6f6356;
  --red:#B83232;
  --red-deep:#8E2026;
  --teal:#3a7d8c;
  --whatsapp:#25D366;
  --hairline:rgba(26,23,20,.14);
  --hairline-strong:rgba(26,23,20,.32);
  --paper-shadow:0 1px 0 rgba(0,0,0,.03), 0 18px 36px -28px rgba(26,23,20,.25);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--cream); color:var(--ink);
  font-family:'EB Garamond', Georgia, serif; font-size:18px; line-height:1.55;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(1100px 600px at 88% -10%, rgba(184,50,50,.035), transparent 60%),
    radial-gradient(900px 700px at -10% 110%, rgba(58,125,140,.035), transparent 60%);
}
img{ max-width:100%; display:block; }
.mono{ font-family:'JetBrains Mono', ui-monospace, monospace; font-weight:500; letter-spacing:.06em; text-transform:uppercase; font-size:11px; }
.wrap{ max-width:1280px; margin:0 auto; padding:0 40px; position:relative; z-index:1; }

/* Double-rule motif */
.double-rule{ position:relative; height:9px; width:100%; }
.double-rule::before,.double-rule::after{ content:""; position:absolute; left:0; right:0; height:1.5px; background:var(--ink); }
.double-rule::before{ top:0; } .double-rule::after{ bottom:0; }
.double-rule > i{ position:absolute; left:14%; right:14%; top:50%; transform:translateY(-50%); height:1.5px; background:var(--teal); display:block; }

/* HEADER */
header.top{ background:var(--header-bg); position:relative; z-index:3; padding-top:18px; border-bottom:1px solid var(--hairline); }
.util-row{ display:flex; justify-content:space-between; align-items:center; padding-bottom:14px; color:var(--ink-3); border-bottom:1px solid var(--hairline); }
.util-row .meta{ display:flex; gap:18px; align-items:center; }
.util-row .meta .dot{ width:6px; height:6px; border-radius:50%; background:var(--red); display:inline-block; margin-right:8px; vertical-align:1px; }
.util-row .right{ display:flex; gap:18px; align-items:center; }
.util-row a{ color:var(--ink-3); text-decoration:none; }
.util-row a:hover{ color:var(--ink); }

.wordmark-wrap{ display:flex; justify-content:center; padding:36px 0 18px; }
.wordmark{ display:inline-flex; flex-direction:column; align-items:center; gap:6px; text-decoration:none; color:var(--ink); }
.wordmark .name{ font-family:'Playfair Display', serif; font-weight:800; color:var(--red); letter-spacing:.06em; font-size:60px; line-height:1; }
.wordmark .num-row{ display:flex; align-items:center; gap:14px; margin-top:6px; }
.wordmark .num-row span{ width:46px; border-top:1.5px solid var(--ink); border-bottom:1.5px solid var(--ink); height:6px; }
.wordmark .num-row .num{ font-family:'Playfair Display', serif; font-weight:800; font-size:24px; letter-spacing:.04em; border:0; height:auto; width:auto; }
.wordmark .tag{ margin-top:8px; font-family:'Playfair Display', serif; font-weight:600; font-size:11px; letter-spacing:.32em; text-transform:uppercase; color:var(--ink-2); }

nav.nav{ padding:14px 0 22px; }
.nav-inner{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:16px; }
.nav-center{ grid-column:2; display:flex; align-items:center; gap:24px; justify-self:center; }
.reserve-wrap{ grid-column:3; justify-self:end; }
nav .links{ display:flex; gap:28px; }
nav .links a{ color:var(--ink); text-decoration:none; font-size:17px; position:relative; padding-bottom:3px; font-family:'EB Garamond', serif; }
nav .links a::after{ content:""; position:absolute; left:0; right:100%; bottom:-2px; height:1.5px; background:var(--red); transition:right .25s ease; }
nav .links a:hover::after, nav .links a.active::after{ right:0; }
.lang{ display:inline-flex; border:1px solid var(--ink); border-radius:2px; overflow:hidden; }
.lang a{ padding:5px 10px; color:var(--ink); text-decoration:none; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.08em; text-transform:uppercase; }
.lang a.on{ background:var(--ink); color:var(--cream); }
.reserve{ display:inline-flex; align-items:center; gap:10px; background:var(--ink); color:var(--cream); padding:10px 16px; border-radius:2px; text-decoration:none; font-size:15px; }
.reserve .arr{ font-family:'Playfair Display',serif; font-style:italic; }

/* Section heads */
.sec{ padding:88px 0; }
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:32px; }
.sec-head h2{ font-family:'Playfair Display', serif; font-weight:800; font-size:50px; line-height:1; margin:0; letter-spacing:-.01em; }
.sec-head h2 em{ color:var(--red); font-style:italic; font-weight:500; }
.eye{ display:inline-flex; align-items:center; gap:10px; color:var(--ink-3); font-family:'JetBrains Mono', monospace; font-size:11px; text-transform:uppercase; letter-spacing:.12em; }
.eye .dash{ width:28px; border-top:1px solid var(--ink); border-bottom:1px solid var(--ink); height:4px; }

/* Buttons */
.btn{ display:inline-flex; align-items:center; gap:10px; padding:13px 20px; border-radius:2px; text-decoration:none; font-family:'EB Garamond', serif; font-size:16px; border:1.5px solid var(--ink); cursor:pointer; }
.btn-primary{ background:var(--red); color:var(--cream-soft); border-color:var(--red); }
.btn-primary:hover{ background:var(--red-deep); border-color:var(--red-deep); }
.btn-ghost{ background:transparent; color:var(--ink); }
.btn-ghost:hover{ background:var(--ink); color:var(--cream); }
.btn .arr{ font-family:'Playfair Display',serif; font-style:italic; }
.btn-wa{ background:var(--whatsapp); border-color:var(--whatsapp); color:#0a3622; }
.btn-wa:hover{ background:#1cb858; border-color:#1cb858; }

/* Page hero */
.page-hero{ padding:62px 0 40px; border-bottom:1px solid var(--hairline); }
.page-hero .eye{ margin-bottom:14px; }
.page-hero h1{ font-family:'Playfair Display', serif; font-weight:800; font-size:clamp(54px, 7vw, 104px); line-height:.96; margin:0 0 14px; letter-spacing:-.015em; }
.page-hero h1 em{ color:var(--red); font-style:italic; font-weight:500; }
.page-hero .sub{ max-width:60ch; font-size:20px; color:var(--ink-2); margin:0; }

.bg-cream{ background:var(--section-cream); }

/* Forms */
.form-grid{ display:grid; gap:18px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field{ display:flex; flex-direction:column; gap:6px; }
.field label{ font-family:'JetBrains Mono', monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }
.field input, .field select, .field textarea{ font-family:'EB Garamond', serif; font-size:17px; color:var(--ink); background:#fff; border:1px solid var(--hairline-strong); border-radius:2px; padding:11px 12px; outline:0; }
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--ink); box-shadow:0 0 0 3px rgba(184,50,50,.12); }
.field textarea{ resize:vertical; min-height:96px; }
.field .hint{ font-style:italic; color:var(--ink-3); font-size:13px; }

.pay-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.pay-opt{ border:1.5px solid var(--hairline-strong); border-radius:3px; padding:14px 16px; cursor:pointer; display:flex; gap:12px; align-items:flex-start; background:#fff; }
.pay-opt.on{ border-color:var(--ink); box-shadow:0 0 0 3px rgba(184,50,50,.12); }
.pay-opt .radio{ width:18px; height:18px; border:1.5px solid var(--ink); border-radius:50%; margin-top:3px; position:relative; flex-shrink:0; }
.pay-opt.on .radio::after{ content:""; position:absolute; inset:3px; background:var(--red); border-radius:50%; }
.pay-opt b{ font-family:'Playfair Display', serif; font-weight:700; font-size:18px; }
.pay-opt p{ margin:4px 0 0; color:var(--ink-3); font-size:14px; }

/* FOOTER */
footer{ background:var(--cream); padding:54px 0 24px; border-top:1px solid var(--hairline); }
.foot-grid{ display:grid; grid-template-columns:1.2fr auto 1.2fr; gap:36px; align-items:center; }
.foot-grid .l{ display:flex; flex-direction:column; gap:12px; }
.foot-grid .l .a-wa{ display:inline-flex; align-items:center; gap:10px; padding:9px 14px; background:var(--whatsapp); color:#0a3622; border-radius:2px; text-decoration:none; font-family:'EB Garamond', serif; font-size:15px; width:fit-content; }
.foot-grid .l .a-wa svg{ width:16px; height:16px; }
.foot-grid .links-row{ display:flex; gap:14px; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }
.foot-grid .links-row a{ color:var(--ink-3); text-decoration:none; }
.foot-grid .links-row a:hover{ color:var(--red); }
.foot-grid .r{ text-align:right; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); display:flex; flex-direction:column; gap:6px; align-items:flex-end; }
.foot-mark{ width:110px; height:110px; border-radius:50%; border:1.5px solid var(--ink); display:grid; place-items:center; position:relative; background:var(--cream-soft); }
.foot-mark::before{ content:""; position:absolute; inset:6px; border:1px solid var(--ink); border-radius:50%; }
.foot-mark .b{ font-family:'Playfair Display', serif; font-weight:800; color:var(--red); font-size:34px; line-height:1; text-align:center; }
.foot-mark .num{ font-family:'Playfair Display', serif; font-weight:800; font-size:13px; margin-top:2px; display:flex; align-items:center; gap:6px; justify-content:center; }
.foot-mark .num span{ width:14px; border-top:1.5px solid var(--ink); border-bottom:1.5px solid var(--ink); height:5px; }
.foot-bot{ display:flex; justify-content:space-between; align-items:center; margin-top:32px; padding-top:16px; border-top:1px solid var(--hairline); font-family:'JetBrains Mono', monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }

@media (max-width:980px){
  .nav-inner{ grid-template-columns:1fr; }
  .nav-center{ grid-column:1; justify-self:start; }
  .reserve-wrap{ grid-column:1; justify-self:start; }
  .foot-grid{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
  .pay-grid{ grid-template-columns:1fr; }
}
