body {
    font-family: "Roboto", sans-serif;
}

.tb-shell-title {
    letter-spacing: -0.03em;
}

.tb-panel-card {
    border-radius: 1.5rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent);
    background: color-mix(in srgb, var(--color-background) 97%, var(--color-primary) 3%);
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06);
    overflow: hidden;
}

.tb-panel-stack {
    display: grid;
    gap: 1.75rem;
}

.tb-stat-card {
    position: relative;
    overflow: hidden;
}

.tb-stat-card::after {
    content: "";
    position: absolute;
    inset: auto -2rem -2rem auto;
    width: 6rem;
    height: 6rem;
    border-radius: 9999px;
    background: color-mix(in srgb, var(--color-primary) 18%, transparent);
}

.tb-input,
.tb-select,
.tb-textarea {
    width: 100%;
    border-radius: 1rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    background: color-mix(in srgb, var(--color-background) 98%, white 2%);
    padding: 0.95rem 1rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.tb-input:focus,
.tb-select:focus,
.tb-textarea:focus {
    outline: none;
    border-color: color-mix(in srgb, var(--color-primary) 45%, transparent);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--color-primary) 15%, transparent);
}

.tb-textarea {
    min-height: 9rem;
    resize: vertical;
}

.tb-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    border-radius: 9999px;
    padding: 0.85rem 1.25rem;
    font-weight: 600;
    transition: transform 0.2s ease, opacity 0.2s ease, background 0.2s ease;
}

.tb-btn:hover {
    transform: translateY(-1px);
}

.tb-btn-primary {
    background: linear-gradient(135deg, var(--color-primary), color-mix(in srgb, var(--color-primary) 70%, black 30%));
    color: white;
}

.tb-btn-secondary {
    background: color-mix(in srgb, var(--color-background) 92%, var(--color-foreground) 8%);
    color: var(--color-foreground);
}

.tb-btn-danger {
    background: color-mix(in srgb, var(--color-danger) 18%, white 82%);
    color: var(--color-danger);
}

.tb-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    border-radius: 9999px;
    background: color-mix(in srgb, var(--color-primary) 15%, transparent);
    padding: 0.35rem 0.75rem;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.tb-hero-gradient {
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--color-primary) 20%, transparent), transparent 42%),
        linear-gradient(135deg, color-mix(in srgb, var(--color-primary) 14%, white 86%), color-mix(in srgb, var(--color-foreground) 5%, white 95%));
}

.tb-table td,
.tb-table th {
    padding: 1rem;
}

.tb-table tbody tr {
    border-top: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent);
}

.tb-share-card {
    border: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent);
    background: color-mix(in srgb, var(--color-background) 94%, var(--color-primary) 6%);
}

.tb-share-input {
    font-size: 0.92rem;
    background: color-mix(in srgb, var(--color-background) 99%, white 1%);
}

.tb-auth-stage {
    min-height: 100vh;
    background:
        linear-gradient(130deg, rgba(15, 23, 42, 0.85), rgba(37, 99, 235, 0.7)),
        url("../images/noise.png");
}

.tb-invitation-shell {
    min-height: 100vh;
    background:
        radial-gradient(circle at top, color-mix(in srgb, var(--color-primary) 15%, transparent), transparent 40%),
        linear-gradient(180deg, color-mix(in srgb, var(--color-background) 98%, white 2%), color-mix(in srgb, var(--color-background) 92%, var(--color-primary) 8%));
}

.tb-ticket {
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--color-primary) 12%, white 88%), white),
        url("../images/noise.png");
    border: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent);
    border-radius: 2rem;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.1);
}

.tb-ticket-stage {
    border-radius: 2.2rem;
    border: 1px solid rgba(223, 207, 203, 0.6);
    background: rgba(255, 253, 251, 0.78);
    padding: 1rem;
    box-shadow: 0 30px 70px rgba(124, 89, 102, 0.1);
}

.tb-ticket-frame {
    border-radius: 2rem;
    border: 1px solid rgba(234, 223, 220, 0.85);
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.92), rgba(255, 249, 247, 0.94) 44%, rgba(252, 245, 243, 0.96)),
        rgba(255, 255, 255, 0.9);
    padding: 1.4rem;
}

.tb-ticket-header {
    text-align: center;
}

.tb-ticket-heading {
    margin: 0;
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2.4rem, 6vw, 4.3rem);
    line-height: 0.94;
    color: var(--tb-ticket-secondary, #4d3a40);
}

.tb-ticket-intro {
    margin: 1rem auto 0;
    max-width: 42rem;
    font-size: 1rem;
    line-height: 1.8;
    color: rgba(100, 86, 91, 0.82);
}

.tb-ticket-card {
    width: min(100%, 42rem);
    margin: 1.8rem auto 0;
    border-radius: 2rem;
    border: 1px solid rgba(234, 223, 220, 0.85);
    background:
        linear-gradient(180deg, rgba(255, 245, 247, 0.9), rgba(255, 253, 251, 0.96)),
        rgba(255, 255, 255, 0.92);
    padding: 1.25rem;
    box-shadow: 0 22px 48px rgba(141, 99, 117, 0.08);
}

.tb-ticket-card-top {
    text-align: center;
}

.tb-ticket-kicker,
.tb-ticket-label,
.tb-ticket-stat-label {
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
}

.tb-ticket-kicker {
    color: var(--tb-ticket-accent, #c19959);
}

.tb-ticket-event {
    margin: 0.7rem 0 0;
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2.4rem, 5vw, 3.7rem);
    line-height: 0.95;
    color: var(--tb-ticket-primary, #ba748b);
}

.tb-ticket-meta-line {
    margin-top: 0.65rem;
    font-size: 0.96rem;
    color: rgba(106, 90, 96, 0.82);
}

.tb-ticket-folio {
    width: fit-content;
    margin: 1rem auto 0;
    border-radius: 999px;
    border: 1px solid rgba(237, 224, 219, 0.95);
    background: rgba(255, 255, 255, 0.72);
    padding: 0.55rem 1rem;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: var(--tb-ticket-primary, #ba748b);
}

.tb-ticket-divider {
    margin: 1.35rem 0;
    border-top: 2px dashed rgba(220, 204, 198, 0.9);
}

.tb-ticket-grid,
.tb-ticket-stats {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.9rem;
}

.tb-ticket-info-card,
.tb-ticket-stat,
.tb-ticket-companions {
    border-radius: 1.35rem;
    border: 1px solid rgba(237, 224, 219, 0.95);
    background: rgba(255, 255, 255, 0.72);
    padding: 1rem 1.05rem;
}

.tb-ticket-label {
    color: rgba(159, 135, 142, 0.92);
}

.tb-ticket-value {
    margin-top: 0.55rem;
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2rem, 4vw, 2.9rem);
    line-height: 1;
    color: var(--tb-ticket-primary, #ba748b);
    font-weight: 700;
}

.tb-ticket-number,
.tb-ticket-stat-number {
    margin-top: 0.55rem;
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2.1rem, 4vw, 3rem);
    line-height: 1;
    color: var(--tb-ticket-secondary, #30272a);
    font-weight: 700;
}

.tb-ticket-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 0.8rem;
}

.tb-ticket-chip {
    border-radius: 999px;
    border: 1px solid rgba(237, 224, 219, 0.95);
    background: rgba(255, 247, 248, 0.95);
    padding: 0.5rem 0.85rem;
    color: rgba(88, 69, 75, 0.9);
    font-size: 0.92rem;
    font-weight: 600;
}

.tb-ticket-stat {
    text-align: center;
}

.tb-ticket-stat-label {
    margin-top: 0.4rem;
    color: rgba(159, 135, 142, 0.92);
}

.tb-ticket-copy {
    margin: 1rem auto 0;
    max-width: 34rem;
    text-align: center;
    font-size: 0.95rem;
    line-height: 1.8;
    color: rgba(106, 90, 96, 0.82);
}

.tb-ticket-qr-wrap {
    display: flex;
    justify-content: center;
    margin-top: 1.3rem;
}

.tb-ticket-qr-card {
    border-radius: 1.5rem;
    border: 1px solid rgba(237, 224, 219, 0.95);
    background: rgba(255, 255, 255, 0.92);
    padding: 1rem;
}

.tb-ticket-qr-card svg {
    width: 12.5rem;
    height: 12.5rem;
}

.tb-ticket-barcode {
    height: 2.4rem;
    margin-top: 1rem;
    border-radius: 0.9rem;
    background: repeating-linear-gradient(
        90deg,
        rgba(16, 16, 16, 0.82) 0 2px,
        transparent 2px 4px,
        rgba(68, 68, 68, 0.78) 4px 5px,
        transparent 5px 8px
    );
    opacity: 0.7;
}

.tb-ticket-actions {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    justify-content: center;
    width: min(100%, 42rem);
    margin: 1rem auto 0;
}

.tb-ticket-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0.95rem 1.25rem;
    font-size: 0.95rem;
    font-weight: 700;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.tb-ticket-action:hover {
    transform: translateY(-1px);
}

.tb-ticket-action-primary {
    background: linear-gradient(135deg, var(--tb-ticket-primary, #ba748b), color-mix(in srgb, var(--tb-ticket-primary, #ba748b) 72%, black 28%));
    color: white;
    box-shadow: 0 16px 28px rgba(159, 98, 120, 0.22);
}

.tb-ticket-action-secondary {
    border: 1px solid rgba(223, 207, 203, 0.95);
    background: rgba(255, 255, 255, 0.74);
    color: rgba(78, 63, 69, 0.92);
}

@media (min-width: 768px) {
    .tb-ticket-frame {
        padding: 2rem;
    }

    .tb-ticket-grid {
        grid-template-columns: minmax(0, 1.5fr) minmax(0, 0.9fr);
    }

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

    .tb-ticket-actions {
        flex-direction: row;
    }
}

.tb-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border-radius: 9999px;
    padding: 0.35rem 0.75rem;
    font-size: 0.8rem;
    font-weight: 600;
}

.tb-badge-success {
    background: color-mix(in srgb, var(--color-success) 16%, white 84%);
    color: var(--color-success);
}

.tb-badge-warning {
    background: color-mix(in srgb, var(--color-warning) 18%, white 82%);
    color: #a16207;
}

.tb-badge-danger {
    background: color-mix(in srgb, var(--color-danger) 16%, white 84%);
    color: var(--color-danger);
}

.tb-badge-neutral {
    background: color-mix(in srgb, var(--color-foreground) 8%, white 92%);
    color: color-mix(in srgb, var(--color-foreground) 72%, black 28%);
}

.tb-checkin-result-hero {
    border-top-left-radius: 1rem;
    border-top-right-radius: 1rem;
}

.tb-checkin-result-hero-danger {
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--color-danger) 84%, #7f1d1d 16%), color-mix(in srgb, var(--color-danger) 62%, #450a0a 38%));
}

.tb-checkin-result-hero-success {
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--color-success) 82%, #166534 18%), color-mix(in srgb, var(--color-success) 60%, #14532d 40%));
}

.tb-checkin-result-hero-danger .tb-badge-danger {
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
}

.tb-checkin-result-hero-success .tb-badge-success {
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
}

.tb-checkin-result-kicker-light {
    background: rgba(255, 255, 255, 0.16);
    color: #fff;
}

.tb-invite-lock-stage {
    min-height: 70vh;
    display: flex !important;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.tb-invite-lock-card {
    width: min(100%, 42rem);
    margin-inline: auto;
    text-align: center;
}

.tb-invite-lock-title {
    margin: 1rem 0 0;
    font-family: "Manrope", "Montserrat", "Roboto", sans-serif;
    font-size: clamp(2rem, 5vw, 3.25rem);
    line-height: 1.02;
    letter-spacing: -0.03em;
    font-weight: 700;
    color: currentColor;
}

.tb-rsvp-shell {
    width: min(100%, 1140px);
    margin: 0 auto;
}

.tb-rsvp-header {
    margin-bottom: 1.35rem;
    text-align: center;
}

.tb-rsvp-kicker {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--tbxv-accent, var(--tbw-accent, var(--tbcorp-accent, #b38b5f))) 70%, #6b4f4f 30%);
}

.tb-rsvp-title {
    margin: 0.8rem 0 0;
    font-family: var(--tbxv-font-display, var(--tbw-font-display, var(--tbcorp-font-display, "Cormorant Garamond", serif)));
    font-size: clamp(2.4rem, 5vw, 4rem);
    line-height: 0.95;
    color: color-mix(in srgb, var(--tbxv-secondary, var(--tbw-secondary, var(--tbcorp-secondary, #48363d))) 88%, white 12%);
}

.tb-rsvp-subtitle {
    margin-top: 1rem;
    font-size: 1.02rem;
    color: color-mix(in srgb, var(--tbxv-secondary, var(--tbw-secondary, var(--tbcorp-secondary, #6b5b63))) 62%, white 38%);
}

.tb-rsvp-card {
    border-radius: 2rem;
    border: 1px solid rgba(214, 190, 181, 0.38);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(255, 249, 246, 0.92)),
        rgba(255, 255, 255, 0.78);
    box-shadow: 0 22px 60px rgba(141, 99, 117, 0.12);
    padding: 0.95rem;
}

.tb-rsvp-form {
    border-radius: 1.7rem;
    border: 1px solid rgba(222, 203, 197, 0.52);
    background: rgba(255, 255, 255, 0.62);
    padding: 1rem;
}

.tb-rsvp-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1rem;
}

.tb-rsvp-field {
    margin-top: 0.85rem;
}

.tb-rsvp-field[hidden],
.tb-rsvp-companion-field[hidden] {
    display: none !important;
}

.tb-rsvp-label {
    display: block;
    margin-bottom: 0.6rem;
    font-size: 0.95rem;
    font-weight: 700;
    color: color-mix(in srgb, var(--tbxv-secondary, var(--tbw-secondary, var(--tbcorp-secondary, #59474e))) 84%, white 16%);
}

.tb-rsvp-input,
.tb-rsvp-select,
.tb-rsvp-textarea {
    width: 100%;
    border-radius: 1.15rem;
    border: 1px solid rgba(222, 203, 197, 0.9);
    background: rgba(255, 255, 255, 0.86);
    padding: 1rem 1rem;
    font-size: 1.02rem;
    color: color-mix(in srgb, var(--tbxv-secondary, var(--tbw-secondary, var(--tbcorp-secondary, #4f3f45))) 88%, white 12%);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.tb-rsvp-input::placeholder,
.tb-rsvp-textarea::placeholder {
    color: rgba(123, 111, 116, 0.68);
}

.tb-rsvp-input:focus,
.tb-rsvp-select:focus,
.tb-rsvp-textarea:focus {
    outline: none;
    border-color: color-mix(in srgb, var(--tbxv-primary, var(--tbw-primary, var(--tbcorp-primary, #b5798d))) 35%, white 65%);
    box-shadow: 0 0 0 4px rgba(186, 116, 139, 0.12);
    background: white;
}

.tb-rsvp-textarea {
    min-height: 8.4rem;
    resize: vertical;
}

.tb-rsvp-help,
.tb-rsvp-footnote,
.tb-rsvp-error {
    margin-top: 0.45rem;
    font-size: 0.9rem;
}

.tb-rsvp-help,
.tb-rsvp-footnote {
    color: rgba(123, 111, 116, 0.78);
}

.tb-rsvp-error {
    color: #b42318;
}

.tb-rsvp-companion-list {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.tb-rsvp-button {
    width: 100%;
    margin-top: 1rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #c4889f, #9f6278);
    color: white;
    padding: 1rem 1.25rem;
    font-size: 1rem;
    font-weight: 700;
    box-shadow: 0 18px 32px rgba(159, 98, 120, 0.22);
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.tb-rsvp-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 22px 36px rgba(159, 98, 120, 0.24);
}

.tb-rsvp-footnote {
    text-align: center;
}

@media (min-width: 768px) {
    .tb-rsvp-card {
        padding: 1rem;
    }

    .tb-rsvp-form {
        padding: 1.15rem;
    }

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

.tb-shortcode-panel {
    border-radius: 1.7rem;
    border: 1px solid rgba(214, 197, 192, 0.5);
    background: rgba(255, 255, 255, 0.76);
    padding: 1.2rem;
    box-shadow: 0 18px 40px rgba(101, 76, 86, 0.08);
}

.tb-shortcode-panel-soft {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.78), rgba(255, 247, 246, 0.84)),
        rgba(255, 255, 255, 0.72);
}

.tb-shortcode-kicker,
.tb-shortcode-label {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(142, 110, 121, 0.85);
}

.tb-shortcode-title,
.tb-shortcode-name {
    margin-top: 0.55rem;
    font-family: "Cormorant Garamond", serif;
    line-height: 0.98;
    color: #47363c;
}

.tb-shortcode-title {
    font-size: clamp(2rem, 4vw, 3rem);
}

.tb-shortcode-name {
    font-size: 2rem;
}

.tb-shortcode-copy {
    margin-top: 0.7rem;
    color: rgba(92, 77, 83, 0.82);
    line-height: 1.8;
}

.tb-shortcode-form,
.tb-shortcode-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1.1rem;
}

.tb-shortcode-choice {
    width: 100%;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    border-radius: 1rem;
    border: 1px solid rgba(176, 149, 158, 0.25);
    background: rgba(255, 255, 255, 0.86);
    padding: 0.9rem 1rem;
    text-align: left;
    cursor: pointer;
}

.tb-shortcode-alert {
    margin-top: 1rem;
    border-radius: 1.1rem;
    padding: 1rem;
}

.tb-shortcode-alert-title {
    font-weight: 700;
}

.tb-shortcode-alert-copy {
    margin-top: 0.35rem;
    line-height: 1.7;
}

.tb-shortcode-alert-success {
    border: 1px solid rgba(34, 197, 94, 0.18);
    background: rgba(34, 197, 94, 0.08);
    color: #166534;
}

.tb-shortcode-alert-warning {
    border: 1px solid rgba(245, 158, 11, 0.18);
    background: rgba(245, 158, 11, 0.1);
    color: #9a5b00;
}

.tb-shortcode-alert-neutral {
    border: 1px solid rgba(79, 70, 229, 0.14);
    background: rgba(79, 70, 229, 0.06);
    color: #4338ca;
}

.tb-shortcode-action-row {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 1rem;
}

.tb-shortcode-logo {
    display: block;
    max-width: min(220px, 100%);
    max-height: 88px;
    object-fit: contain;
}

.tb-shortcode-detail-grid,
.tb-shortcode-countdown {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.9rem;
}

.tb-shortcode-detail-card,
.tb-shortcode-countdown-item {
    border-radius: 1.25rem;
    border: 1px solid rgba(229, 214, 210, 0.8);
    background: rgba(255, 255, 255, 0.72);
    padding: 1rem;
    text-align: center;
}

.tb-shortcode-detail-label,
.tb-shortcode-countdown-label {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(127, 108, 116, 0.74);
}

.tb-shortcode-detail-value,
.tb-shortcode-countdown-value {
    margin-top: 0.55rem;
    color: #4d3a40;
}

.tb-shortcode-detail-value {
    font-size: 1rem;
    line-height: 1.65;
    font-weight: 600;
}

.tb-shortcode-countdown-value {
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(1.8rem, 5vw, 2.7rem);
    line-height: 1;
    font-weight: 600;
}

.tb-shortcode-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0.95rem 1.25rem;
    font-weight: 700;
}

.tb-shortcode-button-primary {
    background: linear-gradient(135deg, #c4889f, #9f6278);
    color: white;
}

.tb-shortcode-button-secondary {
    border: 1px solid rgba(174, 148, 157, 0.24);
    background: rgba(255, 255, 255, 0.84);
    color: #4e3f45;
}

@media (min-width: 768px) {
    .tb-shortcode-action-row {
        flex-direction: row;
    }

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

    .tb-shortcode-countdown {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.tb-xv-page {
    min-height: 100vh;
    padding: 2rem 1rem 3rem;
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.94), rgba(255, 247, 248, 0.96) 42%, rgba(249, 231, 236, 0.92)),
        linear-gradient(180deg, #fffdfd, #fff5f7);
    color: var(--tbxv-secondary);
    font-family: var(--tbxv-font-body);
    overflow-x: hidden;
}

.tb-xv-page::before,
.tb-xv-page::after {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
}

.tb-xv-page::before {
    background:
        radial-gradient(circle at 8% 14%, rgba(243, 205, 215, 0.45) 0 2px, transparent 3px),
        radial-gradient(circle at 92% 18%, rgba(243, 205, 215, 0.4) 0 2px, transparent 3px),
        radial-gradient(circle at 14% 72%, rgba(243, 205, 215, 0.38) 0 2px, transparent 3px),
        radial-gradient(circle at 88% 78%, rgba(243, 205, 215, 0.38) 0 2px, transparent 3px);
    opacity: 0.8;
}

.tb-xv-page::after {
    background:
        linear-gradient(0deg, transparent 48%, rgba(255, 255, 255, 0.22) 50%, transparent 52%),
        linear-gradient(60deg, transparent 48%, rgba(247, 218, 226, 0.34) 50%, transparent 52%),
        linear-gradient(-60deg, transparent 48%, rgba(247, 218, 226, 0.34) 50%, transparent 52%);
    background-size: 120px 120px;
    background-position: -30px 120px, 30px 40px, 100% 70%;
    opacity: 0.16;
}

.tb-xv-shell {
    position: relative;
    z-index: 1;
    width: min(100%, 1120px);
    margin: 0 auto;
}

.tb-xv-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 2rem;
    align-items: center;
}

.tb-xv-envelope-wrap {
    display: flex;
    justify-content: center;
    padding: 1rem 0;
}

.tb-xv-envelope {
    position: relative;
    width: min(100%, 430px);
    aspect-ratio: 1 / 0.92;
    filter: drop-shadow(var(--tbxv-shadow));
}

.tb-xv-envelope-back {
    position: absolute;
    inset: 0;
    border-radius: 14px 14px 22px 22px;
    background: linear-gradient(135deg, #f9d4dd, #efb2c2);
}

.tb-xv-envelope-flap {
    position: absolute;
    top: -1px;
    left: 0;
    right: 0;
    width: 100%;
    height: 54%;
    clip-path: polygon(0 100%, 50% 0, 100% 100%);
    background: linear-gradient(180deg, #f6c7d4, #ebb0c0);
}

.tb-xv-card {
    position: absolute;
    left: 50%;
    bottom: 1rem;
    width: 76%;
    transform: translateX(-50%);
    border: 8px solid rgba(255, 255, 255, 0.82);
    background: var(--tbxv-surface-soft);
    box-shadow: var(--tbxv-shadow-soft);
}

.tb-xv-card-inner {
    border: 1px solid rgba(206, 162, 88, 0.22);
    padding: 1.2rem 1rem 1rem;
    text-align: center;
}

.tb-xv-seal {
    position: absolute;
    top: -22px;
    left: 50%;
    transform: translateX(-50%);
    display: grid;
    place-items: center;
    width: 56px;
    height: 56px;
    border-radius: 999px;
    background: radial-gradient(circle at 30% 30%, #f1d18c, #c9973e 72%);
    color: #fff9f1;
    font-family: var(--tbxv-font-display);
    font-size: 1.8rem;
    font-weight: 700;
    box-shadow: 0 10px 18px rgba(184, 134, 47, 0.28);
}

.tb-xv-card-top,
.tb-xv-card-copy,
.tb-xv-section-kicker,
.tb-xv-info-label,
.tb-xv-countdown-label {
    letter-spacing: 0.22em;
    text-transform: uppercase;
}

.tb-xv-card-top,
.tb-xv-card-copy {
    font-size: 0.64rem;
    line-height: 1.8;
    color: #988188;
}

.tb-xv-date-grid {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 0.5rem;
    margin: 1rem 0;
}

.tb-xv-date-side {
    font-family: var(--tbxv-font-display);
    font-size: 1.2rem;
    color: var(--tbxv-secondary);
}

.tb-xv-date-center {
    padding: 0 1rem;
    border-left: 1px solid rgba(219, 155, 174, 0.35);
    border-right: 1px solid rgba(219, 155, 174, 0.35);
    font-family: var(--tbxv-font-display);
    font-size: 3.4rem;
    line-height: 1;
    color: var(--tbxv-primary);
    font-weight: 600;
}

.tb-xv-card-name {
    margin: 0.6rem 0 0.35rem;
    font-family: var(--tbxv-font-script);
    font-size: clamp(2.8rem, 5vw, 4.1rem);
    line-height: 0.95;
    color: var(--tbxv-primary);
}

.tb-xv-copy {
    max-width: 540px;
}

.tb-xv-kicker {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.55rem 1rem;
    background: rgba(186, 116, 139, 0.1);
    color: var(--tbxv-primary);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.24em;
    text-transform: uppercase;
}

.tb-xv-title,
.tb-xv-section-title,
.tb-xv-mini-title {
    font-family: var(--tbxv-font-display);
    color: var(--tbxv-secondary);
}

.tb-xv-title {
    margin: 1.25rem 0 0;
    font-family: var(--tbxv-font-script);
    font-size: clamp(3.6rem, 8vw, 6rem);
    line-height: 0.92;
    letter-spacing: -0.03em;
    color: var(--tbxv-primary);
    font-weight: 400;
}

.tb-xv-lead,
.tb-xv-body-copy,
.tb-xv-detail-value {
    font-size: 0.98rem;
    line-height: 1.9;
    color: color-mix(in srgb, var(--tbxv-secondary) 78%, white 22%);
}

.tb-xv-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.5rem;
}

.tb-xv-badge {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.7rem 1rem;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(186, 116, 139, 0.18);
    box-shadow: 0 8px 22px rgba(186, 116, 139, 0.08);
    font-size: 0.85rem;
    color: var(--tbxv-secondary);
}

.tb-xv-countdown-card,
.tb-xv-panel {
    border: 1px solid rgba(186, 116, 139, 0.12);
    border-radius: 2rem;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: var(--tbxv-shadow-soft);
    backdrop-filter: blur(16px);
}

.tb-xv-countdown-card {
    margin-top: 1.5rem;
    padding: 1.5rem;
}

.tb-xv-countdown {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1rem;
}

.tb-xv-countdown-item {
    border-radius: 1.35rem;
    padding: 1rem 0.75rem;
    text-align: center;
    background: rgba(186, 116, 139, 0.08);
}

.tb-xv-countdown-item .countdown-value {
    font-family: var(--tbxv-font-display);
    font-size: 2rem;
    font-weight: 600;
    color: var(--tbxv-secondary);
}

.tb-xv-countdown-label,
.tb-xv-section-kicker,
.tb-xv-info-label {
    font-size: 0.68rem;
    color: color-mix(in srgb, var(--tbxv-secondary) 56%, white 44%);
}

.tb-xv-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1.5rem;
    margin-top: 2rem;
}

.tb-xv-main,
.tb-xv-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.tb-xv-panel {
    padding: 1.75rem;
}

.tb-xv-panel-highlight {
    background:
        radial-gradient(circle at top right, rgba(255, 255, 255, 0.65), transparent 30%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(255, 247, 248, 0.95));
}

.tb-xv-panel-soft {
    background: linear-gradient(180deg, rgba(255, 250, 251, 0.96), rgba(255, 255, 255, 0.9));
}

.tb-xv-section-title {
    margin-top: 0.75rem;
    font-size: clamp(2rem, 5vw, 3rem);
    line-height: 1.05;
}

.tb-xv-section-title-sm {
    font-size: clamp(1.85rem, 4vw, 2.35rem);
}

.tb-xv-mini-title {
    margin-top: 0.65rem;
    font-size: 1.7rem;
    line-height: 1.1;
}

.tb-xv-info-grid,
.tb-xv-columns {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1rem;
    margin-top: 1.5rem;
}

.tb-xv-info-card {
    border-radius: 1.5rem;
    padding: 1.25rem;
    background: rgba(186, 116, 139, 0.08);
}

.tb-xv-info-value {
    margin-top: 0.55rem;
    font-family: var(--tbxv-font-display);
    font-size: 1.45rem;
    color: var(--tbxv-secondary);
    line-height: 1.2;
}

.tb-xv-detail-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1.1rem;
}

.tb-xv-inline-link {
    display: inline-flex;
    align-items: center;
    margin-top: 0.35rem;
    color: var(--tbxv-primary);
    font-weight: 600;
}

.tb-xv-rsvp-panel {
    position: sticky;
    top: 1rem;
}

.tb-xv-guest-card {
    margin-top: 1rem;
    border-radius: 1.6rem;
    padding: 1.25rem;
    background: rgba(186, 116, 139, 0.08);
}

.tb-xv-guest-name {
    margin-top: 0.45rem;
    font-family: var(--tbxv-font-display);
    font-size: 2rem;
    line-height: 1.08;
}

.tb-xv-form-stack,
.tb-xv-select-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1.25rem;
}

.tb-xv-button-primary,
.tb-xv-button-secondary,
.tb-xv-select-card {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    border-radius: 999px;
    padding: 0.95rem 1.25rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
    cursor: pointer;
}

.tb-xv-button-primary:hover,
.tb-xv-button-secondary:hover,
.tb-xv-select-card:hover {
    transform: translateY(-1px);
}

.tb-xv-button-primary {
    background: linear-gradient(135deg, var(--tbxv-primary), color-mix(in srgb, var(--tbxv-primary) 72%, black 28%));
    color: white;
    box-shadow: 0 14px 30px rgba(186, 116, 139, 0.24);
}

.tb-xv-button-secondary {
    background: rgba(255, 255, 255, 0.86);
    color: var(--tbxv-secondary);
    border: 1px solid rgba(186, 116, 139, 0.16);
}

.tb-xv-select-card {
    justify-content: space-between;
    border: 1px solid rgba(186, 116, 139, 0.14);
    background: rgba(255, 255, 255, 0.84);
    color: var(--tbxv-secondary);
    text-align: left;
}

.tb-xv-alert {
    margin-top: 1.25rem;
    border-radius: 1.6rem;
    padding: 1.25rem;
}

.tb-xv-alert-success {
    border: 1px solid rgba(34, 197, 94, 0.2);
    background: rgba(34, 197, 94, 0.08);
    color: #166534;
}

.tb-xv-alert-warning {
    border: 1px solid rgba(245, 158, 11, 0.2);
    background: rgba(245, 158, 11, 0.1);
    color: #9a5b00;
}

.tb-xv-alert-title {
    font-weight: 700;
}

.tb-xv-alert-copy {
    margin-top: 0.5rem;
    font-size: 0.95rem;
    line-height: 1.7;
}

.tb-xv-action-row {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 1rem;
}

@media (min-width: 768px) {
    .tb-xv-info-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

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

    .tb-xv-action-row {
        flex-direction: row;
    }
}

@media (min-width: 1024px) {
    .tb-xv-page {
        padding: 3rem 1.5rem 4rem;
    }

    .tb-xv-hero {
        grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
        gap: 3rem;
        min-height: 78vh;
    }

    .tb-xv-grid {
        grid-template-columns: minmax(0, 1.15fr) minmax(360px, 0.85fr);
        gap: 2rem;
    }
}

.tb-corp-page {
    min-height: 100vh;
    padding: 2rem 1rem 3rem;
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.94), rgba(245, 246, 248, 0.96) 42%, rgba(233, 236, 241, 0.92)),
        linear-gradient(180deg, #fbfcfd 0%, #eef1f5 100%);
    color: color-mix(in srgb, var(--tbcorp-secondary) 88%, white 12%);
    font-family: var(--tbcorp-font-body);
    overflow-x: hidden;
}

.tb-corp-page::before,
.tb-corp-page::after {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
}

.tb-corp-page::before {
    background:
        radial-gradient(circle at 12% 18%, rgba(199, 164, 106, 0.18) 0 2px, transparent 3px),
        radial-gradient(circle at 88% 16%, rgba(199, 164, 106, 0.14) 0 2px, transparent 3px),
        radial-gradient(circle at 10% 80%, rgba(34, 53, 83, 0.08) 0 2px, transparent 3px),
        radial-gradient(circle at 90% 76%, rgba(34, 53, 83, 0.08) 0 2px, transparent 3px);
    opacity: 0.9;
}

.tb-corp-page::after {
    background:
        linear-gradient(90deg, transparent 49%, rgba(199, 164, 106, 0.06) 50%, transparent 51%),
        linear-gradient(0deg, transparent 49%, rgba(199, 164, 106, 0.04) 50%, transparent 51%);
    background-size: 140px 140px;
    opacity: 0.28;
}

.tb-corp-shell {
    position: relative;
    z-index: 1;
    width: min(100%, 1120px);
    margin: 0 auto;
}

.tb-corp-hero,
.tb-corp-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1.5rem;
}

.tb-corp-invite-wrap {
    display: flex;
    justify-content: center;
    padding: 1rem 0;
}

.tb-corp-frame {
    position: relative;
    width: min(100%, 430px);
    padding: 1.4rem;
    border-radius: 1.9rem;
    background:
        linear-gradient(135deg, rgba(199, 164, 106, 0.16), rgba(255, 255, 255, 0.78)),
        rgba(255, 255, 255, 0.7);
    box-shadow: var(--tbcorp-shadow);
    border: 1px solid rgba(199, 164, 106, 0.18);
}

.tb-corp-frame::before {
    content: "";
    position: absolute;
    inset: 1rem;
    border-radius: 1.45rem;
    border: 1px solid rgba(199, 164, 106, 0.24);
    pointer-events: none;
}

.tb-corp-card {
    position: relative;
    overflow: hidden;
    border-radius: 1.5rem;
    padding: 2.1rem 1.75rem 1.9rem;
    background: linear-gradient(180deg, rgba(15, 27, 45, 0.98), rgba(26, 39, 62, 0.96));
    color: #f5f6f8;
    text-align: center;
}

.tb-corp-card::before,
.tb-corp-card::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(199, 164, 106, 0.18), rgba(199, 164, 106, 0));
    pointer-events: none;
}

.tb-corp-card::before {
    width: 220px;
    height: 220px;
    top: -110px;
    right: -110px;
}

.tb-corp-card::after {
    width: 180px;
    height: 180px;
    bottom: -80px;
    left: -70px;
}

.tb-corp-badge {
    width: 58px;
    height: 58px;
    margin: 0 auto 1rem;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: radial-gradient(circle at 30% 30%, #d9bd8d, #c7a46a);
    color: var(--tbcorp-secondary);
    font-family: var(--tbcorp-font-display);
    font-size: 1.7rem;
    font-weight: 700;
    box-shadow: 0 10px 18px rgba(199, 164, 106, 0.18);
}

.tb-corp-kicker,
.tb-corp-panel-kicker,
.tb-corp-info-label,
.tb-corp-countdown-label {
    font-size: 0.7rem;
    letter-spacing: 0.26em;
    text-transform: uppercase;
}

.tb-corp-kicker {
    color: rgba(245, 246, 248, 0.68);
}

.tb-corp-card-title,
.tb-corp-heading,
.tb-corp-section-title,
.tb-corp-mini-title,
.tb-corp-guest-name {
    font-family: var(--tbcorp-font-display);
}

.tb-corp-card-title {
    margin: 0;
    font-size: clamp(2.8rem, 5vw, 4.4rem);
    line-height: 0.92;
    color: #fff;
    font-weight: 600;
}

.tb-corp-divider {
    width: 72px;
    height: 1px;
    margin: 1.1rem auto;
    background: linear-gradient(90deg, transparent, var(--tbcorp-accent), transparent);
}

.tb-corp-card-copy,
.tb-corp-text,
.tb-corp-section-copy,
.tb-corp-detail-value {
    line-height: 1.85;
    font-size: 0.95rem;
}

.tb-corp-card-copy {
    color: rgba(245, 246, 248, 0.72);
}

.tb-corp-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1.5rem;
    text-align: left;
}

.tb-corp-meta-box,
.tb-corp-info-card,
.tb-corp-guest-card,
.tb-corp-countdown-box {
    border-radius: 1rem;
}

.tb-corp-meta-box {
    padding: 0.8rem 0.9rem;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.tb-corp-meta-box span {
    display: block;
    margin-bottom: 0.35rem;
    color: rgba(245, 246, 248, 0.5);
    font-size: 0.66rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.tb-corp-meta-box strong {
    display: block;
    color: #fff;
    font-size: 0.95rem;
    font-weight: 600;
    line-height: 1.5;
}

.tb-corp-copy {
    max-width: 520px;
}

.tb-corp-eyebrow {
    margin-bottom: 0.5rem;
    color: color-mix(in srgb, var(--tbcorp-accent) 88%, black 12%);
    font-size: 0.88rem;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    font-weight: 700;
}

.tb-corp-heading {
    margin: 0;
    font-size: clamp(3.3rem, 7vw, 5.4rem);
    line-height: 0.94;
    color: var(--tbcorp-secondary);
    font-weight: 700;
}

.tb-corp-text,
.tb-corp-section-copy,
.tb-corp-detail-value {
    color: color-mix(in srgb, var(--tbcorp-secondary) 68%, white 32%);
}

.tb-corp-text {
    margin: 1.1rem 0 1.5rem;
    max-width: 430px;
}

.tb-corp-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    align-items: stretch;
}

.tb-corp-button-primary,
.tb-corp-button-secondary,
.tb-corp-select-card {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    min-height: 48px;
    padding: 0.85rem 1.3rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
    cursor: pointer;
}

.tb-corp-button-primary:hover,
.tb-corp-button-secondary:hover,
.tb-corp-select-card:hover {
    transform: translateY(-1px);
}

.tb-corp-button-primary {
    background: linear-gradient(135deg, var(--tbcorp-secondary), var(--tbcorp-primary));
    color: white;
    box-shadow: var(--tbcorp-shadow-soft);
}

.tb-corp-button-primary--static {
    cursor: default;
}

.tb-corp-button-secondary {
    min-width: 220px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(34, 53, 83, 0.1);
    box-shadow: var(--tbcorp-shadow-soft);
    color: var(--tbcorp-secondary);
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
}

.tb-corp-button-secondary strong {
    font-size: 0.9rem;
}

.tb-corp-button-secondary span {
    font-size: 0.78rem;
    color: color-mix(in srgb, var(--tbcorp-secondary) 54%, white 46%);
    font-weight: 500;
}

.tb-corp-button-secondary--inline {
    min-width: auto;
    justify-content: center;
    align-items: center;
}

.tb-corp-countdown-panel,
.tb-corp-panel {
    border: 1px solid rgba(34, 53, 83, 0.12);
    box-shadow: var(--tbcorp-shadow);
    backdrop-filter: blur(8px);
    background: rgba(255, 255, 255, 0.86);
}

.tb-corp-countdown-panel {
    margin: 1.75rem auto 0;
    width: 100%;
    max-width: 680px;
    padding: 1.4rem 1.5rem 1.6rem;
    border-radius: 1.7rem;
}

.tb-corp-countdown {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1rem;
}

.tb-corp-countdown-box {
    padding: 0.95rem 0.7rem;
    text-align: center;
    background: rgba(34, 53, 83, 0.04);
}

.tb-corp-countdown-box .countdown-value {
    font-family: var(--tbcorp-font-display);
    font-size: 2rem;
    font-weight: 600;
    color: var(--tbcorp-secondary);
}

.tb-corp-panel-kicker,
.tb-corp-info-label,
.tb-corp-countdown-label {
    color: color-mix(in srgb, var(--tbcorp-secondary) 58%, white 42%);
}

.tb-corp-main,
.tb-corp-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.tb-corp-panel {
    border-radius: 1.8rem;
    padding: 1.75rem;
}

.tb-corp-highlight-panel {
    background:
        radial-gradient(circle at top right, rgba(199, 164, 106, 0.1), transparent 24%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 248, 250, 0.94));
}

.tb-corp-panel-soft {
    background: linear-gradient(180deg, rgba(247, 248, 250, 0.96), rgba(255, 255, 255, 0.9));
}

.tb-corp-section-title {
    margin-top: 0.75rem;
    font-size: clamp(2rem, 4vw, 2.9rem);
    line-height: 1.03;
    color: var(--tbcorp-secondary);
}

.tb-corp-section-title-sm {
    font-size: clamp(1.8rem, 3.5vw, 2.3rem);
}

.tb-corp-mini-title {
    margin-top: 0.65rem;
    font-size: 1.55rem;
    line-height: 1.12;
    color: var(--tbcorp-secondary);
}

.tb-corp-info-grid,
.tb-corp-columns {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1rem;
    margin-top: 1.5rem;
}

.tb-corp-info-card {
    padding: 1.1rem 1.15rem;
    background: rgba(34, 53, 83, 0.04);
}

.tb-corp-info-value {
    margin-top: 0.45rem;
    font-family: var(--tbcorp-font-display);
    font-size: 1.3rem;
    color: var(--tbcorp-secondary);
    line-height: 1.2;
}

.tb-corp-detail-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1rem;
}

.tb-corp-rsvp-panel {
    position: sticky;
    top: 1rem;
}

.tb-corp-guest-card {
    margin-top: 1rem;
    padding: 1.15rem;
    background: rgba(34, 53, 83, 0.04);
}

.tb-corp-guest-name {
    margin-top: 0.35rem;
    font-size: 1.9rem;
    line-height: 1.08;
    color: var(--tbcorp-secondary);
}

.tb-corp-form-stack,
.tb-corp-select-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1.2rem;
}

.tb-corp-select-card {
    width: 100%;
    justify-content: space-between;
    border-radius: 1rem;
    border: 1px solid rgba(34, 53, 83, 0.1);
    background: rgba(255, 255, 255, 0.82);
    color: var(--tbcorp-secondary);
    text-align: left;
}

.tb-corp-alert {
    margin-top: 1.2rem;
    border-radius: 1rem;
    padding: 1.1rem 1.15rem;
}

.tb-corp-alert-success {
    border: 1px solid rgba(34, 197, 94, 0.18);
    background: rgba(34, 197, 94, 0.08);
    color: #166534;
}

.tb-corp-alert-warning {
    border: 1px solid rgba(245, 158, 11, 0.18);
    background: rgba(245, 158, 11, 0.1);
    color: #9a5b00;
}

.tb-corp-alert-title {
    font-weight: 700;
}

.tb-corp-alert-copy {
    margin-top: 0.4rem;
    font-size: 0.94rem;
    line-height: 1.7;
}

.tb-corp-action-row {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 1rem;
}

@media (min-width: 768px) {
    .tb-corp-info-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

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

    .tb-corp-action-row {
        flex-direction: row;
    }
}

@media (min-width: 1024px) {
    .tb-corp-page {
        padding: 3rem 1.5rem 4rem;
    }

    .tb-corp-hero {
        grid-template-columns: minmax(0, 0.96fr) minmax(0, 1.04fr);
        gap: 2.6rem;
        align-items: center;
        min-height: 76vh;
    }

    .tb-corp-grid {
        grid-template-columns: minmax(0, 1.12fr) minmax(360px, 0.88fr);
        gap: 1.9rem;
        margin-top: 2rem;
    }
}

.tb-wedding-page {
    min-height: 100vh;
    padding: 2rem 1rem 3rem;
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.92), rgba(255, 250, 247, 0.95) 44%, rgba(248, 238, 234, 0.92)),
        linear-gradient(180deg, #fffdfb 0%, #fff6f2 100%);
    color: color-mix(in srgb, var(--tbw-secondary) 88%, white 12%);
    font-family: var(--tbw-font-body);
    overflow-x: hidden;
}

.tb-wedding-page::before,
.tb-wedding-page::after {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
}

.tb-wedding-page::before {
    background:
        radial-gradient(circle at 14% 18%, rgba(233, 207, 200, 0.34) 0 2px, transparent 3px),
        radial-gradient(circle at 84% 20%, rgba(233, 207, 200, 0.32) 0 2px, transparent 3px),
        radial-gradient(circle at 10% 78%, rgba(233, 207, 200, 0.3) 0 2px, transparent 3px),
        radial-gradient(circle at 90% 76%, rgba(233, 207, 200, 0.3) 0 2px, transparent 3px);
    opacity: 0.9;
}

.tb-wedding-page::after {
    background:
        linear-gradient(45deg, transparent 49%, rgba(217, 168, 157, 0.06) 50%, transparent 51%),
        linear-gradient(-45deg, transparent 49%, rgba(217, 168, 157, 0.04) 50%, transparent 51%);
    background-size: 140px 140px;
    opacity: 0.18;
}

.tb-wedding-shell {
    position: relative;
    z-index: 1;
    width: min(100%, 1120px);
    margin: 0 auto;
}

.tb-wedding-hero,
.tb-wedding-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1.5rem;
}

.tb-wedding-invite-wrap {
    display: flex;
    justify-content: center;
    padding: 1rem 0;
}

.tb-wedding-frame {
    position: relative;
    width: min(100%, 430px);
    padding: 1.25rem;
    border-radius: 2rem;
    background:
        linear-gradient(135deg, rgba(235, 207, 200, 0.5), rgba(255, 255, 255, 0.82)),
        rgba(255, 255, 255, 0.72);
    box-shadow: var(--tbw-shadow);
    border: 1px solid rgba(200, 164, 110, 0.14);
}

.tb-wedding-frame::before {
    content: "";
    position: absolute;
    inset: 0.9rem;
    border-radius: 1.5rem;
    border: 1px solid rgba(200, 164, 110, 0.2);
    pointer-events: none;
}

.tb-wedding-card {
    position: relative;
    overflow: hidden;
    border-radius: 1.5rem;
    padding: 2.1rem 1.75rem 1.9rem;
    text-align: center;
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.74), rgba(255, 247, 243, 0.95)),
        linear-gradient(180deg, #fffdfb, #fff4ef);
}

.tb-wedding-card::before,
.tb-wedding-card::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(217, 168, 157, 0.2), rgba(217, 168, 157, 0));
    pointer-events: none;
}

.tb-wedding-card::before {
    width: 200px;
    height: 200px;
    top: -90px;
    right: -90px;
}

.tb-wedding-card::after {
    width: 150px;
    height: 150px;
    bottom: -70px;
    left: -55px;
}

.tb-wedding-badge {
    width: 60px;
    height: 60px;
    margin: 0 auto 1rem;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: radial-gradient(circle at 30% 30%, #e2c18c, var(--tbw-accent));
    color: #fff9f2;
    font-family: var(--tbw-font-display);
    font-size: 1.7rem;
    font-weight: 700;
    box-shadow: 0 10px 18px rgba(200, 164, 110, 0.2);
}

.tb-wedding-kicker,
.tb-wedding-panel-kicker,
.tb-wedding-info-label,
.tb-wedding-countdown-label {
    font-size: 0.7rem;
    letter-spacing: 0.26em;
    text-transform: uppercase;
}

.tb-wedding-kicker {
    color: color-mix(in srgb, var(--tbw-primary) 58%, white 42%);
}

.tb-wedding-card-title,
.tb-wedding-heading,
.tb-wedding-section-title,
.tb-wedding-mini-title,
.tb-wedding-guest-name {
    font-family: var(--tbw-font-display);
}

.tb-wedding-card-title {
    margin: 0;
    font-family: var(--tbw-font-script);
    font-size: clamp(3.1rem, 5vw, 4.8rem);
    line-height: 0.9;
    color: var(--tbw-primary);
    font-weight: 400;
}

.tb-wedding-divider {
    width: 72px;
    height: 1px;
    margin: 1rem auto 1.15rem;
    background: linear-gradient(90deg, transparent, var(--tbw-accent), transparent);
}

.tb-wedding-card-copy,
.tb-wedding-text,
.tb-wedding-section-copy,
.tb-wedding-detail-value {
    line-height: 1.85;
    font-size: 0.95rem;
}

.tb-wedding-card-copy {
    color: color-mix(in srgb, var(--tbw-secondary) 62%, white 38%);
}

.tb-wedding-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1.5rem;
    text-align: left;
}

.tb-wedding-meta-box,
.tb-wedding-info-card,
.tb-wedding-guest-card,
.tb-wedding-countdown-box {
    border-radius: 1rem;
}

.tb-wedding-meta-box {
    padding: 0.8rem 0.9rem;
    background: rgba(255, 255, 255, 0.55);
    border: 1px solid rgba(187, 132, 120, 0.1);
}

.tb-wedding-meta-box span {
    display: block;
    margin-bottom: 0.35rem;
    color: color-mix(in srgb, var(--tbw-primary) 62%, white 38%);
    font-size: 0.66rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.tb-wedding-meta-box strong {
    display: block;
    color: var(--tbw-secondary);
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.5;
}

.tb-wedding-copy {
    max-width: 520px;
}

.tb-wedding-eyebrow {
    margin-bottom: 0.5rem;
    color: color-mix(in srgb, var(--tbw-accent) 88%, black 12%);
    font-size: 0.88rem;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    font-weight: 700;
}

.tb-wedding-heading {
    margin: 0;
    font-size: clamp(3.2rem, 7vw, 5.4rem);
    line-height: 0.94;
    color: var(--tbw-secondary);
    font-weight: 700;
}

.tb-wedding-text,
.tb-wedding-section-copy,
.tb-wedding-detail-value {
    color: color-mix(in srgb, var(--tbw-secondary) 68%, white 32%);
}

.tb-wedding-text {
    margin: 1.1rem 0 1.5rem;
    max-width: 430px;
}

.tb-wedding-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    align-items: stretch;
}

.tb-wedding-button-primary,
.tb-wedding-button-secondary,
.tb-wedding-select-card {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    min-height: 48px;
    padding: 0.85rem 1.3rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
    cursor: pointer;
}

.tb-wedding-button-primary:hover,
.tb-wedding-button-secondary:hover,
.tb-wedding-select-card:hover {
    transform: translateY(-1px);
}

.tb-wedding-button-primary {
    background: linear-gradient(135deg, #c39183, #ad756a);
    color: white;
    box-shadow: var(--tbw-shadow-soft);
}

.tb-wedding-button-primary--static {
    cursor: default;
}

.tb-wedding-button-secondary {
    min-width: 220px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(187, 132, 120, 0.12);
    box-shadow: var(--tbw-shadow-soft);
    color: var(--tbw-secondary);
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
}

.tb-wedding-button-secondary strong {
    font-size: 0.9rem;
}

.tb-wedding-button-secondary span {
    font-size: 0.78rem;
    color: color-mix(in srgb, var(--tbw-secondary) 54%, white 46%);
    font-weight: 500;
}

.tb-wedding-button-secondary--inline {
    min-width: auto;
    justify-content: center;
    align-items: center;
}

.tb-wedding-countdown-panel,
.tb-wedding-panel {
    border: 1px solid rgba(187, 132, 120, 0.16);
    box-shadow: var(--tbw-shadow);
    backdrop-filter: blur(8px);
}

.tb-wedding-countdown-panel {
    margin: 1.75rem auto 0;
    width: 100%;
    max-width: 680px;
    padding: 1.4rem 1.5rem 1.6rem;
    border-radius: 1.7rem;
    background: linear-gradient(180deg, rgba(255, 247, 243, 0.84), rgba(255, 250, 247, 0.9));
}

.tb-wedding-countdown {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1rem;
}

.tb-wedding-countdown-box {
    padding: 0.95rem 0.7rem;
    text-align: center;
    background: rgba(255, 255, 255, 0.48);
}

.tb-wedding-countdown-box .countdown-value {
    font-family: var(--tbw-font-display);
    font-size: 2rem;
    font-weight: 600;
    color: var(--tbw-secondary);
}

.tb-wedding-panel-kicker,
.tb-wedding-info-label,
.tb-wedding-countdown-label {
    color: color-mix(in srgb, var(--tbw-primary) 58%, white 42%);
}

.tb-wedding-main,
.tb-wedding-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.tb-wedding-panel {
    border-radius: 1.8rem;
    padding: 1.75rem;
    background: rgba(255, 255, 255, 0.82);
}

.tb-wedding-highlight-panel {
    background:
        radial-gradient(circle at top right, rgba(217, 168, 157, 0.1), transparent 24%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 246, 243, 0.94));
}

.tb-wedding-panel-soft {
    background: linear-gradient(180deg, rgba(255, 247, 243, 0.96), rgba(255, 255, 255, 0.9));
}

.tb-wedding-section-title {
    margin-top: 0.75rem;
    font-size: clamp(2rem, 4vw, 2.9rem);
    line-height: 1.03;
    color: var(--tbw-secondary);
}

.tb-wedding-section-title-sm {
    font-size: clamp(1.8rem, 3.5vw, 2.3rem);
}

.tb-wedding-mini-title {
    margin-top: 0.65rem;
    font-size: 1.55rem;
    line-height: 1.12;
    color: var(--tbw-secondary);
}

.tb-wedding-info-grid,
.tb-wedding-columns {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1rem;
    margin-top: 1.5rem;
}

.tb-wedding-info-card {
    padding: 1.1rem 1.15rem;
    background: rgba(255, 255, 255, 0.55);
}

.tb-wedding-info-value {
    margin-top: 0.45rem;
    font-family: var(--tbw-font-display);
    font-size: 1.3rem;
    color: var(--tbw-secondary);
    line-height: 1.2;
}

.tb-wedding-detail-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1rem;
}

.tb-wedding-rsvp-panel {
    position: sticky;
    top: 1rem;
}

.tb-wedding-guest-card {
    margin-top: 1rem;
    padding: 1.15rem;
    background: rgba(255, 255, 255, 0.52);
}

.tb-wedding-guest-name {
    margin-top: 0.35rem;
    font-size: 1.9rem;
    line-height: 1.08;
    color: var(--tbw-secondary);
}

.tb-wedding-form-stack,
.tb-wedding-select-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1.2rem;
}

.tb-wedding-select-card {
    width: 100%;
    justify-content: space-between;
    border-radius: 1rem;
    border: 1px solid rgba(187, 132, 120, 0.12);
    background: rgba(255, 255, 255, 0.82);
    color: var(--tbw-secondary);
    text-align: left;
}

.tb-wedding-alert {
    margin-top: 1.2rem;
    border-radius: 1rem;
    padding: 1.1rem 1.15rem;
}

.tb-wedding-alert-success {
    border: 1px solid rgba(34, 197, 94, 0.18);
    background: rgba(34, 197, 94, 0.08);
    color: #166534;
}

.tb-wedding-alert-warning {
    border: 1px solid rgba(245, 158, 11, 0.18);
    background: rgba(245, 158, 11, 0.1);
    color: #9a5b00;
}

.tb-wedding-alert-title {
    font-weight: 700;
}

.tb-wedding-alert-copy {
    margin-top: 0.4rem;
    font-size: 0.94rem;
    line-height: 1.7;
}

.tb-wedding-action-row {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 1rem;
}

@media (min-width: 768px) {
    .tb-wedding-info-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

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

    .tb-wedding-action-row {
        flex-direction: row;
    }
}

@media (min-width: 1024px) {
    .tb-wedding-page {
        padding: 3rem 1.5rem 4rem;
    }

    .tb-wedding-hero {
        grid-template-columns: minmax(0, 0.96fr) minmax(0, 1.04fr);
        gap: 2.6rem;
        align-items: center;
        min-height: 76vh;
    }

    .tb-wedding-grid {
        grid-template-columns: minmax(0, 1.12fr) minmax(360px, 0.88fr);
        gap: 1.9rem;
        margin-top: 2rem;
    }
}
