:root{
  --container: 1440px;
  --gap: 28px;
  --muted: #6b7280;
  --text: #0b1020;

  --card-radius: 28px;
  --card-border: 4px solid #000;
  --card-bg-rgba: rgba(255,255,255,0.55);

  /* Feste Höhen */
  --header-h: 220px;
  --nav-h: 240px;
  --nav-gap: 10px;

  /* Card-Breiten / Gutter */
  --face-gutter-max: 320px;
  --gutter-min-phone: 100px;
  --safe-gap: 24px;
  --edge-right: 10px;
  --container-pad: 24px;
  --card-max: 740px;
  --posts-left: 0px;

  /* Fallback-Farbe */
  --bottom-fallback: #fd5525;

  font-family: 'Poppins', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
}

/* Reset / Basics */
*{ box-sizing: border-box; }
html, body{
  margin:0;
  -webkit-font-smoothing:antialiased;
  background: var(--bottom-fallback);
  height:100%;
  color: var(--text);
  overscroll-behavior-y: none;
}
body{
  min-height:100%;
  overflow-x:hidden;
}

/* ===========================
   Fester Hintergrund
   =========================== */
#bg{
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100lvh;
  z-index: 0;
  pointer-events: none;

  background-image:
    url('images/background.png'),
    linear-gradient(180deg,#fd5525 0%, #fd5525 100%);
  background-repeat: no-repeat, no-repeat;
  background-size: cover, cover;
  background-position: left top, left top;
  background-color: var(--bottom-fallback);
  transform: translateZ(0);
}

/* Desktop: Hintergrundbild in voller Höhe zeigen */
@media (min-width: 1024px){
  #bg{
    background-size: auto 100%, cover;
    background-position: left center, left top;
    background-repeat: no-repeat, no-repeat;
  }
}

/* iOS Safe Areas */
@supports (bottom: env(safe-area-inset-bottom)) {
  #bg::before, #bg::after{
    content:""; position: fixed; left:0; right:0; background: var(--bottom-fallback); z-index:0; pointer-events:none;
  }
  #bg::before{ top:0; height: env(safe-area-inset-top); }
  #bg::after{ bottom:0; height: env(safe-area-inset-bottom); }
}

/* ===========================
   HEADER
   =========================== */
.site-header{
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--header-h);
  z-index: 3;
  background: transparent;
  pointer-events: none;
  border-radius: 40px 40px 0 0;
  overflow: hidden;
}
.site-header .container{
  max-width:none; width:100%; height:100%; padding:0;
}
.header-img{
  display:block; width:100%; height:100%;
  object-fit:cover; object-position:center top; border-radius:0;
}

/* ===========================
   NAV-STREIFEN
   =========================== */
.nav-strip{
  position: fixed;
  top: calc(var(--header-h) + var(--nav-gap));
  left: 0; right: 0;
  height: var(--nav-h);
  z-index: 4;
  background: transparent;
}
.nav-overlay{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
  z-index: 0;
  display:block;
}
.chip-nav{
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  justify-content: center;
  align-items: flex-start;

  width: max-content;
  max-width: calc(100% - 2 * var(--container-pad));
  margin: 12px auto 0;
  padding: 0;
}
@media (max-width: 600px){
  .chip-nav{
    width: auto;
    margin: 12px 16px 0;
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 12px;
  }
}
.chip{
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.85);
  padding: 10px 18px;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 600;
  min-width: 150px;
  text-align: center;
  white-space: nowrap;
  backdrop-filter: saturate(120%) blur(2px);
  transition: transform .06s ease, background .15s ease, border-color .15s ease;
  color:#000;
}
.chip:hover{ transform: translateY(1px); }
.chip.is-active{ background: rgba(255,255,255,.95); border-color: rgba(0,0,0,.12); }

/* ===========================
   CONTENT
   =========================== */
main{ position: relative; z-index: 2; }
main.container{
  max-width: var(--container);
  margin: 0 auto;
  padding:
    calc(var(--header-h) + var(--nav-gap) + var(--nav-h) + 16px)
    calc(var(--container-pad) + var(--edge-right))
    24px
    var(--container-pad);
  position: relative;
  z-index: 2;
}
@media (max-width: 900px){
  main.container{
    padding:
      calc(var(--header-h) + var(--nav-gap) + var(--nav-h) + 12px)
      calc(16px + var(--edge-right))
      16px
      16px;
  }
}

/* ===========================
   POSTS
   =========================== */
.posts{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap: var(--gap);
  width:100%;
  padding-left: var(--posts-left);
  padding-right: var(--edge-right);
  padding-bottom: 64px;
}

/* ===========================
   CARD
   =========================== */
.post-card{
  width: min(100%, var(--card-max));
  background: var(--card-bg-rgba);
  border: var(--card-border);
  border-radius: var(--card-radius);
  padding: 20px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.12);
  backdrop-filter: blur(6px);
}
.post-inner{
  display:grid;
  grid-template-columns: minmax(160px,25%) 1fr;
  column-gap:18px;
  row-gap:12px;
  align-items:end;
}
.post-meta{ align-self:start; }
.thumb{
  width:100%;
  aspect-ratio: 9/16;
  border-radius: calc(var(--card-radius) - 6px);
  overflow:hidden;
  background:#fff;
  position:relative;
  justify-self:start;
  align-self:end;
}
.thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.play{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:44px; height:44px; border-radius:50%; border:0;
  background:rgba(255,255,255,0.95);
  display:inline-grid; place-items:center; cursor:pointer;
  box-shadow:0 6px 18px rgba(0,0,0,0.16);
}
.play::after{
  content:""; display:inline-block; margin-left:3px; width:12px; height:12px;
  border-left:10px solid #7b3cff; border-top:6px solid transparent; border-bottom:6px solid transparent;
  transform:translateX(2px);
}

/* Typo */
.post-date{ display:block; color:var(--muted); font-size:0.92rem; margin-bottom:6px; }
.post-title{ margin:0 0 8px; font-size:1.2rem; }
.post-desc{ margin:0; line-height:1.55; white-space: pre-wrap; }

/* Footer */
.site-footer{ padding:40px 0; text-align:center; color:#000; }

/* ===========================
   Responsive
   =========================== */
@media (max-width: 900px){
  .post-card{ padding:16px; border-radius:22px; }
}
@media (max-width: 720px){
  .post-inner{ grid-template-columns:1fr; align-items:start; }
  .thumb{ justify-self:stretch; align-self:start; aspect-ratio:9/16; }
}

/* Dynamische Gutter */
@media (max-width: 600px){ :root{ --card-max: 390px; } }
@media (min-width: 720px){ :root{ --card-max: 580px; } }
@media (min-width: 900px){ :root{ --card-max: 740px; } }
@media (max-width: 900px){ :root{ --container-pad: 16px; } }

@media (min-width: 601px){
  :root{
    --posts-left: clamp(
      0px,
      calc(100vw - var(--container-pad) - var(--card-max) - var(--safe-gap)),
      var(--face-gutter-max)
    );
  }
}
@media (max-width: 600px){
  :root{
    --posts-left: min(
      var(--face-gutter-max),
      max(var(--gutter-min-phone), calc(100vw - var(--container-pad) - var(--card-max) - var(--safe-gap)))
    );
  }
}

/* HiDPI Glättung */
#bg, .site-header, .nav-strip {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

/* ===========================
   ABOUT (Einspalter)
   =========================== */
.about-inner{
  grid-template-columns: 1fr !important;
  align-items: start !important;
  row-gap: 16px;
}
.about-avatar{
  align-self: start !important;
  justify-self: center;
  width: 200px;
  max-width: 65%;
  border-radius: 24px;
  overflow: hidden;
  margin-top: 4px;
}
@media (max-width: 480px){
  .about-avatar{ width: 160px; max-width: 70%; }
}
.about-facts{ margin: 12px 0 0; padding-left: 1.1em; }

/* Social Chips */
.about-social{
  display:flex; flex-wrap:wrap; gap:10px; margin-top:14px;
}
.share-chip{
  appearance:none; border:1px solid rgba(0,0,0,.08); background: rgba(255,255,255,.85);
  border-radius:999px; padding:8px 14px; font: inherit; font-weight:600; cursor:pointer;
  text-decoration:none; color: inherit; backdrop-filter:saturate(120%) blur(2px);
  transition: transform .06s ease, background .15s ease, border-color .15s ease;
}
.share-chip:hover{ transform: translateY(1px); }

.why-box{
  margin-top:16px; padding:14px 16px; border:1px solid rgba(0,0,0,.08);
  border-radius:16px; background: rgba(255,255,255,.70); backdrop-filter: blur(3px);
}
.why-box h4{ margin:0 0 8px; font-size:1.05rem; }
.why-box p{ margin:0; line-height:1.55; }

/* Share-Leiste (einmalig, ohne Dopplungen) */
.share-bar{
  display:flex; flex-wrap:wrap; gap:.5rem; margin-top:.4rem;
}
.share-btn, .share-bar a{
  display:inline-flex; align-items:center; gap:.35rem;
  padding:.4rem .6rem; border-radius:.6rem;
  text-decoration:none; cursor:pointer; line-height:1;
  border:1px solid rgba(0,0,0,.08); background: rgba(255,255,255,.85);
  backdrop-filter:saturate(120%) blur(2px);
}
.share-bar img{ width:18px; height:18px; display:block; }
.share-fb{ border-color: rgba(24,119,242,.18); }
.share-wa{ border-color: rgba(37,211,102,.18); }

/* Mobile Header-Höhe */
@media (max-width: 768px){
  :root{ --header-h: 120px !important; }
  .site-header{ height: var(--header-h) !important; }
  .nav-strip{ top: calc(var(--header-h) + var(--nav-gap)) !important; }
  main.container{ padding-top: calc(var(--header-h) + var(--nav-gap) + var(--nav-h) + 16px) !important; }
  .header-img{ height: 100% !important; width: 100% !important; object-fit: cover; object-position: center top; }
}

/* Sichtbarer Tastaturfokus für Chips/Share-Buttons */
.chip:focus-visible,
.share-btn:focus-visible{
  outline: 3px solid #000;
  outline-offset: 2px;
}

/* Skeleton Loader */
.skeleton{
  background: linear-gradient(90deg,#00000008, #00000012, #00000008);
  background-size:200% 100%;
  animation: sk 1.2s infinite linear;
}
@keyframes sk {
  from{ background-position: 200% 0; }
  to{   background-position: -200% 0; }
}
.card-skeleton{
  height: 220px;
  border-radius: var(--card-radius);
  border: var(--card-border);
  background: #fff8;
  box-shadow: 0 12px 32px rgba(0,0,0,0.12);
  margin-bottom: var(--gap);
}

/* Auf Phones die Karten minimal opaker machen (bessere Lesbarkeit) */
@media (max-width:600px){
  :root{ --card-bg-rgba: rgba(255,255,255,0.7); }
}

/* Toast-Feedback unten mittig */
.toast{
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  background: #000;
  color:#fff;
  padding:10px 14px;
  border-radius:10px;
  box-shadow: 0 8px 20px rgba(0,0,0,.25);
  opacity:0;
  pointer-events:none;
  transition: opacity .25s ease, transform .25s ease;
  z-index: 1000;
}
.toast.show{
  opacity:1;
  transform: translate(-50%, -6px);
}

.chip:focus-visible,
.share-btn:focus-visible{
  outline: 3px solid #000;
  outline-offset: 2px;
}

/* Deep-Link Highlight für Cards */
.post-card.highlight{
  animation: hl 1.8s ease;
}
@keyframes hl{
  0%   { box-shadow: 0 0 0 0 rgba(255,215,0,.9);    transform: translateY(0); }
  30%  { box-shadow: 0 0 0 12px rgba(255,215,0,.25); transform: translateY(-2px); }
  100% { box-shadow: 0 0 0 0 rgba(255,215,0,0);     transform: translateY(0); }
}



/* Media-Elemente in Gedanken-Cards */
.post-card .thoughts-media{ margin-top:.75rem; display:flex; flex-direction:column; gap:.5rem; }
.post-card .thoughts-media img{ max-width:100%; height:auto; border-radius:12px; }
.post-card .thoughts-media audio,
.post-card .thoughts-media video{ width:100%; outline:0; border-radius:12px; }

.gedanke{
  max-width: 100%;
  margin: 0 20px 16px 20px;   /* 20 px links/rechts */
  padding: 18px;
  background: rgba(255,255,255,.85);
  backdrop-filter: saturate(115%) blur(2px);
  border-radius: 14px;
  box-shadow: 0 6px 24px rgba(0,0,0,.06);
}
.gedanke .text { line-height: 1.65; font-size: 1.05rem; }
.gedanke .text p { margin: .5rem 0; }
.gedanke img { max-width: 100%; height: auto; border-radius: 12px; }
.gedanke audio, .gedanke video { width:100%; border-radius:12px; outline:0; }

#emoji-panel{
  position:absolute; z-index:9999; width:260px; max-height:260px; overflow:auto;
  background:#fff; border:1px solid #ddd; border-radius:12px; padding:8px;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
}
#emoji-panel button{
  font-size:20px; line-height:1; width:36px; height:36px; margin:4px; border:0; background:transparent; cursor:pointer;
  border-radius:8px;
}
#emoji-panel button:hover{ background:#f3f3f3; }

/* ===== Gedanken Cards (nur innerhalb der #gedanken-Section) ===== */
#gedanken .gedanke{
  margin: 0 20px 18px 20px;                 /* 20 px links/rechts */
  padding: 18px 18px 16px;
  background: var(--surface, rgba(255,255,255,.86));
  border-radius: 16px;
  box-shadow: var(--shadow, 0 10px 30px rgba(0,0,0,.08));
  backdrop-filter: saturate(115%) blur(2px);
  -webkit-backdrop-filter: saturate(115%) blur(2px);
  border: 1px solid rgba(255,255,255,.7);
  transition: transform .18s ease, box-shadow .18s ease;
}
#gedanken .gedanke:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow, 0 12px 36px rgba(0,0,0,.12));
}

/* Datum */
#gedanken .gedanke .date{
  display:block;
  font-size:.8rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  color: var(--muted, #6b7280);
  margin-bottom:.4rem;
}

/* Texttypografie */
#gedanken .gedanke .text{
  font-size:1.05rem;
  line-height:1.65;
}
#gedanken .gedanke .text p{ margin:.55rem 0; }

/* Links (mit Beschreibung) */
#gedanken .gedanke .text a{
  color: #0b4f2a; /* dunkles Mint – nur in #gedanken */
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 2px;
}
#gedanken .gedanke .text a:hover{
  text-decoration-thickness: 3px;
}
#gedanken .gedanke .text a:focus-visible{
  outline: none;
  box-shadow: var(--ring, 0 0 0 3px rgba(123,211,137,.35));
  border-radius: 6px;
}

/* Medienblöcke (vom Parser befüllt) */
#gedanken .gedanke .media{
  display:flex;
  flex-direction:column;
  gap:.6rem;
  margin-top:.8rem;
}
#gedanken .gedanke img{
  max-width:100%;
  height:auto;
  border-radius:12px;
  display:block;
}
#gedanken .gedanke audio,
#gedanken .gedanke video{
  width:100%;
  border-radius:12px;
  outline:0;
}

/* Überschrift der Section (optional, nur hier) */
#gedanken > h2{
  margin: 16px 20px 10px;
  font-weight: 700;
  letter-spacing:.01em;
  color: #163e2a;
  text-shadow: 0 1px 0 rgba(255,255,255,.6);
}

/* „Mehr laden“-Button (nur in #gedanken) */
#gedanken #gedanken-more{
  margin: 6px 20px 24px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.7);
  background: linear-gradient(90deg, var(--mint, #7bd389), var(--lavender, #b59eff));
  color: #10211a;
  font-weight: 600;
  cursor: pointer;
  box-shadow: var(--shadow, 0 10px 30px rgba(0,0,0,.08));
  transition: filter .16s ease, transform .16s ease;
}
#gedanken #gedanken-more:hover{ filter: saturate(110%); transform: translateY(-1px); }
#gedanken #gedanken-more:focus-visible{
  outline: none;
  box-shadow: var(--ring, 0 0 0 3px rgba(123,211,137,.35));
}

/* Emoji-Panel (nur das im Header, falls genutzt) */
#emoji-panel{
  background: var(--surface, rgba(255,255,255,.86));
  border: 1px solid rgba(255,255,255,.7);
  border-radius: 14px;
  box-shadow: var(--shadow, 0 10px 30px rgba(0,0,0,.08));
}
#emoji-panel button{
  font-size:22px;
  width:38px; height:38px;
  border-radius:10px;
}
#emoji-panel button:hover{ background: rgba(0,0,0,.04); }

/* Dark-Mode – nur fein für die #gedanken-Section */
@media (prefers-color-scheme: dark){
  #gedanken .gedanke{
    background: var(--surface, rgba(18,20,28,.75));
    border-color: rgba(255,255,255,.08);
    box-shadow: var(--shadow, 0 10px 30px rgba(0,0,0,.45));
  }
  #gedanken .gedanke .text a{ color:#8de0a1; }
  #gedanken > h2{ color:#cfe8db; text-shadow:none; }
  #gedanken #gedanken-more{ color:#0e1721; }
}

/* Bewegungs-Reduktion respektieren */
@media (prefers-reduced-motion: reduce){
  #gedanken .gedanke{ transition: none; }
  #gedanken #gedanken-more{ transition: none; }
}

/* Desktop: Gedanken-Karten schmaler & zentriert, Mobile bleibt wie es ist */
@media (min-width: 1024px){
  #gedanken .gedanke{
    max-width: 900px;     /* Breite der Card */
    margin: 0 auto 18px;  /* zentrieren */
    width: 100%;
  }
}

.expand-btn{
  margin-top:.6rem;
  padding:.45rem .75rem;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.9);
  font-weight:600;
  cursor:pointer;
}
.expand-btn:hover{ filter:saturate(108%); }

.expand-btn{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  margin-top:.6rem;
  padding:.5rem .85rem;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.15);
  background: rgba(255,255,255,.75);      /* dunkler als vorher */
  color:#10211a;
  font-weight:700;
  cursor:pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,.10);
  backdrop-filter: saturate(115%) blur(2px);
  transition: transform .12s ease, filter .12s ease, box-shadow .12s ease;
}
.expand-btn:hover{
  transform: translateY(-1px);
  filter: saturate(108%);
  box-shadow: 0 10px 24px rgba(0,0,0,.14);
}
.expand-btn:focus-visible{
  outline:none;
  box-shadow: 0 0 0 3px rgba(123,211,137,.35), 0 8px 24px rgba(0,0,0,.12);
}
@media (prefers-color-scheme: dark){
  .expand-btn{
    background: rgba(18,20,28,.85);
    color:#e8ecf2;
    border-color: rgba(255,255,255,.18);
  }
}

@media (min-width: 900px){
  #gedanken .gedanke .media img{
    width: auto;
    max-width: clamp(360px, 42vw, 520px);  /* kleiner als vorher */
    max-height: 60vh;
    object-fit: contain;
    margin: .3rem auto;
    display:block;
  }
  #gedanken .gedanke video,
  #gedanken .gedanke audio{
    max-width: clamp(360px, 42vw, 520px);
    margin: .3rem auto;
    display:block;
  }
}

/* Gedanken: Typografie verfeinern */
#gedanken .gedanke .text{
  font-size: 1.06rem;
  line-height: 1.7;
  letter-spacing: .005em;
}
#gedanken .gedanke .text p{ margin: .6rem 0; }

/* Erste Zeile minimal größer & mehr Zeilenabstand */
#gedanken .gedanke .text p:first-of-type{
  font-size: 1.08rem;
  line-height: 1.75;
}

/* Fett & Kursiv etwas deutlicher */
#gedanken .gedanke .text strong{ font-weight: 800; }
#gedanken .gedanke .text em{ font-style: italic; opacity:.95; }

/* Listen (aus - item) */
#gedanken .gedanke .text ul{
  margin: .5rem 0 .5rem 1.1rem;
  padding: 0;
  list-style: disc;
}
#gedanken .gedanke .text li{ margin: .25rem 0; }

/* Zitate (aus > Zeilen) */
#gedanken .gedanke blockquote{
  margin: .7rem 0;
  padding: .6rem .8rem;
  border-left: 4px solid #7bd389; /* Mint */
  background: rgba(255,255,255,.65);
  border-radius: 10px;
}
@media (prefers-color-scheme: dark){
  #gedanken .gedanke blockquote{
    background: rgba(18,20,28,.55);
    border-left-color: #8de0a1;
  }
}

/* Links etwas markanter in Gedanken */
#gedanken .gedanke .text a{
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}

/* Expander harmonischer (falls noch nicht gesetzt) */
#gedanken .gedanke .expand-btn{
  display:inline-flex; align-items:center; gap:.4rem;
  margin-top:.7rem; padding:.5rem .9rem; border-radius:999px;
  border:1px solid rgba(0,0,0,.15);
  background: rgba(255,255,255,.78); color:#10211a; font-weight:700;
  cursor:pointer; box-shadow: 0 6px 18px rgba(0,0,0,.10);
  backdrop-filter: saturate(115%) blur(2px);
  transition: transform .12s ease, filter .12s ease, box-shadow .12s ease;
}
#gedanken .gedanke .expand-btn:hover{
  transform: translateY(-1px);
  filter: saturate(108%);
  box-shadow: 0 10px 24px rgba(0,0,0,.14);
}
@media (prefers-color-scheme: dark){
  #gedanken .gedanke .expand-btn{
    background: rgba(18,20,28,.85);
    color:#e8ecf2; border-color: rgba(255,255,255,.18);
  }
}

.reactions{display:flex;gap:.35rem;margin-top:.5rem;flex-wrap:wrap}
.react-btn{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.35rem .6rem;border-radius:999px;border:1px solid rgba(0,0,0,.08);
  background:rgba(255,255,255,.9);cursor:pointer;font-weight:600;line-height:1
}
.react-btn:hover{filter:saturate(108%)}
.react-count{opacity:.8;font-weight:600}

/* Gedanken-Section nur bei aktivem Tab zeigen */
#gedanken{ display:none; }