:root {
  --oaks-cream: var(--color-bg-cream, #fef6e4);
  --oaks-paper: #ffffff;
  --oaks-teal: var(--color-primary-teal, #14b8a6);
  --oaks-teal-soft: #ccfbf1;
  --oaks-coral: var(--color-accent-coral, #ff6b6b);
  --oaks-ink: var(--color-ink, #2d3748);
  --oaks-muted: var(--color-ink-light, #4a5568);
  --oaks-line: #dbcdbb;
  --oaks-serif: var(--font-heading, "Bebas Neue", "Arial Black", sans-serif);
  --oaks-sans: var(--font-body, "Lato", Arial, sans-serif);
}

html { scroll-padding-top: 90px; }
body.oaks-page { background: var(--oaks-cream); color: var(--oaks-ink); font-family: var(--oaks-sans); }
.oaks-page h1, .oaks-page h2, .oaks-page h3 { font-family: var(--oaks-serif); letter-spacing: .02em; }
.oaks-wrap { width: min(1180px, calc(100% - 40px)); margin-inline: auto; }
.oaks-header { position: sticky; top: 0; z-index: 40; background: rgba(255,255,255,.96); border-bottom: 0; box-shadow: var(--shadow-md, 0 4px 6px -1px rgba(0,0,0,.1)); backdrop-filter: blur(12px); }
.oaks-nav { min-height: 82px; display: flex; align-items: center; justify-content: space-between; gap: 28px; }
.oaks-brand { display: flex; align-items: center; gap: 12px; color: var(--oaks-teal); text-decoration: none; }
.oaks-brand img { width: 54px; height: 54px; object-fit: contain; }
.oaks-brand strong { color: #1f2937; font: 700 1.75rem/1 var(--oaks-serif); letter-spacing: .02em; }
.oaks-links { display: flex; gap: 20px; align-items: center; list-style: none; }
.oaks-links a { color: #374151; text-decoration: none; font-size: .95rem; font-weight: 700; }
.oaks-links a:hover, .oaks-links a:focus-visible, .oaks-links a[aria-current="page"] { color: var(--oaks-teal); }
.oaks-menu { display: none; background: transparent; box-shadow: none; color: var(--oaks-teal); padding: 8px; border: 1px solid var(--oaks-line); border-radius: 2px; font: 700 1rem var(--oaks-sans); }
.oaks-hero { min-height: 660px; display: grid; grid-template-columns: minmax(0, .95fr) minmax(520px, 1.05fr); }
.oaks-hero-copy { position: relative; display: flex; flex-direction: column; justify-content: center; padding: 72px max(48px, calc((100vw - 1180px)/2)) 72px max(28px, calc((100vw - 1180px)/2)); overflow: hidden; }
.oaks-hero-copy::before { content: ""; position: absolute; width: 280px; height: 70px; left: -70px; bottom: 45px; background: var(--oaks-teal); opacity: .1; transform: rotate(-8deg); border-radius: 50%; }
.oaks-hero h1 { max-width: 620px; margin: 0 0 26px; color: var(--oaks-teal); font-size: clamp(3.65rem, 6.1vw, 6.4rem); line-height: .88; }
.oaks-hero h1 span { color: var(--oaks-coral); }
.oaks-facts { display: grid; gap: 12px; margin: 0 0 30px; padding: 0; list-style: none; font: 600 clamp(1rem, 1.3vw, 1.25rem)/1.35 var(--oaks-sans); }
.oaks-facts li { display: flex; gap: 12px; align-items: flex-start; }
.oaks-facts svg { flex: 0 0 22px; color: var(--oaks-coral); margin-top: 2px; }
.oaks-actions { display: flex; flex-wrap: wrap; gap: 14px; }
.oaks-button { display: inline-flex; justify-content: center; align-items: center; min-height: 50px; padding: 13px 24px; border: 2px solid var(--oaks-teal); border-radius: 2px; background: var(--oaks-teal); color: #fff; text-decoration: none; font: 700 1rem var(--oaks-sans); transition: transform .18s ease, background .18s ease; }
.oaks-button:hover { transform: translateY(-2px); background: #0b5357; }
.oaks-button--coral { background: var(--oaks-coral); border-color: var(--oaks-coral); }
.oaks-button--outline { color: var(--oaks-teal); background: transparent; }
.oaks-hero-media { min-height: 660px; }
.oaks-hero-media img { display: block; width: 100%; height: 100%; object-fit: cover; }
.oaks-hero-media img { object-position: 56% center; }
.oaks-section { padding: 104px 0; }
.oaks-section--paper { background: var(--oaks-paper); }
.oaks-section--soft { background: var(--oaks-teal-soft); }
.oaks-kicker { margin: 0 0 12px; color: var(--oaks-coral); font-size: .78rem; font-weight: 900; letter-spacing: .16em; text-transform: uppercase; }
.oaks-heading { margin: 0 0 24px; color: var(--oaks-teal); font-size: clamp(2.7rem, 5vw, 4.7rem); line-height: .98; }
.oaks-lead { max-width: 750px; color: var(--oaks-muted); font-size: clamp(1.1rem, 1.8vw, 1.32rem); line-height: 1.7; }
.oaks-overview { display: grid; grid-template-columns: 1.1fr .9fr; gap: 80px; align-items: start; }
.oaks-overview aside { border-left: 2px solid var(--oaks-coral); padding: 8px 0 8px 34px; }
.oaks-overview aside p { margin: 0 0 16px; font-size: 1.08rem; line-height: 1.65; }
.oaks-reasons { margin-top: 70px; display: grid; grid-template-columns: .8fr 1.2fr; gap: 80px; }
.oaks-reason-list { display: grid; grid-template-columns: 1fr 1fr; margin: 0; padding: 0; list-style: none; border-top: 1px solid var(--oaks-line); }
.oaks-reason-list li { padding: 18px 16px 18px 0; border-bottom: 1px solid var(--oaks-line); font-weight: 700; }
.oaks-artists { display: grid; grid-template-columns: .9fr 1.1fr; gap: 80px; align-items: center; }
.oaks-artwork-strip { display: grid; grid-template-columns: 1.1fr .9fr; gap: 16px; min-height: 410px; }
.oaks-artwork-strip img { width: 100%; height: 100%; min-height: 0; object-fit: cover; border: 10px solid #fff; background: var(--oaks-paper); box-shadow: 0 18px 45px rgba(14,54,55,.14); }
.oaks-artwork-strip img:first-child { object-position: center 20%; }
.oaks-artwork-strip img:last-child { object-fit: contain; margin: 48px 0 -30px; }
.oaks-copy p { color: var(--oaks-muted); font-size: 1.08rem; line-height: 1.75; }
.oaks-copy a { color: var(--oaks-teal); font-weight: 800; text-decoration-color: var(--oaks-coral); text-underline-offset: 4px; }
.oaks-venue { display: grid; grid-template-columns: .9fr 1.1fr; gap: 70px; align-items: stretch; }
.oaks-address { font-style: normal; font-size: 1.2rem; line-height: 1.65; margin: 28px 0; }
.oaks-map { min-height: 360px; overflow: hidden; background: #e8eee0; border: 10px solid var(--oaks-paper); box-shadow: 0 16px 40px rgba(14,54,55,.12); }
.oaks-map img { display: block; width: 100%; height: 100%; min-height: 360px; object-fit: cover; }
.oaks-visit-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 90px; }
.oaks-timetable { margin: 30px 0; border-top: 1px solid var(--oaks-line); }
.oaks-time { display: flex; justify-content: space-between; gap: 20px; padding: 22px 0; border-bottom: 1px solid var(--oaks-line); font: 600 1.25rem var(--oaks-serif); }
.oaks-essentials { display: grid; gap: 15px; font-size: 1.05rem; }
.oaks-essentials p { margin: 0; }
.oaks-faq details { border-bottom: 1px solid var(--oaks-line); }
.oaks-faq summary { position: relative; cursor: pointer; list-style: none; padding: 20px 46px 20px 0; font: 700 1.3rem/1.3 var(--oaks-serif); }
.oaks-faq summary::-webkit-details-marker { display: none; }
.oaks-faq summary::after { content: "+"; position: absolute; right: 8px; color: var(--oaks-coral); font: 400 2rem/1 var(--oaks-sans); }
.oaks-faq details[open] summary::after { content: "−"; }
.oaks-faq details p { max-width: 640px; margin: 0; padding: 0 48px 20px 0; color: var(--oaks-muted); line-height: 1.65; }
.oaks-cta { padding: 76px 0; color: #fff; background: var(--oaks-teal); }
.oaks-cta .oaks-wrap { display: flex; align-items: center; justify-content: space-between; gap: 50px; }
.oaks-cta h2 { max-width: 660px; margin: 0; font-size: clamp(2.6rem, 5.4vw, 5rem); line-height: .95; }
.oaks-footer { padding: 54px 0; border-top: 1px solid var(--oaks-line); background: var(--oaks-paper); }
.oaks-footer-grid { display: flex; justify-content: space-between; gap: 40px; align-items: flex-start; }
.oaks-footer nav { display: flex; flex-wrap: wrap; gap: 24px; }
.oaks-footer a { color: var(--oaks-teal); font-weight: 700; }
.oaks-footer p { margin: 12px 0 0; color: var(--oaks-muted); }

@media (max-width: 900px) {
  .oaks-menu { display: inline-flex; }
  .oaks-links { display: none; position: absolute; top: 82px; left: 0; right: 0; padding: 24px; flex-direction: column; align-items: flex-start; gap: 18px; background: var(--oaks-paper); border-bottom: 1px solid var(--oaks-line); }
  .oaks-links.is-open { display: flex; }
  .oaks-hero { grid-template-columns: 1fr; }
  .oaks-hero-copy { padding: 64px max(24px, calc((100vw - 720px)/2)); }
  .oaks-hero-media { min-height: 420px; }
  .oaks-overview, .oaks-artists, .oaks-venue, .oaks-visit-grid { grid-template-columns: 1fr; gap: 50px; }
  .oaks-reasons { grid-template-columns: 1fr; gap: 24px; }
}

@media (max-width: 620px) {
  .oaks-wrap { width: min(100% - 28px, 1180px); }
  .oaks-brand strong { font-size: 1.25rem; }
  .oaks-brand img { width: 44px; height: 44px; }
  .oaks-nav { min-height: 70px; }
  .oaks-links { top: 70px; }
  .oaks-hero { min-height: auto; }
  .oaks-hero-copy { padding: 54px 20px; }
  .oaks-hero h1 { font-size: clamp(3.2rem, 17vw, 4.6rem); }
  .oaks-hero-media { min-height: 330px; }
  .oaks-actions, .oaks-actions .oaks-button { width: 100%; }
  .oaks-section { padding: 72px 0; }
  .oaks-reason-list { grid-template-columns: 1fr; }
  .oaks-artwork-strip { min-height: 330px; }
  .oaks-artwork-strip img:last-child { margin-top: 30px; }
  .oaks-time { flex-direction: column; gap: 4px; }
  .oaks-cta .oaks-wrap, .oaks-footer-grid { align-items: stretch; flex-direction: column; }
  .oaks-cta .oaks-button { width: 100%; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .oaks-button { transition: none; }
}
