/* ═══════════════════════════════════════════════
   MamaHerz – Hauptstylesheet
   ═══════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* ── Pink Watercolor Palette ── */
  --cream:            #fff8f6;
  --beige:            #fdeef0;
  --beige-dark:       #f5d5db;
  --rose:             #f2b8c6;
  --rose-deep:        #c4728a;
  --rose-muted:       #d4889a;
  --rose-light:       #fce8ee;
  --pink-soft:        #f9dde5;
  --warm-gray:        #8a6870;
  --warm-gray-light:  #c4aab2;
  --charcoal:         #4a2d35;
  --brown-soft:       #7a4858;
  --white:            #ffffff;
  --script:           'Dancing Script', cursive;
  --serif:            'Cormorant Garamond', Georgia, serif;
  --sans:             'DM Sans', sans-serif;
}

html { scroll-behavior: smooth; }
body { background: var(--cream); color: var(--charcoal); font-family: var(--sans); font-weight: 300; overflow-x: hidden; }

/* Pink watercolor body bg */
body::before { content: ""; position: fixed; inset: 0; background: radial-gradient(ellipse at 15% 20%, rgba(252,220,228,.18) 0%, transparent 50%), radial-gradient(ellipse at 85% 80%, rgba(245,200,215,.12) 0%, transparent 50%); pointer-events: none; z-index: 0; }
main, section, footer, .about, .hero-new { position: relative; z-index: 1; }

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--beige); }
::-webkit-scrollbar-thumb { background: linear-gradient(#d4889a,#c4728a); border-radius: 3px; }

/* ─── NAV ─── */
nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding: 0 5%; height: 70px; display: flex; align-items: center; justify-content: space-between; background: rgba(255,248,246,0.95); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(212,170,185,0.3); transition: box-shadow .3s; }
nav.scrolled { box-shadow: 0 4px 30px rgba(90,70,50,.08); }

.logo { font-family: var(--script); font-size: 1.7rem; font-weight: 600; color: var(--charcoal); letter-spacing: .01em; text-decoration: none; }
.logo span { color: var(--rose-deep); }

.nav-links { display: flex; gap: 2.5rem; list-style: none; }
.nav-links a { font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; color: #9a6878; text-decoration: none; transition: color .2s; position: relative; }
.nav-links a::after { content: ''; position: absolute; bottom: -3px; left: 0; right: 100%; height: 1px; background: var(--rose-deep); transition: right .3s ease; }
.nav-links a:hover, .nav-links a.active { color: var(--charcoal); }
.nav-links a:hover::after, .nav-links a.active::after { right: 0; }

.nav-cta { background: linear-gradient(135deg,#d4889a,#c4728a); color: white !important; padding: .55rem 1.6rem; border-radius: 40px; font-size: .78rem !important; letter-spacing: .12em !important; transition: all .2s !important; box-shadow: 0 4px 15px rgba(180,90,110,.2); }
.nav-cta:hover { background: linear-gradient(135deg,#c4788a,#b4627a) !important; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(180,90,110,.3) !important; }
.nav-cta::after { display: none !important; }

.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; background: none; border: none; padding: .3rem; }
.hamburger span { display: block; width: 24px; height: 1.5px; background: var(--charcoal); transition: all .3s; }

/* Mobile menu */
.mobile-menu { display: none; position: fixed; top: 70px; left: 0; right: 0; background: var(--cream); border-bottom: 1px solid var(--beige-dark); z-index: 99; flex-direction: column; padding: 1.5rem 6%; gap: 0; }
.mobile-menu.open { display: flex; }
.mobile-menu a { display: block; padding: 1rem 0; font-size: .9rem; letter-spacing: .08em; text-transform: uppercase; color: var(--charcoal); text-decoration: none; border-bottom: 1px solid var(--beige); }
.mobile-menu a:last-child { border-bottom: none; }

/* ─── HERO ─── */
.hero { min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr; overflow: hidden; }
.hero-left { display: flex; flex-direction: column; justify-content: center; padding: 8% 6% 8% 10%; animation: fadeUp 1s ease forwards; opacity: 0; }
.hero-right { position: relative; overflow: hidden; animation: fadeIn 1.2s ease .3s forwards; opacity: 0; }

@keyframes fadeUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.hero-eyebrow { font-size: .75rem; letter-spacing: .22em; text-transform: uppercase; color: var(--rose-deep); margin-bottom: 1.5rem; display: flex; align-items: center; gap: .8rem; }
.hero-eyebrow::before { content: ''; display: block; width: 40px; height: 1px; background: var(--rose-deep); }
.hero-title { font-family: var(--serif); font-size: clamp(2.8rem,5vw,4.2rem); font-weight: 300; line-height: 1.15; color: var(--charcoal); margin-bottom: 1.5rem; }
.hero-title em { font-style: italic; color: var(--rose-deep); }
.hero-sub { font-size: 1rem; line-height: 1.8; color: var(--warm-gray); max-width: 420px; margin-bottom: 3rem; }
.hero-buttons { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero-stats { display: flex; gap: 2.5rem; margin-top: 4rem; padding-top: 2.5rem; border-top: 1px solid var(--beige-dark); }
.hero-stat-num { font-family: var(--serif); font-size: 2rem; font-weight: 300; color: var(--charcoal); display: block; }
.hero-stat-label { font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--warm-gray-light); margin-top: .2rem; }

.hero-img-wrap { position: absolute; inset: 0; background: linear-gradient(135deg, #e8d5c8 0%, #d4b5a5 40%, #c9a090 100%); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.hero-photo-placeholder { width: 100%; height: 100%; position: relative; display: flex; align-items: flex-end; justify-content: center; }
.hero-illustration { position: absolute; bottom: 0; width: 75%; max-width: 380px; }
.hero-deco-circle { position: absolute; top: 12%; right: 10%; width: 180px; height: 180px; border-radius: 50%; background: rgba(255,255,255,.15); backdrop-filter: blur(10px); display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 4px; padding: 1.5rem; animation: float 4s ease-in-out infinite; }
@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
.hero-deco-circle .quote { font-family: var(--serif); font-size: 1rem; font-style: italic; color: white; line-height: 1.4; }
.hero-deco-circle .author { font-size: .65rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.7); }
.hero-tag { position: absolute; bottom: 15%; left: -20px; background: white; padding: 1rem 1.5rem; box-shadow: 0 15px 40px rgba(80,50,30,.12); display: flex; align-items: center; gap: .8rem; animation: slideIn 1s ease .8s forwards; opacity: 0; transform: translateX(-20px); }
@keyframes slideIn { to { opacity: 1; transform: translateX(0); } }
.hero-tag-icon { font-size: 1.5rem; }
.hero-tag-text strong { display: block; font-family: var(--serif); font-size: .95rem; font-weight: 600; color: var(--charcoal); }
.hero-tag-text span { font-size: .7rem; color: var(--warm-gray); letter-spacing: .05em; }

/* ─── BUTTONS ─── */
.btn-primary { display: inline-flex; align-items: center; gap: .7rem; background: linear-gradient(135deg,#d4889a,#c4728a); box-shadow: 0 6px 20px rgba(180,90,110,.25); color: var(--cream); padding: 1rem 2.2rem; font-family: var(--sans); font-size: .8rem; letter-spacing: .15em; text-transform: uppercase; text-decoration: none; border: none; cursor: pointer; transition: all .3s; position: relative; overflow: hidden; }
.btn-primary::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg,#d4889a,#c4728a); transform: translateX(-100%); transition: transform .3s ease; }
.btn-primary:hover::before { transform: translateX(0); }
.btn-primary span, .btn-primary svg { position: relative; z-index: 1; }
.btn-primary svg { transition: transform .3s; }
.btn-primary:hover svg { transform: translateX(4px); }

.btn-outline { display: inline-flex; align-items: center; gap: .7rem; border: 1.5px solid rgba(210,140,165,.4); color: var(--rose-deep); padding: .9rem 2rem; font-family: var(--sans); font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; text-decoration: none; cursor: pointer; background: transparent; transition: all .3s; }
.btn-outline:hover { border-color: var(--rose-deep); color: var(--charcoal); background: rgba(245,200,215,.2); }

/* ─── SECTION COMMONS ─── */
section { padding: 7rem 10%; }
.section-eyebrow { font-size: .7rem; letter-spacing: .22em; text-transform: uppercase; color: var(--rose-deep); margin-bottom: .8rem; display: flex; align-items: center; gap: .8rem; opacity: .85; }
.section-eyebrow::before { content: ''; display: inline-block; width: 28px; height: 1px; background: var(--rose-deep); }
.section-title { font-family: var(--script); font-size: clamp(2rem,3.5vw,2.8rem); font-weight: 600; line-height: 1.25; color: var(--charcoal); margin-bottom: 1.2rem; }
.section-title em { font-style: normal; color: var(--rose-deep); }
.section-sub { font-size: .95rem; color: var(--warm-gray); line-height: 1.8; max-width: 520px; }

/* ─── ABOUT ─── */
.about { background: linear-gradient(135deg, #fff0f3 0%, #fde8ee 50%, #fce0ea 100%); display: grid; grid-template-columns: 1fr 1fr; gap: 6%; align-items: center; padding: 7rem 10%; position: relative; overflow: hidden; }
.about::before { content: '♡'; position: absolute; font-family: var(--serif); font-size: 25rem; color: rgba(210,140,160,.08); top: -5rem; right: -2rem; line-height: 1; pointer-events: none; }
.about-img-frame { width: 100%; padding-bottom: 100%; position: relative; overflow: hidden; background: radial-gradient(circle at 50% 40%, rgba(252,228,235,.95), rgba(248,210,225,.9)); border-radius: 50%; box-shadow: 0 20px 60px rgba(180,90,120,.2), inset 0 0 40px rgba(255,220,230,.3); border: 3px solid rgba(240,180,200,.4); }
.about-img-deco { display: none; }
.about-img-badge { position: absolute; top: -15px; left: -15px; width: 100px; height: 100px; background: linear-gradient(135deg,#d4889a,#c4728a); color: white; border-radius: 50%; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; font-family: var(--serif); font-size: .75rem; line-height: 1.4; padding: 1rem; z-index: 2; }
.about-img-badge em { font-style: italic; font-size: 1.1rem; }
.about-illus { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.about-values { margin-top: 2.5rem; display: flex; flex-direction: column; gap: 1rem; }
.about-value { display: flex; align-items: flex-start; gap: 1rem; }
.about-value-icon { width: 36px; height: 36px; background: linear-gradient(135deg,#f0b8c8,#e0a0b5); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1rem; flex-shrink: 0; margin-top: 2px; }
.about-value-text strong { display: block; font-size: .9rem; font-weight: 500; color: var(--charcoal); margin-bottom: .15rem; }
.about-value-text span { font-size: .82rem; color: var(--warm-gray); line-height: 1.7; }

/* ─── CATEGORIES SECTION ─── */
.categories-section { background: linear-gradient(145deg, #4a2535 0%, #5a3045 50%, #4a2535 100%); padding: 6rem 10%; position: relative; overflow: hidden; }
.categories-section::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 20%, rgba(210,130,160,.15) 0%, transparent 50%), radial-gradient(ellipse at 20% 80%, rgba(180,100,130,.1) 0%, transparent 50%); pointer-events: none; }
.categories-section .section-eyebrow { color: rgba(240,175,195,.8); }
.categories-section .section-eyebrow::before { background: rgba(240,175,195,.8); }
.cats-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1rem;
  margin-top: 2.5rem;
}
.cat-card {
  position: relative;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(240,160,180,.15);
  padding: 1.8rem 1rem;
  text-align: center;
  cursor: pointer;
  overflow: hidden;
  transition: all .3s;
  border-radius: 8px;
}
.cat-card::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg,#d4889a,#c4728a); opacity: 0; transition: opacity .3s; }
.cat-card:hover::before { opacity: 1; }
.cat-card > * { position: relative; z-index: 1; }
.cat-icon { font-size: 2rem; display: block; margin-bottom: .7rem; }
.cat-name { font-family: var(--sans); font-size: .82rem; font-weight: 400; color: var(--cream); letter-spacing: .05em; display: block; margin-bottom: .25rem; }
.cat-count { font-size: .65rem; color: rgba(255,255,255,.45); display: block; }

/* ─── POST CARDS ─── */
.posts-section { background: linear-gradient(180deg, #fff8fa 0%, #fff4f6 100%); padding: 6rem 10%; }
.posts-header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 3rem; }
.posts-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.6rem; }
.posts-link { font-size: .78rem; letter-spacing: .15em; text-transform: uppercase; color: var(--rose-deep); text-decoration: none; border-bottom: 1px solid rgba(196,114,138,.4); padding-bottom: 2px; white-space: nowrap; }

.post-card {
  background: white;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(180,90,120,.07);
  transition: transform .35s, box-shadow .35s;
  display: flex;
  flex-direction: column;
}
.post-card:hover { transform: translateY(-6px); box-shadow: 0 16px 48px rgba(180,90,120,.14); }

.post-card.large { grid-column: span 2; }
.post-card.large .post-card-img { padding-bottom: 52%; }
.post-card.large .post-card-title { font-size: 1.6rem; }

.post-card-img-link { display: block; }
.post-card-img {
  position: relative;
  padding-bottom: 62%;
  overflow: hidden;
}
.post-card-img-inner {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
}
.post-card-img-inner img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}
.post-card:hover .post-card-img-inner img { transform: scale(1.05); }

.post-card-body {
  padding: 1.4rem 1.5rem 1.6rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.post-card-cat {
  display: inline-block;
  font-size: .62rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--rose-deep);
  background: rgba(210,130,155,.1);
  padding: .28rem .85rem;
  margin-bottom: .9rem;
  text-decoration: none;
  border-radius: 20px;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.post-card-cat:hover { background: rgba(210,130,155,.2); }

.post-card-title {
  font-family: var(--script);
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--charcoal);
  line-height: 1.35;
  margin-bottom: .7rem;
  flex: 1;
}
.post-card-title a { color: inherit; text-decoration: none; }
.post-card-title a:hover { color: var(--rose-deep); }

.post-card-excerpt {
  font-size: .82rem;
  color: var(--warm-gray);
  line-height: 1.7;
  margin-bottom: 1.1rem;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.post-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 1rem;
  border-top: 1px solid rgba(210,140,165,.15);
  margin-top: auto;
}
.post-card-date { font-size: .7rem; color: var(--warm-gray-light); }
.read-more {
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--rose-deep);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: .3rem;
  transition: gap .2s;
}
.read-more:hover { gap: .6rem; }

/* Ähnliche Artikel grid — 3 equal cards */
.related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 2.5rem;
}
.related-grid .post-card.large { grid-column: span 1; }
.related-grid .post-card.large .post-card-img { padding-bottom: 62%; }
.related-grid .post-card.large .post-card-title { font-size: 1.3rem; }

/* ─── POPULAR ─── */
.popular-section { background: linear-gradient(160deg, #fff4f6 0%, #fde8ed 100%); padding: 7rem 10%; }
.popular-header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 3rem; flex-wrap: wrap; gap: 1rem; }
.popular-list { display: flex; flex-direction: column; }
.popular-item { display: grid; grid-template-columns: 60px 80px 1fr 30px; align-items: center; gap: 2rem; padding: 1.8rem 0; border-bottom: 1px solid rgba(210,140,165,.2); cursor: pointer; transition: all .2s; }
.popular-item:first-child { border-top: 1px solid rgba(210,140,165,.2); }
.popular-item:hover { background: rgba(255,220,230,.25); margin: 0 -2rem; padding-left: 2rem; padding-right: 2rem; }
.popular-num { font-family: var(--script); font-size: 2.5rem; font-weight: 600; color: var(--rose-deep); line-height: 1; opacity: .7; }
.popular-cat { font-size: .65rem; letter-spacing: .15em; text-transform: uppercase; color: var(--rose-deep); margin-bottom: .3rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.popular-title { font-family: var(--script); font-size: 1.25rem; font-weight: 600; color: var(--charcoal); line-height: 1.3; }
.popular-meta { font-size: .72rem; color: var(--warm-gray-light); margin-top: .3rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.popular-arrow { color: rgba(210,140,165,.5); font-size: 1.2rem; transition: all .2s; }
.popular-item:hover .popular-arrow { color: var(--rose-deep); transform: translateX(5px) scale(1.2); }

/* ─── NEWSLETTER ─── */
.newsletter-section { background: linear-gradient(135deg, #f0b8c8 0%, #e090a8 35%, #d07090 65%, #c06080 100%); padding: 8rem 10%; text-align: center; position: relative; overflow: hidden; }
.newsletter-section::before { content: '🌸'; position: absolute; font-size: 25rem; color: rgba(255,255,255,.06); top: -8rem; left: 50%; transform: translateX(-50%); pointer-events: none; font-family: serif; }
.newsletter-inner { max-width: 600px; margin: 0 auto; position: relative; z-index: 1; }
.newsletter-text { font-size: 1rem; color: rgba(255,255,255,.85); line-height: 1.8; margin-bottom: 2.5rem; }
.newsletter-form { display: flex; gap: 0; max-width: 480px; margin: 0 auto; }
.newsletter-input { flex: 1; padding: 1.1rem 1.5rem; border: 1px solid rgba(90,60,40,.2); background: rgba(255,255,255,.7); font-family: var(--sans); font-size: .88rem; color: var(--charcoal); outline: none; transition: all .3s; width: 100%; }
.newsletter-input:focus { background: white; border-color: var(--rose-deep); }
.newsletter-input::placeholder { color: var(--warm-gray-light); }
.newsletter-btn { background: rgba(255,255,255,.2); backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,.3); color: white; border: none; padding: 1.1rem 1.8rem; font-family: var(--sans); font-size: .75rem; letter-spacing: .15em; text-transform: uppercase; cursor: pointer; transition: background .3s; white-space: nowrap; }
.newsletter-btn:hover { background: rgba(255,255,255,.35); }
.newsletter-privacy { font-size: .72rem; color: rgba(255,255,255,.65); margin-top: 1rem; }

/* ─── FOOTER ─── */
footer { background: linear-gradient(160deg, #4a2535 0%, #5a3045 60%, #4a2535 100%); color: rgba(255,255,255,.55); padding: 5rem 10% 2.5rem; position: relative; overflow: hidden; }
footer::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 90% 10%, rgba(210,130,160,.12) 0%, transparent 50%); pointer-events: none; }
.footer-top { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 4rem; padding-bottom: 4rem; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 2rem; }
.footer-brand p { font-size: .83rem; line-height: 1.8; max-width: 240px; margin-top: .8rem; }
.footer-brand-socials { display: flex; gap: .8rem; margin-top: 1.5rem; }
.footer-social-btn { width: 36px; height: 36px; border: 1px solid rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; font-size: .8rem; cursor: pointer; transition: all .2s; text-decoration: none; color: rgba(255,255,255,.5); }
.footer-social-btn:hover { border-color: rgba(240,160,185,.8); color: rgba(240,160,185,.9); background: rgba(240,160,185,.08); }
.footer-col h4 { font-family: var(--serif); font-size: 1rem; color: var(--cream); margin-bottom: 1.2rem; font-weight: 400; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: .7rem; }
.footer-col ul a { font-size: .8rem; color: rgba(255,255,255,.4); text-decoration: none; transition: color .2s; }
.footer-col ul a:hover { color: var(--rose); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; font-size: .72rem; flex-wrap: wrap; gap: 1rem; }
.footer-bottom a { color: rgba(255,255,255,.3); text-decoration: none; }
.footer-bottom a:hover { color: var(--rose); }
.heart { color: #f0a0c0; animation: heartbeat 1.5s ease-in-out infinite; display: inline-block; }
@keyframes heartbeat { 0%,100% { transform: scale(1); } 50% { transform: scale(1.2); } }

/* ─── PAGE HERO ─── */
.page-hero { background: var(--beige); padding: 6rem 10% 5rem; text-align: center; }
.page-hero-content { max-width: 700px; margin: 0 auto; }

/* ─── BLOG CONTROLS ─── */
.blog-controls { margin-bottom: 0; }
.search-form { display: flex; gap: 0; max-width: 400px; margin-bottom: 1.5rem; }
.search-input { flex: 1; padding: .85rem 1.2rem; border: 1px solid var(--beige-dark); background: white; font-family: var(--sans); font-size: .88rem; outline: none; }
.search-input:focus { border-color: var(--rose-deep); }
.search-btn { background: var(--charcoal); color: white; border: none; padding: .85rem 1.2rem; cursor: pointer; font-size: 1rem; }
.cat-filter { display: flex; gap: .5rem; flex-wrap: wrap; }
.cat-pill { display: inline-block; padding: .45rem 1rem; border: 1px solid var(--beige-dark); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--warm-gray); text-decoration: none; transition: all .2s; background: white; }
.cat-pill:hover, .cat-pill.active { background: var(--charcoal); color: white; border-color: var(--charcoal); }

/* ─── PAGINATION ─── */
.pagination { display: flex; justify-content: center; gap: .5rem; margin-top: 4rem; }
.page-btn { width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--beige-dark); font-size: .85rem; text-decoration: none; color: var(--warm-gray); transition: all .2s; background: white; }
.page-btn:hover, .page-btn.active { background: var(--charcoal); color: white; border-color: var(--charcoal); }

/* ─── POST PAGE ─── */
.post-hero { min-height: 420px; }
.post-layout { display: grid; grid-template-columns: 1fr 300px; gap: 5rem; padding: 5rem 10%; max-width: 1400px; margin: 0 auto; }
.post-lead { font-family: var(--serif); font-size: 1.25rem; font-style: italic; color: var(--warm-gray); line-height: 1.7; margin-bottom: 2.5rem; padding-bottom: 2rem; border-bottom: 1px solid var(--beige-dark); }
.post-body { font-size: .95rem; line-height: 1.9; color: #4a4540; }
.post-body h2 { font-family: var(--script); font-size: 1.9rem; font-weight: 600; color: var(--charcoal); margin: 2.5rem 0 1rem; }
.post-body p { margin-bottom: 1.3rem; }
.post-body ul, .post-body ol { margin: 1rem 0 1.3rem 1.5rem; }
.post-body li { margin-bottom: .5rem; }
.post-body strong { font-weight: 500; color: var(--charcoal); }
.post-body em { font-style: italic; color: #c4728a; }
.post-body blockquote { border-left: 3px solid #d4889a; padding: 1rem 1.5rem; margin: 2rem 0; background: var(--beige); font-family: var(--serif); font-style: italic; font-size: 1.1rem; }
.post-body a { color: var(--rose-deep); }
.post-share { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--beige-dark); display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.post-share span { font-size: .78rem; text-transform: uppercase; letter-spacing: .1em; color: var(--warm-gray); }
.share-btn { padding: .5rem 1.2rem; border: 1px solid var(--beige-dark); font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; color: var(--warm-gray); text-decoration: none; transition: all .2s; }
.share-btn:hover { background: var(--charcoal); color: white; border-color: var(--charcoal); }

/* Sidebar */
.post-sidebar { display: flex; flex-direction: column; gap: 2rem; }
.sidebar-widget { background: var(--beige); padding: 1.8rem; }
.sidebar-title { font-family: var(--script); font-size: 1.3rem; font-weight: 600; color: var(--charcoal); margin-bottom: 1.2rem; padding-bottom: .8rem; border-bottom: 1px solid rgba(210,140,165,.3); }
.sidebar-cat-link { display: flex; align-items: center; gap: .8rem; padding: .6rem 0; border-bottom: 1px solid rgba(224,208,189,.5); font-size: .82rem; color: var(--charcoal); text-decoration: none; transition: color .2s; }
.sidebar-cat-link:hover { color: var(--rose-deep); }
.sidebar-cat-link:last-child { border-bottom: none; }

/* ─── REVEAL ─── */
.reveal { opacity: 0; transform: translateY(25px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ─── CONTACT ─── */
.contact-form-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: start; }
.contact-input { width: 100%; padding: 1rem 1.2rem; border: 1px solid var(--beige-dark); background: white; font-family: var(--sans); font-size: .9rem; color: var(--charcoal); outline: none; margin-bottom: 1rem; transition: border-color .2s; }
.contact-input:focus { border-color: var(--rose-deep); }
.contact-textarea { resize: vertical; min-height: 160px; }
.admin-alert { padding: 1rem 1.5rem; margin-bottom: 1.5rem; font-size: .88rem; }
.admin-alert.success { background: rgba(120,180,120,.15); color: #4a7a4a; border-left: 3px solid #6aaa6a; }
.admin-alert.error { background: rgba(200,100,80,.1); color: #8a4a40; border-left: 3px solid var(--rose-deep); }

/* ─── RESPONSIVE ─── */

/* ─── LOGO BY ─── */
.logo-by { font-family: var(--sans); font-size: .52rem; letter-spacing: .15em; text-transform: uppercase; font-style: normal; color: var(--warm-gray); }
nav .logo-by { font-size: .56rem; margin-left: .35rem; vertical-align: middle; opacity: .65; }
footer .logo { color: var(--cream) !important; font-size: 2rem; display: block; margin-bottom: .4rem; font-family: var(--serif); text-decoration: none; }
footer .logo .logo-ch { color: var(--rose) !important; font-style: italic; }
footer .logo .logo-by { color: rgba(255,255,255,.38) !important; font-size: .58rem; display: block; margin-top: .3rem; letter-spacing: .14em; font-family: var(--sans); font-style: normal; font-weight: 300; }

/* ─── VISITOR COUNTER ─── */
.footer-visitors {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  margin: 1.5rem 0 1.8rem;
  padding: 1rem 1.3rem;
  background: rgba(255,200,215,.06);
  border: 1px solid rgba(240,160,185,.12);
}
.visitor-dot { width: 7px; height: 7px; background: #f0a0c0; border-radius: 50%; flex-shrink: 0; animation: vpulse 2s infinite; }
@keyframes vpulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.7)} }
.visitor-stat { display: flex; flex-direction: column; gap: .12rem; }
.visitor-stat + .visitor-stat { border-left: 1px solid rgba(255,255,255,.1); padding-left: 1.4rem; }
.visitor-num { font-family: var(--serif); font-size: 1.7rem; font-weight: 300; color: var(--cream); line-height: 1; }
.visitor-label { font-size: .6rem; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.3); }

/* ─── COOKIES NOTICE ─── */
.cookie-notice {
  position: fixed;
  bottom: 1.8rem;
  left: 1.8rem;
  z-index: 9999;
  background: linear-gradient(135deg, #5a2d3d, #4a2535);
  padding: 1.4rem 1.6rem;
  max-width: 340px;
  display: none;
  align-items: flex-start;
  gap: 1rem;
  box-shadow: 0 20px 60px rgba(10,5,0,.4);
  animation: cookieUp .5s cubic-bezier(.22,.68,0,1.2) forwards;
  transition: transform .3s, opacity .3s;
}
.cookie-notice.show { display: flex; }
@keyframes cookieUp { from{transform:translateY(20px);opacity:0} to{transform:translateY(0);opacity:1} }
.cookie-emoji { font-size: 1.8rem; flex-shrink: 0; }
.cookie-body { flex: 1; }
.cookie-body strong { display: block; font-family: var(--serif); font-size: 1rem; color: var(--cream); margin-bottom: .3rem; }
.cookie-body p { font-size: .75rem; color: rgba(255,255,255,.45); line-height: 1.6; margin: 0 0 .9rem; }
.cookie-actions { display: flex; align-items: center; gap: .8rem; }
.cookie-accept { background: linear-gradient(135deg,#e090a8,#d07090); color: white; border: none; padding: .55rem 1.2rem; font-family: var(--sans); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; cursor: pointer; transition: background .2s; }
.cookie-accept:hover { background: linear-gradient(135deg,#d080a0,#c06080); }
.cookie-decline { font-size: .7rem; color: rgba(255,255,255,.3); text-decoration: none; }
.cookie-decline:hover { color: rgba(255,255,255,.6); }
.cookie-close { position: absolute; top: .7rem; right: .8rem; background: none; border: none; color: rgba(255,255,255,.2); cursor: pointer; font-size: 1rem; }
.cookie-close:hover { color: rgba(255,255,255,.5); }

/* ─── IMAGE PLACEHOLDERS ─── */
.post-img-pattern { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .5rem; overflow: hidden; }
.post-img-pattern::before { content:''; position:absolute; width:200px; height:200px; border-radius:50%; border:1px solid rgba(255,255,255,.12); top:-50px; right:-50px; }
.post-img-pattern::after { content:''; position:absolute; width:130px; height:130px; border-radius:50%; border:1px solid rgba(255,255,255,.08); bottom:-30px; left:-20px; }
.post-img-pattern .big-icon { font-size: 3rem; opacity: .6; position: relative; z-index: 1; }
.post-img-pattern .cat-tag { font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.7); background: rgba(0,0,0,.12); padding: .25rem .8rem; border-radius: 20px; position: relative; z-index: 1; }
.post-img-pattern .title-preview { font-family: var(--serif); font-size: 1rem; color: rgba(255,255,255,.8); text-align: center; padding: 0 1.2rem; line-height: 1.4; max-width: 90%; position: relative; z-index: 1; }

/* ─── YOUTUBE ─── */
.yt-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; margin-top: 1rem; }
.yt-card { background: white; overflow: hidden; transition: transform .4s, box-shadow .4s; }
.yt-card:hover { transform: translateY(-6px); box-shadow: 0 20px 50px rgba(80,50,30,.1); }
.yt-thumb { display: block; width: 100%; padding-bottom: 56.25%; position: relative; overflow: hidden; cursor: pointer; background: #111; }
.yt-thumb img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.yt-play-btn { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 56px; height: 56px; background: rgba(255,0,0,.9); color: white; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; padding-left: 3px; transition: transform .2s, background .2s; }
.yt-thumb:hover .yt-play-btn { transform: translate(-50%,-50%) scale(1.1); background: red; }
.yt-card-body { padding: 1.4rem; }
.yt-title { font-family: var(--serif); font-size: 1.1rem; font-weight: 400; color: var(--charcoal); line-height: 1.4; margin: .4rem 0; }
.yt-desc { font-size: .82rem; color: var(--warm-gray); line-height: 1.7; }
.yt-subscribe-banner { display: flex; align-items: center; gap: 2rem; background: var(--beige); padding: 2.5rem 3rem; margin-top: 4rem; flex-wrap: wrap; }
.yt-sub-icon { width: 66px; height: 66px; background: red; color: white; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.6rem; flex-shrink: 0; padding-left: 3px; }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — Mobile First
   ═══════════════════════════════════════════════════════════ */

/* ─── Tablet 1024px ─── */
@media (max-width: 1024px) {
  .nav-links { gap: 1.5rem; }
  .nav-links a { font-size: .75rem; }
  .hero { min-height: 80vh; }
  .hero-left { padding: 6% 5% 6% 7%; }
  .posts-grid { grid-template-columns: 1fr 1fr; }
  .post-card.large { grid-column: span 2; }
  .cats-grid { grid-template-columns: repeat(3,1fr) !important; }
  .about { gap: 4%; }
  .post-layout { grid-template-columns: 1fr 260px; gap: 3rem; }
  .footer-top { grid-template-columns: 1.2fr 1fr 1fr; gap: 2.5rem; }
}

/* ─── Mobile 768px ─── */
@media (max-width: 768px) {

  /* Nav */
  nav { padding: 0 5%; height: 62px; }
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .logo { font-size: 1.25rem; }
  nav .logo-by { font-size: .5rem; }
  .mobile-menu { top: 62px; padding: 1rem 5%; }
  .mobile-menu a { padding: .85rem 0; font-size: .85rem; }

  /* Hero */
  .hero { grid-template-columns: 1fr; margin-top: 62px; min-height: auto; }
  .hero-right { min-height: 60vw; max-height: 280px; order: -1; }
  .hero-left { padding: 2.5rem 5% 4rem; order: 1; }
  .hero-title { font-size: clamp(1.9rem, 7.5vw, 2.8rem); margin-bottom: 1rem; }
  .hero-sub { font-size: .88rem; margin-bottom: 2rem; max-width: 100%; }
  .hero-buttons { gap: .7rem; }
  .btn-primary { padding: .8rem 1.4rem; font-size: .75rem; }
  .btn-outline { padding: .75rem 1.3rem; font-size: .75rem; }
  .hero-stats { gap: 1.5rem; margin-top: 2rem; padding-top: 1.5rem; }
  .hero-stat-num { font-size: 1.5rem; }
  .hero-deco-circle { width: 120px; height: 120px; top: 6%; right: 4%; padding: .8rem; }
  .hero-deco-circle .quote { font-size: .8rem; }
  .hero-tag { display: none; }

  /* Sections */
  section { padding: 4rem 5%; }
  .section-title { font-size: clamp(1.7rem, 6vw, 2.2rem); }

  /* About */
  .about { grid-template-columns: 1fr; padding: 4rem 5%; gap: 2.5rem; }
  .about-img-wrap { max-width: 300px; margin: 0 auto; }
  .about-img-frame { padding-bottom: 100%; border-radius: 50%; }
  .about::before { display: none; }

  /* Post Cards — Mobile */
  .posts-section { padding: 3.5rem 4%; }
  .posts-header { flex-direction: column; align-items: flex-start; margin-bottom: 1.5rem; gap: .5rem; }
  .posts-grid { grid-template-columns: 1fr !important; gap: 1.1rem; }
  .post-card { border-radius: 10px; }
  .post-card.large { grid-column: span 1 !important; }
  .post-card.large .post-card-img { padding-bottom: 58%; }
  .post-card.large .post-card-title { font-size: 1.35rem; }
  .post-card-img { padding-bottom: 55%; }
  .post-card-body { padding: 1.1rem 1.2rem 1.3rem; }
  .post-card-title { font-size: 1.15rem; line-height: 1.35; }
  .post-card-excerpt { font-size: .8rem; -webkit-line-clamp: 2; margin-bottom: .8rem; }
  .post-card-cat { font-size: .6rem; padding: .22rem .75rem; }
  .post-card-date { font-size: .67rem; }
  .read-more { font-size: .67rem; }

  /* Ähnliche Artikel — mobile: 1 column */
  .related-grid { grid-template-columns: 1fr !important; gap: 1rem; }

  /* Categories */
  .categories-section { padding: 3rem 4%; }
  .cats-grid { grid-template-columns: repeat(2,1fr) !important; gap: .6rem !important; margin-top: 1.8rem; }
  .cat-card { padding: 1.2rem .8rem; border-radius: 8px; }
  .cat-icon { font-size: 1.7rem; }
  .cat-name { font-size: .78rem; }
  .cat-count { font-size: .6rem; }

  /* Popular Posts — COMPLETELY FIXED */
  .popular-section { padding: 4rem 5%; }
  .popular-header { flex-direction: column; align-items: flex-start; gap: .5rem; margin-bottom: 1.5rem; }
  .popular-item {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1rem 0 !important;
    grid-template-columns: none !important;
  }
  .popular-img-thumb { display: none !important; }
  .popular-arrow { display: none !important; }
  .popular-num {
    font-size: 1.4rem !important;
    width: 36px !important;
    min-width: 36px !important;
    flex-shrink: 0 !important;
    text-align: center !important;
    line-height: 1 !important;
  }
  .popular-content {
    flex: 1 !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }
  .popular-cat {
    font-size: .6rem !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    display: block !important;
    margin-bottom: .2rem !important;
  }
  .popular-title {
    font-size: .9rem !important;
    line-height: 1.35 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }
  .popular-meta {
    font-size: .67rem !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    margin-top: .2rem !important;
  }

  /* Newsletter */
  .newsletter-section { padding: 4.5rem 5%; }
  .newsletter-section .section-title { font-size: 1.8rem; }
  .newsletter-form { flex-direction: column; max-width: 100%; }
  .newsletter-btn { width: 100%; padding: 1rem; }

  /* Post page */
  .post-hero { min-height: 260px; }
  .post-layout { grid-template-columns: 1fr; padding: 2.5rem 5%; gap: 2rem; }
  .post-sidebar { order: -1; }
  .post-lead { font-size: 1rem; }
  .post-body { font-size: .88rem; }
  .post-body h2 { font-size: 1.35rem; }

  /* Blog */
  .search-form { max-width: 100%; }
  .cat-pill { font-size: .65rem; padding: .38rem .75rem; }

  /* Footer */
  footer { padding: 3.5rem 5% 2rem; }
  .footer-top { grid-template-columns: 1fr; gap: 2rem; padding-bottom: 2.5rem; }
  .footer-brand p { max-width: 100%; font-size: .82rem; }
  .footer-visitors { gap: 1.2rem; margin: 1.2rem 0 1.5rem; padding: .9rem 1.1rem; flex-wrap: wrap; }
  .visitor-num { font-size: 1.4rem; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: .7rem; font-size: .7rem; }
  .footer-brand-socials { gap: .6rem; margin-top: 1.2rem; }

  /* Cookie */
  .cookie-notice { left: .8rem; right: .8rem; bottom: .8rem; max-width: none; padding: 1.1rem 1.2rem; }
  .cookie-emoji { font-size: 1.5rem; }

  /* Contact */
  .contact-form-wrap { grid-template-columns: 1fr; gap: 2rem; }

  /* YouTube */
  .yt-grid { grid-template-columns: 1fr; }
  .yt-subscribe-banner { flex-direction: column; text-align: center; padding: 2rem 1.5rem; gap: 1rem; }

  /* Page hero */
  .page-hero { padding: 5rem 5% 3.5rem; }
}

/* ─── Small Mobile 480px ─── */
@media (max-width: 480px) {
  nav { padding: 0 4%; }
  .logo { font-size: 1.1rem; }
  section { padding: 3rem 4%; }
  footer { padding: 3rem 4% 1.5rem; }
  .cats-grid { gap: .5rem; }
  .cat-card { padding: 1rem .6rem; }
  .cat-name { font-size: .75rem; }
  .hero-left { padding: 2rem 4% 3rem; }
  .hero-deco-circle { display: none; }
  .hero-title { font-size: 1.75rem; }
  .hero-sub { font-size: .85rem; }
  .hero-stat-num { font-size: 1.3rem; }
  .btn-primary, .btn-outline { padding: .75rem 1.2rem; font-size: .72rem; }
  .newsletter-section { padding: 3.5rem 4%; }
  .post-layout { padding: 2rem 4%; }
  .cookie-notice { left: .5rem; right: .5rem; }

  /* Popular — small mobile */
  .cats-grid { grid-template-columns: repeat(2,1fr) !important; gap: .5rem !important; }
  .cat-card { padding: 1rem .6rem; }
  .cat-icon { font-size: 1.5rem; }
  .popular-section { padding: 3rem 4%; }
  .popular-num { font-size: 1.2rem !important; width: 28px !important; min-width: 28px !important; }
  .popular-title { font-size: .85rem !important; }
  .popular-meta { font-size: .63rem !important; }

  /* Post cards — small mobile */
  .post-card-body { padding: 1rem; }
  .post-card-title { font-size: 1rem; }
  .section-title { font-size: 1.6rem; }
  .posts-section { padding: 3rem 4%; }
  .categories-section { padding: 3rem 4%; }
}

/* ─── Admin ─── */
@media (max-width: 900px) {
  .admin-layout { grid-template-columns: 1fr; }
  .admin-sidebar { display: none; }
  .admin-stats { grid-template-columns: repeat(2,1fr); }
  .post-edit-form { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════
   NEW HERO — Watercolor / Floral Style
   ═══════════════════════════════════════════════════════════ */

.hero-new {
  position: relative;
  min-height: calc(100vh - 70px);
  background: linear-gradient(155deg, #fff8f6 0%, #fdf0ee 35%, #fce8e8 65%, #f9e0e5 100%);
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 3rem 0;
}
.hero-new::before {
  content: '';
  position: absolute;
  top: -10%; right: -5%;
  width: 65%; height: 110%;
  background: radial-gradient(ellipse at 60% 40%, rgba(245,195,200,.35) 0%, rgba(240,180,190,.2) 40%, transparent 70%);
  border-radius: 40% 60% 55% 45% / 50% 45% 55% 50%;
  pointer-events: none;
}

.floral-tl { position: absolute; top: -10px; left: -10px; width: 220px; height: 220px; pointer-events: none; z-index: 1; opacity: .85; }
.floral-br { position: absolute; bottom: 20px; right: 20px; width: 180px; height: 180px; pointer-events: none; z-index: 1; opacity: .7; }

.hero-new-inner {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: 1.1fr 1fr;
  align-items: center;
  width: 100%; max-width: 1300px;
  margin: 0 auto;
  padding: 0 6%;
  gap: 2rem;
}

.hero-new-left { animation: hnFadeUp .9s ease forwards; opacity: 0; }
@keyframes hnFadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }

.hero-new-logo { display: flex; align-items: flex-end; gap: .5rem; margin-bottom: .4rem; }
.hero-new-logo-text { font-family: 'Dancing Script',cursive; font-size: clamp(3rem,5.5vw,5rem); font-weight: 700; color: #b8637a; line-height: 1; text-shadow: 2px 3px 8px rgba(180,90,110,.15); }
.hero-new-heart { width: 34px; height: 34px; margin-bottom: .5rem; flex-shrink: 0; animation: heartFloat 3s ease-in-out infinite; }
@keyframes heartFloat { 0%,100%{transform:translateY(0) scale(1)} 50%{transform:translateY(-6px) scale(1.1)} }
.hero-new-tagline { font-family:'DM Sans',sans-serif; font-size:.78rem; letter-spacing:.28em; color:#b8637a; opacity:.7; margin-bottom:2rem; text-transform:uppercase; }

/* Search bar */
.hero-search-form { display:flex; gap:0; max-width:420px; margin-bottom:2.5rem; }
.hero-search-input { flex:1; padding:.95rem 1.4rem; border:1.5px solid rgba(185,100,120,.2); background:rgba(255,255,255,.8); backdrop-filter:blur(8px); border-radius:40px 0 0 40px; font-family:'DM Sans',sans-serif; font-size:.88rem; color:#5a3540; outline:none; transition:all .3s; box-shadow:0 4px 20px rgba(180,90,110,.07); }
.hero-search-input:focus { border-color:rgba(185,100,120,.5); background:white; }
.hero-search-input::placeholder { color:rgba(155,90,105,.45); }
.hero-search-btn { padding:.95rem 1.3rem; background:linear-gradient(135deg,#d4889a,#c4728a); border:none; border-radius:0 40px 40px 0; color:white; cursor:pointer; transition:all .2s; box-shadow:0 4px 18px rgba(180,90,110,.22); }
.hero-search-btn:hover { background:linear-gradient(135deg,#c4788a,#b4627a); }

/* Category circles */
.hero-cats { display:flex; gap:1rem; flex-wrap:wrap; }
.hero-cat-pill { display:flex; flex-direction:column; align-items:center; gap:.35rem; text-decoration:none; transition:transform .3s; }
.hero-cat-pill:hover { transform:translateY(-5px); }
.hero-cat-icon { width:70px; height:70px; border-radius:50%; background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(252,230,238,.9)); display:flex; align-items:center; justify-content:center; font-size:1.7rem; box-shadow:0 6px 22px rgba(180,90,110,.14); border:2px solid rgba(210,150,165,.25); transition:all .3s; }
.hero-cat-pill:hover .hero-cat-icon { box-shadow:0 10px 30px rgba(180,90,110,.25); border-color:rgba(210,150,165,.5); }
.hero-cat-name { font-family:'Dancing Script',cursive; font-size:.95rem; color:#b8637a; font-weight:600; text-align:center; }
.hero-cat-sub { font-family:'DM Sans',sans-serif; font-size:.52rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(180,100,120,.5); text-align:center; }

/* RIGHT — circular image */
.hero-new-right { display:flex; justify-content:center; align-items:center; animation:hnFadeIn 1.1s ease .3s forwards; opacity:0; }
@keyframes hnFadeIn { from{opacity:0;transform:scale(.96)} to{opacity:1;transform:scale(1)} }

.hero-circle-outer {
  position: relative;
  width: min(460px, 45vw);
  aspect-ratio: 1;
}

/* Big glowing circle background */
.hero-circle-outer::before {
  content: '';
  position: absolute;
  inset: -15px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(245,195,210,.55) 0%, rgba(238,175,195,.3) 50%, transparent 70%);
  animation: circleGlow 5s ease-in-out infinite;
}
@keyframes circleGlow { 0%,100%{transform:scale(1);opacity:.8} 50%{transform:scale(1.04);opacity:1} }

.hero-circle-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  aspect-ratio: 1;
  border-radius: 50%;
  overflow: hidden;
  background: radial-gradient(circle at 50% 40%, rgba(252,228,235,.95), rgba(248,210,225,.9));
  box-shadow: 0 20px 60px rgba(180,90,120,.2), inset 0 0 40px rgba(255,220,230,.3);
  border: 3px solid rgba(240,180,200,.4);
}

.hero-circle-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  transform: scale(1.05);
}

/* Floating roses */
.hero-rose { position:absolute; z-index:3; animation:roseFloat 4s ease-in-out infinite; pointer-events:none; filter:drop-shadow(0 3px 6px rgba(0,0,0,.1)); }
.hero-rose-1 { top:2%;  left:2%;  font-size:1.5rem; animation-delay:0s; }
.hero-rose-2 { top:5%;  right:3%; font-size:2rem;   animation-delay:1.2s; }
.hero-rose-3 { bottom:8%; left:5%; font-size:1.4rem; animation-delay:2s; }
.hero-rose-4 { bottom:5%; right:2%; font-size:1.2rem; animation-delay:.7s; }
@keyframes roseFloat { 0%,100%{transform:translateY(0) rotate(-5deg)} 50%{transform:translateY(-12px) rotate(5deg)} }

/* ─── MOBILE ─── */
@media (max-width: 900px) {
  .hero-new-inner { grid-template-columns:1fr; padding:2rem 5%; gap:1.5rem; }
  .hero-new-right { order:-1; }
  .hero-circle-outer { width:min(300px,75vw); }
  .hero-new-logo-text { font-size:clamp(2.4rem,9vw,3.6rem); }
  .hero-new { min-height:auto; padding:2rem 0 3rem; }
  .floral-tl { width:140px; height:140px; }
  .floral-br { width:120px; height:120px; }
  .hero-cats { gap:.8rem; }
  .hero-cat-icon { width:58px; height:58px; font-size:1.4rem; }
}
@media (max-width: 480px) {
  .hero-new-logo-text { font-size:2.2rem; }
  .hero-new-heart { width:26px; height:26px; }
  .hero-new-tagline { font-size:.66rem; letter-spacing:.18em; margin-bottom:1.5rem; }
  .hero-search-input { padding:.8rem 1.1rem; font-size:.82rem; }
  .hero-cats { gap:.6rem; }
  .hero-cat-icon { width:52px; height:52px; font-size:1.25rem; }
  .hero-cat-name { font-size:.85rem; }
  .hero-cat-sub { display:none; }
  .hero-circle-outer { width:min(250px,72vw); }
  .floral-tl, .floral-br { display:none; }
}

/* ─── Admin ─── */
@media (max-width: 900px) {
  .admin-layout { grid-template-columns: 1fr; }
  .admin-sidebar { display: none; }
  .admin-stats { grid-template-columns: repeat(2,1fr); }
  .post-edit-form { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════
   NEW HERO — Watercolor / Floral Style
   ═══════════════════════════════════════════════════════════ */

.hero-new {
  position: relative;
  min-height: calc(100vh - 70px);
  background: linear-gradient(155deg, #fff8f6 0%, #fdf0ee 35%, #fce8e8 65%, #f9e0e5 100%);
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 3rem 0;
}

/* Watercolor blob background */
.hero-new::before {
  content: '';
  position: absolute;
  top: -10%;
  right: -5%;
  width: 65%;
  height: 110%;
  background: radial-gradient(ellipse at 60% 40%,
    rgba(245,195,200,.35) 0%,
    rgba(240,180,190,.2) 40%,
    transparent 70%);
  border-radius: 40% 60% 55% 45% / 50% 45% 55% 50%;
  pointer-events: none;
}

.hero-new::after {
  content: '';
  position: absolute;
  bottom: -5%;
  left: -3%;
  width: 45%;
  height: 60%;
  background: radial-gradient(ellipse at 40% 60%,
    rgba(240,185,195,.2) 0%,
    rgba(235,175,185,.12) 50%,
    transparent 70%);
  border-radius: 60% 40% 50% 50% / 45% 55% 45% 55%;
  pointer-events: none;
}

/* Floral decorations */
.floral-tl {
  position: absolute;
  top: -10px;
  left: -10px;
  width: 220px;
  height: 220px;
  pointer-events: none;
  z-index: 1;
  opacity: .85;
}
.floral-br {
  position: absolute;
  bottom: 20px;
  right: 20px;
  width: 180px;
  height: 180px;
  pointer-events: none;
  z-index: 1;
  opacity: .7;
}

.hero-new-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
  padding: 0 6%;
  gap: 3rem;
}

/* ── LEFT ── */
.hero-new-left {
  animation: hnFadeUp .9s ease forwards;
  opacity: 0;
}
@keyframes hnFadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Logo / Big title */
.hero-new-logo {
  display: flex;
  align-items: flex-end;
  gap: .5rem;
  margin-bottom: .5rem;
}
.hero-new-logo-text {
  font-family: 'Dancing Script', cursive;
  font-size: clamp(3.2rem, 6vw, 5.2rem);
  font-weight: 700;
  color: #b8637a;
  line-height: 1;
  letter-spacing: -.01em;
  text-shadow: 2px 3px 8px rgba(180,90,110,.15);
}
.hero-new-heart {
  width: 36px;
  height: 36px;
  margin-bottom: .6rem;
  flex-shrink: 0;
  animation: heartFloat 3s ease-in-out infinite;
}
@keyframes heartFloat {
  0%,100% { transform: translateY(0) scale(1); }
  50%      { transform: translateY(-6px) scale(1.1); }
}

.hero-new-tagline {
  font-family: 'DM Sans', sans-serif;
  font-size: .8rem;
  letter-spacing: .28em;
  color: #b8637a;
  opacity: .75;
  margin-bottom: 1.5rem;
  text-transform: uppercase;
}

.hero-new-sub {
  font-family: 'DM Sans', sans-serif;
  font-size: 1rem;
  color: #7a5560;
  line-height: 1.8;
  max-width: 420px;
  margin-bottom: 2.5rem;
  font-weight: 300;
  opacity: .85;
}

.hero-new-btns {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.hero-btn-main {
  display: inline-block;
  background: linear-gradient(135deg, #d4889a, #c4728a);
  color: white;
  padding: .95rem 2.2rem;
  font-family: 'DM Sans', sans-serif;
  font-size: .8rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 40px;
  box-shadow: 0 8px 28px rgba(180,90,110,.28);
  transition: all .3s;
}
.hero-btn-main:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 35px rgba(180,90,110,.38);
  background: linear-gradient(135deg, #c4788a, #b4627a);
}

.hero-btn-ghost {
  display: inline-block;
  border: 1.5px solid rgba(195,100,120,.4);
  color: #b8637a;
  padding: .9rem 2rem;
  font-family: 'DM Sans', sans-serif;
  font-size: .8rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 40px;
  transition: all .3s;
  background: rgba(255,255,255,.5);
}
.hero-btn-ghost:hover {
  background: rgba(255,255,255,.85);
  border-color: rgba(195,100,120,.7);
  transform: translateY(-3px);
}

/* Search bar */

/* Category pills */

/* ── RIGHT ── */
.hero-new-right {
  display: flex;
  justify-content: center;
  align-items: center;
  animation: hnFadeIn 1.1s ease .3s forwards;
  opacity: 0;
}
@keyframes hnFadeIn {
  from { opacity: 0; transform: scale(.96); }
  to   { opacity: 1; transform: scale(1); }
}

.hero-new-img-wrap {
  position: relative;
  width: min(480px, 100%);
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Soft circle background */
.hero-new-circle-bg {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 45%,
    rgba(250,220,225,.85) 0%,
    rgba(245,205,215,.6) 40%,
    rgba(240,190,205,.3) 65%,
    transparent 80%);
  animation: circleBreath 5s ease-in-out infinite;
}
@keyframes circleBreath {
  0%,100% { transform: scale(1); opacity: .9; }
  50%      { transform: scale(1.03); opacity: 1; }
}

.hero-new-mama-svg {
  width: 82%;
  height: 82%;
  position: relative;
  z-index: 2;
  filter: drop-shadow(0 10px 30px rgba(180,90,110,.15));
}

.hero-new-photo {
  width: 92%;
  height: 92%;
  object-fit: contain;
  border-radius: 50%;
  position: relative;
  z-index: 2;
  box-shadow: 0 20px 60px rgba(180,90,110,.18);
  border: none;
  background: transparent;
  padding: 0;
}

/* Floating rose emojis */
.hero-rose {
  position: absolute;
  font-size: 2rem;
  z-index: 3;
  animation: roseFloat 4s ease-in-out infinite;
  pointer-events: none;
  filter: drop-shadow(0 3px 6px rgba(0,0,0,.1));
}
.hero-rose-1 { top: 5%;  left: 5%;  animation-delay: 0s;    font-size: 1.6rem; }
.hero-rose-2 { top: 8%;  right: 8%; animation-delay: 1.3s;  font-size: 2rem; }
.hero-rose-3 { bottom: 12%; left: 10%; animation-delay: 2.1s; font-size: 1.4rem; }
@keyframes roseFloat {
  0%,100% { transform: translateY(0) rotate(-5deg); }
  50%      { transform: translateY(-10px) rotate(5deg); }
}

/* ─── MOBILE ─── */
@media (max-width: 900px) {
  .hero-new-inner { grid-template-columns: 1fr; padding: 2rem 5%; gap: 1.5rem; }
  .hero-new-right { order: -1; }
  .hero-new-img-wrap { width: min(320px, 80vw); }
  .hero-new-logo-text { font-size: clamp(2.5rem, 10vw, 3.8rem); }
  .hero-new { min-height: auto; padding-top: 2rem; padding-bottom: 3rem; }
  .floral-tl { width: 140px; height: 140px; }
  .floral-br { width: 120px; height: 120px; }
  .hero-new-sub { font-size: .9rem; }
  .hero-new-btns { gap: .8rem; }
}

@media (max-width: 480px) {
  .hero-new-logo-text { font-size: 2.3rem; }
  .hero-new-heart { width: 28px; height: 28px; }
  .hero-new-tagline { font-size: .68rem; letter-spacing: .18em; margin-bottom: 1rem; }
  .hero-new-sub { font-size: .85rem; margin-bottom: 1.8rem; }
  .hero-btn-main, .hero-btn-ghost { padding: .8rem 1.6rem; font-size: .75rem; }
  .hero-new-img-wrap { width: min(260px, 75vw); }
  .floral-tl, .floral-br { display: none; }
}

/* ═══════════════════════════════════════════════════════════
   FOTO GALERIE
   ═══════════════════════════════════════════════════════════ */
.post-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .5rem;
  margin: 2.5rem 0;
  border-radius: 10px;
  overflow: hidden;
}
.post-gallery.cols-2 { grid-template-columns: repeat(2, 1fr); }
.post-gallery.cols-4 { grid-template-columns: repeat(4, 1fr); }

.gallery-item {
  position: relative;
  padding-bottom: 72%;
  overflow: hidden;
  cursor: pointer;
  background: var(--beige);
}
.gallery-item:first-child:nth-last-child(n+3) {
  grid-column: span 2;
  padding-bottom: 55%;
}
.gallery-item img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.gallery-item:hover img { transform: scale(1.04); }
.gallery-item-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  transition: background .3s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.gallery-item:hover .gallery-item-overlay {
  background: rgba(0,0,0,.25);
}
.gallery-zoom-icon {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,.9);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transform: scale(.8);
  transition: all .3s;
  font-size: 1.2rem;
}
.gallery-item:hover .gallery-zoom-icon { opacity: 1; transform: scale(1); }
.gallery-caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.5));
  color: white;
  font-size: .72rem;
  padding: .8rem .7rem .4rem;
  opacity: 0;
  transition: opacity .3s;
}
.gallery-item:hover .gallery-caption { opacity: 1; }

/* Lightbox */
.gallery-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.92);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.gallery-lightbox.open { display: flex; }
.lightbox-img-wrap {
  position: relative;
  max-width: 90vw;
  max-height: 80vh;
}
.lightbox-img-wrap img {
  max-width: 90vw;
  max-height: 80vh;
  object-fit: contain;
  border-radius: 4px;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}
.lightbox-close {
  position: absolute;
  top: -40px; right: 0;
  background: none; border: none;
  color: white; font-size: 2rem;
  cursor: pointer; line-height: 1;
}
.lightbox-nav {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,.15);
  border: none; color: white;
  font-size: 2rem; cursor: pointer;
  width: 50px; height: 50px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
}
.lightbox-nav:hover { background: rgba(255,255,255,.3); }
.lightbox-prev { left: -70px; }
.lightbox-next { right: -70px; }
.lightbox-caption {
  color: rgba(255,255,255,.7);
  font-size: .82rem;
  margin-top: 1rem;
  text-align: center;
}
.lightbox-counter {
  color: rgba(255,255,255,.4);
  font-size: .72rem;
  margin-top: .3rem;
}

/* ═══════════════════════════════════════════════════════════
   INFO BOX — "Tipp für dich"
   ═══════════════════════════════════════════════════════════ */
.info-box {
  background: linear-gradient(135deg, #fff4f7 0%, #fde8ee 100%);
  border: 1.5px solid rgba(196,114,138,.25);
  border-radius: 8px;
  padding: 1.8rem 2rem;
  margin: 2.5rem 0;
  position: relative;
  overflow: hidden;
}
.info-box::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: linear-gradient(135deg, #d4889a, #c4728a);
  border-radius: 4px 0 0 4px;
}
.info-box-title {
  font-family: var(--script);
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--rose-deep);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.info-box-items {
  display: flex;
  flex-direction: column;
  gap: .55rem;
}
.info-box-item {
  display: flex;
  align-items: flex-start;
  gap: .7rem;
  font-size: .88rem;
  color: var(--charcoal);
  line-height: 1.5;
}
.info-box-item .info-emoji {
  font-size: 1rem;
  flex-shrink: 0;
  margin-top: .1rem;
  width: 1.4rem;
  text-align: center;
}
.info-box-item a { color: var(--rose-deep); }
.info-box-item a:hover { text-decoration: underline; }

@media (max-width: 768px) {
  .post-gallery { grid-template-columns: repeat(2,1fr); gap: .4rem; }
  .post-gallery.cols-4 { grid-template-columns: repeat(2,1fr); }
  .post-gallery.cols-3 .gallery-item:first-child:nth-last-child(n+3) { grid-column: span 2; }
  .lightbox-prev { left: -45px; }
  .lightbox-next { right: -45px; }
}
@media (max-width: 480px) {
  .post-gallery { grid-template-columns: repeat(2,1fr); gap: .3rem; }
  .post-gallery.cols-4 { grid-template-columns: repeat(2,1fr); }
  .gallery-item { padding-bottom: 80%; }
  .gallery-item:first-child:nth-last-child(n+3) { grid-column: span 2; padding-bottom: 60%; }
  .lightbox-prev, .lightbox-next { display: none; }
  .info-box { padding: 1.2rem 1rem; }
  .info-box-title { font-size: 1.1rem; }
  .info-box-item { font-size: .82rem; }
}

/* ─── VIDEO EMBED ─── */
.post-video {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  margin: 2rem 0;
  border-radius: 8px;
  box-shadow: 0 10px 40px rgba(180,90,120,.15);
}
.post-video iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border-radius: 8px;
}
