/*
Theme Name: Elmar's Oompah Band 2026
Theme URI: https://oompah-band.com/
Author: Wiesenmüller Entertainment UG (haftungsbeschränkt)
Author URI: https://oompah-band.com/
Description: Custom theme for Elmar's Oompah Band. Refined Bavarian identity for high-end corporate, yacht and Oktoberfest events. Keeps the existing site structure (incl. blog), adds automatic nofollow on outbound links and a DSGVO-friendly two-click YouTube consent. System fonts only, no external CDNs.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: Proprietary
Text Domain: oompah-band
*/

/* ============================================================
   SELF-HOSTED DISPLAY FONT (Lora) — served from this domain, no CDN
   ============================================================ */
@font-face{
  font-family:"Lora";font-style:normal;font-weight:500;font-display:swap;
  src:url("assets/fonts/lora-500.woff") format("woff");
}
@font-face{
  font-family:"Lora";font-style:normal;font-weight:600;font-display:swap;
  src:url("assets/fonts/lora-600.woff") format("woff");
}

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root{
  /* Colour — refined Bavarian: deep blue brand, brass-honey accent, cream paper */
  --c-ink:        #1d1b16;
  --c-ink-soft:   #57524a;
  --c-cream:      #f8f4ea;
  --c-card:       #fffdf8;
  --c-mist:       #eef2f7;
  --c-blue:       #0e3c68;
  --c-blue-2:     #16548f;
  --c-blue-ink:   #0a2a49;
  --c-honey:      #d79a23;
  --c-honey-2:    #b9791a;
  --c-line:       rgba(29,27,22,.12);
  --c-line-soft:  rgba(29,27,22,.07);

  /* Type */
  --f-display: "Lora","Iowan Old Style","Palatino Linotype",Palatino,"Book Antiqua",Georgia,"Times New Roman",serif;
  --f-body:    system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,"Apple Color Emoji",sans-serif;

  /* Fluid type scale */
  --t-eyebrow: .78rem;
  --t-body:    clamp(1.02rem,.98rem + .25vw,1.16rem);
  --t-lead:    clamp(1.16rem,1.06rem + .5vw,1.4rem);
  --t-h3:      clamp(1.3rem,1.1rem + 1vw,1.7rem);
  --t-h2:      clamp(1.7rem,1.3rem + 1.8vw,2.5rem);
  --t-h1:      clamp(2.4rem,1.6rem + 3.6vw,4.3rem);

  /* Space + shape */
  --wrap:    1180px;
  --wrap-narrow: 760px;
  --radius:  14px;
  --radius-sm: 9px;
  --shadow:  0 1px 2px rgba(10,42,73,.06), 0 14px 40px -18px rgba(10,42,73,.28);
  --shadow-sm: 0 1px 2px rgba(10,42,73,.06), 0 8px 22px -14px rgba(10,42,73,.22);
  --ease: cubic-bezier(.22,.61,.36,1);

  /* Bavarian Rauten (lozenge) pattern — blue diamonds on white, crisp at any scale */
  --rauten:
    linear-gradient(135deg, var(--c-blue) 25%, transparent 25%),
    linear-gradient(225deg, var(--c-blue) 25%, transparent 25%),
    linear-gradient(45deg,  var(--c-blue) 25%, transparent 25%),
    linear-gradient(315deg, var(--c-blue) 25%, transparent 25%);
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--f-body);
  font-size:var(--t-body);
  line-height:1.65;
  color:var(--c-ink);
  background:var(--c-cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-blue-2);text-underline-offset:3px;text-decoration-thickness:1px}
a:hover{color:var(--c-honey-2)}
h1,h2,h3,h4{font-family:var(--f-display);font-weight:600;line-height:1.12;color:var(--c-ink);letter-spacing:-.01em}
p{margin:0 0 1.1em}
:focus-visible{outline:3px solid var(--c-honey);outline-offset:2px;border-radius:3px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--c-blue);color:#fff;padding:.7rem 1.1rem;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

.wrap{width:min(100% - 2.4rem,var(--wrap));margin-inline:auto}
.eyebrow{
  font-family:var(--f-body);font-size:var(--t-eyebrow);font-weight:700;
  text-transform:uppercase;letter-spacing:.18em;color:var(--c-honey-2);
  display:inline-flex;align-items:center;gap:.55rem;margin:0 0 .9rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--c-honey);display:inline-block}

/* The signature: a thin Bavarian Rauten ribbon */
.rauten-band{
  height:13px;
  background-color:#fff;
  background-image:var(--rauten);
  background-position:13px 0,13px 0,0 0,0 0;
  background-size:26px 26px;
  border-block:1px solid rgba(10,42,73,.18);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  --bg:var(--c-honey);--fg:#231a05;
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--f-body);font-weight:700;font-size:1rem;line-height:1;
  padding:.95rem 1.5rem;border-radius:999px;border:1.5px solid transparent;
  background:var(--bg);color:var(--fg);text-decoration:none;cursor:pointer;
  transition:transform .18s var(--ease),box-shadow .25s var(--ease),background .2s;
  box-shadow:0 10px 22px -12px rgba(183,121,26,.9);
}
.btn:hover{transform:translateY(-2px);color:#231a05;box-shadow:0 16px 30px -14px rgba(183,121,26,.95)}
.btn--ghost{background:transparent;color:var(--c-blue);border-color:rgba(14,60,104,.35);box-shadow:none}
.btn--ghost:hover{background:rgba(14,60,104,.06);color:var(--c-blue);border-color:var(--c-blue)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:sticky;top:0;z-index:100}
.header-bar{
  background:rgba(248,244,234,.86);backdrop-filter:saturate(1.4) blur(10px);
  border-bottom:1px solid var(--c-line-soft);transition:box-shadow .3s,background .3s;
}
.is-scrolled .header-bar{box-shadow:0 6px 24px -18px rgba(10,42,73,.55);background:rgba(248,244,234,.95)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:100px}
.site-brand{display:flex;align-items:center;text-decoration:none;color:var(--c-ink)}
.site-brand img,.custom-logo{height:76px!important;width:auto!important;max-width:400px}
.brand-text{font-family:var(--f-display);font-size:1.35rem;font-weight:600;line-height:1.05}
.brand-text small{display:block;font-family:var(--f-body);font-size:.66rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--c-honey-2)}

.primary-nav ul{list-style:none;display:flex;align-items:center;gap:.35rem;margin:0;padding:0}
.primary-nav a{
  font-family:var(--f-body);font-weight:600;font-size:1rem;color:var(--c-ink);
  text-decoration:none;padding:.55rem .85rem;border-radius:8px;position:relative;
}
.primary-nav a::after{
  content:"";position:absolute;left:.85rem;right:.85rem;bottom:.32rem;height:2px;
  background:var(--c-honey);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);
}
.primary-nav a:hover{color:var(--c-blue)}
.primary-nav a:hover::after,.primary-nav .current-menu-item>a::after,.primary-nav .current_page_item>a::after{transform:scaleX(1)}
.nav-cta a{background:var(--c-blue);color:#fff!important;padding:.6rem 1.1rem!important;border-radius:999px}
.nav-cta a::after{display:none}
.nav-cta a:hover{background:var(--c-blue-2)}

.nav-toggle{display:none;background:none;border:1.5px solid var(--c-line);border-radius:10px;width:46px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:22px;height:2px;background:var(--c-ink);border-radius:2px;transition:transform .25s var(--ease),opacity .2s}
.nav-toggle span{position:relative}
.nav-toggle span::before{position:absolute;top:-7px}
.nav-toggle span::after{position:absolute;top:7px}
.nav-open .nav-toggle span{background:transparent}
.nav-open .nav-toggle span::before{transform:translateY(7px) rotate(45deg)}
.nav-open .nav-toggle span::after{transform:translateY(-7px) rotate(-45deg)}

@media(max-width:860px){
  .nav-toggle{display:inline-flex}
  .primary-nav{
    position:absolute;left:0;right:0;top:100%;background:var(--c-cream);
    border-bottom:1px solid var(--c-line);box-shadow:var(--shadow);
    transform:translateY(-8px);opacity:0;visibility:hidden;transition:.25s var(--ease);
  }
  .nav-open .primary-nav{transform:none;opacity:1;visibility:visible}
  .primary-nav ul{flex-direction:column;align-items:stretch;gap:0;padding:.5rem 1.2rem 1.2rem}
  .primary-nav li{border-bottom:1px solid var(--c-line-soft)}
  .primary-nav a{display:block;padding:.95rem .4rem;font-size:1.1rem}
  .primary-nav a::after{display:none}
  .nav-cta a{text-align:center;margin-top:.8rem}
}

@media(max-width:560px){
  .header-inner{min-height:80px}
  .site-brand img,.custom-logo{height:58px!important;max-width:74vw}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding:clamp(2.6rem,1rem + 6vw,5.5rem) 0 clamp(2rem,1rem + 4vw,4rem);overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(120% 90% at 100% 0%,rgba(22,84,143,.10),transparent 55%),
    radial-gradient(80% 70% at 0% 100%,rgba(215,154,35,.12),transparent 55%);
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.6rem,1rem + 3vw,3.6rem);align-items:center}
.hero h1{font-size:var(--t-h1);margin:.2rem 0 .9rem}
.hero h1 em{font-style:normal;color:var(--c-honey-2)}
.hero-lead{font-size:var(--t-lead);color:var(--c-ink-soft);max-width:34ch;margin-bottom:1.7rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem}
.hero-figure{position:relative}
.hero-figure img{border-radius:var(--radius);box-shadow:var(--shadow);position:relative;z-index:2;border:5px solid #fff}
.hero-figure::after{
  content:"";position:absolute;z-index:1;inset:auto -14px -16px auto;width:62%;height:78%;
  border-radius:var(--radius);background:var(--c-blue);
}
.hero-figure figcaption{margin-top:.7rem;font-size:.82rem;color:var(--c-ink-soft);text-align:right}
.hero-marks{display:flex;flex-wrap:wrap;gap:.5rem 1.4rem;margin-top:1.9rem;padding-top:1.4rem;border-top:1px solid var(--c-line)}
.hero-marks span{font-size:.82rem;font-weight:700;letter-spacing:.04em;color:var(--c-blue);text-transform:uppercase;display:inline-flex;align-items:center;gap:.45rem}
.hero-marks span::before{content:"";width:8px;height:8px;transform:rotate(45deg);background:var(--c-honey)}
@media(max-width:820px){
  .hero-grid{grid-template-columns:1fr;gap:2rem}
  .hero-figure{order:-1}
  .hero-figure::after{display:none}
  .hero-figure figcaption{text-align:left}
}

/* ============================================================
   SECTIONS / PROSE
   ============================================================ */
.section{padding:clamp(2.4rem,1.4rem + 4vw,4.5rem) 0}
.section--mist{background:var(--c-mist)}
.section--blue{background:var(--c-blue);color:#eaf1f8}
.section--blue h2,.section--blue h3{color:#fff}

.prose{max-width:var(--wrap-narrow);margin-inline:auto}
.prose.full{max-width:100%}
.prose h2{font-size:var(--t-h2);margin:2.4rem 0 1rem;position:relative;padding-top:1.2rem}
.prose h2::before{content:"";position:absolute;top:0;left:0;width:46px;height:3px;background:var(--c-honey)}
.prose h3{font-size:var(--t-h3);margin:2rem 0 .7rem;color:var(--c-blue)}
.prose h4{font-size:1.18rem;margin:1.6rem 0 .5rem;color:var(--c-ink);font-family:var(--f-body);font-weight:800;letter-spacing:.01em}
.prose ul,.prose ol{padding-left:1.3rem;margin:0 0 1.2em}
.prose li{margin:.3em 0}
.prose img{border-radius:var(--radius-sm);margin:1.4rem 0}
.prose blockquote{margin:1.6rem 0;padding:.4rem 0 .4rem 1.3rem;border-left:4px solid var(--c-honey);color:var(--c-ink-soft);font-style:italic}
.prose a{color:var(--c-blue-2);font-weight:600}
.prose hr{border:none;border-top:1px solid var(--c-line);margin:2.4rem 0}
.section-head{text-align:center;max-width:640px;margin:0 auto 2.4rem}
.section-head h2{font-size:var(--t-h2)}

/* ============================================================
   YOUTUBE — DSGVO two-click consent facade
   ============================================================ */
.yt-consent{
  position:relative;aspect-ratio:16/9;width:100%;margin:1.6rem 0;border-radius:var(--radius);
  overflow:hidden;background:#0a2a49;cursor:pointer;border:1px solid var(--c-line);
}
.yt-consent img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.6}
.yt-consent .yt-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1.4rem;color:#fff}
.yt-consent .yt-play{width:74px;height:52px;border-radius:14px;background:var(--c-honey);display:grid;place-items:center;margin-bottom:1rem;box-shadow:0 12px 30px -12px rgba(0,0,0,.6);transition:transform .2s var(--ease)}
.yt-consent:hover .yt-play{transform:scale(1.08)}
.yt-consent .yt-play::after{content:"";border-left:18px solid #231a05;border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:4px}
.yt-consent strong{font-size:1.05rem}
.yt-consent small{display:block;max-width:42ch;margin-top:.5rem;font-size:.8rem;opacity:.85;line-height:1.45}
.yt-consent iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* WordPress core / oEmbed fallbacks */
.wp-embed-aspect-16-9 .wp-block-embed__wrapper,.entry-content iframe{aspect-ratio:16/9;width:100%;height:auto;border-radius:var(--radius)}
figure{margin:1.4rem 0}
figcaption{font-size:.82rem;color:var(--c-ink-soft)}

/* ============================================================
   BLOG — archive / cards
   ============================================================ */
.archive-head{padding:clamp(2.2rem,1rem + 4vw,3.6rem) 0 0;text-align:center}
.archive-head h1{font-size:var(--t-h1)}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:1.6rem;padding:2.4rem 0}
.card{
  background:var(--c-card);border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease),box-shadow .3s var(--ease);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card-media{display:block;aspect-ratio:16/9;overflow:hidden;background:var(--c-mist)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.card:hover .card-media img{transform:scale(1.05)}
.card-body{padding:1.3rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1}
.card .cat{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--c-honey-2);margin-bottom:.6rem}
.card h2,.card h3{font-size:1.28rem;line-height:1.2;margin:0 0 .6rem}
.card h2 a,.card h3 a{color:var(--c-ink);text-decoration:none}
.card h2 a:hover,.card h3 a:hover{color:var(--c-blue)}
.card p{font-size:.97rem;color:var(--c-ink-soft);margin:0 0 1rem}
.card .more{margin-top:auto;font-weight:700;color:var(--c-blue);text-decoration:none;font-size:.95rem;display:inline-flex;align-items:center;gap:.4rem}
.card .more::after{content:"→";transition:transform .2s var(--ease)}
.card:hover .more::after{transform:translateX(4px)}

/* Pagination */
.pagination{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;padding:1rem 0 3rem}
.pagination .page-numbers{
  display:inline-grid;place-items:center;min-width:44px;height:44px;padding:0 .7rem;
  border:1px solid var(--c-line);border-radius:10px;text-decoration:none;color:var(--c-ink);font-weight:600;background:var(--c-card)
}
.pagination .page-numbers:hover{border-color:var(--c-blue);color:var(--c-blue)}
.pagination .page-numbers.current{background:var(--c-blue);color:#fff;border-color:var(--c-blue)}
.pagination .dots{border:none;background:none}

/* ============================================================
   SINGLE POST
   ============================================================ */
.post-hero{padding:clamp(2rem,1rem + 4vw,3.4rem) 0 0}
.post-hero .meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;justify-content:center;font-size:.85rem;color:var(--c-ink-soft);margin-bottom:1rem}
.post-hero .meta .cat{color:var(--c-honey-2);font-weight:700;text-transform:uppercase;letter-spacing:.12em}
.post-hero h1{font-size:var(--t-h1);text-align:center;max-width:18ch;margin:0 auto}
.post-feat{margin:2rem auto 0;max-width:var(--wrap)}
.post-feat img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow)}
.entry-content{padding-top:2.2rem}
.post-foot{max-width:var(--wrap-narrow);margin:2.6rem auto 0;padding-top:1.6rem;border-top:1px solid var(--c-line);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center}
.tags a{display:inline-block;font-size:.8rem;background:var(--c-mist);color:var(--c-blue);padding:.3rem .7rem;border-radius:999px;text-decoration:none;margin:.2rem .2rem 0}

/* ============================================================
   COMMENTS
   ============================================================ */
.comments-area{max-width:var(--wrap-narrow);margin:3rem auto 0}
.comments-area h2,.comments-area h3{font-size:var(--t-h3)}
.comment-list{list-style:none;padding:0;margin:1.4rem 0}
.comment-list li{background:var(--c-card);border:1px solid var(--c-line);border-radius:var(--radius-sm);padding:1.1rem 1.3rem;margin-bottom:1rem}
.comment-list .says{display:none}
.comment-meta{font-size:.82rem;color:var(--c-ink-soft);margin-bottom:.4rem}
.comment-author b,.comment-author .fn{color:var(--c-blue);font-style:normal}
.comment-respond{background:var(--c-card);border:1px solid var(--c-line);border-radius:var(--radius);padding:1.6rem;margin-top:1.6rem}
.comment-form p{margin:0 0 1rem}
.comment-form label{display:block;font-weight:700;font-size:.9rem;margin-bottom:.3rem}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea,
.search-form input[type=search]{
  width:100%;padding:.8rem .9rem;border:1px solid var(--c-line);border-radius:10px;font:inherit;background:#fff;color:var(--c-ink)
}
.comment-form textarea{min-height:130px;resize:vertical}
.form-submit input,.search-form button{cursor:pointer}

/* Search */
.search-form{display:flex;gap:.5rem;max-width:480px}
.search-form button{padding:.8rem 1.2rem;border:none;border-radius:10px;background:var(--c-blue);color:#fff;font-weight:700}
.search-form button:hover{background:var(--c-blue-2)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--c-blue-ink);color:#cdddec;margin-top:auto}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.2rem;padding:3rem 0 2.2rem}
.site-footer h4{color:#fff;font-family:var(--f-body);font-weight:800;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin:0 0 1rem}
.site-footer a{color:#cdddec;text-decoration:none}
.site-footer a:hover{color:var(--c-honey)}
.footer-brand img{height:64px;width:auto;filter:brightness(0) invert(1);opacity:.95;margin-bottom:1rem}
.footer-brand p{color:#9fb6cb;font-size:.92rem;max-width:34ch}
.footer-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.footer-contact a{display:block;margin-bottom:.5rem;font-weight:600}
.footer-contact small{color:#8aa3bb;font-size:.78rem;line-height:1.5;display:block;margin-top:.6rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:1.2rem 0;display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;font-size:.84rem;color:#8aa3bb}
.footer-bottom a{color:#8aa3bb}
@media(max-width:760px){.footer-inner{grid-template-columns:1fr;gap:1.8rem}}

/* ============================================================
   MOTION
   ============================================================ */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
