/*
Theme Name: August Zirner
Theme URI: https://augustzirner.de
Author: AZ Editorial
Author URI: https://augustzirner.de
Description: Editoriales Playbill-Theme für augustzirner.de – warmes Bühnen-Design mit klassischer Serifen-Typografie, Bordeauxrot und Cremepapier. Vollständig responsiv, schnell und SEO-optimiert.
Version: 1.0.2
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: august-zirner
Tags: blog, editorial, two-columns, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ---------- Tokens ---------- */
:root{
  --paper:#f6efe2;
  --paper-2:#efe6d3;
  --ink:#2a1a14;
  --ink-soft:#5a463c;
  --rule:#c8b89a;
  --burgundy:#7a1f2b;
  --burgundy-deep:#5a1620;
  --gold:#b48a3a;
  --gold-soft:#d8b66a;
  --cream-card:#fbf6ea;
  --shadow:0 1px 0 rgba(42,26,20,.06), 0 18px 40px -28px rgba(42,26,20,.35);
}

/* ---------- Reset & Base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Cormorant Garamond','Garamond','Times New Roman',serif;
  color:var(--ink);
  background:var(--paper);
  background-image:
    radial-gradient(1200px 600px at 10% -10%, rgba(122,31,43,.06), transparent 60%),
    radial-gradient(900px 500px at 100% 0%, rgba(180,138,58,.08), transparent 60%);
  font-size:19px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--burgundy);text-decoration:none;border-bottom:1px solid rgba(122,31,43,.25);transition:color .2s,border-color .2s}
a:hover{color:var(--burgundy-deep);border-bottom-color:var(--burgundy)}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:600;line-height:1.18;color:var(--ink);letter-spacing:-.01em;margin:0 0 .6em}
h1{font-size:clamp(2.4rem,5vw,4rem)}
h2{font-size:clamp(1.9rem,3.4vw,2.6rem)}
h3{font-size:1.4rem}
p{margin:0 0 1.05em}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.eyebrow,.mono{font-family:'IBM Plex Mono','Courier New',monospace;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--burgundy);font-weight:500}
blockquote{border:none;border-left:3px solid var(--burgundy);background:rgba(122,31,43,.04);margin:1.6em 0;padding:1em 1.2em;font-style:italic;color:var(--ink-soft);font-size:1.1em}
hr{border:0;border-top:1px solid var(--rule);margin:2em 0}
::selection{background:var(--gold-soft);color:var(--ink)}

/* ---------- Header ---------- */
.site-header{
  background:var(--paper);
  border-bottom:1px double var(--rule);
  position:relative;
}
.site-header::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:3px;background:linear-gradient(90deg,transparent,var(--gold) 30%,var(--gold) 70%,transparent)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;max-width:1180px;margin:0 auto;padding:18px 24px}
.site-branding .site-title{margin:0;font-family:'Cormorant Garamond',serif;font-weight:700;font-size:1.7rem;letter-spacing:.02em}
.site-branding .site-title a{color:var(--ink);border:none}
.site-description{margin:.1em 0 0;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);font-family:'IBM Plex Mono',monospace}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:6px;flex-wrap:wrap}
.main-nav a{display:inline-block;padding:8px 14px;color:var(--ink);font-size:1.02rem;border:none;border-bottom:2px solid transparent;font-family:'Cormorant Garamond',serif;font-weight:600}
.main-nav a:hover,.main-nav .current-menu-item > a{color:var(--burgundy);border-bottom-color:var(--burgundy)}
.menu-toggle{display:none;background:transparent;border:1px solid var(--ink);color:var(--ink);padding:8px 14px;font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;border-radius:0}

@media (max-width:860px){
  .menu-toggle{display:inline-block}
  .main-nav{display:none;flex-basis:100%;margin-top:14px}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:0;border-top:1px solid var(--rule)}
  .main-nav a{display:block;padding:12px 4px;border-bottom:1px solid var(--rule)}
  .header-inner{flex-wrap:wrap}
}

/* ---------- Layout ---------- */
.site-main{padding:42px 0 64px}
.content-grid{display:grid;grid-template-columns:1fr 320px;gap:48px;max-width:1180px;margin:0 auto;padding:0 24px}
@media (max-width:980px){.content-grid{grid-template-columns:1fr}}

/* ---------- Cards / Posts ---------- */
.post-card{background:var(--cream-card);border:1px solid var(--rule);padding:0;margin-bottom:32px;box-shadow:var(--shadow);position:relative}
.post-card::before{content:"";position:absolute;top:8px;left:8px;right:8px;bottom:8px;border:1px solid rgba(180,138,58,.4);pointer-events:none}
.post-card .thumb{display:block;border:none;margin:0}
.post-card img{width:100%;aspect-ratio:16/10;object-fit:cover;filter:saturate(.92)}
.post-card .post-body{padding:26px 30px 28px}
.post-meta{font-family:'IBM Plex Mono',monospace;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px}
.post-card h2{font-size:1.7rem;margin:.1em 0 .4em}
.post-card h2 a{color:var(--ink);border:none}
.post-card h2 a:hover{color:var(--burgundy)}
.read-more{display:inline-block;margin-top:8px;font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--burgundy);border:none;padding-bottom:2px;border-bottom:1px solid var(--burgundy)}

.single-post-content,.page-content{background:var(--cream-card);padding:48px clamp(24px,5vw,64px);border:1px solid var(--rule);box-shadow:var(--shadow);position:relative}
.single-post-content::before,.page-content::before{content:"";position:absolute;top:10px;left:10px;right:10px;bottom:10px;border:1px solid rgba(180,138,58,.35);pointer-events:none}
.single-post-content h1,.page-content h1{font-size:clamp(2rem,4.4vw,3.2rem);text-align:center;margin-top:.2em}
.single-post-content h1::after,.page-content h1::after{content:"";display:block;width:80px;height:2px;background:var(--gold);margin:.4em auto 0}
.featured-image{margin:24px 0}
.featured-image img{width:100%;border:1px solid var(--rule)}

/* ---------- Sidebar ---------- */
.sidebar .widget{background:var(--cream-card);border:1px solid var(--rule);padding:22px 24px;margin-bottom:24px;box-shadow:var(--shadow)}
.sidebar .widget-title{font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--burgundy);margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid var(--rule)}
.sidebar ul{padding-left:0;list-style:none;margin:0}
.sidebar li{padding:6px 0;border-bottom:1px dotted var(--rule)}
.sidebar li:last-child{border-bottom:none}
.fact-widget{background:var(--burgundy);color:var(--paper)}
.fact-widget .widget-title{color:var(--gold-soft);border-bottom-color:rgba(255,255,255,.2)}
.fact-widget a{color:var(--gold-soft)}

/* ---------- Footer ---------- */
.site-footer{margin-top:60px;background:var(--ink);color:var(--paper);position:relative}
.site-footer::before{content:"";display:block;height:4px;background:linear-gradient(90deg,var(--burgundy),var(--gold),var(--burgundy))}
.footer-grid{max-width:1180px;margin:0 auto;padding:48px 24px 28px;display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr}}
.footer-col h3{color:var(--gold-soft);font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;margin:0 0 12px}
.footer-col,.footer-col p{color:#d6c9b3}
.footer-col a{color:var(--gold-soft);border-bottom-color:rgba(216,182,106,.3)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:18px 0;font-family:'IBM Plex Mono',monospace;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;text-align:center;color:#b8a78c}
.footer-bottom a{color:var(--gold-soft);margin:0 4px}

/* ---------- Buttons ---------- */
.az-btn{display:inline-block;padding:13px 26px;font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;border:1.5px solid var(--burgundy);color:var(--paper);background:var(--burgundy);border-radius:0;transition:all .2s;cursor:pointer}
.az-btn:hover{background:var(--burgundy-deep);border-color:var(--burgundy-deep);color:var(--paper)}
.az-btn-outline{background:transparent;color:var(--burgundy)}
.az-btn-outline:hover{background:var(--burgundy);color:var(--paper)}
.az-btn-gold{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.az-btn-gold:hover{background:var(--gold-soft);border-color:var(--gold-soft);color:var(--ink)}

/* ---------- Landing Page ---------- */
.az-hero{padding:60px 0 30px;position:relative}
.az-hero::before{content:"AUGUST ZIRNER";position:absolute;top:8px;left:0;right:0;text-align:center;font-family:'IBM Plex Mono',monospace;letter-spacing:.5em;font-size:.72rem;color:var(--ink-soft);opacity:.55}
.az-hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center;max-width:1180px;margin:0 auto;padding:0 24px}
@media (max-width:860px){.az-hero-grid{grid-template-columns:1fr;gap:36px}}
.az-hero-text .eyebrow{display:inline-block;margin-bottom:18px;padding:6px 14px;border:1px solid var(--burgundy);color:var(--burgundy)}
.az-hero h1{font-size:clamp(2.6rem,5.4vw,4.4rem);font-weight:600}
.az-hero h1 em{font-style:italic;color:var(--burgundy);font-weight:600}
.az-lead{font-size:1.18rem;color:var(--ink-soft);margin:18px 0 28px}
.az-hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px}
.az-hero-points{list-style:none;padding:0;margin:0;border-top:1px solid var(--rule);padding-top:18px}
.az-hero-points li{padding:8px 0;font-size:1.05rem;display:flex;gap:12px;align-items:flex-start}
.az-hero-points li::before{content:"✦";color:var(--gold);flex:0 0 auto;font-size:1rem;margin-top:.25em}

.az-portrait{position:relative;padding:18px;background:var(--cream-card);border:1px solid var(--rule);box-shadow:var(--shadow)}
.az-portrait::before{content:"";position:absolute;top:6px;left:6px;right:6px;bottom:6px;border:1px solid var(--gold);pointer-events:none}
.az-portrait img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:sepia(.1) saturate(.95)}
.az-portrait-cap{margin-top:14px;text-align:center;font-family:'IBM Plex Mono',monospace;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}
.az-portrait-cap strong{color:var(--burgundy);font-weight:600}

/* Stage strip / playbill stats */
.az-strip{background:var(--ink);color:var(--paper);padding:34px 0;margin-top:30px;position:relative}
.az-strip::before,.az-strip::after{content:"";position:absolute;left:0;right:0;height:6px;background:repeating-linear-gradient(90deg,var(--gold) 0 14px,transparent 14px 22px)}
.az-strip::before{top:0}.az-strip::after{bottom:0}
.az-strip-grid{max-width:1180px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:repeat(4,1fr);gap:28px;text-align:center}
@media (max-width:760px){.az-strip-grid{grid-template-columns:repeat(2,1fr)}}
.az-stat-num{display:block;font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:700;color:var(--gold-soft)}
.az-stat-lbl{display:block;font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#b8a78c;margin-top:6px}

.az-section{padding:64px 0}
.az-section-head{text-align:center;max-width:760px;margin:0 auto 40px}
.az-section-head .eyebrow{display:inline-block;margin-bottom:10px}
.az-section-head h2{margin:0 0 .2em}
.az-section-head h2::after{content:"";display:block;width:64px;height:2px;background:var(--gold);margin:.45em auto 0}
.az-section-sub{color:var(--ink-soft);font-size:1.1rem}

/* Roles / Acts grid */
.az-acts{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media (max-width:860px){.az-acts{grid-template-columns:1fr}}
.az-act{background:var(--cream-card);border:1px solid var(--rule);padding:28px 26px;position:relative;box-shadow:var(--shadow)}
.az-act-num{position:absolute;top:-14px;left:24px;background:var(--paper);padding:0 10px;font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.22em;color:var(--burgundy)}
.az-act h3{font-size:1.4rem;margin:.2em 0 .4em}
.az-act p{color:var(--ink-soft);margin:0}

/* Quote band */
.az-quote{background:var(--burgundy);color:var(--paper);padding:80px 24px;text-align:center;position:relative;background-image:linear-gradient(180deg,var(--burgundy) 0%,var(--burgundy-deep) 100%)}
.az-quote::before{content:"„";font-family:'Cormorant Garamond',serif;font-size:9rem;line-height:.6;color:var(--gold-soft);opacity:.45;position:absolute;top:30px;left:50%;transform:translateX(-50%)}
.az-quote blockquote{border:none;background:none;font-family:'Cormorant Garamond',serif;font-size:clamp(1.4rem,2.6vw,2rem);font-style:italic;max-width:820px;margin:30px auto 18px;color:var(--paper);padding:0}
.az-quote cite{font-style:normal;font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft)}

/* Articles grid */
.az-posts{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media (max-width:860px){.az-posts{grid-template-columns:1fr}}
.az-post{background:var(--cream-card);border:1px solid var(--rule);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.az-post .az-thumb{display:block;border:none}
.az-post img{aspect-ratio:4/3;object-fit:cover;width:100%}
.az-post .az-body{padding:22px 24px 26px;flex:1;display:flex;flex-direction:column}
.az-post h3{font-size:1.45rem;margin:.3em 0 .4em;line-height:1.2}
.az-post h3 a{color:var(--ink);border:none}
.az-post h3 a:hover{color:var(--burgundy)}
.az-post p{color:var(--ink-soft);font-size:1rem;margin:0 0 14px;flex:1}

/* FAQ as classical playbill cards */
.az-faq{max-width:820px;margin:0 auto;display:grid;gap:14px}
.az-faq details{background:var(--cream-card);border:1px solid var(--rule);padding:18px 24px;box-shadow:var(--shadow)}
.az-faq summary{cursor:pointer;font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.2rem;list-style:none;display:flex;justify-content:space-between;gap:14px;color:var(--ink)}
.az-faq summary::after{content:"+";color:var(--burgundy);font-size:1.4rem;line-height:1}
.az-faq details[open] summary::after{content:"–"}
.az-faq details p{margin:14px 0 0;color:var(--ink-soft)}

/* CTA */
.az-cta{background:var(--paper-2);padding:70px 24px;text-align:center;border-top:1px double var(--rule);border-bottom:1px double var(--rule)}
.az-cta h2{margin:0 0 .3em}
.az-cta p{max-width:640px;margin:0 auto 24px;color:var(--ink-soft);font-size:1.1rem}

/* Pagination */
.pagination{margin-top:32px;text-align:center}
.pagination .nav-links{display:inline-flex;gap:8px;flex-wrap:wrap}
.pagination a,.pagination span{padding:8px 14px;border:1px solid var(--rule);font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.18em;color:var(--ink);background:var(--cream-card)}
.pagination .current{background:var(--burgundy);color:var(--paper);border-color:var(--burgundy)}

/* Forms */
input[type=text],input[type=email],input[type=search],input[type=url],textarea{width:100%;padding:11px 14px;background:var(--paper);border:1px solid var(--rule);font-family:inherit;font-size:1rem;color:var(--ink);border-radius:0}
input:focus,textarea:focus{outline:none;border-color:var(--burgundy)}
.searchform{display:flex;gap:8px}
.searchform input[type=submit],button[type=submit]{padding:10px 18px;background:var(--burgundy);color:var(--paper);border:none;font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer}

/* Accessibility */
.screen-reader-text{position:absolute;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}
.screen-reader-text:focus{clip:auto;background:var(--gold);color:var(--ink);padding:8px 14px;left:10px;top:10px;z-index:9999}
