
* { box-sizing: border-box; }
:root{
  --brand-font: 'Pacifico', cursive; --bg:#fbfbfd; --text:#14161a; --muted:#5b6166; --card:#ffffff; --line:#e9edf2; --brand:#0b6efb; }
html,body{ margin:0; background:var(--bg); color:var(--text); font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }
a{ color:var(--brand); text-decoration:none; } a:hover{ text-decoration:underline; }
.container{ width:min(1140px, 92vw); margin:0 auto; }

.site-header{ position:sticky; top:0; z-index:50; background:var(--card); border-bottom:1px solid var(--line); transition: box-shadow .2s ease; }
.site-header .container{ display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:12px; }
.site-header.scrolled{ box-shadow: 0 8px 24px rgba(0,0,0,.06); }
.brand{ font-weight:800; font-size:20px; letter-spacing:.2px; color:var(--text); }
.main-nav a{ margin-left:14px; padding:8px 10px; border-radius:10px; }
.main-nav a:hover{ background:#f1f5ff; text-decoration:none; }
.main-nav .active{ background:#e7f0ff; }
.burger{ display:none; background:transparent; border:1px solid var(--line); border-radius:10px; padding:8px 10px; font-size:18px; cursor:pointer; }

@media (max-width: 780px){
  .burger{ display:block; }
  .main-nav{ display:none; position:absolute; top:58px; right:4vw; background:var(--card); border:1px solid var(--line); border-radius:12px; padding:8px; box-shadow:0 6px 28px rgba(0,0,0,.08); }
  .main-nav.open{ display:flex; flex-direction:column; }
  .main-nav a{ margin:6px; }
}

.site-footer{ margin-top:56px; background:var(--card); border-top:1px solid var(--line); }
.site-footer .container{ padding:18px 0; color:var(--muted); font-size:14px; }

.hero{ padding:64px 0 22px; }
.hero .hero-inner{ background:linear-gradient(135deg, #edf3ff, #f7fbff); border:1px solid var(--line); border-radius:16px; padding:32px; }
h1{ font-size: clamp(28px, 3.5vw, 40px); margin:12px 0 8px; }
h2{ font-size: clamp(22px, 3vw, 28px); margin:20px 0 8px; }
p{ line-height:1.6; color:#2b2f33; }
p.meta{ color:var(--muted); }

.crumbs{ font-size:14px; color:var(--muted); margin-top:16px; }
.crumbs span{ color:var(--muted); }
.hide-mobile{ display:inline; }
.show-mobile{ display:none; }
.back-inline{ margin-left:12px; color: var(--muted); font-size:14px; }

@media (max-width: 760px){
  .hide-mobile{ display:none; }
  .show-mobile{ display:inline; }
  .crumbs{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
}

.cta .button{ display:inline-block; padding:10px 14px; border-radius:12px; background:var(--brand); color:white; margin-right:8px; }
.cta .button.ghost{ background:#eff4ff; color:var(--brand); }
.button:hover{ opacity:.95; text-decoration:none; }

.grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(220px, 1fr)); gap:16px; margin:16px 0 28px; }
.card{ background:var(--card); border:1px solid var(--line); border-radius:14px; overflow:hidden; display:flex; flex-direction:column; }
.card img{ width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.card .pad{ padding:12px; }
.card h3{ margin:0 0 6px; font-size:18px; }
.card p.meta{ margin:0; font-size:13px; color:var(--muted); }

.about-photo img{ width:100%; border-radius:14px; border:1px solid var(--line); }
.about-photo figcaption{ color:var(--muted); font-size:14px; margin-top:6px; }

/* Lightbox */
.lightbox-backdrop{ position:fixed; inset:0; display:none; align-items:center; justify-content:center; background:rgba(0,0,0,.92); z-index:100; padding:24px; }
.lightbox-backdrop.active{ display:flex; }
.lightbox-content{ max-width:96vw; max-height:92vh; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.lightbox-content img{ display:block; max-width:96vw; max-height:calc(92vh - 120px); height:auto; width:auto; border-radius:10px; object-fit:contain; transition: transform .15s ease; }
.lightbox-content img.zoomed{ cursor: grab; }
.lightbox-content img.zoomed:active{ cursor: grabbing; }
.lightbox-caption{ color:#e6e6e6; margin-top:10px; text-align:center; font-size:14px; max-width:92vw; }
.lightbox-toolbar{ display:flex; align-items:center; justify-content:center; gap:16px; margin-top:8px; }
.lightbox-toolbar button{ background:white; border:1px solid #d8dbe0; border-radius:10px; padding:8px 12px; cursor:pointer; }
.lightbox-toolbar button:disabled{ opacity:.5; cursor:not-allowed; }
.lightbox-count{ color:#ddd; font-size:13px; }
.lightbox-hints{ color:#aaa; font-size:12px; margin-top:6px; }
.lightbox-side{ position:fixed; top:0; bottom:0; width:20%; cursor:pointer; }
.lightbox-side.left{ left:0; }
.lightbox-side.right{ right:0; }
.lightbox-close{ position:fixed; top:16px; right:16px; background:white; border:none; border-radius:12px; padding:8px 12px; cursor:pointer; box-shadow:0 2px 6px rgba(0,0,0,.12); }

@media (max-height: 800px){
  .lightbox-content img{ max-height:calc(92vh - 110px); }
  .lightbox-caption{ font-size:13px; }
  .lightbox-toolbar button{ padding:6px 10px; }
  .lightbox-hints{ display:none; }
}
@media (max-width: 700px){
  .lightbox-backdrop{ padding:0; }
  .lightbox-content{ width:100vw; height:100vh; max-width:none; max-height:none; }
  .lightbox-content img{ max-width:100vw; max-height:calc(100vh - 90px); border-radius:0; }
  .lightbox-caption{ display:none; }
  .lightbox-toolbar{ position:fixed; left:0; right:0; bottom:0; background:rgba(0,0,0,.5); padding:10px; gap:20px; }
  .lightbox-hints{ position:fixed; left:0; right:0; bottom:52px; text-align:center; color:#ddd; font-size:12px; opacity:.9; }
}

.brand{ font-family: var(--brand-font); font-size:26px; font-weight:400; color:var(--text); }
.hero h1{ font-family: var(--brand-font); font-size:clamp(32px,4vw,52px); font-weight:400; }

.tiles{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px; margin-top:24px; }
.tile{ display:block; padding:20px; border:1px solid var(--line); border-radius:14px; background:var(--card); text-decoration:none; color:var(--text); transition:.2s box-shadow ease; }
.tile:hover{ box-shadow:0 6px 20px rgba(0,0,0,.08); text-decoration:none; }
.tile h3{ margin:0 0 6px; font-size:20px; color:var(--brand); }
.tile p{ margin:0; font-size:14px; color:var(--muted); line-height:1.5; }

.main-nav .logout-link{margin-left:auto;color:#ef4444;font-weight:500;}

.main-nav .logout-link{margin-left:auto;color:#ef4444;font-weight:500;}
@media (max-width: 780px){
  .main-nav .logout-link{margin-left:0;margin-top:6px;}
}

/* Logout Link */
.main-nav .logout-link{margin-left:auto;color:#ef4444;font-weight:500;}
@media (max-width: 780px){
  .main-nav.open .logout-link{margin:6px; order: 999;}
}


/* v24: kompaktere Navigation (Desktop & Mobil) */
.main-nav{ display:flex; align-items:center; gap:24px; justify-content:flex-start; }
.main-nav a{ margin-left:0; } /* alte globale Margins neutralisieren */
.site-header .container{ gap:16px; } /* etwas dichter */
.main-nav .logout-link{ margin-left:auto; color:#ef4444; font-weight:500; }

@media (max-width: 780px){
  .main-nav{ gap:8px; }
  .main-nav.open .logout-link{ order:999; margin:6px 6px 8px; }
}


/* v25: konsistente, kompakte Hauptnavigation */
.main-nav{ display:flex; align-items:center; gap:24px; padding:0; margin:0; }
.main-nav a{ margin:0; padding:8px 10px; border-radius:10px; }
@media (max-width:780px){
  .main-nav{ gap:10px; }
  .main-nav.open .logout-link{ order:999; }
}


/* v26: Mobile nur Burger-Menü, Links erst bei .open sichtbar */
@media (max-width: 780px){
  .main-nav{ display:none !important; position:absolute; top:58px; right:4vw; background:var(--card); border:1px solid var(--line); border-radius:12px; padding:8px; box-shadow:0 6px 28px rgba(0,0,0,.08); }
  .main-nav.open{ display:flex !important; flex-direction:column; gap:8px; }
}


/* v31: kompaktere Popups; Thumbnail klickbar */
.popup-card{display:flex; gap:10px; align-items:flex-start;}
.popup-cover{width:72px; height:54px; object-fit:cover; border-radius:6px; border:1px solid #e5e7eb;}
.popup-meta{display:flex; flex-direction:column; gap:2px; font-size:12px;}
.popup-meta strong{font-size:13px;}
.popup-date,.popup-loc{color:#6b7280;}


/* v32: saubere Karten-Bildgrößen (keine Verzerrung) */
.card img{ width:100%; height:auto; aspect-ratio:3/2; object-fit:cover; display:block; }
.grid .card{ overflow:hidden; }

/* v32: Logout-Link Style & Burger-Menü Verhalten */
.main-nav .logout-link{ margin-left:auto; color:#ef4444; font-weight:500; }
@media (max-width: 780px){
  .main-nav{ display:none; position:absolute; top:58px; right:4vw; background:var(--card); border:1px solid var(--line); border-radius:12px; padding:8px; box-shadow:0 6px 28px rgba(0,0,0,.08); }
  .main-nav.open{ display:flex; flex-direction:column; gap:8px; }
  .main-nav.open .logout-link{ order: 999; }
}
