/* Calculator page — Ratehub-inspired split layout with NerdWallet trust chrome. */

.cw-calc-layout {
    display: grid; gap: 2.5rem;
    grid-template-columns: minmax(0, 1fr);
    padding-top: 1.5rem;
}
@media (min-width: 1024px) {
    .cw-calc-layout { grid-template-columns: minmax(0, 1fr) 300px; align-items: start; }
}

.cw-article-head__title { margin-bottom: 0.3em; }
.cw-article-head__dek {
    font-size: 1.15rem; color: var(--cw-muted-strong);
    max-width: 62ch; margin: 0 0 1.2em;
}

/* Calculator — Ratehub split */
.cw-calc {
    background: #fff;
    border: 1px solid var(--cw-border);
    border-radius: var(--cw-radius);
    padding: 0;
    margin: 0 0 2rem;
    overflow: hidden;
    box-shadow: var(--cw-shadow);
}
.cw-calc__chrome {
    display: grid; gap: 0;
    grid-template-columns: minmax(0, 1fr);
}
@media (min-width: 820px) {
    .cw-calc__chrome { grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr); }
}

.cw-calc__inputs {
    padding: 1.5rem 1.5rem 1.75rem;
    background: #fff;
    border-bottom: 1px solid var(--cw-border);
}
@media (min-width: 820px) {
    .cw-calc__inputs { border-bottom: 0; border-right: 1px solid var(--cw-border); }
}

.cw-calc__inputs label {
    display: block; font-weight: 600; font-size: 0.92rem;
    margin: 0 0 0.4rem; color: var(--cw-fg);
}
.cw-calc__inputs label + label { margin-top: 1.1rem; }
.cw-calc__inputs input, .cw-calc__inputs select {
    width: 100%; padding: 0.65rem 0.8rem; font-size: 1rem;
    border: 1px solid var(--cw-border-strong); border-radius: var(--cw-radius-sm);
    background: #fff; font-family: inherit; color: var(--cw-fg);
    transition: border-color 0.15s, box-shadow 0.15s;
}
.cw-calc__inputs input:focus, .cw-calc__inputs select:focus {
    outline: 0; border-color: var(--cw-brand);
    box-shadow: 0 0 0 3px rgba(10, 37, 64, 0.12);
}
.cw-calc__inputs .cw-hint {
    display: block; font-size: 0.8rem; color: var(--cw-muted);
    font-weight: 400; margin-top: 0.3rem;
}

/* Results panel — Ratehub big-number */
.cw-calc__results {
    padding: 1.75rem 1.5rem;
    background: var(--cw-surface);
}
.cw-calc__results h3 {
    margin: 0 0 1rem; font-family: var(--cw-font);
    font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--cw-muted-strong); font-weight: 600;
}
.cw-calc__result-primary {
    padding: 0 0 1.25rem; margin: 0 0 1rem;
    border-bottom: 2px solid var(--cw-accent);
}
.cw-calc__result-primary-label {
    display: block; font-size: 0.88rem; color: var(--cw-muted-strong);
    margin-bottom: 0.2rem; font-weight: 500;
}
.cw-calc__result-primary-value {
    display: block;
    font-family: var(--cw-font-serif); font-weight: 600;
    font-size: clamp(2.2rem, 3vw + 1rem, 3rem);
    color: var(--cw-brand); line-height: 1.1;
    font-variant-numeric: tabular-nums;
}
.cw-calc__result-row {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: 0.55rem 0; border-bottom: 1px solid var(--cw-border);
}
.cw-calc__result-row:last-child { border-bottom: 0; }
.cw-calc__result-label { color: var(--cw-muted-strong); font-size: 0.93rem; }
.cw-calc__result-value {
    font-weight: 600; font-size: 1rem;
    font-variant-numeric: tabular-nums; color: var(--cw-fg);
}
.cw-calc__result-value--primary { color: var(--cw-brand); font-size: 1.4rem; font-weight: 700; }
.cw-calc__result-value--positive { color: var(--cw-success); }
.cw-calc__fallback { font-size: 0.85rem; color: var(--cw-muted); margin: 0.75rem 0 0; }
.cw-calc.is-ready .cw-calc__fallback { display: none; }

.cw-calc__result-cta {
    margin-top: 1.25rem; padding-top: 1rem;
    border-top: 1px solid var(--cw-border);
    font-size: 0.88rem; color: var(--cw-muted-strong);
}
.cw-calc__result-cta a { color: var(--cw-brand); font-weight: 600; }

/* Mode-dependent input visibility for the TFSA calculator.
   Drive visibility from a body-level data attribute set by the engine
   when the mode input changes, without touching the engine core. */
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-hist_start_year"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-hist_benchmark"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-hist_contribution"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-dd_balance"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-dd_start_age"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-dd_withdrawal"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-dd_return"] { display: none; }

.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-current_balance"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-annual_contribution"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-years"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-return_rate"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-monte_carlo"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-annual_income"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-dd_balance"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-dd_start_age"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-dd_withdrawal"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-dd_return"] { display: none; }

.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-current_balance"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-annual_contribution"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-years"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-return_rate"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-monte_carlo"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-hist_start_year"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-hist_benchmark"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-hist_contribution"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-annual_income"] { display: none; }

/* Room derivation block above the viz */
.cw-room { padding: 0.9rem 1.1rem; background: var(--cw-brand-soft); border-bottom: 1px solid var(--cw-border); font-size: 0.92rem; color: var(--cw-fg); }
.cw-room:empty { display: none; }
.cw-room__copy { margin: 0; line-height: 1.55; }
.cw-room__copy strong { color: var(--cw-brand); font-weight: 600; }

/* Percentile context block below the viz */
.cw-context { padding: 1rem 1.1rem 1.15rem; background: var(--cw-surface); border-top: 1px solid var(--cw-border); font-size: 0.9rem; color: var(--cw-muted-strong); }
.cw-context:empty { display: none; }
.cw-context__copy { margin: 0 0 0.5rem; line-height: 1.55; }
.cw-context__source { margin: 0; font-size: 0.82rem; color: var(--cw-muted); }
.cw-context__source a { color: var(--cw-brand); font-weight: 500; }

/* Slider inputs (range) */
.cw-calc__label-row {
    display: flex; align-items: baseline; justify-content: space-between;
    gap: 0.5rem; margin-bottom: 0.4rem;
}
.cw-calc__label-text { font-weight: 600; font-size: 0.92rem; color: var(--cw-fg); }
.cw-calc__label-value {
    font-family: var(--cw-font-serif); font-weight: 600;
    font-size: 0.98rem; color: var(--cw-brand);
    font-variant-numeric: tabular-nums;
    background: var(--cw-brand-soft);
    padding: 0.1rem 0.55rem; border-radius: 999px;
    border: 1px solid rgba(10, 37, 64, 0.12);
}
.cw-calc__inputs input[type="range"] {
    -webkit-appearance: none; appearance: none;
    width: 100%; height: 32px; background: transparent;
    padding: 0; margin: 0.1rem 0 0.3rem; border: 0;
}
.cw-calc__inputs input[type="range"]:focus { outline: none; }
.cw-calc__inputs input[type="range"]::-webkit-slider-runnable-track {
    height: 6px; border-radius: 3px; background: linear-gradient(90deg, var(--cw-brand) 0%, var(--cw-brand) var(--cw-range-pct, 50%), var(--cw-border-strong) var(--cw-range-pct, 50%), var(--cw-border-strong) 100%);
}
.cw-calc__inputs input[type="range"]::-moz-range-track {
    height: 6px; border-radius: 3px; background: var(--cw-border-strong);
}
.cw-calc__inputs input[type="range"]::-moz-range-progress {
    height: 6px; border-radius: 3px 0 0 3px; background: var(--cw-brand);
}
.cw-calc__inputs input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none; appearance: none;
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--cw-brand); border: 3px solid #fff;
    box-shadow: 0 1px 3px rgba(10,37,64,0.22), 0 0 0 1px var(--cw-border-strong);
    margin-top: -7px; cursor: grab;
    transition: transform 140ms ease, box-shadow 140ms ease;
}
.cw-calc__inputs input[type="range"]:hover::-webkit-slider-thumb,
.cw-calc__inputs input[type="range"]:focus-visible::-webkit-slider-thumb {
    transform: scale(1.1);
    box-shadow: 0 1px 3px rgba(10,37,64,0.3), 0 0 0 4px rgba(10,37,64,0.12);
}
.cw-calc__inputs input[type="range"]:active::-webkit-slider-thumb { transform: scale(1.14); cursor: grabbing; }
.cw-calc__inputs input[type="range"]::-moz-range-thumb {
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--cw-brand); border: 3px solid #fff;
    box-shadow: 0 1px 3px rgba(10,37,64,0.22), 0 0 0 1px var(--cw-border-strong);
    cursor: grab;
    transition: transform 140ms ease, box-shadow 140ms ease;
}
.cw-calc__inputs input[type="range"]:hover::-moz-range-thumb,
.cw-calc__inputs input[type="range"]:focus-visible::-moz-range-thumb {
    transform: scale(1.1);
    box-shadow: 0 1px 3px rgba(10,37,64,0.3), 0 0 0 4px rgba(10,37,64,0.12);
}

/* Mode-dependent input visibility */
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-hist_start_year"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-hist_benchmark"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-hist_contribution"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-dd_balance"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-dd_start_age"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-dd_withdrawal"],
.cw-calc[data-cw-mode="projection"] .cw-calc__inputs label[for$="-dd_return"] { display: none; }

.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-current_balance"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-annual_contribution"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-years"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-return_rate"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-annual_income"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-dd_balance"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-dd_start_age"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-dd_withdrawal"],
.cw-calc[data-cw-mode="historical"] .cw-calc__inputs label[for$="-dd_return"] { display: none; }

.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-current_balance"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-annual_contribution"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-years"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-return_rate"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-hist_start_year"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-hist_benchmark"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-hist_contribution"],
.cw-calc[data-cw-mode="drawdown"] .cw-calc__inputs label[for$="-annual_income"] { display: none; }

/* Primary result value emphasis */
.cw-calc__result-value--primary {
    color: var(--cw-brand); font-size: 1.5rem; font-weight: 700;
    font-family: var(--cw-font-serif); font-variant-numeric: tabular-nums;
}

/* Room and context callouts (already defined below, keep) */
.cw-room { padding: 0.9rem 1.1rem; background: var(--cw-brand-soft); border-bottom: 1px solid var(--cw-border); font-size: 0.92rem; color: var(--cw-fg); }
.cw-room:empty { display: none; }
.cw-room__copy { margin: 0; line-height: 1.55; }
.cw-room__copy strong { color: var(--cw-brand); font-weight: 600; }
.cw-context { padding: 1rem 1.1rem 1.15rem; background: var(--cw-surface); border-top: 1px solid var(--cw-border); font-size: 0.9rem; color: var(--cw-muted-strong); }
.cw-context:empty { display: none; }
.cw-context__copy { margin: 0 0 0.5rem; line-height: 1.55; }
.cw-context__source { margin: 0; font-size: 0.82rem; color: var(--cw-muted); }
.cw-context__source a { color: var(--cw-brand); font-weight: 500; }

/* Tax-drag "live" card */
.cw-taxdrag {
    padding: 1rem 1.1rem; border-top: 1px solid var(--cw-border);
    background: #fff;
}
.cw-taxdrag:empty { display: none; }
.cw-taxdrag__row {
    display: flex; align-items: baseline; justify-content: space-between;
    gap: 1rem; flex-wrap: wrap;
}
.cw-taxdrag__label {
    font-size: 0.88rem; color: var(--cw-muted-strong); font-weight: 500;
}
.cw-taxdrag__value {
    font-family: var(--cw-font-serif); font-weight: 600;
    font-size: 1.4rem; color: var(--cw-accent-dark);
    font-variant-numeric: tabular-nums;
}
.cw-taxdrag__hint {
    margin: 0.4rem 0 0; font-size: 0.8rem; color: var(--cw-muted); line-height: 1.5;
}

/* Viz layout — main + milestones sidebar */
.cw-viz__layout {
    display: grid; gap: 0;
    grid-template-columns: minmax(0, 1fr);
}
@media (min-width: 900px) {
    .cw-viz__layout { grid-template-columns: minmax(0, 1fr) 220px; }
    .cw-viz__aside { border-left: 1px solid var(--cw-border); }
}
.cw-viz__aside { background: var(--cw-surface); padding: 1.25rem 1.1rem; }
.cw-viz__aside:empty { display: none; }

/* Milestones sidebar */
.cw-milestones__title {
    font-family: var(--cw-font); font-size: 0.76rem;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--cw-muted-strong); margin: 0 0 0.9rem; font-weight: 700;
}
.cw-milestones__list { list-style: none; padding: 0; margin: 0; }
.cw-milestones__item {
    display: grid; grid-template-columns: 22px 1fr auto;
    align-items: baseline; gap: 0.4rem;
    padding: 0.55rem 0; border-bottom: 1px solid var(--cw-border);
    transition: background 500ms ease;
}
.cw-milestones__item:last-child { border-bottom: 0; }
.cw-milestones__check {
    color: var(--cw-accent-dark); font-weight: 700;
    font-size: 0.95rem; line-height: 1;
}
.cw-milestones__item.is-unreached .cw-milestones__check { color: var(--cw-border-strong); }
.cw-milestones__tier {
    font-family: var(--cw-font-serif); font-weight: 600;
    font-size: 1rem; color: var(--cw-fg);
}
.cw-milestones__item.is-unreached .cw-milestones__tier { color: var(--cw-muted); }
.cw-milestones__year { font-size: 0.82rem; color: var(--cw-muted); font-variant-numeric: tabular-nums; }
.cw-milestones__item.is-reached .cw-milestones__year { color: var(--cw-brand); font-weight: 600; }
.cw-milestones__hint { font-size: 0.76rem; color: var(--cw-muted); margin: 0.9rem 0 0; line-height: 1.45; }

@keyframes cw-milestone-pulse {
    0%   { background: rgba(200, 162, 75, 0.0);  transform: scale(1); }
    30%  { background: rgba(200, 162, 75, 0.22); transform: scale(1.02); }
    100% { background: rgba(200, 162, 75, 0.0);  transform: scale(1); }
}
.cw-milestones__item.is-just-reached { animation: cw-milestone-pulse 600ms ease-out; }
@media (prefers-reduced-motion: reduce) {
    .cw-milestones__item.is-just-reached { animation: none; }
}

/* Milestone markers inside chart */
@keyframes cw-milestone-pop {
    0%   { opacity: 0; transform: scale(0.6); }
    60%  { opacity: 1; transform: scale(1.12); }
    100% { opacity: 1; transform: scale(1); }
}
.cw-milestone-marker { transform-origin: center; transform-box: fill-box; }
@media (prefers-reduced-motion: reduce) {
    .cw-milestone-marker { animation: none !important; opacity: 1 !important; transform: none !important; }
}

/* Chart tooltip */
.cw-viz__panel[data-cw-panel="chart"] { position: relative; }

/* Chart overlay + chart host: lock down touch so scrubbing doesn't
 * trigger page scroll. touch-action must be on every ancestor up to
 * the element that actually receives the pointer event. */
[data-cw-overlay] {
    touch-action: none;
    cursor: crosshair;
    -webkit-user-select: none;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
}
[data-cw-chart] {
    touch-action: none;
    -webkit-tap-highlight-color: transparent;
}
.cw-viz__panel[data-cw-panel="chart"] svg {
    touch-action: none;
    -webkit-user-select: none;
    user-select: none;
}
.cw-chart__tooltip {
    position: absolute; top: 0; left: 0; pointer-events: none;
    background: #fff; border: 1px solid var(--cw-border-strong);
    border-radius: var(--cw-radius-sm); padding: 0.55rem 0.7rem;
    box-shadow: 0 4px 12px rgba(10, 37, 64, 0.12);
    font-size: 0.82rem; color: var(--cw-fg);
    min-width: 160px; max-width: 220px;
    transition: opacity 120ms ease;
    z-index: 2;
}
.cw-chart__tooltip[hidden] { display: none; }
.cw-chart__tooltip-yr {
    font-family: var(--cw-font); font-weight: 700;
    font-size: 0.76rem; text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--cw-muted-strong); margin-bottom: 0.4rem;
}
.cw-chart__tooltip-row {
    display: flex; justify-content: space-between; gap: 0.8rem;
    padding: 0.15rem 0;
}
.cw-chart__tooltip-row span { color: var(--cw-muted); }
.cw-chart__tooltip-row strong { color: var(--cw-fg); font-variant-numeric: tabular-nums; }
.cw-chart__tooltip-row--accent { border-top: 1px solid var(--cw-border); margin-top: 0.2rem; padding-top: 0.3rem; }
.cw-chart__tooltip-row--accent strong { color: var(--cw-accent-dark); }

/* Viz tab indicator slide */
.cw-viz__tabs { position: relative; }
.cw-viz__tab.is-active { border-bottom-color: transparent; }
.cw-viz__indicator {
    position: absolute; bottom: 0; left: 0;
    height: 2px; background: var(--cw-accent);
    transition: transform 240ms ease, width 240ms ease;
    will-change: transform, width;
}
@media (prefers-reduced-motion: reduce) {
    .cw-viz__indicator { transition: none; }
}

/* Scroll reveal */
[data-cw-reveal] { opacity: 0; transform: translateY(14px); transition: opacity 420ms ease, transform 420ms ease; will-change: opacity, transform; }
[data-cw-reveal].is-inview { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
    [data-cw-reveal] { opacity: 1; transform: none; transition: none; }
}

/* Reserve chart container height to prevent CLS while JS boots */
[data-cw-chart] { min-height: 260px; }
@media (max-width: 420px) { [data-cw-chart] { min-height: 220px; } }

/* Reserve milestones column so layout doesn't pop on first render */
.cw-viz__aside { min-height: 220px; }

/* Mobile tuning for chart tooltip: narrower max-width to fit viewport */
@media (max-width: 520px) {
    .cw-chart__tooltip {
        min-width: 120px; max-width: min(180px, calc(100vw - 48px));
        font-size: 0.78rem; padding: 0.45rem 0.6rem;
    }
    .cw-chart__tooltip-yr { font-size: 0.72rem; margin-bottom: 0.3rem; }
    .cw-chart__tooltip-row { padding: 0.1rem 0; gap: 0.5rem; font-size: 0.8rem; }
}

/* Viz — chart + year-by-year table tabs */
.cw-viz {
    margin: 0 0 1.5rem;
    border: 1px solid var(--cw-border);
    border-radius: var(--cw-radius);
    background: #fff;
    overflow: hidden;
}
.cw-viz__tabs {
    display: flex; gap: 0;
    border-bottom: 1px solid var(--cw-border);
    background: var(--cw-surface);
}
.cw-viz__tab {
    flex: 1 1 auto; min-width: 0;
    background: transparent; border: 0;
    padding: 0.8rem 1rem; cursor: pointer;
    font: inherit; font-weight: 600; font-size: 0.92rem;
    color: var(--cw-muted-strong);
    border-bottom: 2px solid transparent;
    transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.cw-viz__tab:hover { color: var(--cw-brand); background: #fff; }
.cw-viz__tab.is-active {
    color: var(--cw-brand);
    border-bottom-color: var(--cw-accent);
    background: #fff;
}
.cw-viz__panel { display: none; padding: 1.1rem 1.1rem 1.25rem; }
.cw-viz__panel.is-active { display: block; }

.cw-viz__panel[data-cw-panel="chart"] svg { display: block; max-width: 100%; height: auto; }

.cw-chart__legend {
    display: flex; flex-wrap: wrap; gap: 1rem 1.4rem;
    list-style: none; padding: 0; margin: 0.8rem 0 0;
    font-size: 0.85rem; color: var(--cw-muted-strong);
}
.cw-chart__legend li,
.cw-chart__legend > span { display: inline-flex; align-items: center; gap: 0.45rem; }
.cw-chart__swatch {
    width: 14px; height: 14px; border-radius: 3px;
    display: inline-block; flex: 0 0 auto;
}
.cw-chart__swatch--dash {
    background: transparent;
    border-top: 2px dashed var(--cw-muted-strong);
    height: 4px; border-radius: 0;
}

.cw-year-table__wrap { overflow-x: auto; }
.cw-year-table {
    width: 100%; border-collapse: collapse;
    font-size: 0.88rem; font-variant-numeric: tabular-nums;
}
.cw-year-table th, .cw-year-table td {
    padding: 0.5rem 0.7rem; text-align: right;
    border-bottom: 1px solid var(--cw-border);
    white-space: nowrap;
}
.cw-year-table th:first-child, .cw-year-table td:first-child { text-align: left; }
.cw-year-table thead th {
    font-family: var(--cw-font);
    font-size: 0.76rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--cw-muted-strong);
    background: var(--cw-surface); position: sticky; top: 0;
}
.cw-year-table tbody tr:hover { background: var(--cw-surface); }
.cw-year-table td:nth-child(3) { font-weight: 600; color: var(--cw-brand); }

/* Contribution-year ledger table (static content in post body) */
.cw-article-body table.cw-ledger {
    width: 100%; border-collapse: collapse;
    font-variant-numeric: tabular-nums;
    font-size: 0.95rem; margin: 1rem 0 1.5rem;
}
.cw-article-body table.cw-ledger th,
.cw-article-body table.cw-ledger td {
    padding: 0.55rem 0.8rem; border-bottom: 1px solid var(--cw-border);
    text-align: left;
}
.cw-article-body table.cw-ledger th {
    font-family: var(--cw-font);
    font-size: 0.76rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--cw-muted-strong); background: var(--cw-surface);
}
.cw-article-body table.cw-ledger td:nth-child(2),
.cw-article-body table.cw-ledger th:nth-child(2) { text-align: right; }

/* Source panel */
.cw-source {
    background: var(--cw-brand-soft);
    border-left: 4px solid var(--cw-brand);
    padding: 1.1rem 1.3rem; border-radius: var(--cw-radius-sm);
    margin: 2rem 0; font-size: 0.95rem;
}
.cw-source__title {
    font-family: var(--cw-font); font-size: 0.76rem;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--cw-brand); margin: 0 0 0.4rem; font-weight: 700;
}
.cw-source__body { margin: 0; color: var(--cw-fg); }
.cw-source__footnote {
    margin: 0.8rem 0 0; padding-top: 0.7rem;
    border-top: 1px solid rgba(10, 37, 64, 0.15);
    color: var(--cw-muted-strong); font-size: 0.88rem;
}
.cw-source__footnote a { color: var(--cw-brand); font-weight: 600; }

/* Methodology */
.cw-methodology { margin-top: 2.5rem; }

/* FAQ */
.cw-faq { margin-top: 2.5rem; }
.cw-faq__title { margin-bottom: 1rem; }
.cw-faq__list { margin: 0; padding: 0; }
.cw-faq__item {
    padding: 1.1rem 0; border-bottom: 1px solid var(--cw-border);
}
.cw-faq__item:last-child { border-bottom: 0; }
.cw-faq__q {
    font-family: var(--cw-font-serif); font-weight: 600;
    font-size: 1.05rem; margin: 0 0 0.5rem; color: var(--cw-fg);
}
.cw-faq__a { margin: 0; color: var(--cw-muted-strong); line-height: 1.65; }

/* Sidebar */
.cw-related {
    position: sticky; top: 88px;
    background: #fff; border: 1px solid var(--cw-border);
    border-radius: var(--cw-radius); padding: 1.25rem;
}
.cw-related__title {
    font-family: var(--cw-font); font-size: 0.76rem;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--cw-muted-strong); margin: 0 0 0.9rem; font-weight: 700;
}
.cw-related__list { list-style: none; padding: 0; margin: 0; }
.cw-related__list li {
    padding: 0.6rem 0; border-bottom: 1px solid var(--cw-border);
}
.cw-related__list li:last-child { border-bottom: 0; }
.cw-related__list a {
    display: block; text-decoration: none; color: var(--cw-fg);
    font-size: 0.93rem; font-weight: 500;
}
.cw-related__list a:hover { color: var(--cw-brand); }
