/* Ratgeber – brautkleidxxl.de (self-contained, XXL-Branding) */
:root {
  --cream: #fcf9f4; --cream-2: #f5efe5;
  --text: #1c1c19; --muted: #626265;
  --gold: #705742; --gold-light: #8a6f58; --gold-soft: rgba(112, 87, 66, 0.08);
  --line: rgba(28, 28, 25, 0.08);
}
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body { margin: 0; font-family: 'Work Sans', system-ui, sans-serif; font-size: 17px; line-height: 1.65; color: var(--text); background: var(--cream); -webkit-font-smoothing: antialiased; }
h1, h2, h3 { font-family: 'Noto Serif', Georgia, serif; font-weight: 500; color: var(--text); line-height: 1.2; }
h1 em, h2 em, h3 em { color: var(--gold); font-style: italic; font-weight: 400; }
a { color: var(--gold); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; transition: color .2s ease; }
a:hover { color: var(--gold-light); }
.eyebrow { color: var(--gold); font-size: 12px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; }
.top { position: fixed; top: 0; left: 0; right: 0; z-index: 50; padding: 14px 0; background: rgba(252, 249, 244, 0.9); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid var(--line); }
.top-inner { max-width: 1240px; margin: 0 auto; width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-inline: 22px; }
.top-brand img { height: 40px; width: auto; display: block; }
.cta { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; padding: 10px 20px; border-radius: 12px; background: var(--gold); color: #fff; text-decoration: none; font-weight: 500; font-size: 15px; transition: background-color .2s ease; }
.cta:hover { background: var(--gold-light); color: #fff; }
.article-wrap { max-width: 760px; margin: 0 auto; padding: clamp(88px, 12vw, 128px) clamp(22px, 4vw, 40px) clamp(48px, 8vw, 96px); }
.breadcrumb { font-size: 13px; color: var(--muted); margin: 0 0 22px; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; line-height: 1.4; }
.breadcrumb a { color: var(--muted); text-decoration: none; }
.breadcrumb a:hover { color: var(--gold); }
.breadcrumb .crumb-sep { opacity: 0.45; }
.breadcrumb [aria-current="page"] { color: var(--text); }
.article-meta { color: var(--muted); font-size: 14px; margin: 0 0 18px; display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.article-meta time { font-variant-numeric: tabular-nums; }
.article-meta .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--muted); opacity: 0.5; }
.article h1 { font-size: clamp(32px, 5vw, 50px); margin: 0 0 24px; }
.article p.lede { font-size: clamp(18px, 1.8vw, 22px); color: var(--muted); line-height: 1.55; margin: 0 0 32px; max-width: 56ch; }
.article-body h2 { font-size: clamp(23px, 3vw, 30px); margin: 46px 0 16px; }
.article-body p { margin: 0 0 18px; max-width: 64ch; }
.article-body ul, .article-body ol { padding-left: 24px; margin: 0 0 22px; max-width: 64ch; }
.article-body li { margin-bottom: 8px; }
.article-body strong { color: var(--text); font-weight: 600; }
.article-foot { margin-top: 64px; padding-top: 32px; border-top: 1px solid var(--line); display: flex; flex-wrap: wrap; gap: 20px; justify-content: space-between; align-items: center; }
.article-foot a { font-weight: 500; }
/* Ratgeber-Übersicht */
.ratgeber-index { max-width: 920px; margin: 0 auto; padding: clamp(88px, 12vw, 128px) clamp(22px, 4vw, 40px) clamp(48px, 8vw, 96px); }
.ratgeber-index h1 { font-size: clamp(36px, 5vw, 56px); margin: 0 0 16px; }
.ratgeber-index .lede { font-size: 18px; color: var(--muted); margin: 0 0 48px; max-width: 60ch; }
.article-card { display: block; padding: 28px 0; border-bottom: 1px solid var(--line); color: var(--text); text-decoration: none; transition: padding-left .2s ease; }
.article-card:hover { color: var(--text); padding-left: 8px; }
.article-card h2 { font-size: clamp(22px, 2.6vw, 28px); margin: 0 0 10px; color: var(--text); }
.article-card .meta { font-size: 13px; color: var(--muted); margin: 0 0 12px; }
.article-card .excerpt { color: var(--muted); margin: 0; max-width: 60ch; }
.article-card .read-more { color: var(--gold); font-weight: 500; display: inline-block; margin-top: 12px; }
/* Footer */
.site-footer { background: var(--text); color: var(--cream); padding: clamp(40px, 6vw, 72px) clamp(22px, 4vw, 40px); margin-top: 64px; }
.footer-inner { max-width: 1240px; margin: 0 auto; display: grid; gap: 32px; }
@media (min-width: 768px) { .footer-inner { grid-template-columns: 1.4fr 1fr 1fr; } }
.footer-brand p { color: rgba(255, 255, 255, 0.62); margin: 0 0 14px; line-height: 1.6; max-width: 320px; }
.footer-col h4 { font-size: 13px; text-transform: uppercase; letter-spacing: 0.14em; margin: 0 0 16px; color: rgba(255, 255, 255, 0.85); }
.footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.footer-col a { color: rgba(255, 255, 255, 0.62); text-decoration: none; }
.footer-col a:hover { color: #fff; }
.footer-bottom { max-width: 1240px; margin: 32px auto 0; padding-top: 24px; border-top: 1px solid rgba(255, 255, 255, 0.10); font-size: 13px; color: rgba(255, 255, 255, 0.4); }
