.tm-reservas {
    --tm-bg: #f7fbfb;
    --tm-surface: #FFFFFF;
    --tm-surface-soft: #F6FAFB;
    --tm-ink: #091A28;
    --tm-navy: #102335;
    --tm-muted: #60717D;
    --tm-line: #DCE8EA;
    --tm-accent: #20A6BD;
    --tm-accent-dark: #187A8C;
    --tm-sand: #D3A359;
    color: var(--tm-ink);
    font-family: "Montserrat", inherit;
}

/* Contextual guide and commercial panel refinements. */
.tm-op-shell.is-guide-active [data-tm-guide-title] {
    cursor: help;
    outline: 2px solid rgba(211, 163, 89, .42);
    outline-offset: 4px;
}

.tm-op-shell .tm-op-guide-control button {
    min-width: 118px;
}

.tm-op-guide-modal[hidden] {
    display: none !important;
}

.tm-op-guide-backdrop {
    background: rgba(9, 26, 40, .36);
    inset: 0;
    position: fixed;
    z-index: 99998;
}

.tm-op-guide-dialog {
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .10);
    border-left: 5px solid #D3A359;
    border-radius: 22px;
    box-shadow: 0 24px 70px rgba(9, 26, 40, .24);
    color: #102335;
    left: 50%;
    max-width: min(520px, calc(100vw - 32px));
    padding: 28px;
    position: fixed;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    z-index: 99999;
}

.tm-op-guide-dialog > span,
.tm-reseller-section-head span,
.tm-reseller-summary span {
    color: #D3A359;
    display: block;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.tm-op-guide-dialog h3 {
    color: #091A28;
    font-size: clamp(26px, 3vw, 40px);
    letter-spacing: -.04em;
    line-height: 1;
    margin: 8px 0 12px;
}

.tm-op-guide-dialog p {
    color: #526A75;
    font-size: 17px;
    line-height: 1.55;
    margin: 0;
}

.tm-op-guide-close {
    align-items: center;
    background: #102335;
    border: 0;
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    font-size: 24px;
    font-weight: 800;
    height: 38px;
    justify-content: center;
    line-height: 1;
    position: absolute;
    right: 18px;
    top: 18px;
    width: 38px;
}

.tm-reseller-summary {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tm-reseller-summary article {
    background: linear-gradient(135deg, #FFFFFF 0%, #F8FBFB 100%);
    border: 1px solid rgba(16, 35, 53, .09);
    border-radius: 18px;
    padding: 18px;
}

.tm-reseller-summary strong {
    color: #091A28;
    display: block;
    font-size: clamp(28px, 3vw, 42px);
    line-height: 1;
    margin-top: 10px;
}

.tm-reseller-section-head {
    align-items: end;
    border-bottom: 1px solid rgba(16, 35, 53, .08);
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 420px);
    margin-bottom: 20px;
    padding-bottom: 18px;
}

.tm-reseller-section-head h3 {
    color: #091A28;
    font-size: clamp(28px, 3vw, 42px);
    letter-spacing: -.04em;
    line-height: 1;
    margin: 8px 0 0;
}

.tm-reseller-section-head p {
    color: #526A75;
    line-height: 1.6;
    margin: 0;
}

@media (max-width: 900px) {
    .tm-reseller-summary,
    .tm-reseller-section-head {
        grid-template-columns: 1fr;
    }
}

.tm-reservas-panel,
.tm-reservas-booking,
.tm-reservas-card {
    background: var(--tm-surface);
    border: 1px solid rgba(16, 35, 53, .11);
    border-radius: 16px;
    box-shadow: 0 20px 55px rgba(9, 26, 40, .07);
    padding: 20px;
}

.tm-reservas-booking {
    background:
        radial-gradient(circle at 100% 0%, rgba(32, 166, 189, .08), transparent 34%),
        linear-gradient(180deg, #FFFFFF 0%, #FBFDFD 100%);
    border: 1px solid transparent;
    outline: 1px solid rgba(16, 35, 53, .10);
    padding: clamp(18px, 3vw, 28px);
    overflow: visible;
}

.tm-reservas-booking-hero {
    position: relative;
}

.tm-reservas-booking-hero::before {
    background: linear-gradient(90deg, var(--tm-navy) 0%, var(--tm-accent) 62%, var(--tm-sand) 100%);
    border-radius: 16px 16px 0 0;
    content: "";
    height: 5px;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
}

.tm-reservas-grid,
.tm-reservas-admin-grid {
    display: grid;
    gap: 14px;
}

.tm-reservas-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tm-reservas-booking-grid {
    align-items: end;
    grid-template-columns: minmax(180px, .86fr) minmax(260px, 1.32fr) 112px;
}

.tm-reservas-primary-grid {
    align-items: end;
    grid-template-columns: minmax(180px, .72fr) minmax(280px, 1.45fr);
}

.tm-reservas-boat-passenger-grid {
    align-items: end;
    grid-template-columns: minmax(280px, 1fr) 118px;
}

.tm-reservas-admin-grid {
    grid-template-columns: minmax(280px, 360px) 1fr;
    align-items: start;
}

.tm-reservas-form {
    display: grid;
    gap: 20px;
}

.tm-reservas-form-surface {
    background: rgba(255, 255, 255, .82);
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 20px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .85);
    padding: clamp(14px, 2.3vw, 22px);
    overflow: visible;
}

.tm-reservas-quote-layout {
    align-items: stretch;
    display: grid;
    gap: clamp(18px, 3vw, 28px);
    grid-template-columns: minmax(0, 1.55fr) minmax(260px, .75fr);
}

.tm-reservas-step-title {
    border-bottom: 1px solid rgba(16, 35, 53, .09);
    padding-bottom: 12px;
}

.tm-reservas-step-title span,
.tm-reservas-kicker {
    color: var(--tm-sand);
    display: block;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.tm-reservas-step-title strong {
    color: var(--tm-navy);
    display: block;
    font-size: clamp(22px, 2.5vw, 32px);
    line-height: 1.05;
    margin-top: 4px;
}

.tm-reservas-step-title p {
    color: var(--tm-muted);
    margin: 8px 0 0;
}

.tm-route-preview-card {
    align-self: start;
    position: sticky;
    top: 24px;
}

.tm-route-preview {
    aspect-ratio: 1 / 1;
    background:
        linear-gradient(135deg, rgba(16, 35, 53, .82), rgba(16, 35, 53, .42)),
        radial-gradient(circle at 72% 18%, rgba(32, 166, 189, .18), transparent 34%);
    border-radius: 18px;
    box-shadow: 0 18px 44px rgba(9, 26, 40, .12);
    min-height: 260px;
    overflow: hidden;
    position: relative;
}

.tm-route-preview::after {
    background: linear-gradient(180deg, transparent 40%, rgba(9, 26, 40, .84) 100%);
    bottom: 0;
    content: "";
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
}

.tm-route-preview img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.tm-route-preview-caption {
    bottom: 0;
    color: #fff;
    left: 0;
    padding: 22px;
    position: absolute;
    right: 0;
    z-index: 1;
}

.tm-route-preview-caption span {
    color: var(--tm-sand);
    display: block;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.tm-route-preview-caption strong {
    display: block;
    font-size: clamp(24px, 2.4vw, 34px);
    line-height: 1.05;
    margin-top: 6px;
    text-shadow: 0 8px 24px rgba(0, 0, 0, .22);
}

.tm-route-preview-placeholder {
    align-items: flex-start;
    background:
        radial-gradient(circle at 82% 18%, rgba(76, 202, 225, .22), transparent 26%),
        linear-gradient(145deg, #102335, #0B1E2E);
    color: #fff;
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: flex-end;
    padding: 22px;
}

.tm-route-preview-placeholder span {
    color: var(--tm-sand);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.tm-route-preview-placeholder strong {
    font-size: 26px;
    line-height: 1.08;
    margin-top: 8px;
}

.tm-route-preview-description {
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(16, 35, 53, .09);
    border-radius: 16px;
    box-shadow: 0 16px 38px rgba(9, 26, 40, .06);
    color: #4D6470;
    font-size: 15px;
    line-height: 1.55;
    margin: 14px 0 0;
    padding: 16px 18px;
}

.tm-reservas-grid-compact {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
}

.tm-reservas-quote-result {
    align-items: center;
    background: linear-gradient(135deg, rgba(16, 35, 53, .04), rgba(32, 166, 189, .07));
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 16px;
    display: grid;
    gap: 16px;
    grid-template-columns: 1fr auto;
    margin-bottom: 18px;
    padding: 18px;
}

.tm-reservas-quote-result h3 {
    color: var(--tm-navy);
    font-size: 28px;
    margin: 4px 0 0;
}

.tm-reservas-quote-result p {
    color: var(--tm-muted);
    margin: 6px 0 0;
}

.tm-reservas-price-summary {
    background: #fff;
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 14px;
    display: grid;
    gap: 2px;
    min-width: 220px;
    padding: 14px;
}

.tm-reservas-price-summary strong {
    color: var(--tm-navy);
    font-size: 20px;
}

.tm-reservas-price-summary span {
    color: var(--tm-muted);
    font-size: 12px;
    font-weight: 700;
    margin-bottom: 8px;
    text-transform: uppercase;
}

.tm-quote-offer {
    background:
        radial-gradient(circle at 100% 0%, rgba(211, 163, 89, .14), transparent 32%),
        linear-gradient(145deg, #FFFFFF 0%, #F9FCFC 100%);
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 22px;
    box-shadow: 0 22px 58px rgba(9, 26, 40, .09);
    display: grid;
    gap: 18px;
    padding: clamp(18px, 3vw, 30px);
}

.tm-quote-offer-head h3 {
    color: var(--tm-navy);
    font-size: clamp(30px, 4vw, 48px);
    line-height: .98;
    margin: 6px 0 0;
}

.tm-quote-code {
    color: var(--tm-muted);
    margin: 10px 0 0;
}

.tm-quote-code strong {
    color: var(--tm-navy);
}

.tm-quote-essentials {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.tm-quote-essentials span {
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 999px;
    color: var(--tm-navy);
    font-size: 14px;
    font-weight: 800;
    padding: 9px 12px;
}

.tm-quote-money {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tm-quote-money > div,
.tm-quote-boat,
.tm-quote-conditions {
    background: rgba(255, 255, 255, .88);
    border: 1px solid rgba(16, 35, 53, .09);
    border-radius: 18px;
    box-shadow: 0 14px 34px rgba(9, 26, 40, .055);
    padding: 16px;
}

.tm-quote-money span {
    color: var(--tm-muted);
    display: block;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.tm-quote-money strong {
    color: var(--tm-navy);
    display: block;
    font-size: clamp(20px, 2.4vw, 30px);
    line-height: 1;
    margin-top: 8px;
}

.tm-quote-deposit {
    background: linear-gradient(135deg, rgba(211, 163, 89, .16), #FFFFFF) !important;
    border-color: rgba(211, 163, 89, .32) !important;
}

.tm-quote-boat h4 {
    color: var(--tm-navy);
    font-size: 18px;
    margin: 0 0 12px;
}

.tm-quote-boat > div {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
}

.tm-quote-boat span {
    background: #F5F8F8;
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 999px;
    color: #344D5A;
    font-size: 14px;
    font-weight: 800;
    padding: 8px 11px;
}

.tm-quote-conditions {
    border-left: 5px solid var(--tm-sand);
}

.tm-quote-conditions strong {
    color: var(--tm-navy);
    display: block;
    margin-bottom: 6px;
}

.tm-quote-conditions p {
    color: #4D6470;
    line-height: 1.55;
    margin: 0;
}

.tm-route-preview-description[hidden] {
    display: none !important;
}

.tm-reservas-button-cta {
    background: linear-gradient(135deg, var(--tm-sand), #F0C06F 42%, var(--tm-navy)) !important;
    color: #FFFFFF !important;
    font-size: clamp(18px, 2.4vw, 24px);
    letter-spacing: .05em;
    min-height: 64px;
    text-transform: uppercase;
    width: 100%;
}

.tm-reservas-reserve-form-hidden {
    display: none !important;
}

.tm-reservas label span {
    display: block;
    margin-bottom: 6px;
    color: #4B5E68;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .01em;
}

.tm-reservas-form-surface label {
    position: relative;
}

.tm-reservas input,
.tm-reservas select,
.tm-reservas textarea {
    width: 100%;
    background: rgba(255, 255, 255, .96);
    border: 1px solid rgba(16, 35, 53, .14);
    border-radius: 14px;
    color: var(--tm-ink);
    min-height: 54px;
    padding: 12px 16px;
    transition: border-color .18s ease, box-shadow .18s ease;
}

.tm-reservas input:focus,
.tm-reservas select:focus,
.tm-reservas textarea:focus {
    border-color: var(--tm-accent);
    box-shadow: 0 0 0 4px rgba(32, 166, 189, .12);
    outline: 0;
}

.tm-reservas-form-surface input,
.tm-reservas-form-surface select,
.tm-reservas-form-surface textarea {
    box-shadow: 0 10px 26px rgba(9, 26, 40, .035);
}

.tm-passenger-field {
    max-width: 118px;
}

.tm-reservas .tm-passenger-input {
    min-height: 54px;
    padding-left: 10px;
    padding-right: 10px;
    text-align: center;
}

.tm-choice {
    position: relative;
    z-index: 4;
}

.tm-choice-trigger {
    align-items: center;
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .14);
    border-radius: 14px;
    box-shadow: 0 10px 26px rgba(9, 26, 40, .035);
    color: var(--tm-ink);
    cursor: pointer;
    display: flex;
    font: inherit;
    justify-content: space-between;
    min-height: 54px;
    padding: 12px 16px;
    text-align: left;
    width: 100%;
}

.tm-choice-trigger:focus {
    border-color: rgba(16, 35, 53, .32);
    box-shadow: 0 0 0 3px rgba(16, 35, 53, .08);
    outline: none;
}

.tm-choice-caret {
    color: #687984;
    font-size: 14px;
    margin-left: 10px;
}

.tm-choice-menu {
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 10px;
    box-shadow: 0 18px 45px rgba(9, 26, 40, .16);
    max-height: 250px;
    overflow: auto;
    padding: 0;
    position: fixed;
    z-index: 2147483600;
}

.tm-choice-list {
    display: grid;
}

.tm-choice-option {
    background: #FFFFFF;
    border: 0;
    border-bottom: 1px solid rgba(16, 35, 53, .07);
    border-radius: 0;
    color: #091A28;
    cursor: pointer;
    font: inherit;
    font-size: 15px;
    min-height: 38px;
    padding: 7px 12px;
    text-align: left;
    width: 100%;
}

.tm-choice-option:nth-child(even) {
    background: #F8FAFA;
}

.tm-choice-option:hover,
.tm-choice-option:focus {
    background: #F1F4F5;
    color: #102335;
    outline: none;
}

.tm-choice-option:last-child {
    border-bottom: 0;
}

.tm-reservas-check {
    display: flex;
    gap: 8px;
    align-items: center;
}

.tm-reservas-check input {
    width: auto;
    min-height: 0;
}

.tm-reservas-button,
.tm-reservas-small-button {
    align-items: center;
    border: 0;
    border-radius: 999px;
    background: var(--tm-navy);
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    font-weight: 700;
    justify-content: center;
    min-height: 54px;
    padding: 13px 20px;
    pointer-events: auto;
    position: relative;
    box-shadow: 0 14px 34px rgba(16, 35, 53, .18);
    transition: box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
    z-index: 3;
}

.tm-reservas-small-button {
    padding: 8px 10px;
    font-size: 13px;
}

.tm-reservas-button:hover,
.tm-reservas-small-button:hover {
    background: #0B1E2E;
    color: #fff;
    box-shadow: 0 17px 38px rgba(16, 35, 53, .24);
    transform: none;
}

.tm-reservas-reserve-form {
    border-top: 1px solid rgba(16, 35, 53, .09);
    display: grid;
    gap: 16px;
    margin-top: 18px;
    padding-top: 18px;
}

.tm-reservas-note,
.tm-reservas-notice,
.tm-reservas-success {
    border-radius: 6px;
    padding: 12px 14px;
}

.tm-reservas-note,
.tm-reservas-notice {
    background: linear-gradient(135deg, rgba(32, 166, 189, .055), rgba(211, 163, 89, .055));
    border: 1px solid rgba(16, 35, 53, .08);
    color: #4D6470;
}

.tm-reservas-success {
    background: #e7f8ef;
    color: #17633a;
    margin-bottom: 16px;
}

.tm-reservas-context {
    background: linear-gradient(135deg, rgba(16, 35, 53, .035), rgba(32, 166, 189, .055));
    border: 1px solid rgba(16, 35, 53, .12);
    border-radius: 14px;
    display: inline-flex;
    flex-direction: column;
    gap: 2px;
    margin: 0 10px 12px 0;
    padding: 10px 12px;
}

.tm-reservas-context span {
    color: var(--tm-muted);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
}

.tm-reservas-context strong {
    font-size: 15px;
}

.tm-reservas-context-with-passengers {
    align-items: end;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) 118px;
    margin-right: 0;
    width: 100%;
}

.tm-passenger-field-context {
    max-width: 118px;
    width: 118px;
}

.tm-reservas .tm-passenger-field-context span {
    color: var(--tm-muted);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .03em;
    text-transform: uppercase;
}

.tm-country-phone {
    position: relative;
    display: grid;
    grid-template-columns: 118px 1fr;
    z-index: 100;
}

.tm-country-trigger {
    align-items: center;
    background: #F0F3F5;
    border: 1px solid rgba(16, 35, 53, .14);
    border-radius: 14px 0 0 14px;
    color: var(--tm-navy);
    cursor: pointer;
    display: inline-flex;
    font: inherit;
    font-weight: 700;
    gap: 8px;
    justify-content: center;
    min-height: 54px;
    padding: 0 10px;
}

.tm-country-trigger:focus {
    box-shadow: 0 0 0 4px rgba(32, 166, 189, .12);
    outline: 0;
    z-index: 2;
}

.tm-country-flag {
    font-size: 22px;
    line-height: 1;
}

.tm-country-dial {
    color: var(--tm-navy);
    font-size: 17px;
    font-weight: 800;
}

.tm-country-caret {
    color: #5D6E79;
    font-size: 11px;
}

.tm-reservas .tm-country-phone-input {
    border-left: 0;
    border-radius: 0 14px 14px 0;
}

.tm-country-menu {
    background: #fff;
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 8px;
    box-shadow: 0 22px 60px rgba(9, 26, 40, .18);
    left: 0;
    max-height: 260px;
    overflow: auto;
    padding: 0;
    position: fixed;
    right: auto;
    top: calc(100% + 7px);
    z-index: 2147483000;
}

.tm-country-search {
    background: #FFFFFF;
    border-bottom: 1px solid rgba(16, 35, 53, .08);
    padding: 8px;
    position: sticky;
    top: 0;
    z-index: 2;
}

.tm-country-search input,
.tm-reservas .tm-country-search input {
    background: #F7FAFA;
    border: 1px solid rgba(16, 35, 53, .12);
    border-radius: 10px;
    box-shadow: none;
    color: var(--tm-ink);
    font-size: 14px;
    min-height: 38px;
    padding: 8px 11px;
}

.tm-country-search input:focus,
.tm-reservas .tm-country-search input:focus {
    border-color: rgba(16, 35, 53, .32);
    box-shadow: 0 0 0 3px rgba(16, 35, 53, .07);
}

.tm-country-menu::-webkit-scrollbar {
    width: 9px;
}

.tm-country-menu::-webkit-scrollbar-track {
    background: #F3F6F7;
    border-radius: 999px;
}

.tm-country-menu::-webkit-scrollbar-thumb {
    background: #C8D4D8;
    border-radius: 999px;
}

.tm-country-option {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 0;
    color: var(--tm-ink);
    cursor: pointer;
    display: grid;
    font: inherit;
    gap: 10px;
    grid-template-columns: 30px minmax(0, 1fr) auto;
    min-height: 40px;
    padding: 7px 12px;
    text-align: left;
    width: 100%;
}

.tm-country-option[hidden] {
    display: none !important;
}

.tm-country-option:hover,
.tm-country-option:focus {
    background: #F2F5F6;
    outline: 0;
}

.tm-country-option-flag {
    font-size: 18px;
    line-height: 1;
}

.tm-country-option-name {
    color: var(--tm-ink);
    font-size: 15px;
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.tm-country-option-dial {
    color: #88949B;
    font-size: 14px;
    font-weight: 500;
}

.tm-reservas-cards {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tm-reservas-card h3 {
    margin-top: 0;
}

.tm-reservas-card ul {
    margin-bottom: 0;
}

.tm-reservas-table-wrap {
    overflow-x: auto;
}

.tm-reservas-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 760px;
}

.tm-reservas-table th,
.tm-reservas-table td {
    border-bottom: 1px solid var(--tm-line);
    padding: 10px;
    text-align: left;
    vertical-align: middle;
}

.tm-reservas-table th {
    background: var(--tm-bg);
    color: var(--tm-muted);
    font-size: 13px;
    text-transform: uppercase;
}

.tm-reservas-list {
    display: grid;
    gap: 10px;
}

.tm-reservas-row-card {
    display: grid;
    gap: 8px;
    grid-template-columns: 1.5fr repeat(3, 1fr);
    background: linear-gradient(135deg, #ffffff 0%, #f8fbfb 100%);
    border: 1px solid var(--tm-line);
    border-left: 5px solid var(--tm-sand);
    border-radius: 16px;
    box-shadow: 0 16px 38px rgba(9, 26, 40, .045);
    padding: 16px;
}

.tm-reservas-boat-config {
    background: linear-gradient(135deg, #ffffff 0%, #f8fbfb 100%);
    border: 1px solid var(--tm-line);
    border-left: 5px solid var(--tm-sand);
    border-radius: 18px;
    box-shadow: 0 18px 45px rgba(9, 26, 40, .055);
    padding: 18px;
}

.tm-reservas-boat-config-header {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 12px;
}

.tm-reservas-boat-config-header strong {
    color: var(--tm-navy);
    display: block;
    font-size: 22px;
    line-height: 1.1;
}

.tm-reservas-boat-config-header span,
.tm-reservas-help {
    color: var(--tm-muted);
}

.tm-reservas-help {
    margin-top: 0;
}

.tm-reservas-panel > h2 {
    color: var(--tm-navy);
    font-size: clamp(26px, 3vw, 38px);
    line-height: 1;
    margin-top: 0;
}

.tm-reservas-panel > p {
    color: var(--tm-muted);
    font-size: 16px;
}

.tm-reservas-form {
    background: linear-gradient(135deg, #ffffff 0%, #f8fbfb 100%);
    border: 1px solid var(--tm-line);
    border-left: 5px solid #2E8B57;
    border-radius: 18px;
    box-shadow: 0 18px 45px rgba(9, 26, 40, .055);
    padding: 18px;
}

.tm-reservas-form h3 {
    color: var(--tm-navy);
    font-size: 22px;
    line-height: 1.1;
    margin-top: 0;
}

.tm-op-credit-card {
    align-items: center;
    background:
        radial-gradient(circle at 100% 0%, rgba(211,163,89,.18), transparent 34%),
        linear-gradient(135deg, var(--tm-navy), #173B54);
    border-radius: 22px;
    box-shadow: 0 24px 65px rgba(9,26,40,.18);
    color: #fff;
    display: flex;
    gap: 18px;
    justify-content: space-between;
    margin-top: 24px;
    padding: 24px;
}

.tm-op-credit-card span {
    color: var(--tm-sand);
    display: block;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.tm-op-credit-card h3 {
    color: #fff;
    font-size: 28px;
    line-height: 1;
    margin: 6px 0 8px;
}

.tm-op-credit-card p {
    color: rgba(255,255,255,.78);
    margin: 0;
}

.tm-reservas-compact-table {
    min-width: 900px;
}

.tm-reservas-compact-table input[type="number"] {
    min-width: 110px;
}

.tm-reservas-inline-fields {
    display: flex;
    gap: 8px;
}

.tm-reservas-inline-fields select {
    min-width: 76px;
}

.tm-reservas-stats {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 16px 0;
}

.tm-reservas-stats div {
    background: var(--tm-bg);
    border-radius: 8px;
    padding: 16px;
}

.tm-reservas-stats strong {
    display: block;
    font-size: 28px;
}

.tm-reservas-stats span {
    color: var(--tm-muted);
}

.tm-reservas-summary-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 16px 0;
}

.tm-reservas-summary-grid div {
    background: var(--tm-bg);
    border: 1px solid var(--tm-line);
    border-radius: 8px;
    padding: 14px;
}

.tm-reservas-summary-grid span {
    color: var(--tm-muted);
    display: block;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
}

.tm-reservas-summary-grid strong {
    display: block;
    margin-top: 4px;
}

.tm-op-dashboard {
    background:
        radial-gradient(circle at 100% 0%, rgba(211, 163, 89, .12), transparent 28%),
        linear-gradient(180deg, #FFFFFF 0%, #F8FBFB 100%);
    overflow: hidden;
}

.tm-op-hero {
    align-items: center;
    background: linear-gradient(135deg, #102335 0%, #173B54 100%);
    border-radius: 18px;
    color: #FFFFFF;
    display: grid;
    gap: 18px;
    grid-template-columns: 1fr auto;
    margin-bottom: 18px;
    padding: clamp(20px, 3vw, 30px);
}

.tm-op-hero h2 {
    color: #FFFFFF;
    font-size: clamp(28px, 3vw, 42px);
    line-height: 1;
    margin: 5px 0 8px;
}

.tm-op-hero p {
    color: rgba(255, 255, 255, .78);
    margin: 0;
}

.tm-op-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.tm-op-actions a,
.tm-op-metrics a {
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 999px;
    color: #102335;
    display: inline-flex;
    font-weight: 800;
    padding: 10px 14px;
    text-decoration: none;
}

.tm-op-actions a:hover,
.tm-op-metrics a:hover {
    background: #F1F4F5;
    color: #102335;
}

.tm-op-metrics {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.tm-op-metrics article {
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .09);
    border-radius: 18px;
    box-shadow: 0 16px 38px rgba(9, 26, 40, .055);
    padding: 18px;
}

.tm-op-metrics span,
.tm-op-section-title span {
    color: var(--tm-sand);
    display: block;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.tm-op-metrics strong {
    color: var(--tm-navy);
    display: block;
    font-size: 42px;
    line-height: 1;
    margin: 10px 0 14px;
}

.tm-op-metrics a {
    background: #F7FAFA;
    font-size: 13px;
    padding: 8px 11px;
}

.tm-op-validator {
    margin-top: 22px;
}

.tm-op-terms,
.tm-op-tables {
    margin-top: 24px;
}

.tm-op-terms-card {
    align-items: center;
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .09);
    border-radius: 18px;
    box-shadow: 0 16px 38px rgba(9, 26, 40, .055);
    display: grid;
    gap: 18px;
    grid-template-columns: 1fr auto;
    padding: 18px;
}

.tm-op-terms-card > div > strong {
    color: var(--tm-navy);
    display: block;
    font-size: 36px;
    line-height: 1;
    margin-bottom: 8px;
}

.tm-op-terms-card p {
    color: var(--tm-muted);
    margin: 0;
}

.tm-op-terms-list {
    display: grid;
    gap: 8px;
    min-width: 260px;
}

.tm-op-terms-list span {
    background: #F7FAFA;
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 999px;
    color: var(--tm-muted);
    display: flex;
    gap: 6px;
    justify-content: space-between;
    padding: 9px 12px;
}

.tm-op-terms-list strong {
    color: var(--tm-navy);
}

.tm-op-list-table {
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .09);
    border-radius: 16px;
    box-shadow: 0 16px 38px rgba(9, 26, 40, .045);
    overflow: hidden;
}

.tm-op-list-table td small {
    color: var(--tm-muted);
}

.tm-op-status {
    background: #E7F7EF;
    border-radius: 999px;
    color: #17633A;
    display: inline-flex;
    font-size: 12px;
    font-weight: 900;
    padding: 5px 9px;
}

.tm-op-section-title h3 {
    color: var(--tm-navy);
    font-size: 26px;
    margin: 4px 0 14px;
}

.tm-op-checks {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.tm-op-checks article {
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .09);
    border-radius: 15px;
    padding: 14px;
}

.tm-op-checks article > span {
    border-radius: 999px;
    display: inline-flex;
    font-size: 12px;
    font-weight: 900;
    margin-bottom: 10px;
    padding: 5px 9px;
}

.tm-op-checks article.is-complete > span {
    background: #E7F7EF;
    color: #17633A;
}

.tm-op-checks article.is-pending > span {
    background: #FFF3D8;
    color: #8A5A00;
}

.tm-op-checks strong {
    color: var(--tm-navy);
    display: block;
}

.tm-op-checks p {
    color: var(--tm-muted);
    font-size: 13px;
    margin: 6px 0 0;
}

@media (max-width: 900px) {
    .tm-reservas-grid,
    .tm-reservas-primary-grid,
    .tm-reservas-boat-passenger-grid,
    .tm-reservas-admin-grid,
    .tm-reservas-cards,
    .tm-reservas-stats,
    .tm-reservas-row-card,
    .tm-reservas-summary-grid,
    .tm-op-hero,
    .tm-op-metrics,
    .tm-op-checks,
    .tm-op-terms-card,
    .tm-reservas-quote-layout,
    .tm-reservas-context-with-passengers,
    .tm-reservas-grid-compact,
    .tm-reservas-quote-result {
        grid-template-columns: 1fr;
    }

    .tm-route-preview-card {
        order: -1;
        position: relative;
        top: auto;
    }
}

@media (max-width: 560px) {
    .tm-passenger-field-context {
        max-width: 160px;
        width: 160px;
    }

    .tm-country-phone {
        grid-template-columns: 110px 1fr;
    }

    .tm-country-dial {
        font-size: 14px;
    }
}

/* v0.1.5: hard reset for Elementor/theme cached country-picker styles. */
.tm-reservas.tm-reservas-booking {
    background: linear-gradient(180deg, #FFFFFF 0%, #FBFCFC 100%) !important;
    border-color: rgba(16, 35, 53, .08) !important;
    box-shadow: 0 18px 48px rgba(9, 26, 40, .06) !important;
    overflow: visible !important;
}

.tm-reservas.tm-reservas-booking .tm-reservas-form-surface {
    background: #FFFFFF !important;
    border-color: rgba(16, 35, 53, .08) !important;
    overflow: visible !important;
}

.tm-reservas.tm-reservas-booking .tm-reservas-button {
    background: linear-gradient(135deg, #102335 0%, #173B54 100%) !important;
    box-shadow: 0 16px 36px rgba(16, 35, 53, .22) !important;
    color: #FFFFFF !important;
}

.tm-reservas.tm-reservas-booking .tm-reservas-button:hover {
    background: #0B1E2E !important;
}

.tm-reservas.tm-reservas-booking .tm-reservas-note,
.tm-reservas.tm-reservas-booking .tm-reservas-context {
    background: #F7FAFA !important;
    border-color: rgba(16, 35, 53, .08) !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean {
    grid-template-columns: 118px minmax(0, 1fr) !important;
    isolation: isolate;
    z-index: 2147483000 !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean .tm-country-trigger {
    background: #EEF2F3 !important;
    border: 1px solid rgba(16, 35, 53, .14) !important;
    border-radius: 14px 0 0 14px !important;
    box-shadow: none !important;
    color: #102335 !important;
    min-height: 54px !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean .tm-country-dial {
    color: #102335 !important;
    font-weight: 800 !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean .tm-country-caret {
    color: #687984 !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean .tm-country-menu-clean {
    background: #FFFFFF !important;
    border: 1px solid rgba(16, 35, 53, .10) !important;
    border-radius: 8px !important;
    box-shadow: 0 22px 60px rgba(9, 26, 40, .18) !important;
    max-height: 260px !important;
    overflow-y: auto !important;
    padding: 0 !important;
    position: fixed !important;
    z-index: 2147483000 !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean .tm-country-search {
    background: #FFFFFF !important;
    border-bottom: 1px solid rgba(16, 35, 53, .08) !important;
    padding: 8px !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 2 !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean .tm-country-search input {
    background: #F7FAFA !important;
    border: 1px solid rgba(16, 35, 53, .12) !important;
    border-radius: 10px !important;
    box-shadow: none !important;
    font-size: 14px !important;
    min-height: 38px !important;
    padding: 8px 11px !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean .tm-country-option {
    background: #FFFFFF !important;
    border: 0 !important;
    border-radius: 0 !important;
    color: #091A28 !important;
    display: grid !important;
    grid-template-columns: 30px minmax(0, 1fr) auto !important;
    min-height: 40px !important;
    padding: 7px 12px !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean .tm-country-option:hover,
.tm-reservas.tm-reservas-booking .tm-country-phone-clean .tm-country-option:focus {
    background: #F2F5F6 !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean .tm-country-option-name {
    color: #091A28 !important;
    font-size: 15px !important;
    font-weight: 500 !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean .tm-country-option-dial {
    color: #87939A !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

/* v0.1.7: clean global country dropdown skin.
   The menu is moved to <body> by JS, so these rules must not depend on .tm-reservas. */
body .tm-country-menu-clean {
    background: #FFFFFF !important;
    border: 1px solid rgba(16, 35, 53, .10) !important;
    border-radius: 10px !important;
    box-shadow: 0 18px 45px rgba(9, 26, 40, .16) !important;
    max-height: 260px !important;
    overflow: auto !important;
    padding: 0 !important;
    position: fixed !important;
    z-index: 2147483000 !important;
}

body .tm-country-menu-clean .tm-country-search {
    background: #FFFFFF !important;
    border-bottom: 1px solid rgba(16, 35, 53, .08) !important;
    padding: 8px !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 2 !important;
}

body .tm-country-menu-clean .tm-country-search input {
    background: #F7FAFA !important;
    border: 1px solid rgba(16, 35, 53, .14) !important;
    border-radius: 9px !important;
    box-shadow: none !important;
    color: #091A28 !important;
    font-size: 14px !important;
    min-height: 36px !important;
    outline: none !important;
    padding: 8px 11px !important;
    width: 100% !important;
}

body .tm-country-menu-clean .tm-country-search input:focus {
    border-color: rgba(16, 35, 53, .32) !important;
    box-shadow: 0 0 0 3px rgba(16, 35, 53, .08) !important;
    outline: none !important;
}

body .tm-country-menu-clean .tm-country-option {
    background: #FFFFFF !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(16, 35, 53, .07) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    color: #091A28 !important;
    display: grid !important;
    gap: 10px !important;
    grid-template-columns: 30px minmax(0, 1fr) auto !important;
    min-height: 38px !important;
    padding: 7px 12px !important;
    text-align: left !important;
    width: 100% !important;
}

body .tm-country-menu-clean .tm-country-option:nth-of-type(even) {
    background: #F8FAFA !important;
}

body .tm-country-menu-clean .tm-country-option:hover,
body .tm-country-menu-clean .tm-country-option:focus {
    background: #F1F4F5 !important;
    color: #102335 !important;
    outline: none !important;
}

body .tm-country-menu-clean .tm-country-option-flag {
    font-size: 18px !important;
    line-height: 1 !important;
}

body .tm-country-menu-clean .tm-country-option-name {
    color: #091A28 !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

body .tm-country-menu-clean .tm-country-option-dial {
    color: #7B8890 !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

body .tm-country-menu-clean .tm-country-option[hidden] {
    display: none !important;
}

body .tm-country-menu-clean .tm-country-option:last-child {
    border-bottom: 0 !important;
}

/* v0.1.8: shared clean skin for route/boat dropdowns moved to body. */
body .tm-choice-menu-clean {
    background: #FFFFFF !important;
    border: 1px solid rgba(16, 35, 53, .10) !important;
    border-radius: 10px !important;
    box-shadow: 0 18px 45px rgba(9, 26, 40, .16) !important;
    max-height: 250px !important;
    overflow: auto !important;
    padding: 0 !important;
    position: fixed !important;
    z-index: 2147483600 !important;
}

body .tm-choice-menu-clean .tm-choice-list {
    display: grid !important;
}

body .tm-choice-menu-clean .tm-choice-option {
    background: #FFFFFF !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(16, 35, 53, .07) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    color: #091A28 !important;
    cursor: pointer !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    min-height: 38px !important;
    padding: 7px 12px !important;
    text-align: left !important;
    width: 100% !important;
}

body .tm-choice-menu-clean .tm-choice-option:nth-child(even) {
    background: #F8FAFA !important;
}

body .tm-choice-menu-clean .tm-choice-option:hover,
body .tm-choice-menu-clean .tm-choice-option:focus {
    background: #F1F4F5 !important;
    color: #102335 !important;
    outline: none !important;
}

body .tm-choice-menu-clean .tm-choice-option:last-child {
    border-bottom: 0 !important;
}

/* v0.2.0: neutral route/boat selectors and keep them above the phone field. */
.tm-reservas.tm-reservas-booking .tm-choice {
    z-index: 4 !important;
}

.tm-reservas.tm-reservas-booking .tm-choice-trigger {
    background: #FFFFFF !important;
    border: 1px solid rgba(16, 35, 53, .14) !important;
    border-radius: 14px !important;
    box-shadow: 0 10px 26px rgba(9, 26, 40, .035) !important;
    color: #091A28 !important;
}

.tm-reservas.tm-reservas-booking .tm-choice-trigger:hover,
.tm-reservas.tm-reservas-booking .tm-choice-trigger:focus,
.tm-reservas.tm-reservas-booking .tm-choice-trigger[aria-expanded="true"] {
    background: #FFFFFF !important;
    border-color: rgba(16, 35, 53, .30) !important;
    box-shadow: 0 0 0 3px rgba(16, 35, 53, .08) !important;
    color: #091A28 !important;
    outline: none !important;
}

.tm-reservas.tm-reservas-booking .tm-choice-trigger [data-tm-choice-label] {
    color: #091A28 !important;
}

.tm-reservas.tm-reservas-booking .tm-choice-caret {
    color: #687984 !important;
}

.tm-reservas.tm-reservas-booking .tm-country-phone-clean {
    z-index: 4 !important;
}

/* v0.3.14: unified operational panel. */
.tm-op-shell {
    --tm-navy: #102335;
    --tm-deep: #091A28;
    --tm-gold: #D3A359;
    --tm-sea: #F4FAFA;
    --tm-line: rgba(16, 35, 53, .11);
    --tm-text: #213D4C;
    background: linear-gradient(135deg, #F7FBFB 0%, #FFFFFF 42%, #F6F0E7 100%);
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 26px;
    box-shadow: 0 28px 80px rgba(9, 26, 40, .08);
    color: var(--tm-deep);
    display: grid;
    gap: 20px;
    padding: 22px;
}

.tm-op-shell * {
    box-sizing: border-box;
}

.tm-op-hero-luxury,
.tm-op-section {
    background: rgba(255, 255, 255, .86);
    border: 1px solid var(--tm-line);
    border-radius: 22px;
    box-shadow: 0 18px 50px rgba(9, 26, 40, .06);
    padding: clamp(18px, 2.2vw, 24px);
}

.tm-op-hero-luxury {
    align-items: center;
    background: radial-gradient(circle at 82% 12%, rgba(211, 163, 89, .24), transparent 32%), linear-gradient(135deg, #102335, #173B54);
    color: #fff;
    display: grid;
    gap: 20px;
    grid-template-columns: minmax(0, 1fr) auto;
}

.tm-op-kicker,
.tm-op-section-head span,
.tm-op-metric-grid span,
.tm-op-card > h4 + p span {
    color: var(--tm-gold);
    display: block;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.tm-op-hero-luxury h2,
.tm-op-section-head h3 {
    color: inherit;
    font-size: clamp(30px, 4vw, 52px);
    letter-spacing: -.04em;
    line-height: .96;
    margin: 8px 0 10px;
}

.tm-op-section-head h3 {
    color: var(--tm-deep);
    font-size: clamp(26px, 3vw, 38px);
}

.tm-op-hero-luxury p,
.tm-op-section-head p,
.tm-op-card p,
.tm-op-help {
    color: #526A75;
    font-size: 15px;
    line-height: 1.65;
    margin: 0;
}

.tm-op-hero-luxury p {
    color: rgba(255,255,255,.82);
}

.tm-op-guide-control {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.tm-op-guide-control label,
.tm-op-menu button,
.tm-op-form button,
.tm-op-record-actions button,
.tm-op-boat-price-card button {
    background: #fff;
    border: 1px solid rgba(255,255,255,.4);
    border-radius: 999px;
    color: var(--tm-navy);
    cursor: pointer;
    font-weight: 900;
    padding: 12px 16px;
    text-decoration: none;
}

.tm-op-guide-control label {
    align-items: center;
    display: inline-flex;
    gap: 8px;
}

.tm-op-form button,
.tm-op-boat-price-card button {
    background: var(--tm-navy);
    border-color: var(--tm-navy);
    color: #fff;
}

.tm-op-alert {
    background: #EFF8F5;
    border: 1px solid rgba(46, 139, 87, .20);
    border-left: 6px solid #2E8B57;
    border-radius: 16px;
    color: #184D35;
    font-weight: 800;
    padding: 14px 16px;
}

.tm-op-menu {
    align-items: center;
    background: rgba(255,255,255,.86);
    border: 1px solid var(--tm-line);
    border-radius: 18px;
    box-shadow: 0 15px 40px rgba(9, 26, 40, .05);
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 10px;
    position: sticky;
    top: 20px;
    z-index: 50;
}

.tm-op-menu button {
    background: #F7FAFA;
    border-color: rgba(16, 35, 53, .08);
    color: var(--tm-text);
    padding: 10px 14px;
}

.tm-op-menu button:hover,
.tm-op-menu button.is-active {
    background: var(--tm-navy);
    color: #fff;
}

.tm-op-section {
    display: none;
}

.tm-op-section.is-active {
    display: block;
}

.tm-op-section-head {
    align-items: end;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 420px);
    margin-bottom: 20px;
}

.tm-op-metric-grid,
.tm-op-status-grid,
.tm-op-price-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.tm-op-status-grid,
.tm-op-price-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 16px;
}

.tm-op-price-grid {
    grid-template-columns: minmax(0, 1fr);
}

.tm-op-metric-grid article,
.tm-op-status-grid article,
.tm-op-card {
    background: linear-gradient(135deg, #FFFFFF 0%, #F8FBFB 100%);
    border: 1px solid var(--tm-line);
    border-radius: 18px;
    box-shadow: 0 14px 36px rgba(9, 26, 40, .045);
    padding: clamp(16px, 1.8vw, 20px);
}

.tm-op-metric-grid strong {
    color: var(--tm-deep);
    display: block;
    font-size: 42px;
    line-height: 1;
    margin: 12px 0 10px;
}

.tm-op-metric-grid a {
    color: #0F5E91;
    font-weight: 900;
    text-decoration: none;
}

.tm-op-status-grid article {
    border-left: 6px solid #D3A359;
}

.tm-op-status-grid article.is-ready {
    border-left-color: #2E8B57;
}

.tm-op-status-grid article.is-pending {
    border-left-color: #C47D42;
}

.tm-op-status-grid article > span {
    background: #F7FAFA;
    border-radius: 999px;
    color: #526A75;
    display: inline-block;
    font-size: 12px;
    font-weight: 900;
    margin-bottom: 10px;
    padding: 6px 10px;
}

.tm-op-status-grid strong,
.tm-op-card h4 {
    color: var(--tm-deep);
    display: block;
    font-size: 20px;
    line-height: 1.15;
    margin: 0 0 8px;
}

.tm-op-two-cols {
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(320px, .85fr) minmax(320px, 1.15fr);
}

.tm-op-form {
    display: grid;
    gap: 14px;
}

.tm-op-form label,
.tm-op-route-price-list label {
    display: grid;
    gap: 7px;
}

.tm-op-form label > span,
.tm-op-check,
.tm-op-checkbox-grid > strong {
    color: var(--tm-text);
    font-size: 14px;
    font-weight: 900;
}

.tm-op-form input[type="text"],
.tm-op-form input[type="number"],
.tm-op-form input[type="time"],
.tm-op-form select,
.tm-op-form textarea,
.tm-op-route-price-list input[type="number"] {
    background: #fff;
    border: 1px solid rgba(16, 35, 53, .15);
    border-radius: 13px;
    box-shadow: 0 10px 26px rgba(9, 26, 40, .035);
    color: var(--tm-deep);
    min-height: 44px;
    padding: 10px 12px;
    width: 100%;
}

.tm-op-form input:focus,
.tm-op-form select:focus,
.tm-op-form textarea:focus,
.tm-op-route-price-list input:focus {
    border-color: var(--tm-gold);
    box-shadow: 0 0 0 4px rgba(211, 163, 89, .16);
    outline: none;
}

.tm-op-mini-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.tm-op-checkbox-grid {
    background: #F7FAFA;
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 14px;
    display: grid;
    gap: 8px;
    max-height: 220px;
    overflow: auto;
    padding: 14px;
}

.tm-op-checkbox-grid label {
    align-items: center;
    display: flex;
    flex-direction: row;
    gap: 8px;
    min-height: 34px;
    padding: 4px 2px;
}

.tm-op-list {
    display: grid;
    gap: 10px;
    max-height: 560px;
    overflow: auto;
}

.tm-op-list article {
    background: #fff;
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 14px;
    display: grid;
    gap: 5px;
    padding: 14px;
}

.tm-op-list [data-tm-item-panel],
.tm-op-price-grid [data-tm-item-panel] {
    display: none;
}

.tm-op-list [data-tm-item-panel].is-active,
.tm-op-price-grid [data-tm-item-panel].is-active {
    display: grid;
}

.tm-op-select-one {
    display: grid;
    gap: 7px;
    margin: 14px 0;
}

.tm-op-select-one span {
    color: var(--tm-text);
    font-size: 13px;
    font-weight: 900;
}

.tm-op-select-one select {
    background: #fff;
    border: 1px solid rgba(16, 35, 53, .15);
    border-radius: 13px;
    box-shadow: 0 10px 26px rgba(9, 26, 40, .035);
    color: var(--tm-deep);
    min-height: 44px;
    padding: 10px 12px;
    width: 100%;
}

.tm-op-guide-note {
    background: #FFFBF3;
    border: 1px solid rgba(211, 163, 89, .22);
    border-left: 5px solid var(--tm-gold);
    border-radius: 14px;
    color: #6F542B;
    display: none;
    font-size: 14px;
    font-weight: 650;
    line-height: 1.55;
    margin: 0 0 14px;
    padding: 12px 14px;
}

.tm-op-shell.is-guide-active .tm-op-guide-note {
    display: block;
}

.tm-op-selector-card {
    align-items: center;
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(0, 1fr) minmax(240px, 360px);
    margin: 18px 0;
}

.tm-op-selector-card .tm-op-select-one {
    margin: 0;
}

.tm-op-list span,
.tm-op-list small {
    color: #526A75;
}

.tm-op-terms-list {
    display: grid;
    gap: 8px;
    margin-top: 14px;
}

.tm-op-terms-list span {
    background: #F7FAFA;
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 999px;
    color: var(--tm-text);
    font-weight: 800;
    padding: 9px 12px;
}

.tm-op-boat-price-card header {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
    margin-bottom: 10px;
}

.tm-op-route-price-list {
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 16px;
    display: grid;
    margin: 16px 0;
    max-height: 360px;
    overflow: auto;
}

.tm-op-route-price-list label {
    align-items: center;
    border-bottom: 1px solid rgba(16, 35, 53, .07);
    grid-template-columns: auto minmax(120px, 1fr) 150px;
    padding: 10px;
}

.tm-op-route-price-list label:nth-child(even) {
    background: #F8FAFA;
}

.tm-op-route-price-list label:last-child {
    border-bottom: 0;
}

.tm-op-record-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 14px;
}

.tm-op-record-actions button {
    background: #F7FAFA;
    border-color: rgba(16, 35, 53, .14);
}

.tm-op-record-actions .tm-op-danger {
    background: #FFF4F1;
    border-color: rgba(184, 91, 91, .24);
    color: #B85B5B;
}

.tm-op-table-wrap {
    border: 1px solid var(--tm-line);
    border-radius: 18px;
    overflow: auto;
}

.tm-op-table {
    border-collapse: separate;
    border-spacing: 0;
    min-width: 980px;
    width: 100%;
}

.tm-op-table th {
    background: var(--tm-navy);
    color: #fff;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    padding: 16px 14px;
    text-align: left;
    text-transform: uppercase;
}

.tm-op-table td {
    background: #fff;
    border-bottom: 1px solid rgba(16, 35, 53, .07);
    color: var(--tm-deep);
    padding: 14px;
    vertical-align: middle;
}

.tm-op-table tr:nth-child(even) td {
    background: #F8FAFA;
}

.tm-op-table button[data-tm-copy] {
    background: transparent;
    border: 0;
    color: var(--tm-deep);
    cursor: pointer;
    display: block;
    font: inherit;
    font-weight: 800;
    padding: 0;
    text-align: left;
}

.tm-op-table button[data-tm-copy].is-copied::after {
    color: #2E8B57;
    content: " copiado";
    font-size: 12px;
    margin-left: 6px;
}

.tm-op-pill {
    background: #F7FAFA;
    border-radius: 999px;
    color: #526A75;
    display: inline-flex;
    font-weight: 900;
    padding: 7px 10px;
}

.tm-op-empty {
    color: #526A75 !important;
    font-style: italic;
    text-align: center;
}

.tm-op-guide-modal {
    inset: 0;
    position: fixed;
    z-index: 2147483500;
}

.tm-op-shell input[type="checkbox"] {
    appearance: auto !important;
    -webkit-appearance: checkbox !important;
    background: #fff !important;
    border: 1px solid rgba(16, 35, 53, .28) !important;
    border-radius: 4px !important;
    box-shadow: none !important;
    cursor: pointer;
    display: inline-block !important;
    flex: 0 0 auto;
    height: 16px !important;
    margin: 0 !important;
    min-height: 0 !important;
    padding: 0 !important;
    vertical-align: middle;
    width: 16px !important;
}

.tm-op-shell .tm-op-table input[type="checkbox"] {
    height: 15px !important;
    width: 15px !important;
}

.tm-op-check {
    align-items: center;
    background: #F7FAFA;
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 999px;
    display: inline-flex !important;
    gap: 8px !important;
    justify-self: start;
    min-height: auto !important;
    padding: 9px 12px;
}

.tm-op-check input,
.tm-op-guide-control input,
.tm-op-checkbox-grid input,
.tm-op-route-price-list input[type="checkbox"] {
    margin-right: 2px !important;
}

.tm-op-footer-credit {
    align-items: center;
    border-top: 1px solid rgba(16, 35, 53, .08);
    color: rgba(16, 35, 53, .54);
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    justify-content: center;
    margin: 4px 8px 0;
    padding: 14px 10px 2px;
    text-align: center;
}

.tm-op-footer-credit span {
    color: rgba(16, 35, 53, .48);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.tm-op-footer-credit p {
    color: rgba(16, 35, 53, .58);
    font-size: 12px;
    margin: 0;
}

.tm-op-footer-credit a {
    color: rgba(16, 35, 53, .72);
    font-weight: 800;
    text-decoration: none;
}

.tm-op-guide-control button {
    background: rgba(255,255,255,.96);
    border: 1px solid rgba(255,255,255,.46);
    border-radius: 999px;
    color: var(--tm-navy);
    cursor: pointer;
    font-weight: 900;
    padding: 12px 18px;
}

.tm-op-guide-control button.is-active {
    background: var(--tm-gold);
    border-color: var(--tm-gold);
    color: #091A28;
}

.tm-op-edit-panel {
    padding: 0 !important;
}

.tm-op-edit-panel > .tm-op-form {
    padding: 16px;
}

.tm-op-panel-title {
    align-items: center;
    background: var(--tm-navy);
    border-radius: 14px;
    color: #fff;
    display: flex;
    gap: 14px;
    justify-content: space-between;
    margin-bottom: 14px;
    padding: 16px;
}

.tm-op-panel-title span {
    color: var(--tm-gold);
    display: block;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.tm-op-panel-title strong {
    color: #fff;
    display: block;
    font-size: 22px;
    line-height: 1.1;
}

.tm-op-panel-title button,
.tm-op-route-add {
    background: #fff;
    border: 1px solid rgba(255,255,255,.4);
    border-radius: 999px;
    color: var(--tm-navy);
    cursor: pointer;
    font-weight: 900;
    padding: 11px 16px;
}

.tm-op-route-builder {
    gap: 16px;
}

.tm-op-route-block,
.tm-op-route-stop,
.tm-op-danger-zone {
    background: #fff;
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 18px;
    display: grid;
    gap: 12px;
    padding: 16px;
}

.tm-op-route-block {
    border-left: 6px solid var(--tm-gold);
}

.tm-op-route-block.is-departure {
    background: linear-gradient(135deg, #FFFFFF 0%, #F5FBF8 100%);
    border-left-color: #2E8B57;
}

.tm-op-route-block.is-return {
    background: linear-gradient(135deg, #FFFFFF 0%, #FFF7F6 100%);
    border-left-color: #B85B5B;
}

.tm-op-route-block h5 {
    color: var(--tm-deep);
    font-size: 22px;
    line-height: 1.1;
    margin: 0;
}

.tm-op-route-block h5 span {
    color: var(--tm-gold);
    display: block;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .12em;
    margin-bottom: 5px;
    text-transform: uppercase;
}

.tm-op-route-segment-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(160px, 1.3fr) minmax(120px, .7fr) minmax(160px, 1.3fr) minmax(120px, .7fr) minmax(120px, .65fr);
}

.tm-op-route-stops {
    display: grid;
    gap: 12px;
}

.tm-op-route-stop {
    position: relative;
}

.tm-op-route-remove,
.tm-op-delete-button {
    background: #FFF4F1;
    border: 1px solid rgba(184, 91, 91, .25);
    border-radius: 999px;
    color: #B85B5B;
    cursor: pointer;
    font-weight: 900;
    justify-self: end;
    padding: 9px 13px;
}

.tm-op-route-add {
    background: var(--tm-navy);
    border-color: var(--tm-navy);
    color: #fff;
    justify-self: start;
}

.tm-op-danger-zone {
    background: #FFF9F7;
    border-color: rgba(184, 91, 91, .18);
    margin-top: 14px;
}

.tm-op-danger-zone p {
    color: #8E4B4B;
    font-size: 13px;
    font-weight: 750;
}

.tm-op-shell .tm-op-menu button,
.tm-op-shell .tm-op-form button,
.tm-op-shell .tm-op-record-actions button,
.tm-op-shell .tm-op-boat-price-card button,
.tm-op-shell .tm-op-guide-control button,
.tm-op-shell .tm-op-panel-title button,
.tm-op-shell .tm-op-route-add,
.tm-op-shell .tm-op-route-remove,
.tm-op-shell .tm-op-delete-button {
    border-radius: 999px !important;
    transform: none !important;
    transition: background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease;
}

.tm-op-shell .tm-op-menu button:hover,
.tm-op-shell .tm-op-form button:hover,
.tm-op-shell .tm-op-record-actions button:hover,
.tm-op-shell .tm-op-boat-price-card button:hover,
.tm-op-shell .tm-op-guide-control button:hover,
.tm-op-shell .tm-op-panel-title button:hover,
.tm-op-shell .tm-op-route-add:hover,
.tm-op-shell .tm-op-route-remove:hover,
.tm-op-shell .tm-op-delete-button:hover {
    border-radius: 999px !important;
    transform: none !important;
}

.tm-op-section[data-tm-panel="routes"] .tm-op-two-cols {
    grid-template-columns: minmax(0, 1fr);
}

.tm-op-section[data-tm-panel="routes"] .tm-op-card {
    overflow: hidden;
}

.tm-op-section[data-tm-panel="routes"] .tm-op-list {
    max-height: none;
    overflow: visible;
}

.tm-op-section[data-tm-panel="routes"] .tm-op-route-builder {
    max-width: 100%;
    overflow: hidden;
}

.tm-op-section[data-tm-panel="routes"] .tm-op-route-segment-grid {
    grid-template-columns: minmax(180px, 1.15fr) minmax(130px, .7fr) minmax(180px, 1.15fr) minmax(130px, .7fr) minmax(120px, .6fr);
}

.tm-op-section[data-tm-panel="routes"] .tm-op-route-block,
.tm-op-section[data-tm-panel="routes"] .tm-op-route-stop {
    min-width: 0;
    overflow: hidden;
}

.tm-op-section[data-tm-panel="routes"] .tm-op-route-block > p,
.tm-op-section[data-tm-panel="routes"] .tm-op-route-block textarea {
    max-width: 100%;
}

@media (max-width: 1380px) {
    .tm-op-section[data-tm-panel="routes"] .tm-op-route-segment-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tm-op-section[data-tm-panel="routes"] .tm-op-route-segment-grid label:last-child {
        grid-column: 1 / -1;
    }
}

@media (max-width: 900px) {
    .tm-op-shell {
        border-radius: 16px;
        padding: 12px;
    }

    .tm-op-menu {
        flex-wrap: nowrap;
        overflow-x: auto;
        padding: 8px;
        scroll-snap-type: x proximity;
        top: 8px;
    }

    .tm-op-menu button {
        flex: 0 0 auto;
        scroll-snap-align: start;
        white-space: nowrap;
    }

    .tm-op-section-head,
    .tm-op-selector-card,
    .tm-op-panel-title {
        grid-template-columns: 1fr;
    }

    .tm-op-panel-title {
        align-items: flex-start;
        display: grid;
    }

    .tm-op-panel-title button {
        justify-self: start;
    }

    .tm-op-hero-luxury h2,
    .tm-op-section-head h3 {
        font-size: clamp(28px, 9vw, 40px);
    }
}

@media (max-width: 640px) {
    .tm-op-shell {
        margin-inline: 0;
        padding: 10px;
    }

    .tm-op-two-cols,
    .tm-op-mini-grid,
    .tm-op-route-segment-grid,
    .tm-op-section[data-tm-panel="routes"] .tm-op-route-segment-grid {
        grid-template-columns: 1fr;
    }

    .tm-op-card,
    .tm-op-route-block,
    .tm-op-route-stop {
        border-radius: 16px;
        padding: 14px;
    }

    .tm-op-route-block {
        border-left-width: 4px;
    }

    .tm-op-route-block h5 {
        font-size: 20px;
    }

    .tm-op-form input[type="text"],
    .tm-op-form input[type="number"],
    .tm-op-form input[type="time"],
    .tm-op-form select,
    .tm-op-form textarea,
    .tm-op-select-one select {
        font-size: 16px;
        min-height: 48px;
    }

    .tm-op-form button,
    .tm-op-route-add,
    .tm-op-delete-button {
        justify-content: center;
        text-align: center;
        width: 100%;
    }
}

.tm-op-guide-modal[hidden] {
    display: none;
}

.tm-op-guide-backdrop {
    background: rgba(9, 26, 40, .55);
    inset: 0;
    position: absolute;
}

.tm-op-guide-dialog {
    background: #fff;
    border-radius: 24px;
    box-shadow: 0 35px 90px rgba(9, 26, 40, .24);
    left: 50%;
    max-height: calc(100vh - 60px);
    max-width: 900px;
    overflow: auto;
    padding: 28px;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: calc(100vw - 36px);
}

.tm-op-guide-dialog h3 {
    color: var(--tm-deep);
    font-size: 36px;
    line-height: 1;
    margin: 8px 0 20px;
}

.tm-op-guide-close {
    background: var(--tm-navy);
    border: 0;
    border-radius: 999px;
    color: #fff;
    cursor: pointer;
    font-size: 24px;
    height: 42px;
    position: absolute;
    right: 18px;
    top: 18px;
    width: 42px;
}

.tm-op-guide-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.tm-op-guide-grid article {
    background: linear-gradient(135deg, #FFFFFF 0%, #F8FBFB 100%);
    border: 1px solid rgba(16, 35, 53, .08);
    border-left: 5px solid var(--tm-gold);
    border-radius: 16px;
    padding: 16px;
}

.tm-op-guide-grid strong {
    color: var(--tm-deep);
}

.tm-op-color-chip {
    background: var(--tm-boat-color, var(--tm-gold));
    border: 2px solid rgba(255, 255, 255, .9);
    border-radius: 999px;
    box-shadow: 0 8px 20px rgba(9, 26, 40, .18);
    display: inline-block;
    height: 30px;
    width: 30px;
}

.tm-op-color-field {
    align-items: center;
    background: rgba(16, 35, 53, .035);
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 18px;
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between;
    padding: 10px 12px;
}

.tm-op-color-field input[type="color"],
.tm-op-form input[type="color"] {
    background: transparent;
    border: 0;
    cursor: pointer;
    height: 42px;
    min-height: 42px;
    padding: 0;
    width: 64px;
}

.tm-calendar-shell {
    display: grid;
    gap: 18px;
}

.tm-calendar-hero {
    align-items: center;
    background: linear-gradient(135deg, var(--tm-navy), #173B54);
    border-radius: 28px;
    color: #fff;
    display: grid;
    gap: 20px;
    grid-template-columns: minmax(0, 1fr) auto;
    overflow: hidden;
    padding: 28px;
    position: relative;
}

.tm-calendar-hero::after {
    background: radial-gradient(circle, rgba(103, 199, 236, .2), transparent 62%);
    content: "";
    height: 260px;
    position: absolute;
    right: -90px;
    top: -110px;
    width: 260px;
}

.tm-calendar-hero > * {
    position: relative;
    z-index: 1;
}

.tm-calendar-hero span,
.tm-calendar-legend > strong {
    color: var(--tm-gold);
    display: block;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .11em;
    margin-bottom: 8px;
    text-transform: uppercase;
}

.tm-calendar-hero h2 {
    color: #fff;
    font-size: clamp(34px, 5vw, 58px);
    line-height: .95;
    margin: 0 0 10px;
}

.tm-calendar-hero p {
    color: rgba(255, 255, 255, .78);
    font-size: 17px;
    margin: 0;
    max-width: 760px;
}

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

.tm-calendar-actions a,
.tm-calendar-actions strong {
    background: rgba(255, 255, 255, .1);
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    font-weight: 900;
    padding: 12px 16px;
    text-decoration: none;
    white-space: nowrap;
}

.tm-calendar-actions strong {
    background: #fff;
    color: var(--tm-navy);
}

.tm-calendar-legend,
.tm-calendar-list {
    background: #fff;
    border: 1px solid rgba(16, 35, 53, .1);
    border-radius: 24px;
    box-shadow: 0 18px 45px rgba(9, 26, 40, .055);
    padding: 20px;
}

.tm-calendar-legend div {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.tm-calendar-legend span {
    align-items: center;
    background: #F8FAFA;
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 999px;
    color: var(--tm-deep);
    display: inline-flex;
    font-weight: 800;
    gap: 8px;
    padding: 9px 12px;
}

.tm-calendar-legend i,
.tm-calendar-boat-dot {
    border-radius: 999px;
    display: inline-block;
    height: 14px;
    width: 14px;
}

.tm-calendar-boat-dot {
    margin-right: 8px;
    vertical-align: -2px;
}

.tm-calendar-grid {
    background: #fff;
    border: 1px solid rgba(16, 35, 53, .1);
    border-radius: 28px;
    box-shadow: 0 22px 55px rgba(9, 26, 40, .065);
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    overflow: hidden;
}

.tm-calendar-weekday {
    background: var(--tm-navy);
    color: #fff;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    padding: 14px;
    text-transform: uppercase;
}

.tm-calendar-day {
    background: #fff;
    border-bottom: 1px solid rgba(16, 35, 53, .08);
    border-right: 1px solid rgba(16, 35, 53, .08);
    min-height: 154px;
    padding: 12px;
}

.tm-calendar-day:nth-child(14n + 8),
.tm-calendar-day:nth-child(14n + 9),
.tm-calendar-day:nth-child(14n + 10),
.tm-calendar-day:nth-child(14n + 11),
.tm-calendar-day:nth-child(14n + 12),
.tm-calendar-day:nth-child(14n + 13),
.tm-calendar-day:nth-child(14n + 14) {
    background: #FAFCFC;
}

.tm-calendar-day.is-empty {
    background: #F5F8F8;
}

.tm-calendar-day.is-today {
    box-shadow: inset 0 0 0 2px var(--tm-gold);
}

.tm-calendar-day header {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 8px;
}

.tm-calendar-day header span {
    color: var(--tm-deep);
    font-size: 20px;
    font-weight: 900;
}

.tm-calendar-day header small {
    color: var(--tm-muted);
    font-size: 11px;
    font-weight: 800;
}

.tm-calendar-events {
    display: grid;
    gap: 7px;
}

.tm-calendar-event {
    background: linear-gradient(135deg, color-mix(in srgb, var(--tm-event-color) 18%, #fff), #fff);
    border: 1px solid color-mix(in srgb, var(--tm-event-color) 32%, rgba(16, 35, 53, .08));
    border-left: 5px solid var(--tm-event-color);
    border-radius: 14px;
    box-shadow: 0 10px 24px rgba(9, 26, 40, .055);
    display: grid;
    gap: 2px;
    padding: 9px;
}

.tm-calendar-event strong {
    color: var(--tm-deep);
    font-size: 13px;
    line-height: 1.1;
}

.tm-calendar-event span,
.tm-calendar-event small {
    color: #526A75;
    font-size: 12px;
    line-height: 1.25;
}

@supports not (color: color-mix(in srgb, #fff 50%, #000)) {
    .tm-calendar-event {
        background: #fff;
        border-color: rgba(16, 35, 53, .1);
    }
}

@media (max-width: 1100px) {
    .tm-calendar-hero {
        grid-template-columns: 1fr;
    }

    .tm-calendar-actions {
        flex-wrap: wrap;
    }

    .tm-calendar-grid {
        display: block;
    }

    .tm-calendar-weekday,
    .tm-calendar-day.is-empty {
        display: none;
    }

    .tm-calendar-day {
        border-right: 0;
        min-height: auto;
    }
}

@media (max-width: 1200px) {
    .tm-op-metric-grid,
    .tm-op-status-grid,
    .tm-op-price-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tm-op-two-cols,
    .tm-op-section-head,
    .tm-op-commercial-help,
    .tm-op-hero-luxury,
    .tm-op-route-segment-grid {
        grid-template-columns: 1fr;
    }

    .tm-op-guide-control {
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .tm-op-shell {
        border-radius: 18px;
        padding: 12px;
    }

    .tm-op-metric-grid,
    .tm-op-status-grid,
    .tm-op-price-grid,
    .tm-op-mini-grid,
    .tm-op-guide-grid {
        grid-template-columns: 1fr;
    }

    .tm-op-route-price-list label {
        grid-template-columns: auto 1fr;
    }

    .tm-op-route-price-list input[type="number"] {
        grid-column: 1 / -1;
    }

    .tm-quote-money {
        grid-template-columns: 1fr;
    }

    .tm-quote-essentials span,
    .tm-quote-boat span {
        width: 100%;
    }
}

/* Ajustes finales de estabilidad visual del panel operativo. */
@media (min-width: 1280px) {
    .tm-op-shell {
        max-width: none;
        width: min(1720px, calc(100vw - 40px));
        margin-left: calc((100% - min(1720px, calc(100vw - 40px))) / 2);
        margin-right: calc((100% - min(1720px, calc(100vw - 40px))) / 2);
    }

    .tm-op-menu {
        flex-wrap: nowrap;
    }

    .tm-calendar-shell {
        max-width: none;
        width: 100%;
    }
}

.tm-reservas button,
.tm-reservas a,
.tm-op-shell button,
.tm-op-shell a,
.tm-calendar-shell button,
.tm-calendar-shell a {
    font-style: normal !important;
    transform: none !important;
}

.tm-reservas button:hover,
.tm-reservas a:hover,
.tm-reservas button:focus,
.tm-reservas a:focus,
.tm-op-shell button:hover,
.tm-op-shell a:hover,
.tm-op-shell button:focus,
.tm-op-shell a:focus,
.tm-calendar-shell button:hover,
.tm-calendar-shell a:hover,
.tm-calendar-shell button:focus,
.tm-calendar-shell a:focus {
    font-style: normal !important;
    transform: none !important;
}

.tm-op-menu button,
.tm-op-form button,
.tm-op-action,
.tm-calendar-actions a,
.tm-calendar-actions strong {
    border-radius: 999px !important;
    font-style: normal !important;
}

.tm-op-empty,
.tm-op-shell .tm-op-empty,
.tm-calendar-shell,
.tm-calendar-shell * {
    font-style: normal !important;
}

@media (max-width: 1279px) {
    .tm-op-shell {
        margin-left: 0;
        margin-right: 0;
        max-width: 100%;
        width: auto;
    }

    .tm-op-menu {
        flex-wrap: wrap;
    }
}

/* Panel de revendedores */
.tm-reseller-shell {
    display: grid;
    gap: 24px;
    margin: 0 auto;
    max-width: 1380px;
    padding: 24px;
}

.tm-reseller-hero {
    align-items: center;
    background:
        radial-gradient(circle at 88% 18%, rgba(32, 166, 189, .20), transparent 34%),
        linear-gradient(135deg, var(--tm-navy), #173B54);
    border-radius: 30px;
    color: #fff;
    display: grid;
    gap: 22px;
    grid-template-columns: minmax(0, 1fr) auto;
    overflow: hidden;
    padding: clamp(24px, 4vw, 44px);
    position: relative;
}

.tm-reseller-hero h2 {
    color: #fff;
    font-size: clamp(32px, 4vw, 60px);
    line-height: .98;
    margin: 8px 0 10px;
}

.tm-reseller-hero p {
    color: rgba(255, 255, 255, .84);
    font-size: 18px;
    line-height: 1.55;
    margin: 0;
    max-width: 760px;
}

.tm-reseller-rule {
    background: rgba(255, 255, 255, .10);
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 24px;
    min-width: 230px;
    padding: 20px;
}

.tm-reseller-rule span {
    color: var(--tm-sand);
    display: block;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .1em;
    margin-bottom: 8px;
    text-transform: uppercase;
}

.tm-reseller-rule strong {
    color: #fff;
    display: block;
    font-size: 28px;
    line-height: 1;
}

.tm-reseller-card {
    background: #fff;
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 28px;
    box-shadow: 0 22px 55px rgba(9, 26, 40, .065);
    padding: clamp(18px, 3vw, 32px);
}

.tm-reseller-card > h3 {
    color: var(--tm-navy);
    font-size: clamp(24px, 3vw, 36px);
    margin: 0 0 8px;
}

.tm-reseller-card > p {
    color: var(--tm-muted);
    font-size: 17px;
    margin: 0 0 18px;
}

.tm-reservas-booking-reseller {
    box-shadow: none;
    margin-top: 12px;
}

.tm-reservas-booking-reseller .tm-step-one-preview {
    display: none;
}

.tm-reservas-booking-reseller .tm-reservas-step-one-layout {
    grid-template-columns: 1fr;
}

.tm-reseller-table-wrap {
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 22px;
    overflow: auto;
}

.tm-reseller-table {
    border-collapse: collapse;
    min-width: 980px;
    width: 100%;
}

.tm-reseller-table th {
    background: var(--tm-navy);
    color: #fff;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .07em;
    padding: 15px;
    text-align: left;
    text-transform: uppercase;
}

.tm-reseller-table td {
    border-bottom: 1px solid rgba(16, 35, 53, .08);
    color: var(--tm-ink);
    padding: 16px 15px;
    vertical-align: top;
}

.tm-reseller-table tbody tr:nth-child(even) {
    background: #F8FAFA;
}

.tm-reseller-status,
.tm-op-reseller-list em {
    color: var(--tm-muted);
    font-style: normal;
}

.tm-reseller-table a {
    background: var(--tm-navy);
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    font-size: 13px;
    font-weight: 900;
    padding: 8px 13px;
    text-decoration: none;
}

.tm-op-reseller-admin {
    margin-bottom: 22px;
}

.tm-op-commercial-help {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 18px 0;
}

.tm-op-commercial-help article {
    background:
        radial-gradient(circle at 100% 0%, rgba(211, 163, 89, .10), transparent 38%),
        #fff;
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 18px;
    box-shadow: 0 18px 45px rgba(9, 26, 40, .06);
    padding: 18px;
}

.tm-op-commercial-help span {
    color: var(--tm-gold);
    display: block;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.tm-op-commercial-help strong {
    color: var(--tm-navy);
    display: block;
    font-size: 18px;
    line-height: 1.2;
}

.tm-op-commercial-help p {
    margin: 10px 0 0;
}

.tm-op-commercial-help code {
    background: #f3f8f8;
    border-radius: 8px;
    color: var(--tm-navy);
    display: inline-block;
    font-weight: 900;
    padding: 3px 7px;
}

.tm-op-form input[type="email"] {
    background: #fff;
    border: 1px solid rgba(16, 35, 53, .14);
    border-radius: 18px;
    color: var(--tm-ink);
    min-height: 54px;
    padding: 12px 16px;
}

.tm-op-reseller-list article {
    align-items: flex-start;
    display: grid;
    gap: 5px;
}

.tm-op-reseller-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 8px;
}

.tm-op-whatsapp {
    align-items: center;
    background: #128C7E;
    border: 1px solid rgba(18, 140, 126, .22);
    border-radius: 999px;
    color: #fff !important;
    display: inline-flex;
    font-size: 13px;
    font-weight: 900;
    justify-content: center;
    line-height: 1;
    padding: 10px 14px;
    text-decoration: none !important;
}

.tm-op-whatsapp:hover,
.tm-op-whatsapp:focus {
    background: #0F786C;
    border-radius: 999px;
    color: #fff !important;
}

.tm-op-pill-muted {
    background: #F7FAFA;
    color: #6A7D86;
}

/* v0.3.39: lightweight commercial operations panel. */
.tm-op-shell-lite {
    max-width: min(1760px, calc(100vw - 28px));
    margin-inline: auto;
}

.tm-op-shell-lite .tm-op-hero-luxury {
    grid-template-columns: 1fr;
}

.tm-op-shell-lite .tm-op-menu {
    position: sticky;
    top: 10px;
}

.tm-op-shell-lite .tm-op-menu button,
.tm-op-shell-lite .tm-op-record-actions button,
.tm-op-shell-lite .tm-op-metric-grid a {
    border-radius: 999px !important;
    font-style: normal !important;
    transform: none !important;
    transition: background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease !important;
}

.tm-op-shell-lite .tm-op-menu button:hover,
.tm-op-shell-lite .tm-op-menu button:focus,
.tm-op-shell-lite .tm-op-record-actions button:hover,
.tm-op-shell-lite .tm-op-record-actions button:focus,
.tm-op-shell-lite .tm-op-metric-grid a:hover,
.tm-op-shell-lite .tm-op-metric-grid a:focus {
    border-radius: 999px !important;
    font-style: normal !important;
    transform: none !important;
}

.tm-op-shell-lite .tm-op-records-form {
    display: grid;
    gap: 16px;
}

.tm-op-shell-lite .tm-op-record-actions {
    align-items: center;
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 18px;
    box-shadow: 0 14px 32px rgba(9, 26, 40, .04);
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 12px;
}

.tm-op-shell-lite .tm-op-record-actions button {
    margin: 0;
}

.tm-op-shell-lite .tm-op-table-wrap {
    max-width: 100%;
}

.tm-op-shell-lite .tm-op-table button[data-tm-copy] {
    border-radius: 10px !important;
}

/* v0.3.41: Tayrona brand buttons without hover movement or text resizing. */
.tm-reservas button,
.tm-reservas a,
.tm-op-shell button,
.tm-op-shell a,
.tm-op-shell-lite button,
.tm-op-shell-lite a,
.tm-calendar-shell button,
.tm-calendar-shell a {
    border-radius: 999px !important;
    font-style: normal !important;
    text-decoration: none !important;
    transform: none !important;
    transition: background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease !important;
}

.tm-reservas button:hover,
.tm-reservas button:focus,
.tm-reservas a:hover,
.tm-reservas a:focus,
.tm-op-shell button:hover,
.tm-op-shell button:focus,
.tm-op-shell a:hover,
.tm-op-shell a:focus,
.tm-op-shell-lite button:hover,
.tm-op-shell-lite button:focus,
.tm-op-shell-lite a:hover,
.tm-op-shell-lite a:focus,
.tm-calendar-shell button:hover,
.tm-calendar-shell button:focus,
.tm-calendar-shell a:hover,
.tm-calendar-shell a:focus {
    border-radius: 999px !important;
    font-style: normal !important;
    transform: none !important;
}

.tm-op-shell-lite .tm-op-menu button,
.tm-op-shell-lite .tm-op-record-actions button,
.tm-op-shell-lite .tm-op-metric-grid a {
    background: #F7FAFA !important;
    border: 1px solid rgba(16, 35, 53, .10) !important;
    box-shadow: none !important;
    color: #102335 !important;
    font-size: 16px !important;
    font-weight: 900 !important;
    letter-spacing: .01em !important;
    line-height: 1 !important;
    min-height: 56px !important;
    padding: 0 22px !important;
}

.tm-op-shell-lite .tm-op-menu button:hover,
.tm-op-shell-lite .tm-op-menu button:focus,
.tm-op-shell-lite .tm-op-menu button.is-active,
.tm-op-shell-lite .tm-op-record-actions button:hover,
.tm-op-shell-lite .tm-op-record-actions button:focus,
.tm-op-shell-lite .tm-op-metric-grid a:hover,
.tm-op-shell-lite .tm-op-metric-grid a:focus {
    background: #102335 !important;
    border-color: #102335 !important;
    box-shadow: 0 10px 24px rgba(9, 26, 40, .12) !important;
    color: #FFFFFF !important;
    font-size: 16px !important;
    font-weight: 900 !important;
    letter-spacing: .01em !important;
    line-height: 1 !important;
    min-height: 56px !important;
    padding: 0 22px !important;
}

.tm-op-shell-lite .tm-op-record-actions button.tm-op-danger,
.tm-op-shell-lite .tm-op-record-actions button[data-action="delete"] {
    background: #FFFFFF !important;
    border-color: rgba(184, 58, 58, .28) !important;
    color: #8F2D2D !important;
}

.tm-op-shell-lite .tm-op-record-actions button.tm-op-danger:hover,
.tm-op-shell-lite .tm-op-record-actions button.tm-op-danger:focus,
.tm-op-shell-lite .tm-op-record-actions button[data-action="delete"]:hover,
.tm-op-shell-lite .tm-op-record-actions button[data-action="delete"]:focus {
    background: #8F2D2D !important;
    border-color: #8F2D2D !important;
    color: #FFFFFF !important;
}

.tm-calendar-actions a,
.tm-calendar-actions strong {
    border-radius: 999px !important;
    box-shadow: none !important;
    font-size: 16px !important;
    font-weight: 900 !important;
    font-style: normal !important;
    letter-spacing: .01em !important;
    line-height: 1 !important;
    min-height: 56px !important;
    padding: 0 22px !important;
    text-decoration: none !important;
    transform: none !important;
}

.tm-calendar-actions a {
    background: rgba(255, 255, 255, .12) !important;
    border: 1px solid rgba(255, 255, 255, .22) !important;
    color: #FFFFFF !important;
}

.tm-calendar-actions a:hover,
.tm-calendar-actions a:focus {
    background: rgba(255, 255, 255, .18) !important;
    border-color: rgba(211, 163, 89, .58) !important;
    color: #FFFFFF !important;
    font-size: 16px !important;
    font-weight: 900 !important;
    font-style: normal !important;
    letter-spacing: .01em !important;
    line-height: 1 !important;
    min-height: 56px !important;
    padding: 0 22px !important;
    transform: none !important;
}

.tm-calendar-actions strong {
    background: #FFFFFF !important;
    border-color: #FFFFFF !important;
    color: #102335 !important;
}

.tm-reservas-button,
.tm-reservas-small-button,
.tm-reservas-button:hover,
.tm-reservas-small-button:hover,
.tm-reservas-button:focus,
.tm-reservas-small-button:focus {
    border-radius: 999px !important;
    font-weight: 900 !important;
    font-style: normal !important;
    letter-spacing: .01em !important;
    transform: none !important;
}

.tm-reservas-button,
.tm-reservas-button:hover,
.tm-reservas-button:focus {
    font-size: 17px !important;
    line-height: 1 !important;
    min-height: 58px !important;
    padding: 0 24px !important;
}

.tm-reservas-small-button,
.tm-reservas-small-button:hover,
.tm-reservas-small-button:focus {
    font-size: 13px !important;
    line-height: 1 !important;
    min-height: 40px !important;
    padding: 0 14px !important;
}

@media (max-width: 760px) {
    .tm-op-shell-lite {
        border-radius: 18px;
        max-width: calc(100vw - 12px);
        padding: 12px;
    }

    .tm-op-shell-lite .tm-op-menu {
        overflow-x: auto;
        flex-wrap: nowrap;
        position: relative;
        top: auto;
    }

    .tm-op-shell-lite .tm-op-menu button {
        flex: 0 0 auto;
        white-space: nowrap;
    }

    .tm-op-shell-lite .tm-op-section,
    .tm-op-shell-lite .tm-op-hero-luxury {
        border-radius: 18px;
        padding: 16px;
    }

    .tm-op-shell-lite .tm-op-section-head {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 860px) {
    .tm-reseller-shell {
        padding: 12px;
    }

    .tm-reseller-hero {
        grid-template-columns: 1fr;
    }

    .tm-reseller-rule {
        min-width: 0;
        width: auto;
    }

}

/* v0.3.42: Manual de marca Tayrona Marino, espacios compactos y responsive. */
.tm-reservas,
.tm-op-shell,
.tm-op-shell-lite,
.tm-calendar-shell {
    --tm-navy: #102335;
    --tm-navy-950: #060D14;
    --tm-navy-800: #1B3C5A;
    --tm-turquoise: #20A6BD;
    --tm-turquoise-500: #25BFDA;
    --tm-turquoise-400: #4CCAE1;
    --tm-turquoise-700: #187A8C;
    --tm-sand: #D3A359;
    --tm-sand-700: #C3944C;
    --tm-sand-50: #FCF6EF;
    --tm-white: #FFFFFF;
    --tm-ink: #091A28;
    --tm-muted: #60717D;
    --tm-line-brand: rgba(16, 35, 53, .11);
    --font-display: "Trajan Pro 3", "Cinzel", Georgia, serif;
    --font-sans: "Montserrat", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --radius-lg: 28px;
    --radius-md: 18px;
    font-family: var(--font-sans);
}

.tm-op-shell-lite {
    border-radius: var(--radius-lg);
    gap: 18px;
    margin: 14px auto 0;
    max-width: min(1640px, calc(100vw - 24px));
    padding: 18px;
}

.tm-op-shell-lite .tm-op-hero-luxury,
.tm-op-shell-lite .tm-op-section,
.tm-calendar-list,
.tm-calendar-legend {
    border: 1px solid var(--tm-line-brand);
    border-radius: 24px;
    box-shadow: 0 18px 48px rgba(9, 26, 40, .055);
}

.tm-op-shell-lite .tm-op-hero-luxury {
    background:
        radial-gradient(circle at 86% 18%, rgba(76, 202, 225, .16), transparent 32%),
        linear-gradient(135deg, var(--tm-navy), var(--tm-navy-800));
    min-height: 0;
    padding: clamp(20px, 2.6vw, 32px);
}

.tm-op-shell-lite .tm-op-hero-luxury h2,
.tm-calendar-hero h2 {
    font-family: var(--font-display);
    font-weight: 700;
    letter-spacing: .01em;
    line-height: .92;
}

.tm-op-shell-lite .tm-op-hero-luxury h2 {
    font-size: clamp(34px, 3.8vw, 58px);
    margin: 6px 0 8px;
}

.tm-op-shell-lite .tm-op-hero-luxury p,
.tm-calendar-hero p {
    font-size: clamp(14px, 1.2vw, 17px);
    line-height: 1.55;
}

.tm-op-shell-lite .tm-op-section {
    padding: clamp(16px, 2.2vw, 28px);
}

.tm-op-shell-lite .tm-op-section-head {
    gap: 16px;
    margin-bottom: 14px;
}

.tm-op-shell-lite .tm-op-section-head h3 {
    font-size: clamp(24px, 2.6vw, 38px);
    letter-spacing: -.03em;
    margin: 6px 0 6px;
}

.tm-op-shell-lite .tm-op-menu {
    background: rgba(255, 255, 255, .9);
    border: 1px solid rgba(16, 35, 53, .10);
    border-radius: 24px;
    box-shadow: 0 12px 34px rgba(9, 26, 40, .045);
    gap: 10px;
    padding: 10px;
}

.tm-op-shell-lite .tm-op-menu button,
.tm-op-shell-lite .tm-op-record-actions button,
.tm-op-shell-lite .tm-op-metric-grid a,
.tm-calendar-actions a,
.tm-calendar-actions strong,
.tm-reservas-button,
.tm-reservas-small-button {
    align-items: center !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    font-family: var(--font-sans) !important;
    font-size: 12px !important;
    font-style: normal !important;
    font-weight: 900 !important;
    justify-content: center !important;
    letter-spacing: .08em !important;
    line-height: 1 !important;
    min-height: 48px !important;
    padding: 0 20px !important;
    text-transform: uppercase !important;
    transform: none !important;
    transition: background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease !important;
    white-space: nowrap;
}

.tm-op-shell-lite .tm-op-menu button,
.tm-op-shell-lite .tm-op-record-actions button,
.tm-op-shell-lite .tm-op-metric-grid a {
    background: rgba(255, 255, 255, .72) !important;
    border: 1px solid rgba(16, 35, 53, .13) !important;
    box-shadow: none !important;
    color: var(--tm-navy) !important;
}

.tm-op-shell-lite .tm-op-menu button:hover,
.tm-op-shell-lite .tm-op-menu button:focus,
.tm-op-shell-lite .tm-op-record-actions button:hover,
.tm-op-shell-lite .tm-op-record-actions button:focus,
.tm-op-shell-lite .tm-op-metric-grid a:hover,
.tm-op-shell-lite .tm-op-metric-grid a:focus {
    background: rgba(32, 166, 189, .12) !important;
    border-color: rgba(32, 166, 189, .35) !important;
    box-shadow: 0 10px 22px rgba(9, 26, 40, .08) !important;
    color: var(--tm-navy) !important;
    font-size: 12px !important;
    min-height: 48px !important;
    padding: 0 20px !important;
    transform: none !important;
}

.tm-op-shell-lite .tm-op-menu button.is-active,
.tm-op-shell-lite .tm-op-menu button.is-active:hover,
.tm-op-shell-lite .tm-op-menu button.is-active:focus {
    background: var(--tm-navy) !important;
    border-color: var(--tm-navy) !important;
    color: var(--tm-white) !important;
}

.tm-op-shell-lite .tm-op-record-actions button.tm-op-danger,
.tm-op-shell-lite .tm-op-record-actions button[data-action="delete"] {
    border-color: rgba(184, 58, 58, .26) !important;
    color: #8F2D2D !important;
}

.tm-op-shell-lite .tm-op-record-actions button.tm-op-danger:hover,
.tm-op-shell-lite .tm-op-record-actions button.tm-op-danger:focus,
.tm-op-shell-lite .tm-op-record-actions button[data-action="delete"]:hover,
.tm-op-shell-lite .tm-op-record-actions button[data-action="delete"]:focus {
    background: #8F2D2D !important;
    border-color: #8F2D2D !important;
    color: var(--tm-white) !important;
}

.tm-op-shell-lite .tm-op-metric-grid,
.tm-op-shell-lite .tm-op-status-grid {
    gap: 14px;
}

.tm-op-shell-lite .tm-op-metric-grid article,
.tm-op-shell-lite .tm-op-status-grid article,
.tm-op-shell-lite .tm-op-record-actions {
    border-radius: 20px;
    padding: 16px;
}

.tm-op-shell-lite .tm-op-table th,
.tm-op-shell-lite .tm-op-table td {
    padding: 12px 14px;
}

.tm-calendar-shell {
    gap: 16px;
}

.tm-calendar-hero {
    background:
        radial-gradient(circle at 84% 12%, rgba(76, 202, 225, .16), transparent 30%),
        linear-gradient(135deg, var(--tm-navy), var(--tm-navy-800));
    border-radius: var(--radius-lg);
    gap: 18px;
    padding: clamp(20px, 2.8vw, 34px);
}

.tm-calendar-hero h2 {
    font-size: clamp(36px, 4.1vw, 64px);
    margin-bottom: 10px;
}

.tm-calendar-actions {
    flex-wrap: wrap;
    gap: 10px;
}

.tm-calendar-actions a {
    background: linear-gradient(90deg, var(--tm-turquoise), var(--tm-turquoise-500)) !important;
    border-color: transparent !important;
    color: var(--tm-navy) !important;
}

.tm-calendar-actions a:hover,
.tm-calendar-actions a:focus {
    background: linear-gradient(90deg, var(--tm-turquoise-500), var(--tm-turquoise-400)) !important;
    border-color: transparent !important;
    color: var(--tm-navy) !important;
    font-size: 12px !important;
    min-height: 48px !important;
    padding: 0 20px !important;
}

.tm-calendar-actions strong {
    background: var(--tm-white) !important;
    border-color: var(--tm-white) !important;
    color: var(--tm-navy) !important;
}

.tm-calendar-legend,
.tm-calendar-list {
    padding: 16px 18px;
}

.tm-calendar-grid {
    border-radius: 24px;
}

.tm-calendar-weekday {
    font-size: 11px;
    letter-spacing: .10em;
    padding: 12px;
}

.tm-calendar-day {
    min-height: 128px;
    padding: 10px;
}

.tm-reservas-booking {
    border-radius: 24px;
    padding: clamp(14px, 2vw, 22px);
}

.tm-reservas-form {
    gap: 14px;
}

.tm-reservas-form-surface {
    border-radius: 22px;
    padding: clamp(14px, 2vw, 20px);
}

.tm-reservas-button,
.tm-reservas-button:hover,
.tm-reservas-button:focus {
    background: var(--tm-navy) !important;
    color: var(--tm-white) !important;
    font-size: 13px !important;
    min-height: 54px !important;
    padding: 0 22px !important;
}

.tm-reservas-small-button,
.tm-reservas-small-button:hover,
.tm-reservas-small-button:focus {
    font-size: 11px !important;
    min-height: 38px !important;
    padding: 0 14px !important;
}

@media (max-width: 1024px) {
    .tm-op-shell-lite {
        max-width: calc(100vw - 16px);
        padding: 14px;
    }

    .tm-calendar-hero {
        grid-template-columns: 1fr;
    }

    .tm-calendar-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 760px) {
    .tm-op-shell-lite {
        border-radius: 18px;
        gap: 14px;
        max-width: 100%;
        padding: 10px;
    }

    .tm-op-shell-lite .tm-op-hero-luxury,
    .tm-op-shell-lite .tm-op-section,
    .tm-calendar-hero,
    .tm-calendar-legend,
    .tm-calendar-list {
        border-radius: 20px;
        padding: 16px;
    }

    .tm-op-shell-lite .tm-op-hero-luxury h2,
    .tm-calendar-hero h2 {
        font-size: clamp(34px, 11vw, 46px);
        line-height: .9;
    }

    .tm-op-shell-lite .tm-op-menu {
        border-radius: 22px;
        flex-wrap: nowrap;
        overflow-x: auto;
        padding: 8px;
        position: relative;
        scrollbar-width: thin;
        top: auto;
    }

    .tm-op-shell-lite .tm-op-menu button,
    .tm-op-shell-lite .tm-op-record-actions button,
    .tm-op-shell-lite .tm-op-metric-grid a,
    .tm-calendar-actions a,
    .tm-calendar-actions strong {
        flex: 0 0 auto;
        font-size: 11px !important;
        letter-spacing: .06em !important;
        min-height: 42px !important;
        padding: 0 14px !important;
    }

    .tm-op-shell-lite .tm-op-menu button:hover,
    .tm-op-shell-lite .tm-op-menu button:focus,
    .tm-op-shell-lite .tm-op-record-actions button:hover,
    .tm-op-shell-lite .tm-op-record-actions button:focus,
    .tm-op-shell-lite .tm-op-metric-grid a:hover,
    .tm-op-shell-lite .tm-op-metric-grid a:focus,
    .tm-calendar-actions a:hover,
    .tm-calendar-actions a:focus {
        font-size: 11px !important;
        min-height: 42px !important;
        padding: 0 14px !important;
    }

    .tm-op-shell-lite .tm-op-section-head,
    .tm-reservas-quote-layout,
    .tm-reservas-booking-grid,
    .tm-reservas-primary-grid,
    .tm-reservas-boat-passenger-grid {
        grid-template-columns: 1fr;
    }

    .tm-calendar-actions {
        overflow-x: auto;
        padding-bottom: 2px;
    }

    .tm-calendar-grid {
        border-radius: 20px;
    }

    .tm-calendar-day {
        padding: 12px;
    }

    .tm-reservas-booking {
        border-radius: 20px;
        padding: 12px;
    }
}

@media (max-width: 480px) {
    .tm-op-shell-lite {
        margin-top: 8px;
        padding: 8px;
    }

    .tm-op-shell-lite .tm-op-hero-luxury p,
    .tm-calendar-hero p {
        font-size: 14px;
    }

    .tm-op-shell-lite .tm-op-metric-grid,
    .tm-op-shell-lite .tm-op-status-grid {
        grid-template-columns: 1fr;
    }
}

/* v0.3.43: botones frontend sin saltos de texto, tracking ni cambios de caja. */
.tm-reservas button,
.tm-reservas input[type="button"],
.tm-reservas input[type="submit"],
.tm-reservas .tm-reservas-button,
.tm-reservas .tm-reservas-small-button,
.tm-reservas .tm-op-menu button,
.tm-reservas .tm-op-form button,
.tm-reservas .tm-op-record-actions button,
.tm-reservas .tm-op-boat-price-card button,
.tm-reservas .tm-op-guide-control button,
.tm-reservas .tm-op-panel-title button,
.tm-reservas .tm-op-route-add,
.tm-reservas .tm-op-route-remove,
.tm-reservas .tm-op-delete-button,
.tm-reservas .tm-op-whatsapp,
.tm-reservas .tm-op-metric-grid a,
.tm-reservas .tm-calendar-actions a,
.tm-reservas .tm-calendar-actions strong {
    border-radius: 999px !important;
    font-family: var(--font-sans, "Montserrat", system-ui, sans-serif) !important;
    font-size: var(--tm-btn-size, 15px) !important;
    font-style: normal !important;
    font-variation-settings: normal !important;
    font-weight: 800 !important;
    letter-spacing: .02em !important;
    line-height: 1 !important;
    min-height: var(--tm-btn-height, 46px) !important;
    padding: 0 var(--tm-btn-x, 18px) !important;
    text-rendering: geometricPrecision;
    text-transform: none !important;
    transform: none !important;
    translate: none !important;
    scale: none !important;
    will-change: auto !important;
    transition: background-color .16s ease, border-color .16s ease, color .16s ease, box-shadow .16s ease !important;
}

.tm-reservas button:hover,
.tm-reservas button:focus,
.tm-reservas button:active,
.tm-reservas input[type="button"]:hover,
.tm-reservas input[type="button"]:focus,
.tm-reservas input[type="button"]:active,
.tm-reservas input[type="submit"]:hover,
.tm-reservas input[type="submit"]:focus,
.tm-reservas input[type="submit"]:active,
.tm-reservas .tm-reservas-button:hover,
.tm-reservas .tm-reservas-button:focus,
.tm-reservas .tm-reservas-button:active,
.tm-reservas .tm-reservas-small-button:hover,
.tm-reservas .tm-reservas-small-button:focus,
.tm-reservas .tm-reservas-small-button:active,
.tm-reservas .tm-op-menu button:hover,
.tm-reservas .tm-op-menu button:focus,
.tm-reservas .tm-op-menu button:active,
.tm-reservas .tm-op-menu button.is-active,
.tm-reservas .tm-op-form button:hover,
.tm-reservas .tm-op-form button:focus,
.tm-reservas .tm-op-form button:active,
.tm-reservas .tm-op-record-actions button:hover,
.tm-reservas .tm-op-record-actions button:focus,
.tm-reservas .tm-op-record-actions button:active,
.tm-reservas .tm-op-boat-price-card button:hover,
.tm-reservas .tm-op-boat-price-card button:focus,
.tm-reservas .tm-op-boat-price-card button:active,
.tm-reservas .tm-op-guide-control button:hover,
.tm-reservas .tm-op-guide-control button:focus,
.tm-reservas .tm-op-guide-control button:active,
.tm-reservas .tm-op-panel-title button:hover,
.tm-reservas .tm-op-panel-title button:focus,
.tm-reservas .tm-op-panel-title button:active,
.tm-reservas .tm-op-route-add:hover,
.tm-reservas .tm-op-route-add:focus,
.tm-reservas .tm-op-route-add:active,
.tm-reservas .tm-op-route-remove:hover,
.tm-reservas .tm-op-route-remove:focus,
.tm-reservas .tm-op-route-remove:active,
.tm-reservas .tm-op-delete-button:hover,
.tm-reservas .tm-op-delete-button:focus,
.tm-reservas .tm-op-delete-button:active,
.tm-reservas .tm-op-whatsapp:hover,
.tm-reservas .tm-op-whatsapp:focus,
.tm-reservas .tm-op-whatsapp:active,
.tm-reservas .tm-op-metric-grid a:hover,
.tm-reservas .tm-op-metric-grid a:focus,
.tm-reservas .tm-op-metric-grid a:active,
.tm-reservas .tm-calendar-actions a:hover,
.tm-reservas .tm-calendar-actions a:focus,
.tm-reservas .tm-calendar-actions a:active,
.tm-reservas .tm-calendar-actions strong:hover,
.tm-reservas .tm-calendar-actions strong:focus,
.tm-reservas .tm-calendar-actions strong:active {
    border-radius: 999px !important;
    font-size: var(--tm-btn-size, 15px) !important;
    font-style: normal !important;
    font-variation-settings: normal !important;
    font-weight: 800 !important;
    letter-spacing: .02em !important;
    line-height: 1 !important;
    min-height: var(--tm-btn-height, 46px) !important;
    padding: 0 var(--tm-btn-x, 18px) !important;
    text-transform: none !important;
    transform: none !important;
    translate: none !important;
    scale: none !important;
}

.tm-reservas .tm-reservas-button {
    --tm-btn-size: 16px;
    --tm-btn-height: 54px;
    --tm-btn-x: 24px;
}

.tm-reservas .tm-reservas-small-button {
    --tm-btn-size: 13px;
    --tm-btn-height: 40px;
    --tm-btn-x: 14px;
}

.tm-reservas .tm-op-menu button,
.tm-reservas .tm-calendar-actions a,
.tm-reservas .tm-calendar-actions strong {
    --tm-btn-size: 15px;
    --tm-btn-height: 48px;
    --tm-btn-x: 20px;
}

@media (max-width: 760px) {
    .tm-reservas .tm-op-menu button,
    .tm-reservas .tm-calendar-actions a,
    .tm-reservas .tm-calendar-actions strong {
        --tm-btn-size: 14px;
        --tm-btn-height: 42px;
        --tm-btn-x: 14px;
    }
}

/* v0.3.59: enlace privado de abordaje editable con Elementor. */
.tm-boarding-empty,
.tm-client-boarding {
    --tm-client-navy: #102335;
    --tm-client-deep: #091A28;
    --tm-client-gold: #D9A64F;
    --tm-client-muted: #526A79;
    --tm-client-line: rgba(16, 35, 53, .10);
    --tm-client-soft: #F7FAFA;
    color: var(--tm-client-deep);
    font-family: var(--font-sans, "Montserrat", system-ui, sans-serif);
}

.tm-boarding-empty {
    background: linear-gradient(135deg, #FFFFFF 0%, #F7FAFA 100%);
    border: 1px solid var(--tm-client-line);
    border-radius: 24px;
    box-shadow: 0 22px 60px rgba(9, 26, 40, .08);
    margin: 18px auto;
    max-width: 920px;
    padding: clamp(22px, 4vw, 42px);
}

.tm-boarding-empty h2 {
    color: var(--tm-client-deep);
    font-size: clamp(30px, 5vw, 54px);
    line-height: .98;
    margin: 0 0 12px;
}

.tm-boarding-empty p {
    color: var(--tm-client-muted);
    font-size: 17px;
    margin: 0;
}

.tm-client-boarding {
    display: grid;
    gap: 18px;
    margin: 18px auto;
    max-width: 1180px;
}

.tm-client-hero {
    align-items: center;
    background:
        linear-gradient(135deg, rgba(255,255,255,.96) 0%, rgba(247,250,250,.94) 100%),
        radial-gradient(circle at 100% 0%, rgba(103,199,236,.22), transparent 36%);
    border: 1px solid var(--tm-client-line);
    border-left: 4px solid var(--tm-client-gold);
    border-radius: 26px;
    box-shadow: 0 24px 70px rgba(9, 26, 40, .08);
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) auto;
    padding: clamp(22px, 4vw, 34px);
}

.tm-client-hero h2 {
    color: var(--tm-client-deep);
    font-size: clamp(34px, 5vw, 64px);
    line-height: .95;
    margin: 6px 0 12px;
}

.tm-client-hero p {
    color: var(--tm-client-muted);
    font-size: clamp(15px, 1.7vw, 18px);
    margin: 0;
}

.tm-client-code {
    background: var(--tm-client-navy);
    border-radius: 22px;
    box-shadow: 0 18px 44px rgba(9, 26, 40, .16);
    color: #FFFFFF;
    min-width: 210px;
    padding: 20px;
}

.tm-client-code span,
.tm-client-summary-grid span,
.tm-client-price-row span,
.tm-client-muted {
    color: var(--tm-client-muted);
}

.tm-client-code span {
    color: rgba(255,255,255,.72);
    display: block;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .12em;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.tm-client-code strong {
    display: block;
    font-size: 21px;
    letter-spacing: .02em;
}

.tm-client-alert {
    border-radius: 18px;
    font-weight: 800;
    padding: 14px 18px;
}

.tm-client-alert-success {
    background: #ECF8F1;
    border: 1px solid rgba(46, 139, 87, .24);
    color: #165C37;
}

.tm-client-alert-warning {
    background: #FFF7E8;
    border: 1px solid rgba(217, 166, 79, .32);
    color: #7B4B05;
}

.tm-client-layout {
    align-items: start;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) 340px;
}

.tm-client-main,
.tm-client-sidebar {
    display: grid;
    gap: 18px;
}

.tm-client-card {
    background: #FFFFFF;
    border: 1px solid var(--tm-client-line);
    border-radius: 24px;
    box-shadow: 0 22px 58px rgba(9, 26, 40, .06);
    padding: clamp(18px, 3vw, 26px);
}

.tm-client-card h3 {
    color: var(--tm-client-deep);
    font-size: clamp(24px, 3vw, 34px);
    line-height: 1.05;
    margin: 4px 0 12px;
}

.tm-client-card p {
    color: var(--tm-client-muted);
    font-size: 16px;
    line-height: 1.6;
    margin: 0;
}

.tm-client-card-head {
    border-bottom: 1px solid rgba(16, 35, 53, .08);
    margin-bottom: 18px;
    padding-bottom: 16px;
}

.tm-client-summary-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tm-client-summary-grid div {
    background: var(--tm-client-soft);
    border: 1px solid rgba(16, 35, 53, .06);
    border-radius: 18px;
    padding: 14px;
}

.tm-client-summary-grid span,
.tm-client-price-row span {
    display: block;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    margin-bottom: 5px;
    text-transform: uppercase;
}

.tm-client-summary-grid strong {
    color: var(--tm-client-deep);
    display: block;
    font-size: 16px;
}

.tm-client-itinerary {
    display: grid;
    gap: 12px;
}

.tm-client-itinerary-item {
    align-items: flex-start;
    display: grid;
    gap: 12px;
    grid-template-columns: 34px minmax(0, 1fr);
}

.tm-client-itinerary-dot {
    align-items: center;
    background: var(--tm-client-navy);
    border-radius: 999px;
    color: #FFFFFF;
    display: inline-flex;
    font-size: 13px;
    font-weight: 900;
    height: 34px;
    justify-content: center;
    width: 34px;
}

.tm-client-itinerary-item strong {
    color: var(--tm-client-deep);
    display: block;
    margin-bottom: 3px;
}

.tm-client-itinerary-item p,
.tm-client-itinerary-item small {
    color: var(--tm-client-muted);
}

.tm-client-itinerary-item p span {
    color: var(--tm-client-gold);
    font-weight: 900;
    margin: 0 6px;
}

.tm-client-passenger-form {
    display: grid;
    gap: 18px;
}

.tm-client-form-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.tm-client-form-grid label {
    display: grid;
    gap: 7px;
}

.tm-client-form-grid label span {
    color: var(--tm-client-deep);
    font-size: 13px;
    font-weight: 900;
}

.tm-client-form-grid input,
.tm-client-form-grid select {
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .14);
    border-radius: 16px;
    box-shadow: none;
    color: var(--tm-client-deep);
    font-size: 15px;
    min-height: 50px;
    padding: 0 14px;
    width: 100%;
}

.tm-client-form-grid input:focus,
.tm-client-form-grid select:focus {
    border-color: rgba(16, 35, 53, .32);
    box-shadow: 0 0 0 4px rgba(16, 35, 53, .08);
    outline: none;
}

.tm-client-complete {
    background: #ECF8F1;
    border: 1px solid rgba(46, 139, 87, .22);
    border-radius: 18px;
    padding: 16px;
}

.tm-client-guests {
    border-top: 1px solid rgba(16, 35, 53, .08);
    display: grid;
    gap: 10px;
    margin-top: 20px;
    padding-top: 18px;
}

.tm-client-guest-row {
    align-items: center;
    background: var(--tm-client-soft);
    border: 1px solid rgba(16, 35, 53, .06);
    border-radius: 16px;
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 12px 14px;
}

.tm-client-guest-row strong,
.tm-client-guest-row span,
.tm-client-guest-row small {
    display: block;
}

.tm-client-guest-row span,
.tm-client-guest-row small {
    color: var(--tm-client-muted);
    font-size: 13px;
}

.tm-client-price-card {
    background: linear-gradient(135deg, #102335 0%, #173B54 100%);
    color: #FFFFFF;
}

.tm-client-price-card .tm-reservas-kicker,
.tm-client-price-card p,
.tm-client-price-card .tm-client-price-row span {
    color: rgba(255,255,255,.76);
}

.tm-client-price-row {
    align-items: center;
    border-bottom: 1px solid rgba(255,255,255,.12);
    display: flex;
    gap: 12px;
    justify-content: space-between;
    padding: 13px 0;
}

.tm-client-price-row strong {
    color: #FFFFFF;
    font-size: 16px;
    text-align: right;
}

.tm-client-price-row.is-deposit strong {
    color: #F0C06F;
    font-size: 19px;
}

.tm-client-price-card p {
    margin-top: 14px;
}

.tm-client-boat-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.tm-client-boat-tags span {
    background: var(--tm-client-soft);
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 999px;
    color: var(--tm-client-deep);
    font-size: 13px;
    font-weight: 800;
    padding: 8px 11px;
}

.tm-client-sidebar .tm-reservas-small-button {
    margin-top: 14px;
    width: 100%;
}

@media (max-width: 980px) {
    .tm-client-layout,
    .tm-client-hero {
        grid-template-columns: 1fr;
    }

    .tm-client-code {
        min-width: 0;
    }

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

@media (max-width: 640px) {
    .tm-client-boarding {
        margin: 12px auto;
    }

    .tm-client-hero,
    .tm-client-card,
    .tm-boarding-empty {
        border-radius: 20px;
        padding: 16px;
    }

    .tm-client-summary-grid,
    .tm-client-form-grid,
    .tm-client-guest-row {
        grid-template-columns: 1fr;
    }

    .tm-client-price-row {
        align-items: flex-start;
        flex-direction: column;
    }

    .tm-client-price-row strong {
        text-align: left;
    }
}

.tm-route-itinerary {
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .10);
    border-left: 5px solid var(--tm-sand);
    border-radius: 24px;
    box-shadow: 0 22px 60px rgba(9, 26, 40, .08);
    margin: 28px auto;
    max-width: 1180px;
    overflow: hidden;
    padding: clamp(18px, 3vw, 30px);
}

.tm-route-itinerary-hero {
    align-items: center;
    background:
        radial-gradient(circle at 100% 0%, rgba(32, 166, 189, .10), transparent 32%),
        linear-gradient(135deg, #FFFFFF 0%, #F8FCFC 100%);
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 20px;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) auto;
    margin-bottom: 18px;
    padding: clamp(18px, 2.4vw, 26px);
}

.tm-route-itinerary-hero span,
.tm-route-itinerary-count em {
    color: var(--tm-sand);
    display: block;
    font-size: 12px;
    font-style: normal;
    font-weight: 900;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.tm-route-itinerary-hero h2 {
    color: var(--tm-ink);
    font-size: clamp(34px, 4vw, 54px);
    letter-spacing: -.055em;
    line-height: .96;
    margin: 8px 0 10px;
}

.tm-route-itinerary-hero p {
    color: var(--tm-muted);
    font-size: 16px;
    line-height: 1.6;
    margin: 0;
    max-width: 760px;
}

.tm-route-itinerary-route-name {
    border-left: 1px solid rgba(16, 35, 53, .12);
    color: var(--tm-ink);
    justify-self: end;
    min-width: 180px;
    padding-left: 22px;
    text-align: right;
}

.tm-route-itinerary-route-name span {
    color: var(--tm-sand);
    display: block;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .13em;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.tm-route-itinerary-route-name strong {
    display: block;
    font-size: 20px;
    font-weight: 900;
    letter-spacing: -.025em;
    line-height: 1.05;
}

.tm-route-itinerary-list {
    display: grid;
    gap: 14px;
}

.tm-route-itinerary-step {
    align-items: stretch;
    background: #FFFFFF;
    border: 1px solid rgba(16, 35, 53, .09);
    border-radius: 22px;
    display: grid;
    gap: clamp(22px, 3vw, 34px);
    grid-template-columns: minmax(220px, 260px) minmax(0, 1fr);
    padding: 12px 22px 12px 12px;
}

.tm-route-itinerary-step-salida {
    border-left: 5px solid rgba(36, 137, 86, .72);
}

.tm-route-itinerary-step-destino {
    border-left: 5px solid rgba(214, 164, 86, .72);
}

.tm-route-itinerary-step-regreso {
    border-left: 5px solid rgba(184, 61, 61, .68);
}

.tm-route-itinerary-step-no-media {
    background:
        radial-gradient(circle at 100% 0%, rgba(184, 61, 61, .05), transparent 34%),
        #FFFFFF;
    grid-template-columns: minmax(0, 1fr);
    padding: 22px 24px;
}

.tm-route-itinerary-step-no-media .tm-route-itinerary-body {
    padding: 0;
}

.tm-route-itinerary-step-no-media .tm-route-itinerary-body h3 {
    font-size: clamp(22px, 2.2vw, 30px);
}

.tm-route-itinerary-media {
    aspect-ratio: 1 / 1;
    background: linear-gradient(135deg, #102335 0%, #1F5368 100%);
    border-radius: 18px;
    max-width: 260px;
    overflow: hidden;
    width: 100%;
}

.tm-route-itinerary-media img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.tm-route-itinerary-fallback {
    align-content: end;
    background:
        radial-gradient(circle at 74% 18%, rgba(32, 166, 189, .24), transparent 34%),
        linear-gradient(135deg, #102335 0%, #173B54 100%);
    color: #FFFFFF;
    display: grid;
    height: 100%;
    padding: 18px;
}

.tm-route-itinerary-fallback span {
    color: var(--tm-sand);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .13em;
    text-transform: uppercase;
}

.tm-route-itinerary-fallback strong {
    font-size: 20px;
    line-height: 1.1;
    margin-top: 6px;
}

.tm-route-itinerary-body {
    align-content: center;
    display: grid;
    gap: 9px;
    min-width: 0;
    padding: 10px 0;
}

.tm-route-itinerary-count {
    align-items: center;
    display: flex;
    gap: 10px;
}

.tm-route-itinerary-count span {
    align-items: center;
    background: var(--tm-navy);
    border-radius: 999px;
    color: #FFFFFF;
    display: inline-flex;
    font-size: 13px;
    font-weight: 900;
    height: 34px;
    justify-content: center;
    width: 34px;
}

.tm-route-itinerary-body h3 {
    color: var(--tm-ink);
    font-size: clamp(24px, 2.5vw, 34px);
    letter-spacing: -.04em;
    line-height: 1.08;
    margin: 0;
}

.tm-route-itinerary-path {
    color: var(--tm-navy);
    font-size: 15px;
    font-weight: 900;
    line-height: 1.45;
    margin: 0;
}

.tm-route-itinerary-path span {
    color: var(--tm-muted);
    font-weight: 700;
    margin: 0 7px;
}

.tm-route-itinerary-description {
    color: var(--tm-muted);
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
    max-width: 720px;
}

.tm-route-itinerary-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.tm-route-itinerary-meta span {
    background: var(--tm-surface-soft);
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 999px;
    color: var(--tm-ink);
    font-size: 13px;
    font-weight: 800;
    padding: 8px 11px;
}

.tm-route-itinerary-note {
    color: var(--tm-muted);
    font-size: 15px;
    line-height: 1.55;
    margin: 2px 0 0;
}

.tm-route-itinerary-link {
    align-items: center;
    background: var(--tm-navy);
    border: 1px solid var(--tm-navy);
    border-radius: 999px;
    color: #FFFFFF !important;
    display: inline-flex;
    font-size: 13px;
    font-weight: 900;
    justify-content: center;
    letter-spacing: .01em;
    line-height: 1;
    margin-top: 4px;
    min-height: 42px;
    padding: 0 18px;
    text-decoration: none !important;
    width: fit-content;
}

.tm-route-itinerary-link:hover,
.tm-route-itinerary-link:focus {
    background: #173B54;
    border-color: #173B54;
    color: #FFFFFF !important;
    font-size: 13px;
    text-decoration: none !important;
    transform: none !important;
}

.tm-route-itinerary-empty {
    background: var(--tm-surface-soft);
    border: 1px solid rgba(16, 35, 53, .08);
    border-radius: 18px;
    color: var(--tm-muted);
    padding: 18px;
}

.tm-route-itinerary-empty strong {
    color: var(--tm-ink);
    display: block;
    font-size: 20px;
    margin-bottom: 6px;
}

.tm-route-itinerary-empty p {
    margin: 0;
}

@media (max-width: 820px) {
    .tm-route-itinerary-hero,
    .tm-route-itinerary-step {
        grid-template-columns: 1fr;
    }

    .tm-route-itinerary-route-name {
        border-left: 0;
        border-top: 1px solid rgba(16, 35, 53, .10);
        justify-self: stretch;
        min-width: 0;
        padding-left: 0;
        padding-top: 14px;
        text-align: left;
    }

    .tm-route-itinerary-media {
        aspect-ratio: 16 / 10;
        max-width: none;
    }

    .tm-route-itinerary-body {
        padding: 0 4px 4px;
    }
}

@media (max-width: 520px) {
    .tm-route-itinerary {
        border-radius: 20px;
        margin: 18px auto;
        padding: 14px;
    }

    .tm-route-itinerary-hero,
    .tm-route-itinerary-step {
        border-radius: 18px;
    }

    .tm-route-itinerary-hero h2 {
        font-size: 34px;
    }
}
