:root{
  --color-bg: #f5f3ee;
  --color-text: #1a1a1a;
  --color-text-muted: #6b7280;
  --color-primary: #1a6b5a;
  --color-primary-dark: #0f4a3e;
  --color-primary-light: #e6f2ef;
  --color-accent: #d97706;
  --color-accent-hover: #b45309;
  --color-verified: #1a6b5a;
  --color-official: #2563eb;
  --color-danger: #dc2626;
  --color-card: #ffffff;
  --color-border: #e5e2db;
  --color-header-bg: #1a1a1a;
  --color-header-text: #ffffff;
  --color-footer-bg: #111111;
  --color-footer-text: #9ca3af;
}

html{scroll-behavior:smooth;}

body{
  margin:0;
  font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size:16px;
  line-height:1.7;
  color:var(--color-text);
  background:var(--color-bg);
}

h1,h2,h3{
  font-family: Georgia, "Times New Roman", serif;
  line-height:1.25;
}

img{max-width:100%;}

.wrap{
  max-width: 980px;
  padding: 0 16px;
  margin: 0 auto;
}

.section{
  margin-top: 22px;
  margin-bottom: 22px;
}

.muted{
  color: var(--color-text-muted);
}

/* Header */
.site-header{
  background: var(--color-header-bg);
  color: var(--color-header-text);
  position: sticky;
  top: 0;
  z-index: 10;
}

.header-inner{
  max-width: 980px;
  margin: 0 auto;
  padding: 12px 16px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
}

.brand-link{
  color: inherit;
  text-decoration: none;
  display: inline-block;
}
.brand-link:hover .brand-title,
.brand-link:focus-visible .brand-title{
  text-decoration: underline;
  text-underline-offset: 3px;
}
.brand-link:focus-visible{
  outline: 2px solid rgba(255,255,255,0.6);
  outline-offset: 3px;
  border-radius: 4px;
}

.brand-title{
  font-weight: 900;
  letter-spacing: 0.2px;
  font-size: 18px;
}
.brand-sub{
  font-size: 12px;
  color: rgba(255,255,255,0.85);
}

.nav{
  display:none;
  flex-direction: column;
  gap: 8px;
  padding-bottom: 10px;
}
.nav a{
  color:#fff;
  text-decoration:none;
  font-weight:700;
}

.nav-toggle{
  background: transparent;
  border: 1px solid rgba(255,255,255,0.3);
  color:#fff;
  border-radius: 10px;
  width: 44px;
  height: 44px;
  font-size: 18px;
  cursor:pointer;
}

.nav-open .nav{
  display:flex;
}

/* Buttons */
.btn{
  display:inline-block;
  text-decoration:none;
  border-radius: 10px;
  padding: 12px 16px;
  font-weight: 800;
}

.btn-primary{
  background: var(--color-accent);
  color: #fff;
  border: 1px solid rgba(0,0,0,0.05);
}
.btn-primary:hover{ background: var(--color-accent-hover); }

.btn-secondary{
  border: 1px solid var(--color-border);
  background: #fff;
  color: var(--color-primary);
}

.btn-link{
  background: transparent;
  border: none;
  padding: 0;
  color: var(--color-primary);
  font-weight: 900;
}
.btn-link:hover{ text-decoration: underline; }

.btn-newsletter{
  background: var(--color-accent);
  color: #fff;
  border: none;
  cursor:pointer;
  width: 100%;
}

@media (min-width: 768px){
  .nav-toggle{ display:none; }
  .nav{ display:flex; flex-direction: row; flex-wrap: wrap; align-items: center; gap: 16px; padding-bottom: 0; }
  .nav a{ font-size: 14px; }
  .nav-open .nav{ display:flex; }
}

/* Mobile: Themen als Liste; Desktop: Dropdown */
.nav-themen-label-mobile{
  display: block;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.55);
  margin-top: 4px;
}
.nav-cat-mobile{
  display: block;
  padding: 4px 0 4px 8px;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  border-left: 2px solid rgba(255,255,255,0.2);
}
.nav-themen-desktop{ display: none; }

@media (min-width: 768px){
  .nav-themen-label-mobile,
  .nav-cat-mobile{ display: none !important; }
  .nav-themen-desktop{ display: block; position: relative; }
}

.nav-dropdown-trigger{
  color: #fff;
  font-weight: 700;
  font-size: 14px;
  cursor: default;
  user-select: none;
  white-space: nowrap;
}
.nav-dropdown-content{
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  /* Kein margin-top: Lücke zwischen Trigger und Panel beendet :hover — Menü klappt zu, bevor man klicken kann */
  margin-top: 0;
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 10px 0 8px;
  min-width: 240px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
  z-index: 50;
}
.nav-dropdown:hover .nav-dropdown-content,
.nav-dropdown:focus-within .nav-dropdown-content{
  display: block;
}
.nav-dropdown-content a{
  display: block;
  padding: 8px 16px;
  text-decoration: none;
  color: var(--color-text);
  font-size: 14px;
  font-weight: 700;
}
.nav-dropdown-content a:hover{
  background: var(--color-primary-light);
}

/* Hero */
.hero{
  margin-top: 18px;
  background: linear-gradient(180deg, var(--color-primary-light), rgba(230,242,239,0));
  border: 1px solid rgba(26,107,90,0.15);
  border-radius: 18px;
}
.hero-inner{ padding: 20px 0; }

.hero-headline{
  margin: 0;
}
.hero-sub{
  margin-top: 8px;
  max-width: 65ch;
}

.hero-actions{
  display:flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 16px;
}
@media (min-width: 768px){
  .hero-actions{ flex-direction: row; }
  .btn{ padding: 14px 20px; }
}

/* Cards / badges */
.cards{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 768px){
  .cards{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.card{
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 16px;
  padding: 14px;
}

/* Artikelkarten (index, Kategorie) – Klasse article-card im Partial */
.article-card{
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.article-card:hover{
  border-color: var(--color-primary);
  box-shadow: 0 2px 8px rgba(26, 107, 90, 0.1);
}

.card-top{
  display:flex;
  flex-wrap: wrap;
  align-items:center;
  gap: 8px 12px;
}

.badge{
  display:inline-flex;
  align-items:center;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 900;
  color:#fff;
  text-transform: lowercase;
}
.badge-verified{ background: var(--color-verified); }
.badge-official{ background: var(--color-official); }

.pill{
  background: #eaeaea;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 800;
  color: #333;
}

/* Headline-Link in der Artikelkarte (a > h4.card-title, nicht h3) */
.card-link{
  display:block;
  margin-top: 10px;
  text-decoration:none;
  color: var(--color-primary);
  cursor: pointer;
  transition: color 0.2s ease;
}
.card-title{
  font-size: 18px;
  margin: 0;
  color: inherit;
}
.card-link:hover{
  color: var(--color-primary-dark);
  text-decoration: underline;
}

.card-body{
  margin-top: 10px;
  color:#2a2a2a;
}

.relevance-box{
  margin-top: 12px;
  background: var(--color-primary-light);
  border: 1px solid rgba(26,107,90,0.18);
  border-radius: 14px;
  padding: 12px;
}
.relevance-label{
  font-weight: 900;
  font-size: 12px;
  color: var(--color-primary-dark);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.relevance-text{
  margin-top: 6px;
  font-weight: 800;
}

.card-meta{
  margin-top: 12px;
}

.sources{
  font-size: 13px;
  color: #444;
}

.tags{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.tag{
  background: #e5e5e5;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 800;
}

.section-bottom{
  margin-top: 12px;
}

/* Newsletter */
.newsletter{
  background: var(--color-card);
  border-radius: 18px;
  border: 1px solid var(--color-border);
}
.newsletter-inner{
  padding: 18px 14px;
}

.newsletter-form{
  margin-top: 12px;
  display:flex;
  flex-direction: column;
  gap: 12px;
}
.label{
  font-weight: 900;
  font-size: 13px;
}

.input{
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  padding: 12px 12px;
  font-size: 16px;
}

.checks, .radios{
  display:flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
}
.check, .radio{
  display:flex;
  gap: 10px;
  align-items: center;
}

.fineprint{
  color: var(--color-text-muted);
  font-size: 12px;
  margin: 0;
}

/* Proof steps */
.proof{
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  padding: 14px;
}
.steps{
  display:flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 10px;
}
.step{
  border: 1px dashed rgba(0,0,0,0.12);
  border-radius: 14px;
  padding: 12px;
}
.step-num{
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  font-weight: 900;
}

@media (min-width: 768px){
  .steps{ flex-direction: row; }
  .step{ flex: 1; }
}

/* Article page */
.article-page a.btn-link{ margin-bottom: 10px; }
.article-top{
  display:flex;
  flex-wrap: wrap;
  align-items:center;
  gap: 10px;
  margin-top: 14px;
}
.meta-time{
  color: var(--color-text-muted);
  font-weight: 700;
}
.article-headline{
  margin-top: 14px;
  font-size: 28px;
}
.article-divider{
  height: 1px;
  background: var(--color-border);
  margin-top: 14px;
  margin-bottom: 14px;
}
.article-body{
  max-width: 680px;
  font-size: 18px;
  line-height: 1.75;
  white-space: normal;
}
@media (max-width: 767px){
  .article-body{ font-size: 16px; line-height: 1.7; }
  .article-headline{ font-size: 24px; }
}
.article-relevance{
  max-width: 680px;
}

.sources-block{
  margin-top: 18px;
}
.source-list{
  padding-left: 18px;
}
.source-link{
  color: var(--color-primary);
  font-weight: 900;
  text-decoration: none;
}
.source-link:hover{ text-decoration: underline; }

.newsletter-compact{
  margin-top: 22px;
  background: var(--color-primary-light);
  border: 1px solid rgba(26,107,90,0.15);
  border-radius: 18px;
  padding: 16px;
  max-width: 680px;
}

/* Rechtstexte (Impressum, Datenschutz) */
.legal-page .legal-content{
  max-width: 680px;
}
.legal-page h1{
  margin: 0 0 0.35rem 0;
  font-size: 1.85rem;
}
.legal-page .legal-lead{
  margin: 0 0 1.25rem 0;
  line-height: 1.6;
}
.legal-page .legal-section{
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-border);
}
.legal-page .legal-section:first-of-type{
  margin-top: 0.5rem;
  padding-top: 0;
  border-top: none;
}
.legal-page .legal-section h2{
  margin: 0 0 0.75rem 0;
  font-size: 1.25rem;
}
.legal-page .legal-section h3{
  margin: 1rem 0 0.5rem 0;
  font-size: 1.05rem;
  font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
  font-weight: 800;
  color: var(--color-text);
}
.legal-page .legal-section p{
  margin: 0.6rem 0 0 0;
  line-height: 1.65;
}
.legal-page .legal-section h2 + p,
.legal-page .legal-section h3 + p{
  margin-top: 0;
}
.legal-page .legal-content a{
  color: var(--color-primary);
  font-weight: 700;
}

/* Archiv */
.archive-group{ margin-top: 18px; }
.archive-date{ margin-bottom: 10px; }
.archive-list{ display:flex; flex-direction: column; gap: 10px; }
.archive-item{
  padding: 14px;
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 16px;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.archive-item:hover{
  border-color: var(--color-primary);
  box-shadow: 0 2px 8px rgba(26, 107, 90, 0.1);
}
.archive-item-top{
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.archive-badges-row{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.archive-cat-badges{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.archive-link{
  display:block;
  margin-top: 10px;
  font-weight: 900;
  text-decoration:none;
  color: var(--color-primary);
  cursor: pointer;
  transition: color 0.2s ease;
}
.archive-link:hover{
  color: var(--color-primary-dark);
  text-decoration: underline;
}

/* Footer */
.site-footer{
  margin-top: 30px;
  background: var(--color-footer-bg);
  color: var(--color-footer-text);
}
.footer-inner{
  max-width: 980px;
  margin: 0 auto;
  padding: 18px 16px;
  display:flex;
  flex-direction: column;
  gap: 12px;
}
.footer-links{
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
}
.footer-links a{
  color: var(--color-footer-text);
  text-decoration:none;
}
.footer-links a:hover{ text-decoration: underline; }

/* Brevo newsletter — align with INFOTIME (loads after sib-styles.css) */
.newsletter-brevo-wrap{
  margin-top: 12px;
}

.newsletter-inner > .fineprint,
.newsletter-compact > .fineprint{
  margin-top: 12px;
}

.infotime-brevo{
  font-family: inherit;
  color: var(--color-text);
}

.infotime-brevo #sib-form-container{
  margin: 0 auto;
  max-width: 100%;
}

.infotime-brevo #error-message,
.infotime-brevo #success-message{
  max-width: 100% !important;
  box-sizing: border-box;
  border-radius: 10px !important;
  margin-bottom: 12px;
  font-family: inherit !important;
}

.infotime-brevo #sib-container{
  max-width: 100% !important;
  width: 100%;
  box-sizing: border-box;
  border-color: var(--color-border) !important;
  border-radius: 16px !important;
  background-color: var(--color-card) !important;
  padding: 12px 14px;
}

.infotime-brevo #sib-container a{
  color: var(--color-primary) !important;
}

.infotime-brevo #sib-container .entry__label,
.infotime-brevo #sib-container .checkbox__label{
  color: var(--color-text) !important;
  font-family: inherit !important;
}

.infotime-brevo #sib-container .entry__specification{
  color: var(--color-text-muted) !important;
  font-family: inherit !important;
}

.infotime-brevo #sib-container .sib-text-form-block p,
.infotime-brevo #sib-container .entry__choice span p{
  color: var(--color-text);
  font-family: inherit !important;
}

.infotime-brevo #sib-container input.input[type="text"],
.infotime-brevo #sib-container input#EMAIL{
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--color-border) !important;
  border-radius: 10px !important;
  padding: 12px !important;
  font-size: 16px !important;
  font-family: inherit !important;
  background: var(--color-card);
  color: var(--color-text);
}

.infotime-brevo #sib-container input.input[type="text"]:focus,
.infotime-brevo #sib-container input#EMAIL:focus{
  outline: none;
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px rgba(26, 107, 90, 0.2);
}

.infotime-brevo ::placeholder,
.infotime-brevo #sib-container ::placeholder{
  color: var(--color-text-muted) !important;
  font-family: inherit !important;
}

.infotime-brevo .sib-form-block__button{
  background-color: var(--color-accent) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 10px !important;
  padding: 12px 16px !important;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  font-family: inherit !important;
  font-weight: 800 !important;
  text-align: center !important;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.infotime-brevo .sib-form-block__button:hover{
  background-color: var(--color-accent-hover) !important;
}

.infotime-brevo input.input_replaced{
  accent-color: var(--color-primary);
}

.infotime-brevo .checkbox_tick_positive{
  border-color: var(--color-border) !important;
}

.infotime-brevo label input.input_replaced:checked + .checkbox_tick_positive,
.infotime-brevo .checkbox_tick_positive.checkbox_positive{
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.infotime-brevo label input.input_replaced:checked + .checkbox_tick_positive::after{
  border-color: #fff !important;
}

/* —— Themen / Kategorien —— */
.category-nav{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}
.category-pill{
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 14px;
  border-radius: 100px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  border: 1px solid var(--color-border);
  background: var(--color-card);
  color: var(--color-text);
  transition: border-color 0.2s, background 0.2s;
}
.category-pill:hover{
  border-color: var(--color-primary);
}
.category-pill.active{
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}

.badge-cat{
  display: inline-flex;
  align-items: center;
  gap: 3px;
  border-radius: 100px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}
.card-cat-badges{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-left: auto;
}
@media (max-width: 767px){
  .card-cat-badges{ margin-left: 0; width: 100%; }
}

.badge-cat-energie{ background: #fef3c7; color: #92400e; }
.badge-cat-steuern{ background: #e0e7ff; color: #3730a3; }
.badge-cat-rente{ background: #d1fae5; color: #065f46; }
.badge-cat-konsum{ background: #ffe4e6; color: #9f1239; }

a.badge-cat-link{
  text-decoration: none;
}
a.badge-cat-link:hover{
  filter: brightness(0.95);
  text-decoration: underline;
}

.category-cards{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
@media (min-width: 768px){
  .category-cards{ grid-template-columns: repeat(4, 1fr); }
}
.category-card{
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 20px 14px;
  text-align: center;
  text-decoration: none;
  color: var(--color-text);
  transition: border-color 0.2s;
}
.category-card:hover{
  border-color: var(--color-primary);
}
.category-card .icon{
  font-size: 28px;
  margin-bottom: 8px;
  line-height: 1;
}
.category-card .title{
  font-weight: 900;
  font-size: 14px;
  line-height: 1.3;
  font-family: Georgia, "Times New Roman", serif;
}
.category-card .count{
  font-size: 13px;
  color: var(--color-text-muted);
  margin-top: 8px;
  font-weight: 600;
}

.category-hero{
  text-align: center;
  padding-bottom: 8px;
}
.category-hero-icon{
  font-size: 42px;
  margin: 0 0 8px 0;
  line-height: 1;
}
.category-hero-title{
  margin: 0 0 8px 0;
  font-size: 1.75rem;
}
.category-hero-desc{
  margin: 0 auto;
  max-width: 42rem;
}
.category-hero-count{
  margin: 12px 0 0 0;
  font-size: 15px;
}

.related-category{
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid var(--color-border);
  max-width: 680px;
}
.related-list{
  list-style: none;
  padding: 0;
  margin: 12px 0 0 0;
}
.related-list li{
  margin-bottom: 12px;
}
.related-list a{
  font-weight: 900;
  color: var(--color-primary);
  text-decoration: none;
}
.related-list a:hover{ text-decoration: underline; }
.related-meta{
  display: block;
  font-size: 13px;
  margin-top: 2px;
}

/* Tagesgruppen (Startseite & Archiv) */
.day-group{
  margin-bottom: 40px;
}
.day-header{
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--color-primary);
  flex-wrap: wrap;
}
.day-icon{
  font-size: 20px;
  line-height: 1;
}
.day-label{
  font-family: Georgia, "Times New Roman", serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--color-text);
  margin: 0;
}
.day-date{
  font-size: 16px;
  color: var(--color-text-muted);
  font-weight: 400;
}
.day-count{
  font-size: 13px;
  color: var(--color-text-muted);
  background: var(--color-primary-light);
  padding: 2px 10px;
  border-radius: 100px;
  font-weight: 600;
}
.day-group + .day-group{
  padding-top: 20px;
}
.more-articles{
  text-align: center;
  margin: 32px 0 8px;
}
.btn-outline{
  display: inline-block;
  padding: 12px 24px;
  border: 2px solid var(--color-primary);
  color: var(--color-primary);
  border-radius: 8px;
  text-decoration: none;
  font-weight: 600;
  transition: background 0.2s, color 0.2s;
}
.btn-outline:hover{
  background: var(--color-primary);
  color: #fff;
}
@media (max-width: 767px){
  .day-header{
    gap: 6px;
  }
  .day-label{
    font-size: 18px;
  }
  .day-date{
    font-size: 14px;
  }
}

