/* =========================================================
   Verkaufsoffener Sonntag Bayern — stylesheet v2
   Date-first layout · Bavarian blue brand · warm market gold
   ========================================================= */

:root{
  --paper:        #f5f7fb;
  --surface:      #ffffff;
  --ink:          #15202e;
  --ink-soft:     #3f4d5e;
  --muted:        #64718a;
  --blue:         #1b4d8f;
  --blue-mid:     #2f6fb3;
  --blue-deep:    #112a4a;
  --blue-tint:    #e9f0fa;
  --blue-line:    #cfdcef;
  --gold:         #c9912f;
  --gold-soft:    #fbf2dc;
  --gold-line:    #ecd9a8;
  --good:         #1d7a4d;
  --line:         #e2e8f1;
  --line-2:       #cdd6e3;
  --radius:       16px;
  --radius-sm:    10px;
  --maxw:         1140px;
  --shadow-sm:    0 1px 2px rgba(17,42,74,.06);
  --shadow:       0 4px 14px rgba(17,42,74,.08), 0 1px 3px rgba(17,42,74,.06);
  --shadow-lg:    0 18px 50px rgba(17,42,74,.16);
  --serif:  "Fraunces", Georgia, serif;
  --sans:   "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono:   "IBM Plex Mono", ui-monospace, monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  line-height:1.68;font-size:17.5px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{color:var(--blue-mid)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.skip{position:absolute;left:-9999px}
.skip:focus{position:fixed;left:16px;top:16px;background:#fff;padding:10px 16px;border-radius:8px;z-index:99;box-shadow:var(--shadow)}

/* ---------- Header (sticky) ---------- */
.site-head{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--line)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding-top:13px;padding-bottom:13px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px}
.brand:hover{color:inherit}
.brand .mark{width:40px;height:40px;flex:none;border-radius:10px;background:var(--blue);
  position:relative;overflow:hidden;box-shadow:0 2px 8px rgba(27,77,143,.35)}
.brand .mark::before{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(135deg,var(--blue) 0 9px,#fff 9px 18px);opacity:.95}
.brand .mark::after{content:"So";position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--serif);font-weight:600;color:#fff;font-size:16px;text-shadow:0 1px 3px rgba(17,42,74,.6)}
.brand .name{font-family:var(--serif);font-weight:600;font-size:1.18rem;color:var(--ink);line-height:1.04}
.brand .name small{display:block;font-family:var(--sans);font-size:.6rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold);font-weight:700;margin-top:3px}
.nav{display:flex;gap:3px;flex-wrap:wrap}
.nav a{font-size:.84rem;font-weight:600;color:var(--ink-soft);padding:8px 11px;border-radius:8px}
.nav a:hover{background:var(--blue-tint);color:var(--blue)}
.nav a.active{color:var(--blue);background:var(--blue-tint)}

/* ---------- Hero band (homepage) ---------- */
.hero{position:relative;background:linear-gradient(160deg,#1b4d8f 0%,#163f76 55%,#112a4a 100%);
  color:#eaf1fb;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;opacity:.10;
  background:repeating-linear-gradient(135deg,#fff 0 26px,transparent 26px 52px);pointer-events:none}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,145,47,.35),transparent 70%);pointer-events:none}
.hero .wrap{position:relative;padding-top:54px;padding-bottom:118px}
.hero .eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:#ffd98a;font-weight:600;margin:0 0 16px}
.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.3rem,5.4vw,3.6rem);line-height:1.04;
  margin:0 0 16px;color:#fff;max-width:17ch;letter-spacing:-.015em}
.hero .lead{font-size:1.13rem;color:#cfdcef;max-width:54ch;margin:0}

/* ---------- "Nächste Termine" floating card ---------- */
.termine-card{position:relative;margin-top:-86px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:8px 8px 14px;z-index:5}
.termine-card .tc-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  padding:16px 18px 12px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.termine-card .tc-head h2{font-family:var(--serif);font-weight:600;font-size:1.25rem;margin:0;color:var(--ink)}
.termine-card .tc-head .hint{font-family:var(--mono);font-size:.72rem;color:var(--muted)}
.termine-row{display:grid;grid-template-columns:64px 1fr auto;gap:16px;align-items:center;
  padding:14px 18px;border-bottom:1px solid var(--line)}
.termine-row:last-child{border-bottom:0}
.termine-row:hover{background:var(--blue-tint)}
.date-badge{width:64px;text-align:center;border-radius:12px;overflow:hidden;border:1px solid var(--blue-line);
  font-family:var(--mono);line-height:1;box-shadow:var(--shadow-sm)}
.date-badge .d{display:block;background:var(--blue);color:#fff;font-size:1.32rem;font-weight:600;padding:7px 0 6px}
.date-badge .m{display:block;background:#fff;color:var(--blue);font-size:.62rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;padding:5px 0}
.termine-row .tr-main{min-width:0}
.termine-row .tr-city{font-weight:700;font-size:1.02rem;color:var(--ink)}
.termine-row .tr-city a{color:inherit}
.termine-row .tr-city a:hover{color:var(--blue)}
.termine-row .tr-occ{font-size:.86rem;color:var(--muted)}
.termine-row .tr-hours{font-family:var(--mono);font-size:.84rem;color:var(--ink-soft);white-space:nowrap;
  background:var(--gold-soft);border:1px solid var(--gold-line);border-radius:999px;padding:5px 11px}
.tc-foot{padding:12px 18px 4px;font-size:.82rem;color:var(--muted)}

/* ---------- City quick-pick chips ---------- */
.chips{display:flex;gap:9px;flex-wrap:wrap;margin:26px 0 4px}
.chips .chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface);
  border:1px solid var(--line-2);border-radius:999px;padding:9px 16px;font-size:.9rem;font-weight:600;
  color:var(--ink-soft);box-shadow:var(--shadow-sm);transition:transform .12s,border-color .12s,color .12s}
.chips .chip:hover{transform:translateY(-2px);border-color:var(--blue);color:var(--blue)}
.chips .chip .dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}

/* ---------- Layout grid ---------- */
.layout{display:grid;grid-template-columns:minmax(0,1fr) 318px;gap:48px;padding:46px 0 8px}
@media(max-width:900px){.layout{grid-template-columns:1fr;gap:36px;padding:34px 0 4px}}

/* ---------- Article typography ---------- */
.article h2{font-family:var(--serif);font-weight:600;font-size:clamp(1.55rem,3vw,2.05rem);line-height:1.14;
  margin:2.3em 0 .5em;color:var(--blue-deep);letter-spacing:-.01em}
.article h2:first-child{margin-top:.2em}
.article h3{font-size:1.16rem;font-weight:700;margin:1.8em 0 .4em;color:var(--ink)}
.article p{margin:0 0 1.15em}
.article ul,.article ol{margin:0 0 1.3em;padding-left:1.25em}
.article li{margin:.42em 0}
.article strong{color:var(--ink);font-weight:700}
.article a{font-weight:600;text-decoration:underline;text-decoration-color:var(--blue-line);text-underline-offset:3px}
.article a:hover{text-decoration-color:var(--blue)}
.lead-in::first-letter{font-family:var(--serif);font-weight:600;font-size:3.3em;float:left;line-height:.76;
  padding:.06em .12em 0 0;color:var(--blue)}

/* ---------- Glance box ---------- */
.glance{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--gold);
  border-radius:var(--radius);padding:22px 24px;margin:28px 0;box-shadow:var(--shadow)}
.glance .label{font-family:var(--mono);font-size:.69rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);font-weight:600;margin:0 0 14px}
.glance dl{display:grid;grid-template-columns:auto 1fr;gap:10px 18px;margin:0}
.glance dt{font-family:var(--mono);font-size:.79rem;color:var(--muted);white-space:nowrap;padding-top:2px}
.glance dd{margin:0;font-size:.95rem;color:var(--ink);font-weight:500}

/* ---------- Termine table (city pages + overview) ---------- */
.termine-table{width:100%;border-collapse:collapse;margin:24px 0;font-size:.95rem;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.termine-table caption{caption-side:top;text-align:left;font-family:var(--mono);font-size:.69rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;margin:0 0 10px}
.termine-table th{background:var(--blue-deep);color:#dbe6f5;text-align:left;font-size:.72rem;
  letter-spacing:.08em;text-transform:uppercase;font-weight:600;padding:12px 16px}
.termine-table td{padding:13px 16px;border-top:1px solid var(--line);vertical-align:top}
.termine-table tr:hover td{background:var(--blue-tint)}
.termine-table .t-date{font-family:var(--mono);font-weight:600;color:var(--blue);white-space:nowrap}
.termine-table .t-hours{font-family:var(--mono);color:var(--ink-soft);white-space:nowrap}
.tt-wrap{overflow-x:auto}

/* ---------- Timetable strip ---------- */
.timetable{font-family:var(--mono);background:var(--blue-deep);color:#eaf1fb;border-radius:var(--radius);
  padding:20px 22px;margin:26px 0;font-size:.88rem;box-shadow:var(--shadow)}
.timetable .t-cap{font-size:.67rem;letter-spacing:.16em;text-transform:uppercase;color:#9fb6d6;margin:0 0 8px}
.timetable .t-row{display:flex;justify-content:space-between;gap:16px;padding:9px 0;
  border-bottom:1px dashed rgba(255,255,255,.16)}
.timetable .t-row:last-child{border-bottom:0}
.timetable .t-row span:last-child{color:#ffd98a;white-space:nowrap}

/* ---------- Note ---------- */
.note{background:var(--gold-soft);border:1px solid var(--gold-line);border-radius:var(--radius);
  padding:16px 20px;margin:24px 0;font-size:.94rem;color:#6b531f}
.note strong{color:#5a4416}

/* ---------- Sidebar ---------- */
.aside{display:flex;flex-direction:column;gap:24px}
.aside .box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow)}
.aside .box h4{margin:0 0 14px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);font-family:var(--mono);font-weight:600}
.aside ul{list-style:none;margin:0;padding:0}
.aside .post-link{display:block;padding:11px 0;border-bottom:1px solid var(--line)}
.aside .post-link:last-child{border-bottom:0}
.aside .post-link a{font-weight:600;color:var(--ink);font-size:.97rem;line-height:1.3}
.aside .post-link a:hover{color:var(--blue)}
.aside .post-link span{display:block;font-family:var(--mono);font-size:.69rem;color:var(--muted);margin-top:3px}
.aside .cta{background:linear-gradient(160deg,#1b4d8f,#112a4a);color:#eaf1fb;border:0}
.aside .cta h4{color:#ffd98a}
.aside .cta p{margin:0 0 14px;font-size:.9rem;color:#cfdcef}
.aside .cta a{display:inline-block;background:#ffd98a;color:#3a2c08;font-weight:700;font-size:.86rem;
  padding:9px 16px;border-radius:999px}
.aside .cta a:hover{background:#fff}
@media(max-width:900px){.aside{order:2}}

/* ---------- Post grid ---------- */
.posts{padding:14px 0 64px}
.posts .wrap{padding-top:40px;border-top:1px solid var(--line)}
.posts h2{font-family:var(--serif);font-weight:600;font-size:1.85rem;margin:0 0 6px;color:var(--ink)}
.posts .sub{color:var(--muted);margin:0 0 28px;font-size:.96rem}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:820px){.grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.grid{grid-template-columns:1fr}}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;
  display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-sm);
  transition:transform .15s,box-shadow .15s,border-color .15s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-2)}
.card .tag{font-family:var(--mono);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);font-weight:600}
.card h3{font-family:var(--serif);font-weight:600;font-size:1.28rem;line-height:1.16;margin:0;color:var(--ink)}
.card h3 a{color:inherit}
.card h3 a:hover{color:var(--blue)}
.card p{margin:0;font-size:.92rem;color:var(--ink-soft);line-height:1.55}
.card .more{margin-top:auto;font-size:.84rem;font-weight:700;color:var(--blue)}

/* ---------- Post page header ---------- */
.post-head{background:linear-gradient(160deg,#1b4d8f,#142f55);color:#eaf1fb;position:relative;overflow:hidden}
.post-head::before{content:"";position:absolute;inset:0;opacity:.09;
  background:repeating-linear-gradient(135deg,#fff 0 24px,transparent 24px 48px)}
.post-head .wrap{position:relative;padding-top:40px;padding-bottom:42px;max-width:860px}
.crumbs{font-family:var(--mono);font-size:.74rem;color:#a9bcd8;margin:0 0 16px}
.crumbs a{color:#cfdcef}
.crumbs a:hover{color:#fff}
.post-head h1{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,4.4vw,2.9rem);line-height:1.08;
  margin:0 0 14px;color:#fff;letter-spacing:-.015em}
.post-head .lead{font-size:1.1rem;color:#cfdcef;margin:0;max-width:62ch}
.post-meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:20px;font-family:var(--mono);font-size:.75rem;color:#9fb6d6}
.post-meta b{color:#eaf1fb;font-weight:600}
.post-body{max-width:780px;margin:0 auto;padding:44px 22px 56px}

/* related */
.related{max-width:780px;margin:0 auto 60px;padding:0 22px}
.related h4{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);margin:0 0 16px}
.related .grid{grid-template-columns:1fr 1fr}
@media(max-width:560px){.related .grid{grid-template-columns:1fr}}

/* ---------- Disclosure ---------- */
.disclosure{background:var(--blue-tint);border-top:1px solid var(--line)}
.disclosure .wrap{padding:16px 22px;font-size:.81rem;color:var(--ink-soft);text-align:center}

/* ---------- Footer ---------- */
.site-foot{background:var(--blue-deep);color:#cdd9ec}
.site-foot .wrap{padding:46px 22px 32px;display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px}
@media(max-width:720px){.site-foot .wrap{grid-template-columns:1fr;gap:26px}}
.site-foot .f-brand .name{font-family:var(--serif);font-weight:600;font-size:1.28rem;color:#fff;margin:0 0 8px}
.site-foot p{margin:0 0 8px;font-size:.87rem;line-height:1.6;color:#a9bcd8}
.site-foot h5{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:#7f97bd;margin:0 0 13px;
  font-family:var(--mono);font-weight:600}
.site-foot ul{list-style:none;margin:0;padding:0}
.site-foot li{margin:0 0 9px}
.site-foot a{color:#cdd9ec;font-size:.89rem}
.site-foot a:hover{color:#fff}
.foot-base{border-top:1px solid rgba(255,255,255,.12)}
.foot-base .wrap{padding:16px 22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  font-size:.79rem;color:#8ea4c6;font-family:var(--mono)}

/* ---------- Prose (legal) ---------- */
.prose{max-width:780px;margin:0 auto;padding:44px 22px 60px}
.prose h1{font-family:var(--serif);font-weight:600;font-size:2.1rem;margin:0 0 22px;color:var(--ink)}
.prose h2{font-size:1.2rem;font-weight:700;margin:1.8em 0 .5em;color:var(--blue-deep)}
.prose p,.prose ul{color:var(--ink-soft);font-size:.96rem}
.prose .ph{background:var(--gold-soft);border:1px dashed var(--gold-line);border-radius:6px;
  padding:1px 7px;font-family:var(--mono);font-size:.82rem;color:#7a5d1c}

:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:4px}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}
