/* Extracted from public/calculator.html during Eleventy migration. */
    /* ===== Calculator Page Styles ===== */
    .calc-page {
      max-width: 800px;
      margin: 0 auto;
      padding: 32px 24px 80px;
    }

    .calc-header {
      text-align: center;
      margin-bottom: 48px;
    }

    .calc-label {
      display: inline-block;
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--accent);
      margin-bottom: 16px;
    }

    .calc-header h1 {
      font-family: 'Fraunces', Georgia, serif;
      /* Match home page hero-headline scale (landing.css) so all
         marketing pages share one display-heading rhythm. */
      font-size: clamp(2.5rem, 5.5vw, 4.2rem);
      font-weight: 500;
      letter-spacing: -0.02em;
      line-height: 1.06;
      margin-bottom: 16px;
      text-wrap: pretty;
    }

    .calc-header p {
      color: var(--text-secondary);
      font-size: 17px;
      line-height: 1.6;
      max-width: 600px;
      margin: 0 auto;
    }

    /* --- Presets (segmented control) --- */
    .calc-presets {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 12px;
      margin-bottom: 32px;
    }

    .calc-presets-label {
      font-size: 11px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--text-muted);
      font-weight: 600;
    }

    .calc-presets-group {
      display: inline-flex;
      background: var(--color-surface-2);
      border: 1px solid var(--color-border-subtle);
      border-radius: 999px;
      padding: 4px;
      gap: 2px;
    }

    .calc-preset-btn {
      flex: 1;
      background: transparent;
      border: none;
      color: var(--text-secondary);
      padding: 8px 22px;
      border-radius: 999px;
      font-size: 13px;
      font-weight: 600;
      cursor: pointer;
      transition: color 0.15s ease, background 0.15s ease;
      font-family: var(--font);
      white-space: nowrap;
      min-height: 36px;
    }

    .calc-preset-btn:hover { color: var(--accent); }

    .calc-preset-btn.active {
      color: #0a0a0f;
      background: var(--accent);
    }

    @media (max-width: 540px) {
      .calc-presets-group {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        width: 100%;
      }
      .calc-preset-btn {
        padding: 10px 8px;
        font-size: 12px;
      }
    }

    /* --- Input Section --- */
    .calc-inputs {
      display: grid;
      gap: 20px;
      margin-bottom: 48px;
    }

    .calc-input-card {
      background: var(--bg-tile);
      border: 1px solid var(--border-tile);
      border-radius: var(--card-radius);
      padding: 24px 28px;
      transition: border-color 0.2s;
    }

    .calc-input-card:focus-within {
      border-color: var(--accent);
    }

    .calc-input-card label {
      display: block;
      font-size: 14px;
      font-weight: 600;
      color: var(--text-primary);
      margin-bottom: 10px;
    }

    .calc-input-wrap {
      position: relative;
      display: flex;
      align-items: center;
    }

    .calc-input-prefix {
      position: absolute;
      left: 16px;
      color: var(--accent);
      font-size: 18px;
      font-weight: 700;
      pointer-events: none;
      z-index: 1;
    }

    .calc-input-card input[type="number"] {
      width: 100%;
      padding: 14px 16px;
      background: #1a1a26;
      border: 1px solid var(--border-tile-hover);
      border-radius: 10px;
      color: var(--text-primary);
      font-size: 16px;
      font-family: var(--font);
      outline: none;
      transition: border-color 0.15s;
      -moz-appearance: textfield;
    }

    .calc-input-card input[type="number"]::-webkit-outer-spin-button,
    .calc-input-card input[type="number"]::-webkit-inner-spin-button {
      -webkit-appearance: none;
      margin: 0;
    }

    .calc-input-card input[type="number"]:focus {
      border-color: var(--accent);
    }

    .calc-input-card input[type="number"]::placeholder {
      color: var(--text-muted);
    }

    .calc-input-card .has-prefix {
      padding-left: 38px;
    }

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

    .slider-header label {
      margin-bottom: 0 !important;
    }

    .slider-value {
      font-size: 20px;
      font-weight: 700;
      color: var(--accent);
    }

    .calc-slider {
      -webkit-appearance: none;
      appearance: none;
      width: 100%;
      height: 8px;
      border-radius: 4px;
      background: #1a1a26;
      outline: none;
      cursor: pointer;
    }

    .calc-slider::-webkit-slider-thumb {
      -webkit-appearance: none;
      appearance: none;
      width: 24px;
      height: 24px;
      border-radius: 50%;
      background: var(--accent);
      cursor: pointer;
      border: 3px solid var(--bg-tile);
      box-shadow: 0 0 12px rgba(63, 184, 114, 0.4);
      transition: box-shadow 0.15s;
    }

    .calc-slider::-webkit-slider-thumb:hover {
      box-shadow: 0 0 20px rgba(63, 184, 114, 0.6);
    }

    .calc-slider::-moz-range-thumb {
      width: 24px;
      height: 24px;
      border-radius: 50%;
      background: var(--accent);
      cursor: pointer;
      border: 3px solid var(--bg-tile);
      box-shadow: 0 0 12px rgba(63, 184, 114, 0.4);
    }

    .slider-labels {
      display: flex;
      justify-content: space-between;
      margin-top: 8px;
      font-size: 12px;
      color: var(--text-muted);
    }

    /* --- Results Section --- */
    .calc-results {
      margin-bottom: 48px;
    }

    .calc-results-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
      margin-bottom: 16px;
    }

    .calc-result-card {
      background: var(--bg-tile);
      border: 1px solid var(--border-tile);
      border-radius: var(--card-radius);
      padding: 24px 20px;
      text-align: center;
      opacity: 0;
      transform: translateY(16px);
      transition: opacity 0.4s ease, transform 0.4s ease;
    }

    .calc-result-card.visible {
      opacity: 1;
      transform: translateY(0);
    }

    .calc-result-card .result-label {
      font-size: 12px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.06em;
      color: var(--text-secondary);
      margin-bottom: 8px;
    }

    .calc-result-card .result-value {
      font-size: clamp(22px, 3vw, 30px);
      font-weight: 800;
      line-height: 1.2;
    }

    .result-value.red {
      color: #ff4d4d;
    }

    .result-value.green {
      color: var(--accent);
    }

    .result-value.placeholder {
      color: var(--text-muted);
      font-size: 24px;
    }

    /* --- Comparison Bar --- */
    .calc-comparison {
      background: var(--bg-tile);
      border: 1px solid var(--border-tile);
      border-radius: var(--card-radius);
      padding: 28px;
      margin-bottom: 48px;
      opacity: 0;
      transform: translateY(16px);
      transition: opacity 0.4s ease, transform 0.4s ease;
    }

    .calc-comparison.visible {
      opacity: 1;
      transform: translateY(0);
    }

    .comparison-row {
      display: flex;
      align-items: center;
      gap: 16px;
      margin-bottom: 16px;
    }

    .comparison-row:last-child {
      margin-bottom: 0;
    }

    .comparison-label {
      flex: 0 0 200px;
      font-size: 14px;
      font-weight: 600;
      color: var(--text-secondary);
    }

    .comparison-bar-wrap {
      flex: 1;
      height: 32px;
      background: #1a1a26;
      border-radius: 8px;
      position: relative;
      overflow: hidden;
    }

    .comparison-bar {
      height: 100%;
      border-radius: 8px;
      display: flex;
      align-items: center;
      justify-content: flex-end;
      padding-right: 12px;
      font-size: 13px;
      font-weight: 700;
      transition: width 0.6s ease;
      min-width: 60px;
    }

    .comparison-bar.loss {
      background: linear-gradient(90deg, rgba(255, 77, 77, 0.15), rgba(255, 77, 77, 0.3));
      color: #ff4d4d;
    }

    .comparison-bar.recovery {
      background: linear-gradient(90deg, rgba(63, 184, 114, 0.15), rgba(63, 184, 114, 0.3));
      color: var(--accent);
    }

    /* --- CTA Section --- */
    .calc-cta {
      text-align: center;
      background: var(--bg-tile);
      border: 1px solid var(--border-tile);
      border-radius: var(--card-radius);
      padding: 48px 32px;
    }

    .calc-cta h2 {
      font-family: 'Fraunces', Georgia, serif;
      /* Match cta-band h2 scale on the home page (landing.css). */
      font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
      font-weight: 500;
      letter-spacing: -0.03em;
      line-height: 1.1;
      margin-bottom: 10px;
    }

    .calc-cta h2 .cta-amount {
      color: var(--accent);
    }

    .calc-cta .cta-sub {
      color: var(--text-secondary);
      font-size: 16px;
      margin-bottom: 28px;
    }

    .calc-cta .btn-primary {
      display: inline-block;
      padding: 16px 40px;
      background: var(--accent);
      color: var(--bg-body);
      font-size: 16px;
      font-weight: 700;
      border-radius: 10px;
      text-decoration: none;
      transition: opacity 0.15s, transform 0.15s;
    }

    .calc-cta .btn-primary:hover {
      opacity: 0.9;
      transform: translateY(-1px);
    }

    .calc-cta-checks {
      display: flex;
      justify-content: center;
      gap: 24px;
      flex-wrap: wrap;
      margin-top: 20px;
      font-size: 14px;
      color: var(--text-secondary);
    }

    .calc-cta-alt {
      margin-top: 14px;
      font-size: 13px;
      color: var(--text-muted);
    }
    .calc-cta-alt a {
      color: var(--accent);
      text-decoration: none;
    }
    .calc-cta-alt a:hover { text-decoration: underline; }

    .calc-result-card .result-foot {
      margin-top: 8px;
      font-size: 11px;
      line-height: 1.4;
      color: var(--text-muted);
    }

    .calc-trust {
      margin: 32px 0 24px;
    }

    .calc-share {
      display: flex;
      justify-content: center;
      margin: 24px 0 0;
    }
    .calc-share-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 14px;
      background: transparent;
      border: 1px solid var(--color-border-subtle);
      border-radius: 999px;
      color: var(--text-secondary);
      font-size: 13px;
      font-weight: 500;
      font-family: var(--font);
      cursor: pointer;
      transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
    }
    .calc-share-btn svg { width: 14px; height: 14px; }
    .calc-share-btn:hover {
      color: var(--accent);
      border-color: var(--accent);
    }
    .calc-share-btn.is-copied {
      color: var(--accent);
      border-color: var(--accent);
      background: rgba(63, 184, 114, 0.08);
    }

    .calc-cta-checks span {
      white-space: nowrap;
    }

    /* --- Responsive --- */
    @media (max-width: 640px) {
      .calc-results-grid {
        grid-template-columns: 1fr;
      }

      .comparison-row {
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
      }

      .comparison-label {
        flex: none;
      }

      .calc-cta-checks {
        flex-direction: column;
        align-items: center;
        gap: 8px;
      }

      .calc-page {
        padding: 20px 16px 60px;
      }
    }

    @media (min-width: 641px) and (max-width: 768px) {
      .calc-results-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }
