/* Blog Index & Article Styles - Light theme with new feminine accents */
:root {
  --bg: #FDF2F8; /* Very Light Pink/Cream */
  --surface: #FFFFFF; /* White */
  --surface-alt: #F8FAFC; /* Slightly off-white */
  --border: #FBCFE8; /* Light Pink Border */
  --text: #4B5563; /* Charcoal Gray */
  --text-soft: #9CA3AF; /* Light Gray */
  --primary: #A78BFA; /* Soft Lavender */
  --primary-rgb: 167,139,250; /* RGB for Soft Lavender */
  --primary-soft: #EDE9FE; /* Lighter Lavender */
  --accent: #F472B6; /* Rose Pink */
  --success: #34D399; /* Green for success */
  --radius: 20px;
  --card-image-height: 260px;
  --card-radius: 18px;
  --gradient-accent: linear-gradient(135deg, #A78BFA, #F472B6); /* Lavender to Rose Pink */
  font-family:'Poppins',sans-serif;
  
  /* Article-specific variables */
  --fleurisseur-teal: #22a29a;
  --fleurisseur-gold: #f2b705;
  --fleurisseur-dark: #1a2a3a;
  --fleurisseur-bg: #ffffff;
  --fleurisseur-soft: #f5f7fa;
  --fleurisseur-border: #e5e7eb;
  --fleurisseur-accent: #60a5fa; /* Default accent, can be overridden per article */
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Poppins',sans-serif;background:linear-gradient(to bottom, var(--bg), #FCE7F6); /* Gradient with new background */
color:var(--text);line-height:1.6;min-height:100vh;padding-top:90px;}
.container{max-width:1320px;margin:0 auto;padding:40px 28px;}

h1{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:800;letter-spacing:-1px;background:var(--gradient-accent);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:1rem;}
.lead{max-width:960px;font-size:clamp(1.05rem,1.05rem + .4vw,1.4rem);font-weight:500;color:var(--text-soft);}

/* Toolbar */
.toolbar{margin-top:2.2rem;display:flex;flex-wrap:wrap;gap:18px;align-items:stretch;}
.mode-switch{display:flex;align-items:center;gap:16px;background:var(--surface);padding:14px 20px;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 18px -6px rgba(0,0,0,.08);}
.mode-switch span{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-soft);}
.toggle-wrapper{position:relative;width:70px;height:34px;}
.toggle-wrapper input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2;}
.slider{position:absolute;top:0;left:0;right:0;bottom:0;border:1px solid var(--border);background:var(--surface-alt);border-radius:40px;transition:.35s;pointer-events:none;}
.slider:before{content:"🌱";position:absolute;height:28px;width:28px;left:4px;top:2px;background:#fff;border-radius:50%;display:grid;place-items:center;font-size:16px;box-shadow:0 4px 10px -2px rgba(0,0,0,.2);transition:.45s;}
input:checked + .slider{background:var(--primary-soft);border-color:var(--primary); /* Use primary for border */
}
input:checked + .slider:before{transform:translateX(36px);content:"✨";background:linear-gradient(135deg,#fff,var(--primary-soft)); /* Use primary-soft */
}
.mode-labels{display:flex;flex-direction:column;gap:4px;}
.mode-labels .label{font-size:.7rem;font-weight:600;padding:5px 12px;border-radius:14px;display:inline-block;background:var(--surface-alt);color:var(--text-soft);text-align:center;letter-spacing:.5px;}
.mode-labels .label.active{background:var(--gradient-accent);color:#fff;box-shadow:0 4px 12px -4px rgba(var(--primary-rgb),.45);}

.search-box{flex:1;display:flex;gap:14px;align-items:center;background:var(--surface);border:1px solid var(--border);padding:12px 18px;border-radius:var(--radius);min-width:290px;position:relative;box-shadow:0 4px 18px -6px rgba(0,0,0,.05);}
.search-box i{color:var(--primary);font-size:1.1rem;}
.search-box input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:1rem;font-weight:600;}
.search-box input::placeholder{color:var(--text-soft);font-weight:500;}

.sort-box{display:flex;align-items:center;gap:10px;background:var(--surface);padding:12px 18px;border:1px solid var(--border);border-radius:var(--radius);position:relative;min-width:180px;box-shadow:0 4px 18px -6px rgba(0,0,0,.05);}
.sort-box label{font-size:.65rem;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-soft);}
.sort-box select{appearance:none;background:var(--surface-alt);border:1px solid var(--border);padding:8px 34px 8px 12px;border-radius:12px;font-weight:600;color:var(--text);cursor:pointer;line-height:1;position:relative;font-size:.85rem;}
.sort-box select:focus{outline:2px solid var(--primary);outline-offset:2px;}
.sort-box:after{content:"\25BC";position:absolute;right:30px;top:50%;transform:translateY(-50%);font-size:.55rem;color:var(--primary);pointer-events:none;font-weight:700;letter-spacing:-1px;}

/* Featured area */
#featured-section{margin-top:3rem;display:grid;gap:32px;grid-template-columns:1fr;}
.article-card{background:var(--surface);border:1px solid var(--border);border-radius:28px;overflow:hidden;display:flex;flex-direction:column;position:relative;box-shadow:0 10px 26px -10px rgba(0,0,0,.10);transition:transform .35s, box-shadow .35s, border-color .35s;}
.article-card:hover{transform:translateY(-3px);box-shadow:0 16px 38px -12px rgba(0,0,0,.16);border-color:var(--primary-soft);} /* Use primary-soft for hover border */
/* Featured split layout */
.article-card.featured{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:minmax(0,520px) 1fr;grid-template-rows:auto;min-height:420px;}
@media (max-width:980px){.article-card.featured{grid-template-columns:1fr;min-height:unset;}}
.card-image-link{display:block;position:relative;height:var(--card-image-height);overflow:hidden;background:var(--surface-alt);border-top-left-radius:var(--card-radius);border-top-right-radius:var(--card-radius);}
/* Ensure featured and grid cards show the same visible area on mobile and desktop.
  Featured cards in desktop layout should fill their grid cell but have a consistent visible
  height at mobile widths to avoid over-cropping of unfeatured cards. */
.article-card.featured .card-image-link{height:var(--card-image-height);min-height:220px;max-height:420px;overflow:hidden;}/* keep a consistent visible strip for featured on small screens */
.card-image-link img{width:100%;height:100%;object-fit:cover;object-position:center center;transition:transform .45s ease, filter .35s ease;border-radius:0;display:block;} /* fill the frame, crop if necessary */
.article-grid .article-card .card-image-link{height:var(--card-image-height);} /* explicitly match grid cards to featured height */
.article-grid .article-card .card-image-link img{object-position:center top;} /* prefer top-focus on grid cards to reduce center-cropping */
.article-card.featured .card-image-link img{border-radius:0;} /* unify */
.article-card:hover .card-image-link img{transform:scale(1.04);}
.article-card:hover img{filter:brightness(1.04) saturate(1.08);}
/* Rounded image corners only on top when stacked */
.article-grid .article-card:not(.featured) .card-image-link img{border-top-left-radius:var(--card-radius);border-top-right-radius:var(--card-radius);}
/* Make grid cards uniform height for a neat grid */
.article-grid .article-card{min-height:520px;display:flex;flex-direction:column;}
@media (max-width:640px){
  /* On mobile, use the same visible card image height as featured cards so grid cards
    are not excessively cropped. */
  :root{ --card-image-height:260px; }
  .article-grid .article-card{min-height:480px;}
}
.card-content{padding:24px 28px 28px;display:flex;flex-direction:column;height:100%;}
.article-card.featured .card-content{padding:40px 50px 44px;}
@media (max-width:980px){.article-card.featured .card-content{padding:28px 28px 36px;}}
.category-tag{display:inline-block;font-size:.65rem;letter-spacing:1px;font-weight:700;text-transform:uppercase;padding:6px 14px;border-radius:999px;background:var(--primary);color:#fff;margin-bottom:14px;}
.article-card h2{font-size:clamp(1.35rem,1.05rem + .9vw,2.05rem);line-height:1.18;margin:0 0 12px;font-weight:800;color:var(--text);}
.article-card h2 a{text-decoration:none;color:var(--text);}
.article-card h2 a:hover{color:var(--primary);}
.article-card p.excerpt{font-size:.95rem;color:var(--text-soft);margin:0 0 20px;font-weight:500;}
.meta-bottom{margin-top:auto;display:flex;align-items:center;gap:12px;}
.meta-bottom img{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid var(--surface-alt);}
.meta-bottom .auth{display:flex;flex-direction:column;gap:2px;font-size:.7rem;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.7px;}
.meta-bottom time{font-size:.65rem;letter-spacing:.5px;color:var(--text-soft); /* Use text-soft */
font-weight:600;}

/* Grid of regular articles */
#grid-section{margin-top:3.2rem;}
#grid-section h3{font-size:.85rem;font-weight:800;margin:0 0 1.2rem;letter-spacing:1.5px;color:var(--text-soft);text-transform:uppercase;}
.article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:26px;}

/* Badges */
.badge-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;}
.badge{font-size:.58rem;font-weight:700;letter-spacing:.8px;text-transform:uppercase;padding:6px 10px;border-radius:9px;background:var(--surface-alt);color:var(--primary);border:1px solid var(--border);}
.badge.diff-advanced{background:#FCE7F6; /* Lighter pink */
color:#F472B6; /* Rose Pink */
border-color:#FBCFE8; /* Light Pink Border */
}
.badge.diff-intermediate{background:var(--primary-soft);color:var(--primary);border-color:var(--primary-light);}
.badge.diff-einfach, .badge.diff-beginner{background:#E6FFFA; /* Light green */
color:#34D399; /* Green for success */
border-color:#B2F5EA; /* Lighter green */
}
.badge.readtime{background:#E0E7FF; /* Light blue */
color:#6366F1; /* Accent blue */
border-color:#C7D2FE; /* Lighter blue */
}

/* Format badge for simple-language articles */
.format-row{margin-bottom:10px;}
.format-badge{background:var(--primary);color:#fff;border:none;border-radius:999px;padding:8px 14px;font-size:.75rem;font-weight:800;box-shadow:0 6px 18px rgba(var(--primary-rgb),.18);display:inline-block;}

/* Card subtitle (e.g. Kurz & Klar — Einfache Sprache) */
.card-subtitle{font-size:.9rem;color:var(--text-soft);font-weight:700;margin:6px 0 14px;}

/* Load more */
.load-more-wrapper{margin-top:3rem;text-align:center;}
#load-more-btn{background:var(--gradient-accent);border:none;color:#fff;font-weight:700;padding:15px 34px;font-size:1rem;border-radius:50px;cursor:pointer;box-shadow:0 14px 32px -10px rgba(var(--primary-rgb),.45);transition:.4s;}
#load-more-btn:hover{transform:translateY(-3px);box-shadow:0 22px 50px -14px rgba(var(--primary-rgb),.5);}
#load-more-btn:active{transform:translateY(0);}

/* === BLOG ARTICLE STYLES === */

/* Base Article Styles */
html {
  scroll-behavior: smooth;
  scroll-padding-top: 80px;
}

.article-body {
  font-family: 'Poppins', sans-serif;
  margin: 0;
  background-color: var(--fleurisseur-bg);
  color: var(--fleurisseur-dark);
  line-height: 1.7;
}

.article-body h1, .article-body h2, .article-body h3 {
  font-weight: 800;
  color: var(--fleurisseur-dark);
  line-height: 1.2;
}

.article-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
}

/* Hero Section */
.article-hero {
  min-height: 70vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 2rem 1.5rem 3rem;
  background: linear-gradient(rgba(0,0,0,.55), rgba(0,0,0,.55)), var(--hero-bg, none) center/cover no-repeat;
  color: #fff;
  position: relative;
}

.article-hero h1 {
  font-size: clamp(2.4rem, 7vw, 4.2rem);
  margin: 0 0 1rem;
  color: white;
  text-shadow: 2px 2px 10px rgba(0,0,0,0.5);
}

.article-hero p {
  max-width: 760px;
  font-size: clamp(1.05rem, 2.5vw, 1.4rem);
  font-weight: 600;
  margin: 0 0 1.8rem;
  text-shadow: 1px 1px 5px rgba(0,0,0,0.5);
}

.article-hero .highlight {
  color: var(--fleurisseur-accent);
}

.article-cta-button {
  display: inline-block;
  background: var(--fleurisseur-gold);
  color: var(--fleurisseur-dark);
  padding: 1rem 2.5rem;
  border-radius: 50px;
  text-decoration: none;
  font-weight: 800;
  font-size: 1.2rem;
  transition: transform .3s ease, background-color .3s ease;
  box-shadow: 0 8px 24px -6px rgba(0,0,0,.35);
}

.article-cta-button:hover {
  transform: scale(1.05);
  background-color: #ffce3a;
}

/* Alt Link Box */
.article-alt-link-box {
  max-width: 1100px;
  margin: -3rem auto 2.5rem auto;
  padding: 0 2rem;
}

.article-alt-link-content {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(6px);
  border: 1px solid var(--fleurisseur-border);
  box-shadow: 0 4px 18px -4px rgba(0,0,0,0.08);
  border-radius: 18px;
  padding: 14px 22px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.article-alt-link-content span {
  font-size: 1.9rem;
  line-height: 1;
}

.article-alt-link-content p {
  margin: 0;
  font-weight: 600;
  color: var(--fleurisseur-dark);
  font-size: 0.95rem;
}

.article-alt-link-content a {
  color: var(--fleurisseur-teal);
  text-decoration: none;
  font-weight: 700;
}

/* Navigation */
.article-roadmap-nav {
  position: sticky;
  top: 0;
  background: rgba(255,255,255,0.9);
  backdrop-filter: blur(10px);
  z-index: 1000;
  padding: 1rem 0;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
  border-bottom: 1px solid #eee;
  overflow-x: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.article-roadmap-nav::-webkit-scrollbar {
  display: none;
}

.article-roadmap-steps {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0 1rem;
  gap: .5rem;
  width: max-content;
  margin: 0 auto;
}

.article-roadmap-steps a {
  text-decoration: none;
  color: var(--fleurisseur-dark);
  font-weight: 600;
  padding: .5rem 1rem;
  border-radius: 20px;
  border: 2px solid transparent;
  transition: all .3s ease;
  white-space: nowrap;
}

.article-roadmap-steps a:hover {
  color: var(--fleurisseur-dark);
  background-color: #f0f0f0;
}

.article-roadmap-steps a.active {
  border-color: var(--fleurisseur-teal);
  color: var(--fleurisseur-teal);
  background-color: #eaf7f6;
}

/* Phase Sections */
.article-phase-section {
  min-height: 90vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 4rem;
  padding: 5rem 2rem;
  border-bottom: 1px solid #eee;
}

.article-phase-image {
  width: 100%;
  height: 60vh;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  border-radius: 20px;
}

.article-phase-content {
  max-width: 600px;
}

.article-phase-label {
  background: var(--fleurisseur-teal);
  color: white;
  padding: .3rem 1rem;
  border-radius: 6px;
  font-size: 1rem;
  font-weight: 600;
  display: inline-block;
  margin-bottom: 1rem;
}

.article-phase-content h2 {
  font-size: clamp(2rem, 5vw, 3rem);
  margin-top: 0;
  line-height: 1.2;
}

.article-phase-content .core-statement {
  font-size: 1.5rem;
  font-style: italic;
  color: var(--fleurisseur-dark);
  border-left: 4px solid var(--fleurisseur-gold);
  padding-left: 1.5rem;
  margin: 2rem 0;
}

/* Checklists */
.article-checklist {
  list-style: none;
  padding: 0;
}

.article-checklist li {
  background: var(--fleurisseur-soft);
  padding: 1rem 1.5rem;
  border-radius: 12px;
  margin-bottom: .75rem;
  display: flex;
  align-items: center;
  font-weight: 600;
}

.article-checklist li i {
  color: var(--fleurisseur-teal);
  font-size: 1.5rem;
  margin-right: 1rem;
}

/* Expert Corner / FAQ */
.article-expert-corner {
  padding: 5rem 2rem;
  background: var(--fleurisseur-soft);
}

.article-expert-corner h2 {
  text-align: center;
  font-size: 2.5rem;
  margin-bottom: 3rem;
}

.article-accordion {
  max-width: 800px;
  margin: 0 auto;
}

.article-accordion details {
  background: white;
  border-radius: 10px;
  margin-bottom: 1rem;
  border: 1px solid var(--fleurisseur-border);
  box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}

.article-accordion summary {
  padding: 1.5rem;
  font-weight: 600;
  font-size: 1.1rem;
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.article-accordion summary::-webkit-details-marker {
  display: none;
}

.article-accordion summary::after {
  content: '\f078';
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  transition: transform .3s ease;
}

.article-accordion details[open] summary::after {
  transform: rotate(180deg);
}

.article-accordion .answer {
  padding: 0 1.5rem 1.5rem 1.5rem;
  border-top: 1px solid var(--fleurisseur-border);
}

/* Finale Section */
.article-finale {
  text-align: center;
  padding: 5rem 2rem;
}

.article-finale img {
  max-width: 300px;
  margin-bottom: 2rem;
  border-radius: 20px;
}

.article-finale p {
  max-width: 600px;
  margin: 0 auto 2rem auto;
  font-size: 1.2rem;
}

/* Easy/Short Version Styles */
.article-step {
  display: grid;
  gap: 2.5rem;
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  align-items: center;
  padding: 3.5rem 0 2.5rem;
  border-bottom: 1px solid var(--fleurisseur-border);
}

.article-step:last-of-type {
  border-bottom: none;
}

.article-step-image {
  width: 100%;
  height: 380px;
  background: #fff center/contain no-repeat;
  border-radius: 26px;
  box-shadow: 0 14px 40px -10px rgba(0,0,0,.15);
  border: 1px solid var(--fleurisseur-border);
}

.article-badge {
  display: inline-block;
  background: var(--fleurisseur-teal);
  color: #fff;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .5px;
  padding: .4rem .7rem;
  border-radius: 6px;
  margin-bottom: 1rem;
  text-transform: uppercase;
}

.article-plain {
  font-size: 1rem;
  margin: .85rem 0;
}

.article-list {
  list-style: none;
  padding: 0;
  margin: 1rem 0 0;
}

.article-list li {
  background: var(--fleurisseur-soft);
  border: 1px solid var(--fleurisseur-border);
  padding: .8rem 1rem;
  border-radius: 12px;
  font-weight: 600;
  font-size: .9rem;
  display: flex;
  gap: .7rem;
  align-items: center;
  margin-bottom: .6rem;
}

.article-list i {
  color: var(--fleurisseur-teal);
  font-size: 1.1rem;
}

.article-note {
  background: linear-gradient(145deg, #fff, #f1f5f9);
  border: 1px solid var(--fleurisseur-border);
  padding: 1rem 1.1rem;
  border-radius: 14px;
  font-size: .85rem;
  font-weight: 600;
  margin: 1.4rem 0 0;
}

.article-final {
  text-align: center;
  padding: 4rem 0 1rem;
}

.article-final img {
  max-width: 300px;
  width: 100%;
  border-radius: 24px;
  box-shadow: 0 8px 30px -10px rgba(0,0,0,.25);
  border: 3px solid #fff;
}

.article-final h2 {
  margin: 2rem 0 1rem;
  font-size: clamp(2rem, 5vw, 3rem);
}

.article-back-full {
  margin-top: 1.5rem;
  display: inline-block;
  font-weight: 700;
  color: var(--fleurisseur-teal);
  text-decoration: none;
}

/* Responsive Design */
@media (max-width: 768px) {
  html {
    scroll-padding-top: 60px;
  }
  
  .article-roadmap-nav {
    padding: .5rem 0;
  }
  
  .article-phase-section {
    grid-template-columns: 1fr;
    padding: 3rem 1.5rem;
    gap: 1rem;
    min-height: auto;
  }
  
  .article-phase-section:nth-child(even) .article-phase-image {
    order: -1;
  }
  
  .article-phase-image {
    height: 40vh;
    margin-bottom: 2rem;
  }
  
  .article-phase-content h2 {
    font-size: 2rem;
  }
  
  .article-step {
    grid-template-columns: 1fr;
    padding: 2.8rem 0 2rem;
  }
  
  .article-step-image {
    height: 300px;
  }
}


/* Empty state */
.empty-state{margin-top:2.5rem;text-align:center;padding:3rem 2rem;border:2px dashed var(--border);border-radius:28px;background:var(--surface-alt);color:var(--text-soft);font-weight:600;}

/* Focus visible */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:6px;}

/* Responsive */
@media (max-width:920px){#featured-section{grid-template-columns:1fr;} .article-card.featured{max-width:100%;}}
@media (max-width:640px){.toolbar{flex-direction:column;align-items:stretch;} .mode-switch,.search-box,.sort-box{width:100%;}}