/* ===========================
   BKA BLOG – ISOLATED STYLES
   Prefix: blog_
   =========================== */

/* --- helpers --- */
.blog_wrap { max-width: 1100px; margin: 0 auto; padding: 0 18px; }
.blog_muted { color: var(--muted); }
.blog_pill {
  display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--muted);font-size:13px
}
.blog_dot{width:6px;height:6px;border-radius:999px;background:#546;opacity:.8}

/* ===========================
   ÜBERSICHT
   =========================== */

.blog_header {
  margin: 10px auto 16px;
  text-align:center;
}
.blog_header h1{
  margin:0 0 6px;
  font-size:clamp(28px,4.2vw,40px);
  color:#eceaff;
  letter-spacing:.3px;
}
.blog_header p{ margin:0; color:var(--muted) }

/* Tabs */
.blog_tabs{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:18px 0 10px }
.blog_tab{
  display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text);text-decoration:none;font-weight:600
}
.blog_tab:hover{ background:rgba(255,255,255,.06) }
.blog_tab.is-active{ background:linear-gradient(180deg,rgba(139,92,246,.22),rgba(124,58,237,.12)); border-color:#3a2f62 }

/* Grid */
.blog_grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:16px; margin:16px 0 24px }
.blog_card{
  position:relative; border:1px solid var(--line); border-radius:16px; overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  box-shadow:0 8px 28px rgba(0,0,0,.45), inset 0 0 12px rgba(139,92,246,.06);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  transform:translateY(6px); opacity:0;
}
.blog_card.blog_reveal{ transform:none; opacity:1; transition-delay:.05s }
.blog_card:hover{ transform:translateY(-4px); border-color:#3a2f62; box-shadow:0 16px 50px rgba(139,92,246,.28) }

.blog_card_cover{
  position:relative; height:170px; background-size:cover; background-position:center;
}
.blog_card_cover::after{
  content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 45%, rgba(0,0,0,.65));
}
.blog_card_cat{
  position:absolute; left:12px; top:12px; z-index:2;
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px; border-radius:999px; border:1px solid var(--line);
  background:rgba(15,12,31,.45); color:#ddd; backdrop-filter:blur(6px)
}
.blog_card_body{ padding:14px 14px 16px }
.blog_card_title{
  margin:0 0 6px; font-size:1.1rem; line-height:1.25; color:#eef; font-weight:800
}
.blog_card_meta{ display:flex; align-items:center; gap:8px; color:var(--muted); font-size:13px; margin-bottom:8px }
.blog_card_txt{ color:var(--text); opacity:.9 }
.blog_card_actions{ display:flex; align-items:center; justify-content:space-between; margin-top:14px }
.blog_btn{
  display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:12px;border:1px solid var(--line);
  background:rgba(255,255,255,.03); color:#fff; text-decoration:none; font-weight:700
}
.blog_btn:hover{ background:rgba(255,255,255,.06) }
.blog_btn.primary{ border-color:#3a2f62; background:linear-gradient(180deg,rgba(139,92,246,.2),rgba(124,58,237,.12)) }

/* ===========================
   POST / DETAIL
   =========================== */

.blog_post_header{ margin:4px 0 12px }
.blog_hero{
  position:relative;height:280px;border-radius:16px;overflow:hidden;
  box-shadow:0 16px 70px rgba(0,0,0,.45); isolation:isolate
}
@media (max-width:640px){ .blog_hero{ height:220px } }
.blog_hero_bg{ position:absolute; inset:0; background-image:var(--hero); background-size:cover; background-position:center; transform:scale(1.03) }
.blog_hero_glow{
  position:absolute; inset:-25% -12% -18% -12%;
  background:radial-gradient(50% 70% at 60% 90%, rgba(139,92,246,.22), transparent 60%),
             radial-gradient(40% 60% at 10% 20%, rgba(34,211,238,.16), transparent 70%);
  mix-blend-mode:screen; filter:blur(14px); animation:blog_float 18s ease-in-out infinite
}
@keyframes blog_float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
.blog_hero_badges{ position:absolute; left:16px; bottom:14px; z-index:2; display:flex; gap:8px; flex-wrap:wrap }
.blog_chip{
  display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--line);
  background:rgba(15,12,31,.45); backdrop-filter:blur(6px) saturate(120%); color:#d9dcf2; font-weight:600; font-size:.9rem
}
.blog_hero_fade{ position:absolute; left:0; right:0; bottom:0; height:56px; background:linear-gradient(180deg,transparent,rgba(0,0,0,.7)) }

.blog_post_title{ margin:14px 0 6px; font-size:clamp(30px,4.6vw,44px); color:#eef; letter-spacing:.2px }
.blog_post_meta{ display:flex; align-items:center; gap:10px; color:var(--muted) }

.blog_post_body{
  line-height:1.75;color:var(--text); margin-top:12px
}
.blog_post_body p{ margin:0 0 1em }
.blog_post_body h2,.blog_post_body h3{ margin:1.2em 0 .5em; color:#eceaff }
.blog_post_body blockquote{ margin:1em 0; padding:.6em .9em; border-left:3px solid #3a2f62; background:rgba(255,255,255,.03); border-radius:10px }
.blog_post_body img{ max-width:100%; height:auto; border-radius:12px; border:1px solid var(--line); display:block; margin:.6em auto }

.blog_actions{ display:flex; gap:10px; align-items:center; margin-top:16px }
.blog_like{
  display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;border:1px solid #3a2f62;
  background:rgba(139,92,246,.14); color:#fff; font-weight:700; cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease
}
.blog_like:hover{ transform:translateY(-1px); box-shadow:0 0 14px rgba(139,92,246,.22) }
.blog_like.liked{ background:linear-gradient(90deg, rgba(255,100,160,.28), rgba(139,92,246,.24)); border-color:#6a3fe0 }

/* Share */
.blog_share{ position:relative }
.blog_share_menu{
  position:absolute; right:0; top:calc(100% + 8px); min-width:240px; padding:10px; border-radius:14px;
  background:rgba(255,255,255,.04); border:1px solid var(--line); box-shadow:0 22px 90px rgba(0,0,0,.45);
  display:none; z-index:30
}
.blog_share_menu.show{ display:block }
.blog_share_item{
  display:flex; align-items:center; gap:10px; width:100%; padding:10px; border-radius:10px;
  background:transparent; border:0; color:var(--text); cursor:pointer; font-weight:600; text-align:left
}
.blog_share_item:hover{ background:rgba(255,255,255,.06) }
.blog_share_icon{ width:18px; height:18px; display:inline-block; }

/* Toast */
.blog_toast{
  position:fixed; left:50%; bottom:32px; transform:translateX(-50%) translateY(12px);
  background:rgba(0,0,0,.65); color:#fff; border:1px solid var(--line); padding:10px 14px; border-radius:10px;
  opacity:0; pointer-events:none; transition:opacity .2s ease, transform .2s ease; z-index:9999
}
.blog_toast.show{ opacity:1; transform:translateX(-50%) translateY(0) }

/* Grid als gestapelte Liste, deutliche Trennung */
.blog_grid.blog_grid--list{
  grid-template-columns: 1fr;          /* 1 Spalte: klare Stacks */
  gap: 26px;                            /* deutlicher Abstand */
  max-width: 900px;
  margin: 16px auto 28px;
}

/* Cards kräftiger umranden + „Ring“ */
.blog_card{
  border: 2px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  box-shadow:
    0 10px 34px rgba(0,0,0,.45),
    0 0 0 6px rgba(139,92,246,.06) inset;   /* innerer Ring für klare Abgrenzung */
}

/* sanftes Einblenden */
.blog_card{ transform: translateY(10px); opacity: 0; }
.blog_card.blog_reveal{ transform: none; opacity: 1; transition: transform .28s ease, opacity .28s ease; }

.blog_badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:999px;border:1px solid #352b63;
  background:rgba(139,92,246,.12);font-size:12px;color:#e6e4ff
}







.tts-bar{
  display:flex; align-items:center; gap:8px;
  padding:10px 12px; margin:0 0 12px;
  border-radius:12px; border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.02));
  box-shadow: var(--shadow-soft);
}
.tts-bar .btn{ padding:8px 12px; }
.tts-bar .tts-status{ margin-left:6px; }
.tts-bar .tts-opt{ display:flex; align-items:center; gap:6px; }
.tts-bar input[type="range"]{ vertical-align:middle; }
