/* ===========================================================================
   Global theme — applies the bold "food poster" look (Anton + Manrope,
   cream / orange / wine / charcoal) to every page. Loaded after site.css so
   it overrides the legacy styles. The home page additionally loads home.css.
   =========================================================================== */
:root {
    --t-cream: #FBF3E7;
    --t-paper: #FFFFFF;
    --t-ink:   #221A15;
    --t-orange:#CB5A33;
    --t-wine:  #7C1E2A;
    --t-gold:  #E8A33D;
    --t-muted: #5a4f47;
}

/* ── Base ─────────────────────────────────────────────────────────────────── */
body {
    background: var(--t-cream);
    color: var(--t-ink);
    font-family: 'Manrope', system-ui, -apple-system, sans-serif;
}
h1, h2, h3, h4 { font-family: 'Anton', 'Lato', sans-serif; color: var(--t-ink); letter-spacing: .01em; }
a { color: var(--t-wine); }
.container { width: min(1180px, 92%); }

/* ── Header ───────────────────────────────────────────────────────────────── */
.site-header { background: var(--t-cream); border-bottom: 3px solid var(--t-ink); }
.site-header .brand-text strong { font-family: 'Anton', sans-serif; letter-spacing: .02em; color: var(--t-ink); }
.site-nav a { color: var(--t-ink); font-weight: 700; font-size: .92rem; }
.site-nav a:hover { color: var(--t-orange); text-decoration: none; }
.site-nav a.cta-button {
    background: var(--t-orange); color: #fff; border: 2.5px solid var(--t-ink);
    border-radius: 100px; padding: 9px 20px; font-weight: 800; text-transform: uppercase;
    box-shadow: 3px 3px 0 var(--t-ink);
}
.site-nav a.cta-button:hover { background: var(--t-orange); transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--t-ink); }
.site-nav a.nav-outline {
    border: 2.5px solid var(--t-ink); color: var(--t-ink); border-radius: 100px; padding: 8px 18px;
    font-weight: 800; text-transform: uppercase; background: transparent;
}
.site-nav a.nav-outline:hover { background: var(--t-wine); color: #fff; border-color: var(--t-ink); }
.lang-switcher .lang { border: 2px solid var(--t-ink); color: var(--t-ink); font-weight: 800; border-radius: 8px; }
.lang-switcher .lang--current,
.lang-switcher .lang--current:hover { background: var(--t-orange); color: #fff; border-color: var(--t-ink); }
.lang-switcher .lang:hover { background: #fbe3d6; border-color: var(--t-ink); color: var(--t-wine); }

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn {
    font-family: 'Manrope', sans-serif; font-weight: 800; text-transform: uppercase; letter-spacing: .03em;
    font-size: .95rem; padding: 16px 34px; border-radius: 100px; border: 2.5px solid var(--t-ink);
    box-shadow: 4px 4px 0 var(--t-ink); transition: transform .15s ease, box-shadow .15s ease, background .2s ease;
}
.btn:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--t-ink); text-decoration: none; }
.btn:active { transform: translate(2px,2px); box-shadow: 1px 1px 0 var(--t-ink); }
.btn-primary, .btn-primary:hover { background: var(--t-orange); color: #fff; border-color: var(--t-ink); }
.btn-ghost { background: var(--t-gold); color: var(--t-ink); }
.btn-ghost:hover { background: var(--t-gold); color: var(--t-ink); }
.btn-block { display: block; width: 100%; text-align: center; }

/* ── Page hero (photo banner) ─────────────────────────────────────────────── */
.page-hero {
    position: relative;
    padding: 84px 0 72px;
    border-bottom: 4px solid var(--t-ink);
    background:
        linear-gradient(96deg, rgba(28,18,14,.82) 0%, rgba(28,18,14,.5) 45%, rgba(28,18,14,.25) 100%),
        var(--hero-img, url("/static/img/about-hero.97a365cc60ac.jpg")) center 35% / cover no-repeat;
}
.page-hero::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 14px;
    background: var(--diamond-strip) repeat-x; background-size: 14px 14px; opacity: .9;
}
.page-hero .container { position: relative; z-index: 2; }
.page-hero h1 {
    font-family: 'Anton', sans-serif; text-transform: uppercase; color: var(--t-cream);
    font-size: clamp(2.6rem, 6.5vw, 5rem); line-height: .95; text-shadow: 2px 3px 0 rgba(0,0,0,.3);
}
.page-hero .lead, .page-hero p { color: var(--t-cream); opacity: .96; }
.page-hero .eyebrow { color: var(--t-gold); }

/* Brand (photo-less) hero keeps its gradient from site.css; just theme the type */
.page-hero--brand h1 { color: #fff; }

.eyebrow { font-family: 'Manrope', sans-serif; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; color: var(--t-orange); }
.lead, .lead-sub, .sub { font-family: 'Manrope', sans-serif; }

/* ── Prose ────────────────────────────────────────────────────────────────── */
.prose { max-width: 940px; padding-top: 46px; }
.prose p { font-family: 'Manrope', sans-serif; color: var(--t-muted); line-height: 1.8; font-size: 1.08rem; }
.prose h2 {
    font-family: 'Anton', sans-serif; text-transform: uppercase; color: var(--t-ink);
    font-size: clamp(1.7rem, 4vw, 2.6rem); line-height: 1; margin-top: 1.6em;
    padding-bottom: 10px; position: relative;
}
.prose h2::after { content: ""; display: block; width: 56px; height: 3px; margin-top: 12px; border-radius: 2px; background: linear-gradient(90deg, var(--t-orange), var(--t-wine)); }
.prose a { color: var(--t-wine); font-weight: 700; }

/* ── Schedule ─────────────────────────────────────────────────────────────── */
.schedule-list li {
    background: var(--t-paper); border: 3px solid var(--t-ink); border-radius: 16px;
    padding: 18px 22px; margin-bottom: 14px; box-shadow: 4px 4px 0 var(--t-wine);
    grid-template-columns: 110px 1fr;
}
.schedule-list time { font-family: 'Anton', sans-serif; color: var(--t-orange); font-size: 1.3rem; }
.schedule-list strong { font-family: 'Anton', sans-serif; text-transform: uppercase; font-size: 1.15rem; letter-spacing: .02em; }
.schedule-list p { color: var(--t-muted); }

/* ── Menu cards — big, appetizing photos ──────────────────────────────────── */
.menu-grid { grid-template-columns: repeat(auto-fit, minmax(440px, 1fr)); gap: 32px; margin-top: 36px; }
.menu-card { background: var(--t-paper); border: 3px solid var(--t-ink); border-radius: 22px; box-shadow: 6px 8px 0 var(--t-wine); overflow: hidden; transition: transform .2s ease, box-shadow .2s ease; }
.menu-card:hover { transform: translateY(-6px); box-shadow: 10px 14px 0 var(--t-wine); }
.menu-card img { width: 100%; height: clamp(320px, 38vw, 460px); object-fit: cover; border-bottom: 3px solid var(--t-ink); transition: transform .6s ease; }
.menu-card:hover img { transform: scale(1.05); }
.menu-card .menu-card-body { padding: 22px 24px 26px; }
.menu-card h3 { font-family: 'Anton', sans-serif; text-transform: uppercase; font-size: clamp(1.4rem, 2.6vw, 2rem); color: var(--t-ink); line-height: 1.05; }
.menu-card .price { font-family: 'Anton', sans-serif; color: var(--t-orange); font-size: 1.9rem; }
.menu-card p { color: var(--t-muted); font-size: 1.04rem; }
@media (max-width: 520px) { .menu-grid { grid-template-columns: 1fr; } .menu-card img { height: clamp(260px, 70vw, 360px); } }

/* ── Sponsor tiers ────────────────────────────────────────────────────────── */
.tier { background: var(--t-paper); border: 3px solid var(--t-ink) !important; border-radius: 18px; box-shadow: 5px 6px 0 var(--t-wine); }
.tier h3 { font-family: 'Anton', sans-serif; text-transform: uppercase; }
.tier-price { font-family: 'Anton', sans-serif; }
.tier-gold { border-top: 8px solid var(--t-gold) !important; }
.tier-silver { border-top: 8px solid #9ea7ad !important; }
.tier-bronze { border-top: 8px solid #cd7f32 !important; }
.tier-cta { font-weight: 800; text-transform: uppercase; color: var(--t-wine); }
.tier-clickable:hover { transform: translateY(-5px); box-shadow: 8px 11px 0 var(--t-wine); }

/* ── Forms ────────────────────────────────────────────────────────────────── */
.form-row label, .ticket-form label { font-family: 'Manrope', sans-serif; font-weight: 700; color: var(--t-ink); }
.form-control, input[type="text"], input[type="email"], input[type="tel"], input[type="number"], textarea, select {
    border: 2.5px solid var(--t-ink); border-radius: 12px; padding: 13px 15px; font-family: 'Manrope', sans-serif; background: var(--t-paper);
}
.form-control:focus, input:focus, textarea:focus, select:focus { outline: none; border-color: var(--t-orange); box-shadow: 3px 3px 0 var(--t-orange); }
.error { color: var(--t-wine); font-weight: 700; }

/* Sponsor donate / amount buttons */
.amount-btn, .tier-cta, .amount-custom { font-family: 'Manrope', sans-serif; }
.amount-btn { border: 2.5px solid var(--t-ink); border-radius: 100px; font-weight: 800; background: var(--t-paper); color: var(--t-ink); }
.amount-btn:hover, .amount-btn.is-active { background: var(--t-orange); color: #fff; }

/* Tickets */
.ticket-type-row, .tt-info { font-family: 'Manrope', sans-serif; }
.tt-price { font-family: 'Anton', sans-serif; color: var(--t-orange); }
.pay-head h2, .sponsor-card h3 { font-family: 'Anton', sans-serif; text-transform: uppercase; }

/* Stats / testimonials (when used on inner pages) */
.stat-num { font-family: 'Anton', sans-serif; color: var(--t-orange); }
.stat-label { font-family: 'Manrope', sans-serif; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }

/* ── Messages ─────────────────────────────────────────────────────────────── */
.message { border-radius: 12px; border-width: 2px; font-family: 'Manrope', sans-serif; font-weight: 600; }

/* ── Footer ───────────────────────────────────────────────────────────────── */
.site-footer { background: var(--t-wine); color: #f4dfd2; }
.site-footer h4 { font-family: 'Anton', sans-serif; text-transform: uppercase; color: #fff; letter-spacing: .03em; }
.site-footer a { color: var(--t-gold); }
.site-footer .newsletter-form button { background: var(--t-orange); color: #fff; border: 2px solid var(--t-ink); border-radius: 100px; font-weight: 800; }

/* ── Pre-order food rows (buy page) ───────────────────────────────────────── */
.food-row { grid-template-columns: 66px 1fr auto 70px; }
.food-row .tt-img img {
    width: 66px; height: 66px; object-fit: cover;
    border-radius: 12px; border: 2.5px solid var(--t-ink); display: block;
}
@media (max-width: 560px) {
    .food-row { grid-template-columns: 52px 1fr auto; }
    .food-row .tt-qty { grid-column: 1 / -1; }
    .food-row .tt-img img { width: 52px; height: 52px; }
}

/* ── Blog ─────────────────────────────────────────────────────────────────── */
.blog-list { padding-top: 44px; }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); gap: 28px; margin: 8px 0 48px; }
.blog-card {
    display: flex; flex-direction: column; background: var(--t-paper);
    border: 3px solid var(--t-ink); border-radius: 20px; box-shadow: 5px 6px 0 var(--t-wine);
    overflow: hidden; color: var(--t-ink); text-decoration: none;
    transition: transform .2s ease, box-shadow .2s ease;
}
.blog-card:hover { transform: translateY(-6px); box-shadow: 9px 12px 0 var(--t-wine); text-decoration: none; }
.blog-card-img { overflow: hidden; }
.blog-card-img img { width: 100%; height: 240px; object-fit: cover; display: block; border-bottom: 3px solid var(--t-ink); transition: transform .5s ease; }
.blog-card:hover .blog-card-img img { transform: scale(1.06); }
.blog-card-body { padding: 22px 24px 26px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.blog-card-body h2 { font-family: 'Anton', sans-serif; text-transform: uppercase; font-size: 1.35rem; line-height: 1.08; color: var(--t-ink); }
.blog-card-body p { color: var(--t-muted); font-size: .98rem; line-height: 1.6; margin: 0; }
.blog-readmore { font-weight: 800; text-transform: uppercase; letter-spacing: .04em; font-size: .82rem; color: var(--t-wine); margin-top: auto; }
.blog-article { max-width: 760px; }
.blog-article .blog-readmore { display: inline-block; margin-top: 18px; }
.blog-more { padding: 16px 0 64px; }
.blog-more > h2 { font-family: 'Anton', sans-serif; text-transform: uppercase; font-size: clamp(1.6rem, 3.5vw, 2.4rem); margin-bottom: 18px; }
.page-hero--post h1 { font-size: clamp(1.9rem, 4.4vw, 3.4rem); }

/* ── Menu feature image (big, prominent) ──────────────────────────────────── */
.menu-feature { margin: 42px auto 6px; }
.menu-feature img {
    width: 100%; height: clamp(340px, 52vw, 620px); object-fit: cover; display: block;
    border-radius: 24px; border: 4px solid var(--t-ink); box-shadow: 10px 12px 0 var(--t-wine);
}
