/*
Theme Name: Teutonia Modern
Theme URI: https://teuwue.ai-mx.de
Author: Teutonia Würzburg
Description: Eigenständiges Theme der Studentenverbindung Teutonia Würzburg — modernes, aus dem Couleur abgeleitetes Designsystem (rot · weiß · gelb, Fraunces + Archivo, selbst gehostet) mit Edel-Hero (Zoom-in-on-Scroll). Abgeleitet aus dem Prototyp „teutonia-zoom-uebergang" (Stil: Edel).
Version: 0.2.1
Requires at least: 6.4
Tested up to: 7.0
Requires PHP: 8.0
Text Domain: teutonia-modern
*/

/* ============================================================
   1. Design-Tokens (Couleur — aus dem Wappen gemessen)
   Werte werden in wp_head per Option (lions_brand_*) überschrieben.
   ============================================================ */
:root{
  --rot:#CC2A1A; --rot-tief:#8E1B0F; --gelb:#F7C23C; --silber:#C8CBCE;
  --schwarz:#141414; --gold:#BFA046; --tinte:#16181D; --anthrazit:#565B66;
  --nebel:#9AA0AA; --linie:#E6E3DD; --papier:#F6F4EF; --weiss:#FFFFFF;
  --gruen:#2F7D55; --fehler:#C0362C;
  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:24px; --r-full:999px;
  --schatten-karte:0 1px 2px rgba(16,18,29,.04), 0 10px 28px -14px rgba(16,18,29,.16);
  /* Bild-Variablen werden in wp_head gesetzt (--fest/--haus/--logo) */
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Archivo',system-ui,sans-serif;color:var(--tinte);background:var(--weiss);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto}
a{color:var(--rot)}

.lg{display:inline-block;background:var(--logo) center/contain no-repeat;flex:none}

/* ============================================================
   2. Kopfleiste (transparent über dem Hero)
   ============================================================ */
.bar{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;align-items:center;gap:14px;justify-content:space-between;padding:11px 16px;background:linear-gradient(180deg,rgba(10,11,15,.55),rgba(10,11,15,0))}
.brand{display:flex;align-items:center;gap:10px;flex:none;text-decoration:none}
.brand .lg{height:38px;width:36px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
.brand b{font-family:'Fraunces',serif;font-weight:500;font-size:15px;color:#fff;letter-spacing:.2px;white-space:nowrap}
.mainnav{display:flex;gap:4px;align-items:center}
.mainnav ul{list-style:none;display:flex;gap:4px;margin:0;padding:0;flex-wrap:wrap}
.mainnav a{color:#fff;font-family:'Archivo';font-size:13px;font-weight:600;padding:7px 12px;border-radius:var(--r-full);text-decoration:none;opacity:.9}
.mainnav a:hover,.mainnav .current-menu-item>a{background:rgba(255,255,255,.16);opacity:1}
@media(max-width:560px){.brand b{display:none}.mainnav a{padding:6px 9px;font-size:12px}}

/* ============================================================
   3. Zoom-Hero (Edel) — Stage / Sticky / zwei Ebenen
   ============================================================ */
.stage{position:relative;height:210vh}
.sticky{position:sticky;top:0;height:100vh;overflow:hidden}
.layer{position:absolute;inset:0;display:grid;place-items:center}
.p1{z-index:1} .p2{z-index:2;opacity:0}
.bg{position:absolute;inset:0;background-size:cover;background-position:center;will-change:transform}
.p1 .bg{transform-origin:58% 34%}
.tint{position:absolute;inset:0;background:var(--rot);mix-blend-mode:multiply;opacity:0}
.scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,10,16,.5),rgba(8,10,16,.12) 30%,rgba(8,10,16,.55))}
.content{position:relative;z-index:5;width:100%;max-width:1100px;padding:0 26px}

.crest{display:none;height:92px;width:86px;background:var(--logo) center/contain no-repeat;margin:0 auto 22px;filter:drop-shadow(0 6px 18px rgba(0,0,0,.4))}
.eyebrow{display:inline-flex;align-items:center;gap:12px;color:#fff;font-size:18px;letter-spacing:3px;text-transform:uppercase;font-weight:600;margin:0 0 20px} /* +3pt */
.eyebrow::before{content:"";width:40px;height:3px;background:var(--rot)} /* rote Linie dicker */
.htitle{font-family:'Fraunces',serif;color:#fff;margin:0;line-height:.92;letter-spacing:-1.5px;font-size:clamp(51px,11.5vw,125px);font-weight:300;text-shadow:0 4px 38px rgba(0,0,0,.4)} /* Edel: 300 · 3pt kleiner */
.tagline{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:clamp(25px,3vw,31px);color:#fff;margin:22px 0 0} /* +3pt, dann +5pt */
.hint{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:7;color:rgba(255,255,255,.85);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:7px}
.hint .m{width:23px;height:36px;border:2px solid rgba(255,255,255,.8);border-radius:13px;position:relative}
.hint .m::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:6px;border-radius:2px;background:#fff;transform:translateX(-50%);animation:dot 1.5s infinite}
@keyframes dot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,11px)}}

.p2head{margin-bottom:24px}
.p2kick{display:inline-flex;align-items:center;gap:10px;color:#fff;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;font-weight:700;margin:0 0 12px}
.p2kick::before{content:"";width:26px;height:2px;background:var(--rot)}
.p2title{font-family:'Fraunces',serif;color:#fff;font-weight:500;font-size:clamp(30px,5.5vw,54px);line-height:1.02;letter-spacing:-.5px;margin:0;text-shadow:0 3px 20px rgba(0,0,0,.4)}
.boxes{display:grid;gap:16px;margin-top:6px}
@media(min-width:760px){.boxes{grid-template-columns:repeat(3,1fr)}}
.box{background:rgba(255,255,255,.95);border-radius:var(--r-lg);padding:22px;box-shadow:0 14px 36px -18px rgba(0,0,0,.5);border-top:2px solid var(--rot)} /* Edel: rote Oberkante */
.box .num{font-family:'Fraunces',serif;font-size:15px;color:var(--rot);font-weight:600}
.box h3{font-family:'Fraunces',serif;font-weight:500;font-size:20px;margin:8px 0 6px;color:var(--tinte)}
.box p{font-size:14px;color:var(--anthrazit);line-height:1.55;margin:0}

/* „Zu Hause" — Einleitungstext + schwebende, seitlich scrollbare Zimmerbilder */
.p2lead{color:#fff;font-size:clamp(17px,2.2vw,21px);line-height:1.5;max-width:60ch;margin:0 0 22px;text-shadow:0 2px 14px rgba(0,0,0,.45)}
.roomscroll{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 2px 14px;-webkit-overflow-scrolling:touch}
.roomscroll::-webkit-scrollbar{height:6px}
.roomscroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.45);border-radius:6px}
.rcard{flex:0 0 auto;width:300px;max-width:78vw;scroll-snap-align:start;text-decoration:none;display:block}
.rcard .frame{aspect-ratio:4/3;box-shadow:0 18px 40px -18px rgba(0,0,0,.6);transition:transform .18s ease}
.rcard:hover .frame{transform:translateY(-4px)}
.rcard .rcap{display:block;margin-top:10px;color:#fff;font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.rcard--chaos{width:380px}
.rcard--chaos .frame{aspect-ratio:16/9}
.rcard--chaos .rcap{font-family:'Fraunces',serif;font-style:italic;font-weight:400;text-transform:none;letter-spacing:0;font-size:17px}
.roomscroll-hint{margin:6px 0 0;color:rgba(255,255,255,.8);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;font-weight:600}

/* Startseite: gepinnte Mehrstufen-Zoom-Bühne mit Section-Snapping */
.zstage{position:relative}
/* Sticky-Ebene überlagert die Snap-Spacer (negative Margin hebt ihren Flow-Platz auf) */
.zsticky{position:sticky;top:0;height:100vh;overflow:hidden;margin-bottom:-100vh;z-index:1}
.zsnap{height:100vh;scroll-snap-align:start}
.zlayer{position:absolute;inset:0;display:grid;place-items:center;overflow:hidden;will-change:opacity}
.zbg{position:absolute;inset:0;background-size:cover;background-position:center;will-change:transform}
.zscrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,10,16,.55),rgba(8,10,16,.25) 35%,rgba(8,10,16,.7))}
.zsec--hero .zscrim{background:linear-gradient(180deg,rgba(8,10,16,.5),rgba(8,10,16,.12) 30%,rgba(8,10,16,.55))}
.zcontent{position:relative;z-index:3;width:100%;max-width:1000px;padding:90px 26px;text-align:center}
.zcontent .eyebrow{justify-content:center}
.zcontent .htitle,.zcontent .p2title,.zcontent .tagline,.zcontent .p2lead{margin-left:auto;margin-right:auto}
.zcontent .p2lead{margin-top:18px}
/* Kasten („Dein Zuhause" / „Deine Zukunft" / „Deine Freunde") */
.secbox{display:inline-flex;align-items:center;gap:14px;margin-top:30px;background:var(--rot);color:#fff;border-radius:var(--r-lg);padding:16px 24px;text-decoration:none;box-shadow:0 18px 40px -18px rgba(0,0,0,.55);font-family:'Fraunces',serif;font-weight:500;font-size:19px;transition:transform .18s ease,background .18s ease}
.secbox::after{content:"\2192";color:#fff;font-weight:600;font-family:'Archivo',sans-serif}
.secbox:hover{background:var(--rot-tief);transform:translateY(-3px)}
/* Rastpunkte für Abschluss + Footer (damit man nach der Bühne sauber weiterrastet) */
.tail,.site-footer{scroll-snap-align:start}

/* ============================================================
   4. Abschluss-CTA (tail)
   ============================================================ */
.tail{position:relative;background:var(--papier);text-align:center;padding:90px 26px 70px}
.tail h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(30px,5vw,48px);margin:0 0 14px}
.btn{display:inline-block;background:var(--rot);color:#fff;text-decoration:none;font-weight:600;font-size:16px;padding:15px 30px;border-radius:var(--r-md);border:none;cursor:pointer}
.btn:hover{background:var(--rot-tief)}
.btn--ghost{background:transparent;color:var(--tinte);border:1px solid var(--linie)}
.btn--ghost:hover{background:var(--papier)}

/* ============================================================
   5. Couleur-Band (Signatur) — klein & präzise, nie als Fläche
   ============================================================ */
.couleur{height:6px;background:repeating-linear-gradient(-58deg,
  var(--rot) 0 14px,#fff 14px 22px,var(--gelb) 22px 36px,#fff 36px 44px)}

/* ============================================================
   6. Inhalt (Seiten/Beiträge) — generisches Layout im System
   ============================================================ */
.site-main{min-height:60vh}
.page-hero{background:var(--tinte);color:#fff;padding:120px 26px 40px}
.page-hero .inner{max-width:1100px;margin:0 auto}
.page-hero h1{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(30px,6vw,54px);margin:0;letter-spacing:-.5px}
.wrap{max-width:820px;margin:0 auto;padding:48px 26px}
.entry-content{font-size:17px;line-height:1.6;color:var(--tinte)}
.entry-content h2{font-family:'Fraunces',serif;font-weight:500;font-size:28px;margin:36px 0 12px}
.entry-content h3{font-family:'Fraunces',serif;font-weight:500;font-size:22px;margin:28px 0 10px}
.entry-content a{color:var(--rot)}
.entry-content blockquote{border-left:3px solid var(--rot);margin:24px 0;padding:4px 0 4px 20px;color:var(--anthrazit);font-style:italic}
.entry-content img{border-radius:var(--r-md)}
.label{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;font-weight:700;color:var(--nebel)}

/* ============================================================
   6b. Zimmer-Galerie („Deine neue Heimat")
   Bilder NIE in Originalgröße: medium_large, ohne srcset, in
   zugeschnittenen Rahmen (object-fit:cover), ohne Link/Lightbox.
   ============================================================ */
.kick{display:inline-flex;align-items:center;gap:10px;color:var(--anthrazit);font-size:11px;letter-spacing:2.5px;text-transform:uppercase;font-weight:700;margin:0 0 12px}
.kick::before{content:"";width:26px;height:2px;background:var(--rot)}
.rooms{background:var(--papier);padding:64px 0 72px}
.rooms .wrap2{max-width:1100px;margin:0 auto;padding:0 26px}
.rooms-title{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(26px,4vw,40px);letter-spacing:-.5px;margin:0 0 6px;color:var(--tinte)}
.rooms-sub{color:var(--anthrazit);font-size:16px;margin:0 0 28px;max-width:62ch;line-height:1.55}
.roomgrid{display:grid;gap:18px;grid-template-columns:1fr}
@media(min-width:760px){.roomgrid{grid-template-columns:repeat(3,1fr)}}
.room{margin:0}
.frame{position:relative;aspect-ratio:4/3;border-radius:var(--r-lg);overflow:hidden;background:var(--tinte);box-shadow:var(--schatten-karte);border:1px solid var(--linie)}
.frame img{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-drag:none;user-select:none;pointer-events:none}
.room figcaption{margin-top:10px;font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--anthrazit)}
.room--chaos{margin-top:26px}
.room--chaos .frame{aspect-ratio:16/9}
.room--chaos figcaption{margin-top:12px;font-family:'Fraunces',serif;font-style:italic;font-weight:400;text-transform:none;letter-spacing:0;font-size:18px;color:var(--tinte)}

/* Großbild + klickbare Thumbnails (Klick → große Ansicht) */
.room--feature{margin:0 0 18px}
.room--feature .frame{aspect-ratio:16/9}
.room--feature figcaption{margin-top:12px;font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:19px;color:var(--tinte)}
.roomthumb{-webkit-appearance:none;appearance:none;border:0;background:none;padding:0;margin:0;font:inherit;text-align:left;cursor:pointer;display:block;width:100%}
.roomthumb .frame{aspect-ratio:4/3;transition:transform .18s ease}
.roomthumb:hover .frame{transform:translateY(-4px)}
.roomthumb:focus-visible .frame{outline:3px solid var(--rot);outline-offset:2px}
.roomthumb .rcap2{display:block;margin-top:9px;font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--anthrazit)}
.rooms-hint{margin:6px 0 18px;color:var(--anthrazit);font-size:12px;letter-spacing:1px;text-transform:uppercase;font-weight:600}
/* Handy: kein Tippen/Vergrößern — Hinweis weg, alle Bilder gleich gestapelt */
@media(max-width:759px){
  .rooms-hint{display:none}
  .roomthumb{cursor:default}
  .roomthumb:hover .frame{transform:none}
  .room--feature .frame{aspect-ratio:4/3} /* gleiche Form wie die anderen */
}

/* Seitenbreiter Karten-Kasten */
.mapwrap{margin-top:34px}
.mapbox{height:440px;width:100%;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--linie);box-shadow:var(--schatten-karte);background:var(--linie)}
.mapbox img{pointer-events:auto} /* Leaflet-Kacheln/Marker bedienbar */
.map-caption{margin-top:10px;font-size:12px;color:var(--nebel)}
.teu-redpin{background:none;border:0}

/* ============================================================
   7. Footer
   ============================================================ */
.site-footer{background:var(--tinte);color:rgba(255,255,255,.78);padding:0 0 40px}
.site-footer .inner{max-width:1100px;margin:0 auto;padding:48px 26px 0;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:flex-start}
.site-footer .fbrand{display:flex;align-items:center;gap:12px}
.site-footer .fbrand .lg{height:46px;width:44px}
.site-footer .fbrand b{font-family:'Fraunces',serif;font-weight:500;font-size:18px;color:#fff}
.site-footer nav a{color:rgba(255,255,255,.78);text-decoration:none;font-size:14px;margin-left:18px}
.site-footer nav a:hover{color:#fff}
.site-footer .copy{max-width:1100px;margin:32px auto 0;padding:18px 26px 0;border-top:1px solid rgba(255,255,255,.12);font-size:12px;color:var(--nebel)}

/* ============================================================
   8. Bewegung respektieren
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  .hint .m::after{animation:none}
}
