/**
 * SCHEDULED FOR CONSOLIDATION (Verify if still needed)
 * 
 * Target: public/css/velora-components.css
 * Ticket: #3 (Consolidate calculator-results.css)
 * Reason: Result component styles belong in consolidated components file
 * Status: Verify usage before consolidation
 * 
 * DO NOT add new styles to this file.
 * Use velora-components.css instead.
 * 
 * This file will be moved to /public/css/legacy/ after consolidation.
 * See CSS_CONSOLIDATION_REMAINING_TICKETS.md for details.
 */

/*
 * Calculator Results Styling
 * ========================
 * Styles for calculator result pages following the VELORA_DESIGN_DOCTRINE
 * Ensures: Meaning-first hierarchy, progressive disclosure, visual restraint
 * All components use Alpine.js for progressive enhancement
 */

/* Base Container */
.calculator-result-page {
    background-color: var(--color-neutral-50);
    color: var(--color-neutral-900);
}

/* Technical Data Section */
.technical-data-wrapper {
    margin-top: var(--space-8);
    border-top: 1px solid var(--reading-separator-line, var(--color-neutral-200));
    padding-top: var(--space-6);
}

.technical-data-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: var(--space-4);
    background: var(--surface-soft, var(--color-neutral-50));
    border: 1px solid var(--reading-separator-line, var(--color-neutral-200));
    border-radius: var(--radius-md);
    font-family: var(--font-serif);
    font-weight: 600;
    color: var(--velora-text-primary);
    cursor: pointer;
    transition: all 200ms ease;
}

.technical-data-toggle:hover { background: var(--surface-hover, var(--color-neutral-100)); }
.technical-data-toggle i { transition: transform 200ms ease; }
.technical-data-toggle i.rotate-180 { transform: rotate(180deg); }

.technical-data-content { margin-top: var(--space-6); }

.fixed-stars-list, .arabic-parts-list { display: flex; flex-direction: column; gap: var(--space-4); }
.fixed-star-item, .arabic-part-item { padding: var(--space-4); background: var(--surface-card, #ffffff); border: 1px solid var(--reading-separator-line, var(--color-neutral-200)); border-radius: var(--radius-md); }
.fixed-star-item p, .arabic-part-item p { margin-top: var(--space-2); color: var(--velora-text-muted); font-size: 0.9rem; }

.technical-metadata-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: var(--space-4); }
.metadata-item { display: flex; flex-direction: column; gap: var(--space-1); padding: var(--space-3); background: var(--surface-soft, var(--color-neutral-50)); border-radius: var(--radius-sm); }
.metadata-label { font-size: 0.85rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--velora-text-muted); }
.metadata-value { font-family: var(--font-mono, monospace); font-size: 0.95rem; color: var(--velora-text-primary); }
.empty-state { color: var(--velora-text-muted); font-style: italic; text-align: center; padding: var(--space-6); }

/* Dark mode for technical data */
[data-theme="dark"] .technical-data-toggle, .dark .technical-data-toggle { background: var(--surface-soft, var(--color-neutral-800)); border-color: var(--reading-separator-line, var(--color-neutral-700)); color: var(--velora-text-primary, var(--color-neutral-100)); }
[data-theme="dark"] .technical-data-toggle:hover, .dark .technical-data-toggle:hover { background: var(--surface-hover, var(--color-neutral-700)); }
[data-theme="dark"] .fixed-star-item, [data-theme="dark"] .arabic-part-item, .dark .fixed-star-item, .dark .arabic-part-item { background: var(--surface-card, var(--color-neutral-800)); border-color: var(--reading-separator-line, var(--color-neutral-700)); }
[data-theme="dark"] .metadata-item, .dark .metadata-item { background: var(--surface-soft, var(--color-neutral-800)); }

/* Aspect Patterns */
.aspect-patterns-section { margin-top: var(--space-6); }
.aspect-patterns-list { display: flex; flex-direction: column; gap: var(--space-4); }
.aspect-pattern-item { padding: var(--space-4); background: var(--surface-card); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-md); }
.aspect-pattern-type { font-family: var(--font-serif); font-size: 1rem; margin: 0 0 var(--space-2) 0; }
.aspect-pattern-planets { color: var(--velora-text-muted); font-size: 0.95rem; margin-bottom: var(--space-2); }
.aspect-pattern-interpretation { color: var(--calc-text-primary); margin: 0; }
.aspect-pattern-element { display: inline-block; margin-top: var(--space-2); padding: 0.25rem 0.5rem; border-radius: var(--radius-sm); background: var(--color-neutral-50); font-size: 0.85rem; }
.aspect-patterns-empty { color: var(--velora-text-muted); font-style: italic; padding: var(--space-4); text-align: center; }

/* Chart Synthesis */
.chart-synthesis-section { margin-top: var(--space-6); }
.chart-synthesis-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-4); }
.synthesis-item { padding: var(--space-4); background: var(--surface-card); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-md); }
.synthesis-label { font-size: 0.85rem; font-weight: 700; color: var(--velora-text-muted); display: block; margin-bottom: var(--space-2); }
.synthesis-value { font-size: 1.125rem; color: var(--velora-text-primary); font-weight: 600; }
.synthesis-element-bars { margin-top: var(--space-2); }

/* Dark mode overrides for new components */
[data-theme="dark"] .aspect-pattern-item, .dark .aspect-pattern-item,
[data-theme="dark"] .synthesis-item, .dark .synthesis-item { background: var(--surface-card, var(--color-neutral-800)); border-color: var(--color-neutral-700); }


.calculator-result-main {
    max-width: var(--max-width-prose);
    margin: 0 auto;
    padding: var(--space-8);
}

/* ============================================================================
   ORIENTATION SECTION: H1 + Framing + Optional Illustration
   ============================================================================ */

.orientation-section {
    margin-bottom: var(--space-12);
    padding-bottom: var(--space-8);
    border-bottom: 1px solid var(--color-neutral-200);
}

.orientation-section-header {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
}

.orientation-section-title {
    font-family: var(--font-serif);
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-neutral-900);
    margin: 0;
    letter-spacing: -0.02em;
}

@media (max-width: 768px) {
    .orientation-section-title {
        font-size: 1.875rem;
    }
}

.orientation-section-framing {
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.6;
    color: var(--color-neutral-700);
    margin: 0;
    max-width: 60ch;
}

.orientation-section-illustration {
    max-width: 100%;
    height: auto;
    margin: var(--space-6) 0;
}

/* ============================================================================
   CONTENT SECTION: Primary Content (Form + Editorial)
   ============================================================================ */

.content-section {
    margin-bottom: var(--space-12);
}

.content-section-body {
    font-family: var(--font-sans);
    font-size: 1rem;
    line-height: 1.8;
    color: var(--calc-text-primary);
}

.content-section-body p {
    margin: 0 0 var(--space-4) 0;
}

.content-section-body p:last-child {
    margin-bottom: 0;
}

.content-section-body strong {
    font-weight: 600;
    color: var(--calc-text-primary);
}

.content-section-items {
    list-style: none;
    padding: 0;
    margin: var(--space-4) 0 0 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.content-section-items li {
    padding-left: var(--space-6);
    position: relative;
}

.content-section-items li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.5em;
    width: 0.375em;
    height: 0.375em;
    border-radius: 50%;
    background-color: var(--color-purple-600);
}

/* ============================================================================
   RESULT KEY INSIGHT: Human Meaning First
   ============================================================================ */

.result-key-insight {
    background-color: var(--color-purple-50);
    border-left: 4px solid var(--color-purple-600);
    padding: var(--space-6);
    margin-bottom: var(--space-8);
    border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
}

.result-key-insight-title {
    font-family: var(--font-serif);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-neutral-900);
    margin: 0 0 var(--space-3) 0;
    letter-spacing: -0.01em;
}

.result-key-insight-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    background-color: var(--color-purple-200);
    color: var(--color-purple-700);
    margin-bottom: var(--space-3);
    flex-shrink: 0;
}

.result-key-insight-icon svg {
    width: 1.25rem;
    height: 1.25rem;
}

.result-key-insight-content {
    font-family: var(--font-sans);
    font-size: 1rem;
    line-height: 1.8;
    color: var(--color-neutral-900);
    margin: 0;
}

/* ============================================================================
   RESULT INTERPRETATION: Editorial Explanation
   ============================================================================ */

.result-interpretation {
    margin-bottom: var(--space-8);
    padding-bottom: var(--space-8);
    border-bottom: 1px solid var(--color-neutral-200);
}

.result-interpretation-body {
    font-family: var(--font-sans);
    font-size: 1rem;
    line-height: 1.8;
    color: var(--color-neutral-900);
}

.result-interpretation-section {
    margin-bottom: var(--space-6);
}

.result-interpretation-section:last-child {
    margin-bottom: 0;
}

.result-interpretation-section-title {
    font-family: var(--font-serif);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--color-neutral-900);
    margin: 0 0 var(--space-3) 0;
    letter-spacing: -0.01em;
}

.result-interpretation-section-content {
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--color-neutral-800);
}

/* ============================================================================
   RESULT CONTEXTUAL LAYER: Progressive Disclosure (Collapsed by Default)
   ============================================================================ */

.result-contextual-layer {
    margin-bottom: var(--space-6);
    border: 1px solid var(--color-neutral-200);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.result-contextual-layer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-4) var(--space-5);
    background-color: var(--color-neutral-50);
    cursor: pointer;
    user-select: none;
    min-height: 2.75rem;
    transition: background-color 150ms ease;
}

.result-contextual-layer-header:hover {
    background-color: var(--color-neutral-100);
}

.result-contextual-layer-header:focus-within {
    outline: 2px solid var(--color-purple-500);
    outline-offset: -2px;
}

.result-contextual-layer-title {
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 500;
    color: var(--color-neutral-900);
    margin: 0;
    flex: 1;
}

.result-contextual-layer-toggle {
    width: 1.5rem;
    height: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-neutral-600);
    transition: transform 200ms ease;
    flex-shrink: 0;
}

.result-contextual-layer[x-cloak] .result-contextual-layer-toggle {
    transform: rotate(0deg);
}

[x-show="!open"] .result-contextual-layer-toggle {
    transform: rotate(0deg);
}

[x-show="open"] .result-contextual-layer-toggle {
    transform: rotate(180deg);
}

.result-contextual-layer-content {
    padding: var(--space-5);
    border-top: 1px solid var(--color-neutral-200);
    background-color: white;
    display: none;
}

[x-show="open"] .result-contextual-layer-content {
    display: block;
}

.result-contextual-layer-human {
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-neutral-200);
}

.result-contextual-layer-human-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-neutral-600);
    margin-bottom: var(--space-2);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.result-contextual-layer-human-content {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--color-neutral-900);
}

.result-contextual-layer-astrology {
    font-size: 0.95rem;
    color: var(--color-neutral-800);
    line-height: 1.7;
}

.result-contextual-layer-astrology details {
    margin-top: var(--space-3);
}

.result-contextual-layer-astrology summary {
    cursor: pointer;
    font-weight: 500;
    color: var(--color-purple-600);
    user-select: none;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2);
    margin: calc(var(--space-2) * -1);
    border-radius: var(--radius-sm);
    transition: background-color 150ms ease;
}

/* ===== Custom Transit UI Enhancements ===== */
.cluster-header-text {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    flex: 1;
    text-align: left;
}

.cluster-header h3 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
}

.cluster-description {
    font-size: 0.8rem;
    color: var(--velora-text-muted);
    margin: 0;
    font-weight: 400;
}

.result-interpretation-wrapper {
    margin-bottom: var(--space-4);
}

.interpretation-toggle {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    width: 100%;
    padding: var(--space-3);
    background: var(--surface-muted);
    border: 1px solid var(--color-neutral-100);
    border-radius: var(--radius-md);
    cursor: pointer;
    font-weight: 600;
    font-size: 1rem;
}

.interpretation-toggle:hover {
    background: var(--surface-elevated);
}

.interpretation-content {
    margin-top: var(--space-3);
}

.transit-control-bar {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3);
    background: var(--surface-elevated);
    border: 1px solid var(--color-neutral-100);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-4);
    flex-wrap: wrap;
}

.control-group {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.control-label {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--velora-text-primary);
}

.control-reset {
    margin-left: auto;
    padding: 0.4rem 0.8rem;
    border-radius: 999px;
    background: var(--color-neutral-100);
    border: 1px solid var(--color-neutral-200);
    cursor: pointer;
    font-size: 0.85rem;
}

.control-reset:hover { background: var(--color-neutral-200); }

@media (max-width: 640px) {
    .transit-control-bar { flex-direction: column; align-items: stretch; }
    .control-group { width: 100%; }
    .control-reset { margin-left: 0; }
}

.transit-weather { padding: var(--space-4); border-radius: var(--radius-md); background: linear-gradient(90deg, var(--color-purple-50), var(--color-purple-100)); border: 1px solid var(--color-neutral-100); margin-bottom: var(--space-4); }
.transit-weather-header { display:flex; justify-content:space-between; align-items:flex-start; gap:var(--space-3); margin-bottom:var(--space-3); }
.weather-left h3 { margin:0; font-size:1.25rem; font-weight:700; }
.weather-right { text-align:right; }
.intensity-label { font-weight:600; color:var(--color-neutral-700); font-size:0.95rem; }
.transit-weather-list { margin-top:var(--space-3); display:flex; flex-direction:column; gap:0.75rem; }
.weather-bullet { list-style:none; display:flex; flex-direction:column; gap:0.25rem; padding:0.5rem 0; }
.weather-bullet strong { font-weight:700; color:var(--velora-text-primary); }
.bullet-meta { font-size:0.85rem; color:var(--velora-text-muted); }
.bullet-action { font-size:0.9rem; color:var(--color-purple-700); font-weight:500; }

/* Chip style (non-interactive) */
.chip { display:inline-block; padding:0.25rem 0.5rem; border-radius:999px; background:var(--color-neutral-100); color:var(--velora-text-primary); font-weight:600; font-size:0.85rem; }

/* ===== High-specificity overrides to ensure new transit styles win over legacy rules ===== */
.calculator-result-page .transit-weather {
    padding: var(--space-4) !important;
    border-radius: var(--radius-md) !important;
    background: linear-gradient(90deg, var(--color-purple-50), var(--color-purple-100)) !important;
    border: 1px solid var(--color-neutral-100) !important;
    margin-bottom: var(--space-4) !important;
}
.calculator-result-page .transit-weather-header { display:flex !important; justify-content:space-between !important; align-items:flex-start !important; gap:var(--space-3) !important; margin-bottom:var(--space-3) !important; }
.calculator-result-page .transit-control-bar { display:flex !important; align-items:center !important; gap:var(--space-3) !important; padding:var(--space-3) !important; background:var(--surface-elevated) !important; border:1px solid var(--color-neutral-100) !important; border-radius:var(--radius-md) !important; margin-bottom:var(--space-4) !important; flex-wrap:wrap !important; }
.calculator-result-page .chip { display:inline-block !important; padding:0.25rem 0.5rem !important; border-radius:999px !important; background:var(--color-neutral-100) !important; color:var(--velora-text-primary) !important; font-weight:600 !important; font-size:0.85rem !important; cursor: default !important; pointer-events: none !important; }

/* Ensure weather bullets styles also win */
.calculator-result-page .transit-weather-list { margin-top:var(--space-3) !important; display:flex !important; flex-direction:column !important; gap:0.75rem !important; }
.calculator-result-page .weather-bullet { list-style:none !important; display:flex !important; flex-direction:column !important; gap:0.25rem !important; padding:0.5rem 0 !important; }



.result-contextual-layer-astrology summary:hover {
    background-color: var(--color-neutral-100);
}

.result-contextual-layer-astrology summary::marker {
    color: var(--color-purple-600);
}

.result-contextual-layer-astrology-content {
    padding: var(--space-3) 0;
    margin: var(--space-3) 0 0 0;
    border-top: 1px solid var(--color-neutral-200);
    font-size: 0.9rem;
    color: var(--color-neutral-700);
}

/* ============================================================================
   RESULT DATA BLOCK: Collapsed Data Display (Collapsed by Default)
   ============================================================================ */

.result-data-block {
    margin-bottom: var(--space-6);
    border: 1px solid var(--color-neutral-200);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.result-data-block-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-4) var(--space-5);
    background-color: var(--color-neutral-50);
    cursor: pointer;
    user-select: none;
    min-height: 2.75rem;
    transition: background-color 150ms ease;
}

.result-data-block-header:hover {
    background-color: var(--color-neutral-100);
}

.result-data-block-header:focus-within {
    outline: 2px solid var(--color-purple-500);
    outline-offset: -2px;
}

.result-data-block-label {
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 500;
    color: var(--color-neutral-900);
    margin: 0;
    flex: 1;
}

/* Chart Wheel Styles (simplified editorial line aesthetic) */
.chart-wheel-container {
    width: 100%;
    max-width: 600px;
    margin: var(--space-8) auto;
    aspect-ratio: 1;
    position: relative;
}

.chart-wheel-svg {
    width: 100%;
    height: 100%;
    display: block;
}

.zodiac-sep { stroke: var(--color-neutral-200); stroke-width: 1px; opacity: 0.6; stroke-linecap: round; }
.zodiac-symbol { font-size: 1.5rem; fill: var(--velora-text-secondary); font-family: var(--font-sans); }

.house-cusp { stroke: var(--color-neutral-300); stroke-dasharray: 2 2; stroke-width: 1px; }
.house-number { font-size: 0.75rem; fill: var(--velora-text-muted); font-family: var(--font-sans); }

.markers-layer circle { stroke-width: 1; stroke-linejoin: round; stroke-linecap: round; }
.marker-sun { fill: var(--color-gold-500); stroke: var(--color-gold-600); }
.marker-moon { fill: var(--color-purple-300); stroke: var(--color-purple-400); }
.marker-asc { fill: var(--color-cosmic-violet); stroke: var(--color-cosmic-violet-dark); }
.marker-symbol { fill: white; font-size: 1.25rem; font-family: var(--font-sans); pointer-events: none; }
.markers-layer g { transition: transform 0.2s ease; }
.markers-layer g:focus-within, .markers-layer g:hover { transform: scale(1.05); }

.chart-wheel-tooltip {
    position: absolute;
    background: var(--surface-card);
    border: 1px solid var(--color-neutral-200);
    border-radius: var(--radius-md);
    padding: var(--space-2) var(--space-3);
    font-size: 0.875rem;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s ease;
    z-index: 10;
}
.chart-wheel-tooltip.visible { opacity: 1; }

/* Dark mode overrides */
[data-theme="dark"] .zodiac-sep { stroke: var(--color-neutral-600); }
[data-theme="dark"] .house-cusp { stroke: var(--color-neutral-600); }
[data-theme="dark"] .marker-sun, [data-theme="dark"] .marker-moon, [data-theme="dark"] .marker-asc { opacity: 0.85; }
[data-theme="dark"] .chart-wheel-tooltip { background: var(--surface-card-dark); border-color: var(--color-neutral-700); }

/* Responsive */
@media (max-width: 768px) {
    .chart-wheel-container { max-width: 400px; }
    .zodiac-symbol { font-size: 1.25rem; }
    .marker-symbol { font-size: 1rem; }
}
@media (min-width: 768px) and (max-width: 1024px) { .chart-wheel-container { max-width: 500px; } }

@media (prefers-reduced-motion: reduce) {
    .markers-layer g { transition: none !important; }
}

.result-data-block-toggle {
    width: 1.5rem;
    height: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-neutral-600);
    transition: transform 200ms ease;
    flex-shrink: 0;
}

[x-show="!open"] .result-data-block-toggle {
    transform: rotate(0deg);
}

[x-show="open"] .result-data-block-toggle {
    transform: rotate(180deg);
}

.result-data-block-content {
    padding: var(--space-5);
    border-top: 1px solid var(--color-neutral-200);
    background-color: white;
    display: none;
    overflow-x: auto;
}

[x-show="open"] .result-data-block-content {
    display: block;
}

.result-data-block-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95rem;
    font-family: var(--font-mono);
}

.result-data-block-table th {
    background-color: var(--color-neutral-100);
    padding: var(--space-3) var(--space-4);
    text-align: left;
    font-weight: 600;
    color: var(--color-neutral-900);
    border-bottom: 2px solid var(--color-neutral-200);
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.result-data-block-table td {
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--color-neutral-200);
    color: var(--color-neutral-800);
}

.result-data-block-table tr:last-child td {
    border-bottom: none;
}

.result-data-block-table tbody tr:hover {
    background-color: var(--color-neutral-50);
}

.result-data-block-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.result-data-block-item {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: var(--space-3) 0;
    border-bottom: 1px solid var(--color-neutral-200);
}

.result-data-block-item:last-child {
    border-bottom: none;
}

.result-data-block-item-key {
    font-weight: 500;
    color: var(--color-neutral-700);
    font-size: 0.95rem;
}

.result-data-block-item-value {
    color: var(--color-neutral-900);
    font-family: var(--font-mono);
    font-size: 0.9rem;
    font-weight: 600;
}

.result-data-block-empty {
    padding: var(--space-5);
    text-align: center;
    color: var(--color-neutral-600);
    font-style: italic;
}

/* ============================================================================
   RESULT INTEGRATION: Soft CTAs, Related Content, Save
   ============================================================================ */

.result-integration {
    margin-top: var(--space-12);
    padding-top: var(--space-8);
    border-top: 1px solid var(--color-neutral-200);
}

.integration-section {
    margin-bottom: var(--space-8);
    padding: var(--space-6);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-neutral-200);
    background: linear-gradient(180deg, rgba(248, 245, 255, 0.6) 0%, #ffffff 100%);
    box-shadow: 0 12px 30px rgba(24, 16, 56, 0.06);
}

.integration-section:last-child {
    margin-bottom: 0;
}

.integration-section-header {
    margin-bottom: var(--space-4);
}

.integration-section-title {
    font-family: var(--font-serif);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-neutral-900);
    margin: 0 0 var(--space-2) 0;
    letter-spacing: -0.01em;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
}

.integration-section-links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--space-3);
}

.integration-section-link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    border: 1px solid var(--color-neutral-200);
    border-radius: var(--radius-md);
    background-color: #fff;
    color: var(--color-purple-600);
    font-weight: 500;
    text-decoration: none;
    transition: all 150ms ease;
    min-height: 2.75rem;
    min-width: 2.75rem;
    justify-content: flex-start;
}

.integration-section-link:hover {
    background-color: var(--color-purple-50);
    border-color: var(--color-purple-200);
    color: var(--color-purple-700);
}

.integration-section-link::before {
    content: '✦';
    color: var(--color-purple-400);
    font-size: 0.75rem;
}

.calculator-faq {
    margin-top: var(--space-8);
    padding: var(--space-6);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-neutral-200);
    background: linear-gradient(180deg, rgba(248, 245, 255, 0.5) 0%, #ffffff 100%);
    box-shadow: 0 10px 24px rgba(24, 16, 56, 0.05);
}

.calculator-faq h2 {
    font-family: var(--font-serif);
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--color-neutral-900);
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-4);
}

.calculator-faq h3 {
    font-family: var(--font-serif);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-neutral-900);
    margin-top: var(--space-4);
    margin-bottom: var(--space-2);
}

.calculator-faq p {
    margin-bottom: var(--space-3);
    color: var(--color-neutral-700);
    line-height: 1.6;
}

.calculator-faq h3:first-of-type {
    margin-top: 0;
}

@media (max-width: 768px) {
    .integration-section {
        padding: var(--space-5);
    }

    .integration-section-links {
        grid-template-columns: 1fr;
    }
}

[data-theme="dark"] .integration-section,
.dark .integration-section {
    background: linear-gradient(180deg, rgba(42, 32, 64, 0.6) 0%, rgba(24, 16, 40, 0.8) 100%);
    border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .integration-section-link,
.dark .integration-section-link {
    background-color: rgba(36, 30, 52, 0.8);
    border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .calculator-faq,
.dark .calculator-faq {
    background: linear-gradient(180deg, rgba(42, 32, 64, 0.5) 0%, rgba(24, 16, 40, 0.85) 100%);
    border-color: rgba(255, 255, 255, 0.08);
}

.integration-section-link:focus {
    outline: 2px solid var(--color-purple-500);
    outline-offset: 2px;
}

.integration-section-cta {
    margin-top: var(--space-4);
}

.integration-section-cta-link {
    display: inline-block;
    padding: var(--space-4) var(--space-6);
    background-color: var(--color-purple-600);
    color: white;
    border-radius: var(--radius-md);
    font-weight: 600;
    text-decoration: none;
    transition: background-color 150ms ease;
    min-height: 2.75rem;
    display: inline-flex;
    align-items: center;
}

.integration-section-cta-link:hover {
    background-color: var(--color-purple-700);
}

.integration-section-cta-link:focus {
    outline: 2px solid var(--color-purple-700);
    outline-offset: 2px;
}

/* ============================================================================
   INSIGHT SECTION: Patterns and Insights
   ============================================================================ */

.insight-section {
    margin-bottom: var(--space-8);
    padding: var(--space-6);
    background-color: var(--color-neutral-50);
    border-radius: var(--radius-md);
}

.insight-section--highlight {
    background-color: var(--color-purple-50);
    border-left: 4px solid var(--color-purple-600);
}

.insight-section-title {
    font-family: var(--font-serif);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--color-neutral-900);
    margin: 0 0 var(--space-4) 0;
    letter-spacing: -0.01em;
}

.insight-section-content {
    font-family: var(--font-sans);
    font-size: 1rem;
    line-height: 1.8;
    color: var(--color-neutral-900);
}

.insight-section-content p {
    margin: 0 0 var(--space-3) 0;
}

.insight-section-content p:last-child {
    margin-bottom: 0;
}

/* ============================================================================
   UTILITY SECTION: Actionable Features
   ============================================================================ */

.utility-section {
    margin-bottom: var(--space-8);
    padding: var(--space-6);
    background-color: white;
    border: 1px solid var(--color-neutral-200);
    border-radius: var(--radius-md);
}

.utility-section-header {
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-5);
    border-bottom: 1px solid var(--color-neutral-200);
}

.utility-section-title {
    font-family: var(--font-serif);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--color-neutral-900);
    margin: 0 0 var(--space-2) 0;
    letter-spacing: -0.01em;
}

.utility-section-description {
    font-size: 0.95rem;
    color: var(--color-neutral-700);
    margin: 0;
    line-height: 1.6;
}

.utility-section-content {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

/* ============================================================================
   DEEPENING SECTION: Container for Progressive Disclosure
   ============================================================================ */

.calculator-result-deepening {
    margin-bottom: var(--space-12);
}

/* ============================================================================
   RESPONSIVE DESIGN
   ============================================================================ */

@media (max-width: 768px) {
    .calculator-result-main {
        padding: var(--space-4);
    }

    .orientation-section {
        margin-bottom: var(--space-8);
    }

    .orientation-section-title {
        font-size: 1.5rem;
    }

    .result-key-insight {
        padding: var(--space-4);
    }

    .result-contextual-layer-header,
    .result-data-block-header {
        padding: var(--space-3) var(--space-4);
    }

    .result-contextual-layer-content,
    .result-data-block-content {
        padding: var(--space-4);
    }

    .integration-section-links {
        gap: var(--space-2);
    }

    .integration-section-link {
        padding: var(--space-2) var(--space-3);
        font-size: 0.95rem;
    }
}

/* ============================================================================
   ACCESSIBILITY & FOCUS STATES
   ============================================================================ */

@media (prefers-reduced-motion: reduce) {
    .result-contextual-layer-toggle,
    .result-data-block-toggle,
    .result-contextual-layer-header,
    .result-data-block-header,
    .integration-section-link,
    .integration-section-cta-link {
        transition: none;
    }
}

/* Focus visible for keyboard navigation */
button:focus-visible,
a:focus-visible {
    outline: 2px solid var(--color-purple-500);
    outline-offset: 2px;
}

/* ============================================================================
   DARK MODE SUPPORT
   Uses [data-theme="dark"] and .dark selectors for manual theme toggles
   ============================================================================ */

[data-theme="dark"] .calculator-result-page,
.dark .calculator-result-page {
    background-color: var(--surface-base, var(--color-neutral-900));
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .orientation-section,
.dark .orientation-section {
    border-bottom-color: var(--reading-separator-line, var(--color-neutral-700));
}

[data-theme="dark"] .orientation-section-title,
.dark .orientation-section-title {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .orientation-section-framing,
.dark .orientation-section-framing {
    color: var(--velora-text-secondary, var(--color-neutral-300));
}

[data-theme="dark"] .orientation-section-illustration,
.dark .orientation-section-illustration {
    opacity: var(--illustration-opacity-dark, 0.85);
}

[data-theme="dark"] .content-section-body,
.dark .content-section-body {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .content-section-body strong,
.dark .content-section-body strong {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .content-section-items li::before,
.dark .content-section-items li::before {
    background-color: var(--color-purple-400);
}

[data-theme="dark"] .result-key-insight,
.dark .result-key-insight {
    background-color: var(--surface-elevated, var(--color-purple-900));
    border-left-color: var(--color-purple-500);
}

[data-theme="dark"] .result-key-insight-title,
.dark .result-key-insight-title {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .result-key-insight-content,
.dark .result-key-insight-content {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .result-key-insight-icon,
.dark .result-key-insight-icon {
    background-color: var(--color-purple-800);
    color: var(--color-purple-300);
}

[data-theme="dark"] .result-interpretation,
.dark .result-interpretation {
    border-bottom-color: var(--reading-separator-line, var(--color-neutral-700));
}

[data-theme="dark"] .result-interpretation-body,
.dark .result-interpretation-body {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .result-interpretation-section-title,
.dark .result-interpretation-section-title {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .result-interpretation-section-content,
.dark .result-interpretation-section-content {
    color: var(--velora-text-secondary, var(--color-neutral-300));
}

[data-theme="dark"] .result-contextual-layer,
.dark .result-contextual-layer,
[data-theme="dark"] .result-data-block,
.dark .result-data-block {
    border-color: var(--reading-separator-line, var(--color-neutral-700));
}

[data-theme="dark"] .result-contextual-layer-header,
.dark .result-contextual-layer-header,
[data-theme="dark"] .result-data-block-toggle,
.dark .result-data-block-toggle {
    background-color: var(--surface-elevated, var(--color-neutral-800));
}

[data-theme="dark"] .result-contextual-layer-header:hover,
.dark .result-contextual-layer-header:hover,
[data-theme="dark"] .result-data-block-toggle:hover,
.dark .result-data-block-toggle:hover {
    background-color: var(--surface-hover, var(--color-neutral-700));
}

[data-theme="dark"] .result-contextual-layer-title,
.dark .result-contextual-layer-title,
[data-theme="dark"] .result-data-block-label,
.dark .result-data-block-label {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .result-contextual-layer-toggle,
.dark .result-contextual-layer-toggle,
[data-theme="dark"] .result-data-block-icon,
.dark .result-data-block-icon {
    color: var(--velora-text-muted, var(--color-neutral-400));
}

[data-theme="dark"] .result-contextual-layer-content,
.dark .result-contextual-layer-content,
[data-theme="dark"] .result-data-block-content,
.dark .result-data-block-content {
    background-color: var(--surface-base, var(--color-neutral-900));
    border-top-color: var(--reading-separator-line, var(--color-neutral-700));
}

[data-theme="dark"] .result-contextual-layer-human,
.dark .result-contextual-layer-human {
    border-bottom-color: var(--reading-separator-line, var(--color-neutral-700));
}

[data-theme="dark"] .result-contextual-layer-human-label,
.dark .result-contextual-layer-human-label {
    color: var(--velora-text-muted, var(--color-neutral-400));
}

[data-theme="dark"] .result-contextual-layer-human-content,
.dark .result-contextual-layer-human-content {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .result-contextual-layer-astrology,
.dark .result-contextual-layer-astrology {
    color: var(--velora-text-secondary, var(--color-neutral-300));
}

[data-theme="dark"] .result-contextual-layer-astrology summary,
.dark .result-contextual-layer-astrology summary {
    color: var(--color-purple-400);
}

[data-theme="dark"] .result-contextual-layer-astrology summary:hover,
.dark .result-contextual-layer-astrology summary:hover {
    background-color: var(--surface-hover, var(--color-neutral-800));
}

[data-theme="dark"] .result-contextual-layer-astrology-content,
.dark .result-contextual-layer-astrology-content {
    border-top-color: var(--reading-separator-line, var(--color-neutral-700));
    color: var(--velora-text-muted, var(--color-neutral-400));
}

[data-theme="dark"] .result-data-table th,
.dark .result-data-table th {
    background-color: var(--surface-elevated, var(--color-neutral-800));
    border-bottom-color: var(--reading-separator-line, var(--color-neutral-700));
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .result-data-table td,
.dark .result-data-table td {
    border-bottom-color: var(--reading-separator-line, var(--color-neutral-700));
    color: var(--velora-text-secondary, var(--color-neutral-300));
}

[data-theme="dark"] .result-data-table tbody tr:hover,
.dark .result-data-table tbody tr:hover {
    background-color: var(--surface-hover, var(--color-neutral-800));
}

[data-theme="dark"] .result-data-list dt,
.dark .result-data-list dt {
    color: var(--velora-text-muted, var(--color-neutral-400));
}

[data-theme="dark"] .result-data-list dd,
.dark .result-data-list dd {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .result-data-block-item,
.dark .result-data-block-item {
    border-bottom-color: var(--reading-separator-line, var(--color-neutral-700));
}

[data-theme="dark"] .result-data-block-item-key,
.dark .result-data-block-item-key {
    color: var(--velora-text-muted, var(--color-neutral-400));
}

[data-theme="dark"] .result-data-block-item-value,
.dark .result-data-block-item-value {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .result-data-empty,
.dark .result-data-empty {
    color: var(--velora-text-muted, var(--color-neutral-500));
}

[data-theme="dark"] .result-integration,
.dark .result-integration {
    border-top-color: var(--reading-separator-line, var(--color-neutral-700));
}

[data-theme="dark"] .integration-section-title,
.dark .integration-section-title {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .integration-section-link,
.dark .integration-section-link {
    background-color: var(--surface-elevated, var(--color-neutral-800));
    border-color: var(--reading-separator-line, var(--color-neutral-700));
    color: var(--color-purple-400);
}

[data-theme="dark"] .integration-section-link:hover,
.dark .integration-section-link:hover {
    background-color: var(--color-purple-900);
    border-color: var(--color-purple-700);
    color: var(--color-purple-300);
}

[data-theme="dark"] .insight-section,
.dark .insight-section {
    background-color: var(--surface-elevated, var(--color-neutral-800));
}

[data-theme="dark"] .insight-section--highlight,
.dark .insight-section--highlight {
    background-color: var(--color-purple-900);
    border-left-color: var(--color-purple-500);
}

[data-theme="dark"] .insight-section-title,
.dark .insight-section-title {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .insight-section-content,
.dark .insight-section-content {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .utility-section,
.dark .utility-section {
    background-color: var(--surface-elevated, var(--color-neutral-800));
    border-color: var(--reading-separator-line, var(--color-neutral-700));
}

[data-theme="dark"] .utility-section-header,
.dark .utility-section-header {
    border-bottom-color: var(--reading-separator-line, var(--color-neutral-700));
}

[data-theme="dark"] .utility-section-title,
.dark .utility-section-title {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .utility-section-description,
.dark .utility-section-description {
    color: var(--velora-text-secondary, var(--color-neutral-300));
}

/* ==========================================================================
   BIRTH CHART SPECIFIC COMPONENTS
   ========================================================================== */

/* Report Header */
.report-header-identity {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.report-metadata {
    font-size: 0.95rem;
    color: var(--velora-text-muted, var(--color-neutral-600));
    margin: 0;
}
.report-header-actions {
    display: flex;
    gap: var(--space-2);
    align-items: center;
}
.report-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: var(--radius-sm);
    background: transparent;
    border: 1px solid var(--color-neutral-200);
    color: var(--velora-text-primary, var(--color-neutral-900));
    cursor: pointer;
}
.report-action-btn.secondary {
    background: var(--color-neutral-50);
}

/* Big Three Cards */
.big-three-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
}
.big-three-card {
    padding: var(--space-4);
    border: 1px solid var(--color-neutral-200);
    border-radius: var(--radius-md);
    text-align: center;
}
.big-three-symbol {
    font-size: 2.25rem;
    color: var(--color-purple-600);
}
.big-three-label {
    font-family: var(--font-serif);
    margin: var(--space-2) 0 0 0;
}
.big-three-sign {
    font-weight: 700;
    margin: var(--space-1) 0 0 0;
}
.big-three-degree {
    color: var(--velora-text-muted, var(--color-neutral-600));
    font-size: 0.9rem;
}

/* Distribution Bars */
.distribution-section {
    margin-bottom: var(--space-6);
}
.distribution-bars { display: flex; flex-direction: column; gap: var(--space-3); }
.distribution-bar-row { display:flex; align-items:center; gap: var(--space-3); }
.distribution-label { min-width: 6rem; font-weight:600; }
.distribution-bar { flex:1; height:0.75rem; background:var(--color-neutral-100); border-radius:999px; overflow:hidden; }
.distribution-fill { height:100%; background: linear-gradient(90deg,var(--color-purple-500),var(--color-purple-700)); transition: width 300ms ease; }
.distribution-value { min-width:2.25rem; text-align:right; }

/* Houses List */
.houses-list { display:flex; flex-direction:column; gap: var(--space-4); }
.house-item { padding: var(--space-3); border-bottom:1px solid var(--color-neutral-100); }
.house-header { display:flex; justify-content:space-between; align-items:baseline; gap: var(--space-2); }
.house-number { font-family: var(--font-serif); font-weight:700; }
.house-sign { background:var(--color-neutral-50); padding:0.25rem 0.5rem; border-radius:var(--radius-sm); }
.house-meaning { color: var(--velora-text-muted, var(--color-neutral-600)); margin: var(--space-2) 0; }
.house-planets { display:flex; gap:var(--space-2); flex-wrap:wrap; }
.house-planet-chip { display:inline-flex; gap:0.5rem; padding:0.25rem 0.5rem; background:var(--color-neutral-50); border-radius:999px; }

/* Aspects List */
.aspects-section { margin-bottom: var(--space-6); }
.aspects-header { display:flex; justify-content:space-between; align-items:center; }
.aspects-toggle { padding:0.25rem 0.5rem; border-radius:var(--radius-sm); }
.aspects-list { display:flex; flex-direction:column; gap:var(--space-3); margin-top:var(--space-3); }
.aspect-item { padding:var(--space-3); border:1px solid var(--color-neutral-100); border-radius:var(--radius-sm); }
.aspect-planets { font-weight:700; display:flex; gap:0.5rem; align-items:center; }
.aspect-symbol { color:var(--color-purple-600); }
.aspect-details { display:flex; gap:1rem; font-size:0.9rem; color:var(--velora-text-muted); margin-top:var(--space-2); }
.aspect-interpretation { margin-top:var(--space-2); }

/* Planet & Aspect Symbols */
.planet-with-symbol { display:inline-flex; align-items:center; gap:0.375rem; }
.planet-symbol { font-size:1.25em; line-height:1; display:inline-block; width:1.25em; text-align:center; }
.planet-symbol--small { font-size:1rem; }
.planet-symbol--medium { font-size:1.25em; }
.planet-symbol--large { font-size:1.5em; }
.planet-name { margin-left:0.25rem; font-weight:600; }
.retrograde { margin-left:0.375rem; color:var(--color-neutral-500); font-size:0.9em; }

.aspect-symbol { font-size:1.125em; margin:0 0.5rem; display:inline-flex; align-items:center; justify-content:center; }
.aspect-symbol.benefic { color:var(--color-green-600); }
.aspect-symbol.challenging { color:var(--color-red-600); }
.aspect-symbol.neutral { color:var(--color-purple-600); }

.intensity-badge { background:var(--surface-muted, var(--color-neutral-100)); padding:0.25rem 0.5rem; border-radius:999px; font-size:0.85rem; }
.timing-info { color:var(--velora-text-muted); font-size:0.9rem; }

/* Map dynamic data-planet attributes to symbol glyphs via attribute selectors */
.planet-with-symbol[data-planet="Sonne"] .planet-symbol::before { content: "☉"; }
.planet-with-symbol[data-planet="Mond"] .planet-symbol::before { content: "☽"; }
.planet-with-symbol[data-planet="Merkur"] .planet-symbol::before { content: "☿"; }
.planet-with-symbol[data-planet="Venus"] .planet-symbol::before { content: "♀"; }
.planet-with-symbol[data-planet="Mars"] .planet-symbol::before { content: "♂"; }
.planet-with-symbol[data-planet="Jupiter"] .planet-symbol::before { content: "♃"; }
.planet-with-symbol[data-planet="Saturn"] .planet-symbol::before { content: "♄"; }
.planet-with-symbol[data-planet="Uranus"] .planet-symbol::before { content: "♅"; }
.planet-with-symbol[data-planet="Neptun"] .planet-symbol::before { content: "♆"; }
.planet-with-symbol[data-planet="Pluto"] .planet-symbol::before { content: "♇"; }

/* Responsive tweaks */
@media (max-width: 768px) {
    .planet-name { display:none; }
    .aspect-symbol { margin: 0 0.25rem; }
}
/* Aspect data-attribute mapping */
.aspect-symbol[data-aspect="Konjunktion"]::before { content: "☌"; }
.aspect-symbol[data-aspect="Opposition"]::before { content: "☍"; }
.aspect-symbol[data-aspect="Trigon"]::before { content: "△"; }
.aspect-symbol[data-aspect="Quadrat"]::before { content: "□"; }
.aspect-symbol[data-aspect="Sextil"]::before { content: "⚹"; }
.aspect-symbol[data-aspect="Semi-sextil"]::before { content: "⚺"; }
.aspect-symbol[data-aspect="Quincunx"]::before { content: "⚻"; }

/* ===== Transit control bar, weather bullet and cluster description (new) ===== */
.transit-control-bar {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3);
    background: var(--surface-elevated);
    border: 1px solid var(--color-neutral-100);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-4);
    flex-wrap: wrap;
}
.control-group {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}
.control-label {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--velora-text-primary);
}
.control-reset {
    margin-left: auto;
    padding: 0.4rem 0.8rem;
    border-radius: 999px;
    background: var(--color-neutral-100);
    border: 1px solid var(--color-neutral-200);
    cursor: pointer;
    font-size: 0.85rem;
}
.weather-left h3 { margin: 0; font-size: 1.25rem; font-weight: 700; }
.weather-right { text-align: right; }
.weather-bullet { display: flex; flex-direction: column; gap: 0.25rem; padding: 0.5rem 0; }
.bullet-meta { font-size: 0.85rem; color: var(--velora-text-muted); }
.bullet-action { font-size: 0.9rem; color: var(--color-purple-700); font-weight: 500; }
.cluster-header-text { display: flex; flex-direction: column; gap: 0.25rem; flex: 1; }
.cluster-description { font-size: 0.8rem; color: var(--velora-text-muted); margin: 0; font-weight: 400; }

/* Make chips clearly decorative (non-interactive) */
.transit-actions .chip { cursor: default !important; pointer-events: none !important; }

/* Dark mode variants */
[data-theme="dark"] .transit-control-bar,
.dark .transit-control-bar {
    background: var(--surface-elevated);
    border-color: var(--reading-separator-line);
}
[data-theme="dark"] .control-label,
.dark .control-label { color: var(--velora-text-primary); }
[data-theme="dark"] .bullet-meta,
.dark .bullet-meta { color: var(--velora-text-muted); }


/* Transit UI: summary, clusters, cards */
.transit-section { margin-top: var(--space-6); }
.transit-weather { padding: var(--space-4); border-radius: var(--radius-md); background: linear-gradient(90deg, var(--color-purple-50), var(--color-purple-100)); border:1px solid var(--color-neutral-100); margin-bottom: var(--space-4); }
.transit-weather-header { display:flex; justify-content:space-between; align-items:center; gap:var(--space-2); }
.transit-weather-list { margin-top:var(--space-3); display:flex; flex-direction:column; gap:0.5rem; }
.transit-weather-list li { list-style:none; display:flex; gap:0.5rem; align-items:center; }
.transit-weather .bullet-planet { display:inline-flex; align-items:center; }
.intensity-label { font-weight:600; color:var(--color-neutral-700); }

.transit-controls { margin: var(--space-3) 0; }
.transit-view-toggle button { margin-right:0.5rem; padding:0.4rem 0.8rem; border-radius:6px; border:1px solid transparent; background:transparent; cursor:pointer; }
.transit-view-toggle button.active { background:var(--color-purple-600); color:#fff; }

.transit-filters { display:flex; gap:0.5rem; margin-bottom:var(--space-4); }
.transit-filters button { padding:0.25rem 0.6rem; border-radius:999px; background:var(--color-neutral-50); border:1px solid var(--color-neutral-100); }
.transit-filters button.active { background:var(--color-purple-50); border-color:var(--color-purple-200); }

.transit-cluster { margin-bottom:var(--space-4); border-radius:8px; overflow:hidden; }
.cluster-header { display:flex; align-items:center; gap:var(--space-3); width:100%; padding:var(--space-3); background:var(--surface-muted); border:1px solid var(--color-neutral-100); cursor:pointer; }
.cluster-header h3 { margin:0; font-size:1rem; }
.cluster-count { margin-left:auto; color:var(--velora-text-muted); }
.cluster-body { padding:var(--space-3); display:grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap:var(--space-3); }

.transit-card { padding:var(--space-3); border:1px solid var(--color-neutral-100); border-radius:8px; background:var(--surface-elevated); display:flex; flex-direction:column; gap:var(--space-2); }
.transit-card-header { display:flex; flex-direction:column; gap:0.5rem; }
.transit-headline { font-size:1.05rem; margin:0; font-weight:700; }
.transit-subline { font-size:0.85rem; color:var(--velora-text-muted); }
.transit-card-body { margin-top:var(--space-2); }
.transit-actions { display:flex; gap:0.5rem; flex-wrap:wrap; }
.chip { background:var(--color-neutral-50); border:1px solid var(--color-neutral-100); padding:0.25rem 0.5rem; border-radius:999px; cursor:pointer; }
.transit-body { color:var(--velora-text-primary); }
.transit-technical { font-size:0.9rem; color:var(--velora-text-muted); }

.timing-label { padding:0.2rem 0.5rem; border-radius:999px; background:var(--color-neutral-50); font-size:0.8rem; }

/* Dark mode overrides */
[data-theme="dark"] .transit-weather, .dark .transit-weather { background: linear-gradient(90deg, rgba(99,102,241,0.06), rgba(139,92,246,0.06)); border-color:var(--reading-separator-line); }
[data-theme="dark"] .transit-card, .dark .transit-card { background: var(--surface-elevated); border-color:var(--reading-separator-line); color:var(--velora-text-primary); }

@media (max-width: 768px) {
    .cluster-body { grid-template-columns: 1fr; }
    .transit-weather { padding:var(--space-3); }
}


@media (max-width: 768px) {
  .big-three-grid { grid-template-columns: 1fr; }
  .report-header-actions { flex-direction: column; }
  .aspects-header { flex-direction: column; align-items: flex-start; }
}

/* Dark mode overrides for birth-chart components */
[data-theme="dark"] .report-header-identity,
.dark .report-header-identity {
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .report-metadata,
.dark .report-metadata {
    color: var(--velora-text-muted, var(--color-neutral-400));
}

[data-theme="dark"] .report-header-actions .report-action-btn,
.dark .report-header-actions .report-action-btn {
    border-color: var(--reading-separator-line, var(--color-neutral-700));
    background: var(--surface-elevated, var(--color-neutral-800));
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .big-three-card,
.dark .big-three-card {
    background: var(--surface-elevated, var(--color-neutral-800));
    border-color: var(--reading-separator-line, var(--color-neutral-700));
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .big-three-symbol,
.dark .big-three-symbol {
    color: var(--color-purple-400);
}

[data-theme="dark"] .distribution-bar,
.dark .distribution-bar {
    background: var(--surface-elevated, var(--color-neutral-800));
    border-radius: 999px;
}

[data-theme="dark"] .distribution-fill,
.dark .distribution-fill {
    background: linear-gradient(90deg,var(--color-purple-400),var(--color-purple-600));
}

[data-theme="dark"] .house-item,
.dark .house-item {
    background: var(--surface-elevated, var(--color-neutral-800));
    border-bottom-color: var(--reading-separator-line, var(--color-neutral-700));
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .house-meaning,
.dark .house-meaning {
    color: var(--velora-text-muted, var(--color-neutral-400));
}

[data-theme="dark"] .aspect-item,
.dark .aspect-item {
    background: var(--surface-elevated, var(--color-neutral-800));
    border-color: var(--reading-separator-line, var(--color-neutral-700));
    color: var(--velora-text-primary, var(--color-neutral-100));
}

[data-theme="dark"] .aspect-details,
.dark .aspect-details {
    color: var(--velora-text-muted, var(--color-neutral-400));
}

/* ==========================================================================
   Section Tabs Navigation + Sticky Tabs
   ========================================================================== */

.result-section-tabs {
    margin-top: var(--space-8);
}

.section-tabs-nav {
    display: flex;
    gap: var(--space-2);
    border-bottom: 2px solid var(--color-neutral-200);
    margin-bottom: var(--space-6);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.section-tabs-nav button {
    padding: var(--space-3) var(--space-4);
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    font-family: var(--font-serif);
    font-weight: 600;
    color: var(--velora-text-muted);
    cursor: pointer;
    transition: all 200ms ease;
    white-space: nowrap;
}

.section-tabs-nav button:hover {
    color: var(--velora-text-primary);
    background: var(--surface-hover);
}

.section-tabs-nav button.active {
    color: var(--color-purple-600);
    border-bottom-color: var(--color-purple-600);
}

@media (max-width: 768px) {
    .section-tabs-nav {
        flex-direction: column;
        border-bottom: none;
        gap: var(--space-1);
    }
    .section-tabs-nav button {
        text-align: left;
        border-left: 3px solid transparent;
        border-bottom: none;
        margin-bottom: 0;
        padding: var(--space-3);
    }
    .section-tabs-nav button.active {
        border-left-color: var(--color-purple-600);
        border-bottom-color: transparent;
        background: var(--surface-soft);
    }
}

/* Dark mode for section tabs */
[data-theme="dark"] .section-tabs-nav,
.dark .section-tabs-nav {
    border-bottom-color: var(--reading-separator-line, var(--color-neutral-700));
}

[data-theme="dark"] .section-tabs-nav button,
.dark .section-tabs-nav button {
    color: var(--velora-text-muted, var(--color-neutral-400));
}

[data-theme="dark"] .section-tabs-nav button:hover,
.dark .section-tabs-nav button:hover {
    color: var(--velora-text-primary, var(--color-neutral-100));
    background: var(--surface-hover, var(--color-neutral-800));
}

[data-theme="dark"] .section-tabs-nav button.active,
.dark .section-tabs-nav button.active {
    color: var(--color-purple-400);
    border-bottom-color: var(--color-purple-400);
}

@media (max-width: 768px) {
    [data-theme="dark"] .section-tabs-nav button.active,
    .dark .section-tabs-nav button.active {
        border-left-color: var(--color-purple-400);
        border-bottom-color: transparent;
    }
}

/* Chart snapshot placeholder */
.chart-snapshot-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px dashed var(--color-neutral-200);
}

[data-theme="dark"] .chart-snapshot-placeholder,
.dark .chart-snapshot-placeholder {
    background: var(--surface-elevated, var(--color-neutral-800));
    border-color: var(--reading-separator-line, var(--color-neutral-700));
}

/* Sticky section tabs on scroll (desktop only) */
@media (min-width: 769px) {
    .result-section-tabs {
        position: relative;
    }
    .section-tabs-nav {
        /* non-sticky by default; becomes sticky when JS toggles .is-sticky */
        position: static;
        background: transparent;
        z-index: auto;
        padding-top: 0;
        margin-top: 0;
    }
    /* Sticky state applied via JS by adding .is-sticky */
    .section-tabs-nav.is-sticky {
        position: sticky;
        top: 80px; /* offset under main nav */
        background: var(--surface-page);
        backdrop-filter: blur(8px);
        z-index: 100;
        padding: var(--space-3) var(--space-4);
        margin: 0 calc(-1 * var(--space-4));
        border-bottom: 1px solid var(--velora-border-subtle, var(--color-neutral-200));
        box-shadow: var(--shadow-sm);
    }
    [data-theme="dark"] .section-tabs-nav.is-sticky,
    .dark .section-tabs-nav.is-sticky {
        background: rgba(17,17,17,0.95);
        border-bottom-color: rgba(255,255,255,0.06);
    }
}

/* ===== SKELETON LOADING STATES ===== */
.skeleton-card, .skeleton-text, .skeleton-symbol, .skeleton-degree,
.skeleton-table-row, .skeleton-table-cell, .skeleton-bar {
    background: linear-gradient(
        90deg,
        var(--surface-card) 0%,
        var(--velora-surface-elevated) 50%,
        var(--surface-card) 100%
    );
    background-size: 200% 100%;
    animation: skeleton-pulse 1.5s ease-in-out infinite;
    border-radius: var(--radius-sm);
}

@keyframes skeleton-pulse {
    0%, 100% { background-position: 200% 0; }
    50% { background-position: 0 0; }
}

@media (prefers-reduced-motion: reduce) {
    .skeleton-card, .skeleton-text, .skeleton-symbol, .skeleton-degree,
    .skeleton-table-row, .skeleton-table-cell, .skeleton-bar {
        animation: none;
        opacity: 0.6;
    }
}

/* Skeleton specific helpers */
.skeleton-wheel { animation: rotation 8s linear infinite; }
@keyframes rotation { from { transform: rotate(0deg);} to { transform: rotate(360deg);} }

/* ===== SMOOTH SCROLL & ANIMATIONS ===== */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
html { scroll-padding-top: 120px; }

.calculator-results { opacity: 0; transform: translateY(20px); transition: opacity var(--duration-section) var(--ease-out), transform var(--duration-section) var(--ease-out); }
.calculator-results.is-visible { opacity: 1; transform: translateY(0); }
.report-chapter { opacity: 0; animation: fadeInUp 0.6s var(--ease-out) forwards; }
.report-chapter:nth-child(1) { animation-delay: 0.1s; }
.report-chapter:nth-child(2) { animation-delay: 0.2s; }
.report-chapter:nth-child(3) { animation-delay: 0.3s; }
.report-chapter:nth-child(4) { animation-delay: 0.4s; }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@media (prefers-reduced-motion: reduce) { .calculator-results, .report-chapter { opacity: 1; transform: none; animation: none; transition: none; } }

/* ===== SKIP LINK ===== */
.skip-link {
    position: absolute;
    top: -40px;
    left: 0;
    background: var(--velora-purple-600);
    color: white;
    padding: var(--space-2) var(--space-4);
    text-decoration: none;
    border-radius: var(--radius-md);
    z-index: 1000;
    transition: top var(--duration-ui) var(--ease-out);
}
.skip-link:focus { top: var(--space-2); outline: 2px solid var(--velora-purple-400); outline-offset: 2px; }

/* Screen reader only */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border-width: 0; }

/* ===== PRINT STYLES ===== */
@media print {
    .section-tabs-nav, .chart-actions, .technical-data-toggle, .cta-premium-upgrade, nav, footer, .accordion-header i { display: none !important; }
    [x-show], [x-cloak], .technical-data-content, .accordion-item > div { display: block !important; opacity: 1 !important; height: auto !important; }
    body { background: white; color: black; font-size: 12pt; line-height: 1.5; }
    .calculator-result-page { max-width: 100%; padding: 0; }
    .birth-chart-report-header { page-break-after: avoid; border-bottom: 2px solid #333; padding-bottom: 1rem; margin-bottom: 1.5rem; }
    .report-chapter { page-break-inside: avoid; margin-bottom: 1.5rem; }
    .report-chapter h2 { page-break-after: avoid; margin-top: 1.5rem; border-bottom: 1px solid #ccc; padding-bottom: 0.5rem; }
    .big-three-cards { display: flex; gap: 1rem; page-break-inside: avoid; margin-bottom: 1.5rem; }
    .big-three-card { flex: 1; border: 1px solid #ccc; padding: 1rem; text-align: center; }
    .chart-wheel-simple { page-break-inside: avoid; max-width: 500px; margin: 1.5rem auto; }
    .planets-table, .houses-list, .aspects-list { width: 100%; border-collapse: collapse; page-break-inside: avoid; margin-bottom: 1.5rem; }
    .planets-table th, .planets-table td { border: 1px solid #ccc; padding: 0.5rem; text-align: left; }
    .planets-table th { background: #f5f5f5; font-weight: bold; }
    .distribution-bars { page-break-inside: avoid; }
    .distribution-bar::after { content: " (" attr(data-count) ")"; }
    .aspect-patterns, .chart-synthesis { page-break-inside: avoid; margin-bottom: 1.5rem; }
    .technical-metadata-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.5rem; page-break-inside: avoid; }
    .metadata-item { border: 1px solid #ccc; padding: 0.5rem; }
    * { box-shadow: none !important; background: transparent !important; color: black !important; }
    .big-three-card, .planets-table th, .metadata-item { background: #f9f9f9 !important; }
    .page-break-before { page-break-before: always; }
    .page-break-after { page-break-after: always; }
    p, li { orphans: 3; widows: 3; }
    h1, h2, h3, h4, h5, h6 { page-break-after: avoid; orphans: 4; widows: 4; }
}

/* ===== DARK MODE OVERRIDES FOR SKELETONS & TABS ===== */
[data-theme="dark"] .skeleton-card,
[data-theme="dark"] .skeleton-text,
[data-theme="dark"] .skeleton-symbol,
[data-theme="dark"] .skeleton-degree,
[data-theme="dark"] .skeleton-table-row,
[data-theme="dark"] .skeleton-table-cell,
[data-theme="dark"] .skeleton-bar {
    background: linear-gradient(
        90deg,
        var(--surface-card) 0%,
        rgba(255,255,255,0.05) 50%,
        var(--surface-card) 100%
    );
}

[data-theme="dark"] .section-tabs-nav.is-sticky { background: rgba(17,17,17,0.95); border-bottom-color: rgba(255,255,255,0.1); }
[data-theme="dark"] .section-tabs-nav button[role="tab"].active { background: rgba(139,127,184,0.2); color: var(--velora-purple-300); }
[data-theme="dark"] .accordion-item { border-color: rgba(255,255,255,0.1); }
[data-theme="dark"] .accordion-header { background: var(--surface-card); }
[data-theme="dark"] .accordion-header:hover { background: rgba(255,255,255,0.05); }



