:root {
    --color-primary: #691c32;
    --color-primary-dark: #4f1525;
    --color-primary-darker: #3a0f1b;
    --color-accent: #b18a4e;
    --color-bg: #f2f2f2;
    --color-white: #ffffff;
    --color-text: #1f1f1f;
    --color-text-soft: #4a4a4a;
    --color-text-muted: #777;
    --color-border: #d9d9d9;
    --color-success: #257b3a;
    --color-error: #b32d2e;
    --color-whatsapp: #25d366;

    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;

    --shadow-card: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);
    --shadow-elev: 0 4px 12px rgba(0, 0, 0, .1);

    --font-sans: "Noto Sans", "Open Sans", "Helvetica Neue", Arial, sans-serif;

    --container: 1200px;
    --header-h: 64px;
}

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

html, body {
    margin: 0;
    padding: 0;
    font-family: var(--font-sans);
    color: var(--color-text);
    background: var(--color-white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    max-width: 100%;
}

body { display: flex; flex-direction: column; min-height: 100vh; }
.main { flex: 1 0 auto; min-width: 0; }

a { color: var(--color-primary); text-decoration: none; }
a:hover { text-decoration: underline; }

img { max-width: 100%; height: auto; display: block; }

button { font-family: inherit; cursor: pointer; }

/* ---------- HEADER ---------- */
.site-header { width: 100%; }

.site-header__top { background: var(--color-primary); color: var(--color-white); }
.site-header__sub { background: var(--color-primary-dark); color: var(--color-white); }

.site-header__container {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 24px;
    height: var(--header-h);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.site-header__sub .site-header__container { height: 40px; }

.site-header__brand { display: flex; align-items: center; }
.site-header__brand-img { height: 40px; width: auto; }

.site-header__nav { display: flex; align-items: center; gap: 28px; }
.site-header__nav-link {
    color: var(--color-white);
    font-size: 15px;
    font-weight: 600;
    padding: 8px 4px;
    text-decoration: none;
}
.site-header__nav-link:hover { text-decoration: underline; opacity: .9; }

.site-header__version {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: rgba(255,255,255,.92);
    margin-left: auto;
}
.site-header__version strong { font-weight: 700; }
.site-header__version-num { opacity: .75; margin-left: 6px; }
.site-header__version-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--color-accent);
    display: inline-block;
}

.site-header__burger {
    display: none;
    background: transparent;
    border: 0;
    width: 40px; height: 40px;
    flex-direction: column; justify-content: center; align-items: center;
    gap: 4px;
}
.site-header__burger span {
    display: block; width: 22px; height: 2px; background: var(--color-white); border-radius: 2px;
    transition: transform .2s ease, opacity .15s ease;
    transform-origin: center;
}
.site-header__burger.is-active span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.site-header__burger.is-active span:nth-child(2) { opacity: 0; }
.site-header__burger.is-active span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.site-header__mobile-nav {
    display: none;
    flex-direction: column;
    background: var(--color-primary-dark);
    padding: 8px 24px 16px;
}
.site-header__mobile-nav .site-header__nav-link {
    padding: 12px 0;
    border-bottom: 1px solid rgba(255,255,255,.08);
}

@media (max-width: 768px) {
    .site-header__nav { display: none; }
    .site-header__burger { display: inline-flex; }
    .site-header__mobile-nav.is-open { display: flex; }
    .site-header__container { padding: 0 16px; gap: 8px; }
    .site-header__brand-img { height: 32px; }
    .site-header__version { font-size: 12px; gap: 6px; }
    .site-header__version-num { display: none; }
    .site-header__sub .site-header__version { display: none; }
    .site-header__sub .site-header__container { height: 48px; }
}

/* ---------- FOOTER ---------- */
.site-footer {
    background: var(--color-primary-darker);
    color: var(--color-white);
    padding: 24px 0;
    flex-shrink: 0;
}
.site-footer__container {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}
.site-footer__social { display: flex; gap: 14px; align-items: center; }
.site-footer__social-link {
    width: 36px; height: 36px;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--color-white);
    border: 1px solid rgba(255,255,255,.25);
    border-radius: 50%;
    transition: background .15s;
}
.site-footer__social-link:hover { background: rgba(255,255,255,.1); text-decoration: none; }

.site-footer__phone {
    display: inline-flex; align-items: center; gap: 10px;
    color: var(--color-white); font-size: 15px;
}
.site-footer__phone strong { font-size: 16px; }

@media (max-width: 640px) {
    .site-footer__container { flex-direction: column; text-align: center; }
}

/* ---------- HERO (index.php) ---------- */
.hero {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: calc(100vh - var(--header-h) - 40px - 100px);
    width: 100%;
}

.hero__left {
    background: var(--color-primary);
    color: var(--color-white);
    padding: 64px 56px;
    position: relative;
    overflow: hidden;
}
.hero__left::before {
    content: "";
    position: absolute; inset: 0;
    background-image: url("../images/home-bg.990b60fc203b5a6e55dc.png");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    opacity: .18;
    pointer-events: none;
}
.hero__left-inner { position: relative; z-index: 1; max-width: 480px; }

.hero__sre-logo { width: 320px; max-width: 100%; margin-bottom: 36px; }

.hero__title {
    font-size: 48px;
    line-height: 1.1;
    font-weight: 700;
    margin: 0 0 12px;
    letter-spacing: -0.5px;
}
.hero__version {
    font-size: 13px;
    opacity: .8;
    margin-bottom: 18px;
}
.hero__subtitle {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 24px;
    opacity: .95;
}

.hero__list { list-style: none; padding: 0; margin: 0; }
.hero__list li {
    position: relative;
    padding: 8px 0 8px 28px;
    font-size: 17px;
}
.hero__list li::before {
    content: "✓";
    position: absolute; left: 0; top: 8px;
    color: var(--color-accent);
    font-weight: 700;
}

.hero__right {
    background: var(--color-bg);
    padding: 64px 56px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: stretch;
    gap: 20px;
}
.hero__right-inner { max-width: 560px; width: 100%; margin: 0 auto; }

.hero__lead-title {
    font-size: 28px;
    font-weight: 700;
    color: var(--color-primary);
    margin: 0 0 8px;
}
.hero__lead-text {
    font-size: 15px;
    color: var(--color-text-soft);
    line-height: 1.55;
    margin: 0 0 24px;
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 28px;
    border-radius: var(--radius-sm);
    font-size: 16px;
    font-weight: 600;
    border: 0;
    cursor: pointer;
    transition: background .15s, transform .05s;
    text-decoration: none;
}
.btn:active { transform: translateY(1px); }
.btn--primary {
    background: var(--color-primary);
    color: var(--color-white);
}
.btn--primary:hover { background: var(--color-primary-dark); text-decoration: none; color: var(--color-white); }
.btn--block { width: 100%; }
.btn--whatsapp { background: var(--color-whatsapp); color: var(--color-white); }
.btn--whatsapp:hover { background: #1ebc59; text-decoration: none; color: var(--color-white); }
.btn--ghost {
    background: transparent; color: var(--color-primary);
    border: 1px solid var(--color-primary);
}
.btn--ghost:hover { background: var(--color-primary); color: var(--color-white); text-decoration: none; }

/* ---------- WHATSAPP CARD ---------- */
.wa-card {
    margin-top: 28px;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 20px;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 20px;
    align-items: center;
    box-shadow: var(--shadow-card);
}
.wa-card__qr {
    width: 140px; height: 140px;
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    object-fit: contain;
    padding: 6px;
}
.wa-card__body { display: flex; flex-direction: column; gap: 10px; }
.wa-card__title {
    margin: 0;
    font-size: 17px;
    font-weight: 700;
    color: var(--color-text);
    display: inline-flex; align-items: center; gap: 8px;
}
.wa-card__text {
    margin: 0;
    font-size: 14px;
    color: var(--color-text-soft);
    line-height: 1.5;
}
.wa-card__link {
    align-self: flex-start;
    font-size: 14px;
}

@media (max-width: 920px) {
    .hero { grid-template-columns: 1fr; }
    .hero__left, .hero__right { padding: 40px 24px; }
    .hero__left { text-align: center; }
    .hero__left-inner { max-width: 100%; margin: 0 auto; }
    .hero__sre-logo { margin-left: auto; margin-right: auto; }
    .hero__list { display: inline-block; text-align: left; }
    .hero__title { font-size: 36px; }
    .hero__sre-logo { width: 240px; max-width: 100%; }
    .wa-card { grid-template-columns: 1fr; text-align: center; }
    .wa-card__qr { margin: 0 auto; }
    .wa-card__body { align-items: center; }
}

@media (max-width: 480px) {
    .hero__left, .hero__right { padding: 32px 20px; }
    .hero__title { font-size: 30px; line-height: 1.05; }
    .hero__sre-logo { width: 200px; }
    .hero__subtitle { font-size: 16px; }
    .hero__list li { font-size: 15px; }
    .hero__lead-title { font-size: 22px; }
}

/* ---------- CURP PAGE LAYOUT ---------- */
.app {
    display: grid;
    grid-template-columns: 260px 1fr;
    max-width: var(--container);
    margin: 0 auto;
    padding: 32px 24px;
    gap: 32px;
    min-height: calc(100vh - var(--header-h) - 40px - 100px);
}

.sidebar {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 16px;
    height: max-content;
    position: sticky;
    top: 24px;
}
.sidebar__title {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--color-text-muted);
    letter-spacing: .5px;
    margin: 0 0 12px;
    padding: 0 8px;
}
.sidebar__menu { list-style: none; padding: 0; margin: 0; }
.sidebar__link {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 12px;
    color: var(--color-text);
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: 15px;
}
.sidebar__link.is-active,
.sidebar__link:hover {
    background: rgba(105, 28, 50, .08);
    color: var(--color-primary);
    text-decoration: none;
}
.sidebar__icon {
    width: 20px; height: 20px;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--color-primary);
}

.content { min-width: 0; }
.content__heading {
    font-size: 28px; font-weight: 700;
    color: var(--color-primary);
    margin: 0 0 8px;
}
.content__sub {
    font-size: 15px; color: var(--color-text-soft);
    margin: 0 0 24px;
}

/* ---------- STEPPER (PC arrows) ---------- */
.stepper {
    display: flex;
    align-items: stretch;
    gap: 0;
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.stepper__item {
    flex: 0 0 auto;
    display: flex; align-items: center;
    padding: 12px 28px 12px 36px;
    background: var(--color-bg);
    color: var(--color-text-soft);
    font-weight: 600; font-size: 14px;
    position: relative;
    clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 50%, calc(100% - 14px) 100%, 0 100%, 14px 50%);
    margin-right: -10px;
}
.stepper__item:first-child {
    clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 50%, calc(100% - 14px) 100%, 0 100%);
    padding-left: 20px;
}
.stepper__item:last-child {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 14px 50%);
}
.stepper__item.is-active {
    background: var(--color-primary);
    color: var(--color-white);
}
.stepper__item.is-done {
    background: var(--color-accent);
    color: var(--color-white);
}
.stepper__num {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 22px; height: 22px;
    background: rgba(255,255,255,.25);
    color: inherit;
    border-radius: 50%;
    font-size: 12px; font-weight: 700;
    margin-right: 8px;
}
.stepper__item:not(.is-active):not(.is-done) .stepper__num {
    background: rgba(0,0,0,.08);
}

@media (max-width: 768px) {
    .stepper { display: none; }
}

/* mobile-only "Paso 1" label */
.step-label {
    display: none;
    font-size: 13px; font-weight: 700;
    text-transform: uppercase;
    color: var(--color-primary);
    letter-spacing: .5px;
    margin-bottom: 8px;
}
@media (max-width: 768px) {
    .step-label { display: block; }
}

/* ---------- PERSON LIST (curp.php — universal flow) ---------- */
.curp-list { display: flex; flex-direction: column; gap: 16px; }

.person-item {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 20px;
    box-shadow: var(--shadow-card);
    transition: border-color .15s, background .15s;
}
.person-item--confirmed {
    border-color: var(--color-success);
    background: #f4faf5;
}

.person-item__header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 14px;
}
.person-item__title {
    margin: 0;
    font-size: 15px;
    font-weight: 700;
    color: var(--color-text);
    display: inline-flex; align-items: center; gap: 10px;
}
.person-item__confirmed-badge {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 2px 8px;
    background: var(--color-success);
    color: #fff;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .4px;
}
.person-item__remove {
    background: transparent;
    border: 0;
    color: var(--color-text-muted);
    width: 28px; height: 28px;
    border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 18px;
    cursor: pointer;
}
.person-item__remove:hover { background: rgba(0,0,0,.06); color: var(--color-error); }

.person-chooser__lead {
    margin: 0 0 12px;
    font-size: 14px;
    color: var(--color-text-soft);
}
.person-chooser__options {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.person-chooser__btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 6px;
    padding: 18px 14px;
    background: #fafafa;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: border-color .15s, box-shadow .15s, transform .12s, background .15s;
}
.person-chooser__btn:hover,
.person-chooser__btn:focus-visible {
    border-color: var(--color-primary);
    background: #fff;
    box-shadow: 0 4px 14px rgba(105, 28, 50, .12);
    transform: translateY(-1px);
    outline: none;
}
.person-chooser__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 44px; height: 44px;
}
.person-chooser__btn-title {
    font-size: 15px;
    font-weight: 700;
    color: var(--color-text);
}
.person-chooser__btn-desc {
    font-size: 13px;
    color: var(--color-text-muted);
    line-height: 1.35;
}

.curp-field { display: flex; }
.curp-input {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 16px;
    font-family: inherit;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-text);
    background: var(--color-white);
}
.curp-input:focus {
    outline: 0;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(105, 28, 50, .15);
}
.curp-hint {
    font-size: 12px;
    color: var(--color-text-muted);
    margin: 6px 0 0;
}
.curp-error {
    font-size: 13px;
    color: var(--color-error);
    margin: 8px 0 0;
}

.datos-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.datos-grid .form-field { display: flex; flex-direction: column; gap: 6px; }
.datos-grid .form-field--full { grid-column: 1 / -1; }
.datos-grid .form-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text-soft);
}
.datos-grid .form-req { color: var(--color-error); margin-left: 2px; }
.datos-grid input,
.datos-grid select {
    font: inherit;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-white);
    color: var(--color-text);
}
.datos-grid input:focus,
.datos-grid select:focus {
    outline: 0;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(105, 28, 50, .15);
}
.datos-error {
    font-size: 13px;
    color: var(--color-error);
    margin: 10px 0 0;
}

.person-form__switch {
    margin-top: 12px;
    background: transparent;
    border: 0;
    padding: 0;
    color: var(--color-primary);
    font-size: 13px;
    text-decoration: underline;
    cursor: pointer;
}

.person-validating {
    display: flex; align-items: center; gap: 12px;
    padding: 18px 4px;
    color: var(--color-text-soft);
    font-size: 14px;
}
.person-validating__spinner {
    width: 22px; height: 22px;
    border: 3px solid rgba(105, 28, 50, .18);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: personSpin .8s linear infinite;
}
@keyframes personSpin { to { transform: rotate(360deg); } }

.person-confirmed__name {
    margin: 0 0 4px;
    font-size: 16px;
    font-weight: 700;
    color: var(--color-text);
}
.person-confirmed__meta {
    margin: 0 0 10px;
    font-size: 13px;
    color: var(--color-success);
}
.person-confirmed__edit {
    background: transparent;
    border: 0;
    padding: 0;
    color: var(--color-primary);
    font-size: 13px;
    text-decoration: underline;
    cursor: pointer;
}

.curp-add-btn {
    margin-top: 4px;
    align-self: flex-start;
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 18px;
    background: var(--color-white);
    color: var(--color-primary);
    border: 1px dashed var(--color-primary);
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
}
.curp-add-btn:hover { background: rgba(105, 28, 50, .05); }

.curp-actions {
    margin-top: 32px;
    display: flex; gap: 12px; justify-content: flex-end; flex-wrap: wrap;
}

@media (max-width: 920px) {
    .app { grid-template-columns: 1fr; padding: 16px; gap: 16px; }
    .sidebar { position: static; }
    .content__heading { font-size: 22px; }
    .person-item__title { font-size: 14px; }
}

@media (max-width: 600px) {
    .person-chooser__options { grid-template-columns: 1fr; }
    .datos-grid { grid-template-columns: 1fr; }
    .curp-input { font-size: 15px; letter-spacing: 0.5px; }
    .curp-actions { justify-content: stretch; }
    .curp-actions .btn { flex: 1; }
    .content__sub { font-size: 14px; }
}

/* ---------- MODAL ---------- */
.modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.modal[hidden] { display: none; }

.modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(20, 8, 14, .55);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    animation: modalFadeIn .2s ease-out;
}

.modal__dialog {
    position: relative;
    width: 100%;
    max-width: 480px;
    background: var(--color-white);
    border-radius: var(--radius-lg);
    box-shadow: 0 20px 60px rgba(0, 0, 0, .3);
    padding: 32px 28px 24px;
    text-align: center;
    animation: modalSlideIn .25s cubic-bezier(.2, .9, .3, 1);
}

.modal__close {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    border: 0;
    background: transparent;
    border-radius: 50%;
    font-size: 24px;
    line-height: 1;
    color: var(--color-text-muted);
    transition: background .15s, color .15s;
}
.modal__close:hover { background: var(--color-bg); color: var(--color-text); }

.modal__icon {
    width: 72px;
    height: 72px;
    margin: 0 auto 16px;
    border-radius: 50%;
    background: rgba(37, 123, 58, .12);
    color: var(--color-success);
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal__title {
    margin: 0 0 12px;
    font-size: 22px;
    font-weight: 700;
    color: var(--color-text);
    line-height: 1.25;
}

.modal__text {
    margin: 0 0 16px;
    font-size: 15px;
    color: var(--color-text-soft);
    line-height: 1.5;
}

.modal__list {
    margin: 0 0 20px;
    padding: 12px 16px;
    background: var(--color-bg);
    border-radius: var(--radius-sm);
    text-align: left;
    font-size: 13px;
    color: var(--color-text);
    max-height: 160px;
    overflow-y: auto;
}
.modal__list:empty { display: none; }
.modal__list-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 0;
    border-bottom: 1px solid var(--color-border);
}
.modal__list-item:last-child { border-bottom: 0; }
.modal__list-item-name { font-weight: 600; }
.modal__list-item-curp {
    font-family: "SFMono-Regular", Consolas, monospace;
    color: var(--color-text-soft);
    letter-spacing: .5px;
    font-size: 12px;
}

.modal__actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}
.modal__actions .btn { min-width: 140px; }

@keyframes modalFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}
@keyframes modalSlideIn {
    from { opacity: 0; transform: translateY(20px) scale(.96); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

body.modal-open { overflow: hidden; }

@media (max-width: 600px) {
    .modal__dialog { padding: 28px 20px 20px; }
    .modal__title { font-size: 19px; }
    .modal__text { font-size: 14px; }
    .modal__actions { flex-direction: column-reverse; }
    .modal__actions .btn { width: 100%; min-width: 0; }
}

/* ---------- CONTENT PAGES (informacion / contacto) ---------- */
.info-page { padding: 48px 24px 64px; }
.info-page__container { max-width: 860px; margin: 0 auto; }
.info-page__title {
    color: var(--color-primary);
    font-size: 36px; font-weight: 700; margin: 0 0 16px;
}
.info-page__lead { font-size: 17px; color: var(--color-text-soft); margin: 0 0 32px; line-height: 1.6; }

.info-block {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px 28px;
    margin-bottom: 20px;
}
.info-block h2 {
    margin: 0 0 12px;
    color: var(--color-primary);
    font-size: 20px; font-weight: 700;
}
.info-block ul, .info-block ol { margin: 0; padding-left: 22px; line-height: 1.7; }
.info-block li { margin-bottom: 4px; }

.info-page__cta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 32px; }

.contact-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 16px;
    margin-bottom: 16px;
}
.contact-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px;
    display: flex; flex-direction: column; gap: 12px;
}
.contact-card h2 {
    margin: 0;
    color: var(--color-primary);
    font-size: 18px; font-weight: 700;
}
.contact-card p { margin: 0; color: var(--color-text-soft); font-size: 14px; line-height: 1.5; }
.contact-card__big {
    font-size: 24px; font-weight: 700; color: var(--color-primary);
    text-decoration: none; letter-spacing: 0.5px;
}
.contact-card__big:hover { text-decoration: underline; }
.contact-card__link { color: var(--color-primary); font-weight: 600; text-decoration: none; word-break: break-word; }
.contact-card__link:hover { text-decoration: underline; }

@media (max-width: 600px) {
    .info-page { padding: 32px 16px 48px; }
    .info-page__title { font-size: 28px; }
    .info-page__lead { font-size: 15px; }
    .info-block { padding: 20px 18px; }
    .info-page__cta .btn { width: 100%; }
}

/* ---------- CONTACT FORM + MAP ---------- */
.contact-split {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 24px;
    margin: 32px 0;
}
.contact-form-wrap, .contact-map {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px 28px;
}
.contact-section-title {
    color: var(--color-primary);
    font-size: 20px; font-weight: 700;
    margin: 0 0 8px;
}
.contact-section-sub {
    color: var(--color-text-soft);
    font-size: 14px; line-height: 1.5;
    margin: 0 0 20px;
}

.contact-form { display: flex; flex-direction: column; gap: 16px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-field { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.form-label {
    font-size: 13px; font-weight: 600; color: var(--color-text);
    display: inline-flex; align-items: baseline; gap: 4px;
}
.form-req { color: var(--color-primary); }

.form-field input,
.form-field select,
.form-field textarea {
    font: inherit;
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-white);
    color: var(--color-text);
    transition: border-color .15s ease, box-shadow .15s ease;
    box-sizing: border-box;
}
.form-field textarea { resize: vertical; min-height: 110px; }
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(105, 28, 50, 0.12);
}
.form-field input.has-error,
.form-field select.has-error,
.form-field textarea.has-error {
    border-color: #c0392b;
    box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.12);
}

.form-hint { font-size: 12px; color: var(--color-text-soft); align-self: flex-end; }
.form-error { font-size: 12px; color: #c0392b; min-height: 1em; }

.form-check {
    display: flex; align-items: flex-start; gap: 10px;
    font-size: 14px; color: var(--color-text-soft); line-height: 1.4;
}
.form-check input { margin-top: 3px; accent-color: var(--color-primary); }

.form-actions { display: flex; gap: 12px; flex-wrap: wrap; }

.form-success {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 14px 16px;
    background: rgba(39, 174, 96, 0.08);
    border: 1px solid rgba(39, 174, 96, 0.3);
    color: #1e7e3a;
    border-radius: var(--radius-sm);
}
.form-success[hidden] { display: none; }
.form-success strong { display: block; font-size: 15px; margin-bottom: 2px; }
.form-success p { margin: 0; font-size: 14px; }

.contact-map__frame {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: var(--radius-sm);
    overflow: hidden;
    border: 1px solid var(--color-border);
    background: #eee;
    margin-bottom: 16px;
}
.contact-map__frame iframe {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    border: 0;
    display: block;
}
.contact-map__link {
    display: inline-flex; align-items: center; gap: 6px;
    color: var(--color-primary); font-weight: 600;
    text-decoration: none; font-size: 14px;
}
.contact-map__link::after { content: "→"; }
.contact-map__link:hover { text-decoration: underline; }

@media (max-width: 900px) {
    .contact-split { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
    .contact-form-wrap, .contact-map { padding: 20px 18px; }
    .form-row { grid-template-columns: 1fr; gap: 14px; }
    .form-actions .btn { width: 100%; }
}

/* ---------- OFICINA (step 2) ---------- */
.oficina-picker {
    display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
    margin-bottom: 20px;
}
.oficina-field { display: flex; flex-direction: column; gap: 6px; }
.oficina-field__label {
    font-size: 13px; font-weight: 600; color: var(--color-text);
}

/* Custom dropdown */
.dd { position: relative; }
.dd.is-open { z-index: 50; }
.dd__trigger {
    width: 100%;
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 11px 14px;
    font: inherit; font-size: 15px; color: var(--color-text);
    cursor: pointer; text-align: left;
    transition: border-color .15s, box-shadow .15s;
}
.dd__trigger:hover:not(:disabled) { border-color: rgba(105,28,50,.4); }
.dd.is-open .dd__trigger {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(105,28,50,.12);
}
.dd__trigger:disabled,
.dd.is-disabled .dd__trigger {
    background: #f5f5f5; color: var(--color-text-soft); cursor: not-allowed;
}
.dd__value { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dd__value.is-placeholder { color: var(--color-text-soft); }
.dd__chev { color: var(--color-text-soft); flex-shrink: 0; transition: transform .15s; }
.dd.is-open .dd__chev { transform: rotate(180deg); }

.dd__panel {
    position: absolute; left: 0; right: 0; top: calc(100% + 6px);
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: 0 12px 32px rgba(0,0,0,.10), 0 2px 8px rgba(0,0,0,.04);
    z-index: 1000;
    display: flex; flex-direction: column;
    max-height: 320px;
    overflow: hidden;
}
.dd--up .dd__panel {
    top: auto;
    bottom: calc(100% + 6px);
}
.dd__search {
    display: flex; align-items: center; gap: 8px;
    padding: 10px 12px; border-bottom: 1px solid var(--color-border);
    color: var(--color-text-soft);
}
.dd__search input {
    flex: 1; min-width: 0; border: 0; outline: none; background: transparent;
    font: inherit; font-size: 14px; color: var(--color-text);
}
.dd__list {
    list-style: none; margin: 0; padding: 6px 0;
    overflow-y: auto; max-height: 260px;
}
.dd__item {
    padding: 10px 14px; font-size: 14px; color: var(--color-text);
    cursor: pointer;
    transition: background .1s;
}
.dd__item:hover,
.dd__item.is-active { background: rgba(105,28,50,.06); }
.dd__item.is-selected {
    color: var(--color-primary); font-weight: 600;
    background: rgba(105,28,50,.08);
}
.dd__empty {
    margin: 0; padding: 16px; text-align: center;
    color: var(--color-text-soft); font-size: 14px;
}

/* Detail card with embedded map */
.oficina-detail {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: 20px;
    display: grid; grid-template-columns: 1fr 1.1fr; gap: 0;
    overflow: hidden;
}
.oficina-detail__info {
    padding: 20px 22px;
    display: flex; flex-direction: column; gap: 12px;
}
.oficina-detail__head {
    display: flex; justify-content: space-between; align-items: flex-start; gap: 12px;
    flex-wrap: wrap;
}
.oficina-detail__name {
    margin: 0;
    font-size: 18px; font-weight: 700; color: var(--color-primary);
    line-height: 1.3;
}
.oficina-detail__badge {
    font-size: 12px; font-weight: 600;
    color: var(--color-primary);
    background: rgba(105,28,50,.08);
    padding: 4px 10px; border-radius: 999px;
    white-space: nowrap;
}
.oficina-detail__row {
    display: flex; gap: 8px; align-items: flex-start;
    font-size: 14px; color: var(--color-text); line-height: 1.5;
}
.oficina-detail__row svg {
    flex-shrink: 0; margin-top: 3px; color: var(--color-text-soft);
}
.oficina-detail__actions {
    display: flex; gap: 10px; margin-top: auto;
    padding-top: 12px; border-top: 1px solid var(--color-border);
}
.oficina-detail__map {
    display: inline-flex; align-items: center; gap: 8px;
}
.oficina-detail__map-wrap {
    position: relative;
    min-height: 280px;
    background: #eef0f3;
    border-left: 1px solid var(--color-border);
}
.oficina-detail__map-wrap iframe {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    border: 0; display: block;
}

@media (max-width: 760px) {
    .oficina-picker { grid-template-columns: 1fr; }
    .oficina-detail { grid-template-columns: 1fr; }
    .oficina-detail__map-wrap { min-height: 220px; border-left: 0; border-top: 1px solid var(--color-border); }
}

/* ---------- FECHA (step 3) ---------- */
.fecha-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
    margin-bottom: 24px;
}
.fecha-cal, .fecha-slots {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 18px;
}
.fecha-cal__header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 12px;
}
.fecha-cal__month {
    font-weight: 700; color: var(--color-primary); font-size: 16px;
    text-transform: capitalize;
}
.fecha-cal__nav {
    width: 32px; height: 32px; border-radius: 50%;
    border: 1px solid var(--color-border); background: var(--color-white);
    cursor: pointer; font-size: 20px; line-height: 1;
    color: var(--color-text);
    display: flex; align-items: center; justify-content: center;
    transition: border-color .15s, color .15s, background .15s;
}
.fecha-cal__nav:hover:not(:disabled) {
    border-color: var(--color-primary); color: var(--color-primary);
}
.fecha-cal__nav:disabled { opacity: .35; cursor: not-allowed; }

.fecha-cal__weekdays {
    display: grid; grid-template-columns: repeat(7, 1fr);
    text-align: center; font-size: 12px; font-weight: 700;
    color: var(--color-text-soft); padding-bottom: 6px;
    border-bottom: 1px solid var(--color-border); margin-bottom: 6px;
}
.fecha-cal__days {
    display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px;
}
.fecha-day, .fecha-day-blank {
    aspect-ratio: 1;
    display: flex; align-items: center; justify-content: center;
    font-size: 14px;
}
.fecha-day {
    border: 1px solid transparent; border-radius: var(--radius-sm);
    background: transparent; color: var(--color-text);
    cursor: pointer; font-weight: 500;
    transition: background .15s, color .15s, border-color .15s;
}
.fecha-day:hover:not(:disabled) {
    background: rgba(105,28,50,.08); color: var(--color-primary);
}
.fecha-day.is-today { border-color: var(--color-primary); }
.fecha-day.is-selected {
    background: var(--color-primary); color: var(--color-white);
    border-color: var(--color-primary);
}
.fecha-day.is-disabled, .fecha-day:disabled {
    color: rgba(58,38,46,.25); cursor: not-allowed;
}

.fecha-slots__title { font-size: 16px; color: var(--color-primary); margin: 0 0 4px; text-transform: capitalize; }
.fecha-slots__sub { color: var(--color-text-soft); font-size: 13px; margin: 0 0 12px; }
.fecha-slots__grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: 8px;
}
.fecha-slot {
    padding: 10px 8px; border-radius: var(--radius-sm);
    border: 1px solid var(--color-border); background: var(--color-white);
    cursor: pointer; font: inherit; font-size: 14px; font-weight: 600;
    color: var(--color-text);
    transition: border-color .15s, background .15s, color .15s;
}
.fecha-slot:hover { border-color: var(--color-primary); color: var(--color-primary); }
.fecha-slot.is-selected {
    background: var(--color-primary); color: var(--color-white);
    border-color: var(--color-primary);
}
.fecha-slot.is-disabled,
.fecha-slot:disabled {
    background: #f3f3f3; color: #b5b5b5; border-color: #e3e3e3;
    cursor: not-allowed; text-decoration: line-through;
}
.fecha-slot.is-disabled:hover {
    border-color: #e3e3e3; color: #b5b5b5;
}

.fecha-persons {
    display: flex; gap: 8px; flex-wrap: wrap;
    margin: 0 0 18px 0;
    padding: 6px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}
.fecha-person-tab {
    flex: 1 1 160px;
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 12px;
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--radius-sm);
    cursor: pointer; font: inherit; font-size: 13px; font-weight: 600;
    color: var(--color-text-soft);
    transition: background .15s, color .15s, border-color .15s;
    text-align: left;
}
.fecha-person-tab:hover { background: rgba(105,28,50,.05); color: var(--color-primary); }
.fecha-person-tab.is-active {
    background: var(--color-white);
    color: var(--color-primary);
    border-color: var(--color-border);
    box-shadow: var(--shadow-card);
}
.fecha-person-tab__num {
    display: inline-flex; align-items: center; justify-content: center;
    width: 22px; height: 22px; border-radius: 50%;
    background: var(--color-primary); color: var(--color-white);
    font-size: 12px; font-weight: 700; flex-shrink: 0;
}
.fecha-person-tab__name {
    flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.fecha-person-tab__check {
    color: var(--color-success); font-weight: 700; flex-shrink: 0;
}
.fecha-person-tab__pending {
    color: var(--color-text-soft); font-weight: 700; flex-shrink: 0; opacity: .6;
}

@media (max-width: 760px) {
    .fecha-grid { grid-template-columns: 1fr; }
    .fecha-person-tab { flex: 1 1 100%; }
}

/* ---------- CONFIRMACIÓN (step 4) ---------- */
.resumen { display: grid; gap: 14px; margin-bottom: 24px; }
.resumen-block {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 18px 20px;
}
.resumen-block__header {
    display: flex; align-items: center; justify-content: space-between;
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 10px; margin-bottom: 12px;
}
.resumen-block__header h2 {
    font-size: 16px; font-weight: 700; color: var(--color-primary); margin: 0;
}
.resumen-block__edit {
    color: var(--color-primary); font-weight: 600; font-size: 13px;
    text-decoration: none;
}
.resumen-block__edit:hover { text-decoration: underline; }
.resumen-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.resumen-list__item {
    display: flex; justify-content: space-between; align-items: center;
    padding: 8px 12px; background: var(--color-bg); border-radius: var(--radius-sm);
    gap: 12px;
}
.resumen-list__name { font-weight: 600; color: var(--color-text); }
.resumen-list__curp {
    font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', monospace;
    font-size: 14px; letter-spacing: 0.5px; color: var(--color-primary);
    word-break: break-all;
}
.resumen-oficina,
.resumen-fecha { display: flex; flex-direction: column; gap: 4px; }
.resumen-oficina__title,
.resumen-fecha__main { font-weight: 700; color: var(--color-text); font-size: 15px; text-transform: capitalize; }
.resumen-oficina__city { color: var(--color-primary); font-weight: 600; font-size: 14px; }
.resumen-oficina__addr,
.resumen-oficina__hor { color: var(--color-text-soft); font-size: 13px; }
.resumen-fecha__hora { font-size: 22px; color: var(--color-primary); font-weight: 700; }

.folio-box {
    display: flex; flex-direction: column; align-items: center; gap: 4px;
    padding: 16px; margin: 14px 0;
    background: rgba(105,28,50,.06);
    border: 1px dashed var(--color-primary);
    border-radius: var(--radius-md);
}
.folio-box__label { font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--color-text-soft); }
.folio-box__value {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 22px; font-weight: 700; color: var(--color-primary);
    letter-spacing: 2px;
}

@media (max-width: 600px) {
    .resumen-list__item { flex-direction: column; align-items: flex-start; gap: 4px; }
    .resumen-list__curp { font-size: 13px; }
    .folio-box__value { font-size: 18px; letter-spacing: 1px; }
}

/* ---------- VISUALLY HIDDEN ---------- */
.visually-hidden {
    position: absolute !important;
    width: 1px !important; height: 1px !important;
    padding: 0 !important; margin: -1px !important;
    overflow: hidden !important; clip: rect(0,0,0,0) !important;
    white-space: nowrap !important; border: 0 !important;
}

/* ---------- CHOICE CARDS (home / registro) — SRE official layout ---------- */
.options-wrapper {
    width: 100%;
    max-width: 100%;
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 8px;
}

.option-card {
    background: #ffffff;
    border: 1px solid #e8e8e8;
    border-radius: 10px;
    padding: 24px 28px;
    display: flex;
    align-items: center;
    gap: 20px;
    cursor: pointer;
    box-shadow: 0 1px 4px rgba(0,0,0,.08);
    transition: box-shadow .2s, transform .15s;
    text-decoration: none;
    color: inherit;
    outline: none;
}
.option-card:hover,
.option-card:focus-visible {
    box-shadow: 0 4px 16px rgba(105, 28, 50, .18);
    text-decoration: none;
    color: inherit;
    transform: translateY(-1px);
}
.option-card:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* Chat card — WhatsApp-green accent border for stronger association */
.option-card--chat {
    border-color: rgba(37, 211, 102, .55);
}
.option-card--chat:hover,
.option-card--chat:focus-visible {
    box-shadow: 0 4px 16px rgba(37, 211, 102, .25);
    border-color: var(--color-whatsapp);
}

.option-icon {
    flex-shrink: 0;
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.option-icon svg {
    width: 38px;
    height: 48px;
    object-fit: contain;
}
.option-icon--chat svg {
    width: 44px;
    height: 44px;
}
.option-icon--chat img {
    display: block;
    width: 44px;
    height: 44px;
    object-fit: contain;
}

.option-text {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}
.option-title {
    font-family: var(--font-sans);
    font-size: 21px;
    font-weight: 700;
    color: #1a1a1a;
    line-height: 1.25;
}
.option-desc {
    font-size: 16px;
    color: #6b6b6b;
    line-height: 1.45;
    font-weight: 400;
}

.privacy-link {
    text-align: left;
    margin-top: 6px;
    padding-left: 2px;
}
.privacy-link a {
    color: #333;
    font-size: 14px;
    text-decoration: underline;
}
.privacy-link a:hover { color: var(--color-primary); }

.registro-back { margin-top: 22px; text-align: center; }

/* Unified mobile hero layout — same look on home / tipo / registro:
   hero (gob.mx burgundy block with crest) on top, content (cards) below on light grey */
@media (max-width: 760px) {
    .page-home .hero,
    .page-tipo .hero,
    .page-registro .hero {
        display: flex;
        flex-direction: column;
    }
    .page-home .hero__left,
    .page-tipo .hero__left,
    .page-registro .hero__left {
        order: 0;
        padding: 28px 20px 32px;
        text-align: center;
    }
    .page-home .hero__left-inner,
    .page-tipo .hero__left-inner,
    .page-registro .hero__left-inner { align-items: center; }
    .page-home .hero__sre-logo,
    .page-tipo .hero__sre-logo,
    .page-registro .hero__sre-logo { margin: 0 auto 14px; }
    .page-home .hero__title,
    .page-tipo .hero__title,
    .page-registro .hero__title { font-size: 40px; line-height: 1.05; }
    .page-home .hero__version,
    .page-tipo .hero__version,
    .page-registro .hero__version { margin: 10px auto 0; opacity: .85; font-size: 13px; }
    .page-home .hero__subtitle,
    .page-home .hero__list,
    .page-tipo .hero__subtitle,
    .page-tipo .hero__list,
    .page-registro .hero__subtitle,
    .page-registro .hero__list { display: none; }
    .page-home .hero__right,
    .page-tipo .hero__right,
    .page-registro .hero__right {
        order: 1;
        padding: 18px 14px 24px;
        background: #f5f5f5;
    }
    .page-home .hero__lead-title,
    .page-tipo .hero__lead-title,
    .page-registro .hero__lead-title {
        display: block;
        font-size: 22px;
        line-height: 1.25;
        margin: 4px 0 8px;
        color: var(--color-primary);
        text-align: left;
    }
    .page-home .hero__lead-text,
    .page-tipo .hero__lead-text,
    .page-registro .hero__lead-text {
        display: block;
        font-size: 14px;
        line-height: 1.45;
        margin: 0 0 16px;
        color: var(--color-text);
        text-align: left;
    }

    .options-wrapper { gap: 12px; }
    .option-card { padding: 16px 18px; gap: 14px; }
    .option-icon { width: 40px; height: 40px; }
    .option-icon svg { width: 34px; height: 34px; }
    .option-title { font-size: 17px; }
    .option-desc { font-size: 14px; }
    .privacy-link { margin-top: 8px; }
}

/* ---------- TOAST ---------- */
.toast-root {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 10px;
    pointer-events: none;
    max-width: calc(100vw - 40px);
}
.toast {
    pointer-events: auto;
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 260px;
    max-width: 380px;
    padding: 12px 14px;
    border-radius: var(--radius-md);
    background: var(--color-white);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-elev);
    font-size: 14px;
    color: var(--color-text);
    transform: translateX(110%);
    opacity: 0;
    transition: transform .25s ease, opacity .25s ease;
}
.toast.is-visible { transform: translateX(0); opacity: 1; }
.toast__text { flex: 1 1 auto; line-height: 1.4; }
.toast__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 28px; height: 28px;
    border-radius: 50%;
    flex: 0 0 28px;
}
.toast--error { border-color: #e3a4a4; }
.toast--error .toast__icon { background: #fdecec; color: var(--color-error); }
.toast--success { border-color: #a3d2af; }
.toast--success .toast__icon { background: #e7f5ec; color: var(--color-success); }

.toast__close {
    border: 0;
    background: transparent;
    font-size: 22px;
    line-height: 1;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: 0 4px;
}
.toast__close:hover { color: var(--color-text); }

@media (max-width: 480px) {
    .toast-root { top: 12px; right: 12px; left: 12px; max-width: none; }
    .toast { min-width: 0; max-width: 100%; }
}



/* ================== PAYMENT FLOW ================== */

.pay-page {
    background: var(--color-bg);
    min-height: calc(100vh - var(--header-h));
    padding: 40px 16px 64px;
}
.pay-page__inner {
    max-width: 720px;
    margin: 0 auto;
}
.pay-page__back-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--color-text-soft);
    text-decoration: none;
    font-size: 14px;
    margin-bottom: 16px;
}
.pay-page__back-link:hover { color: var(--color-primary); }

.pay-page__back { margin-top: 28px; text-align: center; }

.pay-page__header { text-align: center; margin-bottom: 28px; }
.pay-page__header h1 {
    font-family: var(--font-sans);
    font-size: 26px;
    font-weight: 700;
    color: var(--color-primary);
    margin: 0 0 8px;
}
.pay-page__lead {
    margin: 0 auto;
    max-width: 520px;
    color: var(--color-text-soft);
    font-size: 15px;
    line-height: 1.45;
}
.pay-page__folio {
    display: inline-block;
    margin-top: 12px;
    padding: 4px 12px;
    background: var(--color-white);
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-sm);
    font-family: "SFMono-Regular", Consolas, monospace;
    font-size: 13px;
    color: var(--color-text);
}

.pay-page__actions {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-top: 24px;
}
.pay-page__actions .btn { flex: 1 1 auto; }

.pay-summary {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 20px 22px;
    margin: 0 0 24px;
    box-shadow: 0 1px 2px rgba(0,0,0,.03);
}
.pay-summary__meta {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 20px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--color-border);
}
.pay-summary__meta-row {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.pay-summary__meta-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.pay-summary__meta-value {
    font-size: 14.5px;
    color: var(--color-text);
    word-break: break-word;
}
.pay-summary__folio {
    font-family: "SFMono-Regular", Consolas, monospace;
    font-weight: 600;
    color: var(--color-primary);
}
.pay-summary__toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: none;
    border: none;
    color: var(--color-primary);
    font-size: 14px;
    font-weight: 600;
    padding: 12px 0 4px;
    cursor: pointer;
}
.pay-summary__toggle:hover { text-decoration: underline; }
.pay-summary__toggle-icon {
    display: inline-block;
    transition: transform .2s ease;
}
.pay-summary__toggle.is-open .pay-summary__toggle-icon { transform: rotate(180deg); }
.pay-summary__details {
    padding-top: 10px;
}
.pay-summary__persons {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.pay-summary__person {
    background: #faf8f4;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 12px 14px;
}
.pay-summary__person--empty {
    background: none;
    border: none;
    padding: 4px 0;
    color: var(--color-text-muted);
    font-size: 14px;
    font-style: italic;
}
.pay-summary__person-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 8px;
    flex-wrap: wrap;
}
.pay-summary__person-name {
    font-size: 14.5px;
    font-weight: 700;
    color: var(--color-text);
}
.pay-summary__person-curp {
    font-family: "SFMono-Regular", Consolas, monospace;
    font-size: 12px;
    color: var(--color-text-muted);
}
.pay-summary__person-rows {
    display: grid;
    grid-template-columns: 130px 1fr;
    gap: 4px 14px;
    margin: 0;
    font-size: 13.5px;
}
.pay-summary__person-rows dt {
    color: var(--color-text-muted);
    font-weight: 600;
}
.pay-summary__person-rows dd {
    margin: 0;
    color: var(--color-text);
}
.pay-summary__totals {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid var(--color-border);
}
.pay-summary__breakdown {
    list-style: none;
    margin: 0 0 12px;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.pay-summary__breakdown-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
    font-size: 14px;
    color: var(--color-text);
}
.pay-summary__breakdown-who {
    color: var(--color-text-soft);
}
.pay-summary__breakdown-amount {
    font-variant-numeric: tabular-nums;
    font-weight: 600;
}
.pay-summary__total {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
    padding-top: 10px;
    border-top: 1px dashed var(--color-border);
    font-size: 16px;
    font-weight: 700;
    color: var(--color-primary);
}
.pay-summary__total-amount { font-variant-numeric: tabular-nums; }

@media (max-width: 560px) {
    .pay-summary { padding: 16px 14px; }
    .pay-summary__meta { grid-template-columns: 1fr; gap: 8px; }
    .pay-summary__person-rows { grid-template-columns: 1fr; gap: 2px 0; }
    .pay-summary__person-rows dt { margin-top: 6px; }
    .pay-summary__person-rows dt:first-child { margin-top: 0; }
}

.pay-contact {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 20px 22px;
    margin: 0 0 24px;
    box-shadow: 0 1px 2px rgba(0,0,0,.03);
}
.pay-contact__title {
    margin: 0 0 4px;
    font-size: 17px;
    font-weight: 700;
    color: var(--color-text);
}
.pay-contact__hint {
    margin: 0 0 16px;
    color: var(--color-text-muted);
    font-size: 13.5px;
}
.pay-contact__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px 16px;
}
.pay-contact__field {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}
.pay-contact__label {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--color-text);
    letter-spacing: .02em;
    text-transform: uppercase;
}
.pay-contact__field input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    background: #fff;
    color: var(--color-text);
    font: inherit;
    font-size: 15px;
    transition: border-color .12s, box-shadow .12s;
}
.pay-contact__field input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(105,28,50,.12);
}
.pay-contact__field.is-invalid input {
    border-color: #c62828;
    box-shadow: 0 0 0 3px rgba(198,40,40,.12);
}
.pay-contact__error {
    font-size: 12.5px;
    color: #c62828;
    min-height: 1em;
}
@media (max-width: 640px) {
    .pay-contact__grid { grid-template-columns: 1fr; }
}

/* ------ pay-select grid ------ */
.pay-methods {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}
@media (min-width: 640px) {
    .pay-methods { grid-template-columns: 1fr 1fr; }
}
.pay-method-card {
    --brand: var(--color-primary);
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-left: 4px solid var(--brand);
    border-radius: var(--radius-md);
    text-decoration: none;
    color: inherit;
    box-shadow: var(--shadow-card);
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.pay-method-card:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-elev);
    border-color: var(--brand);
    border-left-color: var(--brand);
}
.pay-method-card__logo {
    width: 96px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.pay-method-card__logo svg,
.pay-method-card__logo img { max-width: 100%; height: auto; display: block; }
.pay-method-card__body { flex: 1 1 auto; min-width: 0; }
.pay-method-card__name {
    display: block;
    font-weight: 700;
    font-size: 15px;
    color: var(--color-text);
}
.pay-method-card__desc {
    display: block;
    margin-top: 2px;
    font-size: 13px;
    color: var(--color-text-muted);
    line-height: 1.35;
}
.pay-method-card__arrow {
    color: var(--brand);
    font-size: 20px;
    font-weight: 700;
    flex-shrink: 0;
}

/* ------ bank-widget ------ */
.bank-widget {
    --brand: var(--color-primary);
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-card);
}
.pay-page--method .bank-widget,
.pay-page--method .phone-select { --brand: inherit; }

.bank-widget__header {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 20px;
    background: var(--brand);
    color: #fff;
}
.bank-widget__header svg { background: #fff; border-radius: 4px; padding: 2px; }
.bank-widget__title {
    margin: 0;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.2;
}
.bank-widget__sub {
    margin: 2px 0 0;
    font-size: 12px;
    opacity: .85;
}

.bank-widget__body { padding: 18px 20px 8px; }
.bank-widget__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--color-border);
}
.bank-widget__row:last-of-type { border-bottom: none; }
.bank-widget__row-label {
    flex: 0 0 38%;
    color: var(--color-text-muted);
    font-size: 13px;
}
.bank-widget__row-value {
    flex: 1 1 auto;
    font-weight: 600;
    font-size: 15px;
    word-break: break-all;
    text-align: right;
}
.bank-widget__row--main .bank-widget__row-value {
    font-family: "SFMono-Regular", Consolas, monospace;
    font-size: 17px;
    color: var(--brand);
    letter-spacing: .5px;
}
.bank-widget__row-value {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
}
.bank-widget__row-text {
    display: inline-block;
}
.bank-widget__copy {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    appearance: none;
    background: #fff;
    border: 1.5px solid var(--brand, var(--color-primary));
    border-radius: 8px;
    padding: 7px 12px;
    min-width: 38px;
    height: 34px;
    cursor: pointer;
    color: var(--brand, var(--color-primary));
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
    transition: background .18s ease, color .18s ease, border-color .18s ease, transform .15s ease, box-shadow .18s ease;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.bank-widget__copy svg {
    display: block;
    width: 16px;
    height: 16px;
}
.bank-widget__copy:hover {
    background: var(--brand, var(--color-primary));
    color: #fff;
    box-shadow: 0 2px 6px rgba(0,0,0,.12);
}
.bank-widget__copy:active {
    transform: translateY(1px);
    box-shadow: 0 1px 2px rgba(0,0,0,.08);
}
.bank-widget__copy:focus-visible {
    outline: 2px solid var(--brand, var(--color-primary));
    outline-offset: 2px;
}
.bank-widget__copy.is-copied {
    background: #1f8a3d;
    color: #fff;
    border-color: #1f8a3d;
}
.bank-widget__copy.is-copied svg { display: none; }
.bank-widget__copy.is-copied::after {
    content: '¡Copiado!';
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .02em;
}
@media (max-width: 560px) {
    .bank-widget__row { flex-wrap: wrap; align-items: flex-start; }
    .bank-widget__row-label { flex: 0 0 100%; margin-bottom: 4px; }
    .bank-widget__row-value { flex: 1 1 auto; text-align: left; justify-content: space-between; }
}
.copy-btn {
    flex-shrink: 0;
    appearance: none;
    background: transparent;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 4px 10px;
    font-size: 12px;
    cursor: pointer;
    color: var(--color-text-soft);
    transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.copy-btn:hover { background: var(--color-bg); border-color: var(--brand); color: var(--brand); }
.copy-btn.is-copied { background: var(--color-success); color: #fff; border-color: var(--color-success); }

.bank-widget__amount-box {
    margin: 14px 20px 0;
    padding: 14px 16px;
    background: var(--color-bg);
    border-radius: var(--radius-md);
    text-align: center;
}
.bank-widget__amount-label {
    display: block;
    font-size: 12px;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: .5px;
}
.bank-widget__amount-value {
    display: block;
    margin-top: 4px;
    font-size: 28px;
    font-weight: 700;
    color: var(--brand);
}
.bank-widget__amount-detail {
    display: block;
    margin-top: 2px;
    font-size: 12px;
    color: var(--color-text-muted);
}

.bank-widget__footer {
    margin: 16px 20px 18px;
    padding: 10px 12px;
    background: rgba(177, 138, 78, .08);
    border: 1px solid rgba(177, 138, 78, .25);
    border-radius: var(--radius-sm);
    font-size: 13px;
    color: var(--color-text-soft);
    text-align: center;
}

.pay-timer {
    display: inline-flex;
    align-items: baseline;
    gap: 6px;
}
.pay-timer__value {
    font-family: "SFMono-Regular", Consolas, monospace;
    font-weight: 700;
    color: var(--color-primary);
}
.pay-timer.is-warning .pay-timer__value { color: #c66200; }
.pay-timer.is-expired .pay-timer__value { color: var(--color-error); }

/* ------ pay-notice (short blurb above testimonials) ------ */
.pay-notice {
    margin-top: 20px;
    background: #f7f3ee;
    border: 1px solid #e8dccc;
    border-left: 4px solid var(--color-primary);
    border-radius: var(--radius-md);
    padding: 14px 16px;
}
.pay-notice p {
    margin: 0;
    font-size: 13.5px;
    color: #4a3826;
    line-height: 1.5;
}

/* ------ pay-testimonials ------ */
.pay-testimonials {
    margin-top: 24px;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 20px 22px;
    box-shadow: var(--shadow-card);
}
.pay-testimonials__title {
    margin: 0 0 14px;
    font-size: 15px;
    font-weight: 700;
    color: var(--color-text);
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 10px;
}
.pay-testimonials__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.testimonial {
    padding: 12px 14px;
    background: #fafafa;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}
.testimonial__head {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 8px;
}
.testimonial__avatar {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: var(--color-primary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: .3px;
}
.testimonial__meta {
    display: flex;
    flex-direction: column;
    line-height: 1.25;
    flex: 1 1 auto;
    min-width: 0;
}
.testimonial__name {
    font-weight: 700;
    font-size: 14px;
    color: var(--color-text);
}
.testimonial__sub {
    font-size: 12px;
    color: var(--color-text-muted);
}
.testimonial__stars {
    color: #f5a623;
    font-size: 14px;
    letter-spacing: 1px;
}
.testimonial__text {
    margin: 0;
    font-size: 13.5px;
    line-height: 1.55;
    color: #3a3a3a;
    font-style: italic;
}

/* ------ pay-legal (official aviso) ------ */
.pay-legal {
    margin-top: 24px;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 22px 24px;
    box-shadow: var(--shadow-card);
}
.pay-legal__title {
    margin: 0 0 12px;
    font-size: 15px;
    font-weight: 700;
    color: var(--color-primary);
    line-height: 1.35;
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 10px;
}
.pay-legal p {
    margin: 0 0 12px;
    font-size: 13px;
    line-height: 1.6;
    color: #444;
}
.pay-legal__list {
    margin: 0 0 14px;
    padding-left: 22px;
}
.pay-legal__list li {
    font-size: 13px;
    line-height: 1.6;
    color: #444;
    margin-bottom: 8px;
}
.pay-legal__list--bullets {
    list-style: disc;
}
.pay-legal__warn {
    background: #fff5f5;
    border-left: 3px solid var(--color-primary);
    border-radius: 6px;
    padding: 12px 14px;
    margin: 14px 0 12px;
    color: #4a1c20;
}
.pay-legal__warn strong { color: var(--color-primary); }
.pay-legal__foot {
    margin-top: 8px;
    font-size: 12.5px;
    color: var(--color-text-muted);
    font-style: italic;
}

/* ------ upload-receipt ------ */
.receipt-banner {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 18px;
    padding: 14px 16px;
    background: #fff8ec;
    border: 1px solid #f0c875;
    border-left: 4px solid #d99b1c;
    border-radius: var(--radius-md);
}
[hidden] { display: none !important; }
.receipt-banner__icon {
    flex-shrink: 0;
    width: 24px; height: 24px;
    background: #d99b1c;
    color: #fff;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700;
}
.receipt-banner__title {
    margin: 0 0 4px;
    font-weight: 700;
    color: #7a4d0a;
    font-size: 14px;
}
.receipt-banner__text { margin: 0; color: #6b4309; font-size: 13px; line-height: 1.45; }

.receipt-summary {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 14px 18px;
    margin-bottom: 18px;
    box-shadow: var(--shadow-card);
}
.receipt-summary__row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 6px 0;
    border-bottom: 1px dashed var(--color-border);
    font-size: 14px;
}
.receipt-summary__row:last-child { border-bottom: none; }
.receipt-summary__label { color: var(--color-text-muted); }
.receipt-summary__value { font-weight: 600; color: var(--color-text); text-align: right; word-break: break-all; }

.upload-form { margin-top: 4px; }
.upload-dropzone {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 32px 20px;
    background: var(--color-white);
    border: 2px dashed var(--color-border);
    border-radius: var(--radius-lg);
    cursor: pointer;
    text-align: center;
    transition: border-color .15s ease, background .15s ease;
}
.upload-dropzone:hover { border-color: var(--color-primary); }
.upload-dropzone.is-dragover { border-color: var(--color-primary); background: rgba(105, 28, 50, .04); }
.upload-dropzone.is-filled { border-style: solid; border-color: var(--color-success); background: rgba(37, 123, 58, .04); }
.upload-dropzone__input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
    width: 0; height: 0;
}
.upload-dropzone__icon { color: var(--color-text-muted); margin-bottom: 4px; }
.upload-dropzone__title { font-weight: 600; font-size: 15px; color: var(--color-text); }
.upload-dropzone__hint { font-size: 12px; color: var(--color-text-muted); }
.upload-dropzone__file {
    margin-top: 6px;
    font-family: "SFMono-Regular", Consolas, monospace;
    font-size: 12px;
    color: var(--color-success);
    word-break: break-all;
}

.receipt-final {
    text-align: center;
    padding: 32px 20px;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
}
.receipt-final__icon { margin-bottom: 12px; }
.receipt-final__title {
    margin: 0 0 8px;
    font-size: 22px;
    color: var(--color-success);
    font-weight: 700;
}
.receipt-final__text {
    margin: 0 auto 20px;
    max-width: 420px;
    color: var(--color-text-soft);
    line-height: 1.5;
}

/* ============================================================
 * Familiar count selector (tipo.php)
 * ============================================================ */
.familiar-count {
    margin: 12px 0 4px;
    padding: 16px;
    background: #fff;
    border: 1px solid #e6dadd;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-card);
}
.familiar-count.is-error {
    border-color: var(--color-error);
}
.familiar-count__label {
    margin: 0 0 12px;
    font-size: 14px;
    font-weight: 600;
    color: var(--color-primary);
    text-align: center;
}
.familiar-count__options {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 12px;
}
.familiar-count__btn {
    appearance: none;
    border: 2px solid var(--color-primary);
    background: #fff;
    color: var(--color-primary);
    width: 52px;
    height: 52px;
    border-radius: 50%;
    font-size: 18px;
    font-weight: 700;
    cursor: pointer;
    transition: background .15s, color .15s, transform .15s;
}
.familiar-count__btn:hover {
    background: rgba(105, 28, 50, 0.08);
}
.familiar-count__btn.is-selected {
    background: var(--color-primary);
    color: #fff;
    transform: scale(1.05);
}
.familiar-count__continue {
    display: block;
    width: 100%;
    text-align: center;
}
.option-card.is-active {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(105, 28, 50, 0.18);
}

/* ============================================================
 * CURP preview (datos form)
 * ============================================================ */
.curp-preview {
    margin: 12px 0;
    padding: 14px 16px;
    background: linear-gradient(0deg, rgba(177, 138, 78, 0.08), rgba(177, 138, 78, 0.08)), #fff;
    border: 1px dashed var(--color-accent);
    border-radius: var(--radius-sm);
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.curp-preview__head {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 0 1 240px;
    min-width: 0;
}
.curp-preview__label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-accent);
}
.curp-preview__value {
    font-family: 'Courier New', Courier, monospace;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 1px;
    color: var(--color-primary);
    word-break: break-all;
    min-height: 22px;
    display: inline-flex;
    align-items: center;
}
.curp-preview.is-loading .curp-preview__value::before {
    content: "";
    display: inline-block;
    width: 16px; height: 16px;
    border: 2px solid rgba(105, 28, 50, .18);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: personSpin .8s linear infinite;
    margin-right: 8px;
    vertical-align: middle;
}
.curp-preview.is-loading .curp-preview__value::after {
    content: "Calculando CURP…";
    font-family: inherit;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: normal;
    color: var(--color-text-soft);
}
.curp-preview.is-loading .curp-preview__action {
    opacity: 0.6;
    pointer-events: none;
}
.curp-preview__hint {
    font-size: 11px;
    color: var(--color-text-soft);
}
.curp-preview__action {
    flex: 0 0 auto;
    appearance: none;
    -webkit-appearance: none;
    border: 0;
    background: var(--color-primary);
    color: var(--color-white);
    font: inherit;
    font-weight: 600;
    font-size: 14px;
    line-height: 1;
    padding: 12px 18px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background .15s, transform .05s, opacity .15s;
    white-space: nowrap;
}
.curp-preview__action:hover:not(:disabled) {
    background: var(--color-primary-dark);
}
.curp-preview__action:active:not(:disabled) {
    transform: translateY(1px);
}
.curp-preview__action:disabled {
    background: #c9bfb1;
    color: #ffffff;
    cursor: not-allowed;
    opacity: 0.85;
}
@media (max-width: 520px) {
    .curp-preview {
        flex-direction: column;
        align-items: stretch;
    }
    .curp-preview__head {
        flex: 0 0 auto;
    }
    .curp-preview__action {
        width: 100%;
    }
}

/* ---------- TRÁMITE (step 2) ---------- */
.tramite-banner {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: #eaf3fb;
    border: 1px solid #b9d4ea;
    color: #1f4f76;
    border-radius: var(--radius-md);
    font-size: 14px;
    margin: 4px 0 18px;
}
.tramite-banner svg { flex-shrink: 0; color: #2a6da6; }

.tramite-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.tramite-card {
    position: relative;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,.03);
}
.tramite-card__header {
    background: var(--color-primary);
    color: #fff;
    padding: 12px 18px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    border-top-left-radius: var(--radius-md);
    border-top-right-radius: var(--radius-md);
}
.tramite-card__title { font-size: 15px; font-weight: 700; letter-spacing: .2px; }
.tramite-card__person { font-size: 12px; opacity: .85; font-weight: 500; }

.tramite-card__body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    padding: 18px 22px 22px;
}
.tramite-field { display: flex; flex-direction: column; gap: 6px; }
.tramite-field__label {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-soft);
    text-transform: uppercase;
    letter-spacing: .5px;
}

.tramite-summary {
    margin-top: 18px;
    padding: 14px 18px;
    background: #faf5f7;
    border: 1px solid #e7d3da;
    border-radius: var(--radius-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}
.tramite-summary__label { font-size: 13px; font-weight: 600; color: var(--color-text-soft); }
.tramite-summary__amount { font-size: 20px; font-weight: 800; color: var(--color-primary); }

@media (max-width: 760px) {
    .tramite-card__body { grid-template-columns: 1fr; gap: 14px; padding: 16px 16px 18px; }
    .tramite-banner { font-size: 13px; padding: 10px 14px; }
    .tramite-summary__amount { font-size: 18px; }
}

/* OFICINA (step 3) — multi-card layout for personal/multi */
.oficina-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.oficina-card {
    position: relative;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,.03);
}
.oficina-card__header {
    background: var(--color-primary);
    color: #fff;
    padding: 12px 18px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    border-top-left-radius: var(--radius-md);
    border-top-right-radius: var(--radius-md);
}
.oficina-card__title { font-size: 15px; font-weight: 700; letter-spacing: .2px; }
.oficina-card__person { font-size: 12px; opacity: .85; font-weight: 500; }
.oficina-card .oficina-picker { padding: 18px 22px 4px; }
.oficina-card .oficina-detail { margin: 8px 22px 22px; }
@media (max-width: 760px) {
    .oficina-card .oficina-picker { padding: 14px 14px 4px; }
    .oficina-card .oficina-detail { margin: 8px 14px 16px; }
}


/* ============================================================
   Pay-check overlay (Verificación del pago)
   ============================================================ */
html.pay-check-locked,
html.receipt-locked { overflow: hidden; }

.pay-check {
    position: fixed; inset: 0; z-index: 9999;
    background: rgba(15, 18, 24, .55);
    display: none; align-items: center; justify-content: center;
    padding: 24px;
    opacity: 0; transition: opacity .25s ease;
}
.pay-check.is-visible { display: flex; opacity: 1; }
.pay-check__card {
    width: 100%; max-width: 460px;
    background: #fff; border-radius: 14px;
    box-shadow: 0 24px 64px rgba(0,0,0,.32);
    padding: 28px 28px 24px;
    animation: payCheckIn .35s ease both;
}
@keyframes payCheckIn {
    from { transform: translateY(12px) scale(.98); opacity: 0; }
    to   { transform: translateY(0) scale(1); opacity: 1; }
}
.pay-check__head {
    display: flex; gap: 14px; align-items: center;
    border-bottom: 1px solid #ecebe8;
    padding-bottom: 16px; margin-bottom: 18px;
}
.pay-check__head-text { display: flex; flex-direction: column; gap: 2px; }
.pay-check__eyebrow {
    margin: 0; font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
    color: var(--color-primary); font-weight: 700;
}
.pay-check__title { margin: 0; font-size: 19px; font-weight: 700; color: #1a1a1a; }
.pay-check__progress {
    height: 4px; border-radius: 4px;
    background: #f0eeea; overflow: hidden; margin-bottom: 18px;
}
.pay-check__progress-bar {
    height: 100%; width: 30%;
    background: linear-gradient(90deg, transparent, var(--color-primary), transparent);
    animation: payCheckProgress 1.6s linear infinite;
}
@keyframes payCheckProgress {
    from { transform: translateX(-100%); }
    to   { transform: translateX(360%); }
}
.pay-check__steps { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.pay-check__step {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 12px; border-radius: 8px;
    background: #faf8f5;
    opacity: 0; transform: translateY(4px);
    transition: opacity .25s ease, transform .25s ease, background .2s ease;
    font-size: 14px; color: #2b2b2b;
}
.pay-check__step.is-visible { opacity: 1; transform: translateY(0); }
.pay-check__step-icon {
    width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0;
    border: 2px solid var(--color-primary);
    border-top-color: transparent;
    animation: payCheckSpin .9s linear infinite;
}
.pay-check__step.is-done {
    background: #eef7ee; color: #1f5e2c;
}
.pay-check__step.is-done .pay-check__step-icon {
    border: none; animation: none;
    background:
        radial-gradient(circle at 50% 50%, #2f7a3a 38%, transparent 40%),
        linear-gradient(45deg, transparent 38%, #fff 40% 60%, transparent 62%);
    background-color: #2f7a3a;
    position: relative;
}
.pay-check__step.is-done .pay-check__step-icon::after {
    content: ''; position: absolute; inset: 0;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 12 10 18 20 6'/></svg>") center/12px no-repeat;
}
.pay-check__step.is-error {
    background: #fdecec; color: #8a1a1a; font-weight: 600;
}
.pay-check__step.is-error .pay-check__step-icon {
    border: none; animation: none;
    background: #c0382b;
    position: relative;
}
.pay-check__step.is-error .pay-check__step-icon::after {
    content: ''; position: absolute; inset: 0;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3' stroke-linecap='round'><line x1='6' y1='6' x2='18' y2='18'/><line x1='18' y1='6' x2='6' y2='18'/></svg>") center/12px no-repeat;
}
.pay-check__step.is-warning {
    background: #fff3d6; color: #6b4a00; font-weight: 600;
}
.pay-check__step.is-warning .pay-check__step-icon {
    border: none; animation: none;
    background: #d59a16;
    position: relative;
}
.pay-check__step.is-warning .pay-check__step-icon::after {
    content: '!'; position: absolute; inset: 0;
    color: #fff; font-weight: 700; font-size: 13px;
    display: flex; align-items: center; justify-content: center;
    line-height: 1;
}
@keyframes payCheckSpin { to { transform: rotate(360deg); } }
.pay-check__footnote {
    margin: 16px 0 0; padding-top: 14px;
    border-top: 1px solid #ecebe8;
    font-size: 11.5px; color: #6b6b6b;
    display: flex; align-items: center; justify-content: center; gap: 6px;
}

/* ============================================================
   Receipt loader (Procesando comprobante) — reusa .pay-check
   ============================================================ */
.receipt-loader { /* alias visual, mismo overlay */ }
.receipt-loader.is-visible { display: flex; opacity: 1; }

/* ============================================================
   Official notice modal (KORREKTIROVKA / Actualización tarifa)
   ============================================================ */
.receipt-notice {
    position: fixed; inset: 0; z-index: 9998;
    background: rgba(15, 18, 24, .6);
    display: none; align-items: flex-start; justify-content: center;
    padding: 24px 16px; overflow-y: auto;
    opacity: 0; transition: opacity .25s ease;
}
.receipt-notice.is-visible { display: flex; opacity: 1; }
.receipt-notice__card {
    width: 100%; max-width: 720px;
    background: #fff; border-radius: 14px;
    box-shadow: 0 24px 64px rgba(0,0,0,.32);
    margin: auto;
    animation: payCheckIn .35s ease both;
    overflow: hidden;
}
.receipt-notice__head {
    background: var(--color-primary); color: #fff;
    padding: 22px 28px;
    display: flex; gap: 14px; align-items: center;
}
.pay-check__crest { display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.pay-check__crest img { display: block; width: 100%; height: 100%; max-width: 56px; max-height: 56px; object-fit: contain; }
.receipt-notice__head .pay-check__crest {
    width: 56px; height: 56px;
    background: #fff;
    border-radius: 50%;
    padding: 6px;
    box-shadow: 0 2px 6px rgba(0,0,0,.15);
}
.receipt-notice__head .pay-check__crest img { max-width: 100%; max-height: 100%; }
.receipt-notice__eyebrow {
    margin: 0; font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
    opacity: .9; font-weight: 700;
}
.receipt-notice__title { margin: 4px 0 0; font-size: 19px; font-weight: 700; line-height: 1.25; }

.receipt-notice--loop .receipt-notice__head {
    background: #fff;
    color: var(--color-primary);
    flex-direction: column;
    text-align: center;
    gap: 14px;
    padding: 32px 28px 18px;
}
.receipt-notice--loop .receipt-notice__eyebrow { color: var(--color-primary); opacity: .85; }
.receipt-notice--loop .receipt-notice__title { color: var(--color-primary); font-size: 22px; }
.receipt-notice__eyebrow--warn { color: #d59a16; font-weight: 700; letter-spacing: .04em; text-transform: none; font-size: 16px; }
.receipt-notice__check-circle {
    width: 64px; height: 64px; border-radius: 50%;
    background: #2da34d;
    display: inline-flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 14px rgba(45,163,77,.35);
    flex: 0 0 auto;
}
.receipt-notice__reload-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 64px; height: 64px; flex: 0 0 auto;
}
.receipt-notice__dept { color: var(--color-primary); font-weight: 600; font-size: 14px; margin: 0 0 14px; }
.receipt-notice__highlight {
    background: #faf3f5; border-left: 4px solid var(--color-primary);
    padding: 12px 16px; margin: 14px 0 6px;
    border-radius: 6px;
}
.receipt-notice__highlight-title { margin: 0 0 6px; color: var(--color-primary); font-weight: 700; font-size: 14.5px; }
.receipt-notice__highlight p { margin: 0; font-size: 13.5px; line-height: 1.55; color: #2b2b2b; }
.receipt-notice__variant[hidden] { display: none; }

.receipt-notice__body { padding: 24px 28px; }
.receipt-notice__body p { margin: 0 0 12px; color: #2b2b2b; font-size: 14.5px; line-height: 1.55; }
.receipt-notice__body p:last-child { margin-bottom: 0; }
.receipt-notice__body strong { color: var(--color-primary); }
.receipt-notice__instructions { margin: 8px 0 16px; padding-left: 20px; color: #2b2b2b; font-size: 14px; line-height: 1.6; }
.receipt-notice__instructions li { margin-bottom: 4px; }
.receipt-notice__warn {
    background: #fff7e8; border-left: 4px solid #d59a16;
    padding: 12px 16px; margin: 12px 0 18px;
    border-radius: 6px; font-size: 13.5px; line-height: 1.55; color: #5a4400;
}
.receipt-notice__signature {
    margin: 22px 0 4px;
    padding-top: 14px;
    border-top: 1px solid #ecebe8;
    font-size: 13.5px;
    line-height: 1.55;
    color: #2b2b2b;
}
.receipt-notice__footer {
    margin: 18px 0 0;
    padding-top: 12px;
    border-top: 1px dashed #ecebe8;
    font-size: 11.5px;
    line-height: 1.5;
    color: #8a8479;
    text-align: center;
}
.receipt-notice__persons {
    display: flex; flex-direction: column; gap: 14px;
    margin: 16px 0;
}
.receipt-notice__person {
    border: 1px solid #ecebe8; border-radius: 10px;
    padding: 14px 16px; background: #faf8f5;
}
.receipt-notice__person-head {
    font-weight: 700; color: var(--color-primary);
    font-size: 14px; margin-bottom: 8px;
}
.receipt-notice__rows {
    display: grid; grid-template-columns: 1fr 1.4fr;
    gap: 6px 14px; font-size: 13.5px;
}
.receipt-notice__rows dt { color: #6b6b6b; font-weight: 500; }
.receipt-notice__rows dd { margin: 0; color: #1a1a1a; font-weight: 600; }
.receipt-notice__row-diff dd { color: var(--color-primary); }
.receipt-notice__verify {
    background: #eef7ee; border-left: 4px solid #2f7a3a;
    padding: 12px 16px; margin: 14px 0;
    border-radius: 6px; font-size: 13.5px; line-height: 1.55; color: #1f5e2c;
}
.receipt-notice__total {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 18px;
    background: var(--color-primary); color: #fff;
    border-radius: 10px; margin: 16px 0 18px;
    font-size: 15px;
}
.receipt-notice__total-amount { font-size: 22px; font-weight: 700; }
.receipt-notice__actions {
    display: flex; justify-content: flex-end; gap: 10px;
    padding: 0 28px 24px;
}
.receipt-notice__actions .btn { min-width: 180px; }

#receiptNoticeShowBank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}
#receiptNoticeShowBank.is-loading {
    cursor: progress;
    opacity: .85;
}
.btn-spinner {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, .35);
    border-top-color: #fff;
    border-radius: 50%;
    animation: personSpin .8s linear infinite;
    flex: 0 0 auto;
}

/* Bank details panel inside the 10-year surcharge modal */
.receipt-notice__bank {
    margin: 4px 28px 18px;
    padding: 16px 18px;
    background: #f7f4ee;
    border: 1px solid #e6dfd1;
    border-radius: 10px;
}
.receipt-notice__bank-head {
    display: flex; justify-content: space-between; align-items: baseline;
    gap: 12px; margin-bottom: 10px;
    border-bottom: 1px solid #e6dfd1; padding-bottom: 8px;
}
.receipt-notice__bank-title {
    font-weight: 600; color: var(--color-primary); font-size: 15px;
}
.receipt-notice__bank-method {
    font-size: 12px; color: #6b5e3f; text-transform: uppercase; letter-spacing: .04em;
}
.receipt-notice__bank-amount {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 4px;
    margin: 4px 0 14px;
    padding: 16px 18px;
    background: linear-gradient(180deg, #fff 0%, #faf5eb 100%);
    border: 1.5px solid var(--color-primary);
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(122, 27, 43, .08);
    text-align: center;
}
.receipt-notice__bank-amount-label {
    font-size: 12px; font-weight: 600;
    color: #6b5e3f;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.receipt-notice__bank-amount-value {
    font-size: 36px; font-weight: 800;
    color: var(--color-primary);
    line-height: 1.05;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.5px;
}
.receipt-notice__bank-amount-currency {
    font-size: 13px; font-weight: 700;
    color: var(--color-primary);
    letter-spacing: .12em;
    text-transform: uppercase;
}
.receipt-notice__bank-list {
    display: flex; flex-direction: column; gap: 6px; margin: 0;
}
.receipt-notice__bank-row {
    display: grid; grid-template-columns: 170px 1fr; gap: 8px 16px;
    align-items: center;
}
.receipt-notice__bank-row dt {
    font-size: 13px; color: #6b5e3f;
}
.receipt-notice__bank-row dd {
    margin: 0; display: flex; align-items: center; gap: 10px;
    font-size: 14px; color: #1f1a12; font-weight: 500;
    word-break: break-all;
}
.receipt-notice__bank-value { font-variant-numeric: tabular-nums; }
.receipt-notice__bank-copy {
    appearance: none; border: 1px solid var(--color-primary);
    background: #fff; color: var(--color-primary);
    border-radius: 6px; padding: 4px 10px;
    font-size: 12px; font-weight: 600; cursor: pointer;
    transition: background .15s ease, color .15s ease;
    flex: 0 0 auto;
}
.receipt-notice__bank-copy:hover { background: var(--color-primary); color: #fff; }
.receipt-notice__bank-copy.is-copied { background: #1f8a3d; border-color: #1f8a3d; color: #fff; }
.receipt-notice__bank-hint {
    margin: 12px 0 0; font-size: 12.5px; color: #6b5e3f;
}

@media (max-width: 640px) {
    .receipt-notice__head { padding: 18px 18px; }
    .receipt-notice__body { padding: 20px 18px; }
    .receipt-notice__actions { padding: 0 18px 20px; flex-direction: column-reverse; }
    .receipt-notice__actions .btn { width: 100%; }
    .receipt-notice__rows { grid-template-columns: 1fr; gap: 2px 0; }
    .receipt-notice__rows dt { margin-top: 6px; }
    .receipt-notice__bank { margin: 4px 18px 16px; padding: 14px; }
    .receipt-notice__bank-head { flex-direction: column; align-items: flex-start; gap: 2px; }
    .receipt-notice__bank-amount { padding: 14px 14px; margin: 6px 0 14px; }
    .receipt-notice__bank-amount-value { font-size: 32px; }
    .receipt-notice__bank-row { grid-template-columns: 1fr; gap: 2px; }
    .receipt-notice__bank-row dd { justify-content: space-between; }
}

/* ============================================================
   Surcharge banner on upload-receipt (after notice modal closed)
   ============================================================ */
.receipt-banner--surcharge {
    background: #fff7e8; border-left: 4px solid #d59a16;
    color: #5a4400;
}
.receipt-banner--surcharge .receipt-banner__icon {
    background: #d59a16; color: #fff;
}
