/* =========================================================
   DE SEO spoke pages (/de/englisch-*) — shared styles.

   Ported verbatim from the klaro-marketer drafts
   (marketing/klaro/content/pages/<slug>/draft.html) and scoped under
   `.de-spoke` so they never leak onto the portal Header / Footer / get-app
   modal. Design tokens mirror /theme.css but are redeclared on `.de-spoke`
   so each page is self-contained (the draft authored its own :root block).
   The four spokes share one identical template, so the CSS lives here once
   and every page links it.
   ========================================================= */
.de-spoke {
  --surface-page: #F5F2EE;
  --surface-card: #FFFFFF;
  --surface-divider: #E7E5E4;
  --text-primary: #1C1917;
  --text-secondary: #44403C;
  --text-muted: #78716C;
  --color-amber: #B45309;
  --color-amber-light: #FEF3C7;
  --radius-pill: 9999px;
  --radius-card: 16px;
  --shadow-card: 0 1px 3px rgba(28, 25, 23, 0.06);

  font-family: 'DM Sans', system-ui, -apple-system, sans-serif;
  color: var(--text-primary);
  background: #fff;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
.de-spoke *, .de-spoke *::before, .de-spoke *::after { box-sizing: border-box; }

/* Same gutter + width as the portal Header/Footer (.site) so content aligns. */
.de-spoke .container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
@media (min-width: 768px) { .de-spoke .container { padding: 0 64px; } }

.de-spoke h1, .de-spoke h2, .de-spoke h3 { font-family: 'Playfair Display', serif; font-weight: 600; line-height: 1.2; margin: 0; }
.de-spoke h1 { font-size: 36px; }
.de-spoke h2 { font-size: 30px; margin-bottom: 18px; }
@media (min-width: 768px) { .de-spoke h1 { font-size: 50px; } .de-spoke h2 { font-size: 40px; } }
.de-spoke p { margin: 0 0 16px; max-width: 65ch; }
.de-spoke a { color: var(--color-amber); }

/* Hero — top padding clears the portal's fixed 64px navbar (+ breathing room). */
.de-spoke section.hero { padding: 104px 0 64px; background: linear-gradient(180deg, #fff, var(--surface-page)); }
.de-spoke .hero-grid { display: grid; grid-template-columns: 1fr; gap: 32px; align-items: center; }
@media (min-width: 900px) { .de-spoke .hero-grid { grid-template-columns: 1.1fr .9fr; } }
.de-spoke .hero-badge { display: inline-flex; align-items: center; gap: 8px; padding: 6px 14px; background: var(--color-amber-light); color: var(--color-amber); border-radius: var(--radius-pill); font-size: 13px; font-weight: 600; }
.de-spoke .hero-badge::before { content: ""; width: 7px; height: 7px; background: var(--color-amber); border-radius: 50%; }
.de-spoke .hero h1 { margin: 18px 0 14px; }
.de-spoke .hero .tagline { font-family: 'Playfair Display', serif; color: var(--color-amber); font-size: 26px; line-height: 1.3; margin: 0 0 14px; }
@media (min-width: 768px) { .de-spoke .hero .tagline { font-size: 34px; } }
.de-spoke .hero .sub { font-size: 17px; color: var(--text-secondary); max-width: 52ch; }
.de-spoke .hero .cta-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; align-items: center; }
.de-spoke .btn-play { display: inline-flex; align-items: center; gap: 8px; padding: 12px 22px; background: var(--text-primary); color: #fff; text-decoration: none; border-radius: var(--radius-pill); font-weight: 600; }
.de-spoke .btn-secondary { display: inline-flex; align-items: center; padding: 12px 22px; background: transparent; color: var(--text-primary); text-decoration: none; border: 1px solid var(--surface-divider); border-radius: var(--radius-pill); font-weight: 600; font-family: inherit; font-size: 15px; cursor: pointer; }
.de-spoke .trust { font-size: 13px; color: var(--text-muted); margin-top: 14px; }
.de-spoke .hero-art { background: var(--color-amber-light); border-radius: var(--radius-card); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; overflow: hidden; padding: 24px; }
.de-spoke .hero-art img { width: 100%; height: 100%; object-fit: contain; }

/* Section base */
.de-spoke section.content { padding: 56px 0; }
.de-spoke section.content.cream { background: var(--surface-page); }
.de-spoke section.content h2 { margin-bottom: 20px; }

/* Citation block */
.de-spoke blockquote.cite { margin: 22px 0; padding: 18px 22px; background: var(--surface-page); border-left: 4px solid var(--color-amber); border-radius: 8px; }
.de-spoke blockquote.cite p { font-style: italic; margin: 0 0 8px; color: var(--text-primary); }
.de-spoke blockquote.cite cite { font-style: normal; color: var(--text-muted); font-size: 13px; }
.de-spoke .book-en { color: var(--text-secondary); }
.de-spoke .book-de-translation { display: block; margin-top: 8px; color: var(--text-muted); font-size: 14px; font-style: normal; }

/* HowTo steps */
.de-spoke .howto { display: grid; grid-template-columns: 1fr; gap: 16px; margin-top: 24px; }
@media (min-width: 768px) { .de-spoke .howto { grid-template-columns: repeat(3, 1fr); } }
.de-spoke .howto-step { padding: 22px; border: 1px solid var(--surface-divider); border-radius: var(--radius-card); background: #fff; }
.de-spoke .howto-step .num { width: 32px; height: 32px; background: var(--color-amber-light); color: var(--color-amber); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-weight: 700; font-family: 'Playfair Display', serif; font-size: 18px; margin-bottom: 12px; }
.de-spoke .howto-step h3 { font-size: 19px; margin-bottom: 8px; }
.de-spoke .howto-step p { margin: 0; font-size: 15px; color: var(--text-secondary); }

/* Episode cards */
.de-spoke .episodes-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 24px; }
@media (min-width: 900px) { .de-spoke .episodes-grid { grid-template-columns: repeat(4, 1fr); } }
.de-spoke .episode-card { aspect-ratio: 3/4; border-radius: var(--radius-card); overflow: hidden; position: relative; box-shadow: var(--shadow-card); display: flex; flex-direction: column; justify-content: flex-end; padding: 14px; color: #fff; background: linear-gradient(180deg, #44403C 30%, #1C1917 100%); }
.de-spoke .episode-card.lvl-1 { background: linear-gradient(180deg, #B45309 30%, #78350F 100%); }
.de-spoke .episode-card.lvl-2 { background: linear-gradient(180deg, #92400E 30%, #44403C 100%); }
.de-spoke .episode-card.lvl-3 { background: linear-gradient(180deg, #92400E 30%, #44403C 100%); }
.de-spoke .episode-card.lvl-4 { background: linear-gradient(180deg, #1C1917 30%, #44403C 100%); }
.de-spoke .episode-card.lvl-5 { background: linear-gradient(180deg, #292524 30%, #0c0a09 100%); }
.de-spoke .episode-card .lvl { display: inline-block; padding: 3px 10px; background: rgba(255, 255, 255, 0.18); border-radius: var(--radius-pill); font-size: 11px; font-weight: 700; letter-spacing: .04em; margin-bottom: 10px; align-self: flex-start; }
.de-spoke .episode-card .ep-title { font-family: 'Playfair Display', serif; font-size: 17px; line-height: 1.25; }
.de-spoke .episode-card .ep-desc { font-size: 12px; opacity: .85; margin-top: 6px; }

/* Segments */
.de-spoke .segments { display: grid; grid-template-columns: 1fr; gap: 22px; margin-top: 22px; }
@media (min-width: 768px) { .de-spoke .segments { grid-template-columns: repeat(3, 1fr); } }
.de-spoke .segment { padding: 22px; background: #fff; border: 1px solid var(--surface-divider); border-radius: var(--radius-card); }
.de-spoke .segment h3 { font-size: 19px; margin-bottom: 8px; }
.de-spoke .segment p { font-size: 15px; color: var(--text-secondary); margin: 0; }

/* FAQ */
.de-spoke .faq { margin-top: 24px; }
.de-spoke .faq details { background: #fff; border: 1px solid var(--surface-divider); border-radius: var(--radius-card); padding: 16px 20px; margin-bottom: 10px; }
.de-spoke .faq details[open] { border-color: var(--color-amber); }
.de-spoke .faq summary { cursor: pointer; font-weight: 600; font-size: 16px; padding-right: 24px; position: relative; list-style: none; }
.de-spoke .faq summary::-webkit-details-marker { display: none; }
.de-spoke .faq summary::after { content: "+"; position: absolute; right: 0; top: 0; color: var(--color-amber); font-size: 20px; }
.de-spoke .faq details[open] summary::after { content: "−"; }
.de-spoke .faq details p { margin: 12px 0 0; color: var(--text-secondary); font-size: 15px; }

/* Sibling links (inline link row) */
.de-spoke .siblings p { max-width: none; }

/* CTA strip */
.de-spoke section.cta-strip { padding: 64px 0; background: var(--surface-page); text-align: center; }
.de-spoke section.cta-strip h2 { margin-bottom: 16px; }
.de-spoke section.cta-strip p { margin: 0 auto 24px; }
.de-spoke .cta-actions { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; align-items: center; }

.de-spoke strong.brand { color: var(--color-amber); font-weight: 600; }

/* =========================================================
   Hub page only (/de/englisch-lernen): value cards, spoke grid, tools strip.
   ========================================================= */
.de-spoke .values { display: grid; grid-template-columns: 1fr; gap: 22px; margin-top: 28px; }
@media (min-width: 768px) { .de-spoke .values { grid-template-columns: repeat(3, 1fr); } }
.de-spoke .value { padding: 22px; background: #fff; border: 1px solid var(--surface-divider); border-radius: var(--radius-card); }
.de-spoke .value .icon { width: 48px; height: 48px; background: var(--color-amber-light); color: var(--color-amber); border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; font-size: 22px; margin-bottom: 14px; }
.de-spoke .value h3 { font-size: 18px; margin-bottom: 6px; }
.de-spoke .value p { margin: 0; font-size: 14px; color: var(--text-secondary); }

.de-spoke .spoke-grid { display: grid; grid-template-columns: 1fr; gap: 16px; margin-top: 24px; }
@media (min-width: 600px) { .de-spoke .spoke-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px) { .de-spoke .spoke-grid { grid-template-columns: repeat(3, 1fr); } }
.de-spoke .spoke-card { padding: 22px; background: #fff; border: 1px solid var(--surface-divider); border-radius: var(--radius-card); transition: border-color .15s; text-decoration: none; color: var(--text-primary); }
.de-spoke .spoke-card:hover { border-color: var(--color-amber); opacity: 1; }
.de-spoke .spoke-card .spoke-eyebrow { font-size: 11px; color: var(--color-amber); font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.de-spoke .spoke-card h3 { font-size: 19px; margin: 8px 0 6px; }
.de-spoke .spoke-card p { font-size: 14px; color: var(--text-secondary); margin: 0; }

.de-spoke .tools-strip { display: grid; grid-template-columns: 1fr; gap: 14px; margin-top: 24px; }
@media (min-width: 600px) { .de-spoke .tools-strip { grid-template-columns: repeat(2, 1fr); } }
.de-spoke .tool-card { display: block; padding: 22px; background: #fff; border: 1px solid var(--surface-divider); border-radius: var(--radius-card); text-decoration: none; color: var(--text-primary); transition: border-color .15s; }
.de-spoke .tool-card:hover { border-color: var(--color-amber); opacity: 1; }
.de-spoke .tool-card .eyebrow { color: var(--color-amber); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; display: block; }
.de-spoke .tool-card h3 { font-size: 18px; margin: 6px 0; }
.de-spoke .tool-card p { margin: 0; font-size: 14px; color: var(--text-secondary); }

/* Breadcrumb visuals + the 84px/20px navbar-clearance spacing live in the shared
   Breadcrumb.astro component. Here we only drop the following hero's own
   navbar-clearance top padding, since the breadcrumb now owns it (KLA-288). */
.de-spoke .breadcrumb + section.hero { padding-top: 0; }
