:root {
    --color-bg: #181411;
    --color-bg-alt: #2a211b;
    --color-surface: #34281f;
    --color-surface-dark: #0d0d0d;
    --color-text: #fff3e0;
    --color-muted: #cdbba5;
    --color-accent: #f2a93b;
    --color-accent-hover: #fff3e0;
    --color-brick: #b85c38;
    --color-border: rgba(255, 243, 224, 0.16);
    --color-overlay: rgba(0, 0, 0, 0.58);
    --font-heading: "Oswald", system-ui, sans-serif;
    --font-body: "Manrope", system-ui, sans-serif;
    --container: min(1160px, calc(100% - 32px));
    --radius-sm: 12px;
    --radius-md: 16px;
    --radius-lg: 28px;
    --shadow-dark: 0 24px 80px rgba(0, 0, 0, 0.36);
    --transition: 180ms ease;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    background: radial-gradient(circle at top left, rgba(242, 169, 59, 0.08), transparent 34rem), linear-gradient(180deg, #0d0d0d 0%, var(--color-bg) 42%, #100d0b 100%);
    color: var(--color-text);
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.6;
}
body::before {
    content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: 0.12;
    background-image: linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);
    background-size: 48px 48px;
}
img { display: block; width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
.container { width: var(--container); margin-inline: auto; }
.section-padding { padding: 76px 0; }
.section-kicker, .eyebrow { margin: 0 0 10px; color: var(--color-accent); font-family: var(--font-heading); font-size: .9rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
h1,h2,h3 { font-family: var(--font-heading); text-transform: uppercase; letter-spacing: .02em; line-height: 1; }
h1,h2,h3,p { margin-top: 0; }
h2 { margin-bottom: 18px; font-size: clamp(2rem, 5vw, 4rem); }
h2 span { color: var(--color-accent); }
p { color: var(--color-muted); }
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 13px 24px; border-radius: var(--radius-sm); border: 1px solid transparent; font-family: var(--font-heading); font-size: .95rem; font-weight: 700; line-height: 1; letter-spacing: .05em; text-transform: uppercase; transition: background-color var(--transition), color var(--transition), border-color var(--transition), transform var(--transition); }
.btn:hover,.btn:focus-visible { transform: translateY(-2px); }
.btn-primary { background: linear-gradient(180deg, #ffc45d 0%, var(--color-accent) 100%); color: #181411; box-shadow: 0 12px 36px rgba(242,169,59,.2); }
.btn-primary:hover,.btn-primary:focus-visible { background: var(--color-accent-hover); color: #181411; }
.btn-secondary { border-color: rgba(255,243,224,.42); color: var(--color-text); background: rgba(0,0,0,.18); }
.btn-secondary:hover,.btn-secondary:focus-visible { background: rgba(255,243,224,.1); border-color: var(--color-accent); }
.btn-small { min-height: 42px; padding: 11px 18px; font-size: .84rem; }
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(8,8,8,.9); border-bottom: 1px solid var(--color-border); backdrop-filter: blur(16px); }
.header-inner { display: flex; align-items: center; justify-content: space-between; min-height: 78px; gap: 24px; }
.brand { display: inline-flex; flex-direction: column; line-height: 1; }
.brand-main { font-family: var(--font-heading); font-size: 2rem; font-weight: 700; color: var(--color-text); letter-spacing: .14em; }
.brand-sub { margin-top: 4px; color: var(--color-accent); font-family: var(--font-heading); font-size: .7rem; text-transform: uppercase; letter-spacing: .07em; }
.desktop-nav { display: none; align-items: center; gap: 28px; }
.desktop-nav a { position: relative; color: var(--color-text); font-family: var(--font-heading); font-size: .86rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.desktop-nav a::after { content: ""; position: absolute; left: 0; bottom: -8px; width: 0; height: 2px; background: var(--color-accent); transition: width var(--transition); }
.desktop-nav a:hover::after { width: 100%; }
.header-call { display: none; align-items: center; gap: 8px; min-height: 40px; padding: 10px 18px; border: 1px solid rgba(242,169,59,.6); border-radius: 8px; color: var(--color-text); font-family: var(--font-heading); font-size: .84rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.menu-toggle { display: inline-flex; flex-direction: column; justify-content: center; width: 44px; height: 44px; gap: 6px; padding: 0; border: 0; background: transparent; cursor: pointer; }
.menu-toggle span { display: block; width: 28px; height: 3px; margin-left: auto; background: var(--color-text); border-radius: 999px; }
.mobile-nav { display: none; flex-direction: column; gap: 16px; padding: 18px 16px 24px; background: #0b0b0b; border-top: 1px solid var(--color-border); }
.mobile-nav.is-open { display: flex; }
.mobile-nav a { padding: 12px 0; border-bottom: 1px solid var(--color-border); font-family: var(--font-heading); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.mobile-call { display: inline-flex; justify-content: center; border: 1px solid var(--color-accent) !important; border-radius: var(--radius-sm); color: var(--color-accent); }
.hero-section { position: relative; min-height: calc(100svh - 78px); display: grid; place-items: center; overflow: hidden; border-bottom: 1px solid var(--color-border); }
.hero-bg,.hero-overlay { position: absolute; inset: 0; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.hero-overlay { background: radial-gradient(circle at center, rgba(242,169,59,.14), transparent 34rem), linear-gradient(180deg, rgba(0,0,0,.4), rgba(0,0,0,.8)), var(--color-overlay); }
.hero-content { position: relative; z-index: 2; padding: 82px 0; text-align: center; }
.hero-content h1 { margin-bottom: 18px; color: var(--color-text); font-size: clamp(5rem, 18vw, 10rem); letter-spacing: .06em; text-shadow: 0 12px 32px rgba(0,0,0,.7); }
.hero-location { display: inline-flex; align-items: center; gap: 18px; margin-bottom: 18px; color: var(--color-text); font-family: var(--font-heading); font-size: clamp(1rem, 2.4vw, 1.55rem); font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
.hero-tags { max-width: 620px; margin: 0 auto 34px; color: var(--color-text); font-family: var(--font-heading); font-size: clamp(1rem, 2vw, 1.28rem); font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.hero-actions { display: flex; flex-direction: column; justify-content: center; gap: 14px; max-width: 360px; margin: 0 auto; }
.scroll-indicator { display: inline-flex; margin-top: 32px; color: var(--color-text); font-size: 2rem; animation: viktorBounce 1.4s infinite; }
@keyframes viktorBounce { 0%,100% { transform: translateY(0); } 50% { transform: translateY(8px); } }
.intro-section { background: linear-gradient(180deg, rgba(255,243,224,.03), transparent), var(--color-bg); }
.intro-grid { display: grid; gap: 30px; align-items: center; }
.intro-image img { aspect-ratio: 4/3; object-fit: cover; border-radius: var(--radius-md); border: 1px solid var(--color-border); box-shadow: var(--shadow-dark); }
.intro-text p { max-width: 620px; }
.feature-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; margin-top: 44px; }
.feature-card { padding: 22px 14px; text-align: center; border: 1px solid var(--color-border); border-radius: var(--radius-md); background: rgba(255,243,224,.03); transition: transform var(--transition), border-color var(--transition), background-color var(--transition); }
.feature-card:hover { transform: translateY(-4px); border-color: rgba(242,169,59,.6); background: rgba(242,169,59,.06); }
.feature-icon { margin-bottom: 12px; font-size: 2rem; }
.feature-card h3 { margin-bottom: 4px; color: var(--color-accent); font-size: 1.1rem; }
.feature-card p { margin: 0; color: var(--color-text); font-family: var(--font-heading); font-size: .86rem; font-weight: 700; text-transform: uppercase; }
.hours-section { padding: 54px 0; background: linear-gradient(90deg, rgba(0,0,0,.72), rgba(24,20,17,.94)), var(--color-bg-alt); border-block: 1px solid var(--color-border); }
.hours-grid { display: grid; gap: 26px; align-items: center; }
.hours-content { display: grid; grid-template-columns: auto 1fr; gap: 18px; align-items: start; }
.hours-icon { display: grid; place-items: center; width: 58px; height: 58px; border: 2px solid var(--color-accent); border-radius: 999px; color: var(--color-accent); font-size: 2rem; }
.hours-content h2 { margin-bottom: 8px; color: var(--color-accent); font-size: clamp(1.5rem, 4vw, 2.4rem); }
.hours-time { margin-bottom: 16px; color: var(--color-text); font-family: var(--font-heading); font-size: clamp(2.3rem, 6vw, 4rem); font-weight: 700; line-height: 1; }
.hours-note { max-width: 420px; margin-bottom: 20px; }
.hours-image img { aspect-ratio: 16/7; object-fit: cover; border-radius: var(--radius-md); border: 1px solid var(--color-border); }
.menu-section { background: #120f0d; }
.section-heading { max-width: 760px; text-align: center; }
.section-heading p { margin-inline: auto; }
.menu-grid { display: grid; grid-template-columns: 1fr; gap: 18px; margin-top: 36px; }
.menu-card { position: relative; min-height: 260px; overflow: hidden; border: 1px solid rgba(242,169,59,.7); border-radius: var(--radius-sm); background: var(--color-surface); }
.menu-card img { width: 100%; height: 100%; min-height: 260px; object-fit: cover; filter: saturate(1.05) contrast(1.04); transition: transform 320ms ease; }
.menu-card:hover img { transform: scale(1.05); }
.menu-card::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 20%, rgba(0,0,0,.85) 100%); }
.menu-card-content { position: absolute; left: 18px; right: 18px; bottom: 18px; z-index: 2; text-align: center; }
.menu-card-content h3 { margin-bottom: 2px; color: var(--color-text); font-size: 1.5rem; }
.menu-card-content p { margin: 0; color: var(--color-text); font-family: var(--font-heading); font-weight: 700; text-transform: uppercase; }
.menu-actions { display: flex; justify-content: center; margin-top: 28px; }
.suggestion-box { display: grid; grid-template-columns: auto 1fr; gap: 18px; margin-top: 32px; padding: 26px; border: 1px solid rgba(242,169,59,.72); border-radius: var(--radius-sm); background: rgba(255,243,224,.03); }
.suggestion-icon { color: var(--color-accent); font-size: 2rem; }
.suggestion-box h3 { margin-bottom: 10px; color: var(--color-accent); font-size: 1.3rem; }
.suggestion-box p { margin-bottom: 0; }
.contact-section { background: linear-gradient(180deg, rgba(255,243,224,.02), transparent), var(--color-bg); }
.contact-grid { display: grid; gap: 28px; align-items: stretch; }
.contact-card { padding: 28px; border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: rgba(255,243,224,.035); }
.contact-list { display: grid; gap: 18px; margin: 0 0 26px; padding: 0; list-style: none; }
.contact-list li { display: grid; grid-template-columns: auto 1fr; gap: 14px; }
.contact-list span { color: var(--color-accent); }
.contact-list strong { display: block; margin-bottom: 3px; color: var(--color-text); font-family: var(--font-heading); text-transform: uppercase; }
.contact-list p { margin: 0; }
.contact-actions { display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px; }
.contact-note { margin-bottom: 0; font-size: .92rem; }
.map-placeholder { position: relative; display: grid; place-items: center; min-height: 340px; padding: 32px; overflow: hidden; border: 1px solid var(--color-border); border-radius: var(--radius-lg); text-align: center; background: linear-gradient(135deg, rgba(255,255,255,.04) 25%, transparent 25%) -20px 0 / 40px 40px, linear-gradient(225deg, rgba(255,255,255,.04) 25%, transparent 25%) -20px 0 / 40px 40px, linear-gradient(315deg, rgba(255,255,255,.04) 25%, transparent 25%) 0 0 / 40px 40px, linear-gradient(45deg, rgba(255,255,255,.04) 25%, #252525 25%) 0 0 / 40px 40px; }
.map-placeholder::after { content: ""; position: absolute; inset: 0; background: rgba(0,0,0,.4); }
.map-placeholder > * { position: relative; z-index: 2; }
.map-pin { width: 62px; height: 62px; display: grid; place-items: center; margin-bottom: 16px; border-radius: 999px; background: var(--color-text); color: #222; font-size: 2rem; }
.map-placeholder p { margin: 0; color: var(--color-text); font-family: var(--font-heading); font-size: 1.8rem; font-weight: 700; text-transform: uppercase; }
.map-placeholder span { color: var(--color-muted); }
.site-footer { padding: 26px 0; background: #080808; border-top: 1px solid var(--color-border); }
.footer-inner { display: grid; gap: 18px; text-align: center; }
.footer-brand { display: grid; gap: 4px; }
.footer-brand strong { color: var(--color-text); font-family: var(--font-heading); font-size: 1.4rem; letter-spacing: .12em; }
.footer-brand span,.footer-copy { color: var(--color-muted); font-size: .88rem; }
.footer-links { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; }
.footer-links a { color: var(--color-muted); font-size: .88rem; }
.footer-links a:hover { color: var(--color-accent); }
.footer-copy { margin: 0; }
@media (min-width: 600px) { .hero-actions,.contact-actions { flex-direction: row; } .menu-grid { grid-template-columns: repeat(2,1fr); } .feature-grid { grid-template-columns: repeat(3,1fr); } }
@media (min-width: 900px) { .section-padding { padding: 104px 0; } .desktop-nav,.header-call { display: flex; } .menu-toggle { display: none; } .mobile-nav { display: none !important; } .hero-section { min-height: 720px; } .intro-grid { grid-template-columns: .9fr 1.1fr; gap: 70px; } .feature-grid { grid-template-columns: repeat(5,1fr); } .hours-grid { grid-template-columns: 1fr 1.25fr; gap: 48px; } .menu-grid { grid-template-columns: repeat(4,1fr); } .contact-grid { grid-template-columns: .9fr 1.1fr; } .footer-inner { grid-template-columns: 1fr auto 1fr; align-items: center; text-align: left; } .footer-copy { text-align: right; } }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } *,*::before,*::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; } }
