/*
Theme Name: ZatBier Festival
Theme URI: https://www.zatbierfestival.nl/
Author: ZatBier Festival
Description: Officieel WordPress-thema voor ZatBier Festival 2026.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
Text Domain: zatbier-festival
*/

:root {
  --bg:          #f4efe2;
  --paper:       #fffaf0;
  --text:        #161616;
  --muted:       #5b5b5b;
  --accent:      #f2c230;
  --accent-dark: #c89608;
  --line:        #161616;
  --max:         1180px;
  --radius:      18px;
  --shadow:      0 16px 40px rgba(0,0,0,.08);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);line-height:1.65}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
p{margin:0 0 1rem}

.container{width:min(calc(100% - 2rem),var(--max));margin-inline:auto}
.section{padding:3rem 0 4.5rem}
.section-head{margin-bottom:2rem}
.section-head h2{margin:0 0 .5rem;font-size:clamp(2rem,4.5vw,3.2rem);text-transform:uppercase;letter-spacing:-.02em}
.section-head p{color:var(--muted);max-width:58ch}

/* Header */
.site-header{position:sticky;top:0;z-index:20;background:rgba(244,239,226,.92);backdrop-filter:blur(12px);border-bottom:2px solid var(--line)}
.navbar{min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.8rem;font-weight:800;letter-spacing:.06em;font-size:1.05rem}
.brand-mark{width:50px;height:50px;border:2px solid var(--line);border-radius:12px;background:var(--accent);display:grid;place-items:center;font-size:.78rem;font-weight:900;letter-spacing:.04em}
.brand-sub{display:block;font-size:.8rem;font-weight:400;color:var(--muted)}
.primary-navigation{display:flex}
.primary-menu{display:flex;align-items:center;gap:1.4rem;list-style:none;margin:0;padding:0;font-weight:700}
.primary-menu a:hover,.primary-menu .current-menu-item a{color:var(--accent-dark)}
.menu-toggle{display:none;border:2px solid var(--line);background:var(--paper);border-radius:10px;padding:.65rem .9rem;font-weight:700;cursor:pointer}

/* Buttons */
.button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.9rem 1.35rem;border-radius:999px;border:2px solid var(--line);background:var(--accent);color:var(--text);font-weight:800;font-size:1rem;box-shadow:6px 6px 0 var(--line);transition:transform .18s,box-shadow .18s;white-space:nowrap}
.button:hover{transform:translate(2px,2px);box-shadow:4px 4px 0 var(--line)}
.button--ghost{background:transparent;box-shadow:none}
.button--ghost:hover{box-shadow:none}
.button--large{padding:1.1rem 2rem;font-size:1.15rem}

/* Hero */
.hero{padding:5.5rem 0 3.5rem}
.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:2.5rem;align-items:center}
.kicker{display:inline-block;margin-bottom:1rem;padding:.4rem .85rem;border:2px solid var(--line);border-radius:999px;background:var(--paper);font-size:.88rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.hero h1{margin:0 0 1rem;font-size:clamp(2.8rem,7.5vw,5.5rem);line-height:.93;text-transform:uppercase;letter-spacing:-.03em}
.hero-sub{font-size:1.15rem;color:var(--muted);max-width:52ch}
.hero-meta{display:flex;flex-wrap:wrap;gap:1rem;margin:1.4rem 0}
.hero-meta span{display:inline-flex;align-items:center;gap:.4rem;font-weight:700;font-size:.93rem;padding:.35rem .75rem;background:var(--paper);border:2px solid var(--line);border-radius:999px}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem}

/* Hero card */
.hero-card{background:var(--paper);border:2px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.4rem}
.logo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.45rem;margin-bottom:1rem}
.logo-grid span{aspect-ratio:1/1;display:grid;place-items:center;border:2px solid var(--line);background:#fff;font-weight:900;font-size:1.3rem}
.hero-card-meta p{margin:.35rem 0;font-weight:700}
.hero-card-meta .small{color:var(--muted);font-weight:400;font-size:.88rem}

/* Cards */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.highlights{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.practical-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.info-card,.content-card,.ticket-card,.practical-card{background:var(--paper);border:2px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}
.info-card h3,.content-card h3,.ticket-card h3,.practical-card h3{margin:0 0 .7rem;font-size:1.1rem;text-transform:uppercase;letter-spacing:.04em}
.info-icon{font-size:2rem;margin-bottom:.7rem;display:block}
.practical-card ul{margin:0;padding:0 0 0 1.2rem}
.practical-card ul li{margin-bottom:.4rem}

/* Ticket banner */
.ticket-banner{display:grid;grid-template-columns:1.3fr .7fr;gap:2rem;align-items:center;padding:2rem 2.2rem;background:var(--accent);border:2px solid var(--line);border-radius:var(--radius);box-shadow:10px 10px 0 var(--line)}
.ticket-banner h2{margin:0 0 .6rem;font-size:clamp(1.8rem,3.5vw,2.8rem);text-transform:uppercase;line-height:1}
.ticket-price{font-size:2.8rem;font-weight:900;line-height:1;margin-bottom:.3rem}
.ticket-includes{font-size:.95rem;margin-bottom:1.2rem}
.ticket-cta{text-align:center}

/* Footer */
.site-footer{margin-top:5rem;padding:2.5rem 0 3rem;border-top:2px solid var(--line);background:#ece5d0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:2rem;align-items:start}
.footer-brand{font-weight:800;font-size:1.1rem;margin-bottom:.5rem}
.footer-copy{margin-top:1.5rem;font-size:.85rem;color:var(--muted);border-top:1px solid #ccc;padding-top:1.2rem}

/* Page */
.page-hero{padding:3rem 0 1rem}
.page-hero h1{margin:0 0 .5rem;font-size:clamp(2rem,5vw,3.5rem);text-transform:uppercase}
.site-main{min-height:50vh}

/* Responsive */
@media(max-width:920px){
  .hero-grid,.info-grid,.highlights,.ticket-banner,.footer-grid,.practical-grid{grid-template-columns:1fr}
  .menu-toggle{display:inline-flex}
  .primary-navigation{position:absolute;top:calc(100% + 1px);left:0;right:0;background:var(--paper);border-bottom:2px solid var(--line);padding:0 1rem 1.2rem;display:none}
  .primary-navigation.is-open{display:block}
  .primary-menu{flex-direction:column;align-items:flex-start;padding-top:1rem;gap:.8rem}
  .hero{padding:3rem 0 2rem}
  .ticket-banner{text-align:center}
  .ticket-cta{display:flex;justify-content:center}
}
