/* =====================================================================
   PrXenon Events - Widgets v2 Stylesheet
   Eigenstaendiges Design-System, unabhaengig von v1 (frontend.css).
   Jedes Widget hat eine klar unterscheidbare visuelle Sprache,
   nutzt aber gemeinsame CSS-Variablen fuer Konsistenz + volle
   Steuerung durch Elementor (Farben/Typo/Background/Border/Shadow
   werden direkt per Selector aus den Widget-Controls injiziert).
   ===================================================================== */

:root{
  --pepv2-accent: var(--pep-accent, #023B59);
  --pepv2-accent2: var(--pep-accent2, #009591);
  --pepv2-ink: var(--pep-ink, #11202b);
  --pepv2-muted: var(--pep-muted, #5c6f78);
  --pepv2-surface: #ffffff;
  --pepv2-radius: 20px;
}

.pepv2-empty{padding:26px;border-radius:18px;background:color-mix(in srgb,var(--pepv2-accent) 8%,white);color:var(--pepv2-muted);font-weight:600}
.pepv2-mosaic-fallback{display:block;width:100%;height:100%;background:linear-gradient(135deg,var(--pepv2-accent),var(--pepv2-accent2))}

/* shared small atoms reused across widgets */
.pepv2-date-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);color:var(--pepv2-ink);font-weight:800;font-size:13px;padding:7px 12px;border-radius:999px}
.pepv2-date-pill em{font-weight:700;opacity:.7}
.pepv2-date-split{display:inline-flex;flex-direction:column;align-items:center;background:rgba(255,255,255,.95);border-radius:14px;padding:8px 12px;line-height:1;color:var(--pepv2-ink)}
.pepv2-date-split b{font-size:19px}
.pepv2-date-split small{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--pepv2-muted)}
.pepv2-date-cal{display:inline-flex;flex-direction:column;align-items:center;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 8px 22px rgba(0,0,0,.12)}
.pepv2-date-cal small{background:var(--pepv2-cat-color,var(--pepv2-accent));color:#fff;font-size:10px;text-transform:uppercase;padding:3px 10px;letter-spacing:.06em}
.pepv2-date-cal b{font-size:18px;padding:2px 10px 0}
.pepv2-date-cal em{font-size:10px;padding:0 10px 5px;color:var(--pepv2-muted)}
.pepv2-date-plain{font-size:13px;font-weight:800;color:var(--pepv2-muted)}
.pepv2-tags{display:flex;gap:6px;flex-wrap:wrap}
.pepv2-tag{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:5px 9px;border-radius:999px;background:color-mix(in srgb,var(--pepv2-accent) 12%,#fff);color:var(--pepv2-accent)}
.pepv2-tag-paid{background:color-mix(in srgb,#c0392b 14%,#fff);color:#c0392b}
.pepv2-tag-online{background:color-mix(in srgb,var(--pepv2-accent2) 16%,#fff);color:var(--pepv2-accent2)}

/* =====================================================================
   1) MOSAIC GRID
   ===================================================================== */
.pepv2-mosaic{display:grid;grid-template-columns:repeat(var(--pepv2-cols,3),minmax(0,1fr));gap:22px;margin:0}
.pepv2-mosaic-card{position:relative;border-radius:var(--pepv2-radius);overflow:hidden;background:#fff;box-shadow:0 14px 40px rgba(10,30,40,.10);border:1px solid rgba(10,30,40,.06);transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s ease}
.pepv2-mosaic-card.is-feature{grid-column:span 2;grid-row:span 2}
.pepv2-mosaic-link{display:block;color:inherit;text-decoration:none;height:100%}
.pepv2-mosaic-card.fx-lift:hover{transform:translateY(-6px);box-shadow:0 26px 60px rgba(10,30,40,.18)}
.pepv2-mosaic-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:linear-gradient(135deg,var(--pepv2-cat-color,var(--pepv2-accent)),var(--pepv2-accent2))}
.pepv2-mosaic-card.is-feature .pepv2-mosaic-media{aspect-ratio:16/9}
.pepv2-mosaic-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.pepv2-mosaic-card.fx-zoom:hover .pepv2-mosaic-media img{transform:scale(1.08)}
.pepv2-mosaic-card.fx-tilt:hover .pepv2-mosaic-media img{transform:scale(1.04) rotate(-1deg)}
.pepv2-mosaic-media:after{content:"";position:absolute;inset:auto 0 0 0;height:55%;background:linear-gradient(transparent,rgba(0,0,0,.5))}
.pepv2-mosaic-date{position:absolute;top:12px;left:12px;z-index:2}
.pepv2-mosaic-body{padding:20px 22px}
.pepv2-mosaic .pepv2-mosaic-cat{display:inline-block;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.07em;color:var(--pepv2-cat-color,var(--pepv2-accent));margin-bottom:8px}
.pepv2-mosaic .pepv2-mosaic-title{margin:0 0 8px;font-size:clamp(18px,1.6vw,24px);line-height:1.18;color:var(--pepv2-ink)}
.pepv2-mosaic-card.is-feature .pepv2-mosaic-title{font-size:clamp(24px,3vw,36px)}
.pepv2-mosaic .pepv2-mosaic-text{margin:0 0 14px;color:var(--pepv2-muted);line-height:1.55;font-size:14.5px}
.pepv2-mosaic-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.pepv2-mosaic-meta span{font-size:12.5px;font-weight:700;color:var(--pepv2-muted);background:color-mix(in srgb,var(--pepv2-accent) 7%,#fff);padding:5px 10px;border-radius:999px}
.pepv2-mosaic-cta{display:inline-flex;align-items:center;gap:6px;font-weight:800;color:var(--pepv2-accent);font-size:14px}
.pepv2-mosaic-cta i{transition:transform .2s ease}
.pepv2-mosaic-card:hover .pepv2-mosaic-cta i{transform:translateX(4px)}
.pepv2-mosaic-card.pos-overlay .pepv2-mosaic-media{aspect-ratio:auto;position:absolute;inset:0}
.pepv2-mosaic-card.pos-overlay{min-height:280px}
.pepv2-mosaic-card.pos-overlay .pepv2-mosaic-body{position:relative;z-index:2;margin-top:auto;color:#fff}
.pepv2-mosaic-card.pos-overlay{display:flex;flex-direction:column}
.pepv2-mosaic-card.pos-overlay .pepv2-mosaic-title,.pepv2-mosaic-card.pos-overlay .pepv2-mosaic-text{color:#fff}
@media(max-width:980px){.pepv2-mosaic{grid-template-columns:repeat(2,1fr)}.pepv2-mosaic-card.is-feature{grid-column:span 2}}
@media(max-width:640px){.pepv2-mosaic{grid-template-columns:1fr}.pepv2-mosaic-card.is-feature{grid-column:span 1;grid-row:span 1}}

/* =====================================================================
   2) HIGHLIGHT SPOTLIGHT
   ===================================================================== */
.pepv2-spotlight{margin:0;--pepv2-list-w:34%}
.pepv2-spot-head{display:flex;flex-direction:column;gap:4px;margin-bottom:18px}
.pepv2-spot-kicker{font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:var(--pepv2-accent2)}
.pepv2-spot-head h2{margin:0;font-size:clamp(26px,3vw,40px);color:var(--pepv2-ink);letter-spacing:-.02em}
.pepv2-spot-row{display:grid;grid-template-columns:1fr var(--pepv2-list-w);gap:28px;align-items:stretch}
.pepv2-spot-feature{border-radius:var(--pepv2-radius);overflow:hidden;background:#fff;box-shadow:0 20px 60px rgba(10,30,40,.14);position:relative}
.pepv2-spot-feature a{display:block;color:inherit;text-decoration:none;height:100%}
.pepv2-spot-media{position:relative;aspect-ratio:16/9;background:linear-gradient(135deg,var(--pepv2-cat-color,var(--pepv2-accent)),var(--pepv2-accent2))}
.pepv2-spot-media img{width:100%;height:100%;object-fit:cover;display:block}
.pepv2-spot-media:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.55),transparent 55%)}
.pepv2-spot-media-overlay{position:absolute;inset:auto 16px 14px 16px;display:flex;justify-content:space-between;align-items:flex-end;z-index:2}
.pepv2-spot-cat{background:#fff;color:var(--pepv2-cat-color,var(--pepv2-accent));font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.05em;padding:6px 11px;border-radius:999px}
.pepv2-spot-body{padding:22px 26px 26px}
.pepv2-spotlight .pepv2-spot-title{margin:0 0 10px;font-size:clamp(24px,3vw,34px);line-height:1.12;color:var(--pepv2-ink)}
.pepv2-spotlight .pepv2-spot-text{color:var(--pepv2-muted);line-height:1.6;margin:0 0 14px}
.pepv2-spot-meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.pepv2-spot-meta span{font-size:13px;font-weight:700;background:color-mix(in srgb,var(--pepv2-accent) 8%,#fff);padding:6px 12px;border-radius:999px;color:var(--pepv2-ink)}
.pepv2-spot-cta{display:inline-flex;gap:6px;align-items:center;background:var(--pepv2-accent);color:#fff;font-weight:800;padding:11px 18px;border-radius:999px}
.pepv2-spot-list{display:flex;flex-direction:column;gap:10px;max-height:520px;overflow:auto}
.pepv2-spot-item{display:grid;grid-template-columns:64px 1fr;gap:12px;text-decoration:none;color:inherit;background:#fff;border-radius:16px;padding:10px;box-shadow:0 8px 22px rgba(10,30,40,.07);transition:transform .18s ease,box-shadow .18s ease}
.pepv2-spot-item:hover{transform:translateX(3px);box-shadow:0 12px 30px rgba(10,30,40,.12)}
.pepv2-spot-item-thumb{width:64px;height:64px;border-radius:12px;overflow:hidden;background:color-mix(in srgb,var(--pepv2-cat-color,var(--pepv2-accent)) 18%,#fff)}
.pepv2-spot-item-thumb img{width:100%;height:100%;object-fit:cover}
.pepv2-spot-item-body{display:flex;flex-direction:column;justify-content:center;gap:2px;min-width:0}
.pepv2-spot-item-date{font-size:11px;font-weight:800;color:var(--pepv2-cat-color,var(--pepv2-accent));text-transform:uppercase}
.pepv2-spot-item strong{font-size:14.5px;color:var(--pepv2-ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pepv2-spot-item small{font-size:12px;color:var(--pepv2-muted)}
@media(max-width:900px){.pepv2-spot-row{grid-template-columns:1fr}.pepv2-spotlight{--pepv2-list-w:100%}.pepv2-spot-list{max-height:none}}

/* =====================================================================
   3) CINEMATIC HERO SLIDER
   ===================================================================== */
.pepv2-cine{position:relative;border-radius:0;overflow:hidden;min-height:560px;background:#0c1418}
.pepv2-cine-track{position:relative;height:100%;min-height:inherit}
.pepv2-cine-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .7s ease;display:flex}
.pepv2-cine-slide.is-active{opacity:1;visibility:visible;z-index:1}
.pepv2-cine-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.02)}
.pepv2-cine.has-kenburns .pepv2-cine-slide.is-active .pepv2-cine-bg{animation:pepv2-kenburns 11s ease-in-out forwards}
@keyframes pepv2-kenburns{from{transform:scale(1.02)}to{transform:scale(1.14)}}
.pepv2-cine-slide:before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(5,15,20,.86) 0%,rgba(5,15,20,.5) 45%,rgba(5,15,20,.15) 75%);z-index:1}
.pepv2-cine-copy{position:relative;z-index:2;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;width:100%;max-width:680px;padding:60px;color:#fff;gap:12px}
.pepv2-cine .pepv2-cine-kicker{font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:var(--pepv2-accent2)}
.pepv2-cine .pepv2-cine-date{font-size:13px;font-weight:700;opacity:.85;color:#fff}
.pepv2-cine .pepv2-cine-title{margin:0;font-size:clamp(32px,5vw,64px);line-height:1.02;letter-spacing:-.02em;color:#fff}
.pepv2-cine .pepv2-cine-subtitle{margin:0;font-size:18px;opacity:.92;font-weight:600;color:#fff}
.pepv2-cine .pepv2-cine-text{margin:0;opacity:.85;line-height:1.6;max-width:520px;color:#fff}
.pepv2-cine-meta{display:flex;gap:10px;flex-wrap:wrap}
.pepv2-cine-meta span{background:rgba(255,255,255,.14);backdrop-filter:blur(6px);padding:7px 13px;border-radius:999px;font-size:13px;font-weight:700}
.pepv2-cine-btn{display:inline-flex;margin-top:6px;background:var(--pepv2-accent2);color:#fff;text-decoration:none;font-weight:800;padding:13px 22px;border-radius:999px;transition:transform .18s ease}
.pepv2-cine-btn:hover{transform:translateY(-2px)}
.pepv2-cine-arrow,.pepv2-diag-arrow,.pepv2-cine-dots button,.pepv2-diag-dots button,.pepv2-tl-filter button,.pepv2-cal-nav{appearance:none;-webkit-appearance:none;-moz-appearance:none;font-family:inherit;box-sizing:border-box;outline-offset:2px}
.pepv2-cine-arrow,.pepv2-diag-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:42px;height:42px;border-radius:50%;border:0;background:rgba(20,20,20,.32);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .2s ease,transform .2s ease}
.pepv2-cine-arrow:hover,.pepv2-diag-arrow:hover{background:rgba(20,20,20,.55);transform:translateY(-50%) scale(1.06)}
.pepv2-cine-arrow.prev,.pepv2-diag-arrow.prev{left:16px}
.pepv2-cine-arrow.next,.pepv2-diag-arrow.next{right:16px}
.pepv2-cine-dots,.pepv2-diag-dots{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:4;display:flex;gap:7px;align-items:center}
.pepv2-cine-dots button,.pepv2-diag-dots button{width:8px;height:8px;border-radius:50%;border:0;background:rgba(255,255,255,.45);cursor:pointer;padding:0;transition:width .25s ease,background .2s ease}
.pepv2-cine-dots button.is-active,.pepv2-diag-dots button.is-active{background:#fff;width:22px;border-radius:5px}
@media(max-width:760px){.pepv2-cine-copy{padding:30px 24px}.pepv2-cine-title{font-size:32px}.pepv2-cine-arrow{width:34px;height:34px;font-size:16px}}
.pepv2-cine-progress{position:absolute;left:0;bottom:0;width:100%;height:3px;background:rgba(255,255,255,.15);z-index:3}
.pepv2-cine-progress i{display:block;height:100%;width:0;background:var(--pepv2-accent2)}
@media(max-width:760px){.pepv2-cine-copy{padding:30px 24px}.pepv2-cine-title{font-size:32px}.pepv2-cine-arrow{width:36px;height:36px;font-size:18px}}

/* =====================================================================
   4) DIAGONAL SPLIT SLIDER
   ===================================================================== */
.pepv2-diag{position:relative;overflow:hidden;min-height:460px;--pepv2-panel-w:42%;--pepv2-skew:6deg}
.pepv2-diag-track{position:relative;height:100%;min-height:inherit}
.pepv2-diag-slide{position:absolute;inset:0;display:flex;opacity:0;visibility:hidden;transition:opacity .5s ease}
.pepv2-diag-slide.is-active{opacity:1;visibility:visible;z-index:1}
.pepv2-diag.side-right .pepv2-diag-slide{flex-direction:row-reverse}
.pepv2-diag-media{flex:1;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--pepv2-cat-color,var(--pepv2-accent)),var(--pepv2-accent2))}
.pepv2-diag-media img{width:100%;height:100%;object-fit:cover;display:block}
.pepv2-diag-panel{position:relative;width:var(--pepv2-panel-w);flex:0 0 var(--pepv2-panel-w);background:var(--pepv2-ink);color:#fff;display:flex;align-items:center;clip-path:polygon(calc(var(--pepv2-skew)*4) 0,100% 0,100% 100%,0 100%)}
.pepv2-diag.side-right .pepv2-diag-panel{clip-path:polygon(0 0,100% 0,calc(100% - var(--pepv2-skew)*4) 100%,0 100%)}
.pepv2-diag-panel-inner{padding:48px 44px;display:flex;flex-direction:column;gap:10px}
.pepv2-diag .pepv2-diag-cat{font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.07em;color:var(--pepv2-accent2)}
.pepv2-diag .pepv2-diag-date{font-size:13px;opacity:.85;color:#fff}
.pepv2-diag .pepv2-diag-title{margin:0;font-size:clamp(24px,3.4vw,40px);line-height:1.08;color:#fff}
.pepv2-diag .pepv2-diag-text{opacity:.85;line-height:1.6;margin:0;color:#fff}
.pepv2-diag-meta{display:flex;gap:8px;flex-wrap:wrap}
.pepv2-diag-meta span{background:rgba(255,255,255,.12);padding:6px 12px;border-radius:999px;font-size:12.5px;font-weight:700}
.pepv2-diag-btn{margin-top:8px;align-self:flex-start;background:var(--pepv2-accent2);color:#fff;text-decoration:none;font-weight:800;padding:12px 20px;border-radius:999px}
@media(max-width:820px){.pepv2-diag-slide{flex-direction:column!important}.pepv2-diag-panel{width:100%;flex:1 1 auto;clip-path:none!important;order:2}.pepv2-diag-media{order:1;min-height:200px}.pepv2-diag-panel-inner{padding:28px}.pepv2-diag-arrow{width:34px;height:34px;font-size:16px}}

/* =====================================================================
   5) MODERN CALENDAR
   ===================================================================== */
.pepv2-cal{background:var(--pepv2-surface);border-radius:var(--pepv2-radius);padding:clamp(16px,3vw,30px);box-shadow:0 18px 50px rgba(10,30,40,.10)}
.pepv2-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.pepv2-cal-head h2{margin:0;font-size:clamp(22px,2.6vw,32px);color:var(--pepv2-ink);text-transform:capitalize}
.pepv2-cal-nav{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:color-mix(in srgb,var(--pepv2-accent) 9%,#fff);color:var(--pepv2-accent);text-decoration:none;font-size:20px;font-weight:900;transition:background .2s ease}
.pepv2-cal-nav:hover{background:var(--pepv2-accent);color:#fff}
.pepv2-cal-weekdays,.pepv2-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.pepv2-cal-weekdays span{text-align:center;font-size:12px;font-weight:800;color:var(--pepv2-muted);text-transform:uppercase}
.pepv2-cal-day{min-height:112px;border-radius:14px;padding:9px;background:color-mix(in srgb,var(--pepv2-ink) 3%,#fff);border:1px solid rgba(10,30,40,.05);display:flex;flex-direction:column;gap:5px}
.pepv2-cal-day.is-empty{background:transparent;border-color:transparent}
.pepv2-cal-day.is-today{background:color-mix(in srgb,var(--pepv2-accent) 10%,#fff);border-color:var(--pepv2-accent)}
.pepv2-cal-num{font-weight:800;color:var(--pepv2-ink);font-size:13px}
.pepv2-cal-events{display:flex;flex-direction:column;gap:4px;overflow:hidden}
.pepv2-cal-event{display:flex;align-items:center;gap:5px;text-decoration:none;font-size:11.5px;font-weight:700;color:var(--pepv2-ink);background:#fff;border-radius:8px;padding:3px 6px;box-shadow:0 2px 6px rgba(10,30,40,.08);overflow:hidden}
.pepv2-cal-event span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pepv2-cal-dot{width:7px;height:7px;border-radius:50%;background:var(--pepv2-cat-color,var(--pepv2-accent));flex:0 0 auto}
.pepv2-cal-more{font-size:10.5px;color:var(--pepv2-muted);font-weight:700;padding-left:4px}
@media(max-width:760px){.pepv2-cal-weekdays{display:none}.pepv2-cal-grid{grid-template-columns:1fr}.pepv2-cal-day.is-empty{display:none}.pepv2-cal-day{min-height:auto;flex-direction:row;align-items:flex-start;gap:10px}.pepv2-cal-num{min-width:26px}}

/* =====================================================================
   6) WEEKDAY TIMELINE (regelmaessige Veranstaltungen)
   ===================================================================== */
.pepv2-tl-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.pepv2-tl-filter button{border:1px solid color-mix(in srgb,var(--pepv2-accent) 25%,transparent);background:#fff;color:var(--pepv2-accent);font-weight:800;font-size:13px;padding:8px 16px;border-radius:999px;cursor:pointer;transition:all .18s ease}
.pepv2-tl-filter button.is-active{background:var(--pepv2-accent);color:#fff;border-color:var(--pepv2-accent)}
.pepv2-tl-list{display:flex;flex-direction:column;gap:12px;position:relative;padding-left:6px}
.pepv2-tl-item{display:grid;grid-template-columns:72px 1fr auto;align-items:center;gap:16px;background:#fff;border-radius:16px;padding:16px 18px;box-shadow:0 10px 28px rgba(10,30,40,.07);border:1px solid rgba(10,30,40,.05);position:relative}
.pepv2-tl-item:before{content:"";position:absolute;left:-6px;top:50%;width:10px;height:10px;border-radius:50%;background:var(--pepv2-accent);transform:translateY(-50%)}
.pepv2-tl-when{display:flex;flex-direction:column;align-items:center;justify-content:center;background:color-mix(in srgb,var(--pepv2-accent) 9%,#fff);border-radius:12px;padding:8px 4px}
.pepv2-tl-when strong{font-size:15px;color:var(--pepv2-accent);text-transform:uppercase}
.pepv2-tl-when span{font-size:11.5px;color:var(--pepv2-muted);font-weight:700}
.pepv2-tl-title{margin:0 0 3px;font-size:16.5px;color:var(--pepv2-ink)}
.pepv2-tl-sub{margin:0 0 4px;font-size:12.5px;color:var(--pepv2-muted);font-weight:700}
.pepv2-tl-venue,.pepv2-tl-contact{display:inline-block;font-size:12px;color:var(--pepv2-muted);margin-right:10px}
.pepv2-tl-link{justify-self:end;display:inline-flex;align-items:center;gap:5px;font-weight:800;color:var(--pepv2-accent);text-decoration:none;white-space:nowrap}
.pepv2-tl-item[hidden]{display:none}
@media(max-width:680px){.pepv2-tl-item{grid-template-columns:56px 1fr;}.pepv2-tl-link{grid-column:1/-1;justify-self:start;margin-top:4px}}

/* =====================================================================
   7+8) MAGAZINE DETAIL (Event + Regelmaessig)
   ===================================================================== */
.pepv2-detail,.pepv2-regdetail{max-width:1180px;margin:0 auto;padding:clamp(20px,4vw,50px) 16px;color:var(--pepv2-ink)}
.pepv2-detail-hero,.pepv2-regdetail-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,5vw,60px);align-items:center;background:radial-gradient(circle at 90% 10%,color-mix(in srgb,var(--pepv2-accent2) 18%,transparent),transparent 38%),linear-gradient(135deg,color-mix(in srgb,var(--pepv2-accent) 9%,#fff),#fff);border-radius:calc(var(--pepv2-radius) + 12px);padding:clamp(28px,5vw,54px);box-shadow:0 22px 60px rgba(10,30,40,.10)}
.pepv2-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.pepv2-chip{background:#fff;color:var(--pepv2-cat-color,var(--pepv2-accent));font-weight:800;font-size:12px;padding:6px 12px;border-radius:999px;box-shadow:0 6px 16px rgba(10,30,40,.08)}
.pepv2-detail-hero h1{font-size:clamp(36px,5.5vw,64px);line-height:1.02;margin:.15em 0;letter-spacing:-.03em;color:var(--pepv2-accent)}
.pepv2-detail-lead{font-size:clamp(18px,2vw,24px);color:var(--pepv2-muted);margin:0 0 18px}
.pepv2-detail-facts{display:flex;gap:10px;flex-wrap:wrap}
.pepv2-detail-facts span{background:#fff;padding:11px 15px;border-radius:999px;font-weight:800;box-shadow:0 8px 20px rgba(10,30,40,.06)}
.pepv2-detail-hero-media img,.pepv2-detail-hero-media .pepv2-mosaic-fallback{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:calc(var(--pepv2-radius) + 4px);box-shadow:0 18px 50px rgba(0,0,0,.15)}
.pepv2-detail-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:30px;margin-top:32px}
.pepv2-detail-content{background:#fff;border-radius:var(--pepv2-radius);padding:clamp(22px,3vw,32px);box-shadow:0 16px 46px rgba(10,30,40,.08);font-size:1.05rem;line-height:1.75}
.pepv2-detail-side{background:#fff;border-radius:var(--pepv2-radius);padding:clamp(22px,3vw,30px);box-shadow:0 16px 46px rgba(10,30,40,.08);align-self:start;position:sticky;top:24px}
.pepv2-detail-side h2{margin:0 0 16px;font-size:30px;color:var(--pepv2-accent)}
.pepv2-info-list{display:grid;gap:10px}
.pepv2-info-row{display:grid;grid-template-columns:34px 1fr;gap:10px;background:color-mix(in srgb,var(--pepv2-accent) 5%,#fff);border-radius:14px;padding:12px 14px}
.pepv2-info-ico{font-size:18px}
.pepv2-info-row span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--pepv2-muted);font-weight:800}
.pepv2-info-row strong{display:block;margin-top:2px}
.pepv2-info-row p{margin:6px 0 0;color:var(--pepv2-muted);font-size:13.5px}
.pepv2-info-map{margin-top:14px;border-radius:14px;overflow:hidden}
.pepv2-org-box{margin-top:16px}
.pepv2-org-item{display:grid;grid-template-columns:46px 1fr;gap:10px;padding:12px 0;border-top:1px solid rgba(10,30,40,.08)}
.pepv2-org-item img{width:46px;height:46px;border-radius:11px;object-fit:contain;background:#f6f8f8}
.pepv2-org-item a{font-weight:700;margin-right:8px;font-size:13px}
.pepv2-action-stack{display:grid;gap:9px;margin-top:16px}
.pepv2-btn{display:inline-flex;justify-content:center;align-items:center;border-radius:999px;background:var(--pepv2-accent);color:#fff!important;text-decoration:none;font-weight:800;padding:13px 16px}
.pepv2-btn-alt{background:var(--pepv2-ink)}
.pepv2-kicker{display:inline-flex;border-radius:999px;padding:7px 12px;background:#fff;color:var(--pepv2-muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;box-shadow:0 8px 20px rgba(10,30,40,.06);margin-bottom:10px}
.pepv2-weekday-ring{display:flex;gap:6px;margin:10px 0}
.pepv2-weekday-ring span{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;background:#fff;color:var(--pepv2-muted);box-shadow:0 6px 14px rgba(10,30,40,.08)}
.pepv2-weekday-ring span.is-active{background:var(--pepv2-accent);color:#fff}
.pepv2-regdetail-time{font-weight:800;color:var(--pepv2-muted)}
@media(max-width:900px){.pepv2-detail-hero,.pepv2-regdetail-hero,.pepv2-detail-grid{grid-template-columns:1fr}.pepv2-detail-side{position:static}.pepv2-detail-hero,.pepv2-regdetail-hero{padding:24px}}

/* =====================================================================
   9) MAP CARD
   ===================================================================== */
.pepv2-mapcard{background:#fff;border-radius:var(--pepv2-radius);overflow:hidden;box-shadow:0 16px 44px rgba(10,30,40,.10)}
.pepv2-mapcard-head{padding:18px 20px 6px}
.pepv2-mapcard-title{display:block;font-size:17px;color:var(--pepv2-ink)}
.pepv2-mapcard-head p{margin:4px 0 0;color:var(--pepv2-muted);font-size:13px}
.pepv2-mapcard-frame{margin:14px 20px;border-radius:14px;overflow:hidden}
.pepv2-mapcard-frame .pep-map{width:100%;height:320px}
.pepv2-mapcard-route{display:flex;align-items:center;justify-content:center;gap:6px;margin:0 20px 20px;padding:12px 16px;border-radius:999px;background:var(--pepv2-accent);color:#fff;text-decoration:none;font-weight:800}

@media(max-width:760px){
  .pepv2-detail,.pepv2-regdetail{padding:14px}
}

/* =====================================================================
   v2.1 ERWEITERUNGEN
   - Datum-Größe (em-basierte Badges, skalieren mit font-size)
   - CTA-Link-Stile (arrow / pill / outline / underline)
   - Mosaik: weitere Basis-Vorlagen (Liste links, Wechsel, Magazin)
   - Status-Störer in v2-Widgets (nutzt die v1-Ribbon-Klassen)
   ===================================================================== */

/* -- Datum-Badges: em-basiert, damit "Datum Größe" alles proportional skaliert -- */
.pepv2-date{font-size:13px;line-height:1}
.pepv2-date.pepv2-date-pill{padding:.5em .9em;border-radius:999px}
.pepv2-date.pepv2-date-pill span{font-size:1em}
.pepv2-date.pepv2-date-pill em{font-size:.9em}
.pepv2-date.pepv2-date-split{padding:.55em .8em;border-radius:1em}
.pepv2-date.pepv2-date-split b{font-size:1.45em}
.pepv2-date.pepv2-date-split small{font-size:.8em}
.pepv2-date.pepv2-date-cal b{font-size:1.35em;padding:.15em .7em 0}
.pepv2-date.pepv2-date-cal small{font-size:.75em;padding:.25em .7em}
.pepv2-date.pepv2-date-cal em{font-size:.7em;padding:0 .7em .35em}
.pepv2-date.pepv2-date-plain{font-size:13px}

/* -- CTA Link-Stile (shared, geringere Spezifität als die Style-Tab-Controls) -- */
.pepv2-cta{font-size:14px}
.pepv2-cta-style-arrow{background:none!important;border:0!important;padding:0!important;color:var(--pepv2-cat-color,var(--pepv2-accent))}
.pepv2-cta-style-arrow i{transition:transform .2s ease}
.pepv2-cta-style-arrow:hover i{transform:translateX(4px)}
.pepv2-cta-style-pill{display:inline-flex;background:var(--pepv2-cat-color,var(--pepv2-accent));color:#fff;padding:.7em 1.3em;border-radius:999px;transition:filter .18s ease,transform .18s ease}
.pepv2-cta-style-pill:hover{filter:brightness(1.1);transform:translateY(-1px)}
.pepv2-cta-style-pill i{display:none}
.pepv2-cta-style-outline{display:inline-flex;border:2px solid var(--pepv2-cat-color,var(--pepv2-accent));color:var(--pepv2-cat-color,var(--pepv2-accent));background:transparent;padding:.6em 1.2em;border-radius:999px;transition:all .18s ease}
.pepv2-cta-style-outline:hover{background:var(--pepv2-cat-color,var(--pepv2-accent));color:#fff}
.pepv2-cta-style-outline i{display:none}
.pepv2-cta-style-underline{display:inline-flex;padding:0 0 .15em;border-bottom:2px solid currentColor;color:var(--pepv2-cat-color,var(--pepv2-accent));border-radius:0}
.pepv2-cta-style-underline i{display:none}
.pepv2-cta-style-underline:hover{opacity:.7}
/* Auf dunklem Slider-Untergrund (Cine/Diagonal) bleiben Pill/Outline weiß-neutral lesbar */
.pepv2-cine-copy .pepv2-cta-style-outline,.pepv2-diag-panel .pepv2-cta-style-outline{border-color:rgba(255,255,255,.7);color:#fff}
.pepv2-cine-copy .pepv2-cta-style-outline:hover,.pepv2-diag-panel .pepv2-cta-style-outline:hover{background:#fff;color:var(--pepv2-ink)}
.pepv2-cine-copy .pepv2-cta-style-arrow,.pepv2-diag-panel .pepv2-cta-style-arrow,.pepv2-cine-copy .pepv2-cta-style-underline,.pepv2-diag-panel .pepv2-cta-style-underline{color:#fff}

/* -- Mosaik: zusätzliche Basis-Vorlagen -- */
.pepv2-mosaic.mode-grid .pepv2-mosaic-card.is-feature{grid-column:auto;grid-row:auto}
.pepv2-mosaic.mode-list_left,.pepv2-mosaic.mode-list_alternate,.pepv2-mosaic.mode-magazine{grid-template-columns:1fr!important}
.pepv2-mosaic.mode-list_left .pepv2-mosaic-link,.pepv2-mosaic.mode-list_alternate .pepv2-mosaic-link{display:flex;align-items:stretch}
.pepv2-mosaic.mode-list_left .pepv2-mosaic-media,.pepv2-mosaic.mode-list_alternate .pepv2-mosaic-media{flex:0 0 320px;aspect-ratio:auto!important}
.pepv2-mosaic.mode-list_left .pepv2-mosaic-body,.pepv2-mosaic.mode-list_alternate .pepv2-mosaic-body{flex:1;display:flex;flex-direction:column;justify-content:center}
.pepv2-mosaic.mode-list_alternate .pepv2-mosaic-card:nth-child(even) .pepv2-mosaic-link{flex-direction:row-reverse}
.pepv2-mosaic.mode-magazine .pepv2-mosaic-card{background:transparent;border:0;box-shadow:none;border-bottom:1px solid rgba(10,30,40,.1);border-radius:0;padding-bottom:8px}
.pepv2-mosaic.mode-magazine .pepv2-mosaic-card:last-child{border-bottom:0}
.pepv2-mosaic.mode-magazine .pepv2-mosaic-link{display:flex;align-items:stretch;gap:8px}
.pepv2-mosaic.mode-magazine .pepv2-mosaic-card:nth-child(even) .pepv2-mosaic-link{flex-direction:row-reverse}
.pepv2-mosaic.mode-magazine .pepv2-mosaic-media{flex:0 0 44%;aspect-ratio:4/3!important;border-radius:var(--pepv2-radius);overflow:hidden}
.pepv2-mosaic.mode-magazine .pepv2-mosaic-body{flex:1;padding:18px 8px;display:flex;flex-direction:column;justify-content:center}
.pepv2-mosaic.mode-magazine .pepv2-mosaic-title{font-size:clamp(26px,3.4vw,42px);letter-spacing:-.02em}
.pepv2-mosaic.mode-magazine .pepv2-mosaic-cat{font-size:12px}
@media(max-width:760px){
  .pepv2-mosaic.mode-list_left .pepv2-mosaic-link,.pepv2-mosaic.mode-list_alternate .pepv2-mosaic-link,.pepv2-mosaic.mode-magazine .pepv2-mosaic-link{flex-direction:column!important}
  .pepv2-mosaic.mode-list_left .pepv2-mosaic-media,.pepv2-mosaic.mode-list_alternate .pepv2-mosaic-media,.pepv2-mosaic.mode-magazine .pepv2-mosaic-media{flex:0 0 auto;aspect-ratio:16/10!important}
}

/* -- Status-Störer in v2-Widgets (Wiederverwendung der v1-Klassen aus PEP_Render::status_ribbon_html) -- */
.pepv2-mosaic-card,.pepv2-spot-feature,.pepv2-detail-hero-media{position:relative}
.pepv2-spot-item{position:relative}
.pepv2-spot-item-ribbon{position:static!important;transform:none!important;width:auto!important;text-align:left!important;box-shadow:none!important;margin:0 0 6px!important}
.pepv2-spot-item-ribbon span{display:inline-flex;border-radius:999px;padding:3px 10px;font-size:10.5px}
.pepv2-detail-ribbon{margin-bottom:14px}
.pepv2-cal-event.is-cancelled{opacity:.62;text-decoration:line-through}
.pepv2-cal-event.is-postponed{background:color-mix(in srgb,#b8860b 12%,#fff)}
.pepv2-cal-status{display:block;font-size:9.5px;font-weight:900;text-transform:uppercase;letter-spacing:.05em;color:#b8860b}
.pepv2-cal-event.is-cancelled .pepv2-cal-status{color:#c0392b}

/* =====================================================================
   v2.2 - Drei weitere Grid-Basisstile: Minimal / Light / Colorful
   ===================================================================== */

/* -- MINIMAL: clean, reduziert, viel Weissraum, kaum Schatten -- */
.pepv2-mosaic.mode-minimal .pepv2-mosaic-card{background:transparent;border:0;box-shadow:none;border-radius:0}
.pepv2-mosaic.mode-minimal .pepv2-mosaic-media{border-radius:10px;aspect-ratio:4/3!important}
.pepv2-mosaic.mode-minimal .pepv2-mosaic-date{top:10px;left:10px}
.pepv2-mosaic.mode-minimal .pepv2-mosaic-body{padding:16px 2px 0}
.pepv2-mosaic.mode-minimal .pepv2-mosaic-cat{font-size:10.5px;letter-spacing:.1em;margin-bottom:6px}
.pepv2-mosaic.mode-minimal .pepv2-mosaic-title{font-size:clamp(17px,1.4vw,21px);font-weight:700}
.pepv2-mosaic.mode-minimal .pepv2-mosaic-meta span{background:transparent;padding:0;font-weight:600}
.pepv2-mosaic.mode-minimal .pepv2-mosaic-meta{gap:14px}
.pepv2-mosaic.mode-minimal .pepv2-mosaic-meta span:not(:last-child):after{content:"·";margin-left:14px;color:var(--pepv2-muted)}
.pepv2-mosaic.mode-minimal .pepv2-mosaic-cta{border-bottom:1px solid currentColor;border-radius:0;padding:0 0 .1em}

/* -- LIGHT: luftig, pastellige Flaeche aus der Akzentfarbe -- */
.pepv2-mosaic.mode-light .pepv2-mosaic-card{background:color-mix(in srgb,var(--pepv2-cat-color,var(--pepv2-accent)) 7%,#fff);border:1px solid color-mix(in srgb,var(--pepv2-cat-color,var(--pepv2-accent)) 14%,transparent);box-shadow:none}
.pepv2-mosaic.mode-light .pepv2-mosaic-media{margin:14px 14px 0;border-radius:16px;overflow:hidden;aspect-ratio:16/11!important}
.pepv2-mosaic.mode-light .pepv2-mosaic-body{padding:18px 20px 22px}
.pepv2-mosaic.mode-light .pepv2-mosaic-cat{background:color-mix(in srgb,var(--pepv2-cat-color,var(--pepv2-accent)) 14%,#fff);padding:4px 10px;border-radius:999px}
.pepv2-mosaic.mode-light .pepv2-mosaic-card:hover{transform:translateY(-4px);transition:transform .25s ease}

/* -- COLORFUL: kraeftige Farbflaeche aus Kategorie-/Bildfarbe -- */
.pepv2-mosaic.mode-colorful .pepv2-mosaic-card{background:linear-gradient(150deg,var(--pepv2-cat-color,var(--pepv2-accent)),color-mix(in srgb,var(--pepv2-cat-color,var(--pepv2-accent)) 55%,#000 45%));border:0;box-shadow:0 18px 40px color-mix(in srgb,var(--pepv2-cat-color,var(--pepv2-accent)) 35%,transparent)}
.pepv2-mosaic.mode-colorful .pepv2-mosaic-media{aspect-ratio:4/3!important;margin:14px 14px 0;border-radius:14px;overflow:hidden;box-shadow:0 8px 22px rgba(0,0,0,.25)}
.pepv2-mosaic.mode-colorful .pepv2-mosaic-body{padding:16px 20px 22px}
.pepv2-mosaic.mode-colorful .pepv2-mosaic-cat{color:#fff;opacity:.85}
.pepv2-mosaic.mode-colorful .pepv2-mosaic-title{color:#fff;font-weight:800}
.pepv2-mosaic.mode-colorful .pepv2-mosaic-text{color:rgba(255,255,255,.88)}
.pepv2-mosaic.mode-colorful .pepv2-mosaic-meta span{background:rgba(255,255,255,.16);color:#fff}
.pepv2-mosaic.mode-colorful .pepv2-mosaic-cta{color:#fff}
.pepv2-mosaic.mode-colorful .pepv2-mosaic-date.pepv2-date-pill{background:rgba(255,255,255,.92)}
