/* =======================================================
   Ratgeber / Blog – Artikel & Hub
   ======================================================= */

/* ---------- Artikel ---------- */
.article-wrap { background: var(--cream); padding: 112px 0 80px; }
.article-container { max-width: 760px; margin: 0 auto; padding: 0 28px; }

.breadcrumb { font-size: 0.82rem; color: var(--text-muted); margin-bottom: 22px; }
.breadcrumb a { color: var(--gold-dark); text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }

.article-eyebrow { display: inline-block; font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold-dark); font-weight: 700; margin-bottom: 14px; }
.article h1 { font-family: var(--serif); font-size: clamp(2.1rem, 4.6vw, 3rem); font-weight: 700; color: var(--black); line-height: 1.12; margin-bottom: 16px; }
.article-meta { font-size: 0.85rem; color: var(--text-muted); margin-bottom: 32px; padding-bottom: 26px; border-bottom: 1px solid var(--border); }
.article-lead { font-size: 1.13rem; line-height: 1.7; color: var(--text); margin-bottom: 8px; }

.article h2 { font-family: var(--serif); font-size: 1.62rem; font-weight: 600; color: var(--black); margin: 42px 0 14px; line-height: 1.25; }
.article h3 { font-size: 1.12rem; font-weight: 600; color: var(--text); margin: 26px 0 8px; }
.article p, .article li { font-size: 1.02rem; line-height: 1.8; color: var(--text-mid); margin-bottom: 15px; }
.article strong { color: var(--text); font-weight: 600; }
.article a { color: var(--gold-dark); text-decoration: underline; text-underline-offset: 2px; }
.article a:hover { color: var(--gold); }
.article ul, .article ol { padding-left: 22px; margin-bottom: 18px; }
.article li { margin-bottom: 8px; }
.article-tip { background: var(--white); border: 1px solid var(--border); border-left: 3px solid var(--gold); border-radius: 10px; padding: 16px 20px; margin: 22px 0; font-size: 0.96rem; color: var(--text-mid); }
.article-tip strong { color: var(--gold-dark); }

.article-cta { background: var(--black); border-radius: 18px; padding: 34px 30px; margin: 42px 0; text-align: center; position: relative; overflow: hidden; }
.article-cta::before { content: ''; position: absolute; top: -50%; left: 50%; transform: translateX(-50%); width: 420px; height: 420px; background: radial-gradient(circle, rgba(201,168,76,0.12), transparent 65%); pointer-events: none; }
.article-cta h3 { position: relative; font-family: var(--serif); font-size: 1.55rem; color: #fff; margin-bottom: 8px; }
.article-cta p { position: relative; color: rgba(255,255,255,0.62); margin-bottom: 22px; font-size: 0.98rem; line-height: 1.6; }
.article-cta .btn-gold { position: relative; }

.article-faq { margin: 42px 0; }
.article-faq h2 { margin-bottom: 6px; }
.article-faq details { border-top: 1px solid var(--border); padding: 16px 2px; }
.article-faq details:last-child { border-bottom: 1px solid var(--border); }
.article-faq summary { font-weight: 600; color: var(--text); cursor: pointer; font-size: 1.04rem; list-style: none; position: relative; padding-right: 28px; }
.article-faq summary::-webkit-details-marker { display: none; }
.article-faq summary::after { content: '+'; position: absolute; right: 4px; top: -2px; font-size: 1.4rem; color: var(--gold-dark); font-weight: 400; }
.article-faq details[open] summary::after { content: '–'; }
.article-faq details p { margin: 12px 0 2px; }

.article-related { margin-top: 52px; padding-top: 30px; border-top: 1px solid var(--border); }
.article-related h2 { font-size: 1.3rem; margin-bottom: 14px; }
.article-related a { display: block; padding: 13px 0; color: var(--text); text-decoration: none; border-bottom: 1px solid var(--border); font-weight: 500; transition: color 0.2s; }
.article-related a:hover { color: var(--gold-dark); }
.article-related a span { color: var(--gold-dark); }
.article-disclaimer { margin-top: 30px; font-size: 0.82rem; color: var(--text-muted); font-style: italic; line-height: 1.6; }

/* ---------- Hub ---------- */
.hub-hero { background: var(--black); padding: 128px 0 66px; text-align: center; position: relative; overflow: hidden; }
.hub-hero-glow { position: absolute; top: -20%; left: 50%; transform: translateX(-50%); width: 640px; height: 640px; background: radial-gradient(circle, rgba(201,168,76,0.1), transparent 65%); filter: blur(40px); pointer-events: none; }
.hub-hero .container { position: relative; z-index: 1; }
.hub-eyebrow { color: var(--gold); font-size: 0.74rem; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 600; margin-bottom: 16px; }
.hub-hero h1 { font-family: var(--serif); font-size: clamp(2.4rem, 5vw, 3.4rem); font-weight: 700; color: #fff; line-height: 1.1; margin-bottom: 16px; }
.hub-hero h1 em { color: var(--gold); font-style: italic; }
.hub-hero p { color: rgba(255,255,255,0.6); max-width: 560px; margin: 0 auto; font-size: 1.05rem; line-height: 1.7; }
.hub-grid { max-width: 1000px; margin: 0 auto; padding: 56px 28px 20px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.hub-card { background: #fff; border: 1px solid var(--border); border-radius: 16px; padding: 28px 26px; text-decoration: none; transition: transform 0.25s var(--ease), box-shadow 0.25s, border-color 0.25s; display: block; }
.hub-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,0.08); border-color: rgba(201,168,76,0.4); }
.hub-card-tag { font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-dark); font-weight: 700; }
.hub-card h2 { font-family: var(--serif); font-size: 1.4rem; color: var(--black); margin: 10px 0 8px; line-height: 1.25; }
.hub-card p { color: var(--text-mid); font-size: 0.95rem; line-height: 1.6; }
.hub-card .read { display: inline-block; margin-top: 14px; color: var(--gold-dark); font-weight: 600; font-size: 0.9rem; }
@media (max-width: 680px) { .hub-grid { grid-template-columns: 1fr; } }
