@import url("https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Italiana&display=swap");

:root { --bg:#f4efe5; --surface:#fffaf0; --ink:#201b16; --muted:#756d63; --accent:#a8782a; --line:#d9cebc; --dark:#161310; --serif:"Italiana",serif; --sans:"DM Sans",sans-serif; }
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; background:var(--bg); color:var(--ink); font-family:var(--sans); }
body.beef { --bg:#0d0d0c; --surface:#171613; --ink:#f8f1e3; --muted:#b7ad9d; --line:#383229; --accent:#d1a04b; --dark:#080807; }
a { color:inherit; }
button,input,select,textarea { font:inherit; }
.site-header { position:fixed; inset:0 0 auto; z-index:30; height:82px; display:flex; align-items:center; padding:0 max(24px,5vw); background:color-mix(in srgb,var(--dark) 88%,transparent); color:white; backdrop-filter:blur(14px); border-bottom:1px solid #ffffff18; }
.site-brand { display:flex; align-items:center; gap:12px; text-decoration:none; font-weight:700; letter-spacing:.02em; }
.site-mark { width:38px; height:38px; display:grid; place-items:center; border:1px solid var(--accent); color:var(--accent); border-radius:50%; font-family:var(--serif); font-size:22px; }
.site-nav { margin-left:auto; display:flex; align-items:center; gap:24px; }
.site-nav a { text-decoration:none; font-size:13px; color:#eee6d9; }
.lang-switch { width:auto; padding:8px 10px; border:1px solid #ffffff33; border-radius:999px; background:transparent; color:white; }
.lang-switch option { color:#111; }
.menu-toggle { display:none; margin-left:12px; border:0; background:none; color:white; font-size:24px; }
.hero { min-height:92vh; padding:150px max(24px,8vw) 80px; display:grid; align-items:end; position:relative; overflow:hidden; background:radial-gradient(circle at 80% 20%,color-mix(in srgb,var(--accent) 30%,transparent),transparent 34%),linear-gradient(135deg,var(--dark),color-mix(in srgb,var(--dark) 80%,var(--accent))); color:white; }
.hero::after { content:""; position:absolute; width:min(56vw,760px); aspect-ratio:1; border:1px solid #ffffff18; border-radius:50%; right:-10%; top:12%; box-shadow:0 0 0 90px #ffffff08,0 0 0 180px #ffffff05; }
.hero-content { position:relative; z-index:2; max-width:850px; }
.eyebrow { color:var(--accent); text-transform:uppercase; letter-spacing:.2em; font-size:11px; font-weight:700; }
h1,h2 { font-family:var(--serif); font-weight:400; }
h1 { margin:14px 0 24px; font-size:clamp(58px,9vw,128px); line-height:.9; letter-spacing:-.035em; }
.hero-copy { max-width:650px; color:#e0d7ca; font-size:18px; line-height:1.75; }
.actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:34px; }
.button { display:inline-flex; justify-content:center; align-items:center; min-height:48px; padding:0 22px; border:1px solid var(--accent); border-radius:999px; background:var(--accent); color:#17120b; text-decoration:none; font-weight:700; }
.button.ghost { background:transparent; color:white; }
section { padding:100px max(24px,8vw); }
.section-head { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:end; margin-bottom:48px; }
.section-head h2 { margin:8px 0 0; font-size:clamp(42px,6vw,76px); line-height:1; }
.section-head p { color:var(--muted); line-height:1.8; }
.location-grid,.concept-grid,.gallery-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; }
.location-card,.concept-card,.menu-card,.legal-card { padding:30px; background:var(--surface); border:1px solid var(--line); border-radius:20px; }
.location-card h3,.concept-card h3 { margin:0 0 12px; font-size:25px; }
.location-card p,.concept-card p { color:var(--muted); line-height:1.65; }
.card-actions { display:flex; flex-wrap:wrap; gap:10px; margin-top:22px; }
.text-link { color:var(--accent); font-weight:700; text-decoration:none; }
.menu-filters { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:24px; }
.menu-filters button { border:1px solid var(--line); background:transparent; color:var(--ink); border-radius:999px; padding:9px 15px; }
.menu-filters button.active { background:var(--accent); color:#16120c; border-color:var(--accent); }
.menu-list { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.menu-card { display:grid; grid-template-columns:1fr auto; gap:10px; }
.menu-card h3 { margin:0; font-size:17px; }
.menu-card p { grid-column:1/-1; margin:0; color:var(--muted); font-size:13px; line-height:1.6; }
.menu-card strong { color:var(--accent); }
.allergens { font-size:10px; color:var(--muted); }
.reservation-shell,.career-shell { display:grid; grid-template-columns:.8fr 1.2fr; background:var(--surface); border:1px solid var(--line); border-radius:26px; overflow:hidden; }
.form-copy { padding:44px; background:color-mix(in srgb,var(--accent) 13%,var(--surface)); }
.form-copy h2 { font-size:48px; margin:10px 0 18px; }
.site-form { padding:44px; display:grid; gap:15px; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
label { display:grid; gap:7px; font-size:12px; font-weight:700; color:var(--muted); }
input,select,textarea { width:100%; border:1px solid var(--line); border-radius:10px; padding:12px; background:var(--bg); color:var(--ink); }
.consent { grid-template-columns:auto 1fr; align-items:start; font-weight:400; line-height:1.5; }
.consent input { width:auto; margin-top:3px; }
.honeypot { position:absolute!important; left:-10000px!important; }
.form-message { padding:12px; border-radius:10px; background:#267a4930; color:#5bc181; }
.form-message.error { background:#a13b3b30; color:#e77979; }
.hidden { display:none!important; }
.legal-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.legal-card h2 { font-size:38px; margin:0 0 20px; }
.legal-card p { color:var(--muted); line-height:1.7; }
.site-footer { padding:45px max(24px,8vw); background:var(--dark); color:#d9d0c2; display:flex; justify-content:space-between; gap:25px; flex-wrap:wrap; }
.site-footer a { color:#d9d0c2; margin-right:18px; font-size:12px; }
.cookie-banner { position:fixed; z-index:50; left:20px; right:20px; bottom:20px; max-width:760px; margin:auto; padding:20px; border:1px solid var(--line); border-radius:16px; background:var(--surface); box-shadow:0 18px 80px #0006; }
.cookie-banner p { margin:0 0 14px; color:var(--muted); font-size:13px; line-height:1.5; }
.cookie-actions { display:flex; gap:9px; }
.cookie-actions button { border:1px solid var(--line); border-radius:999px; padding:9px 15px; background:transparent; color:var(--ink); }
.cookie-actions .accept { background:var(--accent); border-color:var(--accent); color:#17120b; }
@media (max-width:820px) {
  .site-header { height:70px; }
  .menu-toggle { display:block; }
  .site-nav { display:none; position:absolute; top:70px; left:0; right:0; padding:24px; background:var(--dark); flex-direction:column; align-items:flex-start; }
  .site-nav.open { display:flex; }
  .section-head,.reservation-shell,.career-shell,.legal-grid { grid-template-columns:1fr; }
  .location-grid,.concept-grid,.gallery-grid,.menu-list { grid-template-columns:1fr; }
  .form-copy,.site-form { padding:28px; }
  section { padding-top:72px; padding-bottom:72px; }
  .hero { min-height:86vh; padding-top:120px; }
}
@media (max-width:520px) { .form-grid { grid-template-columns:1fr; } h1 { font-size:58px; } }
