:root {
    --col-blue: #0066A0;
    --col-blue-light: #d1ebf9;
    --col-blue-border: #79c7f2;
    --col-green: #00B450;
    --col-green-light: #d6f9e6;
    --col-green-chart: #00B450;
    --col-paper: #faf8f4;
    --col-paper-dot: rgba(160, 140, 100, 0.12);
    --col-border: #e8e2d6;
    --col-text: #2a2520;
    --col-muted: #7a7268;
    --col-hint: #2a2520;
    --col-card: #fff;

    /* Fiscal constants — update here if law changes */
    --pf-micromec-pct: 80;
    --pf-micromec-limit: 250;
    --pf-general-pct: 40;
    --pf-fidelity-pct: 45;
    --is-base-pct: 40;
    --is-fidelity-pct: 50;
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* ==========================================================================
   DONATE SIMULATOR - PAGE
   ========================================================================== */

.donate-simulator {
	padding-top: 50px;
	margin: 15px auto;
	max-width: 952px;
}

.donate-simulator label.btn-amount {
	border: var(--border-width-thick) solid transparent;
	margin: 10px;
}

.donate-simulator input[data-toggle]:checked + label.btn-amount,
.donate-simulator input[data-toggle]:checked + label.btn-amount:active,
.donate-simulator label.btn-amount:hover,
.donate-simulator label.btn-amount:focus {
	color: var(--gray-white) !important;
	background-color: #E85109 !important;
	border: var(--border-width-thick) solid var(--gray-ink);
}

.donate-simulator .data-table {
	margin: 0 auto 20px;
	max-width: 90%;
	background: var(--gray-white);
}

.donate-simulator .data-table td {
	font-size: 0.9rem;
	padding: 10px 15px;
	color: #333333;
	border-bottom: var(--border-width) solid #666666;
}

.donate-simulator .data-table tr td:last-child {
	text-align: right;
}

.donate-simulator .data-table tr:last-child td:last-child {
	font-weight: 700;
}

.donate-simulator .data-table tr:last-child td {
	border-top: var(--border-width-thick) solid #666666;
	border-bottom: none;
}

.donate-simulator .disclamer p {
	font-size: 12px;
	color: slategray;
}

/* ==========================================================================
   DONATE SIMULATOR - CALCULATOR
   ========================================================================== */

.w {
    font-family: var(--font-family-body);
    background: var(--col-paper);
    background-image: radial-gradient(circle at 1px 1px, var(--col-paper-dot) 1px, transparent 0);
    background-size: 24px 24px;
    border-radius: 16px;
    padding: 2rem 1.5rem 2.5rem;
    color: var(--col-text);
    max-width: 660px;
    margin: 0 auto;
}

.w-header {
    text-align: center;
    margin-bottom: 1.75rem;
}

.w-header h1 {
    font-family: var(--font-family-headline);
    font-size: 22px;
    font-weight: 500;
    color: var(--col-text);
    line-height: 1.25;
    margin-bottom: 6px;
}

.w-header p {
    font-size: 13px;
    color: var(--col-muted);
    line-height: 1.5;
}

.w .card {
    background: var(--col-card);
    padding: 1.25rem 1.25rem 1.25rem;    
    margin-bottom: 0 !important;
    border-radius: 0 !important;
    border: none !important;
    border-bottom: 1px dashed var(--col-border) !important;
}

.w .card:first-of-type,
.w .card.carf-first {
    border-radius: 5px 5px 0 0 !important;
}

.w .card:last-of-type,
.w .card.carf-last {
    border-radius: 0 0 5px 5px !important;
    border-bottom: none !important;
}

.section-label {
    font-size: .9rem;
    font-weight: 500;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: var(--col-hint);
    margin-bottom: 12px;
}

.btn-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.btn-grid.three {
    grid-template-columns: 1fr 1fr 1fr;
}

.sel-btn {
    background: var(--col-paper);
    border: 1.5px solid var(--col-border);
    border-radius: 10px;
    padding: 12px 8px;
    cursor: pointer;
    text-align: center;
    font-family: var(--font-family-body)
    transition: border-color 0.15s, background 0.15s;
}

.sel-btn:hover {
    border-color: #c8a87a;
    background: #fdf5ec;
}

.sel-btn.active {
    background: var(--col-blue);
    border-color: var(--col-blue-light);
}

.sel-btn .sb-icon {
    font-size: 20px;
    display: block;
    margin-bottom: 4px;
}

.sel-btn .sb-label {
    font-size: .95rem;
    font-weight: 600;
    color: var(--col-text);
    display: block;
}

.sel-btn .sb-sub {
    font-size: .85rem;
    color: #9a9086;
    display: block;
    margin-top: 2px;
}

.sel-btn.active .sb-icon,
.sel-btn.active .sb-label,
.sel-btn.active .sb-sub {
    color: #FFFFFF;
}

.toggle-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 2px 0;
}

.toggle-label {
    font-size: 13px;
    color: var(--col-text);
    line-height: 1.4;
}

.toggle-label small {
    display: block;
    font-size: 11px;
    color: var(--col-muted);
    margin-top: 2px;
}

.toggle-switch {
    position: relative;
    width: 40px;
    height: 22px;
    flex-shrink: 0;
}

.toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-track {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #d8d2c8;
    border-radius: 22px;
    transition: background 0.2s;
}

.toggle-track:before {
    position: absolute;
    content: '';
    height: 16px;
    width: 16px;
    left: 3px;
    bottom: 3px;
    background: white;
    border-radius: 50%;
    transition: transform 0.2s;
}

.toggle-switch input:checked+.toggle-track {
    background: var(--col-blue);
}

.toggle-switch input:checked+.toggle-track:before {
    transform: translateX(18px);
}

.amount-row {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--col-paper);
    border: 1.5px solid var(--col-border);
    border-radius: 10px;
    padding: 10px 14px;
    transition: border-color 0.15s;
}

.amount-row:focus-within {
    border-color: var(--col-blue);
}

.amount-symbol {
    font-family: var(--font-family-body);
    font-size: 26px;
    color: var(--col-muted);
    line-height: 1;
}

.amount-input {
    flex: 1;
    border: none;
    background: transparent;
    font-family: var(--font-family-body);
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--col-text);
    outline: none;
    min-width: 0;
}

.amount-input::placeholder {
    color: #d5ccbf;
}

.amount-period {
    font-size: 12px;
    color: var(--col-muted);
    white-space: nowrap;
}

.dashed {
    border: none;
    border-top: 2px dashed var(--col-border);
    margin: 1rem 0;
}

.pills {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-bottom: 1rem;
}

.pill {
    background: var(--col-paper);
    border: 1px solid var(--col-border);
    border-radius: 10px;
    padding: 10px 12px;
    text-align: center;
}

.pill.hi {
    background: var(--col-blue-light);
    border-color: var(--col-blue-border);
}

.pill.gr {
    background: var(--col-green-light);
    border-color: #b8ddb8;
}

.pill .pl {
    font-size: 10px;
    color: var(--col-muted);
    display: block;
    margin-bottom: 3px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.pill .pv {
    font-family: var(--font-headline-body);
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--col-text);
    display: block;
    line-height: 1.1;
}

.pill.hi .pv {
    color: var(--col-blue);
}

.pill.gr .pv {
    color: var(--col-green);
}

.pill .ps {
    font-size: 10px;
    color: var(--col-hint);
    display: block;
    margin-top: 2px;
}

.pill .pv:not(.no-format)::first-letter,
.chart-center .cc-val:not(.no-format)::first-letter {
    font-size: 1.2rem;
    vertical-align: super;
}

.chart-wrap {
    position: relative;
    height: 200px;
    margin: 0.25rem 0;
}

.chart-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    pointer-events: none;
}

.cc-val {
    font-family: var(--font-family-body);
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--col-text);
    display: block;
    line-height: 1;
}

.cc-sub {
    font-size: 10px;
    color: var(--col-muted);
    display: block;
    margin-top: 3px;
}

.legend {
    display: flex;
    justify-content: center;
    gap: 18px;
    margin-top: 8px;
    flex-wrap: wrap;
}

.leg {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    color: var(--col-muted);
}

.leg-dot {
    width: 9px;
    height: 9px;
    border-radius: 2px;
    flex-shrink: 0;
}

.info-box {
    background: #fdf5ec;
    border: 1px solid #e8c8a8;
    border-radius: 10px;
    padding: 10px 14px;
    font-size: .9rem;
    color: var(--col-text);
    line-height: 1.55;
    margin-top: 10px;
}

.info-box strong {
    color: var(--col-blue);
}

.expand-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    font-size: .9rem;
    font-weight: 500;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: var(--col-hint);
    gap: 8px;
}

.eb-content {
    display: flex;
    flex-direction: column;
    gap: 3px;
    text-align: left;
}

.eb-desc {
    font-size: .78rem;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    color: var(--col-muted);
    line-height: 1.45;
}

.expand-btn:hover,
.expand-btn:hover .eb-desc {
    color: #1d1813 !important;
}

.eb-chevron {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    transition: transform 0.22s ease;
    color: var(--col-blue);
}

.expand-btn.is-open .eb-chevron {
    transform: rotate(180deg);
}

.cx-box {
    position: relative;
    margin-top: 2rem;
}

.cx-box p {
    font-size: 1rem;
    color: var(--col-text);
    line-height: 1.55;
    margin-bottom: 10px;
}

.cx-table {
    width: 100%;
    font-size: 12px;
    border-collapse: collapse;
    display: table !important;
}

.cx-table td {
    padding: 6px 0;
    color: var(--col-text);
    border-bottom: 1px dashed #e8d8c4;
}

.cx-table tr:last-child td {
    border-bottom: none;
    font-weight: 500;
}

.cx-table td:last-child {
    text-align: right;
}

.cx-badge {
    display: inline-block;
    text-align: center;
    border-radius: 6px;
    padding: 2px 8px;
    font-weight: 700;
}

.cx-badge-blue  { background: var(--col-blue); color: #fff; }
.cx-badge-green { background: var(--col-green); color: #fff; }

.cx-table .cx-diff {
    text-align: right;
    font-size: 11px;
    color: var(--col-muted);
    white-space: nowrap;
}

/* La fila destacada según el tipo de donativo */
tr.cx-highlight td {
    font-weight: 700;
}

.rate-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--col-blue-light);
    border: 1px solid var(--col-blue-border);
    border-radius: 6px;
    padding: 3px 8px;
    font-size: 11px;
    font-weight: 500;
    color: var(--col-blue);
    margin-top: 8px;
}

.cta-btn {
    display: block;
    width: 100%;
    background: var(--col-blue);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 12px;
    font-family: var(--font-family-body)
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    text-align: center;
    transition: background 0.15s;
    margin-top: 10px;
}

.cta-btn:hover {
    background: #b05e2a;
}

.disclaimer {
    font-size: 10px;
    color: var(--col-muted);
    line-height: 1.5;
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px dashed var(--col-border);
}

/* ==========================================================================
   MOBILE — APP-LIKE EXPERIENCE
   ========================================================================== */

@media (max-width: 768px) {
    /* Full-bleed widget, no radius — feels native */
    .w {
        border-radius: 0;
        padding: 1.25rem 1rem 2rem;
        margin: 0;
    }

    /* Cards already have no border/padding, add breathing room between them */
    .w .card {
        background: transparent !important;
        border-bottom: none !important;
        border-left: none !important;
        border-right: none !important;
        border-top: 1px dashed var(--col-border) !important;
        border-radius: none !important;
        padding: 2rem 0 0 0;
        box-shadow: none !important;
        margin-bottom: 10px;
    }

    .w .card:first-child {
        border-top: none;
    }

    .dashed {
        border-top: 1px dashed var(--col-border) !important;
    }

    .sel-btn {
        background: #FFFFFF;
    }    

    /* Tighter section label */
    .section-label {
        font-size: .8rem;
        margin-bottom: 10px;
    }

    /* Pills: keep 2-col grid but reduce font */
    .pill {
        background: #FFFFFF;
    }

    /* Amount input: slightly smaller so it doesn't overflow */
    .amount-row,
    .amount-input {
        background: #FFFFFF;
        font-size: 2rem;
    }

    /* cx-box: tighter padding */
    .cx-box {
        width: 100%;
        padding: .8rem 0 0 0;
        box-shadow: none !important;        
    }

    .cx-table {
        width: 100%;
        margin: 0;
        box-shadow: none !important;
    }

    /* chart: a touch shorter on small screens */
    .chart-wrap {
        height: 170px;
    }

    /* disclaimer: give it breathing room */
    .disclaimer {
        margin-top: 1.5rem;
        font-size: 9.5px;
    }
}

.hidden {
    display: none !important;
}

/* ==========================================================================
   DARK MODE
   ========================================================================== */

@media (prefers-color-scheme: dark) {
    .w {
        --col-paper:       #1a1a1a;
        --col-border:      #333330;
        --col-text:        #f0ece6;
        --col-muted:       #9a9086;
        --col-hint:        #f0ece6;
        --col-card:        #242420;
        --col-blue-light:  #0d2d40;
        --col-blue-border: #1a4d6a;
        --col-green-light: #0a2a18;

        background: #121212;
    }

    /* Botones de selección */
    .w .sel-btn {
        background: #242420;
        border-color: #333330;
    }

    .w .sel-btn:hover {
        background: #2e2a24;
        border-color: #555;
    }

    /* Input de importe */
    .w .amount-row {
        background: #242420;
    }

    /* Pills neutras */
    .w .pill {
        background: #242420;
    }

    /* Info box */
    .w .info-box {
        background: #2a2218;
        border-color: #4a3828;
    }

    /* cx-box */
    .w .cx-box {
        background: #1e1e1a;
        border-color: #333330;
    }

    .w .cx-table td {
        border-bottom-color: #333330;
    }

    /* Toggle track apagado */
    .w .toggle-track {
        background: #444;
    }

    /* Separadores */
    .w .dashed {
        border-top-color: #333330;
    }

    .w .disclaimer {
        border-top-color: #333330;
    }

    /* Cards en móvil */
    @media (max-width: 768px) {
        .w .card {
            background: transparent !important;
            border-top-color: #333330 !important;
        }

        .w .sel-btn,
        .w .pill,
        .w .amount-row {
            background: #242420;
        }
    }
}