/* ================================================================
   OLIVER FÄSSLER CFA — DESIGN SYSTEM  v1.0
   ================================================================

   EINBINDUNG IN HTML-SEITEN:
     <link rel="stylesheet" href="/design-system.css">

   EINBINDUNG IN PYTHON-GENERIERTEN REPORTS:
     Den Inhalt dieser Datei in einen <style>-Block einfügen,
     oder per <link> auf den jeweiligen Domain-Pfad verweisen.
     Beispiel Python: open('/var/www/design-system.css').read()

   AUFBAU:
     1.  Design Tokens (Farben, Typografie, Abstände)
     2.  Reset & Base
     3.  Layout
     4.  Header & Navigation
     5.  Hero Section
     6.  Section Labels
     7.  Karten (Method Cards, Report Cards, Tool Cards)
     8.  Badges, Pills, Tags
     9.  Pipeline Steps
     10. Farb-Streifen (Regime, Zyklusphasen)
     11. Listen (Struktur-Liste, Archiv-Grid)
     12. Info-Blöcke (Factors, Quality Note)
     13. Footer
     14. Utilities & Responsive
   ================================================================ */


/* ================================================================
   1. DESIGN TOKENS
   ================================================================ */

:root {

  /* Primärfarbe — Markenblau */
  --c-primary:        #1D4ED8;   /* Hauptakzent: Header-Unterstrich, Icons, Links */
  --c-primary-dark:   #1E3A8A;   /* Dunkelblau: Nummern-Badges, Textakzente */
  --c-primary-mid:    #3B82F6;   /* Mittelblau: Hover-Zustände */
  --c-primary-bg:     #EFF6FF;   /* Sehr hell: Icon-Hintergründe, Featured Cards */
  --c-primary-border: #DBEAFE;   /* Hellblau: Borders für blaue Elemente */
  --c-primary-subtle: #BFDBFE;   /* Subtil: Border bei featured Cards (narrative-Stil) */

  /* Neutrale Farben — Hintergründe & Oberflächen */
  --c-bg:             #F8FAFC;   /* Seiten-Hintergrund */
  --c-surface:        #FFFFFF;   /* Karten, Header */
  --c-surface-dim:    #F8FAFC;   /* Eingesunkene Flächen (Pipeline Steps) */
  --c-border:         #E2E8F0;   /* Standard-Border */
  --c-border-light:   #F1F5F9;   /* Zarte Trennlinien */

  /* Textfarben */
  --c-text-primary:   #0F172A;   /* Überschriften, wichtige Labels */
  --c-text-body:      #374151;   /* Fliesstext, Lead-Texte */
  --c-text-secondary: #475569;   /* Karten-Body-Text */
  --c-text-muted:     #64748B;   /* Byline, Datum, Metadaten */
  --c-text-label:     #94A3B8;   /* Section-Labels, Hilfstexte */
  --c-text-faint:     #CBD5E1;   /* Pfeile, sehr dezente Elemente */

  /* Semantische Farben — Regime / Phasen */
  --c-green-bg:       #F0FDF4;
  --c-green-border:   #86EFAC;
  --c-green-text:     #166534;
  --c-green-sub:      #15803D;

  --c-yellow-bg:      #FFFBEB;
  --c-yellow-border:  #FCD34D;
  --c-yellow-text:    #92400E;
  --c-yellow-sub:     #A16207;

  --c-amber-bg:       #FEF9C3;
  --c-amber-border:   #FDE047;
  --c-amber-text:     #713F12;
  --c-amber-sub:      #92400E;

  --c-red-bg:         #FFF1F2;
  --c-red-border:     #FCA5A5;
  --c-red-text:       #991B1B;
  --c-red-sub:        #B91C1C;

  --c-blue-reg-bg:    #EFF6FF;
  --c-blue-reg-border:#93C5FD;
  --c-blue-reg-text:  #1E3A8A;
  --c-blue-reg-sub:   #1D4ED8;

  /* Status */
  --c-success:        #22C55E;
  --c-warning:        #F59E0B;
  --c-error:          #EF4444;

  /* Typografie */
  --font-base: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;

  /* Abstände */
  --space-xs:   0.4rem;
  --space-sm:   0.75rem;
  --space-md:   1.25rem;
  --space-lg:   2.5rem;
  --space-xl:   4rem;

  /* Radien */
  --radius-sm:  6px;
  --radius-md:  8px;
  --radius-lg:  10px;
  --radius-xl:  12px;
  --radius-pill:999px;

  /* Schatten */
  --shadow-card: 0 1px 3px rgba(0,0,0,.06);
  --shadow-hover: 0 2px 8px rgba(29,78,216,.08);
  --shadow-featured: 0 4px 16px rgba(29,78,216,.14);
}


/* ================================================================
   2. RESET & BASE
   ================================================================ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--font-base);
  background: var(--c-bg);
  color: var(--c-text-primary);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

a { text-decoration: none; }


/* ================================================================
   3. LAYOUT
   ================================================================ */

/* Haupt-Inhaltsbereich — zentriert, max. 860px breit */
main {
  max-width: 860px;
  margin: 0 auto;
  padding: 2.5rem 2rem 4rem;
}

/* Variante: mehr Top-Padding (für Landing-Seite) */
main.main--spacious {
  padding-top: var(--space-xl);
}


/* ================================================================
   4. HEADER & NAVIGATION
   ================================================================ */

header {
  background: var(--c-surface);
  border-bottom: 2px solid var(--c-primary);
  padding: 1.1rem 2rem;
  display: flex;
  align-items: center;
  gap: 0.85rem;
  box-shadow: var(--shadow-card);
}

/* Quadratisches Icon links im Header */
.header-icon {
  width: 32px;
  height: 32px;
  background: var(--c-primary);
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: white;
}
.header-icon svg { width: 18px; height: 18px; }

/* Seiten-Titel im Header */
.header-logo {
  font-size: 1rem;
  font-weight: 800;
  color: var(--c-primary);
  letter-spacing: -0.01em;
}

/* Unterzeile: Autorenname */
.header-byline {
  font-size: 0.78rem;
  color: var(--c-text-muted);
  margin-top: 0.1rem;
}

/* Frequenz-Badge (z.B. "Daily · Mo–Fr") rechts im Header */
.header-badge {
  margin-left: auto;
  background: var(--c-primary-bg);
  color: var(--c-primary);
  font-size: 0.68rem;
  font-weight: 700;
  padding: 0.25rem 0.65rem;
  border-radius: var(--radius-pill);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 1px solid var(--c-primary-border);
}

/* Zurück-Button (Link zur Startseite) */
.back-btn {
  margin-left: 0.75rem;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--c-text-muted);
  text-decoration: none;
  padding: 0.2rem 0.55rem;
  border: 1px solid var(--c-border);
  border-radius: var(--radius-pill);
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
}
.back-btn:hover {
  color: var(--c-primary);
  border-color: var(--c-primary-subtle);
}


/* ================================================================
   5. HERO SECTION
   ================================================================ */

.hero {
  margin-bottom: var(--space-lg);
  text-align: center;
}

.hero h1 {
  font-size: 1.9rem;
  font-weight: 800;
  color: var(--c-text-primary);
  letter-spacing: -0.03em;
  margin-bottom: 0.55rem;
}

/* Einleitungstext unter dem Titel */
.hero .lead {
  font-size: 1rem;
  color: var(--c-text-body);
  max-width: 640px;
  line-height: 1.65;
  margin: 0 auto 1rem;
}

/* Tag-Zeile unter dem Lead-Text */
.hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}

/* Einzelner Tag in der Hero-Tag-Zeile */
.hero-tag {
  background: var(--c-primary-bg);
  color: var(--c-primary-dark);
  font-size: 0.72rem;
  font-weight: 600;
  padding: 0.22rem 0.65rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--c-primary-border);
}


/* ================================================================
   6. SECTION LABELS
   ================================================================ */

/* Abschnitts-Titel (Grau, Grossbuchstaben) */
.section-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-text-label);
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--c-border);
}

/* Engerer Abstand: direkt vor featured Report */
.section-label--tight { margin-bottom: 0.75rem; }


/* ================================================================
   7. KARTEN
   ================================================================ */

/* ---- 7a. METHOD CARDS (2-spaltiges Grid) ---- */

.method-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.85rem;
  margin-bottom: var(--space-lg);
}

.method-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: 1.1rem 1.2rem;
}

/* Header-Zeile mit Icon + Titel */
.method-card .mc-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.6rem;
}

/* Icon-Container in Method Card */
.mc-icon {
  width: 28px;
  height: 28px;
  background: var(--c-primary-bg);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--c-primary);
}
.mc-icon svg { width: 15px; height: 15px; }

.mc-title {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--c-text-primary);
}

.mc-body {
  font-size: 0.8rem;
  color: var(--c-text-secondary);
  line-height: 1.6;
}
.mc-body strong {
  color: var(--c-primary-dark);
  font-weight: 600;
}

/* Variante: Method Card mit Icon links neben Body (narrative-Stil) */
.method-card--inline {
  display: flex;
  gap: 0.9rem;
  align-items: flex-start;
}
.method-card--inline .mc-icon {
  width: 34px;
  height: 34px;
  border-radius: 7px;
  margin-top: 0;
}
.method-card--inline .mc-icon svg { width: 17px; height: 17px; }
.method-card--inline .mc-title { font-size: 0.82rem; }
.method-card--inline .mc-body { font-size: 0.78rem; color: var(--c-text-muted); }


/* ---- 7b. REPORT CARDS (Archiv-Liste) ---- */

.reports-grid {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: var(--space-lg);
}

.report-card {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: 1rem 1.25rem;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s, box-shadow 0.15s;
  box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.report-card:hover {
  border-color: var(--c-primary);
  box-shadow: var(--shadow-hover);
}

/* Hervorgehobene Karte (neuester Report) */
.report-card--featured {
  border-color: var(--c-primary);
  border-width: 2px;
  background: var(--c-primary-bg);
  padding: 1.2rem 1.4rem;
}
.report-card--featured .report-card__icon {
  background: var(--c-primary);
  color: white;
  width: 40px;
  height: 40px;
}
.report-card--featured .report-card__title { font-size: 1rem; }
.report-card--featured:hover { box-shadow: var(--shadow-featured); }

/* Icon */
.report-card__icon {
  width: 36px;
  height: 36px;
  background: var(--c-primary-bg);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--c-primary);
}
.report-card__icon svg { width: 18px; height: 18px; }

/* Meta-Block (Titel + Datum) */
.report-card__meta { flex: 1; }

.report-card__title {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--c-text-primary);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.report-card__date {
  font-size: 0.78rem;
  color: var(--c-text-label);
  margin-top: 0.15rem;
}

/* Pfeil rechts */
.report-card__arrow { color: var(--c-text-faint); flex-shrink: 0; }
.report-card__arrow svg { width: 16px; height: 16px; }

/* --- Kurzform-Aliases (ohne BEM, werden von Index-Generatoren ausgegeben) --- */
.report-card-featured,
.report-card--featured {
  border-color: var(--c-primary);
  border-width: 2px;
  background: var(--c-primary-bg);
  padding: 1.2rem 1.4rem;
}
.report-card-featured .icon,
.report-card--featured .report-card__icon { background: var(--c-primary); color: white; width: 40px; height: 40px; }
.report-card-featured .title { font-size: 1rem; }
.report-card-featured:hover,
.report-card--featured:hover { box-shadow: var(--shadow-featured); }

.report-card .icon {
  width: 36px; height: 36px;
  background: var(--c-primary-bg);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: var(--c-primary);
}
.report-card .icon svg { width: 18px; height: 18px; }
.report-card .meta  { flex: 1; }
.report-card .title { font-size: 0.9rem; font-weight: 600; color: var(--c-text-primary); display: flex; align-items: center; gap: 0.5rem; }
.report-card .date  { font-size: 0.78rem; color: var(--c-text-label); margin-top: 0.15rem; }
.report-card .arrow { color: var(--c-text-faint); flex-shrink: 0; }
.report-card .arrow svg { width: 16px; height: 16px; }

/* Latest-Badge (Featured-Markierung in Index-Seiten) */
.latest-badge {
  background: var(--c-primary);
  color: white;
  font-size: 0.62rem;
  font-weight: 700;
  padding: 0.15rem 0.5rem;
  border-radius: var(--radius-pill);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}


/* ---- 7c. TOOL CARDS (Landing-Seite) ---- */

.tools-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}

.tool-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-top: 4px solid var(--c-primary);
  border-radius: var(--radius-xl);
  padding: 1.75rem 1.75rem 1.5rem;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  transition: box-shadow 0.15s, transform 0.15s;
}
.tool-card:hover {
  box-shadow: 0 4px 16px rgba(29,78,216,.10);
  transform: translateY(-2px);
}

.tool-card__icon {
  width: 44px;
  height: 44px;
  background: var(--c-primary-bg);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.tool-card__icon svg { width: 22px; height: 22px; }

.tool-card__title {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--c-text-primary);
  letter-spacing: -0.02em;
}

.tool-card__desc {
  font-size: 0.845rem;
  color: var(--c-text-secondary);
  line-height: 1.7;
  flex: 1;
}

.tool-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.25rem;
}

.tool-card__link {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--c-primary);
  display: flex;
  align-items: center;
  gap: 0.3rem;
  margin-top: 0.25rem;
}
.tool-card__link svg { width: 13px; height: 13px; }


/* ---- 7d. STRUCTURE ITEMS (Report-Aufbau-Liste) ---- */

.structure-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: var(--space-lg);
}

.structure-item {
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: 0.75rem 1rem;
}

/* Nummerierter Badge links */
.structure-item__num {
  background: var(--c-primary-dark);
  color: white;
  font-size: 0.68rem;
  font-weight: 700;
  min-width: 22px;
  height: 22px;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 0.05rem;
}

.structure-item__title {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--c-text-primary);
  margin-bottom: 0.15rem;
}

.structure-item__desc {
  font-size: 0.78rem;
  color: var(--c-text-muted);
  line-height: 1.5;
}

/* Dezenter Hinweis im Titel (z.B. "aufklappbar") */
.structure-item__hint {
  font-size: 0.72rem;
  color: var(--c-text-label);
  font-weight: 400;
}


/* ================================================================
   8. BADGES, PILLS, TAGS
   ================================================================ */

/* "Aktuell"-Badge auf dem neuesten Report */
.badge-latest {
  background: var(--c-primary);
  color: white;
  font-size: 0.62rem;
  font-weight: 700;
  padding: 0.15rem 0.5rem;
  border-radius: var(--radius-pill);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  vertical-align: middle;
}

/* Tags in Tool Cards und Hero */
.tag {
  background: var(--c-primary-bg);
  color: var(--c-primary-dark);
  font-size: 0.68rem;
  font-weight: 600;
  padding: 0.18rem 0.55rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--c-primary-border);
  letter-spacing: 0.02em;
}

/* Archetype / Faktor-Pill (rechteckiger als Tag) */
.pill {
  background: var(--c-primary-bg);
  border: 1px solid var(--c-primary-border);
  color: #1E40AF;
  font-size: 0.72rem;
  font-weight: 500;
  padding: 0.22rem 0.6rem;
  border-radius: 5px;
}

/* Nummern-Pill (z.B. Faktoren-Liste) */
.factor-pill {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  padding: 0.4rem 0.65rem;
  font-size: 0.77rem;
}

.factor-pill__num {
  background: var(--c-primary);
  color: white;
  font-size: 0.62rem;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.factor-pill__name {
  color: var(--c-primary-dark);
  font-weight: 600;
}

/* Pipeline-Stufen-Badges (farbkodiert nach Funktion) */
.ps-badge {
  display: inline-block;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 0.18rem 0.55rem;
  border-radius: var(--radius-pill);
  margin-bottom: 0.35rem;
}
.ps-badge--generate { background: var(--c-primary-bg);   color: var(--c-primary);       border: 1px solid var(--c-primary-border); }
.ps-badge--check    { background: #F0FDF4; color: #166534; border: 1px solid #BBF7D0; }
.ps-badge--verify   { background: #FDF4FF; color: #7E22CE; border: 1px solid #E9D5FF; }
.ps-badge--infer    { background: #FFF7ED; color: #9A3412; border: 1px solid #FED7AA; }
.ps-badge--clean    { background: #F0FDFA; color: #115E59; border: 1px solid #99F6E4; }


/* ================================================================
   9. PIPELINE STEPS
   ================================================================ */

.pipeline-steps {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin-bottom: 1.2rem;
}

.pipeline-step {
  flex: 1;
  background: var(--c-surface-dim);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: 0.85rem 1rem;
}

.pipeline-arrow {
  color: var(--c-text-faint);
  font-size: 1.1rem;
  font-weight: 300;
  padding-top: 0.9rem;
  flex-shrink: 0;
}

.ps-model { font-size: 0.82rem; font-weight: 700; color: var(--c-text-primary); margin-bottom: 0.3rem; }
.ps-desc  { font-size: 0.76rem; color: var(--c-text-muted); line-height: 1.55; }


/* ================================================================
   10. FARB-STREIFEN (Regime / Zyklusphasen)
   ================================================================ */

/* Container: n-spaltiges Grid */
.color-strip {
  display: grid;
  gap: 0.6rem;
  margin-bottom: var(--space-lg);
}
.color-strip--4col { grid-template-columns: repeat(4, 1fr); }
.color-strip--3col { grid-template-columns: repeat(3, 1fr); }

/* Einzelne farbige Karte */
.color-card {
  border-radius: var(--radius-md);
  padding: 0.75rem 0.9rem;
  border: 1px solid transparent;
}
.color-card__name { font-size: 0.82rem; font-weight: 700; margin-bottom: 0.25rem; }
.color-card__desc { font-size: 0.72rem; line-height: 1.45; }

/* Makro-Regime */
.color-card--goldilocks  { background: var(--c-green-bg);  border-color: var(--c-green-border); }
.color-card--goldilocks  .color-card__name { color: var(--c-green-text); }
.color-card--goldilocks  .color-card__desc { color: var(--c-green-sub);  }

.color-card--reflation   { background: var(--c-yellow-bg); border-color: var(--c-yellow-border); }
.color-card--reflation   .color-card__name { color: var(--c-yellow-text); }
.color-card--reflation   .color-card__desc { color: var(--c-yellow-sub);  }

.color-card--stagflation { background: var(--c-red-bg);    border-color: var(--c-red-border); }
.color-card--stagflation .color-card__name { color: var(--c-red-text);    }
.color-card--stagflation .color-card__desc { color: var(--c-red-sub);     }

.color-card--deflation   { background: var(--c-blue-reg-bg); border-color: var(--c-blue-reg-border); }
.color-card--deflation   .color-card__name { color: var(--c-blue-reg-text); }
.color-card--deflation   .color-card__desc { color: var(--c-blue-reg-sub);  }

/* Zyklusphasen */
.color-card--early-bull  { background: var(--c-green-bg);  border-color: var(--c-green-border); }
.color-card--early-bull  .color-card__name { color: var(--c-green-text); }
.color-card--early-bull  .color-card__desc { color: var(--c-green-sub);  }

.color-card--mid-bull    { background: var(--c-yellow-bg); border-color: var(--c-yellow-border); }
.color-card--mid-bull    .color-card__name { color: var(--c-yellow-text); }
.color-card--mid-bull    .color-card__desc { color: var(--c-yellow-sub);  }

.color-card--late-bull   { background: #FEF3C7; border-color: #FBBF24; }
.color-card--late-bull   .color-card__name { color: #92400E; }
.color-card--late-bull   .color-card__desc { color: #A16207; }

.color-card--topping     { background: var(--c-red-bg);    border-color: var(--c-red-border); }
.color-card--topping     .color-card__name { color: var(--c-red-text); }
.color-card--topping     .color-card__desc { color: var(--c-red-sub);  }

.color-card--bear        { background: var(--c-amber-bg);  border-color: var(--c-amber-border); }
.color-card--bear        .color-card__name { color: var(--c-amber-text); }
.color-card--bear        .color-card__desc { color: var(--c-amber-sub);  }

.color-card--bottoming   { background: var(--c-blue-reg-bg); border-color: var(--c-blue-reg-border); }
.color-card--bottoming   .color-card__name { color: var(--c-blue-reg-text); }
.color-card--bottoming   .color-card__desc { color: var(--c-blue-reg-sub);  }


/* ================================================================
   11. INFO-BLÖCKE
   ================================================================ */

/* Generischer weisser Block mit Border (Faktoren, Qualitätssicherung etc.) */
.info-block {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: 1.2rem 1.4rem;
  margin-bottom: var(--space-lg);
}

.info-block__title {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--c-text-primary);
  margin-bottom: 0.75rem;
}

.info-block__sub {
  font-size: 0.76rem;
  color: var(--c-text-muted);
  margin-bottom: 1rem;
  line-height: 1.55;
}

/* Intro-Zeile mit grösserem Icon (Qualitätssicherung) */
.info-block__intro {
  display: flex;
  gap: 0.9rem;
  margin-bottom: 1.4rem;
  padding-bottom: 1.2rem;
  border-bottom: 1px solid var(--c-border-light);
}

.info-block__intro-icon {
  width: 34px;
  height: 34px;
  background: var(--c-primary-bg);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--c-primary);
  margin-top: 0.1rem;
}
.info-block__intro-icon svg { width: 18px; height: 18px; }

.info-block__intro-title {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--c-text-primary);
  margin-bottom: 0.3rem;
}

.info-block__intro-body {
  font-size: 0.78rem;
  color: var(--c-text-secondary);
  line-height: 1.65;
}

/* Hervorgehobene Notiz (blauer linker Balken) */
.info-note {
  background: var(--c-bg);
  border-left: 3px solid var(--c-primary);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: 0.7rem 0.9rem;
  font-size: 0.77rem;
  color: var(--c-text-secondary);
  line-height: 1.6;
}
.info-note strong { color: var(--c-primary-dark); }

/* Faktoren-Grid (3-spaltig) */
.factors-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
}

/* Archetype Pills Container */
.pills-container {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}


/* ================================================================
   12. FOOTER
   ================================================================ */

footer {
  text-align: center;
  padding: 2rem;
  font-size: 0.75rem;
  color: var(--c-text-label);
  border-top: 1px solid var(--c-border);
  margin-top: 3rem;
}

footer a {
  color: var(--c-primary);
  text-decoration: none;
}

footer a:hover { text-decoration: underline; }

.footer-sub {
  margin-top: 0.4rem;
  font-size: 0.7rem;
  color: var(--c-text-faint);
}


/* ================================================================
   13. UTILITIES & RESPONSIVE
   ================================================================ */

/* Spacing Helpers */
.mb-section { margin-bottom: var(--space-lg); }   /* 2.5rem */
.mb-sm      { margin-bottom: var(--space-sm); }   /* 0.75rem */
.mb-0       { margin-bottom: 0; }

/* Text Helpers */
.text-muted   { color: var(--c-text-muted); }
.text-label   { color: var(--c-text-label); font-size: 0.72rem; font-weight: 400; }
.text-primary { color: var(--c-primary); }
.text-strong  { color: var(--c-primary-dark); font-weight: 600; }

/* Responsive Breakpoints */
@media (max-width: 640px) {
  main { padding: 1.5rem 1rem 3rem; }

  .method-grid      { grid-template-columns: 1fr; }
  .tools-grid       { grid-template-columns: 1fr; }
  .color-strip--4col{ grid-template-columns: 1fr 1fr; }
  .color-strip--3col{ grid-template-columns: 1fr 1fr; }
  .factors-grid     { grid-template-columns: 1fr 1fr; }

  .pipeline-steps   { flex-direction: column; }
  .pipeline-arrow   { transform: rotate(90deg); align-self: center; }

  .hero h1 { font-size: 1.5rem; }
}


/* ================================================================
   15. REPORT — Narrative Cycle Intelligence
   ================================================================ */

/* ---- 15a. Variable-Aliases (Rückwärts-Kompatibilität Report) ---- */
:root {
  --primary:      var(--c-primary);
  --primary-mid:  var(--c-primary-mid);
  --primary-lt:   var(--c-primary-mid);
  --primary-pale: var(--c-primary-border);
  --white:        var(--c-surface);
  --bg:           var(--c-bg);
  --border:       var(--c-border);
  --border-mid:   var(--c-text-faint);
  --text:         var(--c-text-primary);
  --text-mid:     var(--c-text-body);
  --text-muted:   var(--c-text-muted);
  --text-light:   var(--c-text-label);
  --red:          #DC2626;
  --red-mid:      #EF4444;
  --red-bg:       #FEF2F2;
  --red-pale:     #FEE2E2;
  --amber:        var(--c-warning);
  --amber-bg:     var(--c-yellow-bg);
  --amber-pale:   #FEF3C7;
  --green:        var(--c-success);
  --green-bg:     var(--c-green-bg);
  --green-pale:   #DCFCE7;
  --shadow-sm:    0 1px 2px rgba(0,0,0,.05);
  --shadow:       var(--shadow-card);
  --shadow-md:    var(--shadow-hover);
  --shadow-lg:    var(--shadow-featured);
  --radius:       var(--radius-lg);
  --radius-xs:    4px;
}

/* ---- 15b. Base Overrides ---- */
html { scroll-behavior: smooth; }
body { font-size: 14px; line-height: 1.6; }

/* ---- 15c. Report Layout ---- */
main.main--report {
  max-width: 1320px;
  padding: 24px 32px 60px;
}

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 18px; }
.col-span-2 { grid-column: span 2; }
section + section { margin-top: 20px; }

/* ---- 15d. Report Header ---- */
header {
  position: sticky;
  top: 0;
  z-index: 100;
  padding: 16px 40px 20px;
}

.header-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.header-brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Report-Variante: back-btn mit Hintergrund statt Border */
.back-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-left: auto;
  background: var(--c-primary-bg);
  color: var(--c-primary);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.3rem 0.75rem;
  border-radius: var(--radius-md);
  border: none;
  text-decoration: none;
  transition: background .15s;
}
.back-btn:hover { background: var(--c-primary-border); border-color: transparent; color: var(--c-primary); }
.back-btn svg { width: 14px; height: 14px; }

header h1 {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--c-text-primary);
  line-height: 1.2;
  margin-top: 0.85rem;
}

header .subtitle {
  font-size: 0.78rem;
  color: var(--c-text-muted);
  margin-top: 0.2rem;
}

header .tags {
  display: flex;
  gap: 6px;
  margin-top: 10px;
  flex-wrap: wrap;
}

/* Report-Tag: leicht eckiger als Design-System-Pill */
.tag {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .03em;
  padding: 3px 9px;
  border-radius: var(--radius-sm);
  background: var(--c-primary-bg);
  color: var(--c-primary-mid);
  border: 1px solid var(--c-primary-border);
}

.tag--alert {
  background: var(--red-bg);
  color: var(--red);
  border-color: var(--red-pale);
}

/* ---- 15e. Cards ---- */
.card {
  background: var(--c-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.card-header {
  padding: 13px 20px 11px;
  border-bottom: 1px solid var(--c-border);
  display: flex;
  align-items: center;
  gap: 10px;
}

.card-header .label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--c-text-label);
  margin-bottom: 2px;
}

.card-header h2 {
  font-size: 13px;
  font-weight: 700;
  color: var(--c-text-body);
}

.card-body { padding: 18px 20px; }

.section-title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--c-primary-mid);
  margin-bottom: 14px;
  padding-bottom: 5px;
  border-bottom: 2px solid var(--c-primary-bg);
}

/* ---- 15f. Regime Card ---- */
.regime-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-hover);
  overflow: hidden;
}

.regime-card-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 200px;
}

.regime-dominant {
  padding: 22px 24px;
  border-right: 1px solid var(--c-border);
  border-left: 4px solid var(--c-primary);
}

.regime-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--c-primary-mid);
  margin-bottom: 8px;
}

.regime-name {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--c-text-primary);
  line-height: 1.2;
  margin-bottom: 14px;
}

.regime-score-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
}

.regime-score-num { font-size: 36px; font-weight: 800; color: var(--c-primary); line-height: 1; }
.regime-score-pct { font-size: 16px; color: var(--c-text-muted); }

.score-bar-track {
  flex: 1;
  height: 6px;
  background: var(--c-primary-border);
  border-radius: 3px;
  overflow: hidden;
}

.score-bar-fill {
  height: 6px;
  background: var(--c-primary);
  border-radius: 3px;
  transition: width .5s ease;
}

.regime-chips { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }

.chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
}

.chip-phase   { background: var(--c-primary-bg);  color: var(--c-primary-mid); border: 1px solid var(--c-primary-border); }
.chip-neutral { background: var(--c-bg);           color: var(--c-text-muted);  border: 1px solid var(--c-border); }
.chip-bullish { background: var(--c-green-bg);     color: var(--c-success);     border: 1px solid var(--c-green-border); }
.chip-bearish { background: var(--red-bg);         color: var(--red);           border: 1px solid var(--red-pale); }

.chip-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--c-warning); }

.regime-stats { display: flex; gap: 20px; font-size: 12px; color: var(--c-text-muted); }
.regime-stats .stat strong { color: var(--c-text-body); font-weight: 600; }

.regime-secondary { padding: 22px 24px; }

.secondary-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--c-text-label);
  margin-bottom: 14px;
}

.secondary-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 0;
  border-bottom: 1px solid var(--c-bg);
}
.secondary-item:last-child { border-bottom: none; }

.secondary-rank {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700; color: var(--c-text-muted);
  flex-shrink: 0;
}

.secondary-name {
  flex: 1;
  font-size: 12px; font-weight: 600; color: var(--c-text-body);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.secondary-bar-track {
  width: 70px; height: 4px;
  background: var(--c-border);
  border-radius: 2px; overflow: hidden; flex-shrink: 0;
}
.secondary-bar-fill { height: 4px; background: var(--c-primary-mid); border-radius: 2px; }

.secondary-score {
  font-size: 12px; font-weight: 700; color: var(--c-text-primary);
  width: 38px; text-align: right; flex-shrink: 0;
}

/* ---- 15g. Lifecycle ---- */
.lifecycle { display: flex; align-items: stretch; gap: 0; margin: 4px 0 16px; }

.lc-step {
  flex: 1; text-align: center;
  font-size: 9.5px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
  padding: 8px 4px;
  border-top: 3px solid var(--c-border);
  color: var(--c-text-label);
}
.lc-step.active  { border-top-color: var(--c-primary);  color: var(--c-primary-mid); }
.lc-step.done    { border-top-color: var(--c-text-faint); color: var(--c-text-label); }
.lc-step.warning { border-top-color: var(--c-warning);   color: var(--c-warning); }

/* ---- 15h. Horizon Cards ---- */
.horizon-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }

.horizon-card {
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.horizon-card-header {
  padding: 8px 14px;
  font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
}

.horizon-immediate .horizon-card-header { background: var(--red-bg);        color: var(--red);           border-bottom: 1px solid var(--red-pale); }
.horizon-tactical  .horizon-card-header { background: var(--c-yellow-bg);   color: var(--c-warning);     border-bottom: 1px solid var(--c-yellow-border); }
.horizon-strategic .horizon-card-header { background: var(--c-primary-bg);  color: var(--c-primary-mid); border-bottom: 1px solid var(--c-primary-border); }

.horizon-card-body { padding: 12px 14px; background: var(--c-surface); }
.horizon-regime    { font-size: 13px; font-weight: 700; color: var(--c-text-primary); }
.horizon-detail    { font-size: 12px; color: var(--c-text-body); margin-top: 5px; line-height: 1.5; }

/* ---- 15i. Transition Probabilities ---- */
.trans-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 5px 0;
  border-bottom: 1px solid var(--c-bg);
}
.trans-item:last-child { border-bottom: none; }

.trans-name { font-size: 12px; color: var(--c-text-body); flex: 1; }

.trans-bar-track {
  width: 80px; height: 5px;
  background: var(--c-border);
  border-radius: 3px; overflow: hidden;
  margin: 0 10px; flex-shrink: 0;
}
.trans-bar-fill { height: 5px; border-radius: 3px; background: var(--c-primary); }

.trans-prob { font-size: 12px; font-weight: 700; color: var(--c-text-primary); width: 36px; text-align: right; }

/* ---- 15j. Claude Synthesis ---- */
.synthesis-card {
  background: var(--c-primary-bg);
  border: 1px solid var(--c-primary-border);
  border-left: 4px solid var(--c-primary);
  border-radius: var(--radius-lg);
  padding: 22px 28px;
  box-shadow: var(--shadow-card);
}

.synthesis-top-label {
  font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--c-primary-mid); margin-bottom: 4px;
}

.synthesis-title { font-size: 15px; font-weight: 800; color: var(--c-text-primary); margin-bottom: 18px; }

.conf-row { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; margin-bottom: 18px; }

.conf-block {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.conf-block .cb-label {
  font-size: 10px; font-weight: 600; color: var(--c-text-muted);
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: 8px;
}
.conf-block .cb-num  { font-size: 30px; font-weight: 800; line-height: 1; margin-bottom: 6px; }
.conf-block .cb-bar-bg { background: var(--c-border); border-radius: 3px; height: 4px; }
.conf-block .cb-bar    { height: 4px; border-radius: 3px; }

.synthesis-reasoning {
  font-size: 13px; color: var(--c-text-body); line-height: 1.7;
  margin-bottom: 14px;
  border-left: 3px solid var(--c-primary-mid);
  padding-left: 14px;
}

.key-risk-box {
  background: var(--red-bg);
  border: 1px solid var(--red-pale);
  border-radius: var(--radius-md);
  padding: 10px 14px;
}
.key-risk-label {
  font-size: 10px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  color: var(--red); margin-bottom: 4px;
  display: flex; align-items: center; gap: 5px;
}
.key-risk-label svg { width: 12px; height: 12px; flex-shrink: 0; }
.key-risk-box p { font-size: 12px; color: #7F1D1D; }

.syn-disclaimer { font-size: 10px; color: var(--c-text-label); margin-top: 10px; text-align: right; }

/* ---- 15k. Tables ---- */
table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
th {
  text-align: left;
  font-size: 10px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  color: var(--c-text-label);
  padding: 8px 12px;
  background: var(--c-bg);
  border-bottom: 1px solid var(--c-border);
}
td { padding: 9px 12px; border-bottom: 1px solid var(--c-bg); vertical-align: middle; }
tr:last-child td { border-bottom: none; }
tr:hover td { background: var(--c-bg); }

/* ---- 15l. Report Badges ---- */
.phase-badge-sm {
  font-size: 10px; font-weight: 600; padding: 2px 7px;
  border-radius: var(--radius-sm);
  background: var(--c-primary-bg); color: var(--c-primary-mid);
}

.trend-up { color: var(--c-success);    font-weight: 600; }
.trend-dn { color: var(--red-mid);      font-weight: 600; }
.trend-st { color: var(--c-text-label); }

.polarity-bullish { color: var(--c-success);    font-weight: 600; }
.polarity-bearish { color: var(--red);           font-weight: 600; }
.polarity-neutral { color: var(--c-text-label); }

/* ---- 15m. Emerging Alerts ---- */
.emerging-alert {
  background: var(--c-yellow-bg);
  border: 1px solid var(--amber-pale);
  border-left: 4px solid var(--c-warning);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  margin-bottom: 12px;
}

.alert-badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 10px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  color: var(--c-warning); margin-bottom: 6px;
}
.alert-badge svg { width: 12px; height: 12px; }

.alert-name { font-size: 15px; font-weight: 700; color: #78350F; margin-bottom: 6px; }
.alert-text { font-size: 12.5px; color: #92400E; line-height: 1.55; }

.tag-list { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.keyword-tag {
  font-size: 11px;
  background: rgba(217,119,6,.1);
  color: #78350F;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(217,119,6,.2);
}

/* ---- 15n. Market Signals ---- */
.market-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }

.market-item {
  padding: 12px 14px;
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
}
.market-label { font-size: 10px; color: var(--c-text-label); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 4px; }
.market-value { font-size: 15px; font-weight: 700; color: var(--c-text-primary); }

.divergence-item {
  padding: 10px 14px;
  background: var(--c-yellow-bg);
  border: 1px solid var(--amber-pale);
  border-radius: var(--radius-md);
  margin-bottom: 8px;
  font-size: 12.5px; color: #78350F;
}
.divergence-ok { background: var(--c-green-bg); border-color: var(--c-green-border); color: #14532D; }

/* ---- 15o. Charts ---- */
.chart-wrap    { position: relative; height: 220px; }
.chart-wrap-lg { position: relative; height: 300px; }
.chart-wrap-md { position: relative; height: 240px; }

/* ---- 15p. Conviction Matrix ---- */
.matrix-wrap { position: relative; }
.matrix-quadrant {
  position: absolute;
  font-size: 9px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
  opacity: .5; pointer-events: none;
}

/* ---- 15q. Parent Groups ---- */
.parent-card {
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  background: var(--c-bg);
}
.parent-name { font-size: 10px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--c-text-muted); margin-bottom: 6px; }
.parent-score { font-size: 24px; font-weight: 800; color: var(--c-text-primary); }
.parent-sub   { font-size: 11px; color: var(--c-text-label); margin-top: 4px; }

/* ---- 15r. Falsification ---- */
.trigger-active {
  background: var(--red-bg);
  border: 1px solid var(--red-pale);
  border-left: 3px solid var(--red);
  border-radius: var(--radius-sm);
  padding: 10px 14px; margin-bottom: 6px;
}
.trigger-watch {
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  padding: 9px 14px; margin-bottom: 5px;
}
.trigger-text { font-size: 12.5px; }
.trigger-meta { font-size: 10px; text-transform: uppercase; letter-spacing: .04em; margin-top: 3px; }
.trigger-active .trigger-text { color: #7F1D1D; }
.trigger-active .trigger-meta { color: var(--red); }
.trigger-watch  .trigger-text { color: var(--c-text-body); }
.trigger-watch  .trigger-meta { color: var(--c-text-label); }

/* ---- 15s. Pipeline Details ---- */
details summary {
  cursor: pointer;
  font-size: 11px; font-weight: 600; color: var(--c-text-muted);
  letter-spacing: .06em; text-transform: uppercase;
  padding: 10px 0;
  list-style: none; user-select: none;
}
details summary::-webkit-details-marker { display: none; }
details summary::before       { content: '▶ '; font-size: 9px; }
details[open] summary::before { content: '▼ '; }

/* ---- 15t. Glossary ---- */
.glossary-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.glossary-item {
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  background: var(--c-bg);
}
.glossary-term { font-size: 12px; font-weight: 700; color: var(--c-text-primary); margin-bottom: 5px; }
.glossary-def  { font-size: 12px; color: var(--c-text-body); line-height: 1.55; }

/* ---- 15u. Report Footer ---- */
.footer--report {
  background: var(--c-surface);
  border-top: 1px solid var(--c-border);
  padding: 14px 40px;
  font-size: 11px; color: var(--c-text-label);
  display: flex; justify-content: space-between;
  margin-top: 40px;
  text-align: left;
}
.footer--report a       { color: var(--c-text-muted); text-decoration: none; }
.footer--report a:hover { color: var(--c-primary); }

/* ---- 15v. Responsive (Report) ---- */
@media (max-width: 1024px) {
  .regime-card-inner { grid-template-columns: 1fr; }
  .regime-dominant   { border-right: none; border-bottom: 1px solid var(--c-border); }
}

@media (max-width: 900px) {
  .grid-2, .grid-3, .horizon-grid, .market-grid, .glossary-grid, .conf-row {
    grid-template-columns: 1fr;
  }
  .col-span-2              { grid-column: span 1; }
  main.main--report        { padding: 16px; }
  header                   { padding: 14px 20px 16px; position: static; }
}


/* ================================================================
   15. TECHNICALS REPORT KOMPONENTEN
   Verwendet von: ResearchHub/Technicals/report/report_generator.py
   Breites Layout (max-width 1100px), report-spezifische Blöcke.
   ================================================================ */

/* --- Wide page layout (Technicals verwendet 1100px statt 860px) --- */
.header-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 14px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--c-primary);
  letter-spacing: -0.3px;
}
.header-meta {
  font-size: 12px;
  color: var(--c-text-muted);
}
.page {
  max-width: 1100px;
  margin: 0 auto;
  padding: 28px 24px 60px;
}

/* --- Hero (3-Stat-Grid) --- */
.hero {
  background: white;
  border-radius: var(--radius-md);
  border: 1px solid var(--c-border);
  padding: 28px 32px;
  margin-bottom: 24px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 24px;
}
.hero-stat         { text-align: center; }
.hero-stat-label   { font-size: 11px; text-transform: uppercase; letter-spacing: 0.8px; color: var(--c-text-faint); margin-bottom: 6px; }
.hero-stat-value   { font-size: 26px; font-weight: 700; color: var(--c-text-primary); letter-spacing: -0.5px; }
.hero-stat-sub     { font-size: 12px; color: var(--c-text-muted); margin-top: 3px; }

/* --- Stats Row (4 Boxen) --- */
.stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.stat-box         { background: var(--c-surface); border-radius: var(--radius-sm); padding: 12px; text-align: center; border: 1px solid var(--c-border); }
.stat-box-label   { font-size: 10px; text-transform: uppercase; letter-spacing: 0.6px; color: var(--c-text-faint); }
.stat-box-value   { font-size: 17px; font-weight: 700; color: var(--c-text-primary); margin-top: 3px; }
.stat-box-sub     { font-size: 11px; color: var(--c-text-muted); margin-top: 2px; }

/* --- Progress Bar --- */
.progress-bar-wrap { background: var(--c-border); border-radius: var(--radius-sm); height: 10px; margin: 8px 0; overflow: hidden; }
.progress-bar-fill { height: 10px; border-radius: var(--radius-sm); background: linear-gradient(90deg, var(--c-primary), var(--c-primary-mid)); transition: width 0.3s; }

/* --- Card (Technicals-Variante, wide-layout) --- */
.card {
  background: white;
  border-radius: var(--radius-md);
  border: 1px solid var(--c-border);
  padding: 24px;
  margin-bottom: 20px;
}
.card-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--c-text-primary);
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--c-primary-bg);
  display: flex;
  align-items: center;
  gap: 8px;
}
.card-title-icon {
  width: 20px;
  height: 20px;
  background: var(--c-primary-bg);
  border-radius: var(--radius-xs);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}

/* --- Chart Container --- */
.chart-container img { width: 100%; border-radius: var(--radius-xs); border: 1px solid var(--c-border); }

/* --- Grid Utilities --- */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }

/* --- Section Subheaders --- */
.section-subheader  { font-size: 15px; font-weight: 700; color: var(--c-primary); margin: 20px 0 8px; padding-bottom: 4px; border-bottom: 1px solid var(--c-primary-border); }
.section-subheader2 { font-size: 14px; font-weight: 600; color: var(--c-text-body); margin: 14px 0 6px; }

/* --- Analysis List (Bullet → Pfeil) --- */
.analysis-list      { list-style: none; padding: 0; }
.analysis-list li   { padding: 5px 0 5px 18px; position: relative; font-size: 13.5px; color: var(--c-text-body); border-bottom: 1px solid var(--c-border); }
.analysis-list li::before { content: "→"; position: absolute; left: 0; color: var(--c-primary); font-weight: 700; }

/* --- Analysis Label --- */
.analysis-label { font-weight: 700; color: var(--c-primary); }

/* --- Elliott Wave Tabs --- */
.ew-tabs   { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.ew-tab    { padding: 6px 16px; border-radius: var(--radius-xs); font-size: 12px; font-weight: 600; cursor: pointer; border: 1px solid var(--c-border); background: white; color: var(--c-text-muted); }
.ew-tab.active  { background: var(--c-primary); color: white; border-color: var(--c-primary); }
.ew-panel       { display: none; }
.ew-panel.active { display: block; }

/* --- Tabellen --- */
table { width: 100%; border-collapse: collapse; }
th    { background: var(--c-surface); font-size: 11px; text-transform: uppercase; letter-spacing: 0.6px; color: var(--c-text-faint); padding: 8px 12px; text-align: left; border-bottom: 2px solid var(--c-border); }
td    { padding: 8px 12px; font-size: 13px; color: var(--c-text-body); }
tr:not(:last-child) td { border-bottom: 1px solid var(--c-border); }

/* --- Signal Pills --- */
.signal-bull    { background: var(--c-green-bg);  color: var(--c-green-text);  padding: 2px 8px; border-radius: var(--radius-pill); font-size: 11px; font-weight: 600; }
.signal-bear    { background: var(--c-red-bg);    color: var(--c-red-text);    padding: 2px 8px; border-radius: var(--radius-pill); font-size: 11px; font-weight: 600; }
.signal-neutral { background: var(--c-neutral-bg, #F3F4F6); color: var(--c-text-body); padding: 2px 8px; border-radius: var(--radius-pill); font-size: 11px; font-weight: 600; }
.signal-caution { background: var(--c-yellow-bg); color: var(--c-yellow-text); padding: 2px 8px; border-radius: var(--radius-pill); font-size: 11px; font-weight: 600; }

/* --- Collapsible Synthesis --- */
.synthesis-collapse   { margin-bottom: 20px; }
.synthesis-summary    { background: white; border: 1px solid var(--c-border); border-radius: var(--radius-md); padding: 16px 24px; cursor: pointer; display: flex; align-items: center; gap: 8px; font-size: 15px; font-weight: 700; color: var(--c-text-primary); list-style: none; user-select: none; }
.synthesis-summary::-webkit-details-marker { display: none; }
.synthesis-summary:hover { background: var(--c-surface); }
.synthesis-toggle-hint { margin-left: auto; font-size: 12px; font-weight: 400; color: var(--c-text-muted); }
details[open] .synthesis-toggle-hint { display: none; }
.synthesis-inner { margin-top: 4px; border-top-left-radius: 0; border-top-right-radius: 0; }

/* --- Disclaimer (Technicals-Variante) --- */
.disclaimer { margin-top: 40px; padding: 16px 20px; background: var(--c-surface); border-radius: var(--radius-sm); border: 1px solid var(--c-border); font-size: 11px; color: var(--c-text-faint); line-height: 1.5; }

/* --- Byline (Header-Unterzeile) --- */
.byline { font-size: 0.78rem; color: var(--c-text-muted); margin-top: 0.1rem; }

/* --- Structure Item Kurzform-Aliases (si-* statt structure-item__*) --- */
.si-num   { background: var(--c-primary-dark); color: white; font-size: 0.68rem; font-weight: 700; min-width: 22px; height: 22px; border-radius: 5px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 0.05rem; }
.si-title { font-size: 0.85rem; font-weight: 700; color: var(--c-text-primary); margin-bottom: 0.15rem; }
.si-desc  { font-size: 0.78rem; color: var(--c-text-muted); line-height: 1.5; }

/* --- Technicals Index: Cycle-Phase-Strip --- */
.cycle-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.6rem;
  margin-bottom: 2.5rem;
}
.cycle-card          { border-radius: var(--radius-md); padding: 0.75rem 0.9rem; border: 1px solid transparent; }
.cycle-card .cc-name { font-size: 0.82rem; font-weight: 700; margin-bottom: 0.25rem; }
.cycle-card .cc-desc { font-size: 0.72rem; line-height: 1.45; }
.cc-bull   { background: var(--c-green-bg);  border-color: #86efac; }
.cc-bull .cc-name   { color: var(--c-green-text); }
.cc-bull .cc-desc   { color: #15803d; }
.cc-mid    { background: var(--c-yellow-bg); border-color: #fcd34d; }
.cc-mid .cc-name    { color: var(--c-yellow-text); }
.cc-mid .cc-desc    { color: #a16207; }
.cc-top    { background: var(--c-red-bg);    border-color: #fca5a5; }
.cc-top .cc-name    { color: var(--c-red-text); }
.cc-top .cc-desc    { color: #b91c1c; }
.cc-bear   { background: #fef9c3; border-color: #fde047; }
.cc-bear .cc-name   { color: #713f12; }
.cc-bear .cc-desc   { color: var(--c-yellow-text); }
.cc-bottom { background: var(--c-primary-bg); border-color: #93c5fd; }
.cc-bottom .cc-name { color: var(--c-primary-dark); }
.cc-bottom .cc-desc { color: var(--c-primary); }

/* --- Responsive (Technicals) --- */
@media (max-width: 768px) {
  .hero        { grid-template-columns: 1fr; }
  .stats-row   { grid-template-columns: 1fr 1fr; }
  .grid-2      { grid-template-columns: 1fr; }
  .page        { padding: 16px 16px 40px; }
  .cycle-strip { grid-template-columns: 1fr 1fr; }
}
