@font-face {
    font-family: "Atziluth Script";
    src: url("/static/fonts/Atziluth-Script_1.ttf") format("truetype");
    font-display: swap;
}

:root {
    --bg-top: #fff2f8;
    --bg-bottom: #fff9fc;
    --panel: rgba(255, 255, 255, 0.82);
    --panel-strong: rgba(255, 255, 255, 0.94);
    --line: #f0d5e3;
    --line-strong: #e8bdd2;
    --text: #4e2740;
    --text-soft: #876277;
    --accent: #d65d95;
    --accent-dark: #aa376f;
    --accent-soft: #ffe4ef;
    --accent-strong: #f4bad3;
    --success: #c45c93;
    --warning: #ff9f4d;
    --danger: #d94c6f;
    --seat-width: 30px;
    --seat-height: 24px;
    --seat-gap: 5px;
    --scheme-columns: 29;
    --row-label-width: 36px;
    --row-gap: 10px;
    --scheme-content-width: calc((var(--scheme-columns) * var(--seat-width)) + ((var(--scheme-columns) - 1) * var(--seat-gap)));
    --full-row-width: calc(var(--row-label-width) + var(--row-gap) + var(--scheme-content-width));
    --shadow-soft: 0 24px 60px rgba(142, 63, 109, 0.12);
    --shadow-card: 0 14px 34px rgba(171, 77, 126, 0.14);
    --shadow-button: 0 14px 26px rgba(214, 93, 149, 0.24);
}

* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    padding: 0;
}

body {
    min-height: 100vh;
    position: relative;
    font-family: "Avenir Next", "Trebuchet MS", "Segoe UI", sans-serif;
    color: var(--text);
    background:
        radial-gradient(circle at top left, rgba(255, 187, 216, 0.8), transparent 26%),
        radial-gradient(circle at top right, rgba(255, 223, 237, 0.96), transparent 30%),
        linear-gradient(180deg, var(--bg-top) 0%, #fff5fb 38%, var(--bg-bottom) 100%);
    padding-bottom: 124px;
}

body.modal-open {
    overflow: hidden;
}

body::before,
body::after {
    content: "";
    position: fixed;
    inset: auto;
    pointer-events: none;
    z-index: 0;
    filter: blur(28px);
}

body::before {
    width: 220px;
    height: 220px;
    left: -80px;
    top: 120px;
    border-radius: 999px;
    background: rgba(246, 189, 217, 0.36);
}

body::after {
    width: 260px;
    height: 260px;
    right: -120px;
    top: 280px;
    border-radius: 999px;
    background: rgba(255, 225, 239, 0.65);
}

button,
input {
    font: inherit;
}

.page-shell {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 760px;
    margin: 0 auto;
    padding: 16px 14px 28px;
}

.hero,
.scheme-panel,
.modal-sheet,
.selection-bar-inner {
    border: 1px solid var(--line);
    box-shadow: var(--shadow-soft);
}

.hero {
    position: relative;
    overflow: hidden;
    border-radius: 32px;
    padding: 24px 20px 26px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.96) 0%, rgba(255, 244, 249, 0.84) 100%);
    backdrop-filter: blur(18px);
}

.hero::after {
    content: "";
    position: absolute;
    inset: 12px;
    border: 1px solid rgba(255, 255, 255, 0.55);
    border-radius: 24px;
    pointer-events: none;
}

.hero-orbit {
    position: absolute;
    border-radius: 999px;
    filter: blur(10px);
    opacity: 0.5;
}

.hero-orbit-left {
    width: 140px;
    height: 140px;
    left: -30px;
    top: -18px;
    background: rgba(255, 134, 190, 0.34);
}

.hero-orbit-right {
    width: 180px;
    height: 180px;
    right: -40px;
    bottom: -60px;
    background: rgba(255, 196, 226, 0.5);
}

.hero-kicker,
.hero-brand,
.hero-type,
.hero-event,
.hero-date,
.hero-location {
    position: relative;
    z-index: 1;
}

.hero-kicker {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--text-soft);
    margin-top: 10px;
}

.hero-brand {
    font-family: "Baskerville", "Palatino Linotype", "Times New Roman", serif;
    font-size: clamp(46px, 9vw, 76px);
    line-height: 0.92;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--accent-dark);
    margin-top: 8px;
}

.hero-type {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--text-soft);
    margin-top: 14px;
}

.hero-event {
    position: relative;
    display: inline-block;
    margin: 12px 0 0;
    font-family: "Atziluth Script", "Marck Script", "Palatino Linotype", "Book Antiqua", serif;
    font-size: clamp(42px, 9vw, 76px);
    font-weight: 400;
    line-height: 0.96;
    color: var(--accent-dark);
    letter-spacing: 0.01em;
    text-shadow: 0 6px 18px rgba(214, 93, 149, 0.12);
}

.hero-date {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 18px;
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
}

.hero-date-day,
.hero-date-time {
    display: inline-flex;
    align-items: center;
    min-height: auto;
    padding: 0;
    border-radius: 0;
    font-weight: 700;
    letter-spacing: 0.08em;
    font-variant-numeric: tabular-nums;
}

.hero-date-day {
    background: transparent;
    color: var(--text);
    text-transform: uppercase;
}

.hero-date-time {
    background: transparent;
    color: var(--accent-dark);
}

.hero-date-divider {
    width: 24px;
    height: 1px;
    border-radius: 999px;
    background: rgba(170, 55, 111, 0.35);
    box-shadow: none;
}

.hero-location {
    margin: 14px 0 0;
    max-width: 560px;
    color: var(--text-soft);
    line-height: 1.6;
}

.hero-location-venue,
.hero-location-address {
    display: block;
}

.hero-location-venue {
    white-space: nowrap;
}

.hero-aux-button {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 12px;
    min-height: 36px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(232, 189, 210, 0.78);
    background: linear-gradient(135deg, rgba(255, 251, 253, 0.96) 0%, rgba(255, 240, 247, 0.95) 100%);
    color: var(--accent-dark);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    cursor: pointer;
    box-shadow: 0 12px 28px rgba(214, 93, 149, 0.1);
    backdrop-filter: blur(10px);
    transition: transform 0.12s ease, box-shadow 0.12s ease, border-color 0.12s ease;
}

.hero-aux-button:hover {
    transform: translateY(-1px);
    border-color: rgba(220, 141, 183, 0.92);
    box-shadow: 0 14px 30px rgba(214, 93, 149, 0.14);
}

.page-status {
    margin-top: 14px;
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.9);
    box-shadow: var(--shadow-card);
}

.page-status.is-success,
.warning-card.is-success,
.modal-notice.is-success {
    color: #7a244f;
    background: #ffeaf4;
    border-color: #f3b7d4;
}

.page-status.is-warning,
.warning-card.is-warning,
.modal-notice.is-warning {
    color: #885100;
    background: #fff5e6;
    border-color: #f5d69e;
}

.page-status.is-error,
.modal-notice.is-error {
    color: #8a2447;
    background: #ffe9f1;
    border-color: #f2a8c5;
}

.page-status.is-info,
.warning-card.is-info,
.modal-notice.is-info {
    color: #7b3357;
    background: #fff2f8;
    border-color: #f2bfd9;
}

.main-stack {
    margin-top: 16px;
}

.scheme-panel {
    width: 100%;
    border-radius: 32px;
    padding: 20px 16px 18px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.82) 0%, rgba(255, 248, 252, 0.92) 100%);
    backdrop-filter: blur(16px);
}

.scheme-head {
    display: grid;
    gap: 14px;
    margin-bottom: 14px;
}

.scheme-head h2 {
    margin: 0;
    font-size: 22px;
    letter-spacing: 0.02em;
}

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

.legend-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text-soft);
    font-size: 12px;
}

.legend-seat {
    width: 18px;
    height: 18px;
    border-radius: 7px;
    border: 1px solid transparent;
}

.legend-seat.seat-free {
    background: #fff7fb;
    border-color: #f0bad7;
}

.legend-seat.seat-price-standard {
    background: rgba(255, 248, 252, 0.98);
    border-color: rgba(236, 183, 210, 0.92);
}

.legend-seat.seat-price-discount {
    background: rgba(255, 235, 244, 0.98);
    border-color: rgba(237, 174, 205, 0.95);
}

.legend-seat.seat-selected {
    background: var(--accent);
    border-color: var(--accent);
}

.legend-seat.seat-busy {
    background: #d7bcc9;
    border-color: #d7bcc9;
}

.scheme-scroll {
    position: relative;
    overflow-x: auto;
    padding-bottom: 4px;
}

.scheme-scroll::-webkit-scrollbar {
    height: 8px;
}

.scheme-scroll::-webkit-scrollbar-thumb {
    background: rgba(214, 61, 127, 0.3);
    border-radius: 999px;
}

.stage {
    position: sticky;
    left: 0;
    z-index: 3;
    width: 100%;
    min-width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    margin-left: 0;
    margin-bottom: 18px;
    border-radius: 999px;
    border: 1px solid rgba(232, 189, 210, 0.7);
    background: linear-gradient(90deg, rgba(255, 234, 244, 0.96) 0%, rgba(255, 244, 249, 0.98) 100%);
    color: var(--accent-dark);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.scheme-root {
    display: grid;
    gap: 18px;
    width: var(--full-row-width);
}

.scheme-section {
    display: grid;
    gap: 10px;
}

.section-title {
    position: sticky;
    left: 0;
    z-index: 2;
    width: 100%;
    min-width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    color: var(--accent-dark);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    background: transparent;
    border: none;
    box-shadow: none;
}

.scheme-row {
    display: flex;
    align-items: center;
    gap: var(--row-gap);
    width: var(--full-row-width);
}

.scheme-row.has-after-gap {
    margin-bottom: 16px;
}

.row-label {
    width: var(--row-label-width);
    text-align: center;
    font-weight: 700;
    color: var(--text-soft);
    font-size: 13px;
}

.scheme-row-grid {
    display: grid;
    grid-template-columns: repeat(var(--cells), var(--seat-width));
    gap: var(--seat-gap);
}

.seat-button,
.scheme-gap {
    width: var(--seat-width);
    height: var(--seat-height);
    border-radius: 11px;
}

.seat-button {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    appearance: none;
    -webkit-appearance: none;
    overflow: hidden;
    padding: 0;
    border: 1px solid rgba(232, 189, 210, 0.75);
    cursor: pointer;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    text-align: center;
    font-variant-numeric: tabular-nums;
    background-clip: padding-box;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
    transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.12s ease, border-color 0.12s ease;
}

.seat-button:hover:enabled {
    transform: translateY(-1px);
    box-shadow: 0 10px 18px rgba(214, 61, 127, 0.18);
}

.seat-button.is-price-standard.is-free {
    background: rgba(255, 250, 252, 0.96);
    border-color: rgba(238, 184, 211, 0.85);
    color: var(--text);
}

.seat-button.is-price-discount.is-free {
    background: rgba(255, 238, 246, 0.98);
    border-color: rgba(237, 174, 205, 0.95);
    color: #8f3a63;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.seat-button.is-selected {
    background: #d65d95;
    border-color: #d65d95;
    color: #fff;
    box-shadow: 0 12px 22px rgba(214, 93, 149, 0.24);
    animation: seat-pop 0.18s ease-out;
}

.seat-button.is-own {
    background: #e683b1;
    border-color: #e683b1;
    color: #fff;
    box-shadow: none;
}

.seat-button.is-busy {
    background: #d9c8d1;
    border-color: #d9c8d1;
    color: #fff;
    box-shadow: none;
    cursor: not-allowed;
}

.scheme-gap.is-empty {
    border: none;
    background: transparent;
}

.scheme-gap.is-aisle {
    border: none;
    background: transparent;
}

.selection-bar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 40;
    padding: 8px 12px calc(8px + env(safe-area-inset-bottom));
    transition: opacity 0.16s ease, transform 0.16s ease;
}

body.modal-open .selection-bar {
    opacity: 0;
    pointer-events: none;
    transform: translateY(14px);
}

.selection-bar-inner {
    max-width: 760px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(18px);
}

.selection-copy {
    min-width: 0;
}

.selection-text {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.35;
}

.selection-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.selection-total {
    font-size: 18px;
    font-weight: 800;
    color: var(--accent-dark);
    white-space: nowrap;
}

.primary-button {
    min-height: 42px;
    padding: 0 16px;
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--accent) 0%, #ee89b5 100%);
    color: #fff;
    cursor: pointer;
    white-space: nowrap;
    font-weight: 700;
    box-shadow: var(--shadow-button);
    transition: transform 0.12s ease, opacity 0.12s ease;
}

.primary-button:hover:enabled {
    transform: translateY(-1px);
}

.primary-button:disabled {
    opacity: 0.48;
    cursor: not-allowed;
    transform: none;
}

.primary-button-wide {
    width: 100%;
}

.secondary-button {
    min-height: 42px;
    padding: 0 16px;
    border-radius: 14px;
    border: 1px solid rgba(232, 189, 210, 0.9);
    background: rgba(255, 247, 251, 0.92);
    color: var(--accent-dark);
    cursor: pointer;
    white-space: nowrap;
    font-weight: 700;
    transition: transform 0.12s ease, opacity 0.12s ease, border-color 0.12s ease;
}

.secondary-button:hover:enabled {
    transform: translateY(-1px);
    border-color: #dc8db7;
}

.secondary-button:disabled {
    opacity: 0.48;
    cursor: not-allowed;
    transform: none;
}

.secondary-button-wide {
    width: 100%;
}

.modal {
    position: fixed;
    inset: 0;
    z-index: 70;
}

.modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(81, 27, 54, 0.42);
    backdrop-filter: blur(8px);
}

.modal-sheet {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    max-width: 760px;
    margin: 0 auto;
    padding: 18px 16px calc(18px + env(safe-area-inset-bottom));
    border-radius: 30px 30px 0 0;
    background: var(--panel-strong);
    max-height: 92vh;
    overflow-y: auto;
    backdrop-filter: blur(22px);
}

.modal-sheet-small {
    max-width: 620px;
}

#payment-step {
    display: grid;
    gap: 10px;
    padding-bottom: 6px;
}

.modal-close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 38px;
    height: 38px;
    border: none;
    border-radius: 999px;
    background: rgba(255, 222, 238, 0.95);
    color: var(--accent-dark);
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
}

.modal-notice,
.warning-card {
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid var(--line);
    margin-bottom: 12px;
}

.modal-kicker {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent-dark);
    margin-top: 16px;
}

.modal-title {
    margin: 8px 0 0;
    font-size: 26px;
}

.modal-text {
    margin: 10px 0 18px;
    color: var(--text-soft);
    line-height: 1.55;
}

.payment-alert {
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid rgba(236, 152, 185, 0.92);
    background: linear-gradient(135deg, rgba(255, 233, 242, 0.98) 0%, rgba(255, 244, 249, 0.98) 100%);
    color: #8b214f;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.45;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    box-shadow: 0 16px 30px rgba(214, 93, 149, 0.12);
}

.payment-alert-critical {
    border-color: rgba(224, 111, 157, 0.9);
    background: linear-gradient(135deg, rgba(255, 225, 237, 0.98) 0%, rgba(255, 242, 247, 0.98) 100%);
}

.payment-instructions {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 0 0 0 18px;
    color: var(--text);
    line-height: 1.7;
}

.payment-instructions li {
    padding-left: 4px;
}

.payment-strong-value {
    font-size: 18px;
    font-weight: 900;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--accent-dark);
}

.payment-emphasis {
    display: inline-block;
    margin-top: 4px;
    font-size: 15px;
    font-weight: 900;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: #8b214f;
}

.copy-inline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    vertical-align: middle;
}

.copy-button {
    min-height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid rgba(232, 189, 210, 0.92);
    background: rgba(255, 248, 252, 0.98);
    color: var(--accent-dark);
    font-size: 11px;
    font-weight: 700;
    cursor: pointer;
}

.payment-refund-note {
    color: var(--text-soft);
    line-height: 1.6;
    font-size: 13px;
}

.payment-meta-cards {
    display: grid;
    gap: 10px;
}

.payment-meta-card {
    background: rgba(255, 249, 252, 0.98);
}

.detail-grid,
.form-stack {
    display: grid;
    gap: 10px;
}

.detail-card {
    display: grid;
    gap: 6px;
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid var(--line);
    background: rgba(255, 249, 252, 0.96);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.detail-card span {
    color: var(--text-soft);
    font-size: 13px;
}

.detail-card strong {
    line-height: 1.5;
    word-break: break-word;
}

.detail-card-wide {
    grid-column: 1 / -1;
}

.field {
    display: grid;
    gap: 6px;
}

.field span {
    color: var(--text-soft);
    font-size: 13px;
}

.field input {
    width: 100%;
    min-height: 50px;
    padding: 0 14px;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: #fff;
    color: var(--text);
}

.field input:focus {
    outline: 2px solid rgba(242, 84, 152, 0.22);
    border-color: var(--accent);
}

.payment-actions {
    display: grid;
    gap: 10px;
    margin-top: 6px;
    position: sticky;
    bottom: 0;
    padding-top: 10px;
    background: linear-gradient(180deg, rgba(255, 250, 252, 0) 0%, rgba(255, 250, 252, 0.98) 28%);
}

.payment-confirm-note {
    font-size: 12px;
    line-height: 1.35;
    color: var(--text-soft);
}

.payment-confirm-note:empty {
    display: none;
}

@keyframes seat-pop {
    0% {
        transform: scale(0.92);
    }

    65% {
        transform: scale(1.06);
    }

    100% {
        transform: scale(1);
    }
}

@media (min-width: 768px) {
    :root {
        --seat-width: 26px;
        --seat-height: 24px;
        --seat-gap: 3px;
        --row-label-width: 32px;
        --row-gap: 8px;
    }

    .page-shell {
        max-width: 1280px;
        padding: 24px 16px 42px;
    }

    .main-stack {
        display: flex;
        justify-content: center;
    }

    .hero,
    .scheme-panel,
    .page-status {
        width: min(100%, calc(var(--full-row-width) + 52px));
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    .hero,
    .scheme-panel {
        padding-left: 22px;
        padding-right: 22px;
    }

    .hero {
        padding-top: 30px;
        padding-right: 220px;
        padding-bottom: 30px;
    }

    .hero-brand {
        font-size: 80px;
    }

    .hero-event {
        font-size: clamp(48px, 5vw, 78px);
    }

    .stage {
        width: var(--full-row-width);
        min-width: var(--full-row-width);
        margin-left: 0;
    }

    .scheme-head h2 {
        font-size: 26px;
    }

    .scheme-panel {
        width: min(100%, calc(var(--full-row-width) + 52px));
    }

    .detail-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .payment-actions {
        grid-template-columns: minmax(0, 1fr);
    }

    .selection-bar {
        padding-left: 20px;
        padding-right: 20px;
    }

    .selection-bar-inner {
        max-width: 1280px;
        padding: 10px 14px;
    }

    .modal-sheet {
        top: 50%;
        bottom: auto;
        left: 50%;
        right: auto;
        width: min(720px, calc(100vw - 32px));
        max-height: min(88vh, 920px);
        transform: translate(-50%, -50%);
        border-radius: 30px;
        padding: 22px 20px 24px;
    }
}

@media (min-width: 1200px) {
    :root {
        --seat-width: 28px;
        --seat-height: 24px;
        --seat-gap: 4px;
        --row-label-width: 34px;
        --row-gap: 8px;
    }

    .page-shell {
        max-width: 1420px;
    }

    .selection-bar-inner {
        max-width: 1420px;
    }

    .hero {
        padding-right: 300px;
    }
}

@media (max-width: 767px) {
    :root {
        --seat-width: 24px;
        --seat-height: 22px;
        --seat-gap: 3px;
        --row-label-width: 24px;
    }

    body {
        padding-bottom: 118px;
    }

    .page-shell {
        max-width: 460px;
        padding: 12px 10px 22px;
    }

    .hero {
        border-radius: 26px;
        padding: 22px 16px 20px 24px;
    }

    .hero-kicker,
    .hero-brand,
    .hero-type,
    .hero-event,
    .hero-date,
    .hero-location {
        margin-left: 3px;
    }

    .hero-kicker {
        margin-top: 14px;
    }

    .hero-brand {
        font-size: clamp(38px, 11vw, 56px);
    }

    .hero-event {
        font-size: clamp(29px, 8vw, 40px);
        white-space: nowrap;
        line-height: 1;
    }

    .hero-date {
        gap: 8px;
    }

    .hero-date-day,
    .hero-date-time {
        font-size: 14px;
    }

    .hero-location {
        font-size: 14px;
    }

    .hero-aux-button {
        margin-left: 3px;
        min-height: 32px;
        font-size: 11px;
    }

    .scheme-panel {
        border-radius: 26px;
        padding: 14px 10px 14px;
    }

    .scheme-head {
        gap: 10px;
        margin-bottom: 12px;
    }

    .scheme-head h2 {
        font-size: 20px;
    }

    .legend {
        gap: 8px;
    }

    .legend-item {
        font-size: 11px;
    }

    .row-label {
        font-size: 12px;
    }

    .section-title {
        font-size: 11px;
        width: calc(100vw - 40px);
        min-width: calc(100vw - 40px);
        padding: 0;
    }

    .stage,
    .section-title {
        justify-content: center;
        text-align: center;
    }

    .stage {
        min-height: 40px;
        font-size: 12px;
    }

    .selection-bar {
        padding: 8px 10px calc(8px + env(safe-area-inset-bottom));
    }

    .selection-bar-inner {
        border-radius: 22px;
        grid-template-columns: minmax(0, 1fr) auto;
        padding: 9px 10px;
        align-items: center;
    }

    .selection-text {
        font-size: 12px;
    }

    .selection-total {
        font-size: 16px;
    }

    .primary-button {
        min-height: 38px;
        padding: 0 14px;
        border-radius: 12px;
        font-size: 13px;
    }

    .secondary-button {
        min-height: 38px;
        padding: 0 14px;
        border-radius: 12px;
        font-size: 13px;
    }

    .modal-sheet {
        padding: 16px 14px calc(16px + env(safe-area-inset-bottom));
        border-radius: 24px 24px 0 0;
    }

    .modal-title {
        font-size: 24px;
    }

    .payment-actions {
        gap: 8px;
    }

    .payment-confirm-note {
        font-size: 11px;
    }

    .payment-alert {
        font-size: 14px;
        padding: 13px 14px;
    }

    .payment-strong-value {
        font-size: 16px;
    }

    .payment-emphasis {
        font-size: 14px;
    }

    .copy-button {
        min-height: 28px;
        font-size: 10px;
        padding: 0 9px;
    }
}
