/* File: wwwroot/css/site.css */

:root {
    --hotelcode-logo-size: 2.75rem;
    --hotelcode-logo-radius: 1rem;
    --hotelcode-logo-padding: 0;
    --app-bg: #f4f7fb;
    --surface: #ffffff;
    --surface-muted: #f8fafc;
    --border: #e5e7eb;
    --text: #111827;
    --muted: #64748b;
    --primary: #2563eb;
    --primary-strong: #1d4ed8;
    --primary-soft: #dbeafe;
    --success: #16a34a;
    --success-soft: #dcfce7;
    --warning: #d97706;
    --warning-soft: #fef3c7;
    --danger: #dc2626;
    --danger-soft: #fee2e2;
    --market-europe: #2563eb;
    --market-europe-soft: #dbeafe;
    --market-cis: #16a34a;
    --market-cis-soft: #dcfce7;
    --market-uk: #d97706;
    --market-uk-soft: #fef3c7;
    --market-other: #7c3aed;
    --market-other-soft: #ede9fe;
    --sidebar: #0f172a;
    --sidebar-soft: #1e293b;
    --shadow: 0 18px 55px rgba(15, 23, 42, 0.08);
    --shadow-sm: 0 10px 30px rgba(15, 23, 42, 0.06);
    --card-radius: 1.35rem;
    --card-padding-x: 1.25rem;
    --card-padding-y: 1rem;
}

* {
    box-sizing: border-box;
}

html,
body {
    width: 100%;
    min-height: 100%;
}

body {
    margin: 0;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, 0.10), transparent 28rem),
        linear-gradient(180deg, #f8fbff 0%, var(--app-bg) 45%, #eef3f9 100%);
    color: var(--text);
    overflow-x: clip;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

img,
svg,
video,
canvas {
    max-width: 100%;
}

a {
    text-decoration: none;
}

.app-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 1040;
    display: flex;
    width: 18rem;
    min-height: 100vh;
    flex-direction: column;
    padding: 1.25rem;
    color: #fff;
    background:
        radial-gradient(circle at top left, rgba(96, 165, 250, 0.22), transparent 18rem),
        linear-gradient(180deg, var(--sidebar), #111827);
    box-shadow: 1.5rem 0 4rem rgba(15, 23, 42, 0.16);
}

.sidebar-brand {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-height: 3rem;
    margin-bottom: 1.5rem;
}

.brand-mark {
    box-sizing: border-box;
    display: inline-grid;
    place-items: center;
    width: var(--hotelcode-logo-size);
    height: var(--hotelcode-logo-size);
    padding: var(--hotelcode-logo-padding);
    border-radius: var(--hotelcode-logo-radius);
    font-weight: 800;
    letter-spacing: -0.04em;
    color: #fff;
    background: linear-gradient(135deg, #60a5fa, #2563eb);
    box-shadow: 0 1rem 2rem rgba(37, 99, 235, 0.35);
}

.brand-mark-image {
    box-sizing: border-box;
    display: block;
    width: var(--hotelcode-logo-size);
    height: var(--hotelcode-logo-size);
    padding: var(--hotelcode-logo-padding);
    border-radius: var(--hotelcode-logo-radius);
    object-fit: contain;
    background: transparent;
    box-shadow: none;
    flex: 0 0 auto;
}

.brand-title,
.mobile-title {
    display: block;
    min-width: 0;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.brand-subtitle {
    display: block;
    color: #93a4b8;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
}

.sidebar-nav {
    display: grid;
    flex: 1 1 auto;
    gap: 0.35rem;
    min-height: 0;
    overflow-y: auto;
    padding-right: 0.15rem;
}

.sidebar-section-label {
    margin: 0.75rem 0.85rem 0.35rem;
    color: #94a3b8;
    font-size: 0.72rem;
    font-weight: 850;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.sidebar-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.8rem 0.9rem;
    color: #cbd5e1;
    border-radius: 0.95rem;
    font-weight: 650;
    transition: background-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.sidebar-link i {
    width: 1.25rem;
    font-size: 1.05rem;
}

.sidebar-link:hover,
.sidebar-link.active {
    color: #fff;
    background: rgba(255, 255, 255, 0.10);
    transform: translateX(0.15rem);
}

.sidebar-link.active {
    box-shadow: inset 0.2rem 0 0 #60a5fa;
}

.sidebar-group {
    display: grid;
    gap: 0.25rem;
}

.sidebar-subnav {
    display: grid;
    gap: 0.2rem;
    margin-left: 1.45rem;
    padding-left: 0.75rem;
    border-left: 1px solid rgba(148, 163, 184, 0.28);
}

.sidebar-sub-link {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.58rem 0.75rem;
    color: #94a3b8;
    border-radius: 0.8rem;
    font-size: 0.93rem;
    font-weight: 650;
    transition: background-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.sidebar-sub-link i {
    width: 1rem;
    font-size: 0.95rem;
}

.sidebar-sub-link:hover,
.sidebar-sub-link.active {
    color: #fff;
    background: rgba(255, 255, 255, 0.09);
    transform: translateX(0.12rem);
}

.sidebar-sub-link.active {
    box-shadow: inset 0.18rem 0 0 #60a5fa;
}

.sidebar-admin-group {
    display: grid;
    gap: 0.25rem;
}

.sidebar-admin-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.68rem 0.8rem;
    color: #cbd5e1;
    border-radius: 0.9rem;
    cursor: pointer;
    font-weight: 750;
    list-style: none;
    transition: background-color 0.18s ease, color 0.18s ease;
}

.sidebar-admin-summary::-webkit-details-marker {
    display: none;
}

.sidebar-admin-summary > span {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
}

.sidebar-admin-summary i:first-child {
    width: 1.25rem;
    font-size: 1.05rem;
}

.sidebar-admin-chevron {
    flex: 0 0 auto;
    font-size: 0.85rem;
    transition: transform 0.18s ease;
}

.sidebar-admin-group[open] .sidebar-admin-chevron {
    transform: rotate(180deg);
}

.sidebar-admin-group.active > .sidebar-admin-summary,
.sidebar-admin-summary:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.10);
}

.sidebar-admin-subnav {
    display: grid;
    gap: 0.15rem;
    margin-left: 1.45rem;
    padding-left: 0.75rem;
    border-left: 1px solid rgba(148, 163, 184, 0.28);
}

.mobile-nav .sidebar-admin-summary {
    color: #334155;
}

.mobile-nav .sidebar-admin-group.active > .sidebar-admin-summary,
.mobile-nav .sidebar-admin-summary:hover {
    color: #0f172a;
    background: rgba(37, 99, 235, 0.08);
}

.sidebar-footer {
    display: grid;
    gap: 0.85rem;
    margin-top: auto;
}

.user-chip {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    min-width: 0;
    padding: 0.75rem 0.85rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 1rem;
    color: #e2e8f0;
    background: rgba(255, 255, 255, 0.07);
}

.user-chip.light {
    color: var(--text);
    border-color: var(--border);
    background: var(--surface-muted);
}

.mobile-topbar {
    position: sticky;
    top: 0;
    z-index: 1030;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
    padding: calc(0.68rem + env(safe-area-inset-top)) 0.9rem 0.68rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.82)),
        rgba(255, 255, 255, 0.86);
    border-bottom: 1px solid rgba(226, 232, 240, 0.9);
    box-shadow: 0 0.8rem 1.9rem rgba(15, 23, 42, 0.035);
    backdrop-filter: blur(18px) saturate(140%);
    transition: box-shadow 180ms ease, border-color 180ms ease, background-color 180ms ease;
}

.icon-btn {
    display: inline-grid;
    place-items: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 0.9rem;
}

.mobile-topbar .mobile-title {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}


.mobile-topbar.is-scrolled {
    border-bottom-color: rgba(203, 213, 225, 0.98);
    box-shadow: 0 1rem 2.35rem rgba(15, 23, 42, 0.09);
}

.mobile-title-stack {
    display: grid;
    flex: 1 1 auto;
    min-width: 0;
    gap: 0.05rem;
}

.mobile-subtitle {
    display: block;
    min-width: 0;
    overflow: hidden;
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
}

.mobile-role-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2rem;
    padding: 0 0.68rem;
    border: 1px solid rgba(37, 99, 235, 0.16);
    border-radius: 999px;
    background: rgba(219, 234, 254, 0.82);
    color: #1d4ed8;
    font-size: 0.74rem;
    font-weight: 900;
}

.mobile-menu-button {
    border: 1px solid rgba(226, 232, 240, 0.92);
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 0.65rem 1.4rem rgba(15, 23, 42, 0.075);
    transition: transform 160ms ease, box-shadow 160ms ease, background-color 160ms ease;
}

.mobile-menu-button:active {
    transform: scale(0.94);
}

.mobile-menu-button i {
    font-size: 1.35rem;
    transition: transform 200ms cubic-bezier(0.2, 0.75, 0.2, 1);
}

body.is-mobile-nav-open .mobile-menu-button {
    background: var(--primary-soft);
    color: var(--primary-strong);
    box-shadow: 0 0.45rem 1.1rem rgba(37, 99, 235, 0.14);
}

body.is-mobile-nav-open .mobile-menu-button i {
    transform: rotate(90deg) scale(0.95);
}

.mobile-nav-sheet {
    --bs-offcanvas-width: min(91vw, 23.5rem);
    overflow: hidden;
    border: 0;
    border-radius: 0 1.65rem 1.65rem 0;
    background:
        radial-gradient(circle at 0% 0%, rgba(37, 99, 235, 0.10), transparent 16rem),
        rgba(255, 255, 255, 0.97);
    box-shadow: 1.35rem 0 3rem rgba(15, 23, 42, 0.22);
    backdrop-filter: blur(22px) saturate(135%);
    transition: transform 320ms cubic-bezier(0.2, 0.78, 0.22, 1);
}

.mobile-nav-grabber {
    position: absolute;
    top: calc(0.58rem + env(safe-area-inset-top));
    left: 50%;
    z-index: 2;
    width: 2.75rem;
    height: 0.28rem;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.55);
    transform: translateX(-50%);
}

.mobile-nav .offcanvas-header {
    position: sticky;
    top: 0;
    z-index: 1;
    align-items: flex-start;
    padding: calc(1.25rem + env(safe-area-inset-top)) 1rem 0.9rem;
    background: rgba(255, 255, 255, 0.90);
    border-bottom: 1px solid rgba(226, 232, 240, 0.82);
    backdrop-filter: blur(16px);
}

.mobile-nav-title {
    min-width: 0;
}

.mobile-nav-close {
    width: 2.4rem;
    height: 2.4rem;
    margin: -0.1rem -0.15rem 0 0;
    border-radius: 999px;
    background-color: rgba(241, 245, 249, 0.95);
    opacity: 1;
}

.mobile-nav .offcanvas-body {
    display: grid;
    align-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1rem calc(1rem + env(safe-area-inset-bottom));
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
}

.mobile-nav .sidebar-nav {
    gap: 0.42rem;
}

.mobile-nav .sidebar-link,
.mobile-nav .sidebar-sub-link {
    min-height: 2.9rem;
    border: 1px solid transparent;
    border-radius: 1rem;
    transition: transform 150ms ease, background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease, color 160ms ease;
}

.mobile-nav .sidebar-link:active,
.mobile-nav .sidebar-sub-link:active,
.mobile-nav .sidebar-link.is-tapping,
.mobile-nav .sidebar-sub-link.is-tapping {
    transform: scale(0.985);
}

.mobile-nav .sidebar-link.active,
.mobile-nav .sidebar-sub-link.active {
    border-color: rgba(37, 99, 235, 0.14);
    box-shadow: 0 0.65rem 1.35rem rgba(37, 99, 235, 0.10);
}

.mobile-nav .sidebar-section-label {
    margin-top: 1rem;
    padding-left: 0.18rem;
}

.offcanvas-backdrop.show {
    opacity: 0.36;
    backdrop-filter: blur(7px);
}

@media (prefers-reduced-motion: reduce) {
    .mobile-topbar,
    .mobile-menu-button,
    .mobile-menu-button i,
    .mobile-nav-sheet,
    .mobile-nav .sidebar-link,
    .mobile-nav .sidebar-sub-link,
    .mobile-admin-tabbar,
    .mobile-admin-tabbar-link,
    .mobile-card-primary-chip,
    .mobile-details-toggle,
    .mobile-details-toggle::after {
        transition: none !important;
    }
}

.mobile-nav .sidebar-link {
    color: var(--text);
}

.mobile-nav .sidebar-link:hover,
.mobile-nav .sidebar-link.active {
    color: var(--primary);
    background: var(--primary-soft);
    transform: none;
}

.mobile-nav .sidebar-subnav {
    border-left-color: var(--border);
}

.mobile-nav .sidebar-sub-link {
    color: var(--muted);
}

.mobile-nav .sidebar-sub-link:hover,
.mobile-nav .sidebar-sub-link.active {
    color: var(--primary);
    background: var(--primary-soft);
    transform: none;
}

.mobile-nav .sidebar-link:active,
.mobile-nav .sidebar-sub-link:active,
.mobile-nav .sidebar-link.is-tapping,
.mobile-nav .sidebar-sub-link.is-tapping {
    transform: scale(0.985);
}


.mobile-admin-tabbar {
    position: fixed;
    right: max(0.72rem, env(safe-area-inset-right));
    bottom: calc(0.62rem + env(safe-area-inset-bottom));
    left: max(0.72rem, env(safe-area-inset-left));
    z-index: 1035;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.22rem;
    padding: 0.42rem;
    border: 1px solid rgba(203, 213, 225, 0.82);
    border-radius: 1.35rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.93), rgba(248, 250, 252, 0.91)),
        rgba(255, 255, 255, 0.88);
    box-shadow: 0 1rem 2.5rem rgba(15, 23, 42, 0.18);
    backdrop-filter: blur(20px) saturate(150%);
}

.mobile-admin-tabbar-link {
    display: grid;
    grid-template-rows: 1.15rem auto;
    place-items: center;
    gap: 0.18rem;
    min-width: 0;
    min-height: 3.35rem;
    padding: 0.42rem 0.18rem;
    border: 1px solid transparent;
    border-radius: 1rem;
    color: #64748b;
    background: transparent;
    font-size: 0.68rem;
    font-weight: 900;
    line-height: 1;
    text-align: center;
    text-decoration: none;
    transition: transform 145ms ease, background-color 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
}

.mobile-admin-tabbar-link i {
    font-size: 1.08rem;
    line-height: 1;
}

.mobile-admin-tabbar-link span {
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mobile-admin-tabbar-button {
    appearance: none;
    border: 1px solid transparent;
    cursor: pointer;
}

.mobile-admin-tabbar-link:hover,
.mobile-admin-tabbar-link.active,
.mobile-admin-tabbar-link[aria-expanded="true"] {
    color: var(--primary-strong);
    background: rgba(219, 234, 254, 0.86);
    border-color: rgba(37, 99, 235, 0.14);
    box-shadow: 0 0.6rem 1.2rem rgba(37, 99, 235, 0.11);
}

.mobile-admin-tabbar-link:active,
.mobile-admin-tabbar-link.is-tapping {
    transform: scale(0.965);
}

body.is-mobile-nav-open .mobile-admin-tabbar {
    transform: translateY(0.25rem);
}

@media (max-width: 991.98px) {
    .app-main.has-mobile-admin-tabs .app-content {
        padding-bottom: calc(6.4rem + env(safe-area-inset-bottom));
    }

    .app-main.has-mobile-admin-tabs ~ .whatsapp-widget {
        bottom: calc(5.95rem + env(safe-area-inset-bottom));
    }
}


.app-main.with-sidebar {
    min-height: 100vh;
    padding-left: 18rem;
}

.app-main.auth-main {
    display: grid;
    place-items: center;
    min-height: 100vh;
    padding: 1rem;
}

.app-content {
    width: 100%;
    max-width: 1480px;
    padding: 1.5rem;
    margin: 0 auto;
}

.auth-main {
    background:
        radial-gradient(circle at 20% 20%, rgba(37, 99, 235, 0.18), transparent 26rem),
        radial-gradient(circle at 80% 0%, rgba(14, 165, 233, 0.14), transparent 22rem),
        linear-gradient(135deg, #f8fbff, #edf4ff 52%, #f7f9fc);
}

.auth-main .app-content {
    width: min(100%, 1180px);
    max-width: 1180px;
    padding: 1rem;
}

.auth-card {
    width: 100%;
    max-width: 34rem;
    margin-inline: auto;
}

.auth-card.analytics-card {
    border-radius: 1.6rem;
    box-shadow: 0 2rem 5rem rgba(15, 23, 42, 0.13);
}

.auth-hero {
    text-align: center;
}

.auth-hero h1 {
    margin-bottom: 0.35rem;
    font-size: clamp(1.9rem, 8vw, 2.55rem);
    font-weight: 900;
    letter-spacing: -0.06em;
}

.auth-hero p {
    max-width: 22rem;
    margin: 0 auto;
    color: var(--muted);
}

.otp-input {
    letter-spacing: 0.35rem;
}

.page-shell {
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    padding: 1.5rem;
}

.page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    min-width: 0;
    margin-bottom: 1.25rem;
}

.page-kicker,
.page-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-bottom: 0.35rem;
    color: var(--primary);
    font-size: 0.78rem;
    font-weight: 850;
    letter-spacing: 0.11em;
    text-transform: uppercase;
}

.page-title {
    margin: 0;
    font-size: clamp(1.75rem, 4vw, 2.45rem);
    font-weight: 900;
    letter-spacing: -0.045em;
}

.page-subtitle {
    margin: 0.3rem 0 0;
    color: var(--muted);
}

.analytics-card,
.tc-card {
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: var(--card-radius);
    background: rgba(255, 255, 255, 0.94);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.analytics-card-header,
.tc-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-width: 0;
    padding: var(--card-padding-y) var(--card-padding-x);
    border-bottom: 1px solid var(--border);
    font-weight: 800;
}

.analytics-card-header-with-info {
    align-items: center;
}

.analytics-card-title,
.analytics-card-actions {
    display: flex;
    align-items: center;
    min-width: 0;
}

.analytics-card-title {
    gap: 0.55rem;
    flex: 1 1 auto;
}

.analytics-card-title i {
    flex: 0 0 auto;
}

.analytics-card-actions {
    gap: 0.5rem;
    justify-content: flex-end;
    margin-left: auto;
    flex: 0 0 auto;
}

.tc-card-title {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
    margin: 0;
    font-size: 1.05rem;
    font-weight: 900;
}

.card-body,
.analytics-card-body,
.tc-card-body {
    padding: var(--card-padding-y) var(--card-padding-x);
}

.analytics-card > .card-body,
.analytics-card > .analytics-card-body,
.analytics-card > .tc-card-body,
.tc-card > .card-body,
.tc-card > .analytics-card-body,
.tc-card > .tc-card-body {
    padding: var(--card-padding-y) var(--card-padding-x);
}

.tc-stack > * + * {
    margin-top: 1rem;
}

.tc-form-label,
.form-label {
    display: inline-block;
    margin-bottom: 0.5rem;
    font-weight: 650;
    color: var(--text);
}

.helper-text,
.tc-helper-text {
    display: block;
    margin-top: 0.5rem;
    color: var(--muted);
    font-size: 0.88rem;
    line-height: 1.55;
}

.tc-inline-note {
    margin: 0.5rem 0 0;
    color: var(--muted);
    font-size: 0.9rem;
}

.tc-section-copy {
    margin: 0;
    color: var(--muted);
    line-height: 1.6;
}

.form-control,
.form-select {
    border-radius: 0.9rem;
    border-color: #dbe3ee;
}

.btn {
    border-radius: 0.9rem;
    font-weight: 750;
}

.btn-sm {
    border-radius: 0.7rem;
}

.toast-panel {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.85rem 1rem;
    border: 1px solid var(--border);
    border-radius: 1rem;
    background: #fff;
    box-shadow: 0 0.5rem 1.25rem rgba(15, 23, 42, 0.04);
}

.toast-panel-danger {
    color: #991b1b;
    border-color: rgba(239, 68, 68, 0.28);
    background: #fff5f5;
}



.pwa-install-toast {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1085;
    display: flex;
    align-items: center;
    gap: 0.7rem;
    max-width: min(24rem, calc(100vw - 2rem));
    padding: 0.9rem 1rem;
    color: #166534;
    font-weight: 750;
    background: #fff;
    border: 1px solid var(--success-soft);
    border-radius: 1rem;
    box-shadow: 0 1rem 2.5rem rgba(15, 23, 42, 0.16);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-0.75rem);
    transition: opacity 0.22s ease, transform 0.22s ease;
}

.pwa-install-toast.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.pwa-install-toast i {
    font-size: 1.15rem;
}

html[dir="rtl"] .pwa-install-toast {
    right: auto;
    left: 1rem;
}

.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.32rem 0.58rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 800;
    white-space: nowrap;
}

.status-neutral {
    color: #334155;
    background: #f1f5f9;
}

.status-success {
    color: #166534;
    background: var(--success-soft);
}

.status-warning {
    color: #92400e;
    background: var(--warning-soft);
}

.status-danger {
    color: #991b1b;
    background: var(--danger-soft);
}

.market-badge {
    min-width: 4.75rem;
    justify-content: center;
}

.market-badge-turkey {
    color: var(--market-other);
    background: var(--market-other-soft);
}

.market-badge-europe {
    color: var(--market-europe);
    background: var(--market-europe-soft);
}

.market-badge-cis {
    color: var(--market-cis);
    background: var(--market-cis-soft);
}

.market-badge-uk {
    color: var(--market-uk);
    background: var(--market-uk-soft);
}

.market-badge-other {
    color: var(--market-other);
    background: var(--market-other-soft);
}

.market-badge-all {
    color: #334155;
    background: #f1f5f9;
}

.market-select {
    position: relative;
}

.market-select-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 2.375rem;
    gap: 0.75rem;
    padding: 0.375rem 0.75rem;
    color: var(--text);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 0.5rem;
}

.market-select-toggle:focus {
    border-color: var(--primary);
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(37, 99, 235, 0.16);
}

.market-select-toggle i {
    color: var(--muted);
    font-size: 0.85rem;
}

.market-select-menu {
    position: absolute;
    top: calc(100% + 0.35rem);
    right: 0;
    left: 0;
    z-index: 30;
    display: none;
    gap: 0.2rem;
    padding: 0.35rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 0.85rem;
    box-shadow: var(--shadow-sm);
}

.market-select.open .market-select-menu {
    display: grid;
}

.market-select-option {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 0.35rem;
    text-align: left;
    background: transparent;
    border: 0;
    border-radius: 0.7rem;
}

.market-select-option:hover,
.market-select-option:focus,
.market-select-option.active {
    background: var(--surface-muted);
    outline: 0;
}

.market-select .market-badge {
    min-width: 5.75rem;
}

.app-table {
    margin: 0;
}

.app-table thead th {
    color: var(--muted);
    font-size: 0.75rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: var(--surface-muted);
    border-bottom: 1px solid var(--border);
}

.sortable-header {
    display: inline-flex;
    align-items: center;
    justify-content: inherit;
    gap: 0.35rem;
    color: inherit;
    white-space: nowrap;
}

.sortable-header:hover,
.sortable-header.active {
    color: var(--primary);
}

.sortable-header i {
    font-size: 0.85rem;
}

.app-table tbody td {
    vertical-align: middle;
    border-color: #edf2f7;
}

.empty-state {
    display: grid;
    place-items: center;
    min-height: 12rem;
    padding: 2rem;
    color: var(--muted);
    text-align: center;
}

.empty-state i {
    display: block;
    margin-bottom: 0.5rem;
    font-size: 2rem;
    color: #94a3b8;
}

.empty-state strong {
    display: block;
    color: var(--text);
}

.metric-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.metric-tile {
    min-width: 0;
    padding: 0.95rem;
    border: 1px solid var(--border);
    border-radius: 1rem;
    background: rgba(248, 250, 252, 0.92);
}

.metric-label {
    margin-bottom: 0.25rem;
    color: var(--muted);
    font-size: 0.76rem;
    font-weight: 850;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.metric-value {
    color: var(--text);
    font-size: 1.22rem;
    font-weight: 900;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.data-coverage-card {
    background:
        radial-gradient(circle at top right, rgba(22, 163, 74, 0.12), transparent 20rem),
        rgba(255, 255, 255, 0.94);
}

.coverage-summary {
    display: flex;
    align-items: center;
    gap: 1rem;
    min-width: 0;
}

.coverage-icon {
    display: grid;
    flex: 0 0 auto;
    place-items: center;
    width: 3.35rem;
    height: 3.35rem;
    border-radius: 1.1rem;
    color: #166534;
    background: var(--success-soft);
    font-size: 1.65rem;
}

.coverage-label {
    color: var(--muted);
    font-size: 0.8rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.coverage-value {
    margin-top: 0.1rem;
    color: var(--text);
    font-size: clamp(2rem, 4vw, 3.35rem);
    font-weight: 950;
    line-height: 1;
    letter-spacing: -0.045em;
}

.coverage-note {
    margin-top: 0.35rem;
    color: var(--muted);
    line-height: 1.55;
}

.coverage-metrics {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.comparable-insight-card {
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, 0.12), transparent 20rem),
        rgba(255, 255, 255, 0.94);
}

.comparable-scope {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    min-width: 0;
    padding: 0.72rem 0.85rem;
    color: #475569;
    background: rgba(248, 250, 252, 0.9);
    border: 1px solid var(--border);
    border-radius: 0.95rem;
    font-size: 0.88rem;
    line-height: 1.45;
}

.comparable-scope i {
    flex: 0 0 auto;
    color: var(--primary);
    margin-top: 0.1rem;
}

.comparable-scope span {
    min-width: 0;
    overflow-wrap: anywhere;
}

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

.comparable-warning {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    min-width: 0;
    padding: 0.72rem 0.85rem;
    color: #92400e;
    background: rgba(254, 243, 199, 0.82);
    border: 1px solid rgba(245, 158, 11, 0.35);
    border-radius: 0.95rem;
    font-size: 0.88rem;
    line-height: 1.45;
}

.comparable-warning i {
    flex: 0 0 auto;
    margin-top: 0.1rem;
}

.comparable-warning span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.volatility-value {
    font-size: clamp(1.65rem, 3.2vw, 2.65rem);
    letter-spacing: -0.04em;
}

.market-volatility-list {
    display: grid;
    gap: 0.85rem;
}

.market-volatility-item {
    padding: 0.85rem;
    border: 1px solid var(--border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.82);
    box-shadow: var(--shadow-sm);
}

.market-volatility-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    min-width: 0;
}

.market-volatility-heading > div {
    min-width: 0;
}

.market-volatility-title-row {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-width: 0;
}

.market-volatility-warning-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.35rem;
    height: 1.35rem;
    border-radius: 999px;
    color: #991b1b;
    background: rgba(254, 226, 226, 0.95);
    border: 1px solid rgba(220, 38, 38, 0.28);
    font-size: 0.74rem;
    line-height: 1;
    box-shadow: 0 8px 18px rgba(220, 38, 38, 0.12);
}

.market-volatility-note {
    margin-top: 0.65rem;
}

.market-volatility-actions {
    display: flex;
    justify-content: flex-start;
    margin-top: 0.7rem;
}

.market-volatility-review-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    width: fit-content;
    max-width: 100%;
    padding: 0.34rem 0.62rem;
    border: 1px solid rgba(220, 38, 38, 0.24);
    border-radius: 999px;
    color: #991b1b;
    background: rgba(254, 226, 226, 0.78);
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1.1;
    text-decoration: none;
    transition: background-color 0.14s ease, border-color 0.14s ease, box-shadow 0.14s ease, transform 0.14s ease;
}

.market-volatility-review-link:hover,
.market-volatility-review-link:focus-visible {
    color: #7f1d1d;
    background: rgba(254, 202, 202, 0.95);
    border-color: rgba(220, 38, 38, 0.42);
    box-shadow: 0 10px 20px rgba(220, 38, 38, 0.14);
    transform: translateY(-1px);
}

.market-volatility-review-link:focus-visible {
    outline: 3px solid rgba(220, 38, 38, 0.18);
    outline-offset: 2px;
}


.market-volatility-item.volatility-level-stable {
    border-color: rgba(22, 163, 74, 0.28);
    background:
        linear-gradient(135deg, rgba(22, 163, 74, 0.1), rgba(255, 255, 255, 0.88) 56%),
        rgba(255, 255, 255, 0.9);
}

.market-volatility-item.volatility-level-moderate {
    border-color: rgba(245, 158, 11, 0.34);
    background:
        linear-gradient(135deg, rgba(245, 158, 11, 0.12), rgba(255, 255, 255, 0.88) 56%),
        rgba(255, 255, 255, 0.9);
}

.market-volatility-item.volatility-level-high {
    border-color: rgba(220, 38, 38, 0.32);
    background:
        linear-gradient(135deg, rgba(220, 38, 38, 0.11), rgba(255, 255, 255, 0.88) 56%),
        rgba(255, 255, 255, 0.9);
}

.market-volatility-item.volatility-level-needs-data,
.market-volatility-item.volatility-level-neutral {
    border-color: rgba(100, 116, 139, 0.26);
    background:
        linear-gradient(135deg, rgba(100, 116, 139, 0.1), rgba(255, 255, 255, 0.88) 56%),
        rgba(255, 255, 255, 0.9);
}

.volatility-level-badge,
.volatility-level-pill {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    max-width: 100%;
    border-radius: 999px;
    border: 1px solid transparent;
    font-weight: 900;
}

.volatility-level-badge {
    margin-top: 0.2rem;
    padding: 0.28rem 0.6rem;
    font-size: 0.94rem;
    line-height: 1.1;
}

.volatility-level-pill {
    padding: 0.34rem 0.62rem;
    font-size: 0.78rem;
    line-height: 1.1;
}

.volatility-level-badge.volatility-level-stable,
.volatility-level-pill.volatility-level-stable {
    color: #166534;
    background: rgba(220, 252, 231, 0.92);
    border-color: rgba(22, 163, 74, 0.24);
}

.volatility-level-badge.volatility-level-moderate,
.volatility-level-pill.volatility-level-moderate {
    color: #92400e;
    background: rgba(254, 243, 199, 0.92);
    border-color: rgba(245, 158, 11, 0.3);
}

.volatility-level-badge.volatility-level-high,
.volatility-level-pill.volatility-level-high {
    color: #991b1b;
    background: rgba(254, 226, 226, 0.92);
    border-color: rgba(220, 38, 38, 0.26);
}

.volatility-level-badge.volatility-level-needs-data,
.volatility-level-pill.volatility-level-needs-data,
.volatility-level-badge.volatility-level-neutral,
.volatility-level-pill.volatility-level-neutral {
    color: #475569;
    background: rgba(241, 245, 249, 0.94);
    border-color: rgba(100, 116, 139, 0.22);
}

@media (max-width: 767.98px) {
    .market-volatility-heading {
        flex-direction: column;
        gap: 0.45rem;
    }

    .market-volatility-item {
        padding: 0.75rem;
    }

    .market-volatility-review-link {
        width: 100%;
        justify-content: center;
        white-space: normal;
        text-align: center;
    }
}

.kpi-card {
    min-height: 8rem;
    padding: 1.1rem;
    border: 1px solid var(--border);
    border-radius: 1.25rem;
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.tc-guide-body {
    padding: var(--card-padding-y) var(--card-padding-x);
}

.tc-guide-section + .tc-guide-section {
    margin-top: 1.5rem;
}

.tc-guide-section-title {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
    font-weight: 800;
}

.tc-guide-section p {
    margin: 0 0 0.75rem;
    color: var(--muted);
}

.tc-guide-section ul {
    margin: 0;
    padding-left: 1.25rem;
}

.tc-guide-section li + li {
    margin-top: 0.4rem;
}

.landing-shell {
    width: 100%;
    display: grid;
    gap: 1.25rem;
}

.landing-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(20rem, 0.75fr);
    gap: 2rem;
    padding: clamp(1.5rem, 4vw, 3rem);
    position: relative;
    overflow: hidden;
}

.landing-hero::before {
    content: "";
    position: absolute;
    inset: -12rem auto auto 45%;
    width: 34rem;
    height: 34rem;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(37, 99, 235, 0.16), transparent 68%);
    pointer-events: none;
}

.landing-hero-content,
.landing-demo-panel {
    position: relative;
    z-index: 1;
}

.landing-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-bottom: 0.7rem;
    color: var(--primary);
    font-size: 0.78rem;
    font-weight: 850;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.landing-hero h1,
.landing-section h2,
.landing-auth-copy h2 {
    margin: 0;
    color: var(--text);
    font-weight: 950;
    letter-spacing: -0.055em;
}

.landing-hero h1 {
    max-width: 48rem;
    font-size: clamp(2.3rem, 5vw, 4.75rem);
    line-height: 0.95;
}

.landing-lead {
    max-width: 43rem;
    margin: 1.25rem 0 0;
    color: var(--muted);
    font-size: clamp(1rem, 1.8vw, 1.25rem);
    line-height: 1.75;
}

.landing-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 1.6rem;
}

.pwa-install-button[hidden] {
    display: none !important;
}

.landing-trust-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
    margin-top: 2rem;
}

.landing-trust-grid > div {
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: 1.15rem;
    background: rgba(255, 255, 255, 0.72);
}

.landing-trust-grid strong {
    display: block;
    margin-bottom: 0.25rem;
    font-weight: 900;
}

.landing-trust-grid span {
    display: block;
    color: var(--muted);
    font-size: 0.9rem;
    line-height: 1.45;
}

.landing-demo-panel {
    display: flex;
    align-items: center;
    justify-content: center;
}

.demo-window {
    width: min(100%, 24rem);
    padding: 1rem;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 1.5rem;
    background: rgba(15, 23, 42, 0.94);
    box-shadow: 0 2rem 4rem rgba(15, 23, 42, 0.22);
}

.demo-window-top {
    display: flex;
    gap: 0.35rem;
    margin-bottom: 1rem;
}

.demo-window-top span {
    width: 0.65rem;
    height: 0.65rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.3);
}

.demo-card {
    padding: 1rem;
    border-radius: 1.2rem;
    color: #fff;
    background:
        radial-gradient(circle at top right, rgba(96, 165, 250, 0.45), transparent 11rem),
        linear-gradient(135deg, #2563eb, #1d4ed8);
}

.demo-label,
.demo-note {
    color: rgba(255, 255, 255, 0.82);
    font-size: 0.86rem;
}

.demo-price {
    margin: 0.35rem 0;
    font-size: 2.35rem;
    font-weight: 950;
    letter-spacing: -0.05em;
}

.demo-bars {
    display: grid;
    gap: 0.8rem;
    margin-top: 1rem;
}

.demo-bars div {
    position: relative;
    min-height: 2.6rem;
    padding: 0.7rem 0.85rem;
    border-radius: 0.95rem;
    overflow: hidden;
    color: #dbeafe;
    background: rgba(255, 255, 255, 0.08);
}

.demo-bars div::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: var(--w);
    background: linear-gradient(90deg, rgba(96, 165, 250, 0.42), rgba(37, 99, 235, 0.15));
}

.demo-bars span {
    position: relative;
    z-index: 1;
    font-weight: 800;
}

.landing-section {
    padding: clamp(1.25rem, 3vw, 2rem);
    border: 1px solid rgba(226, 232, 240, 0.8);
    border-radius: 1.5rem;
    background: rgba(255, 255, 255, 0.55);
}

.landing-section-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.75fr);
    gap: 1.5rem;
    align-items: end;
    margin-bottom: 1.25rem;
}

.landing-section h2,
.landing-auth-copy h2 {
    font-size: clamp(1.8rem, 3vw, 2.75rem);
    line-height: 1.05;
}

.landing-section-header p,
.landing-auth-copy p,
.landing-policy p {
    margin: 0;
    color: var(--muted);
    line-height: 1.7;
}

.landing-feature-grid,
.pricing-grid {
    display: grid;
    gap: 1rem;
}

.landing-feature-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

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

.landing-feature-card,
.pricing-card {
    border: 1px solid var(--border);
    border-radius: 1.25rem;
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.landing-feature-card {
    padding: 1.15rem;
}

.landing-feature-card i {
    display: inline-grid;
    place-items: center;
    width: 2.75rem;
    height: 2.75rem;
    margin-bottom: 0.9rem;
    border-radius: 0.95rem;
    color: var(--primary);
    background: var(--primary-soft);
    font-size: 1.2rem;
}

.landing-feature-card h3,
.pricing-name {
    margin: 0 0 0.5rem;
    font-size: 1.05rem;
    font-weight: 900;
}

.landing-feature-card p {
    margin: 0;
    color: var(--muted);
    line-height: 1.6;
}

.pricing-card {
    position: relative;
    padding: 1.25rem;
}

.pricing-card.featured {
    border-color: rgba(37, 99, 235, 0.38);
    box-shadow: 0 1.5rem 4rem rgba(37, 99, 235, 0.12);
}

.pricing-pill {
    display: inline-flex;
    margin-bottom: 0.75rem;
    padding: 0.35rem 0.65rem;
    border-radius: 999px;
    color: #1d4ed8;
    background: #dbeafe;
    font-size: 0.78rem;
    font-weight: 900;
}

.pricing-price {
    font-size: 2.2rem;
    font-weight: 950;
    letter-spacing: -0.05em;
}

.pricing-code {
    margin: 0.35rem 0 0.25rem;
    color: var(--text);
    font-size: clamp(1.05rem, 2vw, 1.35rem);
    font-weight: 950;
    letter-spacing: -0.02em;
    overflow-wrap: anywhere;
}

.pricing-note {
    margin-bottom: 1rem;
    color: var(--muted);
}

.pricing-card ul {
    display: grid;
    gap: 0.55rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.pricing-card li {
    display: flex;
    gap: 0.5rem;
    color: #334155;
    line-height: 1.45;
}

.pricing-card li::before {
    content: "✓";
    color: var(--success);
    font-weight: 950;
}

.landing-policy {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.75fr);
    gap: 1.5rem;
    padding: clamp(1.25rem, 3vw, 2rem);
}

.policy-list {
    display: grid;
    gap: 0.75rem;
}

.policy-list div {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.9rem 1rem;
    border: 1px solid var(--border);
    border-radius: 1rem;
    background: var(--surface-muted);
    font-weight: 800;
}

.policy-list i {
    color: var(--primary);
}

.landing-auth-section {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(24rem, 28rem);
    gap: 1.25rem;
    align-items: center;
    padding: clamp(1.25rem, 3vw, 2rem);
    border-radius: 1.5rem;
    background:
        radial-gradient(circle at top left, rgba(37, 99, 235, 0.10), transparent 22rem),
        rgba(255, 255, 255, 0.58);
    border: 1px solid rgba(226, 232, 240, 0.8);
}

.landing-auth-card {
    max-width: none;
    margin: 0;
}

@media (max-width: 1199.98px) {
    .metric-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    :root {
        --card-padding-x: 1rem;
        --card-padding-y: 1rem;
    }

    .app-main.with-sidebar {
        padding-left: 0;
    }

    .app-content {
        padding: 1rem;
    }

    .page-shell {
        padding: 1rem;
    }

    .page-header {
        flex-direction: column;
    }

    .quick-actions {
        grid-template-columns: 1fr;
    }

    .landing-hero,
    .landing-section-header,
    .landing-policy,
    .landing-auth-section {
        grid-template-columns: 1fr;
    }

    .landing-trust-grid,
    .landing-feature-grid,
    .pricing-grid {
        grid-template-columns: 1fr;
    }

    .landing-actions .btn {
        width: 100%;
    }

    .demo-window {
        width: 100%;
    }
}

.mobile-card-primary-chip {
    display: none;
}

@media (max-width: 767.98px) {
    .metric-strip,
    .coverage-metrics {
        grid-template-columns: 1fr;
    }

    .coverage-summary {
        align-items: flex-start;
    }

    .coverage-icon {
        width: 2.85rem;
        height: 2.85rem;
        border-radius: 0.95rem;
        font-size: 1.35rem;
    }

    .comparable-scope {
        padding: 0.65rem 0.75rem;
        font-size: 0.82rem;
    }

    .kpi-card {
        min-height: 7.25rem;
    }

    .table {
        font-size: 0.9rem;
    }

    .mobile-card-table {
        width: 100%;
        min-width: 0;
        table-layout: auto;
        border-collapse: separate;
        border-spacing: 0;
    }

    .mobile-card-table thead {
        display: none;
    }

    .mobile-card-table,
    .mobile-card-table tbody,
    .mobile-card-table tr,
    .mobile-card-table td {
        display: block;
        width: 100%;
        min-width: 0;
        max-width: 100%;
    }

    .mobile-card-table tr {
        margin: 0.75rem 0;
        padding: 0.95rem;
        overflow: hidden;
        border: 1px solid rgba(226, 232, 240, 0.95);
        border-radius: 1.1rem;
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
        box-shadow: 0 0.65rem 1.45rem rgba(15, 23, 42, 0.055);
    }

    .mobile-card-table tr:first-child {
        margin-top: 0;
    }

    .mobile-card-table tr:last-child {
        margin-bottom: 0;
    }

    .mobile-card-table td {
        display: grid;
        grid-template-columns: minmax(6.85rem, 38%) minmax(0, 1fr);
        align-items: flex-start;
        gap: 0.72rem;
        min-width: 0;
        padding: 0.62rem 0;
        border: 0;
        border-bottom: 1px solid rgba(226, 232, 240, 0.9);
        color: var(--text);
        text-align: right;
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .mobile-card-table td:last-child {
        border-bottom: 0;
        padding-bottom: 0;
    }

    .mobile-card-table td:first-child {
        padding-top: 0;
    }

    .mobile-card-table td::before {
        content: attr(data-label);
        min-width: 0;
        color: var(--muted);
        font-size: 0.72rem;
        font-weight: 900;
        line-height: 1.25;
        letter-spacing: 0.025em;
        text-align: left;
        text-transform: uppercase;
        overflow-wrap: anywhere;
    }

    .mobile-card-table td > * {
        min-width: 0;
        max-width: 100%;
        justify-self: end;
    }

    .mobile-card-table td.text-end,
    .mobile-card-table td .text-end {
        text-align: right !important;
    }

    .mobile-card-table td[data-label="Actions"] > *,
    .mobile-card-table td[data-label="Action"] > * {
        justify-self: stretch;
        width: 100%;
    }

    .mobile-card-table td[data-label="Actions"] .d-flex,
    .mobile-card-table td[data-label="Action"] .d-flex,
    .mobile-card-table td[data-label="Actions"] .btn-group,
    .mobile-card-table td[data-label="Action"] .btn-group {
        justify-content: flex-end;
    }

    .mobile-card-table .d-flex,
    .mobile-card-table .btn-group,
    .mobile-card-table .input-group,
    .mobile-card-table form {
        min-width: 0;
        max-width: 100%;
        flex-wrap: wrap;
    }

    .mobile-card-table .btn {
        max-width: 100%;
        white-space: normal;
    }

    .mobile-card-table td[data-label="Actions"] .btn,
    .mobile-card-table td[data-label="Action"] .btn {
        flex: 1 1 auto;
    }

    .mobile-card-table .form-control,
    .mobile-card-table .form-select,
    .mobile-card-table textarea,
    .mobile-card-table select,
    .mobile-card-table input:not([type="checkbox"]):not([type="radio"]) {
        width: 100%;
        min-width: 0;
    }

    .mobile-card-table pre,
    .mobile-card-table code,
    .mobile-card-table .text-nowrap {
        white-space: normal !important;
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .mobile-card-table td[colspan] {
        display: block;
        text-align: center;
    }

    .mobile-card-table td[colspan]::before {
        display: none;
    }

    .hotel-picker-results {
        top: 4.25rem;
        left: 0.75rem;
        right: 0.75rem;
    }

    .selected-hotel {
        align-items: flex-start !important;
    }

    .selected-hotel span {
        overflow-wrap: anywhere;
    }

    .tall-select {
        min-height: 12rem;
    }
}

@media (max-width: 575.98px) {
    :root {
        --card-padding-x: 0.9rem;
        --card-padding-y: 0.9rem;
    }

    .auth-main .app-content {
        padding: 0.75rem;
    }

    .auth-card .card-body {
        padding: 1.25rem !important;
    }

    .landing-hero,
    .landing-section,
    .landing-policy,
    .landing-auth-section {
        border-radius: 1.1rem;
        padding: 1rem;
    }

    .landing-hero h1 {
        font-size: 2.25rem;
    }
}

@media (min-width: 576px) {
    .w-sm-auto {
        width: auto !important;
    }
}

@media (min-width: 768px) {
    .w-md-auto {
        width: auto !important;
    }
}


/* Visual and usability refinements */
.tall-select {
    min-height: 16rem;
    overflow-y: auto;
}

.tall-select option {
    padding-block: 0.28rem;
}

.app-table th,
.app-table td {
    white-space: normal;
}

.app-table td[data-label="User"],
.app-table td[data-label="E-mail"] {
    min-width: 13rem;
    word-break: keep-all;
    overflow-wrap: normal;
}

.app-table td[data-label="Message"] {
    min-width: 32rem;
    overflow-wrap: anywhere;
}

.app-table td[data-label="Hotel"] {
    min-width: 12rem;
}

.log-table th:nth-child(2),
.log-table td:nth-child(2) {
    min-width: 13rem;
}

.log-table th:nth-child(8),
.log-table td:nth-child(8) {
    min-width: 34rem;
}

.visual-dashboard {
    display: grid;
    gap: 1rem;
    width: min(100%, 31rem);
    padding: 1rem;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 1.6rem;
    background:
        radial-gradient(circle at top right, rgba(96, 165, 250, 0.18), transparent 18rem),
        rgba(255, 255, 255, 0.94);
    box-shadow: 0 2rem 4.5rem rgba(15, 23, 42, 0.16);
}

.visual-dashboard-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.visual-dashboard-title {
    font-weight: 950;
    letter-spacing: -0.04em;
}

.visual-dashboard-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
}

.visual-metric {
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: 1.1rem;
    background: #fff;
}

.visual-metric span {
    display: block;
    color: var(--muted);
    font-size: 0.82rem;
}

.visual-metric strong {
    display: block;
    margin-top: 0.25rem;
    font-size: 1.4rem;
    font-weight: 950;
    letter-spacing: -0.04em;
}

.visual-bars {
    display: grid;
    gap: 0.75rem;
}

.visual-bar {
    display: grid;
    grid-template-columns: 6rem 1fr auto;
    align-items: center;
    gap: 0.75rem;
    color: #334155;
    font-weight: 750;
}

.visual-bar-track {
    height: 0.7rem;
    overflow: hidden;
    border-radius: 999px;
    background: #e5e7eb;
}

.visual-bar-track::before {
    content: "";
    display: block;
    width: var(--w);
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #60a5fa, #2563eb);
}

.visual-workflow {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.visual-workflow-step {
    position: relative;
    padding: 1.15rem;
    border: 1px solid var(--border);
    border-radius: 1.25rem;
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.visual-workflow-step i {
    display: inline-grid;
    place-items: center;
    width: 2.75rem;
    height: 2.75rem;
    margin-bottom: 0.85rem;
    border-radius: 0.95rem;
    color: var(--primary);
    background: var(--primary-soft);
    font-size: 1.15rem;
}

.visual-workflow-step strong {
    display: block;
    margin-bottom: 0.35rem;
    font-weight: 900;
}

.visual-workflow-step span {
    display: block;
    color: var(--muted);
    line-height: 1.5;
}

.overview-poster {
    width: 100%;
    max-width: 28rem;
    border: 1px solid var(--border);
    border-radius: 1.4rem;
    box-shadow: var(--shadow);
}

.landing-visual-pair {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.65fr);
    gap: 1.25rem;
    align-items: center;
}

.usage-explainer {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1.25rem;
}

.usage-explainer-card {
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: 1.15rem;
    background: var(--surface-muted);
}

.usage-explainer-card strong {
    display: block;
    margin-bottom: 0.35rem;
}

.usage-explainer-card span {
    color: var(--muted);
    line-height: 1.55;
}

@media (max-width: 991.98px) {
    .visual-workflow,
    .landing-visual-pair,
    .usage-explainer {
        grid-template-columns: 1fr;
    }

    .visual-dashboard {
        width: 100%;
    }
}

@media (max-width: 767.98px) {
    .tall-select {
        min-height: 14rem;
    }

    .visual-dashboard-grid {
        grid-template-columns: 1fr;
    }

    .visual-bar {
        grid-template-columns: 1fr;
        gap: 0.35rem;
    }

    .app-table td[data-label="User"],
    .app-table td[data-label="E-mail"],
    .app-table td[data-label="Message"],
    .app-table td[data-label="Hotel"] {
        min-width: 0;
        word-break: normal;
        overflow-wrap: anywhere;
    }
}

/* Full-width workspace update */
.app-content {
    width: 100%;
    max-width: none;
    padding: 1.5rem 2rem;
    margin: 0;
}

.app-main.with-sidebar .app-content {
    max-width: none;
}

.page-shell {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 1.5rem 2rem;
}

.auth-main .app-content {
    width: min(100%, 1180px);
    max-width: 1180px;
    margin: 0 auto;
    padding: 1rem;
}

.tc-card,
.analytics-card,
.table-responsive {
    width: 100%;
    max-width: 100%;
}

.table-responsive {
    overflow-x: auto;
}

.app-table {
    width: 100%;
}

/* Source Records wide table layout */
.source-records-page .source-summary-grid {
    display: grid;
    grid-template-columns: minmax(18rem, 0.85fr) minmax(34rem, 1.65fr);
    gap: 1rem;
    align-items: stretch;
    margin-bottom: 1.25rem;
}

.source-records-page .source-table-card {
    width: 100%;
}

.source-records-page .table-responsive {
    max-width: 100%;
    overflow-x: auto;
}

.source-records-page .app-table {
    min-width: 82rem;
}

.source-records-page .app-table th:first-child,
.source-records-page .app-table td:first-child {
    min-width: 17rem;
}

.source-records-page .app-table td {
    vertical-align: top;
}

.source-records-page .app-table td:not(:first-child) {
    min-width: 12rem;
    max-width: 20rem;
    overflow-wrap: anywhere;
}


.source-url-link {
    display: inline-block;
    max-width: 100%;
    color: var(--primary);
    font-weight: 750;
    overflow-wrap: anywhere;
    text-decoration: none;
}

.source-url-link:hover,
.source-url-link:focus-visible {
    color: var(--primary-strong);
    text-decoration: underline;
}

.hotel-urls-table td[data-label="Coverage"] {
    min-width: 6.75rem;
}

.hotel-url-edit-page .analytics-card {
    box-shadow: 0 1.5rem 3rem rgba(15, 23, 42, 0.07);
}

@media (max-width: 767.98px) {
    .source-records-page .hotel-urls-table {
        min-width: 0;
    }

    .source-records-page .hotel-urls-table td:not(:first-child) {
        min-width: 0;
        max-width: 100%;
    }

    .source-url-link {
        text-align: right;
    }
}

/* Better child age field layout */
.child-age-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: flex-start;
}

.child-age-grid > * {
    flex: 0 0 9rem;
    min-width: 9rem;
}

.child-age-grid label,
.child-age-grid .form-label {
    display: block;
    margin-bottom: 0.4rem;
    font-size: 0.88rem;
    font-weight: 700;
    line-height: 1.25;
    white-space: normal;
}

.child-age-grid select,
.child-age-grid .form-select {
    width: 100%;
    min-height: 2.75rem;
}

/* Easier airport selection */
.tall-select {
    min-height: 16rem;
    overflow-y: auto;
}

.tall-select option {
    padding-block: 0.28rem;
}

/* Log and wide table readability */
.app-table td[data-label="User"],
.app-table td[data-label="E-mail"] {
    min-width: 12rem;
    word-break: keep-all;
    overflow-wrap: normal;
}

.app-table td[data-label="Message"] {
    min-width: 32rem;
    overflow-wrap: anywhere;
}

.app-table td[data-label="Hotel"] {
    min-width: 12rem;
}

.log-table th:nth-child(2),
.log-table td:nth-child(2) {
    min-width: 13rem;
}

.log-table th:nth-child(8),
.log-table td:nth-child(8) {
    min-width: 34rem;
}

@media (min-width: 1600px) {
    .app-content,
    .page-shell {
        padding-left: 2.5rem;
        padding-right: 2.5rem;
    }
}

@media (max-width: 991.98px) {
    .app-content,
    .page-shell {
        padding: 1rem;
    }

    .source-records-page .source-summary-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .source-records-page .app-table {
        min-width: 0;
    }

    .app-table td[data-label="User"],
    .app-table td[data-label="E-mail"],
    .app-table td[data-label="Message"],
    .app-table td[data-label="Hotel"] {
        min-width: 0;
        word-break: normal;
        overflow-wrap: anywhere;
    }

    .tall-select {
        min-height: 14rem;
    }
}

@media (max-width: 575.98px) {
    .child-age-grid {
        display: grid;
        grid-template-columns: 1fr;
    }

    .child-age-grid > * {
        min-width: 0;
        width: 100%;
    }
}


/* Full-width HotelCode landing override */
.app-main.auth-main {
    display: block;
    min-height: 100vh;
    padding: 0;
}

.auth-main .app-content {
    width: 100%;
    max-width: none;
    padding: 1.5rem 2rem;
    margin: 0;
}

.landing-shell,
.landing-hero,
.landing-section,
.landing-auth-section,
.landing-policy {
    width: 100%;
    max-width: none;
}

/* CodeBW style product visual */
.product-visual {
    width: min(100%, 34rem);
    padding: 1rem;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 1.6rem;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, 0.16), transparent 18rem),
        linear-gradient(180deg, #ffffff, #f8fafc);
    box-shadow: 0 2rem 4.5rem rgba(15, 23, 42, 0.16);
}

.product-visual-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.35rem 0.35rem 1rem;
}

.product-visual-header strong {
    display: block;
    font-size: 1.25rem;
    font-weight: 950;
    letter-spacing: -0.04em;
}

.visual-kicker {
    display: block;
    color: var(--primary);
    font-size: 0.75rem;
    font-weight: 850;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.visual-stat-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.visual-stat-grid > div {
    padding: 0.95rem;
    border: 1px solid var(--border);
    border-radius: 1.1rem;
    background: #fff;
}

.visual-stat-grid span,
.visual-stat-grid small {
    display: block;
    color: var(--muted);
    font-size: 0.82rem;
}

.visual-stat-grid strong {
    display: block;
    margin: 0.15rem 0;
    font-size: 1.45rem;
    font-weight: 950;
    letter-spacing: -0.04em;
}

.market-bars {
    display: grid;
    gap: 0.75rem;
    margin-top: 1rem;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: 1.2rem;
    background: #fff;
}

.market-bar {
    display: grid;
    grid-template-columns: 5.5rem 1fr auto;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.92rem;
    font-weight: 800;
}

.market-bar span {
    color: #334155;
}

.market-bar div {
    height: 0.7rem;
    overflow: hidden;
    border-radius: 999px;
    background: #e5e7eb;
}

.market-bar i {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #60a5fa, #2563eb);
}

.market-bar strong {
    color: #0f172a;
}

.visual-insight {
    display: flex;
    gap: 0.85rem;
    margin-top: 1rem;
    padding: 1rem;
    border-radius: 1.15rem;
    color: #1e3a8a;
    background: #dbeafe;
}

.visual-insight i {
    font-size: 1.35rem;
}

.visual-insight strong,
.visual-insight span {
    display: block;
}

.visual-insight span {
    margin-top: 0.2rem;
    color: #475569;
    line-height: 1.45;
}

.visual-module-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.visual-module-card {
    padding: 1.2rem;
    border: 1px solid var(--border);
    border-radius: 1.25rem;
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.visual-module-card i {
    display: inline-grid;
    place-items: center;
    width: 2.75rem;
    height: 2.75rem;
    margin-bottom: 0.9rem;
    border-radius: 0.95rem;
    color: var(--primary);
    background: var(--primary-soft);
    font-size: 1.2rem;
}

.visual-module-card strong,
.visual-module-card span {
    display: block;
}

.visual-module-card strong {
    margin-bottom: 0.35rem;
    font-weight: 900;
}

.visual-module-card span {
    color: var(--muted);
    line-height: 1.55;
}

@media (min-width: 1600px) {
    .auth-main .app-content {
        padding-left: 2.5rem;
        padding-right: 2.5rem;
    }
}

@media (max-width: 991.98px) {
    .auth-main .app-content {
        padding: 1rem;
    }

    .product-visual {
        width: 100%;
    }

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

@media (max-width: 575.98px) {
    .visual-module-grid,
    .visual-stat-grid {
        grid-template-columns: 1fr;
    }

    .market-bar {
        grid-template-columns: 1fr;
        gap: 0.35rem;
    }
}


/* Brand, corporate home and premium HotelCode landing */
.brand-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
    padding: 0.9rem 1.1rem;
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 1.25rem;
    background: rgba(255, 255, 255, 0.82);
    backdrop-filter: blur(18px);
    box-shadow: 0 1rem 2.5rem rgba(15, 23, 42, 0.06);
}

.brand-lockup {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    color: inherit;
}

.brand-lockup:hover {
    color: inherit;
}


.codebw-logo-image {
    box-sizing: border-box;
    display: block;
    width: var(--hotelcode-logo-size);
    height: var(--hotelcode-logo-size);
    padding: var(--hotelcode-logo-padding);
    border-radius: var(--hotelcode-logo-radius);
    object-fit: contain;
    background: transparent;
    box-shadow: none;
    flex: 0 0 auto;
}

.codebw-logo-mark {
    box-sizing: border-box;
    display: inline-grid;
    place-items: center;
    width: var(--hotelcode-logo-size);
    height: var(--hotelcode-logo-size);
    padding: var(--hotelcode-logo-padding);
    border-radius: var(--hotelcode-logo-radius);
    color: #fff;
    background: linear-gradient(135deg, #0f172a, #2563eb);
    font-size: 0.82rem;
    font-weight: 950;
    letter-spacing: -0.04em;
    box-shadow: 0 1rem 2rem rgba(37, 99, 235, 0.25);
}

.codebw-brand {
    color: #0f172a;
    font-size: 0.78rem;
    font-weight: 950;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.hotelcode-brand {
    margin-top: 0.1rem;
    color: #2563eb;
    font-size: 1.15rem;
    font-weight: 950;
    letter-spacing: -0.04em;
}

.brand-nav {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    color: var(--muted);
    font-size: 0.92rem;
    font-weight: 750;
}

.brand-nav a {
    color: var(--muted);
}

.brand-nav a:hover {
    color: var(--primary);
}

.brand-nav-cta {
    padding: 0.55rem 0.9rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: #fff;
    color: var(--primary) !important;
    box-shadow: 0 0.5rem 1.25rem rgba(15, 23, 42, 0.04);
}

.corporate-shell .landing-hero h1,
.landing-shell .landing-hero h1 {
    max-width: 58rem;
}

.corporate-shell .landing-lead,
.landing-shell .landing-lead {
    max-width: 58rem;
}

.landing-hero {
    min-height: 34rem;
    align-items: center;
}

.landing-demo-panel {
    justify-content: flex-end;
}

.product-visual {
    width: min(100%, 38rem);
}

.visual-module-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.visual-module-card {
    padding: 1.2rem;
    border: 1px solid var(--border);
    border-radius: 1.25rem;
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.visual-module-card i {
    display: inline-grid;
    place-items: center;
    width: 2.75rem;
    height: 2.75rem;
    margin-bottom: 0.9rem;
    border-radius: 0.95rem;
    color: var(--primary);
    background: var(--primary-soft);
    font-size: 1.2rem;
}

.visual-module-card strong,
.visual-module-card span {
    display: block;
}

.visual-module-card strong {
    margin-bottom: 0.35rem;
    font-weight: 900;
}

.visual-module-card span {
    color: var(--muted);
    line-height: 1.55;
}

.visual-workflow {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

@media (max-width: 1199.98px) {
    .visual-workflow {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

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

@media (max-width: 991.98px) {
    .brand-topbar,
    .brand-nav {
        align-items: flex-start;
        flex-direction: column;
    }

    .brand-nav {
        width: 100%;
        gap: 0.75rem;
    }

    .product-visual {
        width: 100%;
    }
}

@media (max-width: 575.98px) {
    .visual-module-grid,
    .visual-stat-grid,
    .visual-workflow {
        grid-template-columns: 1fr;
    }

    .market-bar {
        grid-template-columns: 1fr;
        gap: 0.35rem;
    }
}


/* Premium corporate visual layer */
.premium-landing {
    gap: 1.5rem;
}

.premium-topbar {
    position: sticky;
    top: 1rem;
    z-index: 20;
    border-color: rgba(226, 232, 240, 0.8);
    background: rgba(255, 255, 255, 0.78);
    backdrop-filter: blur(22px);
}

.saas-hero {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(26rem, 0.95fr);
    gap: clamp(2rem, 5vw, 5rem);
    align-items: center;
    min-height: 42rem;
    padding: clamp(2rem, 5vw, 4.5rem);
    overflow: hidden;
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 2rem;
    background:
        radial-gradient(circle at 80% 12%, rgba(37, 99, 235, 0.16), transparent 24rem),
        radial-gradient(circle at 20% 80%, rgba(14, 165, 233, 0.10), transparent 22rem),
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.92));
    box-shadow: 0 2rem 5.5rem rgba(15, 23, 42, 0.08);
}

.saas-hero-bg {
    position: absolute;
    inset: auto -8rem -12rem auto;
    width: 32rem;
    height: 32rem;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(37, 99, 235, 0.18), transparent 68%);
    pointer-events: none;
}

.saas-hero-content,
.saas-hero-visual {
    position: relative;
    z-index: 1;
}

.saas-hero h1 {
    max-width: 58rem;
    margin: 0;
    color: var(--text);
    font-size: clamp(3rem, 6.2vw, 6rem);
    font-weight: 950;
    letter-spacing: -0.07em;
    line-height: 0.93;
}

.hero-proof-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1.75rem;
}

.hero-proof-grid > div {
    padding: 1rem;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 1.2rem;
    background: rgba(255, 255, 255, 0.78);
    box-shadow: 0 0.75rem 2rem rgba(15, 23, 42, 0.04);
}

.hero-proof-grid span,
.hero-proof-grid small {
    display: block;
    color: var(--muted);
    font-size: 0.84rem;
}

.hero-proof-grid strong {
    display: block;
    margin: 0.15rem 0;
    color: var(--text);
    font-size: 1.65rem;
    font-weight: 950;
    letter-spacing: -0.04em;
}

.hero-area-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.55rem;
}

.hero-area-tags span {
    display: inline-flex;
    align-items: center;
    padding: 0.34rem 0.62rem;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.08);
    border: 1px solid rgba(15, 23, 42, 0.1);
    color: var(--text);
    font-size: 0.76rem;
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.01em;
}

.dashboard-window {
    width: min(100%, 44rem);
    padding: 1rem;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 1.8rem;
    background:
        radial-gradient(circle at 90% 0%, rgba(96, 165, 250, 0.22), transparent 18rem),
        linear-gradient(180deg, #ffffff, #f8fafc);
    box-shadow: 0 2rem 5rem rgba(15, 23, 42, 0.16);
}

.dashboard-window-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.35rem 0.35rem 1rem;
}

.dashboard-window-top strong {
    display: block;
    color: var(--text);
    font-size: 1.35rem;
    font-weight: 950;
    letter-spacing: -0.04em;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.8fr 0.8fr;
    gap: 0.75rem;
}

.dash-card {
    padding: 1rem;
    min-height: 7rem;
    border: 1px solid var(--border);
    border-radius: 1.15rem;
    background: #fff;
}

.dash-card.big {
    background:
        radial-gradient(circle at 90% 10%, rgba(37, 99, 235, 0.12), transparent 9rem),
        #fff;
}

.dash-card span,
.dash-card small {
    display: block;
    color: var(--muted);
    font-size: 0.84rem;
}

.dash-card strong {
    display: block;
    margin: 0.35rem 0 0.15rem;
    color: var(--text);
    font-size: 2rem;
    font-weight: 950;
    letter-spacing: -0.06em;
}

.premium-bars {
    box-shadow: inset 0 0 0 1px rgba(226, 232, 240, 0.45);
}

.impact-section {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    padding: 0;
    border: 0;
    background: transparent;
}

.impact-card {
    padding: 1.25rem;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 1.35rem;
    background: rgba(255, 255, 255, 0.86);
    box-shadow: var(--shadow-sm);
}

.impact-card i {
    display: inline-grid;
    place-items: center;
    width: 2.75rem;
    height: 2.75rem;
    margin-bottom: 0.85rem;
    border-radius: 0.95rem;
    color: #fff;
    background: linear-gradient(135deg, #60a5fa, #2563eb);
    font-size: 1.25rem;
}

.impact-card strong,
.impact-card span {
    display: block;
}

.impact-card strong {
    margin-bottom: 0.35rem;
    color: var(--text);
    font-size: 1.05rem;
    font-weight: 950;
}

.impact-card span {
    color: var(--muted);
    line-height: 1.55;
}

.premium-section {
    position: relative;
    overflow: hidden;
}

.premium-section::before {
    content: "";
    position: absolute;
    inset: -12rem -10rem auto auto;
    width: 22rem;
    height: 22rem;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(37, 99, 235, 0.08), transparent 70%);
    pointer-events: none;
}

.premium-module {
    min-height: 13rem;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.premium-module:hover {
    transform: translateY(-0.25rem);
    border-color: rgba(37, 99, 235, 0.25);
    box-shadow: 0 1.25rem 3rem rgba(15, 23, 42, 0.09);
}

.comparison-showcase {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(24rem, 1.1fr);
    gap: 2rem;
    align-items: center;
    background:
        radial-gradient(circle at 100% 0%, rgba(37, 99, 235, 0.10), transparent 22rem),
        rgba(255, 255, 255, 0.72);
}

.showcase-copy h2 {
    margin: 0;
    max-width: 48rem;
    color: var(--text);
    font-size: clamp(2rem, 4vw, 3.4rem);
    font-weight: 950;
    letter-spacing: -0.06em;
    line-height: 1;
}

.showcase-copy p {
    margin: 1rem 0 0;
    color: var(--muted);
    font-size: 1.05rem;
    line-height: 1.7;
}

.showcase-list {
    display: grid;
    gap: 0.75rem;
    margin-top: 1.25rem;
}

.showcase-list div {
    display: flex;
    gap: 0.65rem;
    align-items: center;
    color: #334155;
    font-weight: 750;
}

.showcase-list i {
    color: var(--primary);
    font-size: 1.15rem;
}

.showcase-panel {
    padding: 1rem;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 1.5rem;
    background: #fff;
    box-shadow: var(--shadow);
}

.mini-table {
    display: grid;
    gap: 0.55rem;
}

.mini-table > div {
    display: grid;
    grid-template-columns: 1.1fr 0.8fr 0.7fr 0.6fr;
    gap: 0.75rem;
    align-items: center;
    padding: 0.85rem 0.95rem;
    border-radius: 0.95rem;
    background: #f8fafc;
}

.mini-table .mini-table-head {
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: #eef2ff;
}

.mini-table strong {
    color: var(--text);
}

.mini-table em {
    justify-self: start;
    font-style: normal;
}

.visual-workflow-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.premium-policy {
    border-radius: 1.6rem;
    background:
        radial-gradient(circle at 0% 0%, rgba(37, 99, 235, 0.10), transparent 22rem),
        rgba(255, 255, 255, 0.86);
}

.premium-signin {
    border-radius: 1.6rem;
    box-shadow: var(--shadow-sm);
}

.corporate-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.5rem 0.75rem;
    border: 1px solid rgba(37, 99, 235, 0.14);
    border-radius: 999px;
    color: var(--primary);
    background: rgba(219, 234, 254, 0.7);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

@media (max-width: 1199.98px) {
    .saas-hero,
    .comparison-showcase {
        grid-template-columns: 1fr;
    }

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

    .saas-hero h1 {
        font-size: clamp(2.6rem, 8vw, 4.5rem);
    }
}

@media (max-width: 991.98px) {
    .premium-topbar {
        position: static;
    }

    .saas-hero {
        min-height: auto;
        padding: 1.25rem;
        border-radius: 1.35rem;
    }

    .hero-proof-grid,
    .impact-section,
    .dashboard-grid,
    .visual-workflow-5 {
        grid-template-columns: 1fr;
    }

    .mini-table {
        overflow-x: auto;
    }

    .mini-table > div {
        min-width: 42rem;
    }
}


/* Info popovers for analytics explanations */
.info-popover {
    display: inline-grid;
    place-items: center;
    width: 1.85rem;
    height: 1.85rem;
    margin-left: 0.35rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--primary);
    background: #fff;
    font-size: 0.95rem;
    line-height: 1;
    vertical-align: middle;
}

.chart-info-button {
    flex: 0 0 auto;
    margin-left: 0;
    padding: 0;
    cursor: pointer;
}

.info-popover:hover,
.info-popover:focus {
    color: #fff;
    background: var(--primary);
    border-color: var(--primary);
}

.popover {
    max-width: 25rem;
    border: 1px solid var(--border);
    border-radius: 1rem;
    box-shadow: var(--shadow-sm);
}

.popover-header {
    color: var(--text);
    background: var(--surface-muted);
    border-bottom: 1px solid var(--border);
    font-weight: 850;
}

.popover-body {
    color: var(--muted);
    line-height: 1.55;
}

@media (max-width: 575.98px) {
    .analytics-card-header-with-info {
        gap: 0.75rem;
    }

    .analytics-card-actions {
        gap: 0.4rem;
    }

    .chart-info-button {
        width: 1.75rem;
        height: 1.75rem;
        font-size: 0.88rem;
    }
}


/* v6.3 layout fixes */
.premium-landing,
.corporate-shell,
.landing-shell {
    padding-left: clamp(1.25rem, 2.4vw, 3rem);
    padding-right: clamp(1.25rem, 2.4vw, 3rem);
}

.premium-landing .saas-hero {
    padding-left: clamp(2rem, 5.5vw, 6rem);
    padding-right: clamp(2rem, 5.5vw, 6rem);
}

.premium-landing .saas-hero-content {
    max-width: 58rem;
}

.child-age-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(8.5rem, 1fr));
    gap: 0.85rem;
    align-items: start;
    max-width: 32rem;
}

.child-age-field {
    min-width: 0;
}

.child-age-field label,
.child-age-field .form-label {
    display: block;
    margin-bottom: 0.45rem;
    font-size: 0.92rem;
    font-weight: 800;
    line-height: 1.25;
    color: var(--text);
    white-space: normal;
}

.child-age-field .form-select,
.child-age-field select {
    width: 100%;
    min-width: 8.5rem;
    min-height: 2.75rem;
}

.tc-stat-card {
    height: 100%;
    padding: 1.35rem;
    border: 1px solid var(--border);
    border-radius: 1.5rem;
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.tc-stat-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.tc-stat-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 850;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.tc-stat-value {
    margin-top: 0.35rem;
    font-size: 2.4rem;
    font-weight: 950;
    letter-spacing: -0.05em;
    line-height: 1;
}

.tc-stat-subtitle {
    margin-top: 0.45rem;
    color: var(--muted);
}

.tc-stat-icon {
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 1.2rem;
    color: var(--primary);
    background: var(--primary-soft);
    font-size: 1.4rem;
}

.provider-coverage-list {
    display: grid;
    gap: 0.65rem;
    margin-top: 1.4rem;
}

.provider-coverage-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.7rem 0.85rem;
    border-radius: 1rem;
    background: var(--surface-muted);
}

.provider-coverage-row span {
    color: #334155;
    font-weight: 750;
}

.provider-coverage-row strong {
    font-size: 0.95rem;
    font-weight: 900;
}

@media (max-width: 991.98px) {
    .premium-landing,
    .corporate-shell,
    .landing-shell {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .premium-landing .saas-hero {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }

    .child-age-grid {
        grid-template-columns: repeat(2, minmax(8.5rem, 1fr));
        max-width: none;
    }
}

@media (max-width: 575.98px) {
    .child-age-grid {
        grid-template-columns: 1fr;
    }

    .child-age-field .form-select,
    .child-age-field select {
        min-width: 0;
    }
}


/* Dashboard usage and subscription cards */
.usage-kpi {
    position: relative;
    overflow: hidden;
}

.usage-kpi::after {
    content: "";
    position: absolute;
    inset: auto -2rem -3rem auto;
    width: 8rem;
    height: 8rem;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(37, 99, 235, 0.14), transparent 70%);
    pointer-events: none;
}

.usage-kpi .kpi-value {
    color: var(--primary);
}



/* Final corporate product highlight alignment fix */
.site-product-highlight {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(28rem, 1.05fr);
    gap: 2rem;
    align-items: center;
    margin-top: 1.5rem;
    padding: clamp(2rem, 4vw, 3.5rem);
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 1.75rem;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, 0.10), transparent 28rem),
        rgba(255, 255, 255, 0.82);
    box-shadow: var(--shadow-sm);
}

.site-product-copy h2 {
    max-width: 48rem;
    margin: 0;
    color: var(--text);
    font-size: clamp(2.4rem, 4vw, 4.25rem);
    font-weight: 950;
    line-height: 1;
    letter-spacing: -0.055em;
}

.site-product-copy p {
    max-width: 44rem;
    margin: 1.1rem 0 0;
    color: var(--muted);
    font-size: 1.05rem;
    line-height: 1.75;
}

.product-benefit-list {
    display: grid;
    gap: 0.85rem;
    margin: 1.5rem 0 1.75rem;
    padding: 0;
    list-style: none;
}

.product-benefit-list li {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    color: #0f172a;
    font-weight: 850;
}

.product-benefit-list li::before {
    content: "✓";
    display: inline-grid;
    place-items: center;
    width: 1.45rem;
    height: 1.45rem;
    border-radius: 999px;
    color: var(--primary);
    background: var(--primary-soft);
    font-size: 0.9rem;
    font-weight: 950;
}

.site-product-table-card {
    padding: 1rem;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 1.35rem;
    background: #fff;
    box-shadow: 0 1.5rem 4rem rgba(15, 23, 42, 0.08);
}

.log-table th:nth-child(10),
.log-table td:nth-child(10) {
    min-width: 28rem;
}

.log-table th:nth-child(11),
.log-table td:nth-child(11),
.log-table th:nth-child(12),
.log-table td:nth-child(12) {
    min-width: 18rem;
}

.log-url-cell a {
    display: inline-flex;
    margin-bottom: 0.35rem;
    font-weight: 850;
}

.log-url-preview {
    max-width: 28rem;
    color: var(--muted);
    font-size: 0.8rem;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

@media (max-width: 1199.98px) {
    .site-product-highlight {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    .site-product-highlight {
        padding: 1rem;
        border-radius: 1.1rem;
    }

    .site-product-copy h2 {
        font-size: 2.2rem;
    }
}


/* Admin product plans */
.product-plan-row-inactive {
    opacity: 0.64;
    background: #f8fafc;
}

.product-plan-row-inactive td {
    color: #64748b;
}

.product-plan-row-inactive input,
.product-plan-row-inactive select,
.product-plan-row-inactive textarea {
    background-color: #f1f5f9;
    color: #64748b;
}

.product-plan-status {
    width: fit-content;
    font-size: 0.65rem;
}

.payment-plan-card {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    height: 100%;
    padding: 1rem;
    border: 1px solid rgba(148, 163, 184, .35);
    border-radius: 1rem;
    background: #fff;
    cursor: pointer;
    transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}

.payment-plan-card:hover,
.payment-plan-card:has(input:checked) {
    border-color: rgba(37, 99, 235, .75);
    box-shadow: 0 14px 30px rgba(15, 23, 42, .08);
    transform: translateY(-1px);
}

.payment-plan-card input {
    width: 1rem;
    height: 1rem;
}

.payment-plan-name {
    font-weight: 700;
    color: #0f172a;
}

.payment-plan-price {
    font-size: 1.35rem;
    font-weight: 800;
    color: #2563eb;
}

.payment-plan-note {
    font-size: .85rem;
    color: #64748b;
    line-height: 1.35;
}

.payment-bank-details {
    display: grid;
    gap: .75rem;
    margin-bottom: 1.25rem;
}

.payment-bank-details dt {
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #64748b;
}

.payment-bank-details dd {
    margin-bottom: 0;
    color: #0f172a;
}

.admin-payment-action-form {
    min-width: 14rem;
}

/* File: wwwroot/css/site.css */

.whatsapp-widget {
    position: fixed;
    right: 1.25rem;
    bottom: 1.25rem;
    z-index: 1080;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.75rem;
    width: auto;
    max-width: 20rem;
    pointer-events: none;
}

.whatsapp-backdrop,
.whatsapp-menu-header {
    display: none;
}

.whatsapp-fab {
    pointer-events: auto;
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.85rem 1rem;
    color: #fff;
    background: #25d366;
    border: 0;
    border-radius: 999px;
    box-shadow: 0 1rem 2.2rem rgba(15, 23, 42, 0.22);
    font-weight: 800;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease;
}

    .whatsapp-fab:hover,
    .whatsapp-fab:focus-visible {
        color: #fff;
        background: #1ebe5d;
        transform: translateY(-0.15rem);
        box-shadow: 0 1.25rem 2.6rem rgba(15, 23, 42, 0.28);
    }

    .whatsapp-fab i {
        font-size: 1.25rem;
    }

.whatsapp-menu {
    display: grid;
    gap: 0.65rem;
    width: min(20rem, calc(100vw - 2rem));
    margin-bottom: 0;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(0.5rem) scale(0.98);
    transform-origin: bottom right;
    transition: opacity 0.13s ease, transform 0.13s ease, visibility 0.13s ease;
}

.whatsapp-widget.open .whatsapp-menu,
.whatsapp-widget.is-open .whatsapp-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0) scale(1);
}

.whatsapp-option {
    pointer-events: auto;
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
    width: min(20rem, calc(100vw - 2rem));
    padding: 0.85rem 0.95rem;
    color: #0f172a;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(148, 163, 184, 0.35);
    border-radius: 1rem;
    box-shadow: 0 0.75rem 2rem rgba(15, 23, 42, 0.14);
    text-decoration: none;
    transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

    .whatsapp-option:hover,
    .whatsapp-option:focus-visible {
        color: #0f172a;
        border-color: rgba(37, 211, 102, 0.7);
        transform: translateY(-0.1rem);
    }

    .whatsapp-option i {
        display: inline-grid;
        place-items: center;
        width: 2.35rem;
        height: 2.35rem;
        color: #fff;
        background: #25d366;
        border-radius: 999px;
        flex: 0 0 auto;
    }

    .whatsapp-option span {
        display: flex;
        flex-direction: column;
        line-height: 1.25;
    }

    .whatsapp-option strong,
    .whatsapp-option small {
        display: block;
    }

    .whatsapp-option small {
        color: #64748b;
    }

@media (max-width: 575.98px) {
    body.whatsapp-sheet-open {
        overflow: hidden;
    }

    .whatsapp-widget {
        right: max(0.9rem, env(safe-area-inset-right));
        bottom: calc(1rem + env(safe-area-inset-bottom));
        max-width: calc(100vw - 1.5rem);
    }

    .whatsapp-backdrop {
        position: fixed;
        inset: 0;
        z-index: 1078;
        display: block;
        background: rgba(15, 23, 42, 0.38);
        backdrop-filter: blur(0.75px);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition: opacity 0.12s ease, visibility 0.12s ease;
    }

    .whatsapp-widget.open .whatsapp-backdrop,
    .whatsapp-widget.is-open .whatsapp-backdrop {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .whatsapp-fab {
        position: fixed;
        right: max(0.9rem, env(safe-area-inset-right));
        bottom: calc(1rem + env(safe-area-inset-bottom));
        z-index: 1081;
        display: inline-grid;
        place-items: center;
        width: 3.35rem;
        height: 3.35rem;
        min-width: 3.35rem;
        min-height: 3.35rem;
        padding: 0;
        border: 2px solid rgba(255, 255, 255, 0.75);
        border-radius: 999px;
        background: linear-gradient(135deg, #25d366 0%, #16a34a 100%);
        box-shadow: 0 0.8rem 1.8rem rgba(22, 163, 74, 0.35);
    }

    .whatsapp-widget.open .whatsapp-fab,
    .whatsapp-widget.is-open .whatsapp-fab {
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
    }

    .whatsapp-fab span {
        display: none;
    }

    .whatsapp-fab i {
        font-size: 1.45rem;
        line-height: 1;
    }

    .whatsapp-menu {
        position: fixed;
        right: 0;
        bottom: 0;
        left: 0;
        z-index: 1082;
        display: grid;
        width: 100%;
        max-height: calc(100dvh - 4.5rem);
        margin: 0;
        padding: 1rem 1rem calc(1rem + env(safe-area-inset-bottom));
        overflow-y: auto;
        background: rgba(255, 255, 255, 0.98);
        border: 1px solid rgba(148, 163, 184, 0.22);
        border-bottom: 0;
        border-radius: 1.5rem 1.5rem 0 0;
        box-shadow: 0 -1rem 3rem rgba(15, 23, 42, 0.24);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transform: translateY(110%);
        transform-origin: bottom center;
        transition: transform 0.17s cubic-bezier(0.2, 0.85, 0.22, 1), opacity 0.12s ease, visibility 0.12s ease;
        touch-action: pan-y;
        will-change: transform, opacity;
    }

    .whatsapp-widget.open .whatsapp-menu,
    .whatsapp-widget.is-open .whatsapp-menu {
        opacity: var(--whatsapp-sheet-drag-opacity, 1);
        visibility: visible;
        pointer-events: auto;
        transform: translateY(var(--whatsapp-sheet-drag-y, 0)) scale(var(--whatsapp-sheet-drag-scale, 1));
    }

    .whatsapp-menu.is-swiping {
        transition: none;
    }

    .whatsapp-menu-header {
        position: relative;
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 1rem;
        padding-top: 0.85rem;
        padding-bottom: 0.35rem;
    }

    .whatsapp-menu-header::before {
        content: "";
        position: absolute;
        top: 0.15rem;
        left: 50%;
        width: 2.75rem;
        height: 0.28rem;
        border-radius: 999px;
        background: rgba(100, 116, 139, 0.35);
        transform: translateX(-50%);
    }

    .whatsapp-menu-header strong,
    .whatsapp-menu-header small {
        display: block;
    }

    .whatsapp-menu-header strong {
        color: #0f172a;
        font-size: 1rem;
        font-weight: 800;
    }

    .whatsapp-menu-header small {
        color: #64748b;
        font-size: 0.82rem;
    }

    .whatsapp-menu-close {
        display: inline-grid;
        place-items: center;
        width: 2.35rem;
        height: 2.35rem;
        color: #0f172a;
        background: rgba(15, 23, 42, 0.06);
        border: 1px solid rgba(148, 163, 184, 0.25);
        border-radius: 999px;
    }

    .whatsapp-option {
        width: 100%;
        box-shadow: none;
    }
}

.hotel-list-information-subtitle {
    display: block;
    margin-bottom: 0.35rem;
    color: var(--text);
    font-size: 0.84rem;
    font-weight: 800;
}

.tc-form-label-with-info {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    margin-bottom: 0.35rem;
}

.tc-form-label-with-info .tc-form-label {
    margin-bottom: 0;
}

.hotel-information-trigger-row {
    display: inline-flex;
    align-items: center;
}

.hotel-information-trigger {
    display: inline-grid;
    place-items: center;
    width: 1.65rem;
    height: 1.65rem;
    padding: 0;
    border: 1px solid rgba(99, 102, 241, 0.22);
    border-radius: 999px;
    color: var(--primary);
    background: linear-gradient(135deg, #eef2ff, #f8fafc);
    font-size: 0.9rem;
    line-height: 1;
}

.hotel-information-trigger:hover,
.hotel-information-trigger:focus {
    color: #ffffff;
    background: var(--primary);
    border-color: var(--primary);
}

.hotel-information-modal .modal-content {
    border: 1px solid rgba(99, 102, 241, 0.18);
    border-radius: 1.4rem;
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    box-shadow: 0 1.4rem 3rem rgba(15, 23, 42, 0.16);
}

.hotel-information-modal .modal-header {
    padding: 1.15rem 1.2rem 0.9rem;
    border-bottom: 1px solid rgba(148, 163, 184, 0.18);
}

.hotel-information-modal .modal-header small {
    color: var(--muted);
}

.hotel-information-modal .modal-body {
    padding: 1.1rem 1.2rem 1.2rem;
}

.hotel-information-modal .modal-body p {
    margin: 0 0 0.85rem;
    color: var(--muted);
    font-size: 0.92rem;
    line-height: 1.6;
}

.hotel-information-modal-icon {
    display: inline-grid;
    place-items: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    color: var(--primary);
    background: var(--primary-soft);
    font-size: 1rem;
}

.hotel-information-section {
    margin: 1rem 0 0.85rem;
    padding: 0.95rem 1rem;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.72);
}

.hotel-information-selected-preview {
    margin: 0.9rem 0 1rem;
    padding: 0.85rem 0.95rem;
    border: 1px dashed rgba(37, 99, 235, 0.28);
    border-radius: 1rem;
    background: rgba(219, 234, 254, 0.38);
}

.hotel-information-selected-preview strong {
    display: block;
    margin-bottom: 0.35rem;
    color: var(--text);
    font-size: 0.88rem;
}

.hotel-information-selected-preview p {
    margin-bottom: 0;
}

.hotel-information-selected-preview ul {
    display: grid;
    gap: 0.35rem;
    margin: 0;
    padding-left: 1.1rem;
    color: var(--muted);
    font-size: 0.9rem;
}

.hotel-duplicate-merge-link {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    font-size: 0.88rem;
    font-weight: 800;
    color: #047857;
}

.hotel-duplicate-merge-link:hover {
    color: #065f46;
}

.duplicate-merge-message {
    max-width: 26rem;
    white-space: pre-wrap;
}



.premium-decision-modal .modal-content {
    border-radius: 1.5rem;
    background: linear-gradient(180deg, #ffffff, #f8fafc);
}

.premium-decision-icon {
    width: 3.25rem;
    height: 3.25rem;
    border-radius: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(13, 110, 253, 0.10);
    color: #0d6efd;
    font-size: 1.6rem;
}

.premium-decision-modal[data-tone="success"] .premium-decision-icon {
    background: rgba(25, 135, 84, 0.12);
    color: #198754;
}

.premium-decision-modal[data-tone="danger"] .premium-decision-icon {
    background: rgba(220, 53, 69, 0.12);
    color: #dc3545;
}

.premium-decision-modal[data-tone="warning"] .premium-decision-icon {
    background: rgba(255, 193, 7, 0.18);
    color: #996404;
}

.premium-decision-modal .modal-body .lead {
    color: #1f2937;
    font-size: 1rem;
    line-height: 1.6;
}

.premium-decision-modal .modal-body .alert {
    border-radius: 1rem;
    color: #475569;
}

.premium-decision-modal .modal-footer {
    gap: 0.6rem;
}

.premium-decision-modal .modal-footer .btn {
    min-width: 7rem;
    border-radius: 999px;
    font-weight: 800;
    padding: 0.65rem 1.1rem;
}


.pricing-offer-banner {
    border: 1px solid rgba(37, 99, 235, 0.18);
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.08), rgba(15, 23, 42, 0.03));
    color: #1e293b;
    font-weight: 800;
    letter-spacing: -0.01em;
    padding: 14px 18px;
    margin-bottom: 18px;
}

.pricing-list-price,
.payment-plan-list-price {
    color: #94a3b8;
    font-weight: 700;
    text-decoration: line-through;
}

.pricing-discount,
.payment-plan-save {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    border-radius: 999px;
    background: #dcfce7;
    color: #166534;
    font-size: 0.78rem;
    font-weight: 900;
    padding: 5px 10px;
    margin-top: 6px;
}


/* HotelCode landing dashboard overview */
.hotelcode-overview-section {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 0.88fr) minmax(31rem, 1.12fr);
    gap: clamp(2rem, 4vw, 4.5rem);
    align-items: center;
    margin-top: 1.5rem;
    padding: clamp(2rem, 5vw, 4.5rem);
    overflow: hidden;
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 2rem;
    background:
        radial-gradient(circle at 10% 16%, rgba(37, 99, 235, 0.14), transparent 22rem),
        radial-gradient(circle at 86% 78%, rgba(16, 185, 129, 0.14), transparent 26rem),
        linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(248, 250, 252, 0.82));
    box-shadow: var(--shadow-sm);
}

.hotelcode-overview-section::before {
    content: "";
    position: absolute;
    inset: auto -6rem -8rem auto;
    width: 18rem;
    height: 18rem;
    border-radius: 999px;
    background: rgba(76, 224, 166, 0.12);
    filter: blur(1px);
}

.hotelcode-overview-copy {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.hotelcode-overview-copy h2 {
    max-width: 50rem;
    margin: 0;
    color: var(--text);
    font-size: clamp(2.25rem, 4vw, 4.4rem);
    font-weight: 950;
    line-height: 0.98;
    letter-spacing: -0.06em;
}

.hotelcode-overview-copy p {
    max-width: 45rem;
    margin: 1.1rem 0 0;
    color: var(--muted);
    font-size: 1.08rem;
    line-height: 1.75;
}

.overview-proof-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin: 1.6rem 0 1.8rem;
}

.overview-proof-list span {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    min-height: 3.2rem;
    padding: 0.78rem 0.9rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 1rem;
    color: #0f172a;
    background: rgba(255, 255, 255, 0.78);
    font-size: 0.92rem;
    font-weight: 850;
    line-height: 1.35;
    box-shadow: 0 0.8rem 1.8rem rgba(15, 23, 42, 0.04);
}

.overview-proof-list i {
    flex: 0 0 auto;
    color: #10b981;
    font-size: 1.1rem;
    line-height: 1.2;
}

.overview-action-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.9rem 1rem;
}

.overview-action-row span {
    max-width: 25rem;
    color: var(--muted);
    font-size: 0.92rem;
    font-weight: 750;
    line-height: 1.45;
}

.overview-dashboard-mockup {
    position: relative;
    z-index: 1;
}

.overview-dashboard-shell {
    position: relative;
    display: grid;
    gap: 1rem;
    padding: clamp(1rem, 2.4vw, 1.45rem);
    overflow: hidden;
    border: 1px solid rgba(76, 224, 166, 0.2);
    border-radius: 1.8rem;
    background:
        radial-gradient(circle at 14% 0%, rgba(76, 224, 166, 0.2), transparent 18rem),
        radial-gradient(circle at 90% 30%, rgba(37, 99, 235, 0.16), transparent 20rem),
        linear-gradient(145deg, #020617, #0f172a);
    box-shadow: 0 2rem 4rem rgba(15, 23, 42, 0.24);
}

.overview-dashboard-shell::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(148, 163, 184, 0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(148, 163, 184, 0.06) 1px, transparent 1px);
    background-size: 36px 36px;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.55), transparent 75%);
}

.overview-dashboard-header,
.overview-dashboard-kpis,
.overview-dashboard-table,
.overview-dashboard-insights,
.overview-dashboard-flow {
    position: relative;
    z-index: 1;
}

.overview-dashboard-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.2rem 0.2rem 0.4rem;
}

.overview-dashboard-header strong {
    display: block;
    margin-top: 0.25rem;
    color: #f8fafc;
    font-size: clamp(1.15rem, 2vw, 1.65rem);
    font-weight: 950;
    letter-spacing: -0.04em;
}

.overview-dashboard-kpis {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
}

.overview-dashboard-kpis article,
.overview-dashboard-table,
.overview-dashboard-insights article,
.overview-dashboard-flow div {
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(15, 23, 42, 0.76);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 1rem 2rem rgba(0, 0, 0, 0.14);
    backdrop-filter: blur(18px);
}

.overview-dashboard-kpis article {
    display: grid;
    gap: 0.35rem;
    min-height: 8rem;
    padding: 0.9rem;
    border-radius: 1.15rem;
}

.overview-dashboard-kpis span,
.overview-dashboard-kpis small {
    color: rgba(226, 232, 240, 0.72);
    font-size: 0.73rem;
    font-weight: 800;
    line-height: 1.35;
}

.overview-dashboard-kpis span {
    color: #9cf3d5;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.overview-dashboard-kpis strong {
    color: #ffffff;
    font-size: clamp(1.25rem, 2vw, 1.75rem);
    font-weight: 950;
    line-height: 1;
    letter-spacing: -0.04em;
}

.overview-dashboard-table {
    display: grid;
    gap: 0.35rem;
    padding: 0.95rem;
    border-radius: 1.25rem;
}

.overview-dashboard-table-title {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 0 0 0.5rem;
}

.overview-dashboard-table-title strong {
    color: #f8fafc;
    font-size: 0.98rem;
    font-weight: 950;
}

.overview-dashboard-table-title span {
    color: rgba(226, 232, 240, 0.68);
    font-size: 0.78rem;
    font-weight: 800;
    text-align: right;
}

.overview-dashboard-row {
    display: grid;
    grid-template-columns: minmax(7rem, 1.4fr) repeat(3, minmax(4rem, 0.72fr)) minmax(6rem, 1fr);
    gap: 0.55rem;
    align-items: center;
    min-width: 0;
    padding: 0.58rem 0.65rem;
    border-radius: 0.9rem;
    color: rgba(248, 250, 252, 0.82);
    background: rgba(255, 255, 255, 0.04);
    font-size: 0.82rem;
}

.overview-dashboard-row-head {
    color: rgba(156, 243, 213, 0.9);
    background: rgba(76, 224, 166, 0.08);
    font-size: 0.72rem;
    font-weight: 950;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.overview-dashboard-row span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.overview-dashboard-row strong {
    color: #ffffff;
    font-weight: 900;
}

.overview-dashboard-row em {
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    padding: 0.25rem 0.5rem;
    overflow: hidden;
    border-radius: 999px;
    color: #03100b;
    background: #9cf3d5;
    font-size: 0.72rem;
    font-style: normal;
    font-weight: 950;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.overview-dashboard-insights {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.overview-dashboard-insights article {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.2rem 0.65rem;
    padding: 0.85rem;
    border-radius: 1.1rem;
}

.overview-dashboard-insights i {
    grid-row: span 2;
    display: inline-grid;
    place-items: center;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    color: #03100b;
    background: #9cf3d5;
    font-size: 0.95rem;
}

.overview-dashboard-insights strong {
    color: #ffffff;
    font-size: 0.86rem;
    font-weight: 950;
}

.overview-dashboard-insights span {
    color: rgba(226, 232, 240, 0.7);
    font-size: 0.78rem;
    font-weight: 750;
    line-height: 1.42;
}

.overview-dashboard-flow {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.overview-dashboard-flow div {
    display: grid;
    gap: 0.35rem;
    padding: 0.9rem;
    border-radius: 1.1rem;
}

.overview-dashboard-flow span {
    display: inline-grid;
    place-items: center;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    color: #03100b;
    background: #9cf3d5;
    font-size: 0.76rem;
    font-weight: 950;
}

.overview-dashboard-flow strong {
    color: #ffffff;
    font-size: 0.9rem;
    font-weight: 950;
}

.overview-dashboard-flow p {
    margin: 0;
    color: rgba(226, 232, 240, 0.68);
    font-size: 0.78rem;
    line-height: 1.45;
}

@media (max-width: 1199.98px) {
    .hotelcode-overview-section {
        grid-template-columns: 1fr;
    }

    .overview-dashboard-shell {
        max-width: 58rem;
        margin: 0 auto;
    }
}

@media (max-width: 767.98px) {
    .overview-proof-list,
    .overview-dashboard-kpis,
    .overview-dashboard-insights,
    .overview-dashboard-flow {
        grid-template-columns: 1fr;
    }

    .overview-dashboard-row {
        grid-template-columns: minmax(8rem, 1fr) repeat(2, minmax(4rem, 0.7fr));
    }

    .overview-dashboard-row > :nth-child(4),
    .overview-dashboard-row > :nth-child(5) {
        display: none;
    }

    .overview-dashboard-table-title {
        display: grid;
    }

    .overview-dashboard-table-title span {
        text-align: left;
    }
}

@media (max-width: 575.98px) {
    .hotelcode-overview-section {
        padding: 1.15rem;
        border-radius: 1.5rem;
    }

    .hotelcode-overview-copy h2 {
        font-size: clamp(2rem, 12vw, 3rem);
    }

    .overview-dashboard-shell {
        padding: 0.8rem;
        border-radius: 1.35rem;
    }

    .overview-dashboard-row {
        gap: 0.35rem;
        padding: 0.52rem;
        font-size: 0.76rem;
    }
}



/* Operational log compact details */
.log-compact-scroll {
    overflow-x: visible;
}

.log-compact-table {
    table-layout: fixed;
    width: 100%;
}

.log-compact-table th,
.log-compact-table td {
    vertical-align: top;
}

.log-compact-table th:nth-child(1),
.log-compact-table td:nth-child(1) {
    width: 8.5rem;
}

.log-compact-table th:nth-child(2),
.log-compact-table td:nth-child(2) {
    width: 15rem;
}

.log-compact-table th:nth-child(3),
.log-compact-table td:nth-child(3) {
    width: 13rem;
}

.log-compact-table th:nth-child(4),
.log-compact-table td:nth-child(4) {
    width: 14rem;
}

.log-compact-table th:nth-child(5),
.log-compact-table td:nth-child(5) {
    width: 14rem;
}

.log-compact-table th:nth-child(6),
.log-compact-table td:nth-child(6) {
    width: 8rem;
}

.log-compact-table th:nth-child(8),
.log-compact-table td:nth-child(8) {
    width: 7rem;
}

.log-main-text {
    font-weight: 700;
    color: #0f172a;
}

.log-muted {
    margin-top: 0.15rem;
    color: #64748b;
    font-size: 0.78rem;
    line-height: 1.3;
}

.log-message-summary {
    color: #334155;
    font-size: 0.9rem;
    line-height: 1.45;
}

.log-details-row > td {
    border-top: 0;
    background: #f8fafc;
}

.log-details-panel {
    margin: 0.25rem 0.75rem 1rem;
    padding: 1rem;
    border: 1px solid rgba(203, 213, 225, 0.8);
    border-radius: 1rem;
    background: #ffffff;
    box-shadow: 0 0.75rem 1.5rem rgba(15, 23, 42, 0.06);
}

.log-details-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem 1rem;
}

.log-detail-label {
    display: block;
    margin-bottom: 0.25rem;
    color: #64748b;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.log-detail-block {
    margin-top: 1rem;
}

.log-detail-value,
.log-detail-link {
    display: block;
    max-width: 100%;
    color: #0f172a;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.log-detail-link {
    color: #2563eb;
    text-decoration: none;
}

.log-detail-link:hover {
    text-decoration: underline;
}

@media (max-width: 991.98px) {
    .log-compact-table {
        table-layout: auto;
    }

    .log-details-grid {
        grid-template-columns: 1fr;
    }

    .log-compact-table th,
    .log-compact-table td {
        width: auto !important;
    }
}


/* Demo and upgrade CTA visibility */
.brand-nav-primary {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    box-shadow: 0 12px 24px rgba(37, 99, 235, .16);
}

.auth-trial-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem;
    border: 1px solid rgba(37, 99, 235, .18);
    border-radius: 1rem;
    background: linear-gradient(135deg, rgba(239, 246, 255, .96), rgba(255, 255, 255, .98));
}

.auth-trial-cta strong,
.auth-trial-cta small {
    display: block;
}

.auth-trial-kicker {
    display: block;
    margin-bottom: .15rem;
    color: #64748b;
    font-size: .85rem;
}

.dashboard-upgrade-banner {
    border: 1px solid rgba(37, 99, 235, .18);
    background: linear-gradient(135deg, rgba(239, 246, 255, .96), rgba(255, 255, 255, .98));
    box-shadow: 0 18px 40px rgba(15, 23, 42, .06);
}

@media (max-width: 575.98px) {
    .auth-trial-cta {
        align-items: stretch;
        flex-direction: column;
    }

    .auth-trial-cta .btn {
        width: 100%;
    }
}


/* Mobile UX polish */
@media (max-width: 767.98px) {
    html,
    body {
        max-width: 100%;
        overflow-x: clip;
    }

    .app-main,
    .app-content,
    .page-shell,
    .tc-card,
    .analytics-card,
    .table-responsive,
    .site-product-table-card,
    .source-records-page .source-summary-grid,
    .site-product-highlight,
    .hotelcode-overview-section,
    .usage-explainer,
    .landing-visual-pair,
    .log-details-grid {
        min-width: 0;
        max-width: 100%;
    }

    .app-content,
    .page-shell {
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }

    .table-responsive,
    .log-compact-scroll {
        overflow-x: visible;
    }

    .source-records-page .source-summary-grid,
    .site-product-highlight,
    .hotelcode-overview-section,
    .usage-explainer,
    .landing-visual-pair,
    .log-details-grid {
        grid-template-columns: 1fr;
    }

    .source-records-page .app-table,
    .source-records-page .app-table th,
    .source-records-page .app-table td,
    .log-compact-table,
    .log-compact-table th,
    .log-compact-table td,
    .bandwidth-main-table,
    .bandwidth-main-table th,
    .bandwidth-main-table td,
    .product-plans-table,
    .product-plans-table th,
    .product-plans-table td,
    .proxy-edit-table,
    .proxy-edit-table th,
    .proxy-edit-table td,
    .proxy-status-table,
    .proxy-status-table th,
    .proxy-status-table td {
        min-width: 0 !important;
        max-width: 100% !important;
    }

    .app-table td[data-label="User"],
    .app-table td[data-label="E-mail"],
    .app-table td[data-label="Message"],
    .app-table td[data-label="Hotel"],
    .app-table td[data-label="Provider"],
    .app-table td[data-label="Effective server"],
    .app-table td[data-label="Base server"],
    .app-table td[data-label="Intro label"] {
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .mobile-card-table .status-badge,
    .mobile-card-table .badge {
        max-width: 100%;
        white-space: normal;
        text-align: right;
    }

    .mobile-card-table .form-check,
    .mobile-card-table .form-switch {
        justify-self: end;
        margin-bottom: 0;
    }
}

@media (max-width: 575.98px) {
    .page-header,
    .analytics-card-header,
    .tc-card-header,
    .brand-topbar,
    .landing-actions,
    .auth-trial-cta {
        align-items: stretch;
        flex-direction: column;
    }

    .page-header > *,
    .analytics-card-header > *,
    .tc-card-header > *,
    .brand-lockup,
    .brand-nav,
    .landing-actions .btn,
    .auth-trial-cta .btn {
        min-width: 0;
        max-width: 100%;
    }

    .page-header .btn,
    .page-header .btn-group,
    .landing-actions .btn,
    .auth-trial-cta .btn {
        width: 100%;
    }

    .brand-topbar {
        padding: 0.8rem;
    }

    .brand-lockup {
        overflow: hidden;
    }

    .brand-nav {
        width: 100%;
        gap: 0.55rem;
    }

    .brand-nav a {
        width: 100%;
        padding-block: 0.45rem;
        overflow-wrap: anywhere;
    }

    .codebw-brand,
    .hotelcode-brand,
    .mobile-title,
    .tc-card-title {
        min-width: 0;
        overflow-wrap: anywhere;
    }

    .mini-table {
        overflow-x: visible;
    }

    .mini-table > div {
        min-width: 0;
        grid-template-columns: 1fr;
    }

    .mini-table > div > * {
        min-width: 0;
        max-width: 100%;
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .mobile-card-table tr {
        padding: 0.85rem;
        border-radius: 1rem;
    }

    .mobile-card-table td {
        grid-template-columns: minmax(6.4rem, 39%) minmax(0, 1fr);
        gap: 0.62rem;
        padding: 0.58rem 0;
    }

    .mobile-card-table td::before {
        font-size: 0.68rem;
    }
}

@media (max-width: 379.98px) {
    .app-content,
    .page-shell {
        padding-left: 0.55rem;
        padding-right: 0.55rem;
    }

    .mobile-card-table tr {
        margin: 0.65rem 0;
        padding: 0.75rem;
        border-radius: 0.9rem;
    }

    .mobile-card-table td {
        grid-template-columns: minmax(5.85rem, 37%) minmax(0, 1fr);
        gap: 0.55rem;
        font-size: 0.86rem;
    }

    .mobile-card-table td::before {
        font-size: 0.64rem;
        letter-spacing: 0.015em;
    }

    .mobile-card-table td[data-label="Actions"],
    .mobile-card-table td[data-label="Action"] {
        grid-template-columns: 1fr;
        text-align: left;
    }

    .mobile-card-table td[data-label="Actions"]::before,
    .mobile-card-table td[data-label="Action"]::before {
        margin-bottom: 0.15rem;
    }

    .mobile-card-table td[data-label="Actions"] > *,
    .mobile-card-table td[data-label="Action"] > * {
        justify-self: stretch;
    }
}

@media (max-width: 339.98px) {
    .app-content,
    .page-shell {
        padding-left: 0.45rem;
        padding-right: 0.45rem;
    }

    .mobile-card-table td {
        grid-template-columns: 1fr;
        text-align: left;
    }

    .mobile-card-table td::before {
        margin-bottom: 0.1rem;
    }

    .mobile-card-table td > *,
    .mobile-card-table .form-check,
    .mobile-card-table .form-switch {
        justify-self: start;
    }

    .mobile-card-table td.text-end,
    .mobile-card-table td .text-end {
        text-align: left !important;
    }

    .mobile-card-table .status-badge,
    .mobile-card-table .badge {
        text-align: left;
    }
}

/* Mobile admin action bar */
@media (max-width: 767.98px) {
    .mobile-card-table td[data-label="Actions"],
    .mobile-card-table td[data-label="Action"],
    .mobile-card-table td[data-label="Details"]:not([colspan]) {
        display: block;
        margin: 0.4rem -0.2rem -0.2rem;
        padding: 0.8rem 0.2rem 0.15rem;
        border-bottom: 0;
        border-top: 1px solid rgba(226, 232, 240, 0.95);
        text-align: left !important;
    }

    .mobile-card-table td[data-label="Actions"]::before,
    .mobile-card-table td[data-label="Action"]::before,
    .mobile-card-table td[data-label="Details"]:not([colspan])::before {
        display: block;
        margin-bottom: 0.55rem;
        color: #64748b;
        font-size: 0.68rem;
        font-weight: 900;
        letter-spacing: 0.08em;
        line-height: 1;
        text-align: left;
        text-transform: uppercase;
    }

    .mobile-card-table td[data-label="Actions"] > *,
    .mobile-card-table td[data-label="Action"] > *,
    .mobile-card-table td[data-label="Details"]:not([colspan]) > * {
        width: 100%;
        max-width: 100%;
        justify-self: stretch;
    }

    .mobile-card-table td[data-label="Actions"] .d-flex,
    .mobile-card-table td[data-label="Action"] .d-flex,
    .mobile-card-table td[data-label="Details"]:not([colspan]) .d-flex,
    .mobile-card-table td[data-label="Actions"] .btn-group,
    .mobile-card-table td[data-label="Action"] .btn-group,
    .mobile-card-table td[data-label="Details"]:not([colspan]) .btn-group {
        display: grid !important;
        grid-template-columns: repeat(auto-fit, minmax(7.75rem, 1fr));
        gap: 0.55rem;
        justify-content: stretch !important;
        width: 100%;
    }

    .mobile-card-table td[data-label="Actions"] .btn,
    .mobile-card-table td[data-label="Action"] .btn,
    .mobile-card-table td[data-label="Details"]:not([colspan]) .btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 2.45rem;
        width: 100%;
        padding: 0.52rem 0.72rem;
        border-radius: 0.85rem;
        font-size: 0.82rem;
        font-weight: 800;
        line-height: 1.15;
        white-space: normal;
    }

    .product-plans-table td[data-label="Actions"],
    .proxy-edit-table td[data-label="Action"],
    .log-compact-table td[data-label="Details"]:not([colspan]) {
        position: sticky;
        right: 0;
        bottom: 0;
        z-index: 2;
        background: linear-gradient(180deg, rgba(248, 250, 252, 0.72) 0%, #ffffff 28%, #ffffff 100%);
        backdrop-filter: blur(10px);
    }

    .product-plans-table td[data-label="Actions"] .d-flex {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 339.98px) {
    .mobile-card-table td[data-label="Actions"] .d-flex,
    .mobile-card-table td[data-label="Action"] .d-flex,
    .mobile-card-table td[data-label="Details"]:not([colspan]) .d-flex,
    .mobile-card-table td[data-label="Actions"] .btn-group,
    .mobile-card-table td[data-label="Action"] .btn-group,
    .mobile-card-table td[data-label="Details"]:not([colspan]) .btn-group,
    .product-plans-table td[data-label="Actions"] .d-flex {
        grid-template-columns: 1fr;
    }

    .mobile-card-table td[data-label="Actions"] .btn,
    .mobile-card-table td[data-label="Action"] .btn,
    .mobile-card-table td[data-label="Details"]:not([colspan]) .btn {
        min-height: 2.35rem;
        font-size: 0.8rem;
    }
}

/* Mobile premium forms and collapsible admin cards */
.mobile-card-detail-toggle {
    display: none;
}

@media (max-width: 767.98px) {
    .form-label,
    .col-form-label {
        margin-bottom: 0.38rem;
        color: #334155;
        font-size: 0.86rem;
        font-weight: 850;
        letter-spacing: -0.01em;
    }

    .form-control,
    .form-select {
        min-width: 0;
        min-height: 2.85rem;
        border-color: rgba(203, 213, 225, 0.95);
        border-radius: 0.95rem;
        background-color: #ffffff;
        font-size: 16px;
        box-shadow: 0 0.45rem 1.1rem rgba(15, 23, 42, 0.035);
    }

    textarea.form-control {
        min-height: 7rem;
        line-height: 1.45;
        resize: vertical;
    }

    .form-control:focus,
    .form-select:focus {
        border-color: rgba(37, 99, 235, 0.58);
        box-shadow:
            0 0 0 0.2rem rgba(37, 99, 235, 0.12),
            0 0.65rem 1.4rem rgba(37, 99, 235, 0.08);
    }

    .input-group {
        align-items: stretch;
        min-width: 0;
        border-radius: 0.95rem;
    }

    .input-group > .form-control,
    .input-group > .form-select,
    .input-group > .btn,
    .input-group > .input-group-text {
        min-width: 0;
        min-height: 2.85rem;
    }

    .input-group > .input-group-text {
        border-color: rgba(203, 213, 225, 0.95);
        background: #f8fafc;
        color: #475569;
        font-size: 0.84rem;
        font-weight: 800;
    }

    .form-text,
    .text-muted.small,
    .field-validation-valid,
    .field-validation-error,
    .invalid-feedback {
        overflow-wrap: anywhere;
        line-height: 1.4;
    }

    .field-validation-error,
    .invalid-feedback,
    .validation-summary-errors,
    .validation-summary-valid.text-danger:not(:empty) {
        display: block;
        margin-top: 0.45rem;
        padding: 0.58rem 0.72rem;
        border: 1px solid rgba(220, 38, 38, 0.18);
        border-radius: 0.85rem;
        background: rgba(254, 242, 242, 0.92);
        color: #b91c1c !important;
        font-size: 0.84rem;
        font-weight: 700;
    }

    .validation-summary-errors ul {
        margin: 0;
        padding-left: 1.05rem;
    }

    .form-check {
        display: flex;
        align-items: flex-start;
        gap: 0.68rem;
        min-width: 0;
        padding: 0.72rem 0.82rem;
        border: 1px solid rgba(203, 213, 225, 0.72);
        border-radius: 1rem;
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
        box-shadow: 0 0.45rem 1rem rgba(15, 23, 42, 0.035);
    }

    .form-check .form-check-input {
        flex: 0 0 auto;
        width: 1.15rem;
        height: 1.15rem;
        margin-top: 0.12rem;
        margin-left: 0;
        border-color: #94a3b8;
        cursor: pointer;
    }

    .form-check .form-check-label {
        min-width: 0;
        color: #1e293b;
        font-size: 0.9rem;
        font-weight: 750;
        line-height: 1.35;
        overflow-wrap: anywhere;
        cursor: pointer;
    }

    .form-switch {
        align-items: center;
        padding: 0.78rem 0.88rem;
    }

    .form-switch .form-check-input {
        width: 2.75rem;
        height: 1.48rem;
        margin-top: 0;
        background-color: #cbd5e1;
        background-position: left center;
        border-color: transparent;
    }

    .form-switch .form-check-input:checked {
        background-color: var(--primary);
        border-color: var(--primary);
    }

    .form-switch .form-check-input:focus {
        box-shadow: 0 0 0 0.2rem rgba(37, 99, 235, 0.14);
    }

    .mobile-card-table .form-check {
        justify-self: stretch;
        width: 100%;
        text-align: left;
    }

    .mobile-card-table .form-check .form-check-label {
        flex: 1 1 auto;
    }

    .admin-mobile-collapsible-table tr {
        position: relative;
        display: flex;
        flex-direction: column;
        transition: box-shadow 160ms ease, transform 160ms ease;
    }

    .admin-mobile-collapsible-table tr.has-mobile-details:not(.is-mobile-expanded) {
        box-shadow: 0 0.72rem 1.65rem rgba(15, 23, 42, 0.065);
    }

    .admin-mobile-collapsible-table td.mobile-card-summary-field {
        border-bottom-color: rgba(203, 213, 225, 0.9);
    }

    .admin-mobile-collapsible-table td.mobile-card-summary-field::before {
        color: #475569;
    }

    .admin-mobile-collapsible-table td.mobile-card-summary-field > * {
        font-weight: 750;
    }

    .admin-mobile-collapsible-table td.mobile-card-primary-value {
        order: -20;
        grid-template-columns: minmax(0, 1fr) auto;
        column-gap: 0.72rem;
        row-gap: 0.35rem;
        margin: -0.08rem 0 0.45rem;
        padding: 0.82rem 0.9rem;
        border: 1px solid rgba(37, 99, 235, 0.14);
        border-radius: 1rem;
        background:
            radial-gradient(circle at 0% 0%, rgba(96, 165, 250, 0.16), transparent 8rem),
            linear-gradient(135deg, rgba(239, 246, 255, 0.96), #ffffff);
        color: #0f172a;
        font-size: 1rem;
        font-weight: 950;
        letter-spacing: -0.02em;
        line-height: 1.28;
        text-align: left;
        box-shadow: 0 0.7rem 1.45rem rgba(37, 99, 235, 0.08);
    }

    .admin-mobile-collapsible-table td.mobile-card-primary-value::before {
        grid-column: 1 / -1;
        color: #2563eb;
        font-size: 0.68rem;
        letter-spacing: 0.08em;
    }

    .admin-mobile-collapsible-table td.mobile-card-primary-value > * {
        justify-self: start;
        font-size: inherit;
        font-weight: inherit;
        text-align: left !important;
    }

    .admin-mobile-collapsible-table td.mobile-card-primary-value .badge,
    .admin-mobile-collapsible-table td.mobile-card-primary-value .status-badge {
        font-size: 0.78rem;
        letter-spacing: 0;
    }

    .admin-mobile-collapsible-table td.mobile-card-primary-value .mobile-card-primary-main {
        min-width: 0;
        overflow-wrap: anywhere;
    }

    .admin-mobile-collapsible-table td.mobile-card-chip-source {
        display: none !important;
    }

    .admin-mobile-collapsible-table td.mobile-card-primary-value .mobile-card-primary-chip {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        justify-self: end;
        align-self: center;
        max-width: 8.25rem;
        min-height: 1.72rem;
        padding: 0.3rem 0.58rem;
        border: 1px solid rgba(100, 116, 139, 0.16);
        border-radius: 999px;
        background: rgba(248, 250, 252, 0.92);
        color: #475569;
        font-size: 0.72rem;
        font-weight: 950;
        letter-spacing: -0.01em;
        line-height: 1;
        text-align: center;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        box-shadow: 0 0.45rem 1rem rgba(15, 23, 42, 0.07);
    }

    .admin-mobile-collapsible-table td.mobile-card-primary-value .mobile-card-primary-chip[data-mobile-chip-kind="metric"] {
        font-variant-numeric: tabular-nums;
    }

    .admin-mobile-collapsible-table td.mobile-card-primary-value .mobile-card-primary-chip[data-mobile-chip-tone="success"] {
        border-color: rgba(22, 163, 74, 0.18);
        background: rgba(220, 252, 231, 0.9);
        color: #15803d;
    }

    .admin-mobile-collapsible-table td.mobile-card-primary-value .mobile-card-primary-chip[data-mobile-chip-tone="danger"] {
        border-color: rgba(220, 38, 38, 0.18);
        background: rgba(254, 226, 226, 0.9);
        color: #b91c1c;
    }

    .admin-mobile-collapsible-table td.mobile-card-primary-value .mobile-card-primary-chip[data-mobile-chip-tone="warning"] {
        border-color: rgba(217, 119, 6, 0.2);
        background: rgba(254, 243, 199, 0.9);
        color: #b45309;
    }

    .admin-mobile-collapsible-table td.mobile-card-primary-value .mobile-card-primary-chip[data-mobile-chip-tone="info"] {
        border-color: rgba(37, 99, 235, 0.17);
        background: rgba(219, 234, 254, 0.88);
        color: #1d4ed8;
    }

    .admin-mobile-collapsible-table td.mobile-card-summary-field:first-child {
        padding-top: 0;
    }

    .admin-mobile-collapsible-table td[data-mobile-detail="true"]:not([colspan]) {
        display: none;
        order: 100;
    }

    .admin-mobile-collapsible-table tr.is-mobile-expanded td[data-mobile-detail="true"]:not([colspan]) {
        display: grid;
        animation: adminMobileDetailIn 150ms ease-out;
    }

    .admin-mobile-collapsible-table tr.is-mobile-expanded td[data-mobile-detail="true"]:not([colspan]) + td[data-mobile-detail="true"]:not([colspan]) {
        border-top: 0;
    }

    .admin-mobile-collapsible-table .mobile-card-detail-toggle {
        order: 750;
        display: block;
        margin: 0.45rem 0 0;
        padding: 0.72rem 0 0.32rem;
        border-top: 1px dashed rgba(203, 213, 225, 0.95);
        border-bottom: 0;
        text-align: left;
    }

    .admin-mobile-collapsible-table .mobile-card-detail-toggle::before {
        display: none;
    }

    .admin-mobile-collapsible-table td[data-label="Actions"],
    .admin-mobile-collapsible-table td[data-label="Action"],
    .admin-mobile-collapsible-table td[data-label="Details"]:not([colspan]) {
        order: 800;
    }

    .mobile-details-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 0.45rem;
        width: 100%;
        min-height: 2.55rem;
        border: 1px solid rgba(37, 99, 235, 0.18);
        border-radius: 999px;
        background:
            linear-gradient(135deg, rgba(239, 246, 255, 0.96), #ffffff),
            #ffffff;
        color: #1d4ed8;
        font-size: 0.83rem;
        font-weight: 900;
        line-height: 1.15;
        box-shadow: 0 0.55rem 1.1rem rgba(37, 99, 235, 0.075);
        transition: transform 140ms ease, box-shadow 140ms ease, background-color 140ms ease;
    }

    .mobile-details-toggle:active {
        transform: scale(0.985);
        box-shadow: 0 0.35rem 0.85rem rgba(37, 99, 235, 0.09);
    }

    .mobile-details-toggle::after {
        content: "⌄";
        font-size: 1rem;
        line-height: 1;
        transform: translateY(-0.02rem);
        transition: transform 140ms ease;
    }

    .mobile-details-toggle[aria-expanded="true"]::after {
        transform: rotate(180deg);
    }

    .product-plans-table td[data-label="Actions"],
    .proxy-edit-table td[data-label="Action"],
    .log-compact-table td[data-label="Details"]:not([colspan]) {
        margin-top: 0.45rem;
    }
}

@media (max-width: 379.98px) {
    .form-control,
    .form-select,
    .input-group > .form-control,
    .input-group > .form-select,
    .input-group > .btn,
    .input-group > .input-group-text {
        min-height: 2.7rem;
        border-radius: 0.85rem;
    }

    .form-check {
        padding: 0.64rem 0.68rem;
        border-radius: 0.9rem;
    }

    .mobile-details-toggle {
        min-height: 2.35rem;
        font-size: 0.8rem;
    }

    .mobile-admin-tabbar {
        right: max(0.45rem, env(safe-area-inset-right));
        left: max(0.45rem, env(safe-area-inset-left));
        padding: 0.32rem;
        border-radius: 1.15rem;
    }

    .mobile-admin-tabbar-link {
        min-height: 3.05rem;
        border-radius: 0.85rem;
        font-size: 0.62rem;
    }
}

@keyframes adminMobileDetailIn {
    from {
        opacity: 0;
        transform: translateY(-0.18rem);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Register auth mobile tap safety */
.auth-register-form,
.auth-register-form .auth-submit-button {
    position: relative;
    z-index: 2;
}

.auth-register-form .auth-submit-button {
    min-height: 3.2rem;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

.auth-register-form .payment-plan-card {
    cursor: default;
}

@media (max-width: 575.98px) {
    body.auth-register-page .app-main.auth-main {
        display: block;
        min-height: 100svh;
        padding-bottom: calc(1rem + env(safe-area-inset-bottom));
    }

    body.auth-register-page .auth-main .app-content {
        padding-bottom: calc(1.25rem + env(safe-area-inset-bottom));
    }

    body.auth-register-page .whatsapp-widget {
        display: none;
    }
}


/* Public site footer */
.site-footer {
    width: min(calc(100% - 2rem), 1440px);
    margin: 0 auto clamp(1rem, 3vw, 2rem);
    padding: clamp(1.25rem, 3vw, 2rem);
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 1.75rem;
    background:
        radial-gradient(circle at 12% 0%, rgba(37, 99, 235, 0.12), transparent 22rem),
        linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(248, 250, 252, 0.88));
    box-shadow: var(--shadow-sm);
}

.site-footer-inner {
    display: grid;
    grid-template-columns: minmax(28rem, 2.2fr) repeat(3, minmax(8.5rem, 0.78fr));
    gap: clamp(1.25rem, 3vw, 2rem);
    align-items: flex-start;
}

.site-footer-brand {
    display: grid;
    gap: 1rem;
    max-width: 44rem;
}

.site-footer-lockup {
    display: inline-flex;
    align-items: center;
    gap: 0.85rem;
    width: fit-content;
    color: inherit;
}

.site-footer-lockup:hover {
    color: inherit;
}

.site-footer-logo {
    box-sizing: border-box;
    display: block;
    width: var(--hotelcode-logo-size);
    height: var(--hotelcode-logo-size);
    flex: 0 0 auto;
    padding: var(--hotelcode-logo-padding);
    border-radius: var(--hotelcode-logo-radius);
    background: transparent;
    object-fit: contain;
    box-shadow: none;
}

.site-footer-lockup strong,
.site-footer-lockup small {
    display: block;
}

.site-footer-lockup strong {
    color: #0f172a;
    font-size: 0.8rem;
    font-weight: 950;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.site-footer-lockup small {
    margin-top: 0.08rem;
    color: var(--primary);
    font-size: 1rem;
    font-weight: 900;
    letter-spacing: -0.035em;
}

.site-footer-brand p {
    margin: 0;
    color: var(--muted);
    font-size: 0.95rem;
    line-height: 1.7;
}

.site-footer-column {
    display: grid;
    gap: 0.55rem;
}

.site-footer-column h2 {
    margin: 0 0 0.25rem;
    color: #0f172a;
    font-size: 0.78rem;
    font-weight: 950;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.site-footer-column a {
    width: fit-content;
    color: #64748b;
    font-size: 0.94rem;
    font-weight: 700;
    line-height: 1.35;
    transition: color 160ms ease, transform 160ms ease;
}

.site-footer-column a:hover {
    color: var(--primary);
    transform: translateX(0.12rem);
}

.site-footer-bottom {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    justify-content: space-between;
    margin-top: clamp(1.25rem, 3vw, 2rem);
    padding-top: 1rem;
    border-top: 1px solid rgba(226, 232, 240, 0.95);
    color: #94a3b8;
    font-size: 0.84rem;
    font-weight: 700;
}

@media (max-width: 991.98px) {
    .site-footer-inner {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .site-footer-brand {
        grid-column: 1 / -1;
        max-width: none;
    }
}

@media (max-width: 575.98px) {
    .site-footer {
        width: min(calc(100% - 1rem), 1180px);
        margin-bottom: calc(0.75rem + env(safe-area-inset-bottom));
        padding: 1rem;
        border-radius: 1.35rem;
    }

    .site-footer-inner {
        grid-template-columns: 1fr;
        gap: 1.2rem;
    }

    .site-footer-column {
        padding-top: 1rem;
        border-top: 1px solid rgba(226, 232, 240, 0.85);
    }

    .site-footer-column a {
        min-height: 2.15rem;
        display: inline-flex;
        align-items: center;
    }

    .site-footer-bottom {
        display: grid;
        justify-content: stretch;
    }
}


/* Typography readability patch */
html {
    text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
}

body {
    line-height: 1.5;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.page-kicker,
.page-eyebrow,
.landing-kicker {
    font-size: 0.8rem;
    line-height: 1.2;
    letter-spacing: 0.09em;
}

.page-title {
    line-height: 1.08;
    letter-spacing: -0.025em;
    text-wrap: balance;
}

.auth-hero h1 {
    line-height: 1.06;
    letter-spacing: -0.04em;
    text-wrap: balance;
}

.tc-card-title {
    line-height: 1.25;
    letter-spacing: -0.015em;
}

.landing-hero h1,
.landing-section h2,
.landing-auth-copy h2 {
    font-weight: 900;
    line-height: 1.06;
    letter-spacing: -0.04em;
    text-wrap: balance;
}

.landing-hero h1 {
    font-size: clamp(2.15rem, 5vw, 4.5rem);
    line-height: 1.04;
}

.saas-hero h1 {
    font-size: clamp(2.45rem, 6vw, 5.25rem);
    font-weight: 900;
    line-height: 1.03;
    letter-spacing: -0.04em;
    text-wrap: balance;
}

.showcase-copy h2,
.site-product-copy h2,
.hotelcode-overview-copy h2 {
    font-weight: 900;
    line-height: 1.06;
    letter-spacing: -0.04em;
    text-wrap: balance;
}

@media (max-width: 575.98px) {
    .page-title {
        font-size: clamp(1.55rem, 8vw, 2rem);
        line-height: 1.12;
        letter-spacing: -0.02em;
    }

    .auth-hero h1 {
        font-size: clamp(1.8rem, 9vw, 2.25rem);
        line-height: 1.1;
    }

    .landing-hero h1,
    .saas-hero h1 {
        font-size: clamp(2rem, 10vw, 3rem);
        line-height: 1.08;
        letter-spacing: -0.03em;
    }

    .landing-section h2,
    .landing-auth-copy h2,
    .showcase-copy h2,
    .site-product-copy h2,
    .hotelcode-overview-copy h2 {
        font-size: clamp(1.8rem, 8.5vw, 2.5rem);
        line-height: 1.1;
        letter-spacing: -0.03em;
    }

    .page-kicker,
    .page-eyebrow,
    .landing-kicker {
        font-size: 0.76rem;
        letter-spacing: 0.075em;
    }

    .page-subtitle,
    .landing-lead,
    .site-product-copy p,
    .hotelcode-overview-copy p {
        line-height: 1.65;
    }
}

@media (max-width: 379.98px) {
    .page-title {
        font-size: 1.45rem;
    }

    .landing-hero h1,
    .saas-hero h1 {
        font-size: clamp(1.85rem, 10vw, 2.35rem);
        letter-spacing: -0.025em;
    }

    .page-kicker,
    .page-eyebrow,
    .landing-kicker {
        font-size: 0.72rem;
    }
}

/* Footer alignment, social links, legal pages and compact app footer */
.auth-main .app-content > .site-footer {
    width: auto;
    max-width: none;
    margin: clamp(0.25rem, 1.5vw, 1rem) clamp(1.25rem, 2.4vw, 3rem) clamp(1rem, 3vw, 2rem);
}

.site-footer-inner {
    grid-template-columns: minmax(34rem, 2.15fr) repeat(4, minmax(8rem, 0.72fr));
}

.site-footer-social {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.site-footer-social a {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 2.25rem;
    padding: 0.48rem 0.7rem;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 999px;
    color: #334155;
    background: rgba(255, 255, 255, 0.78);
    font-size: 0.86rem;
    font-weight: 850;
    transition: border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.site-footer-social a:hover,
.site-footer-social a:focus-visible {
    color: var(--primary);
    border-color: rgba(37, 99, 235, 0.35);
    transform: translateY(-0.08rem);
}

.site-footer-address {
    display: flex;
    align-items: flex-start;
    gap: 0.45rem;
    max-width: 46rem;
    margin: 0.85rem 0 0;
    color: #64748b;
    font-size: 0.88rem;
    font-style: normal;
    font-weight: 750;
    line-height: 1.5;
}

.site-footer-address i {
    color: var(--primary);
    font-size: 1rem;
    line-height: 1.45;
}

.site-footer-address span {
    display: block;
    max-width: none;
}

@media (max-width: 1199.98px) {
    .site-footer-inner {
        grid-template-columns: minmax(0, 1fr) repeat(2, minmax(9rem, 0.5fr));
    }

    .site-footer-brand {
        grid-column: 1 / -1;
        max-width: 100%;
    }

    .site-footer-address {
        max-width: 100%;
    }
}

@media (max-width: 991.98px) {
    .site-footer-inner {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .site-footer-brand {
        grid-column: 1 / -1;
        max-width: 100%;
    }
}

@media (max-width: 575.98px) {
    .site-footer-inner {
        grid-template-columns: 1fr;
        gap: 1.2rem;
    }
}

.site-footer-bottom-address,
.app-footer-address {
    color: #64748b;
    font-size: 0.82rem;
    font-weight: 750;
    line-height: 1.45;
}

body.auth-page.hotelcode-corporate-ui .site-footer-address,
body.auth-page.hotelcode-corporate-ui .site-footer-bottom-address {
    color: rgba(203, 213, 225, 0.88);
}

body.auth-page.hotelcode-corporate-ui .site-footer-address i {
    color: #4ce0a6;
}

.site-footer-bottom-links {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.45rem 0.85rem;
    align-items: center;
}

.site-footer-bottom-links a {
    color: #64748b;
    font-weight: 800;
}

.site-footer-bottom-links a:hover,
.site-footer-bottom-links a:focus-visible {
    color: var(--primary);
}

.app-footer {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1rem;
    align-items: center;
    justify-content: space-between;
    margin: 2rem 0 0;
    padding: 1rem 1.15rem;
    border: 1px solid rgba(226, 232, 240, 0.85);
    border-radius: 1rem;
    color: #64748b;
    background: rgba(255, 255, 255, 0.72);
    font-size: 0.86rem;
    font-weight: 750;
}

.app-footer nav {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.45rem 0.85rem;
    align-items: center;
}

.app-footer a {
    color: #475569;
    font-weight: 850;
}

.app-footer a:hover,
.app-footer a:focus-visible {
    color: var(--primary);
}

.legal-page {
    gap: 1.5rem;
}

.legal-hero-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.35fr);
    gap: clamp(1.25rem, 3vw, 2.5rem);
    align-items: center;
}

.legal-title {
    max-width: 64rem;
    margin: 0.35rem 0 0;
    color: var(--text);
    font-size: clamp(2rem, 5vw, 4.25rem);
    font-weight: 925;
    line-height: 1.04;
    letter-spacing: -0.045em;
    text-wrap: balance;
}

.legal-lead {
    max-width: 56rem;
    margin: 1rem 0 0;
    color: var(--muted);
    font-size: clamp(1rem, 1.6vw, 1.16rem);
    line-height: 1.7;
}

.legal-summary-card {
    display: grid;
    gap: 0.45rem;
    padding: 1.15rem;
    border: 1px solid rgba(219, 234, 254, 0.95);
    border-radius: 1.25rem;
    color: #1e3a8a;
    background: linear-gradient(135deg, rgba(219, 234, 254, 0.92), rgba(239, 246, 255, 0.86));
}

.legal-summary-card i {
    display: inline-grid;
    place-items: center;
    width: 2.45rem;
    height: 2.45rem;
    border-radius: 0.85rem;
    color: var(--primary);
    background: #ffffff;
    font-size: 1.1rem;
}

.legal-summary-card strong,
.legal-summary-card span {
    display: block;
}

.legal-summary-card strong {
    color: #0f172a;
    font-weight: 900;
}

.legal-summary-card span {
    color: #475569;
    line-height: 1.55;
}

.legal-content-card {
    background: rgba(255, 255, 255, 0.76);
}

.legal-content {
    display: grid;
    gap: 1rem;
    max-width: 74rem;
}

.legal-content h2 {
    margin: 1rem 0 0;
    color: #0f172a;
    font-size: clamp(1.15rem, 2vw, 1.55rem);
    font-weight: 900;
    letter-spacing: -0.025em;
}

.legal-content h2:first-child {
    margin-top: 0;
}

.legal-content p {
    margin: 0;
    color: #475569;
    line-height: 1.75;
}

@media (max-width: 1199.98px) {
    .site-footer-inner {
        grid-template-columns: minmax(0, 1.35fr) repeat(2, minmax(0, 0.8fr));
    }

    .site-footer-brand {
        grid-column: 1 / -1;
    }
}

@media (max-width: 991.98px) {
    .auth-main .app-content > .site-footer {
        margin-right: 1rem;
        margin-left: 1rem;
    }

    .legal-hero-card {
        grid-template-columns: 1fr;
    }

    .app-footer {
        margin-top: 1.25rem;
    }
}

@media (max-width: 575.98px) {
    .auth-main .app-content > .site-footer {
        margin-right: 0;
        margin-left: 0;
    }

    .site-footer-social,
    .site-footer-social a,
    .site-footer-bottom-links,
    .app-footer,
    .app-footer nav {
        width: 100%;
    }

    .site-footer-social a {
        justify-content: center;
    }

    .site-footer-bottom-links {
        justify-content: flex-start;
    }

    .app-footer nav {
        justify-content: center;
    }

    .app-footer {
        display: grid;
        margin-bottom: calc(0.75rem + env(safe-area-inset-bottom));
    }

    .legal-title {
        font-size: clamp(1.85rem, 10vw, 2.55rem);
        line-height: 1.08;
        letter-spacing: -0.03em;
    }
}



/* Mobile app footer for every user */
.mobile-app-footer {
    display: none;
}

@media (max-width: 767.98px) {
    .site-footer-public {
        display: none;
    }

    .mobile-app-footer {
        display: grid;
    }

    .mobile-app-footer.app-footer {
        gap: 0.6rem;
        justify-items: center;
        margin-top: 1rem;
        margin-bottom: calc(0.9rem + env(safe-area-inset-bottom));
        padding: 0.95rem 4.85rem 1rem 1rem;
        border: 1px solid rgba(255, 255, 255, 0.16);
        border-radius: 1rem;
        background: linear-gradient(135deg, rgba(11, 18, 19, 0.96), rgba(17, 24, 26, 0.94));
        box-shadow: 0 18px 42px rgba(2, 6, 23, 0.28);
        text-align: center;
        font-size: 0.82rem;
        line-height: 1.45;
        color: #e2e8f0;
    }

    .mobile-app-footer.app-footer > span:first-child {
        color: #ffffff;
        font-size: 0.8rem;
        font-weight: 850;
        letter-spacing: -0.01em;
    }

    .mobile-app-footer.app-footer .app-footer-address {
        display: block;
        max-width: 100%;
        color: #dbe6ef;
        font-size: 0.8rem;
        font-weight: 720;
        line-height: 1.5;
        text-wrap: balance;
    }

    .mobile-app-footer.app-footer nav {
        width: 100%;
        justify-content: center;
        gap: 0.45rem 0.9rem;
        padding-top: 0.6rem;
        border-top: 1px solid rgba(255, 255, 255, 0.14);
    }

    .mobile-app-footer.app-footer a {
        display: inline-flex;
        align-items: center;
        min-height: 1.7rem;
        color: #f8fafc;
        font-size: 0.79rem;
        font-weight: 800;
        line-height: 1.25;
    }

    .mobile-app-footer.app-footer a:hover,
    .mobile-app-footer.app-footer a:focus-visible {
        color: #8fffd8;
    }

    .app-footer-mobile-hidden {
        display: none !important;
    }

    .app-main.has-mobile-admin-tabs .app-footer {
        margin-bottom: calc(5rem + env(safe-area-inset-bottom));
    }
}


/* Mobile spacing consistency pass */
@media (max-width: 767.98px) {
    :root {
        --mobile-page-gutter: clamp(0.72rem, 3.8vw, 1rem);
        --mobile-section-gap: 0.85rem;
        --mobile-card-padding-x: 0.9rem;
        --mobile-card-padding-y: 0.85rem;
        --mobile-card-radius: 1rem;
    }

    .app-content {
        padding: 0.9rem var(--mobile-page-gutter);
    }

    .app-content > .page-shell,
    .auth-main .app-content > .landing-shell,
    .auth-main .app-content > .premium-landing,
    .auth-main .app-content > .corporate-shell {
        padding-right: 0;
        padding-left: 0;
    }

    .page-shell,
    .landing-shell,
    .premium-landing,
    .corporate-shell,
    .tc-stack {
        gap: var(--mobile-section-gap);
    }

    .page-header {
        gap: 0.75rem;
        margin-bottom: 0.95rem;
    }

    .page-subtitle {
        margin-top: 0.25rem;
        line-height: 1.55;
    }

    .analytics-card,
    .tc-card,
    .kpi-card,
    .landing-section,
    .landing-auth-section,
    .landing-policy,
    .site-product-highlight,
    .hotelcode-overview-section,
    .usage-explainer,
    .visual-workflow,
    .product-visual,
    .visual-dashboard,
    .demo-window {
        border-radius: var(--mobile-card-radius);
    }

    .analytics-card-header,
    .tc-card-header,
    .analytics-card > .card-body,
    .analytics-card > .analytics-card-body,
    .analytics-card > .tc-card-body,
    .tc-card > .card-body,
    .tc-card > .analytics-card-body,
    .tc-card > .tc-card-body,
    .card-body {
        padding: var(--mobile-card-padding-y) var(--mobile-card-padding-x);
    }

    .analytics-card-header,
    .tc-card-header {
        gap: 0.65rem;
    }

    .tc-stack > * + * {
        margin-top: var(--mobile-section-gap);
    }

    .row.g-3,
    .row.g-4,
    .row.gx-3,
    .row.gx-4 {
        --bs-gutter-x: 0.85rem;
    }

    .row.g-3,
    .row.g-4,
    .row.gy-3,
    .row.gy-4 {
        --bs-gutter-y: 0.85rem;
    }

    .metric-strip,
    .landing-trust-grid,
    .landing-feature-grid,
    .pricing-grid,
    .source-records-page .source-summary-grid,
    .log-details-grid,
    .usage-explainer,
    .landing-visual-pair,
    .visual-dashboard-grid {
        gap: 0.75rem;
    }

    .kpi-card,
    .tc-stat-card,
    .landing-feature-card,
    .pricing-card {
        min-height: auto;
        padding: 0.9rem;
    }

    .landing-hero,
    .landing-section,
    .landing-policy,
    .landing-auth-section,
    .site-product-highlight,
    .hotelcode-overview-section,
    .usage-explainer {
        padding: clamp(0.95rem, 4vw, 1.2rem);
    }

    .landing-hero,
    .landing-auth-section,
    .site-product-highlight,
    .hotelcode-overview-section,
    .usage-explainer {
        gap: 1rem;
    }

    .landing-section-header {
        gap: 0.8rem;
        margin-bottom: 0.85rem;
    }

    .landing-lead,
    .site-product-copy p,
    .hotelcode-overview-copy p {
        margin-top: 0.75rem;
    }

    .landing-actions {
        gap: 0.6rem;
        margin-top: 1rem;
    }

    .landing-trust-grid {
        margin-top: 1rem;
    }

    .mobile-card-table tr {
        margin: 0.65rem 0;
    }

    .mobile-card-table td {
        padding-top: 0.52rem;
        padding-bottom: 0.52rem;
    }

    .empty-state {
        min-height: 9rem;
        padding: 1.25rem 0.9rem;
    }

    .modal-dialog {
        margin-right: var(--mobile-page-gutter);
        margin-left: var(--mobile-page-gutter);
    }
}

@media (max-width: 575.98px) {
    :root {
        --mobile-page-gutter: 0.68rem;
        --mobile-section-gap: 0.72rem;
        --mobile-card-padding-x: 0.82rem;
        --mobile-card-padding-y: 0.78rem;
        --mobile-card-radius: 0.95rem;
    }

    .mobile-topbar {
        gap: 0.62rem;
        padding: calc(0.58rem + env(safe-area-inset-top)) 0.72rem 0.58rem;
    }

    .icon-btn {
        width: 2.45rem;
        height: 2.45rem;
        border-radius: 0.78rem;
    }

    .mobile-role-pill {
        min-height: 1.8rem;
        padding-right: 0.55rem;
        padding-left: 0.55rem;
        font-size: 0.68rem;
    }

    .app-content {
        padding-top: 0.72rem;
        padding-bottom: 0.72rem;
    }

    .page-header,
    .analytics-card-header,
    .tc-card-header {
        gap: 0.6rem;
    }

    .page-header {
        margin-bottom: 0.78rem;
    }

    .auth-card .card-body {
        padding: 1rem !important;
    }

    .landing-hero,
    .landing-section,
    .landing-policy,
    .landing-auth-section,
    .site-product-highlight,
    .hotelcode-overview-section,
    .usage-explainer {
        padding: 0.9rem;
    }

    .landing-feature-card,
    .pricing-card,
    .tc-stat-card,
    .kpi-card {
        padding: 0.82rem;
    }

    .btn:not(.mobile-admin-tabbar-link):not(.whatsapp-fab) {
        min-height: 2.55rem;
    }

    .form-text,
    .helper-text,
    .tc-helper-text,
    .tc-inline-note {
        margin-top: 0.35rem;
    }

    .app-main:not(.has-mobile-admin-tabs) ~ .whatsapp-widget {
        bottom: calc(3.45rem + env(safe-area-inset-bottom));
    }
}

@media (max-width: 379.98px) {
    :root {
        --mobile-page-gutter: 0.55rem;
        --mobile-section-gap: 0.62rem;
        --mobile-card-padding-x: 0.72rem;
        --mobile-card-padding-y: 0.72rem;
    }

    .landing-hero,
    .landing-section,
    .landing-policy,
    .landing-auth-section,
    .site-product-highlight,
    .hotelcode-overview-section,
    .usage-explainer {
        padding: 0.78rem;
    }

    .mobile-card-table tr {
        margin: 0.52rem 0;
    }
}

/* Mobile footer centering fix */
@media (max-width: 575.98px) {
    .app-footer {
        place-items: center;
        align-content: center;
        justify-content: center;
        text-align: center;
    }

    .app-footer span,
    .app-footer nav {
        width: 100%;
        text-align: center;
    }

    .app-footer nav {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
    }

    .app-footer a {
        justify-content: center;
        text-align: center;
    }

    .mobile-app-footer.app-footer {
        padding-right: 5.1rem;
    }
}



/* Dashboard charts */
.chart-wrap {
    position: relative;
    width: 100%;
    min-height: 18rem;
}

@media (max-width: 575.98px) {
    .chart-wrap {
        min-height: 15.5rem;
    }
}


/* Flight Split analytics */
.flight-analytics-section .metric-value {
    font-size: clamp(1.1rem, 2.4vw, 1.55rem);
}

.flight-chart-wrap {
    min-height: 17rem;
}

@media (max-width: 767.98px) {
    .flight-analytics-section .analytics-card-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .flight-analytics-section .analytics-card-actions {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .flight-chart-wrap {
        min-height: 15rem;
    }
}


.flight-market-analytics {
    display: grid;
    gap: 1rem;
}

.flight-market-tabs {
    gap: .5rem;
}

.flight-market-tabs .nav-link {
    border: 1px solid rgba(148, 163, 184, .25);
    border-radius: 999px;
    color: #475569;
    font-weight: 800;
    padding: .45rem .8rem;
}

.flight-market-tabs .nav-link.active {
    background: #2563eb;
    border-color: #2563eb;
    color: #fff;
}

.flight-market-tabs .nav-link.daily-lowest-market-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.flight-market-tabs .nav-link.daily-lowest-market-tab.volatility-level-stable {
    color: #166534;
    background: rgba(220, 252, 231, 0.7);
    border-color: rgba(22, 163, 74, 0.26);
}

.flight-market-tabs .nav-link.daily-lowest-market-tab.volatility-level-moderate {
    color: #92400e;
    background: rgba(254, 243, 199, 0.72);
    border-color: rgba(245, 158, 11, 0.32);
}

.flight-market-tabs .nav-link.daily-lowest-market-tab.volatility-level-high {
    color: #991b1b;
    background: rgba(254, 226, 226, 0.74);
    border-color: rgba(220, 38, 38, 0.3);
}

.flight-market-tabs .nav-link.daily-lowest-market-tab.volatility-level-needs-data,
.flight-market-tabs .nav-link.daily-lowest-market-tab.volatility-level-neutral {
    color: #475569;
    background: rgba(241, 245, 249, 0.86);
    border-color: rgba(100, 116, 139, 0.24);
}

.flight-market-tabs .nav-link.daily-lowest-market-tab.volatility-level-stable.active {
    color: #fff;
    background: #16a34a;
    border-color: #16a34a;
    box-shadow: 0 10px 22px rgba(22, 163, 74, 0.22);
}

.flight-market-tabs .nav-link.daily-lowest-market-tab.volatility-level-moderate.active {
    color: #111827;
    background: #f59e0b;
    border-color: #f59e0b;
    box-shadow: 0 10px 22px rgba(245, 158, 11, 0.24);
}

.flight-market-tabs .nav-link.daily-lowest-market-tab.volatility-level-high.active {
    color: #fff;
    background: #dc2626;
    border-color: #dc2626;
    box-shadow: 0 10px 22px rgba(220, 38, 38, 0.24);
}

.flight-market-tabs .nav-link.daily-lowest-market-tab.volatility-level-needs-data.active,
.flight-market-tabs .nav-link.daily-lowest-market-tab.volatility-level-neutral.active {
    color: #fff;
    background: #64748b;
    border-color: #64748b;
    box-shadow: 0 10px 22px rgba(100, 116, 139, 0.2);
}

.daily-lowest-market-tab-label {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
    min-width: 0;
}

.daily-lowest-market-tab-warning {
    font-size: 0.78rem;
    line-height: 1;
}

.market-tab-count {
    background: rgba(15, 23, 42, .08);
    border-radius: 999px;
    display: inline-flex;
    font-size: .72rem;
    margin-left: .35rem;
    padding: .1rem .4rem;
}

.flight-market-tabs .nav-link.active .market-tab-count {
    background: rgba(255, 255, 255, .18);
}

.flight-market-tabs .nav-link.daily-lowest-market-tab.volatility-level-moderate.active .market-tab-count {
    color: #111827;
    background: rgba(255, 255, 255, 0.34);
}

.flight-market-tab-content {
    min-width: 0;
}

@media (max-width: 767.98px) {
    .flight-market-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        padding-bottom: .25rem;
    }

    .flight-market-tabs .nav-link {
        white-space: nowrap;
    }
}



/* Processing estimate */
.process-estimate {
    display: grid;
    gap: .75rem;
    padding: 1rem;
    border: 1px solid rgba(37, 99, 235, .16);
    border-radius: 1rem;
    background:
        radial-gradient(circle at top left, rgba(37, 99, 235, .10), transparent 18rem),
        var(--surface);
    box-shadow: var(--shadow-sm);
}

.process-estimate-top,
.process-estimate-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
}

.process-estimate-title {
    color: var(--text);
    font-weight: 800;
}

.process-estimate-percent {
    display: inline-flex;
    align-items: center;
    min-width: 3.25rem;
    justify-content: center;
    padding: .25rem .65rem;
    border-radius: 999px;
    color: var(--primary-strong);
    background: var(--primary-soft);
    font-weight: 800;
}

.process-estimate-bar {
    height: .65rem;
    border-radius: 999px;
    background: rgba(37, 99, 235, .12);
    overflow: hidden;
}

.process-estimate-meta {
    flex-wrap: wrap;
    color: var(--muted);
    font-size: .88rem;
    font-weight: 700;
}

.process-estimate-note {
    color: var(--muted);
    line-height: 1.45;
}

@media (max-width: 575.98px) {
    .process-estimate-top {
        align-items: flex-start;
        flex-direction: column;
    }

    .process-estimate-percent {
        justify-content: flex-start;
    }

    .process-estimate-meta {
        align-items: flex-start;
        flex-direction: column;
    }
}

.admin-filter-chip-list {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  min-width: 0;
  max-width: 100%;
}

.admin-filter-chip-label {
  flex: 0 0 auto;
  white-space: nowrap;
}

.admin-filter-chip {
  display: inline-flex;
  align-items: center;
  flex: 0 1 auto;
  gap: 0.125rem;
  min-width: 0;
  max-width: 100%;
  white-space: normal;
  line-height: 1.25;
}

.admin-filter-chip-text {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.admin-filter-chip-remove {
  max-width: 0;
  opacity: 0;
  overflow: hidden;
  transform: scale(0.75);
  transition: max-width 0.15s ease, opacity 0.15s ease, transform 0.15s ease;
}

.admin-filter-chip:hover .admin-filter-chip-remove,
.admin-filter-chip:focus .admin-filter-chip-remove,
.admin-filter-chip:focus-visible .admin-filter-chip-remove {
  max-width: 1rem;
  opacity: 1;
  transform: scale(1);
}

@media (max-width: 575.98px) {
  .admin-filter-chip-list {
    display: flex;
    align-items: flex-start;
    width: 100%;
    gap: 0.375rem;
  }

  .admin-filter-chip-label {
    width: 100%;
  }

  .admin-filter-chip {
    justify-content: flex-start;
    align-items: flex-start;
    white-space: normal;
    word-break: normal;
    overflow-wrap: anywhere;
  }

  .admin-filter-chip > i {
    flex: 0 0 auto;
    margin-top: 0.05rem;
  }

  .admin-filter-chip-text {
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .admin-filter-chip-remove {
    flex: 0 0 auto;
    margin-top: 0.02rem;
  }

  .admin-filter-chip-empty {
    display: block;
    width: 100%;
  }
}


/* Language and demo signup enhancements */
.language-switcher {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    min-width: 8.75rem;
    padding: .35rem .5rem;
    border: 1px solid rgba(148, 163, 184, .35);
    border-radius: 999px;
    background: rgba(255, 255, 255, .92);
    color: var(--text);
}

.language-switcher i {
    color: var(--primary);
}

.language-switcher-select {
    min-width: 0;
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    color: inherit;
    font: inherit;
    font-weight: 750;
}

.sidebar-footer .language-switcher,
.mobile-nav .language-switcher {
    width: 100%;
    border-color: rgba(255, 255, 255, .14);
    background: rgba(255, 255, 255, .08);
    color: #e2e8f0;
}

.mobile-nav .language-switcher {
    color: var(--text);
    border-color: var(--border);
    background: var(--surface-muted);
}

.demo-benefit-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: .75rem;
}

.demo-benefit-card {
    display: grid;
    grid-template-columns: auto 1fr;
    column-gap: .75rem;
    row-gap: .15rem;
    padding: .85rem;
    border: 1px solid rgba(148, 163, 184, .28);
    border-radius: 1rem;
    background: rgba(248, 250, 252, .82);
}

.demo-benefit-card i {
    grid-row: span 2;
    display: inline-grid;
    place-items: center;
    width: 2.35rem;
    height: 2.35rem;
    border-radius: .85rem;
    color: var(--primary);
    background: var(--primary-soft);
}

.demo-benefit-card strong {
    color: var(--text);
    font-weight: 850;
}

.demo-benefit-card span {
    color: var(--muted);
    font-size: .9rem;
    line-height: 1.35;
}

html[dir="rtl"] body {
    direction: rtl;
    text-align: right;
}

html[dir="rtl"] .brand-nav,
html[dir="rtl"] .landing-actions,
html[dir="rtl"] .sidebar-link,
html[dir="rtl"] .sidebar-sub-link,
html[dir="rtl"] .whatsapp-option,
html[dir="rtl"] .language-switcher {
    flex-direction: row-reverse;
}

html[dir="rtl"] .me-1 {
    margin-right: 0 !important;
    margin-left: .25rem !important;
}


/* SocialCode-inspired HotelCode corporate design layer */
body.hotelcode-corporate-ui {
    --primary: #26c281;
    --primary-strong: #168a5a;
    --primary-soft: rgba(38, 194, 129, 0.14);
    --success: #26c281;
    --success-soft: rgba(38, 194, 129, 0.14);
    --sidebar: #020403;
    --sidebar-soft: #07100d;
    --shadow: 0 1.6rem 4rem rgba(2, 4, 3, 0.16);
    --shadow-sm: 0 1rem 2.4rem rgba(2, 4, 3, 0.10);
}

body.auth-page.hotelcode-corporate-ui {
    background:
        radial-gradient(circle at 13% 8%, rgba(38, 194, 129, 0.20), transparent 24rem),
        radial-gradient(circle at 88% 0%, rgba(13, 110, 253, 0.16), transparent 25rem),
        radial-gradient(circle at 54% 92%, rgba(38, 194, 129, 0.08), transparent 27rem),
        linear-gradient(180deg, #010403 0%, #06110e 50%, #020403 100%);
    color: #f8fafc;
}

body.app-page.hotelcode-corporate-ui {
    background:
        radial-gradient(circle at top left, rgba(38, 194, 129, 0.10), transparent 26rem),
        radial-gradient(circle at top right, rgba(13, 110, 253, 0.08), transparent 28rem),
        linear-gradient(180deg, #f7fbf9 0%, #eef6f2 46%, #f8fafc 100%);
}

.hotelcode-corporate-ui .btn-primary {
    --bs-btn-color: #ffffff;
    --bs-btn-bg: #26c281;
    --bs-btn-border-color: #26c281;
    --bs-btn-hover-color: #ffffff;
    --bs-btn-hover-bg: #20a970;
    --bs-btn-hover-border-color: #20a970;
    --bs-btn-focus-shadow-rgb: 38, 194, 129;
    --bs-btn-active-color: #ffffff;
    --bs-btn-active-bg: #168a5a;
    --bs-btn-active-border-color: #168a5a;
    box-shadow: 0 0.85rem 1.9rem rgba(38, 194, 129, 0.20);
}

.hotelcode-corporate-ui .btn-outline-primary {
    --bs-btn-color: #22b879;
    --bs-btn-border-color: rgba(38, 194, 129, 0.55);
    --bs-btn-hover-color: #ffffff;
    --bs-btn-hover-bg: #26c281;
    --bs-btn-hover-border-color: #26c281;
    --bs-btn-focus-shadow-rgb: 38, 194, 129;
    --bs-btn-active-color: #ffffff;
    --bs-btn-active-bg: #168a5a;
    --bs-btn-active-border-color: #168a5a;
}

body.auth-page.hotelcode-corporate-ui .btn-outline-primary,
body.auth-page.hotelcode-corporate-ui .btn-outline-light {
    color: #f8fafc;
    border-color: rgba(248, 250, 252, 0.22);
    background: rgba(255, 255, 255, 0.03);
}

body.auth-page.hotelcode-corporate-ui .btn-outline-primary:hover,
body.auth-page.hotelcode-corporate-ui .btn-outline-light:hover {
    color: #03100b;
    background: #35d9ae;
    border-color: #35d9ae;
}

/* Public marketing shell */
body.auth-page.hotelcode-corporate-ui .auth-main {
    align-items: stretch;
    place-items: stretch;
    background: transparent;
}

body.auth-page.hotelcode-corporate-ui .auth-main .app-content {
    width: 100%;
    max-width: none;
    padding: clamp(0.75rem, 2vw, 1.25rem);
}

body.auth-page.hotelcode-corporate-ui .landing-shell.premium-landing {
    width: min(100%, 1480px);
    margin-inline: auto;
    gap: clamp(1rem, 2.4vw, 2rem);
}

body.auth-page.hotelcode-corporate-ui .brand-topbar {
    position: sticky;
    top: 0.75rem;
    z-index: 1020;
    margin-bottom: clamp(1rem, 2vw, 1.65rem);
    border-color: rgba(255, 255, 255, 0.11);
    background: rgba(2, 4, 3, 0.64);
    backdrop-filter: blur(20px);
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.26);
}

body.auth-page.hotelcode-corporate-ui .brand-lockup,
body.auth-page.hotelcode-corporate-ui .brand-lockup:hover,
body.auth-page.hotelcode-corporate-ui .brand-nav a {
    color: #f8fafc;
}

body.auth-page.hotelcode-corporate-ui .codebw-brand,
body.auth-page.hotelcode-corporate-ui .site-footer-lockup strong {
    color: #ffffff;
}

body.auth-page.hotelcode-corporate-ui .hotelcode-brand,
body.auth-page.hotelcode-corporate-ui .brand-nav a:not(.brand-nav-cta),
body.auth-page.hotelcode-corporate-ui .site-footer-lockup small {
    color: rgba(248, 250, 252, 0.68);
}

body.auth-page.hotelcode-corporate-ui .brand-nav a:not(.brand-nav-cta):hover {
    color: #ffffff;
}

body.auth-page.hotelcode-corporate-ui .brand-nav-primary {
    color: #03100b;
    border: 1px solid rgba(76, 224, 166, 0.38);
    background: linear-gradient(135deg, #35d9ae, #26c281);
    box-shadow: 0 0.95rem 2rem rgba(38, 194, 129, 0.25);
}

body.auth-page.hotelcode-corporate-ui .codebw-logo-image {
    background: transparent;
    box-shadow: none;
}

body.auth-page.hotelcode-corporate-ui .site-footer-logo,
.hotelcode-corporate-ui .brand-mark-image {
    background: transparent;
    box-shadow: none;
}

body.auth-page.hotelcode-corporate-ui .language-switcher {
    color: #f8fafc;
    border-color: rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.06);
}

body.auth-page.hotelcode-corporate-ui .language-switcher-select {
    color: #f8fafc;
}

body.auth-page.hotelcode-corporate-ui .language-switcher-select option {
    color: #0f172a;
}

body.auth-page.hotelcode-corporate-ui .saas-hero {
    min-height: clamp(35rem, 74vh, 47rem);
    border-color: rgba(91, 141, 255, 0.28);
    background:
        radial-gradient(circle at 14% 0%, rgba(78, 124, 255, 0.22), transparent 28rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.14), transparent 34rem),
        linear-gradient(135deg, rgba(7, 14, 18, 0.88), rgba(2, 6, 8, 0.78));
    box-shadow: 0 2rem 5rem rgba(0, 0, 0, 0.34);
}

body.auth-page.hotelcode-corporate-ui .saas-hero::after {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    pointer-events: none;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.09), transparent 28%),
        radial-gradient(circle at 72% 38%, rgba(38, 194, 129, 0.10), transparent 18rem);
}

body.auth-page.hotelcode-corporate-ui .saas-hero-bg {
    background: radial-gradient(circle, rgba(53, 217, 174, 0.20), transparent 68%);
}

body.auth-page.hotelcode-corporate-ui .corporate-hero-badge,
body.auth-page.hotelcode-corporate-ui .landing-kicker,
body.auth-page.hotelcode-corporate-ui .page-kicker {
    color: #4ce0a6;
}

body.auth-page.hotelcode-corporate-ui .saas-hero h1,
body.auth-page.hotelcode-corporate-ui .landing-section h2,
body.auth-page.hotelcode-corporate-ui .landing-policy h2,
body.auth-page.hotelcode-corporate-ui .legal-title,
body.auth-page.hotelcode-corporate-ui .auth-hero h1 {
    color: #ffffff;
}

body.auth-page.hotelcode-corporate-ui .saas-hero h1 {
    max-width: 62rem;
    font-size: clamp(2.6rem, 5vw, 5.4rem);
    letter-spacing: -0.07em;
    text-wrap: balance;
}

body.auth-page.hotelcode-corporate-ui .landing-lead,
body.auth-page.hotelcode-corporate-ui .landing-section-header p,
body.auth-page.hotelcode-corporate-ui .landing-policy p,
body.auth-page.hotelcode-corporate-ui .legal-lead,
body.auth-page.hotelcode-corporate-ui .auth-hero p,
body.auth-page.hotelcode-corporate-ui .helper-text {
    color: rgba(248, 250, 252, 0.68);
}

body.auth-page.hotelcode-corporate-ui .hero-proof-grid > div,
body.auth-page.hotelcode-corporate-ui .visual-module-card,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step,
body.auth-page.hotelcode-corporate-ui .impact-card,
body.auth-page.hotelcode-corporate-ui .pricing-card,
body.auth-page.hotelcode-corporate-ui .landing-section,
body.auth-page.hotelcode-corporate-ui .landing-policy,
body.auth-page.hotelcode-corporate-ui .dashboard-window,
body.auth-page.hotelcode-corporate-ui .showcase-panel,
body.auth-page.hotelcode-corporate-ui .auth-card.analytics-card,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card,
body.auth-page.hotelcode-corporate-ui .legal-summary-card,
body.auth-page.hotelcode-corporate-ui .site-footer {
    border-color: rgba(255, 255, 255, 0.105);
    background: rgba(255, 255, 255, 0.055);
    box-shadow: 0 1.25rem 3rem rgba(0, 0, 0, 0.22);
    backdrop-filter: blur(18px);
}

body.auth-page.hotelcode-corporate-ui .hero-proof-grid > div,
body.auth-page.hotelcode-corporate-ui .visual-module-card,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step,
body.auth-page.hotelcode-corporate-ui .impact-card,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card {
    background: rgba(2, 6, 8, 0.42);
}

body.auth-page.hotelcode-corporate-ui .dashboard-window {
    background:
        radial-gradient(circle at 10% 0%, rgba(78, 124, 255, 0.18), transparent 18rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.12), transparent 18rem),
        rgba(4, 10, 13, 0.72);
}

body.auth-page.hotelcode-corporate-ui .dashboard-window-top,
body.auth-page.hotelcode-corporate-ui .visual-insight,
body.auth-page.hotelcode-corporate-ui .mini-table > div {
    border-color: rgba(255, 255, 255, 0.10);
}

body.auth-page.hotelcode-corporate-ui .dash-card,
body.auth-page.hotelcode-corporate-ui .mini-table,
body.auth-page.hotelcode-corporate-ui .legal-content-card {
    border-color: rgba(255, 255, 255, 0.10);
    background: rgba(2, 6, 8, 0.42);
}

body.auth-page.hotelcode-corporate-ui .dash-card strong,
body.auth-page.hotelcode-corporate-ui .dash-card span,
body.auth-page.hotelcode-corporate-ui .visual-module-card strong,
body.auth-page.hotelcode-corporate-ui .impact-card strong,
body.auth-page.hotelcode-corporate-ui .pricing-name,
body.auth-page.hotelcode-corporate-ui .pricing-price,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step strong,
body.auth-page.hotelcode-corporate-ui .policy-list,
body.auth-page.hotelcode-corporate-ui .mini-table strong,
body.auth-page.hotelcode-corporate-ui .mini-table span,
body.auth-page.hotelcode-corporate-ui .legal-summary-card strong,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card strong {
    color: #f8fafc;
}

body.auth-page.hotelcode-corporate-ui .dash-card small,
body.auth-page.hotelcode-corporate-ui .visual-module-card span,
body.auth-page.hotelcode-corporate-ui .impact-card span,
body.auth-page.hotelcode-corporate-ui .pricing-note,
body.auth-page.hotelcode-corporate-ui .pricing-card li,
body.auth-page.hotelcode-corporate-ui .visual-insight span,
body.auth-page.hotelcode-corporate-ui .mini-table em,
body.auth-page.hotelcode-corporate-ui .legal-content p,
body.auth-page.hotelcode-corporate-ui .legal-summary-card span,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card span,
body.auth-page.hotelcode-corporate-ui .auth-trial-kicker {
    color: rgba(248, 250, 252, 0.64);
}

body.auth-page.hotelcode-corporate-ui .visual-module-card i,
body.auth-page.hotelcode-corporate-ui .impact-card i,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card i,
body.auth-page.hotelcode-corporate-ui .legal-summary-card i,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step i {
    color: #4ce0a6;
    background: rgba(76, 224, 166, 0.11);
    border: 1px solid rgba(76, 224, 166, 0.20);
}

body.auth-page.hotelcode-corporate-ui .pricing-card.featured {
    border-color: rgba(76, 224, 166, 0.42);
    background:
        radial-gradient(circle at 10% 0%, rgba(76, 224, 166, 0.12), transparent 17rem),
        rgba(255, 255, 255, 0.07);
    box-shadow: 0 1.7rem 4rem rgba(38, 194, 129, 0.14);
}

body.auth-page.hotelcode-corporate-ui .pricing-pill,
body.auth-page.hotelcode-corporate-ui .pricing-offer-banner {
    color: #052e21;
    background: linear-gradient(135deg, #7ee7c0, #35d9ae);
}

body.auth-page.hotelcode-corporate-ui .pricing-list-price {
    color: rgba(248, 250, 252, 0.46);
}

body.auth-page.hotelcode-corporate-ui .pricing-discount {
    color: #052e21;
    background: linear-gradient(135deg, #d8fff0, #8fffd8);
    border: 1px solid rgba(143, 255, 216, 0.42);
    box-shadow: 0 0.65rem 1.6rem rgba(53, 217, 174, 0.18);
    text-shadow: none;
}

body.auth-page.hotelcode-corporate-ui .comparison-showcase {
    border-color: rgba(91, 141, 255, 0.22);
    background:
        radial-gradient(circle at 0% 0%, rgba(78, 124, 255, 0.14), transparent 18rem),
        rgba(255, 255, 255, 0.052);
}

body.auth-page.hotelcode-corporate-ui .showcase-list div,
body.auth-page.hotelcode-corporate-ui .policy-list div {
    color: rgba(248, 250, 252, 0.72);
    background: rgba(255, 255, 255, 0.055);
    border-color: rgba(255, 255, 255, 0.10);
}

body.auth-page.hotelcode-corporate-ui .form-label {
    color: rgba(248, 250, 252, 0.78);
}

body.auth-page.hotelcode-corporate-ui .form-control,
body.auth-page.hotelcode-corporate-ui .form-select {
    color: #f8fafc;
    border-color: rgba(255, 255, 255, 0.13);
    background: rgba(255, 255, 255, 0.06);
}

body.auth-page.hotelcode-corporate-ui .form-control::placeholder {
    color: rgba(248, 250, 252, 0.38);
}

body.auth-page.hotelcode-corporate-ui .form-control:focus,
body.auth-page.hotelcode-corporate-ui .form-select:focus {
    border-color: rgba(76, 224, 166, 0.55);
    box-shadow: 0 0 0 0.2rem rgba(38, 194, 129, 0.14);
}

body.auth-page.hotelcode-corporate-ui .auth-card.analytics-card {
    max-width: 36rem;
    background:
        radial-gradient(circle at 14% 0%, rgba(78, 124, 255, 0.14), transparent 18rem),
        rgba(0, 0, 0, 0.42);
}

body.auth-page.hotelcode-corporate-ui.auth-register-page .auth-card.analytics-card {
    max-width: 50rem;
}

body.auth-page.hotelcode-corporate-ui .auth-trial-cta {
    border-color: rgba(76, 224, 166, 0.18);
    background: rgba(255, 255, 255, 0.055);
}

body.auth-page.hotelcode-corporate-ui .auth-trial-cta strong,
body.auth-page.hotelcode-corporate-ui .auth-trial-cta small {
    color: #f8fafc;
}

body.auth-page.hotelcode-corporate-ui .text-muted,
body.auth-page.hotelcode-corporate-ui .text-secondary {
    color: rgba(248, 250, 252, 0.62) !important;
}

body.auth-page.hotelcode-corporate-ui .toast-panel {
    color: #d9fff0;
    border-color: rgba(76, 224, 166, 0.20);
    background: rgba(76, 224, 166, 0.10);
}

body.auth-page.hotelcode-corporate-ui .site-footer {
    width: min(100%, 1480px);
    color: rgba(248, 250, 252, 0.68);
    background:
        radial-gradient(circle at 12% 0%, rgba(38, 194, 129, 0.12), transparent 22rem),
        rgba(255, 255, 255, 0.045);
}

body.auth-page.hotelcode-corporate-ui .site-footer-column h2,
body.auth-page.hotelcode-corporate-ui .site-footer-bottom,
body.auth-page.hotelcode-corporate-ui .app-footer {
    color: rgba(248, 250, 252, 0.72);
}

body.auth-page.hotelcode-corporate-ui .site-footer-column a,
body.auth-page.hotelcode-corporate-ui .site-footer-bottom a,
body.auth-page.hotelcode-corporate-ui .site-footer-social a,
body.auth-page.hotelcode-corporate-ui .app-footer a {
    color: rgba(248, 250, 252, 0.62);
}

body.auth-page.hotelcode-corporate-ui .site-footer-column a:hover,
body.auth-page.hotelcode-corporate-ui .site-footer-bottom a:hover,
body.auth-page.hotelcode-corporate-ui .site-footer-social a:hover,
body.auth-page.hotelcode-corporate-ui .app-footer a:hover {
    color: #ffffff;
}

/* Portal shell refinement */
body.app-page.hotelcode-corporate-ui .app-sidebar {
    background:
        radial-gradient(circle at top left, rgba(38, 194, 129, 0.20), transparent 18rem),
        radial-gradient(circle at bottom right, rgba(13, 110, 253, 0.13), transparent 16rem),
        linear-gradient(180deg, #020403, #07100d 58%, #020403);
    border-right: 1px solid rgba(255, 255, 255, 0.10);
    box-shadow: 1.5rem 0 4rem rgba(2, 4, 3, 0.18);
}

body.app-page.hotelcode-corporate-ui .app-brand-lockup {
    color: inherit;
}

body.app-page.hotelcode-corporate-ui .app-brand-lockup:hover,
body.app-page.hotelcode-corporate-ui .app-brand-lockup:focus-visible {
    color: inherit;
}

body.app-page.hotelcode-corporate-ui .sidebar-brand.app-brand-lockup {
    align-items: center;
    min-width: 0;
}

body.app-page.hotelcode-corporate-ui .sidebar-brand .app-brand-wordmark {
    display: grid;
    min-width: 0;
    line-height: 1.02;
}

body.app-page.hotelcode-corporate-ui .sidebar-brand .codebw-brand {
    color: #f8fafc;
    font-size: 0.72rem;
    font-weight: 950;
    letter-spacing: 0.13em;
    line-height: 1.15;
    text-transform: uppercase;
    white-space: nowrap;
}

body.app-page.hotelcode-corporate-ui .sidebar-brand .hotelcode-brand {
    margin-top: 0.12rem;
    font-size: 1.06rem;
    font-weight: 950;
    letter-spacing: -0.045em;
    text-transform: uppercase;
    white-space: nowrap;
}

body.app-page.hotelcode-corporate-ui .mobile-nav-title .app-brand-lockup-mobile {
    display: inline-flex;
    align-items: center;
    gap: 0.72rem;
    min-width: 0;
}

body.app-page.hotelcode-corporate-ui .mobile-nav-title .app-brand-wordmark {
    display: grid;
    min-width: 0;
    line-height: 1.02;
}

body.app-page.hotelcode-corporate-ui .mobile-nav-title .codebw-brand {
    color: #0f172a;
    font-size: 0.68rem;
    font-weight: 950;
    letter-spacing: 0.12em;
    line-height: 1.12;
    text-transform: uppercase;
    white-space: nowrap;
}

body.app-page.hotelcode-corporate-ui .mobile-nav-title .hotelcode-brand {
    margin-top: 0.08rem;
    font-size: 0.98rem;
    font-weight: 950;
    letter-spacing: -0.045em;
    text-transform: uppercase;
    white-space: nowrap;
}

.hotelcode-corporate-ui .sidebar-link:hover,
.hotelcode-corporate-ui .sidebar-link.active,
.hotelcode-corporate-ui .sidebar-sub-link:hover,
.hotelcode-corporate-ui .sidebar-sub-link.active {
    background: rgba(38, 194, 129, 0.12);
}

.hotelcode-corporate-ui .sidebar-link.active,
.hotelcode-corporate-ui .sidebar-sub-link.active {
    box-shadow: inset 0.2rem 0 0 #26c281;
}

body.app-page.hotelcode-corporate-ui .mobile-topbar {
    border-bottom: 1px solid rgba(38, 194, 129, 0.14);
    background: rgba(248, 250, 252, 0.82);
    backdrop-filter: blur(18px);
}

.hotelcode-corporate-ui .analytics-card,
.hotelcode-corporate-ui .tc-card,
.hotelcode-corporate-ui .kpi-card,
.hotelcode-corporate-ui .page-header,
.hotelcode-corporate-ui .toast-panel {
    border-color: rgba(15, 23, 42, 0.08);
    box-shadow: 0 1.15rem 2.75rem rgba(2, 4, 3, 0.08);
}

.hotelcode-corporate-ui .page-kicker,
.hotelcode-corporate-ui .kpi-label,
.hotelcode-corporate-ui .tc-stat-label {
    color: #168a5a;
}

.hotelcode-corporate-ui .status-success {
    color: #065f46;
    background: rgba(38, 194, 129, 0.14);
}

.hotelcode-corporate-ui .language-switcher:focus-within {
    border-color: rgba(38, 194, 129, 0.52);
    box-shadow: 0 0 0 0.2rem rgba(38, 194, 129, 0.12);
}

.hotelcode-corporate-ui .pwa-install-toast {
    border-color: rgba(38, 194, 129, 0.22);
    background:
        radial-gradient(circle at top left, rgba(38, 194, 129, 0.14), transparent 11rem),
        rgba(2, 4, 3, 0.92);
    color: #f8fafc;
}

/* Responsive marketing parity with SocialCode */
@media (max-width: 1199.98px) {
    body.auth-page.hotelcode-corporate-ui .saas-hero {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    body.auth-page.hotelcode-corporate-ui .saas-hero-visual {
        max-width: 48rem;
    }
}

@media (max-width: 991.98px) {
    body.auth-page.hotelcode-corporate-ui .brand-topbar {
        position: relative;
        top: 0;
    }

    body.auth-page.hotelcode-corporate-ui .brand-nav {
        width: 100%;
        justify-content: flex-start;
        overflow-x: auto;
        padding-bottom: 0.15rem;
        scrollbar-width: thin;
    }

    body.auth-page.hotelcode-corporate-ui .hero-proof-grid,
    body.auth-page.hotelcode-corporate-ui .visual-module-grid,
    body.auth-page.hotelcode-corporate-ui .pricing-grid,
    body.auth-page.hotelcode-corporate-ui .visual-workflow {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    body.auth-page.hotelcode-corporate-ui .landing-section-header {
        grid-template-columns: 1fr;
        align-items: start;
    }
}

@media (max-width: 575.98px) {
    body.auth-page.hotelcode-corporate-ui .auth-main .app-content {
        padding: 0.5rem;
    }

    body.auth-page.hotelcode-corporate-ui .landing-shell.premium-landing {
        gap: 0.85rem;
    }

    body.auth-page.hotelcode-corporate-ui .brand-topbar,
    body.auth-page.hotelcode-corporate-ui .saas-hero,
    body.auth-page.hotelcode-corporate-ui .landing-section,
    body.auth-page.hotelcode-corporate-ui .landing-policy,
    body.auth-page.hotelcode-corporate-ui .site-footer,
    body.auth-page.hotelcode-corporate-ui .auth-card.analytics-card {
        border-radius: 1.15rem;
    }

    body.auth-page.hotelcode-corporate-ui .saas-hero {
        padding: 1.1rem;
    }

    body.auth-page.hotelcode-corporate-ui .saas-hero h1 {
        font-size: clamp(2.15rem, 14vw, 3.2rem);
    }

    body.auth-page.hotelcode-corporate-ui .hero-proof-grid,
    body.auth-page.hotelcode-corporate-ui .visual-module-grid,
    body.auth-page.hotelcode-corporate-ui .pricing-grid,
    body.auth-page.hotelcode-corporate-ui .visual-workflow {
        grid-template-columns: 1fr;
    }

    body.auth-page.hotelcode-corporate-ui .site-footer {
        width: calc(100% - 1rem);
        margin-bottom: 0.75rem;
    }
}

body.rtl-page.auth-page.hotelcode-corporate-ui .brand-nav,
body.rtl-page.auth-page.hotelcode-corporate-ui .landing-actions,
body.rtl-page.auth-page.hotelcode-corporate-ui .hero-proof-grid,
body.rtl-page.auth-page.hotelcode-corporate-ui .visual-workflow {
    direction: rtl;
}



/* SocialCode product bridge */
.brand-nav-social {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
}

.suite-pipeline {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .75rem;
    margin-top: .9rem;
}

.suite-pipeline-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: .2rem .65rem;
    align-items: center;
    min-height: 5.35rem;
    padding: .95rem;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 1.05rem;
    color: var(--text);
    background: rgba(255, 255, 255, .72);
    box-shadow: 0 .85rem 2rem rgba(15, 23, 42, .06);
    transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.suite-pipeline-item:hover,
.suite-pipeline-item:focus-visible {
    color: var(--text);
    border-color: rgba(38, 194, 129, .34);
    transform: translateY(-.12rem);
    box-shadow: 0 1.1rem 2.6rem rgba(15, 23, 42, .10);
}

.suite-pipeline-item > span {
    grid-row: span 2;
    display: inline-grid;
    place-items: center;
    width: 2.55rem;
    height: 2.55rem;
    border-radius: .85rem;
    color: #ffffff;
    background: linear-gradient(135deg, #2563eb, #26c281);
    font-size: .82rem;
    font-weight: 950;
    letter-spacing: -.04em;
}

.suite-pipeline-item strong,
.suite-pipeline-item small {
    display: block;
    min-width: 0;
}

.suite-pipeline-item strong {
    font-size: .98rem;
    font-weight: 950;
}

.suite-pipeline-item small {
    color: var(--muted);
    font-size: .78rem;
    line-height: 1.35;
}

.suite-pipeline-item.social > span {
    background: linear-gradient(135deg, #4f46e5, #22c55e);
}

.socialcode-showcase {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(24rem, 1.1fr);
    gap: clamp(1.25rem, 3vw, 2.4rem);
    align-items: center;
    border-color: rgba(226, 232, 240, .92);
    background:
        radial-gradient(circle at 0% 0%, rgba(79, 70, 229, .12), transparent 22rem),
        radial-gradient(circle at 100% 100%, rgba(38, 194, 129, .12), transparent 24rem),
        rgba(255, 255, 255, .74);
}

.socialcode-showcase-copy h2 {
    max-width: 48rem;
    margin: 0;
    color: var(--text);
    font-size: clamp(2rem, 4vw, 3.45rem);
    font-weight: 950;
    letter-spacing: -.06em;
    line-height: 1;
    text-wrap: balance;
}

.socialcode-showcase-copy p {
    max-width: 43rem;
    margin: 1rem 0 0;
    color: var(--muted);
    font-size: 1.05rem;
    line-height: 1.72;
}

.socialcode-badge-row {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
    margin-top: 1.15rem;
}

.socialcode-badge-row span {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .55rem .75rem;
    border: 1px solid rgba(38, 194, 129, .18);
    border-radius: 999px;
    color: #0f5132;
    background: rgba(38, 194, 129, .10);
    font-size: .86rem;
    font-weight: 850;
}

.socialcode-platform-panel {
    position: relative;
    padding: 1rem;
    overflow: hidden;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 1.55rem;
    background:
        radial-gradient(circle at 0% 0%, rgba(79, 70, 229, .14), transparent 18rem),
        radial-gradient(circle at 100% 100%, rgba(38, 194, 129, .14), transparent 20rem),
        #ffffff;
    box-shadow: var(--shadow);
}

.socialcode-panel-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: .85rem;
    padding: .15rem .15rem .65rem;
}

.socialcode-panel-header strong,
.socialcode-panel-header span {
    display: block;
}

.socialcode-panel-header strong {
    color: var(--text);
    font-size: 1.35rem;
    font-weight: 950;
    letter-spacing: -.04em;
}

.socialcode-channel-grid {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: .75rem;
}

.socialcode-channel-card {
    min-height: 10rem;
    padding: 1rem;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 1.15rem;
    background: rgba(248, 250, 252, .88);
}

.socialcode-channel-card.primary {
    grid-row: span 2;
    background:
        radial-gradient(circle at 100% 0%, rgba(38, 194, 129, .16), transparent 12rem),
        rgba(248, 250, 252, .96);
}

.socialcode-channel-card i {
    display: inline-grid;
    place-items: center;
    width: 2.7rem;
    height: 2.7rem;
    margin-bottom: .8rem;
    border-radius: .95rem;
    color: #168a5a;
    background: rgba(38, 194, 129, .13);
    font-size: 1.2rem;
}

.socialcode-channel-card strong,
.socialcode-channel-card span {
    display: block;
}

.socialcode-channel-card strong {
    margin-bottom: .35rem;
    color: var(--text);
    font-weight: 950;
}

.socialcode-channel-card span {
    color: var(--muted);
    line-height: 1.55;
}

.socialcode-platform-rail {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    margin-top: .8rem;
}

.socialcode-platform-rail span {
    padding: .48rem .65rem;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 999px;
    color: #334155;
    background: rgba(255, 255, 255, .72);
    font-size: .82rem;
    font-weight: 850;
}

.sidebar-external-link .bi-box-arrow-up-right {
    width: auto;
    font-size: .9rem;
    opacity: .7;
}

body.auth-page.hotelcode-corporate-ui .brand-nav-social {
    color: #d9fff0 !important;
    border-color: rgba(76, 224, 166, .26);
    background: rgba(76, 224, 166, .08);
}

body.auth-page.hotelcode-corporate-ui .suite-pipeline-item,
body.auth-page.hotelcode-corporate-ui .socialcode-showcase,
body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card {
    border-color: rgba(255, 255, 255, .105);
    background: rgba(255, 255, 255, .055);
    box-shadow: 0 1.25rem 3rem rgba(0, 0, 0, .22);
    backdrop-filter: blur(18px);
}

body.auth-page.hotelcode-corporate-ui .socialcode-showcase {
    background:
        radial-gradient(circle at 0% 0%, rgba(78, 124, 255, .16), transparent 22rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, .12), transparent 24rem),
        rgba(255, 255, 255, .052);
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel {
    background:
        radial-gradient(circle at 0% 0%, rgba(78, 124, 255, .18), transparent 17rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, .13), transparent 18rem),
        rgba(4, 10, 13, .72);
}

body.auth-page.hotelcode-corporate-ui .socialcode-channel-card.primary {
    background:
        radial-gradient(circle at 100% 0%, rgba(76, 224, 166, .14), transparent 13rem),
        rgba(2, 6, 8, .42);
}

body.auth-page.hotelcode-corporate-ui .suite-pipeline-item:hover,
body.auth-page.hotelcode-corporate-ui .suite-pipeline-item:focus-visible {
    color: #ffffff;
    border-color: rgba(76, 224, 166, .34);
}

body.auth-page.hotelcode-corporate-ui .socialcode-showcase-copy h2,
body.auth-page.hotelcode-corporate-ui .socialcode-panel-header strong,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card strong,
body.auth-page.hotelcode-corporate-ui .suite-pipeline-item strong {
    color: #f8fafc;
}

body.auth-page.hotelcode-corporate-ui .socialcode-showcase-copy p,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card span,
body.auth-page.hotelcode-corporate-ui .suite-pipeline-item small {
    color: rgba(248, 250, 252, .64);
}

body.auth-page.hotelcode-corporate-ui .socialcode-badge-row span,
body.auth-page.hotelcode-corporate-ui .socialcode-platform-rail span {
    color: rgba(248, 250, 252, .76);
    border-color: rgba(255, 255, 255, .10);
    background: rgba(255, 255, 255, .055);
}

body.auth-page.hotelcode-corporate-ui .socialcode-channel-card i {
    color: #4ce0a6;
    border: 1px solid rgba(76, 224, 166, .20);
    background: rgba(76, 224, 166, .11);
}

@media (max-width: 1199.98px) {
    .socialcode-showcase {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .suite-pipeline,
    .socialcode-channel-grid {
        grid-template-columns: 1fr;
    }

    .socialcode-channel-card.primary {
        grid-row: auto;
    }
}

@media (max-width: 575.98px) {
    .socialcode-showcase-copy h2 {
        font-size: clamp(1.9rem, 10vw, 2.55rem);
        line-height: 1.08;
        letter-spacing: -.035em;
    }

    .socialcode-platform-panel {
        padding: .85rem;
        border-radius: 1.15rem;
    }

    .socialcode-panel-header {
        flex-direction: column;
    }
}

html[dir="rtl"] .suite-pipeline-item,
html[dir="rtl"] .socialcode-panel-header {
    direction: rtl;
}

html[dir="rtl"] .sidebar-external-link .ms-auto {
    margin-right: auto !important;
    margin-left: 0 !important;
}


/* Contrast, full-width containers and product overview refinement */
body.hotelcode-corporate-ui {
    --muted: #475569;
    --border: #d4dde8;
}

body.app-page.hotelcode-corporate-ui .app-content {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: clamp(0.75rem, 1.15vw, 1.25rem);
}

body.app-page.hotelcode-corporate-ui .page-shell {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 0;
}

body.auth-page.hotelcode-corporate-ui .auth-main .app-content {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: clamp(0.5rem, 1vw, 1rem);
}

body.auth-page.hotelcode-corporate-ui .landing-shell.premium-landing,
body.auth-page.hotelcode-corporate-ui .site-footer {
    width: 100%;
    max-width: none;
    margin-inline: 0;
}

body.auth-page.hotelcode-corporate-ui .brand-topbar,
body.auth-page.hotelcode-corporate-ui .saas-hero,
body.auth-page.hotelcode-corporate-ui .landing-section,
body.auth-page.hotelcode-corporate-ui .landing-policy,
body.auth-page.hotelcode-corporate-ui .hotelcode-overview-section {
    width: 100%;
}

body.auth-page.hotelcode-corporate-ui .brand-topbar {
    border-color: rgba(255, 255, 255, 0.18);
    background: rgba(2, 4, 3, 0.78);
}

body.auth-page.hotelcode-corporate-ui .brand-nav a:not(.brand-nav-cta),
body.auth-page.hotelcode-corporate-ui .hotelcode-brand,
body.auth-page.hotelcode-corporate-ui .site-footer-lockup small {
    color: rgba(248, 250, 252, 0.84);
}

body.auth-page.hotelcode-corporate-ui .landing-lead,
body.auth-page.hotelcode-corporate-ui .landing-section-header p,
body.auth-page.hotelcode-corporate-ui .landing-policy p,
body.auth-page.hotelcode-corporate-ui .legal-lead,
body.auth-page.hotelcode-corporate-ui .auth-hero p,
body.auth-page.hotelcode-corporate-ui .helper-text,
body.auth-page.hotelcode-corporate-ui .socialcode-showcase-copy p {
    color: rgba(248, 250, 252, 0.82);
}

body.auth-page.hotelcode-corporate-ui .dash-card small,
body.auth-page.hotelcode-corporate-ui .visual-module-card span,
body.auth-page.hotelcode-corporate-ui .impact-card span,
body.auth-page.hotelcode-corporate-ui .pricing-note,
body.auth-page.hotelcode-corporate-ui .pricing-card li,
body.auth-page.hotelcode-corporate-ui .visual-insight span,
body.auth-page.hotelcode-corporate-ui .mini-table em,
body.auth-page.hotelcode-corporate-ui .legal-content p,
body.auth-page.hotelcode-corporate-ui .legal-summary-card span,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card span,
body.auth-page.hotelcode-corporate-ui .auth-trial-kicker,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card span,
body.auth-page.hotelcode-corporate-ui .suite-pipeline-item small {
    color: rgba(248, 250, 252, 0.78);
}

body.auth-page.hotelcode-corporate-ui .hero-proof-grid > div,
body.auth-page.hotelcode-corporate-ui .visual-module-card,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step,
body.auth-page.hotelcode-corporate-ui .impact-card,
body.auth-page.hotelcode-corporate-ui .pricing-card,
body.auth-page.hotelcode-corporate-ui .landing-section,
body.auth-page.hotelcode-corporate-ui .landing-policy,
body.auth-page.hotelcode-corporate-ui .dashboard-window,
body.auth-page.hotelcode-corporate-ui .showcase-panel,
body.auth-page.hotelcode-corporate-ui .auth-card.analytics-card,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card,
body.auth-page.hotelcode-corporate-ui .legal-summary-card,
body.auth-page.hotelcode-corporate-ui .site-footer,
body.auth-page.hotelcode-corporate-ui .suite-pipeline-item,
body.auth-page.hotelcode-corporate-ui .socialcode-showcase,
body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card {
    border-color: rgba(255, 255, 255, 0.16);
}

body.auth-page.hotelcode-corporate-ui .hero-proof-grid > div,
body.auth-page.hotelcode-corporate-ui .visual-module-card,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step,
body.auth-page.hotelcode-corporate-ui .impact-card,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card {
    background: rgba(2, 6, 8, 0.56);
}

body.app-page.hotelcode-corporate-ui .analytics-card,
body.app-page.hotelcode-corporate-ui .tc-card,
body.app-page.hotelcode-corporate-ui .kpi-card,
body.app-page.hotelcode-corporate-ui .toast-panel {
    border-color: rgba(15, 23, 42, 0.13);
    background: rgba(255, 255, 255, 0.98);
}

body.app-page.hotelcode-corporate-ui .page-subtitle,
body.app-page.hotelcode-corporate-ui .helper-text,
body.app-page.hotelcode-corporate-ui .tc-helper-text,
body.app-page.hotelcode-corporate-ui .tc-section-copy,
body.app-page.hotelcode-corporate-ui .log-muted,
body.app-page.hotelcode-corporate-ui .text-muted {
    color: #475569 !important;
}

body.app-page.hotelcode-corporate-ui .form-control,
body.app-page.hotelcode-corporate-ui .form-select {
    border-color: #cbd5e1;
    color: #0f172a;
    background-color: #ffffff;
}

body.auth-page.hotelcode-corporate-ui .hotelcode-overview-section {
    position: relative;
    border-color: rgba(91, 141, 255, 0.28);
    background:
        radial-gradient(circle at 10% 0%, rgba(78, 124, 255, 0.18), transparent 24rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.14), transparent 26rem),
        rgba(255, 255, 255, 0.055);
    box-shadow: 0 1.55rem 3.5rem rgba(0, 0, 0, 0.24);
    backdrop-filter: blur(18px);
}

body.auth-page.hotelcode-corporate-ui .hotelcode-overview-copy h2 {
    color: #ffffff;
    text-wrap: balance;
}

body.auth-page.hotelcode-corporate-ui .hotelcode-overview-copy p {
    color: rgba(248, 250, 252, 0.82);
}

body.auth-page.hotelcode-corporate-ui .overview-proof-list span {
    color: rgba(248, 250, 252, 0.90);
}

body.auth-page.hotelcode-corporate-ui .overview-proof-list i {
    color: #4ce0a6;
}

body.auth-page.hotelcode-corporate-ui .overview-dashboard-shell {
    border-color: rgba(76, 224, 166, 0.24);
    background:
        radial-gradient(circle at 14% 0%, rgba(76, 224, 166, 0.22), transparent 18rem),
        radial-gradient(circle at 90% 30%, rgba(37, 99, 235, 0.18), transparent 20rem),
        linear-gradient(145deg, #010403, #08130f);
}




@media (min-width: 1600px) {
    body.app-page.hotelcode-corporate-ui .app-content {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }
}

@media (max-width: 575.98px) {
    body.auth-page.hotelcode-corporate-ui .auth-main .app-content,
    body.app-page.hotelcode-corporate-ui .app-content {
        padding: 0.5rem;
    }
}

/* Final contrast and brand lockup correction */
body.auth-page.hotelcode-corporate-ui .brand-topbar {
    min-height: 4.7rem;
    padding: 0.75rem 1rem;
    border-color: rgba(255, 255, 255, 0.24);
    background: rgba(0, 0, 0, 0.88);
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.38);
}

body.auth-page.hotelcode-corporate-ui .brand-lockup {
    gap: 0.9rem;
}

body.auth-page.hotelcode-corporate-ui {
    --hotelcode-logo-size: clamp(3.45rem, 3.4vw, 4.25rem);
    --hotelcode-logo-radius: 1.05rem;
}

body.auth-page.hotelcode-corporate-ui .codebw-logo-image {
    width: var(--hotelcode-logo-size);
    height: var(--hotelcode-logo-size);
    padding: var(--hotelcode-logo-padding);
    border-radius: var(--hotelcode-logo-radius);
    object-fit: contain;
    background: transparent;
    box-shadow: none;
}

body.auth-page.hotelcode-corporate-ui .codebw-brand {
    color: #ffffff;
    font-size: clamp(0.86rem, 0.84vw, 1rem);
    font-weight: 950;
    letter-spacing: 0.14em;
    line-height: 1.05;
    text-transform: none;
}

body.auth-page.hotelcode-corporate-ui .hotelcode-brand {
    margin-top: 0.28rem;
    color: #ffffff;
    font-size: clamp(1rem, 1.02vw, 1.18rem);
    font-weight: 950;
    line-height: 1.08;
}

body.auth-page.hotelcode-corporate-ui .brand-nav {
    gap: clamp(0.85rem, 1.05vw, 1.25rem);
    color: #ffffff;
    font-weight: 850;
}

body.auth-page.hotelcode-corporate-ui .brand-nav a:not(.brand-nav-cta) {
    color: rgba(255, 255, 255, 0.94);
}

body.auth-page.hotelcode-corporate-ui .brand-nav a:not(.brand-nav-cta):hover,
body.auth-page.hotelcode-corporate-ui .brand-nav a:not(.brand-nav-cta):focus-visible {
    color: #ffffff;
}

body.auth-page.hotelcode-corporate-ui .brand-nav-primary,
body.auth-page.hotelcode-corporate-ui .brand-nav a.brand-nav-primary {
    color: #03100b !important;
    border-color: rgba(126, 231, 192, 0.62);
    background: linear-gradient(135deg, #8fffd8, #35d9ae);
    font-weight: 950;
    box-shadow: 0 0.95rem 2rem rgba(38, 194, 129, 0.34);
}

body.auth-page.hotelcode-corporate-ui .brand-nav-primary:hover,
body.auth-page.hotelcode-corporate-ui .brand-nav-primary:focus-visible {
    color: #03100b !important;
    background: linear-gradient(135deg, #d8fff0, #7ee7c0);
}

body.auth-page.hotelcode-corporate-ui .corporate-hero-badge {
    color: #03100b;
    border-color: rgba(126, 231, 192, 0.72);
    background: linear-gradient(135deg, #d8fff0, #7ee7c0);
    box-shadow: 0 0.8rem 1.8rem rgba(38, 194, 129, 0.20);
}

body.auth-page.hotelcode-corporate-ui .landing-kicker,
body.auth-page.hotelcode-corporate-ui .page-kicker {
    color: #9fffe0;
}

body.auth-page.hotelcode-corporate-ui .landing-lead,
body.auth-page.hotelcode-corporate-ui .landing-section-header p,
body.auth-page.hotelcode-corporate-ui .landing-policy p,
body.auth-page.hotelcode-corporate-ui .legal-lead,
body.auth-page.hotelcode-corporate-ui .auth-hero p,
body.auth-page.hotelcode-corporate-ui .helper-text,
body.auth-page.hotelcode-corporate-ui .socialcode-showcase-copy p,
body.auth-page.hotelcode-corporate-ui .hotelcode-overview-copy p {
    color: rgba(255, 255, 255, 0.88);
}

body.auth-page.hotelcode-corporate-ui .dash-card small,
body.auth-page.hotelcode-corporate-ui .visual-module-card span,
body.auth-page.hotelcode-corporate-ui .impact-card span,
body.auth-page.hotelcode-corporate-ui .pricing-note,
body.auth-page.hotelcode-corporate-ui .pricing-card li,
body.auth-page.hotelcode-corporate-ui .visual-insight span,
body.auth-page.hotelcode-corporate-ui .mini-table em,
body.auth-page.hotelcode-corporate-ui .legal-content p,
body.auth-page.hotelcode-corporate-ui .legal-summary-card span,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card span,
body.auth-page.hotelcode-corporate-ui .auth-trial-kicker,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card span,
body.auth-page.hotelcode-corporate-ui .suite-pipeline-item small {
    color: rgba(255, 255, 255, 0.84);
}

body.auth-page.hotelcode-corporate-ui .language-switcher {
    color: #ffffff;
    border-color: rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.10);
}

body.auth-page.hotelcode-corporate-ui .language-switcher i {
    color: #8fffd8;
}

body.auth-page.hotelcode-corporate-ui .language-switcher-select {
    color: #ffffff;
    font-weight: 850;
}

body.auth-page.hotelcode-corporate-ui .saas-hero {
    border-color: rgba(126, 231, 192, 0.20);
    background:
        radial-gradient(circle at 12% 0%, rgba(78, 124, 255, 0.20), transparent 28rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.16), transparent 34rem),
        linear-gradient(135deg, rgba(6, 13, 17, 0.94), rgba(0, 3, 4, 0.90));
}

@media (max-width: 991.98px) {
    body.auth-page.hotelcode-corporate-ui .brand-topbar {
        min-height: 0;
    }

    body.auth-page.hotelcode-corporate-ui .brand-nav {
        gap: 0.72rem;
    }

    body.auth-page.hotelcode-corporate-ui .brand-nav a {
        white-space: nowrap;
    }
}

@media (max-width: 575.98px) {
    body.auth-page.hotelcode-corporate-ui {
        --hotelcode-logo-size: 3.2rem;
        --hotelcode-logo-radius: 1rem;
    }

    body.auth-page.hotelcode-corporate-ui .codebw-brand {
        font-size: 0.78rem;
        letter-spacing: 0.11em;
    }

    body.auth-page.hotelcode-corporate-ui .hotelcode-brand {
        font-size: 0.98rem;
    }
}



/* High contrast stabilization for the corporate dark theme */
body.auth-page.hotelcode-corporate-ui {
    color: #f8fafc;
    --muted: #d9e3ef;
}

body.auth-page.hotelcode-corporate-ui .brand-topbar,
body.auth-page.hotelcode-corporate-ui .site-footer,
body.auth-page.hotelcode-corporate-ui .saas-hero,
body.auth-page.hotelcode-corporate-ui .landing-section,
body.auth-page.hotelcode-corporate-ui .landing-policy,
body.auth-page.hotelcode-corporate-ui .hotelcode-overview-section {
    border-color: rgba(255, 255, 255, 0.24);
}

body.auth-page.hotelcode-corporate-ui .saas-hero,
body.auth-page.hotelcode-corporate-ui .landing-section,
body.auth-page.hotelcode-corporate-ui .landing-policy,
body.auth-page.hotelcode-corporate-ui .hotelcode-overview-section {
    background:
        radial-gradient(circle at 12% 0%, rgba(78, 124, 255, 0.18), transparent 28rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.14), transparent 34rem),
        linear-gradient(135deg, rgba(7, 13, 16, 0.96), rgba(1, 6, 8, 0.94));
}

body.auth-page.hotelcode-corporate-ui .site-footer {
    color: #e8eef6;
    background:
        radial-gradient(circle at 12% 0%, rgba(38, 194, 129, 0.18), transparent 22rem),
        linear-gradient(135deg, rgba(7, 13, 12, 0.98), rgba(12, 18, 17, 0.96));
}

body.auth-page.hotelcode-corporate-ui .site-footer-lockup strong,
body.auth-page.hotelcode-corporate-ui .site-footer-column h2,
body.auth-page.hotelcode-corporate-ui .site-footer strong {
    color: #ffffff;
}

body.auth-page.hotelcode-corporate-ui .site-footer-lockup small {
    color: #d7fff0;
}

body.auth-page.hotelcode-corporate-ui .site-footer-brand p,
body.auth-page.hotelcode-corporate-ui .site-footer-bottom,
body.auth-page.hotelcode-corporate-ui .site-footer-bottom span {
    color: #dbe6ef;
}

body.auth-page.hotelcode-corporate-ui .site-footer-column a,
body.auth-page.hotelcode-corporate-ui .site-footer-bottom a,
body.auth-page.hotelcode-corporate-ui .site-footer-social a {
    color: #f0f6fb;
}

body.auth-page.hotelcode-corporate-ui .site-footer-column a:hover,
body.auth-page.hotelcode-corporate-ui .site-footer-column a:focus-visible,
body.auth-page.hotelcode-corporate-ui .site-footer-bottom a:hover,
body.auth-page.hotelcode-corporate-ui .site-footer-bottom a:focus-visible,
body.auth-page.hotelcode-corporate-ui .site-footer-social a:hover,
body.auth-page.hotelcode-corporate-ui .site-footer-social a:focus-visible {
    color: #8fffd8;
}

body.auth-page.hotelcode-corporate-ui .site-footer-bottom {
    border-top-color: rgba(255, 255, 255, 0.36);
}

body.auth-page.hotelcode-corporate-ui .landing-hero h1,
body.auth-page.hotelcode-corporate-ui .landing-section h2,
body.auth-page.hotelcode-corporate-ui .landing-auth-copy h2,
body.auth-page.hotelcode-corporate-ui .saas-hero h1,
body.auth-page.hotelcode-corporate-ui .showcase-copy h2,
body.auth-page.hotelcode-corporate-ui .site-product-copy h2,
body.auth-page.hotelcode-corporate-ui .hotelcode-overview-copy h2,
body.auth-page.hotelcode-corporate-ui .socialcode-showcase-copy h2,
body.auth-page.hotelcode-corporate-ui .auth-hero h1,
body.auth-page.hotelcode-corporate-ui .legal-content h2,
body.auth-page.hotelcode-corporate-ui .legal-content h3 {
    color: #ffffff;
    text-shadow: 0 0.08rem 0.2rem rgba(0, 0, 0, 0.35);
}

body.auth-page.hotelcode-corporate-ui .landing-lead,
body.auth-page.hotelcode-corporate-ui .landing-section-header p,
body.auth-page.hotelcode-corporate-ui .landing-policy p,
body.auth-page.hotelcode-corporate-ui .legal-lead,
body.auth-page.hotelcode-corporate-ui .auth-hero p,
body.auth-page.hotelcode-corporate-ui .helper-text,
body.auth-page.hotelcode-corporate-ui .socialcode-showcase-copy p,
body.auth-page.hotelcode-corporate-ui .hotelcode-overview-copy p,
body.auth-page.hotelcode-corporate-ui .legal-content p,
body.auth-page.hotelcode-corporate-ui .pricing-note {
    color: #e4edf6;
}

body.auth-page.hotelcode-corporate-ui .hero-proof-grid > div,
body.auth-page.hotelcode-corporate-ui .dash-card,
body.auth-page.hotelcode-corporate-ui .visual-module-card,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step,
body.auth-page.hotelcode-corporate-ui .impact-card,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card,
body.auth-page.hotelcode-corporate-ui .legal-summary-card,
body.auth-page.hotelcode-corporate-ui .suite-pipeline-item,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card,
body.auth-page.hotelcode-corporate-ui .visual-insight,
body.auth-page.hotelcode-corporate-ui .mini-table,
body.auth-page.hotelcode-corporate-ui .legal-content-card,
body.auth-page.hotelcode-corporate-ui .pricing-card {
    color: #f8fafc;
    border-color: rgba(255, 255, 255, 0.24);
    background:
        linear-gradient(135deg, rgba(13, 24, 28, 0.92), rgba(3, 10, 12, 0.88));
    box-shadow: 0 1.1rem 2.6rem rgba(0, 0, 0, 0.28);
}

body.auth-page.hotelcode-corporate-ui .dashboard-window,
body.auth-page.hotelcode-corporate-ui .showcase-panel,
body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel,
body.auth-page.hotelcode-corporate-ui .auth-card.analytics-card {
    color: #f8fafc;
    border-color: rgba(255, 255, 255, 0.22);
    background:
        radial-gradient(circle at 10% 0%, rgba(78, 124, 255, 0.18), transparent 18rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.15), transparent 18rem),
        linear-gradient(145deg, rgba(9, 18, 22, 0.96), rgba(3, 8, 10, 0.94));
}

body.auth-page.hotelcode-corporate-ui .hero-proof-grid > div span,
body.auth-page.hotelcode-corporate-ui .dash-card span,
body.auth-page.hotelcode-corporate-ui .visual-kicker,
body.auth-page.hotelcode-corporate-ui .mini-table span,
body.auth-page.hotelcode-corporate-ui .dashboard-window-top span,
body.auth-page.hotelcode-corporate-ui .socialcode-panel-header span {
    color: #cfe8ff;
}

body.auth-page.hotelcode-corporate-ui .hero-proof-grid > div strong,
body.auth-page.hotelcode-corporate-ui .dash-card strong,
body.auth-page.hotelcode-corporate-ui .visual-module-card strong,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step strong,
body.auth-page.hotelcode-corporate-ui .impact-card strong,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card strong,
body.auth-page.hotelcode-corporate-ui .legal-summary-card strong,
body.auth-page.hotelcode-corporate-ui .suite-pipeline-item strong,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card strong,
body.auth-page.hotelcode-corporate-ui .pricing-name,
body.auth-page.hotelcode-corporate-ui .pricing-price,
body.auth-page.hotelcode-corporate-ui .dashboard-window-top strong,
body.auth-page.hotelcode-corporate-ui .mini-table strong {
    color: #ffffff;
}

body.auth-page.hotelcode-corporate-ui .hero-area-tags span {
    color: #f8fafc;
    background: rgba(143, 255, 216, 0.08);
    border-color: rgba(143, 255, 216, 0.22);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

body.auth-page.hotelcode-corporate-ui .hero-proof-grid > div small,
body.auth-page.hotelcode-corporate-ui .dash-card small,
body.auth-page.hotelcode-corporate-ui .visual-module-card span,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step span,
body.auth-page.hotelcode-corporate-ui .impact-card span,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card span,
body.auth-page.hotelcode-corporate-ui .legal-summary-card span,
body.auth-page.hotelcode-corporate-ui .suite-pipeline-item small,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card span,
body.auth-page.hotelcode-corporate-ui .visual-insight span,
body.auth-page.hotelcode-corporate-ui .mini-table em,
body.auth-page.hotelcode-corporate-ui .pricing-card li {
    color: #dbeafe;
}

body.auth-page.hotelcode-corporate-ui .landing-kicker,
body.auth-page.hotelcode-corporate-ui .page-kicker,
body.auth-page.hotelcode-corporate-ui .corporate-hero-badge,
body.auth-page.hotelcode-corporate-ui .visual-module-card i,
body.auth-page.hotelcode-corporate-ui .impact-card i,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card i,
body.auth-page.hotelcode-corporate-ui .legal-summary-card i,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step i,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card i {
    color: #8fffd8;
}

body.auth-page.hotelcode-corporate-ui .corporate-hero-badge {
    color: #04130d;
    background: linear-gradient(135deg, #d8fff0, #7ee7c0);
}

body.auth-page.hotelcode-corporate-ui .btn-outline-primary {
    color: #ffffff;
    border-color: rgba(143, 255, 216, 0.68);
    background: rgba(143, 255, 216, 0.08);
}

body.auth-page.hotelcode-corporate-ui .btn-outline-primary:hover,
body.auth-page.hotelcode-corporate-ui .btn-outline-primary:focus-visible {
    color: #03100b;
    border-color: #8fffd8;
    background: #8fffd8;
}

body.auth-page.hotelcode-corporate-ui .btn-primary {
    color: #03100b;
    border-color: rgba(143, 255, 216, 0.72);
    background: linear-gradient(135deg, #8fffd8, #35d9ae);
    font-weight: 950;
}

body.auth-page.hotelcode-corporate-ui .language-switcher,
body.auth-page.hotelcode-corporate-ui .brand-nav-social,
body.auth-page.hotelcode-corporate-ui .socialcode-badge-row span,
body.auth-page.hotelcode-corporate-ui .socialcode-platform-rail span,
body.auth-page.hotelcode-corporate-ui .overview-proof-list span {
    color: #f8fafc;
    border-color: rgba(255, 255, 255, 0.24);
    background: rgba(9, 18, 22, 0.76);
}

body.auth-page.hotelcode-corporate-ui .status-success,
body.auth-page.hotelcode-corporate-ui .overview-proof-list i {
    color: #05150f;
    background: #8fffd8;
}

body.auth-page.hotelcode-corporate-ui .text-muted,
body.auth-page.hotelcode-corporate-ui .small,
body.auth-page.hotelcode-corporate-ui small {
    color: #dbeafe;
}

body.auth-page.hotelcode-corporate-ui ::placeholder {
    color: #cbd5e1;
}


body.auth-page.hotelcode-corporate-ui .site-footer-social a {
    color: #03100b;
    border-color: rgba(143, 255, 216, 0.68);
    background: linear-gradient(135deg, #f3fff9, #b9ffe5);
}

body.auth-page.hotelcode-corporate-ui .site-footer-social a:hover,
body.auth-page.hotelcode-corporate-ui .site-footer-social a:focus-visible {
    color: #03100b;
    border-color: #8fffd8;
    background: #8fffd8;
}

body.auth-page.hotelcode-corporate-ui .site-footer-column,
body.auth-page.hotelcode-corporate-ui .site-footer-brand {
    color: #f8fafc;
}

body.auth-page.hotelcode-corporate-ui .showcase-copy p,
body.auth-page.hotelcode-corporate-ui .site-product-copy p,
body.auth-page.hotelcode-corporate-ui .comparison-showcase p,
body.auth-page.hotelcode-corporate-ui .premium-section p {
    color: #e4edf6;
}


/* SocialCode section: stronger contrast, cleaner showcase layout, and Turkish-safe brand text */
body.auth-page.hotelcode-corporate-ui .socialcode-showcase-upgraded {
    align-items: stretch;
    grid-template-columns: minmax(22rem, 0.78fr) minmax(0, 1.22fr);
    gap: clamp(1.25rem, 2.6vw, 2rem);
    padding: clamp(1.15rem, 2.4vw, 1.75rem);
    border-color: rgba(143, 255, 216, 0.28);
    background:
        radial-gradient(circle at 0% 0%, rgba(78, 124, 255, 0.22), transparent 22rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.18), transparent 24rem),
        linear-gradient(145deg, rgba(10, 20, 25, 0.96), rgba(3, 9, 12, 0.98));
    box-shadow: 0 1.5rem 4rem rgba(0, 0, 0, 0.34);
}

body.auth-page.hotelcode-corporate-ui .socialcode-showcase-upgraded .landing-kicker {
    color: #b9ffe5;
    text-shadow: 0 0.08rem 0.2rem rgba(0, 0, 0, 0.4);
}

body.auth-page.hotelcode-corporate-ui .socialcode-showcase-upgraded .socialcode-showcase-copy {
    display: flex;
    min-width: 0;
    flex-direction: column;
    justify-content: center;
}

body.auth-page.hotelcode-corporate-ui .socialcode-showcase-upgraded .socialcode-showcase-copy h2 {
    max-width: 48rem;
    color: #ffffff;
}

body.auth-page.hotelcode-corporate-ui .socialcode-showcase-upgraded .socialcode-showcase-copy p {
    max-width: 46rem;
    color: #eaf4ff;
    font-weight: 650;
}

.socialcode-latin-text {
    text-transform: none !important;
    unicode-bidi: isolate;
}

body.auth-page.hotelcode-corporate-ui .socialcode-latin-text {
    letter-spacing: 0.08em;
}

body.auth-page.hotelcode-corporate-ui .socialcode-value-list {
    display: grid;
    gap: 0.7rem;
    margin-top: 1.15rem;
}

body.auth-page.hotelcode-corporate-ui .socialcode-value-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.18rem 0.75rem;
    align-items: flex-start;
    padding: 0.85rem 0.95rem;
    border: 1px solid rgba(255, 255, 255, 0.20);
    border-radius: 1rem;
    background: linear-gradient(135deg, rgba(13, 26, 31, 0.94), rgba(4, 13, 16, 0.92));
    box-shadow: 0 0.85rem 2rem rgba(0, 0, 0, 0.20);
}

body.auth-page.hotelcode-corporate-ui .socialcode-value-card i {
    grid-row: span 2;
    display: inline-grid;
    place-items: center;
    width: 2.25rem;
    height: 2.25rem;
    border: 1px solid rgba(143, 255, 216, 0.30);
    border-radius: 0.8rem;
    color: #8fffd8;
    background: rgba(143, 255, 216, 0.10);
}

body.auth-page.hotelcode-corporate-ui .socialcode-value-card strong {
    color: #ffffff;
    font-weight: 950;
    line-height: 1.2;
}

body.auth-page.hotelcode-corporate-ui .socialcode-value-card span {
    color: #dbeafe;
    line-height: 1.48;
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel-upgraded {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 0.85rem;
    padding: clamp(0.9rem, 1.8vw, 1.15rem);
    border-color: rgba(143, 255, 216, 0.26);
    background:
        radial-gradient(circle at 8% 0%, rgba(78, 124, 255, 0.22), transparent 18rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.18), transparent 20rem),
        linear-gradient(145deg, rgba(7, 17, 22, 0.98), rgba(1, 8, 10, 0.98));
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel-upgraded .socialcode-panel-header {
    margin-bottom: 0;
    padding: 0.25rem 0.25rem 0.4rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.14);
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel-upgraded .visual-kicker {
    color: #c8f7ff;
    font-weight: 950;
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel-upgraded .socialcode-panel-header strong {
    color: #ffffff;
    font-size: clamp(1.4rem, 1.7vw, 1.85rem);
    line-height: 1.05;
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel-upgraded .status-success {
    color: #04130d;
    border: 1px solid rgba(143, 255, 216, 0.72);
    background: linear-gradient(135deg, #effff8, #8fffd8);
    box-shadow: 0 0.75rem 1.6rem rgba(53, 217, 174, 0.18);
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.65rem;
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-metrics div {
    padding: 0.85rem;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 1rem;
    background: linear-gradient(135deg, rgba(13, 28, 33, 0.94), rgba(3, 12, 14, 0.92));
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-metrics strong,
body.auth-page.hotelcode-corporate-ui .socialcode-platform-metrics span {
    display: block;
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-metrics strong {
    color: #8fffd8;
    font-size: clamp(1.35rem, 2vw, 1.75rem);
    font-weight: 950;
    letter-spacing: -0.04em;
    line-height: 1;
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-metrics span {
    margin-top: 0.28rem;
    color: #e5f2ff;
    font-size: 0.86rem;
    font-weight: 850;
    line-height: 1.3;
}

.socialcode-channel-grid-upgraded {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
    gap: 0.75rem;
}

.socialcode-channel-grid-upgraded .socialcode-channel-card.primary {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) minmax(12rem, 0.72fr);
    grid-column: 1 / -1;
    grid-row: auto;
    gap: 0.35rem 0.9rem;
    align-items: start;
    min-height: auto;
}

.socialcode-channel-grid-upgraded .socialcode-channel-card.primary > i {
    grid-row: span 2;
}

body.auth-page.hotelcode-corporate-ui .socialcode-channel-grid-upgraded .socialcode-channel-card {
    min-height: 12.2rem;
    padding: 1rem;
    border-color: rgba(255, 255, 255, 0.22);
    background:
        radial-gradient(circle at 100% 0%, rgba(143, 255, 216, 0.12), transparent 11rem),
        linear-gradient(145deg, rgba(13, 26, 31, 0.96), rgba(3, 11, 13, 0.94));
}

body.auth-page.hotelcode-corporate-ui .socialcode-channel-grid-upgraded .socialcode-channel-card.primary {
    min-height: 0;
    border-color: rgba(143, 255, 216, 0.30);
    background:
        radial-gradient(circle at 0% 0%, rgba(78, 124, 255, 0.18), transparent 16rem),
        radial-gradient(circle at 100% 100%, rgba(143, 255, 216, 0.14), transparent 18rem),
        linear-gradient(145deg, rgba(13, 31, 36, 0.98), rgba(3, 12, 14, 0.98));
}

body.auth-page.hotelcode-corporate-ui .socialcode-channel-grid-upgraded .socialcode-channel-card i {
    color: #8fffd8;
    border-color: rgba(143, 255, 216, 0.32);
    background: rgba(143, 255, 216, 0.12);
}

body.auth-page.hotelcode-corporate-ui .socialcode-channel-grid-upgraded .socialcode-channel-card strong {
    color: #ffffff;
    font-size: 1.02rem;
}

body.auth-page.hotelcode-corporate-ui .socialcode-channel-grid-upgraded .socialcode-channel-card span {
    color: #e4f0ff;
    font-weight: 600;
}

body.auth-page.hotelcode-corporate-ui .socialcode-feature-points {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    align-content: flex-start;
    justify-content: flex-end;
}

body.auth-page.hotelcode-corporate-ui .socialcode-feature-points span {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.42rem 0.62rem;
    border: 1px solid rgba(143, 255, 216, 0.24);
    border-radius: 999px;
    color: #f6fffb;
    background: rgba(143, 255, 216, 0.08);
    font-size: 0.8rem;
    font-weight: 900;
    line-height: 1;
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel-upgraded .socialcode-platform-rail {
    margin-top: 0;
}

body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel-upgraded .socialcode-platform-rail span,
body.auth-page.hotelcode-corporate-ui .socialcode-showcase-upgraded .socialcode-badge-row span {
    color: #ffffff;
    border-color: rgba(143, 255, 216, 0.30);
    background: rgba(13, 28, 33, 0.94);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}

body.auth-page.hotelcode-corporate-ui .site-footer-lockup strong {
    text-transform: none;
}

@media (max-width: 1199.98px) {
    body.auth-page.hotelcode-corporate-ui .socialcode-showcase-upgraded {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    body.auth-page.hotelcode-corporate-ui .socialcode-platform-metrics,
    .socialcode-channel-grid-upgraded {
        grid-template-columns: 1fr;
    }

    .socialcode-channel-grid-upgraded .socialcode-channel-card.primary {
        grid-template-columns: auto minmax(0, 1fr);
    }

    body.auth-page.hotelcode-corporate-ui .socialcode-feature-points {
        grid-column: 1 / -1;
        justify-content: flex-start;
    }
}

@media (max-width: 575.98px) {
    body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel-upgraded .socialcode-panel-header {
        align-items: flex-start;
    }

    body.auth-page.hotelcode-corporate-ui .socialcode-platform-metrics {
        gap: 0.5rem;
    }

    body.auth-page.hotelcode-corporate-ui .socialcode-value-card {
        grid-template-columns: 1fr;
    }

    body.auth-page.hotelcode-corporate-ui .socialcode-value-card i {
        grid-row: auto;
    }
}

/* WhatsApp widget keeps the original light-card look on every theme. */
body .whatsapp-widget .whatsapp-menu {
    color: #0f172a !important;
}

body .whatsapp-widget .whatsapp-option,
body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-option {
    color: #0f172a !important;
    background: rgba(255, 255, 255, 0.96) !important;
    border-color: rgba(148, 163, 184, 0.35) !important;
    box-shadow: 0 0.75rem 2rem rgba(15, 23, 42, 0.14) !important;
}

body .whatsapp-widget .whatsapp-option:hover,
body .whatsapp-widget .whatsapp-option:focus-visible,
body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-option:hover,
body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-option:focus-visible {
    color: #0f172a !important;
    background: rgba(255, 255, 255, 0.98) !important;
    border-color: rgba(37, 211, 102, 0.7) !important;
}

body .whatsapp-widget .whatsapp-option strong,
body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-option strong {
    color: #0f172a !important;
    font-weight: 800 !important;
    text-shadow: none !important;
}

body .whatsapp-widget .whatsapp-option small,
body .whatsapp-widget .whatsapp-option span small,
body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-option small,
body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-option span small {
    color: #64748b !important;
    opacity: 1 !important;
    font-weight: 500 !important;
    text-shadow: none !important;
}

body .whatsapp-widget .whatsapp-option i,
body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-option i {
    color: #ffffff !important;
    background: #25d366 !important;
    box-shadow: none !important;
}

@media (max-width: 575.98px) {
    body .whatsapp-widget .whatsapp-menu,
    body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-menu {
        background: rgba(255, 255, 255, 0.98) !important;
        color: #0f172a !important;
    }

    body .whatsapp-widget .whatsapp-menu-header strong,
    body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-menu-header strong {
        color: #0f172a !important;
    }

    body .whatsapp-widget .whatsapp-menu-header small,
    body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-menu-header small {
        color: #64748b !important;
    }
}



/* Admin language settings */
.admin-language-card .alert {
    color: #0f172a;
    background: #e0f2fe;
    border-color: rgba(14, 165, 233, 0.35);
}

.admin-language-select-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.85rem;
    align-items: center;
}

.admin-language-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(13.5rem, 1fr));
    gap: 0.75rem;
}

.admin-language-option {
    margin: 0;
}

.admin-language-button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
    width: 100%;
    min-height: 4.5rem;
    padding: 0.95rem 1rem;
    color: #0f172a;
    text-align: start;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.12);
    border-radius: 1rem;
    box-shadow: 0 0.85rem 1.8rem rgba(15, 23, 42, 0.08);
    transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.admin-language-button:hover,
.admin-language-button:focus-visible {
    border-color: rgba(38, 194, 129, 0.55);
    box-shadow: 0 1rem 2rem rgba(15, 23, 42, 0.12);
    transform: translateY(-0.08rem);
}

.admin-language-button.active {
    border-color: rgba(38, 194, 129, 0.75);
    background:
        radial-gradient(circle at top right, rgba(38, 194, 129, 0.16), transparent 8rem),
        #ffffff;
}

.admin-language-button strong,
.admin-language-button small {
    display: block;
}

.admin-language-button strong {
    color: #0f172a;
    font-size: 1rem;
    font-weight: 850;
}

.admin-language-button small {
    color: #475569;
    font-weight: 650;
}

.admin-language-button > i {
    color: #168a5a;
    font-size: 1.35rem;
}

.mobile-nav-language-switcher .language-switcher {
    width: 100%;
}

.mobile-nav-language-switcher .language-switcher-select option,
.sidebar-language-switcher .language-switcher-select option {
    color: #0f172a;
}

@media (max-width: 575.98px) {
    .admin-language-select-row {
        grid-template-columns: 1fr;
    }

    .admin-language-select-row .btn {
        width: 100%;
    }
}


.auth-back-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    padding: 0.8rem 1.15rem;
    min-width: 11rem;
    color: #d8fff0;
    background: rgba(143, 255, 216, 0.08);
    border: 1px solid rgba(143, 255, 216, 0.28);
    border-radius: 999px;
    font-size: 0.98rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    text-decoration: none;
    box-shadow: 0 0.9rem 2rem rgba(0, 0, 0, 0.18);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.auth-back-link i {
    font-size: 1rem;
    line-height: 1;
}

.auth-back-link:hover,
.auth-back-link:focus-visible {
    color: #03100b;
    background: linear-gradient(135deg, #d8fff0, #7ee7c0);
    border-color: rgba(143, 255, 216, 0.9);
    box-shadow: 0 1rem 2.25rem rgba(38, 208, 157, 0.24);
    transform: translateY(-0.08rem);
    text-decoration: none;
}

.auth-back-link:focus-visible {
    outline: 0;
}

@media (max-width: 575.98px) {
    .auth-back-link {
        width: 100%;
        min-width: 0;
    }
}

/* Footer social links: compact professional icon-only buttons */
.site-footer-social {
    align-items: center;
    gap: 0.5rem;
}

.site-footer-social a {
    justify-content: center;
    width: 2.55rem;
    height: 2.55rem;
    min-width: 2.55rem;
    min-height: 2.55rem;
    padding: 0;
    gap: 0;
    color: #1e293b;
    background: rgba(255, 255, 255, 0.88);
    border-color: rgba(148, 163, 184, 0.42);
    box-shadow: 0 0.55rem 1.3rem rgba(15, 23, 42, 0.08);
}

.site-footer-social a i {
    font-size: 1.08rem;
    line-height: 1;
}

.site-footer-social a:hover,
.site-footer-social a:focus-visible {
    color: #03100b;
    background: #8fffd8;
    border-color: #8fffd8;
    box-shadow: 0 0.7rem 1.55rem rgba(38, 208, 157, 0.18);
}

body.auth-page.hotelcode-corporate-ui .site-footer-social a {
    color: #d8fff0;
    background: rgba(255, 255, 255, 0.07);
    border-color: rgba(143, 255, 216, 0.34);
    box-shadow: none;
}

body.auth-page.hotelcode-corporate-ui .site-footer-social a:hover,
body.auth-page.hotelcode-corporate-ui .site-footer-social a:focus-visible {
    color: #03100b;
    background: #8fffd8;
    border-color: #8fffd8;
    box-shadow: 0 0.7rem 1.55rem rgba(143, 255, 216, 0.16);
}

@media (max-width: 575.98px) {
    .site-footer-social {
        width: auto;
        justify-content: flex-start;
    }

    .site-footer-social a {
        width: 2.55rem;
        height: 2.55rem;
        min-width: 2.55rem;
    }
}


.socialcode-tag-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    align-items: center;
}

.socialcode-tag-row span {
    display: inline-flex;
    align-items: center;
    gap: 0.38rem;
    padding: 0.36rem 0.62rem;
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 999px;
    color: var(--text);
    background: rgba(15, 23, 42, 0.07);
    font-size: 0.78rem;
    font-weight: 850;
    line-height: 1.1;
    letter-spacing: -0.01em;
    white-space: nowrap;
}

.socialcode-tag-row span i,
.socialcode-channel-card .socialcode-tag-row span i {
    display: inline-flex;
    place-items: initial;
    width: auto;
    height: auto;
    margin: 0;
    color: #168a5a;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    flex: 0 0 auto;
    font-size: 0.9rem;
    line-height: 1;
}

.socialcode-badge-row.socialcode-tag-row {
    margin-top: 1.15rem;
}

.socialcode-feature-points.socialcode-tag-row {
    margin-top: 0.9rem;
    justify-content: flex-start;
}

.socialcode-platform-rail.socialcode-tag-row {
    margin-top: 0.9rem;
}

body.auth-page.hotelcode-corporate-ui .socialcode-tag-row span,
body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel-upgraded .socialcode-platform-rail.socialcode-tag-row span,
body.auth-page.hotelcode-corporate-ui .socialcode-showcase-upgraded .socialcode-badge-row.socialcode-tag-row span,
body.auth-page.hotelcode-corporate-ui .socialcode-feature-points.socialcode-tag-row span {
    color: #f8fafc;
    background: rgba(143, 255, 216, 0.08);
    border-color: rgba(143, 255, 216, 0.24);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}

body.auth-page.hotelcode-corporate-ui .socialcode-tag-row span i,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card .socialcode-tag-row span i {
    color: #8fffd8;
    background: transparent;
    border: 0;
    box-shadow: none;
}

@media (max-width: 575.98px) {
    .socialcode-tag-row span {
        white-space: normal;
    }
}


body.auth-page.hotelcode-corporate-ui .status-badge.status-success {
    color: #000000;
    background: linear-gradient(135deg, #d8fff0, #8fffd8);
    border: 1px solid rgba(143, 255, 216, 0.42);
    box-shadow: 0 0.65rem 1.6rem rgba(53, 217, 174, 0.18);
    text-shadow: none;
}


/* Design tokens and contrast guardrails */
:root {
    --cbw-dark-950: #020706;
    --cbw-dark-900: #06100f;
    --cbw-dark-850: #0a1715;
    --cbw-surface-dark: rgba(8, 18, 20, 0.96);
    --cbw-surface-dark-soft: rgba(12, 26, 29, 0.92);
    --cbw-border-dark: rgba(226, 232, 240, 0.28);
    --cbw-text-dark: #f8fafc;
    --cbw-text-dark-muted: #dbeafe;
    --cbw-text-dark-soft: #cfe8ff;
    --cbw-accent: #35d9ae;
    --cbw-accent-strong: #26c281;
    --cbw-accent-soft: #d8fff0;
    --cbw-focus-ring: rgba(143, 255, 216, 0.38);
    --cbw-card-shadow: 0 1.15rem 2.75rem rgba(0, 0, 0, 0.32);
}

body.auth-page.hotelcode-corporate-ui {
    color: var(--cbw-text-dark);
    background:
        radial-gradient(circle at 12% 0%, rgba(78, 124, 255, 0.14), transparent 26rem),
        radial-gradient(circle at 100% 18%, rgba(53, 217, 174, 0.16), transparent 24rem),
        linear-gradient(180deg, var(--cbw-dark-950), #010403 64%, var(--cbw-dark-950));
}

body.auth-page.hotelcode-corporate-ui .premium-topbar,
body.auth-page.hotelcode-corporate-ui .premium-hero-card,
body.auth-page.hotelcode-corporate-ui .dashboard-window,
body.auth-page.hotelcode-corporate-ui .showcase-panel,
body.auth-page.hotelcode-corporate-ui .socialcode-platform-panel,
body.auth-page.hotelcode-corporate-ui .auth-card.analytics-card,
body.auth-page.hotelcode-corporate-ui .legal-content-card,
body.auth-page.hotelcode-corporate-ui .pricing-card,
body.auth-page.hotelcode-corporate-ui .tc-card {
    color: var(--cbw-text-dark);
    border-color: var(--cbw-border-dark);
    background:
        radial-gradient(circle at 0% 0%, rgba(78, 124, 255, 0.12), transparent 18rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.12), transparent 18rem),
        linear-gradient(145deg, var(--cbw-surface-dark), rgba(2, 8, 9, 0.95));
    box-shadow: var(--cbw-card-shadow);
}

body.auth-page.hotelcode-corporate-ui .landing-lead,
body.auth-page.hotelcode-corporate-ui .landing-section-header p,
body.auth-page.hotelcode-corporate-ui .landing-policy p,
body.auth-page.hotelcode-corporate-ui .legal-lead,
body.auth-page.hotelcode-corporate-ui .auth-hero p,
body.auth-page.hotelcode-corporate-ui .helper-text,
body.auth-page.hotelcode-corporate-ui .socialcode-showcase-copy p,
body.auth-page.hotelcode-corporate-ui .hotelcode-overview-copy p,
body.auth-page.hotelcode-corporate-ui .legal-content p,
body.auth-page.hotelcode-corporate-ui .pricing-note,
body.auth-page.hotelcode-corporate-ui .tc-card-body,
body.auth-page.hotelcode-corporate-ui .tc-card-body p {
    color: var(--cbw-text-dark-muted);
}

body.auth-page.hotelcode-corporate-ui .hero-proof-grid > div,
body.auth-page.hotelcode-corporate-ui .dash-card,
body.auth-page.hotelcode-corporate-ui .visual-module-card,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step,
body.auth-page.hotelcode-corporate-ui .impact-card,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card,
body.auth-page.hotelcode-corporate-ui .legal-summary-card,
body.auth-page.hotelcode-corporate-ui .suite-pipeline-item,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card,
body.auth-page.hotelcode-corporate-ui .visual-insight,
body.auth-page.hotelcode-corporate-ui .mini-table {
    color: var(--cbw-text-dark);
    border-color: var(--cbw-border-dark);
    background:
        linear-gradient(135deg, rgba(13, 24, 28, 0.95), rgba(3, 10, 12, 0.92));
}

body.auth-page.hotelcode-corporate-ui .hero-proof-grid > div span,
body.auth-page.hotelcode-corporate-ui .hero-proof-grid > div small,
body.auth-page.hotelcode-corporate-ui .dash-card span,
body.auth-page.hotelcode-corporate-ui .visual-module-card span,
body.auth-page.hotelcode-corporate-ui .visual-workflow-step span,
body.auth-page.hotelcode-corporate-ui .impact-card span,
body.auth-page.hotelcode-corporate-ui .demo-benefit-card span,
body.auth-page.hotelcode-corporate-ui .legal-summary-card span,
body.auth-page.hotelcode-corporate-ui .suite-pipeline-item small,
body.auth-page.hotelcode-corporate-ui .socialcode-channel-card span,
body.auth-page.hotelcode-corporate-ui .visual-insight span,
body.auth-page.hotelcode-corporate-ui .mini-table em {
    color: var(--cbw-text-dark-muted);
}

body.auth-page.hotelcode-corporate-ui .btn-primary,
body.auth-page.hotelcode-corporate-ui .brand-nav-primary,
body.auth-page.hotelcode-corporate-ui .auth-submit-button {
    color: #03100b;
    background: linear-gradient(135deg, #9ff7d6, #35d9ae);
    border-color: rgba(143, 255, 216, 0.64);
    box-shadow: 0 1rem 2.2rem rgba(38, 194, 129, 0.22);
    text-shadow: none;
}

body.auth-page.hotelcode-corporate-ui .btn-primary:hover,
body.auth-page.hotelcode-corporate-ui .btn-primary:focus-visible,
body.auth-page.hotelcode-corporate-ui .brand-nav-primary:hover,
body.auth-page.hotelcode-corporate-ui .brand-nav-primary:focus-visible {
    color: #03100b;
    background: linear-gradient(135deg, #d8fff0, #7ee7c0);
    border-color: rgba(216, 255, 240, 0.82);
}

body.auth-page.hotelcode-corporate-ui :focus-visible {
    outline: 3px solid var(--cbw-focus-ring);
    outline-offset: 2px;
}

/* Keep third-party/contact widgets intentionally light and readable. */
body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-option {
    color: #0f172a !important;
    background: rgba(255, 255, 255, 0.98) !important;
}

body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-option strong {
    color: #0f172a !important;
}

body.auth-page.hotelcode-corporate-ui .whatsapp-widget .whatsapp-option small {
    color: #64748b !important;
}

/* Admin translation health */
.translation-health-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.translation-health-summary-card,
.translation-health-language-card {
    padding: 1rem;
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 1.2rem;
    background: #ffffff;
    box-shadow: 0 0.85rem 1.9rem rgba(15, 23, 42, 0.06);
}

.translation-health-summary-card span,
.translation-health-summary-card small,
.translation-health-language-card small {
    display: block;
    color: #64748b;
    font-size: 0.82rem;
    font-weight: 700;
}

.translation-health-summary-card strong {
    display: block;
    margin: 0.25rem 0 0.5rem;
    color: #0f172a;
    font-size: clamp(1.35rem, 2vw, 2rem);
    font-weight: 950;
    letter-spacing: -0.04em;
}

.translation-health-language-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
    gap: 0.85rem;
}

.translation-health-language-card {
    display: grid;
    gap: 0.75rem;
}

.translation-health-language-card strong {
    display: block;
    color: #0f172a;
    font-size: 1rem;
    font-weight: 900;
}

.translation-health-meter {
    position: relative;
    height: 0.65rem;
    overflow: hidden;
    border-radius: 999px;
    background: #e2e8f0;
}

.translation-health-meter span {
    position: absolute;
    inset: 0 auto 0 0;
    min-width: 0.2rem;
    border-radius: inherit;
    background: linear-gradient(90deg, #35d9ae, #26c281);
}

.translation-health-language-stats {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.translation-health-card {
    margin-top: 1rem;
}

.translation-health-table-wrap {
    max-height: 38rem;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 1rem;
}

.translation-health-table {
    margin-bottom: 0;
}

.translation-health-table thead th {
    position: sticky;
    top: 0;
    z-index: 2;
    color: #334155;
    background: #f8fafc;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.translation-health-table td {
    vertical-align: top;
}

.translation-health-table td small,
.translation-health-table td strong,
.translation-health-value {
    display: block;
}

.translation-health-table code {
    color: #0f172a;
    background: #f1f5f9;
    border-radius: 0.45rem;
    padding: 0.2rem 0.35rem;
    white-space: nowrap;
}

.translation-health-language-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.2rem;
    margin-bottom: 0.25rem;
    padding: 0.18rem 0.4rem;
    color: #03100b;
    background: #d8fff0;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 900;
    text-transform: uppercase;
}

.translation-health-value {
    max-width: 22rem;
    color: #334155;
    font-size: 0.85rem;
    line-height: 1.45;
}

@media (max-width: 991.98px) {
    .translation-health-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .translation-health-summary-grid {
        grid-template-columns: 1fr;
    }

    .translation-health-table-wrap {
        max-height: none;
    }
}

/* Operational proxy dashboard */
.proxy-ops-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.proxy-ops-card {
    display: flex;
    align-items: flex-start;
    gap: 0.9rem;
    min-width: 0;
    padding: 1rem;
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 1.15rem;
    background: #ffffff;
    box-shadow: 0 0.85rem 2rem rgba(15, 23, 42, 0.06);
}

.proxy-ops-card.is-on {
    border-color: rgba(22, 163, 74, 0.22);
    background: linear-gradient(135deg, rgba(220, 252, 231, 0.78), rgba(255, 255, 255, 0.95));
}

.proxy-ops-card.is-off {
    border-color: rgba(148, 163, 184, 0.24);
    background: linear-gradient(135deg, rgba(241, 245, 249, 0.84), rgba(255, 255, 255, 0.95));
}

.proxy-ops-icon {
    display: inline-grid;
    place-items: center;
    width: 2.65rem;
    height: 2.65rem;
    border-radius: 0.9rem;
    color: #047857;
    background: rgba(16, 185, 129, 0.12);
    border: 1px solid rgba(16, 185, 129, 0.22);
    flex: 0 0 auto;
}

.proxy-ops-label {
    display: block;
    margin-bottom: 0.25rem;
    color: #64748b;
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.proxy-ops-card strong {
    display: block;
    color: #0f172a;
    font-size: 1rem;
    font-weight: 950;
    line-height: 1.2;
}

.proxy-ops-card p {
    margin: 0.45rem 0 0;
    color: #475569;
    font-size: 0.86rem;
    line-height: 1.45;
}

.proxy-playbook-steps {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.proxy-playbook-steps > div {
    min-width: 0;
    padding: 1rem;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 1rem;
    background: rgba(248, 250, 252, 0.86);
}

.proxy-playbook-steps span {
    display: inline-grid;
    place-items: center;
    width: 2rem;
    height: 2rem;
    margin-bottom: 0.75rem;
    border-radius: 999px;
    color: #052e21;
    background: linear-gradient(135deg, #d8fff0, #8fffd8);
    font-size: 0.82rem;
    font-weight: 950;
}

.proxy-playbook-steps strong {
    display: block;
    color: #0f172a;
    font-weight: 950;
}

.proxy-playbook-steps p {
    margin: 0.45rem 0 0;
    color: #475569;
    font-size: 0.86rem;
    line-height: 1.5;
}

/* Empty/error states */
.empty-state {
    display: grid;
    place-items: center;
    min-height: 12rem;
    padding: 2rem;
    color: #64748b;
    text-align: center;
    border: 1px dashed rgba(148, 163, 184, 0.42);
    border-radius: 1.15rem;
    background:
        radial-gradient(circle at 50% 0%, rgba(96, 165, 250, 0.08), transparent 12rem),
        rgba(248, 250, 252, 0.78);
}

.empty-state-compact {
    min-height: 9rem;
    margin: 1rem;
}

.empty-state i {
    display: inline-grid;
    place-items: center;
    width: 3rem;
    height: 3rem;
    margin-bottom: 0.75rem;
    color: #047857;
    background: rgba(16, 185, 129, 0.12);
    border: 1px solid rgba(16, 185, 129, 0.22);
    border-radius: 1rem;
    font-size: 1.35rem;
}

.empty-state strong {
    display: block;
    color: #0f172a;
    font-size: 1rem;
    font-weight: 950;
}

.empty-state span,
.empty-state p {
    display: block;
    max-width: 34rem;
    margin: 0.35rem auto 0;
    color: #64748b;
    font-size: 0.92rem;
    line-height: 1.55;
}

.error-state {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 1.25rem;
    align-items: flex-start;
    max-width: 54rem;
    margin: 0 auto;
    padding: clamp(1.25rem, 3vw, 2rem);
    border-radius: 1.4rem;
}

.error-state-icon {
    display: inline-grid;
    place-items: center;
    width: 4.25rem;
    height: 4.25rem;
    color: #991b1b;
    background: rgba(254, 226, 226, 0.92);
    border: 1px solid rgba(248, 113, 113, 0.32);
    border-radius: 1.25rem;
    font-size: 1.75rem;
}

.error-state-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.25rem;
}


.error-page-shell {
    display: grid;
    place-items: center;
    width: 100%;
    min-height: min(70vh, 48rem);
    padding: clamp(1rem, 3vw, 2rem);
}

.error-page-shell .error-state {
    width: min(100%, 54rem);
}

@media (max-width: 575.98px) {
    .error-page-shell {
        min-height: auto;
        padding: 0;
    }

    .error-page-shell .error-state {
        grid-template-columns: 1fr;
    }
}

body.auth-page.hotelcode-corporate-ui .proxy-ops-card,
body.auth-page.hotelcode-corporate-ui .proxy-playbook-steps > div,
body.auth-page.hotelcode-corporate-ui .empty-state {
    color: var(--cbw-text-dark);
    border-color: var(--cbw-border-dark);
    background:
        radial-gradient(circle at 0% 0%, rgba(78, 124, 255, 0.10), transparent 14rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.10), transparent 14rem),
        linear-gradient(145deg, var(--cbw-surface-dark), rgba(2, 8, 9, 0.94));
}

body.auth-page.hotelcode-corporate-ui .proxy-ops-label,
body.auth-page.hotelcode-corporate-ui .proxy-ops-card p,
body.auth-page.hotelcode-corporate-ui .proxy-playbook-steps p,
body.auth-page.hotelcode-corporate-ui .empty-state span,
body.auth-page.hotelcode-corporate-ui .empty-state p {
    color: var(--cbw-text-dark-muted);
}

body.auth-page.hotelcode-corporate-ui .proxy-ops-card strong,
body.auth-page.hotelcode-corporate-ui .proxy-playbook-steps strong,
body.auth-page.hotelcode-corporate-ui .empty-state strong {
    color: var(--cbw-text-dark);
}

body.auth-page.hotelcode-corporate-ui .proxy-ops-icon,
body.auth-page.hotelcode-corporate-ui .empty-state i {
    color: #8fffd8;
    background: rgba(143, 255, 216, 0.10);
    border-color: rgba(143, 255, 216, 0.22);
}

@media (max-width: 1199.98px) {
    .proxy-ops-grid,
    .proxy-playbook-steps {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .proxy-ops-grid,
    .proxy-playbook-steps {
        grid-template-columns: 1fr;
    }

    .error-state {
        grid-template-columns: 1fr;
    }

    .error-state-actions .btn {
        width: 100%;
    }
}


/* Landing visual QA consistency pass */
.premium-landing {
    --landing-section-radius: clamp(1.35rem, 2vw, 2rem);
    --landing-section-padding: clamp(1.25rem, 4vw, 4.5rem);
    --landing-card-radius: 1.25rem;
    --landing-card-border: rgba(226, 232, 240, 0.92);
    --landing-card-bg: rgba(255, 255, 255, 0.84);
    --landing-card-shadow: 0 1.4rem 3.5rem rgba(15, 23, 42, 0.07);
    width: min(100%, 1720px);
    margin-inline: auto;
    gap: clamp(1rem, 2vw, 1.75rem);
}

.premium-landing .premium-topbar {
    margin-bottom: clamp(1rem, 2vw, 1.75rem);
    border-radius: var(--landing-card-radius);
    box-shadow: 0 1rem 2.6rem rgba(15, 23, 42, 0.07);
}

.premium-landing .brand-nav {
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.45rem 0.75rem;
}

.premium-landing .brand-nav a:not(.brand-nav-primary) {
    padding: 0.45rem 0.6rem;
    border-radius: 999px;
    transition: color 180ms ease, background-color 180ms ease;
}

.premium-landing .brand-nav a:not(.brand-nav-primary):hover,
.premium-landing .brand-nav a:not(.brand-nav-primary):focus {
    color: var(--text);
    background: rgba(15, 23, 42, 0.06);
}

.premium-landing .brand-nav-primary,
.premium-landing .landing-actions .btn,
.premium-landing .overview-action-row .btn {
    min-height: 2.85rem;
    border-radius: 999px;
    font-weight: 900;
}

.premium-landing .saas-hero,
.premium-landing .hotelcode-overview-section,
.premium-landing .landing-section.premium-section,
.premium-landing .landing-policy.premium-policy {
    border-color: var(--landing-card-border);
    border-radius: var(--landing-section-radius);
    box-shadow: var(--landing-card-shadow);
}

.premium-landing .landing-section.premium-section,
.premium-landing .landing-policy.premium-policy {
    padding: clamp(1.35rem, 3.2vw, 2.6rem);
    background:
        radial-gradient(circle at 100% 0%, rgba(37, 99, 235, 0.08), transparent 22rem),
        linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(248, 250, 252, 0.82));
}

.premium-landing .landing-section-header {
    gap: clamp(1rem, 3vw, 2rem);
    margin-bottom: clamp(1rem, 2vw, 1.5rem);
}

.premium-landing .landing-section-header p {
    max-width: 44rem;
}

.premium-landing .landing-kicker,
.premium-landing .visual-kicker,
.premium-landing .corporate-hero-badge {
    letter-spacing: 0.11em;
}

.premium-landing .saas-hero {
    grid-template-columns: minmax(0, 1.02fr) minmax(28rem, 0.98fr);
    padding: var(--landing-section-padding);
}

.premium-landing .saas-hero h1,
.premium-landing .hotelcode-overview-copy h2,
.premium-landing .landing-section h2,
.premium-landing .landing-policy h2 {
    text-wrap: balance;
}

.premium-landing .landing-lead,
.premium-landing .hotelcode-overview-copy p,
.premium-landing .showcase-copy p,
.premium-landing .landing-section-header p,
.premium-landing .landing-policy p {
    text-wrap: pretty;
}

.premium-landing .hero-proof-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.premium-landing .hero-proof-grid > div,
.premium-landing .dash-card,
.premium-landing .visual-module-card,
.premium-landing .visual-workflow-step,
.premium-landing .impact-card,
.premium-landing .socialcode-value-card,
.premium-landing .socialcode-channel-card,
.premium-landing .socialcode-platform-panel,
.premium-landing .dashboard-window {
    border-color: var(--landing-card-border);
    border-radius: var(--landing-card-radius);
}

.premium-landing .dashboard-window,
.premium-landing .overview-dashboard-shell,
.premium-landing .socialcode-platform-panel {
    width: min(100%, 46rem);
    margin-inline: auto;
}

.premium-landing .dashboard-window,
.premium-landing .socialcode-platform-panel {
    box-shadow: 0 1.75rem 4rem rgba(15, 23, 42, 0.13);
}

.premium-landing .dashboard-grid,
.premium-landing .overview-dashboard-kpis,
.premium-landing .overview-dashboard-insights,
.premium-landing .overview-dashboard-flow,
.premium-landing .socialcode-platform-metrics,
.premium-landing .socialcode-value-list,
.premium-landing .socialcode-channel-grid,
.premium-landing .visual-module-grid,
.premium-landing .visual-workflow {
    gap: clamp(0.75rem, 1.4vw, 1rem);
}

.premium-landing .dash-card,
.premium-landing .visual-module-card,
.premium-landing .visual-workflow-step,
.premium-landing .socialcode-value-card,
.premium-landing .socialcode-channel-card {
    min-width: 0;
    transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.premium-landing .visual-module-card:hover,
.premium-landing .visual-workflow-step:hover,
.premium-landing .socialcode-value-card:hover,
.premium-landing .socialcode-channel-card:hover {
    transform: translateY(-0.18rem);
    border-color: rgba(38, 194, 129, 0.28);
    box-shadow: 0 1.15rem 2.8rem rgba(15, 23, 42, 0.08);
}

.premium-landing .visual-module-card i,
.premium-landing .visual-workflow-step i,
.premium-landing .socialcode-value-card i,
.premium-landing .socialcode-channel-card > i,
.premium-landing .policy-list i {
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 2.55rem;
    height: 2.55rem;
    border-radius: 0.95rem;
    color: #03100b;
    background: linear-gradient(135deg, #9cf3d5, #4ce0a6);
    font-size: 1.15rem;
}

.premium-landing .visual-module-card strong,
.premium-landing .visual-workflow-step strong,
.premium-landing .socialcode-value-card strong,
.premium-landing .socialcode-channel-card strong {
    color: var(--text);
    font-size: 1rem;
    font-weight: 950;
    letter-spacing: -0.02em;
}

.premium-landing .visual-module-card span,
.premium-landing .socialcode-value-card span,
.premium-landing .socialcode-channel-card span,
.premium-landing .policy-list div {
    color: var(--muted);
    line-height: 1.58;
}

.premium-landing .overview-dashboard-shell {
    box-shadow: 0 2rem 4.5rem rgba(15, 23, 42, 0.26);
}

.premium-landing .overview-dashboard-row,
.premium-landing .overview-dashboard-kpis article,
.premium-landing .overview-dashboard-insights article,
.premium-landing .overview-dashboard-flow div {
    border-radius: 1rem;
}

.premium-landing .overview-dashboard-row-head {
    letter-spacing: 0.05em;
}

.premium-landing .socialcode-showcase {
    grid-template-columns: minmax(0, 0.92fr) minmax(28rem, 1.08fr);
}

.premium-landing .socialcode-platform-panel {
    padding: clamp(1rem, 2vw, 1.35rem);
}

.premium-landing .socialcode-tag-row span,
.premium-landing .hero-area-tags span,
.premium-landing .status-badge {
    white-space: nowrap;
}

.premium-landing .visual-workflow-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.premium-landing .visual-workflow-step {
    display: grid;
    gap: 0.75rem;
    align-content: start;
    min-height: 9rem;
}

.premium-landing .policy-list {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.85rem;
}

.premium-landing .policy-list div {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    min-width: 0;
    padding: 0.95rem;
    border: 1px solid var(--landing-card-border);
    border-radius: var(--landing-card-radius);
    background: var(--landing-card-bg);
}

@media (max-width: 1399.98px) {
    .premium-landing {
        width: 100%;
    }

    .premium-landing .hero-proof-grid,
    .premium-landing .overview-proof-list,
    .premium-landing .policy-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .premium-landing .visual-workflow-5 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1199.98px) {
    .premium-landing .saas-hero,
    .premium-landing .hotelcode-overview-section,
    .premium-landing .socialcode-showcase {
        grid-template-columns: 1fr;
    }

    .premium-landing .saas-hero-visual,
    .premium-landing .overview-dashboard-mockup,
    .premium-landing .socialcode-platform-panel {
        width: 100%;
    }

    .premium-landing .visual-module-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .premium-landing .premium-topbar {
        align-items: flex-start;
        flex-direction: column;
    }

    .premium-landing .brand-nav {
        justify-content: flex-start;
        width: 100%;
    }

    .premium-landing .dashboard-grid,
    .premium-landing .overview-dashboard-kpis,
    .premium-landing .overview-dashboard-insights,
    .premium-landing .overview-dashboard-flow,
    .premium-landing .socialcode-platform-metrics,
    .premium-landing .socialcode-value-list,
    .premium-landing .socialcode-channel-grid,
    .premium-landing .visual-workflow-5 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .premium-landing .landing-section-header {
        grid-template-columns: 1fr;
        align-items: start;
    }
}

@media (max-width: 767.98px) {
    .premium-landing,
    .corporate-shell,
    .landing-shell {
        padding-left: 0.85rem;
        padding-right: 0.85rem;
    }

    .premium-landing .saas-hero,
    .premium-landing .hotelcode-overview-section,
    .premium-landing .landing-section.premium-section,
    .premium-landing .landing-policy.premium-policy {
        padding: 1rem;
        border-radius: 1.35rem;
    }

    .premium-landing .hero-proof-grid,
    .premium-landing .overview-proof-list,
    .premium-landing .dashboard-grid,
    .premium-landing .overview-dashboard-kpis,
    .premium-landing .overview-dashboard-insights,
    .premium-landing .overview-dashboard-flow,
    .premium-landing .socialcode-platform-metrics,
    .premium-landing .socialcode-value-list,
    .premium-landing .socialcode-channel-grid,
    .premium-landing .visual-module-grid,
    .premium-landing .visual-workflow-5,
    .premium-landing .policy-list {
        grid-template-columns: 1fr;
    }

    .premium-landing .landing-actions .btn,
    .premium-landing .overview-action-row .btn,
    .premium-landing .brand-nav-primary {
        justify-content: center;
        width: 100%;
    }

    .premium-landing .overview-action-row span {
        max-width: none;
    }

    .premium-landing .socialcode-tag-row span,
    .premium-landing .hero-area-tags span,
    .premium-landing .status-badge {
        white-space: normal;
    }
}

@media (max-width: 575.98px) {
    .premium-landing .brand-lockup {
        align-items: flex-start;
        width: 100%;
    }

    .premium-landing .brand-nav a:not(.brand-nav-primary),
    .premium-landing .brand-nav .language-switcher {
        width: 100%;
    }

    .premium-landing .saas-hero h1 {
        font-size: clamp(2.4rem, 14vw, 3.4rem);
        line-height: 0.96;
    }

    .premium-landing .hotelcode-overview-copy h2,
    .premium-landing .landing-section h2,
    .premium-landing .landing-policy h2 {
        font-size: clamp(2rem, 11vw, 2.8rem);
        line-height: 1;
    }

    .premium-landing .overview-dashboard-table {
        overflow-x: auto;
    }

    .premium-landing .overview-dashboard-row {
        min-width: 32rem;
    }
}


/* Minimal public header polish: keep the existing logo asset, prevent brand text wrapping. */
.premium-landing .brand-lockup {
    flex: 0 0 auto;
    min-width: 18rem;
    text-decoration: none;
}

.premium-landing .brand-wordmark {
    display: flex;
    flex-direction: column;
    min-width: 0;
    line-height: 1.05;
}

.premium-landing .hotelcode-brand {
    margin: 0;
    font-size: clamp(1rem, 1.08vw, 1.22rem) !important;
    font-weight: 950;
    letter-spacing: -0.045em;
    white-space: nowrap;
}

.premium-landing .codebw-brand {
    margin-top: 0.22rem;
    font-size: clamp(0.78rem, 0.85vw, 0.98rem);
    font-weight: 800;
    letter-spacing: -0.01em;
    text-transform: none;
    white-space: nowrap;
}

.premium-landing .brand-nav {
    min-width: 0;
    margin-left: auto;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .hotelcode-brand {
    color: #f8fafc;
    text-shadow: 0 0.55rem 1.4rem rgba(0, 0, 0, 0.24);
}

body.auth-page.hotelcode-corporate-ui .premium-landing .codebw-brand {
    color: rgba(248, 250, 252, 0.86);
}

@media (max-width: 991.98px) {
    .premium-landing .brand-lockup {
        min-width: 0;
    }
}

@media (max-width: 575.98px) {
    .premium-landing .brand-wordmark {
        line-height: 1.08;
    }

    .premium-landing .hotelcode-brand {
        font-size: 1.32rem;
    }

    .premium-landing .codebw-brand {
        font-size: 0.78rem;
    }
}


/* Final logo hierarchy: Code Black & White first, HotelCode secondary. */
body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup {
    flex: 0 0 auto;
    min-width: 0;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .codebw-logo-image {
    width: 3.6rem;
    height: 3.6rem;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .codebw-wordmark {
    display: grid;
    width: clamp(14.5rem, 15.2vw, 17rem);
    min-width: 14.5rem;
    gap: 0.22rem;
    line-height: 1;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .codebw-brand,
body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .hotelcode-brand {
    display: block;
    width: 100%;
    margin: 0;
    overflow: hidden;
    line-height: 1;
    white-space: nowrap;
    text-align: justify;
    text-align-last: justify;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .codebw-brand {
    color: #f8fafc;
    font-size: clamp(1.02rem, 1.08vw, 1.24rem);
    font-weight: 950;
    letter-spacing: 0.035em;
    text-transform: none;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .hotelcode-brand {
    margin-top: 0.18rem;
    color: rgba(216, 255, 240, 0.82);
    font-size: clamp(0.66rem, 0.7vw, 0.78rem);
    font-weight: 820;
    letter-spacing: 0.035em;
    text-transform: uppercase;
}

@media (max-width: 575.98px) {
    body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup {
        min-width: 0;
    }

    body.auth-page.hotelcode-corporate-ui .premium-landing .codebw-wordmark {
        width: clamp(11.8rem, 60vw, 13.8rem);
        min-width: 0;
    }

    body.auth-page.hotelcode-corporate-ui .premium-landing .codebw-brand {
        font-size: 0.9rem;
        letter-spacing: 0.035em;
    }

    body.auth-page.hotelcode-corporate-ui .premium-landing .hotelcode-brand {
        font-size: 0.72rem;
        letter-spacing: 0.06em;
    }
}


/* Example-based logo lockup: match CodeBlackWhite reference gap and HOTELCODE subtitle. */
body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup {
    gap: 0.17rem;
    align-items: center;
    min-width: 0;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .codebw-logo-image {
    width: 3.6rem;
    height: 3.6rem;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .brand-wordmark {
    display: grid;
    width: clamp(14.5rem, 15.2vw, 17rem);
    min-width: 14.5rem;
    gap: 0.22rem;
    line-height: 1;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .codebw-brand,
body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .hotelcode-brand {
    display: block;
    width: 100%;
    margin: 0;
    overflow: hidden;
    line-height: 1;
    white-space: nowrap;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .codebw-brand {
    color: #ffffff;
    font-size: clamp(1.02rem, 1.08vw, 1.24rem);
    font-weight: 1000;
    letter-spacing: 0.035em;
    text-align: justify;
    text-align-last: justify;
    text-transform: uppercase;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .hotelcode-brand {
    margin-top: 0.18rem;
    color: rgba(216, 255, 240, 0.82);
    font-size: clamp(0.66rem, 0.7vw, 0.78rem);
    font-weight: 760;
    letter-spacing: 0.035em;
    text-align: right;
    text-transform: uppercase;
}

@media (max-width: 575.98px) {
    body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup {
        gap: 0.15rem;
    }

    body.auth-page.hotelcode-corporate-ui .premium-landing .codebw-logo-image {
        width: 3.2rem;
        height: 3.2rem;
    }

    body.auth-page.hotelcode-corporate-ui .premium-landing .brand-wordmark {
        width: clamp(12.25rem, 58vw, 14.5rem);
        min-width: 12.25rem;
    }

    body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .codebw-brand {
        font-size: 0.98rem;
        letter-spacing: 0.065em;
    }

    body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .hotelcode-brand {
        font-size: 0.58rem;
        letter-spacing: 0.02em;
    }
}


/* Final visual logo gap fix: remove fixed wordmark width and compensate transparent logo padding. */
body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup {
    gap: 0 !important;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .codebw-wordmark {
    display: inline-grid !important;
    justify-items: end !important;
    width: max-content !important;
    min-width: 0 !important;
    margin-left: -0.28rem !important;
    gap: 0.14rem !important;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .codebw-brand,
body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .hotelcode-brand {
    width: auto !important;
    max-width: none !important;
    text-align: right !important;
    text-align-last: auto !important;
}

@media (max-width: 575.98px) {
    body.auth-page.hotelcode-corporate-ui .premium-landing .codebw-wordmark {
        width: max-content !important;
        min-width: 0 !important;
        margin-left: -0.22rem !important;
        gap: 0.12rem !important;
    }
}

/* Compact login pill in the public header. */
body.auth-page.hotelcode-corporate-ui .premium-landing .brand-nav-login {
    padding: 0.48rem 0.78rem;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    color: rgba(248, 250, 252, 0.9) !important;
    background: rgba(255, 255, 255, 0.075);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

body.auth-page.hotelcode-corporate-ui .premium-landing .brand-nav-login:hover,
body.auth-page.hotelcode-corporate-ui .premium-landing .brand-nav-login:focus-visible {
    color: #ffffff !important;
    border-color: rgba(76, 224, 166, 0.34);
    background: rgba(76, 224, 166, 0.11);
}


/* Requested HotelCode brand size fix. Keep this after auth-page logo overrides. */
body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .hotelcode-brand {
    margin: 0;
    font-size: clamp(1rem, 1.08vw, 1.22rem) !important;
    font-weight: 950;
    letter-spacing: -0.045em;
    white-space: nowrap;
}

/* Footer brand alignment patch: match the public header lockup and right-align footer link groups. */
.site-footer.site-footer-public .site-footer-inner {
    grid-template-columns: minmax(0, 1fr) repeat(4, minmax(8.5rem, auto));
    align-items: flex-start;
}

.site-footer.site-footer-public .site-footer-lockup {
    display: inline-flex;
    align-items: center;
    gap: 0;
    width: fit-content;
    text-decoration: none;
}

.site-footer.site-footer-public .site-footer-logo {
    margin: 0;
}

.site-footer.site-footer-public .site-footer-lockup > span {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    min-width: 0;
    margin: 0;
    text-align: right;
    line-height: 1.05;
}

.site-footer.site-footer-public .site-footer-lockup strong {
    margin: 0;
    color: #0f172a;
    font-size: clamp(0.78rem, 0.85vw, 0.98rem);
    font-weight: 800;
    letter-spacing: -0.01em;
    text-transform: none;
    white-space: nowrap;
}

.site-footer.site-footer-public .site-footer-lockup small {
    margin: 0;
    color: var(--primary);
    font-size: clamp(1rem, 1.08vw, 1.22rem) !important;
    font-weight: 950;
    letter-spacing: -0.045em;
    white-space: nowrap;
}

.site-footer.site-footer-public .site-footer-column {
    justify-items: end;
    text-align: right;
}

.site-footer.site-footer-public .site-footer-column a {
    margin-left: auto;
    text-align: right;
}

.site-footer.site-footer-public .site-footer-bottom-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    justify-content: flex-end;
    margin-left: auto;
    text-align: right;
}

@media (max-width: 991.98px) {
    .site-footer.site-footer-public .site-footer-inner {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .site-footer.site-footer-public .site-footer-brand {
        grid-column: 1 / -1;
    }
}

@media (max-width: 575.98px) {
    .site-footer.site-footer-public .site-footer-inner {
        grid-template-columns: 1fr;
    }

    .site-footer.site-footer-public .site-footer-column {
        justify-items: end;
        text-align: right;
    }

    .site-footer.site-footer-public .site-footer-column a {
        margin-left: auto;
    }
}



/* Footer logo lockup: use the same visual standards as the public header logo. */
.site-footer.site-footer-public .site-footer-brand {
    justify-items: end;
    text-align: right;
}

.site-footer.site-footer-public .site-footer-lockup.brand-lockup {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0 !important;
    width: fit-content !important;
    min-width: 0 !important;
    margin-left: auto !important;
    text-decoration: none !important;
}

.site-footer.site-footer-public .site-footer-logo.codebw-logo-image {
    width: 3.6rem !important;
    height: 3.6rem !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
}

.site-footer.site-footer-public .site-footer-wordmark.codebw-wordmark {
    display: inline-grid !important;
    justify-items: end !important;
    width: max-content !important;
    min-width: 0 !important;
    margin-left: -0.28rem !important;
    gap: 0.14rem !important;
    line-height: 1 !important;
    text-align: right !important;
}

.site-footer.site-footer-public .site-footer-lockup .codebw-brand,
.site-footer.site-footer-public .site-footer-lockup .hotelcode-brand {
    display: block !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
    overflow: hidden !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    text-align: right !important;
    text-align-last: auto !important;
}

.site-footer.site-footer-public .site-footer-lockup .codebw-brand {
    color: #0f172a !important;
    font-size: clamp(1.02rem, 1.08vw, 1.24rem) !important;
    font-weight: 1000 !important;
    letter-spacing: 0.035em !important;
    text-transform: uppercase !important;
}

.site-footer.site-footer-public .site-footer-lockup .hotelcode-brand {
    color: var(--primary) !important;
    font-size: clamp(1rem, 1.08vw, 1.22rem) !important;
    font-weight: 950 !important;
    letter-spacing: -0.045em !important;
    text-transform: uppercase !important;
}

@media (max-width: 575.98px) {
    .site-footer.site-footer-public .site-footer-logo.codebw-logo-image {
        width: 3.2rem !important;
        height: 3.2rem !important;
    }

    .site-footer.site-footer-public .site-footer-wordmark.codebw-wordmark {
        margin-left: -0.22rem !important;
        gap: 0.12rem !important;
    }

    .site-footer.site-footer-public .site-footer-lockup .codebw-brand {
        font-size: 0.98rem !important;
        letter-spacing: 0.065em !important;
    }

    .site-footer.site-footer-public .site-footer-lockup .hotelcode-brand {
        font-size: 0.88rem !important;
        letter-spacing: -0.045em !important;
    }
}

/* Footer brand final fix: left start, header-style lockup, readable dark-theme contrast. */
.site-footer.site-footer-public .site-footer-brand {
    justify-items: start !important;
    text-align: left !important;
}

.site-footer.site-footer-public .site-footer-lockup.brand-lockup {
    justify-content: flex-start !important;
    margin-left: 0 !important;
    margin-right: auto !important;
}

.site-footer.site-footer-public .site-footer-brand p,
.site-footer.site-footer-public .site-footer-social {
    margin-left: 0 !important;
    margin-right: auto !important;
    text-align: left !important;
}

body.auth-page.hotelcode-corporate-ui .site-footer.site-footer-public .site-footer-lockup .codebw-brand {
    color: #f8fafc !important;
    text-shadow: 0 0.65rem 1.5rem rgba(0, 0, 0, 0.34) !important;
}

body.auth-page.hotelcode-corporate-ui .site-footer.site-footer-public .site-footer-lockup .hotelcode-brand {
    color: #4ce0a6 !important;
    text-shadow: 0 0.65rem 1.5rem rgba(0, 0, 0, 0.28) !important;
}

/* Flight Split create form: keep action buttons readable and separated. */
.flight-split-create-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: 1rem !important;
    padding: 1.25rem 1.5rem 1.5rem !important;
}

.flight-split-create-actions .flight-split-create-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 9.5rem;
    white-space: nowrap;
}

@media (max-width: 575.98px) {
    .flight-split-create-actions {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .flight-split-create-actions .flight-split-create-action {
        width: 100%;
    }
}


/* English brand lock: avoid Turkish locale uppercasing (i -> İ) on product-name badges. */
.brand-english-text,
.brand-english-text * {
    text-transform: none !important;
}

.lead-report-mini-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
    margin-top: 0.85rem;
}

.lead-report-mini-metric {
    display: grid;
    gap: 0.18rem;
    min-width: 0;
    padding: 0.7rem 0.75rem;
    border: 1px solid rgba(37, 99, 235, 0.14);
    border-radius: 0.95rem;
    background: rgba(219, 234, 254, 0.7);
}

.lead-report-mini-metric strong {
    overflow-wrap: anywhere;
    color: #1e3a8a;
    font-size: 0.98rem;
    font-weight: 900;
    line-height: 1.18;
}

.lead-report-mini-metric span {
    color: #475569;
    font-size: 0.74rem;
    font-weight: 800;
    line-height: 1.25;
}

@media (max-width: 575.98px) {
    .lead-report-mini-metrics {
        grid-template-columns: 1fr;
    }
}



/* SocialCode AI inbox gradient style applied to HotelCode hero and logo wordmarks. */
.hotelcode-gradient-text {
    display: inline-block;
    width: fit-content;
    padding-bottom: .14em;
    margin-bottom: -.02em;
    line-height: 1.1;
    overflow: visible;
    background: linear-gradient(95deg, #4e7cff, #35d9ae 78%) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    color: transparent !important;
    -webkit-text-fill-color: transparent !important;
}

.hotelcode-hero-title .hotelcode-gradient-text {
    white-space: normal;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .hotelcode-brand.hotelcode-brand-gradient,
body.auth-page.hotelcode-corporate-ui .site-footer.site-footer-public .site-footer-lockup .hotelcode-brand.hotelcode-brand-gradient,
body.hotelcode-corporate-ui .sidebar-brand .brand-subtitle.hotelcode-brand-gradient {
    text-shadow: none !important;
}

body.auth-page.hotelcode-corporate-ui .premium-landing .brand-lockup .hotelcode-brand.hotelcode-brand-gradient {
    font-size: clamp(1rem, 1.08vw, 1.22rem) !important;
    font-weight: 950 !important;
    letter-spacing: -0.045em !important;
    text-transform: none !important;
}

body.hotelcode-corporate-ui .sidebar-brand .brand-subtitle.hotelcode-brand-gradient {
    font-weight: 900;
}

.hotelcode-corporate-ui .toast-panel.toast-panel-danger,
body.app-page.hotelcode-corporate-ui .toast-panel.toast-panel-danger,
body.auth-page.hotelcode-corporate-ui .toast-panel.toast-panel-danger {
    color: #991b1b;
    border-color: rgba(239, 68, 68, 0.32);
    background: #fff5f5;
}

/* Public SEO landing pages */
.seo-landing-page {
    --seo-page-accent: #2563eb;
}

.seo-breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    width: min(1180px, calc(100% - 2rem));
    margin: 1.25rem auto 0;
    color: #64748b;
    font-size: 0.92rem;
    font-weight: 700;
}

.seo-breadcrumb a {
    color: #2563eb;
}

.seo-breadcrumb span {
    color: #334155;
}

.seo-page-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(19rem, 0.75fr);
    gap: 1.25rem;
    align-items: stretch;
    width: min(1180px, calc(100% - 2rem));
    margin: 1.25rem auto 0;
    padding: clamp(1.4rem, 3vw, 2.4rem);
    border: 1px solid rgba(37, 99, 235, 0.13);
    border-radius: 2rem;
    background:
        radial-gradient(circle at top left, rgba(37, 99, 235, 0.13), transparent 24rem),
        linear-gradient(135deg, #ffffff 0%, #f8fbff 58%, #eef5ff 100%);
    box-shadow: 0 28px 70px rgba(15, 23, 42, 0.10);
}

.seo-page-hero-copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
}

.seo-page-hero h1 {
    max-width: 52rem;
    margin: 0.55rem 0 0;
    color: #0f172a;
    font-size: clamp(2.15rem, 5vw, 4.5rem);
    line-height: 0.98;
    letter-spacing: -0.06em;
}

.seo-page-hero p {
    max-width: 47rem;
    margin: 1rem 0 0;
    color: #475569;
    font-size: clamp(1rem, 1.45vw, 1.18rem);
    line-height: 1.65;
}

.seo-keyword-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 1.2rem;
}

.seo-keyword-list span {
    display: inline-flex;
    align-items: center;
    border: 1px solid rgba(37, 99, 235, 0.16);
    border-radius: 999px;
    padding: 0.52rem 0.78rem;
    color: #1d4ed8;
    background: rgba(219, 234, 254, 0.75);
    font-size: 0.88rem;
    font-weight: 800;
}

.seo-page-hero-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 1rem;
    min-width: 0;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 1.55rem;
    padding: 1rem;
    background: rgba(255, 255, 255, 0.82);
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.09);
    backdrop-filter: blur(12px);
}

.seo-hero-card-top {
    display: flex;
    align-items: center;
    gap: 0.8rem;
}

.seo-hero-card-top strong,
.seo-metric-stack strong {
    display: block;
    color: #0f172a;
}

.seo-hero-card-top small,
.seo-metric-stack small {
    display: block;
    color: #64748b;
}

.seo-icon-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.1rem;
    height: 3.1rem;
    border-radius: 1.1rem;
    color: #fff;
    background: linear-gradient(135deg, #2563eb, #111827);
    box-shadow: 0 14px 30px rgba(37, 99, 235, 0.28);
    font-size: 1.35rem;
}

.seo-metric-stack {
    display: grid;
    gap: 0.75rem;
}

.seo-metric-stack article {
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 1.15rem;
    padding: 0.9rem;
    background: #f8fafc;
}

.seo-metric-stack span {
    display: block;
    color: #64748b;
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.seo-metric-stack strong {
    margin-top: 0.2rem;
    font-size: 1.25rem;
}

.seo-content-section {
    width: min(1180px, calc(100% - 2rem));
    margin-right: auto;
    margin-left: auto;
}

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

.seo-info-card span {
    line-height: 1.6;
}

.seo-audience-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.seo-audience-grid article {
    min-width: 0;
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 1.35rem;
    padding: 1.15rem;
    background: #fff;
    box-shadow: 0 16px 42px rgba(15, 23, 42, 0.06);
}

.seo-audience-grid i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.6rem;
    height: 2.6rem;
    border-radius: 0.9rem;
    color: #2563eb;
    background: #dbeafe;
    font-size: 1.15rem;
}

.seo-audience-grid strong {
    display: block;
    margin-top: 0.85rem;
    color: #0f172a;
    font-size: 1.05rem;
}

.seo-audience-grid p {
    margin: 0.45rem 0 0;
    color: #64748b;
    line-height: 1.6;
}

.seo-workflow-list {
    display: grid;
    gap: 0.8rem;
}

.seo-workflow-list article {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.9rem;
    align-items: start;
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 1.2rem;
    padding: 1rem;
    background: #fff;
    box-shadow: 0 12px 34px rgba(15, 23, 42, 0.05);
}

.seo-workflow-list article > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.45rem;
    height: 2.45rem;
    border-radius: 0.9rem;
    color: #fff;
    background: #111827;
    font-weight: 900;
}

.seo-workflow-list strong {
    display: block;
    color: #0f172a;
    font-size: 1.03rem;
}

.seo-workflow-list p {
    margin: 0.32rem 0 0;
    color: #64748b;
    line-height: 1.55;
}

.seo-faq-list {
    display: grid;
    gap: 0.85rem;
}

.seo-faq-list article {
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 1.25rem;
    padding: 1.05rem 1.15rem;
    background: #fff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.05);
}

.seo-faq-list h3 {
    margin: 0;
    color: #0f172a;
    font-size: 1.02rem;
    letter-spacing: -0.02em;
}

.seo-faq-list p {
    margin: 0.5rem 0 0;
    color: #64748b;
    line-height: 1.65;
}

.seo-related-section {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: 1rem;
    width: min(1180px, calc(100% - 2rem));
    margin-right: auto;
    margin-left: auto;
}

.seo-related-links {
    display: grid;
    gap: 0.75rem;
}

.seo-related-links a {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.2rem 0.8rem;
    align-items: center;
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 1.05rem;
    padding: 0.9rem 1rem;
    color: #0f172a;
    background: #fff;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.04);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.seo-related-links a:hover {
    border-color: rgba(37, 99, 235, 0.35);
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
    transform: translateY(-2px);
}

.seo-related-links strong,
.seo-related-links span {
    min-width: 0;
}

.seo-related-links span {
    grid-column: 1;
    color: #64748b;
    line-height: 1.45;
}

.seo-related-links i {
    grid-row: 1 / span 2;
    grid-column: 2;
    color: #2563eb;
}

.seo-home-guides {
    width: min(1180px, calc(100% - 2rem));
    margin-right: auto;
    margin-left: auto;
}

.seo-home-guide-links {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.seo-channel-group-list {
    display: grid;
    gap: 1rem;
}

.seo-channel-group-card {
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 1.35rem;
    padding: 1.15rem;
    background: #fff;
    box-shadow: 0 16px 42px rgba(15, 23, 42, 0.06);
}

.seo-channel-group-header {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 0.85rem;
}

.seo-channel-group-header strong {
    display: block;
    color: #0f172a;
    font-size: 1.05rem;
}

.seo-channel-group-header span {
    display: block;
    margin-top: 0.25rem;
    color: #64748b;
    line-height: 1.5;
}

.seo-channel-group-header small {
    flex: 0 0 auto;
    border-radius: 999px;
    padding: 0.35rem 0.7rem;
    color: #1d4ed8;
    background: #dbeafe;
    font-size: 0.78rem;
    font-weight: 800;
}

.seo-channel-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.seo-channel-chip-list span {
    border: 1px solid rgba(203, 213, 225, 0.9);
    border-radius: 999px;
    padding: 0.38rem 0.65rem;
    color: #334155;
    background: #f8fafc;
    font-size: 0.82rem;
    font-weight: 700;
}

@media (max-width: 991.98px) {
    .seo-page-hero,
    .seo-related-section {
        grid-template-columns: 1fr;
    }

    .seo-card-grid,
    .seo-audience-grid,
    .seo-home-guide-links {
        grid-template-columns: 1fr;
    }

    .seo-page-hero h1 {
        letter-spacing: -0.045em;
    }
}

@media (max-width: 575.98px) {
    .seo-breadcrumb,
    .seo-page-hero,
    .seo-content-section,
    .seo-related-section,
    .seo-home-guides {
        width: min(100% - 1rem, 1180px);
    }

    .seo-page-hero {
        border-radius: 1.35rem;
        padding: 1rem;
    }

    .seo-page-hero h1 {
        font-size: 2.1rem;
    }

    .seo-keyword-list span {
        font-size: 0.82rem;
    }
}



@media (max-width: 575.98px) {
    .seo-channel-group-header {
        flex-direction: column;
    }
}


/* Public SEO pages aligned with the corporate home dark hero */
body.hotelcode-corporate-ui .seo-landing-page {
    --seo-page-accent: #35d9ae;
    --seo-page-accent-soft: rgba(53, 217, 174, 0.11);
    --seo-page-blue-soft: rgba(78, 124, 255, 0.16);
    --seo-page-surface: rgba(2, 6, 8, 0.42);
    --seo-page-panel: rgba(255, 255, 255, 0.055);
    --seo-page-border: rgba(255, 255, 255, 0.105);
    --seo-page-text: #f8fafc;
    --seo-page-muted: rgba(248, 250, 252, 0.68);
    --seo-page-muted-soft: rgba(248, 250, 252, 0.54);
}

body.hotelcode-corporate-ui .seo-landing-page main {
    display: grid;
    gap: clamp(1rem, 2.4vw, 2rem);
}

body.hotelcode-corporate-ui .seo-breadcrumb,
body.hotelcode-corporate-ui .seo-page-hero,
body.hotelcode-corporate-ui .seo-content-section,
body.hotelcode-corporate-ui .seo-related-section,
body.hotelcode-corporate-ui .seo-home-guides {
    width: 100%;
}

body.hotelcode-corporate-ui .seo-breadcrumb {
    margin: 0;
    padding: 0 0 0.15rem;
    color: var(--seo-page-muted-soft);
}

body.hotelcode-corporate-ui .seo-breadcrumb a {
    color: var(--seo-page-accent);
}

body.hotelcode-corporate-ui .seo-breadcrumb span,
body.hotelcode-corporate-ui .seo-breadcrumb i {
    color: var(--seo-page-muted-soft);
}

body.hotelcode-corporate-ui .seo-page-hero {
    position: relative;
    overflow: hidden;
    grid-template-columns: minmax(0, 1.05fr) minmax(22rem, 0.95fr);
    gap: clamp(2rem, 5vw, 5rem);
    align-items: center;
    min-height: clamp(31rem, 60vh, 42rem);
    margin: 0;
    padding: clamp(2rem, 5vw, 4.5rem);
    border: 1px solid rgba(91, 141, 255, 0.28);
    border-radius: 2rem;
    background:
        radial-gradient(circle at 14% 0%, rgba(78, 124, 255, 0.22), transparent 28rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.14), transparent 34rem),
        linear-gradient(135deg, rgba(7, 14, 18, 0.88), rgba(2, 6, 8, 0.78));
    box-shadow: 0 2rem 5rem rgba(0, 0, 0, 0.34);
}

body.hotelcode-corporate-ui .seo-page-hero::after {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    pointer-events: none;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.09), transparent 28%),
        radial-gradient(circle at 72% 38%, rgba(38, 194, 129, 0.10), transparent 18rem);
}

body.hotelcode-corporate-ui .seo-page-hero-copy,
body.hotelcode-corporate-ui .seo-page-hero-card {
    position: relative;
    z-index: 1;
}

body.hotelcode-corporate-ui .seo-page-hero h1 {
    max-width: 62rem;
    color: var(--seo-page-text);
    font-size: clamp(2.6rem, 5vw, 5.4rem);
    letter-spacing: -0.07em;
    text-wrap: balance;
}

body.hotelcode-corporate-ui .seo-page-hero p {
    max-width: 48rem;
    color: var(--seo-page-muted);
    font-size: clamp(1rem, 1.8vw, 1.22rem);
    line-height: 1.75;
}

body.hotelcode-corporate-ui .seo-keyword-list {
    gap: 0.45rem;
    margin-top: 1.35rem;
}

body.hotelcode-corporate-ui .seo-keyword-list span,
body.hotelcode-corporate-ui .seo-channel-chip-list span {
    border: 1px solid rgba(76, 224, 166, 0.20);
    color: #d9fff0;
    background: rgba(76, 224, 166, 0.10);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
}

body.hotelcode-corporate-ui .seo-page-hero-card {
    justify-content: flex-start;
    gap: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.105);
    border-radius: 1.8rem;
    padding: 1rem;
    background:
        radial-gradient(circle at 10% 0%, rgba(78, 124, 255, 0.18), transparent 18rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.12), transparent 18rem),
        rgba(4, 10, 13, 0.72);
    box-shadow: 0 1.25rem 3rem rgba(0, 0, 0, 0.22);
    backdrop-filter: blur(18px);
}

body.hotelcode-corporate-ui .seo-hero-card-top strong,
body.hotelcode-corporate-ui .seo-metric-stack strong {
    color: var(--seo-page-text);
}

body.hotelcode-corporate-ui .seo-hero-card-top small,
body.hotelcode-corporate-ui .seo-metric-stack small,
body.hotelcode-corporate-ui .seo-metric-stack span {
    color: var(--seo-page-muted);
}

body.hotelcode-corporate-ui .seo-icon-badge {
    color: #052e21;
    background: linear-gradient(135deg, #7ee7c0, #35d9ae);
    box-shadow: 0 0.95rem 2rem rgba(38, 194, 129, 0.25);
}

body.hotelcode-corporate-ui .seo-metric-stack article,
body.hotelcode-corporate-ui .seo-audience-grid article,
body.hotelcode-corporate-ui .seo-workflow-list article,
body.hotelcode-corporate-ui .seo-faq-list article,
body.hotelcode-corporate-ui .seo-related-links a,
body.hotelcode-corporate-ui .seo-channel-group-card {
    border: 1px solid var(--seo-page-border);
    background: var(--seo-page-surface);
    box-shadow: 0 1.25rem 3rem rgba(0, 0, 0, 0.18);
    backdrop-filter: blur(18px);
}

body.hotelcode-corporate-ui .seo-metric-stack article {
    border-radius: 1.15rem;
}

body.hotelcode-corporate-ui .seo-content-section,
body.hotelcode-corporate-ui .seo-related-section {
    margin: 0;
    border-color: var(--seo-page-border);
    border-radius: 1.5rem;
    background:
        radial-gradient(circle at 0% 0%, rgba(78, 124, 255, 0.10), transparent 18rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.08), transparent 18rem),
        var(--seo-page-panel);
    box-shadow: 0 1.25rem 3rem rgba(0, 0, 0, 0.22);
    backdrop-filter: blur(18px);
}

body.hotelcode-corporate-ui .seo-content-section {
    padding: clamp(1.25rem, 3vw, 2rem);
}

body.hotelcode-corporate-ui .seo-related-section {
    padding: clamp(1.25rem, 3vw, 2rem);
}

body.hotelcode-corporate-ui .seo-audience-grid article,
body.hotelcode-corporate-ui .seo-channel-group-card {
    border-radius: 1.35rem;
}

body.hotelcode-corporate-ui .seo-workflow-list article,
body.hotelcode-corporate-ui .seo-faq-list article {
    border-radius: 1.2rem;
}

body.hotelcode-corporate-ui .seo-audience-grid i {
    color: var(--seo-page-accent);
    border: 1px solid rgba(76, 224, 166, 0.20);
    background: var(--seo-page-accent-soft);
}

body.hotelcode-corporate-ui .seo-workflow-list article > span {
    color: #052e21;
    background: linear-gradient(135deg, #7ee7c0, #35d9ae);
    box-shadow: 0 0.65rem 1.6rem rgba(53, 217, 174, 0.18);
}

body.hotelcode-corporate-ui .seo-audience-grid strong,
body.hotelcode-corporate-ui .seo-workflow-list strong,
body.hotelcode-corporate-ui .seo-faq-list h3,
body.hotelcode-corporate-ui .seo-channel-group-header strong,
body.hotelcode-corporate-ui .seo-related-links strong {
    color: var(--seo-page-text);
}

body.hotelcode-corporate-ui .seo-audience-grid p,
body.hotelcode-corporate-ui .seo-workflow-list p,
body.hotelcode-corporate-ui .seo-faq-list p,
body.hotelcode-corporate-ui .seo-channel-group-header span,
body.hotelcode-corporate-ui .seo-related-links span,
body.hotelcode-corporate-ui .seo-info-card span {
    color: var(--seo-page-muted);
}

body.hotelcode-corporate-ui .seo-channel-group-header small {
    color: #052e21;
    background: linear-gradient(135deg, #d8fff0, #8fffd8);
    border: 1px solid rgba(143, 255, 216, 0.42);
    box-shadow: 0 0.65rem 1.6rem rgba(53, 217, 174, 0.18);
}

body.hotelcode-corporate-ui .seo-related-links a {
    color: var(--seo-page-text);
}

body.hotelcode-corporate-ui .seo-related-links a:hover {
    border-color: rgba(76, 224, 166, 0.35);
    box-shadow: 0 1.5rem 3.5rem rgba(38, 194, 129, 0.13);
}

body.hotelcode-corporate-ui .seo-related-links i {
    color: var(--seo-page-accent);
}

body.hotelcode-corporate-ui .seo-home-guides {
    margin-right: 0;
    margin-left: 0;
}

@media (max-width: 991.98px) {
    body.hotelcode-corporate-ui .seo-page-hero,
    body.hotelcode-corporate-ui .seo-related-section {
        grid-template-columns: 1fr;
    }

    body.hotelcode-corporate-ui .seo-page-hero {
        min-height: auto;
    }
}

@media (max-width: 575.98px) {
    body.hotelcode-corporate-ui .seo-page-hero {
        padding: 1.25rem;
        border-radius: 1.35rem;
    }

    body.hotelcode-corporate-ui .seo-content-section,
    body.hotelcode-corporate-ui .seo-related-section {
        border-radius: 1.25rem;
    }

    body.hotelcode-corporate-ui .seo-page-hero h1 {
        font-size: 2.3rem;
    }
}



/* Unified public dark component system: home + SEO */
body.hotelcode-corporate-ui.public-dark-page {
    background:
        radial-gradient(circle at 13% 8%, rgba(38, 194, 129, 0.20), transparent 24rem),
        radial-gradient(circle at 88% 0%, rgba(13, 110, 253, 0.16), transparent 25rem),
        radial-gradient(circle at 54% 92%, rgba(38, 194, 129, 0.08), transparent 27rem),
        linear-gradient(180deg, #010403 0%, #06110e 50%, #020403 100%);
    color: #f8fafc;
}

body.hotelcode-corporate-ui.public-dark-page .app-shell,
body.hotelcode-corporate-ui.public-dark-page .app-content {
    background: transparent;
}

body.hotelcode-corporate-ui .home-landing-page,
body.hotelcode-corporate-ui .seo-landing-page {
    --public-surface: rgba(2, 6, 8, 0.42);
    --public-panel: rgba(255, 255, 255, 0.055);
    --public-border: rgba(255, 255, 255, 0.105);
    --public-text: #f8fafc;
    --public-muted: rgba(248, 250, 252, 0.70);
    --public-muted-soft: rgba(248, 250, 252, 0.54);
    --public-accent: #35d9ae;
    --public-accent-soft: rgba(53, 217, 174, 0.12);
    color: var(--public-text);
}

body.hotelcode-corporate-ui .home-landing-page .premium-topbar,
body.hotelcode-corporate-ui .seo-landing-page .premium-topbar {
    border-color: rgba(255, 255, 255, 0.105);
    background: rgba(2, 6, 8, 0.72);
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.24);
    backdrop-filter: blur(22px) saturate(135%);
}

body.hotelcode-corporate-ui .home-landing-page .codebw-brand,
body.hotelcode-corporate-ui .seo-landing-page .codebw-brand,
body.hotelcode-corporate-ui .home-landing-page .brand-nav a,
body.hotelcode-corporate-ui .seo-landing-page .brand-nav a {
    color: rgba(248, 250, 252, 0.76);
}

body.hotelcode-corporate-ui .home-landing-page .brand-nav a:hover,
body.hotelcode-corporate-ui .seo-landing-page .brand-nav a:hover {
    color: var(--public-accent);
}

body.hotelcode-corporate-ui .home-landing-page .brand-nav-cta,
body.hotelcode-corporate-ui .seo-landing-page .brand-nav-cta {
    border-color: rgba(53, 217, 174, 0.22);
    background: rgba(53, 217, 174, 0.10);
    color: #d9fff0 !important;
}

body.hotelcode-corporate-ui .home-landing-page .saas-hero,
body.hotelcode-corporate-ui .home-landing-page .landing-section,
body.hotelcode-corporate-ui .home-landing-page .landing-policy,
body.hotelcode-corporate-ui .seo-landing-page .seo-page-hero,
body.hotelcode-corporate-ui .seo-landing-page .seo-content-section,
body.hotelcode-corporate-ui .seo-landing-page .seo-related-section {
    border: 1px solid var(--public-border);
    background:
        radial-gradient(circle at 14% 0%, rgba(78, 124, 255, 0.16), transparent 28rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.10), transparent 34rem),
        linear-gradient(135deg, rgba(7, 14, 18, 0.88), rgba(2, 6, 8, 0.78));
    box-shadow: 0 2rem 5rem rgba(0, 0, 0, 0.32);
}

body.hotelcode-corporate-ui .home-landing-page .saas-hero,
body.hotelcode-corporate-ui .seo-landing-page .seo-page-hero {
    border-radius: 2rem;
}

body.hotelcode-corporate-ui .home-landing-page .landing-section,
body.hotelcode-corporate-ui .home-landing-page .landing-policy,
body.hotelcode-corporate-ui .seo-landing-page .seo-content-section,
body.hotelcode-corporate-ui .seo-landing-page .seo-related-section {
    border-radius: 1.5rem;
    backdrop-filter: blur(18px);
}

body.hotelcode-corporate-ui .home-landing-page .saas-hero h1,
body.hotelcode-corporate-ui .home-landing-page .landing-section h2,
body.hotelcode-corporate-ui .home-landing-page .landing-policy h2,
body.hotelcode-corporate-ui .seo-landing-page .seo-page-hero h1,
body.hotelcode-corporate-ui .seo-landing-page .landing-section h2,
body.hotelcode-corporate-ui .seo-landing-page .landing-policy h2 {
    color: var(--public-text);
}

body.hotelcode-corporate-ui .home-landing-page .landing-lead,
body.hotelcode-corporate-ui .home-landing-page .landing-section-header p,
body.hotelcode-corporate-ui .home-landing-page .landing-policy p,
body.hotelcode-corporate-ui .seo-landing-page .seo-page-hero p,
body.hotelcode-corporate-ui .seo-landing-page .landing-section-header p,
body.hotelcode-corporate-ui .seo-landing-page .landing-policy p {
    color: var(--public-muted);
}

body.hotelcode-corporate-ui .home-landing-page .landing-kicker,
body.hotelcode-corporate-ui .seo-landing-page .landing-kicker {
    color: var(--public-accent);
}

body.hotelcode-corporate-ui .home-landing-page .dashboard-window,
body.hotelcode-corporate-ui .home-landing-page .overview-dashboard-shell,
body.hotelcode-corporate-ui .home-landing-page .visual-module-card,
body.hotelcode-corporate-ui .home-landing-page .visual-workflow-step,
body.hotelcode-corporate-ui .home-landing-page .pricing-card,
body.hotelcode-corporate-ui .home-landing-page .impact-card,
body.hotelcode-corporate-ui .home-landing-page .hero-proof-grid > div,
body.hotelcode-corporate-ui .home-landing-page .dash-card,
body.hotelcode-corporate-ui .home-landing-page .suite-pipeline-item,
body.hotelcode-corporate-ui .seo-landing-page .visual-module-card,
body.hotelcode-corporate-ui .seo-landing-page .seo-page-hero-card,
body.hotelcode-corporate-ui .seo-landing-page .seo-metric-stack article,
body.hotelcode-corporate-ui .seo-landing-page .seo-audience-grid article,
body.hotelcode-corporate-ui .seo-landing-page .seo-workflow-list article,
body.hotelcode-corporate-ui .seo-landing-page .seo-faq-list article,
body.hotelcode-corporate-ui .seo-landing-page .seo-related-links a,
body.hotelcode-corporate-ui .seo-landing-page .seo-channel-group-card {
    border: 1px solid var(--public-border);
    background:
        radial-gradient(circle at 0% 0%, rgba(78, 124, 255, 0.10), transparent 14rem),
        rgba(255, 255, 255, 0.055);
    box-shadow: 0 1.25rem 3rem rgba(0, 0, 0, 0.18);
    backdrop-filter: blur(18px);
}

body.hotelcode-corporate-ui .home-landing-page .visual-module-card strong,
body.hotelcode-corporate-ui .home-landing-page .visual-workflow-step strong,
body.hotelcode-corporate-ui .home-landing-page .pricing-name,
body.hotelcode-corporate-ui .home-landing-page .pricing-price,
body.hotelcode-corporate-ui .home-landing-page .pricing-code,
body.hotelcode-corporate-ui .home-landing-page .dashboard-window-top strong,
body.hotelcode-corporate-ui .home-landing-page .dash-card strong,
body.hotelcode-corporate-ui .home-landing-page .suite-pipeline-item strong,
body.hotelcode-corporate-ui .home-landing-page .hero-proof-grid strong,
body.hotelcode-corporate-ui .seo-landing-page .visual-module-card strong,
body.hotelcode-corporate-ui .seo-landing-page .seo-hero-card-top strong,
body.hotelcode-corporate-ui .seo-landing-page .seo-metric-stack strong,
body.hotelcode-corporate-ui .seo-landing-page .seo-audience-grid strong,
body.hotelcode-corporate-ui .seo-landing-page .seo-workflow-list strong,
body.hotelcode-corporate-ui .seo-landing-page .seo-faq-list h3,
body.hotelcode-corporate-ui .seo-landing-page .seo-channel-group-header strong,
body.hotelcode-corporate-ui .seo-landing-page .seo-related-links strong {
    color: var(--public-text);
}

body.hotelcode-corporate-ui .home-landing-page .visual-module-card span,
body.hotelcode-corporate-ui .home-landing-page .pricing-card li,
body.hotelcode-corporate-ui .home-landing-page .pricing-note,
body.hotelcode-corporate-ui .home-landing-page .dashboard-window-top small,
body.hotelcode-corporate-ui .home-landing-page .dash-card span,
body.hotelcode-corporate-ui .home-landing-page .dash-card small,
body.hotelcode-corporate-ui .home-landing-page .suite-pipeline-item small,
body.hotelcode-corporate-ui .home-landing-page .hero-proof-grid span,
body.hotelcode-corporate-ui .home-landing-page .hero-proof-grid small,
body.hotelcode-corporate-ui .seo-landing-page .visual-module-card span,
body.hotelcode-corporate-ui .seo-landing-page .seo-hero-card-top small,
body.hotelcode-corporate-ui .seo-landing-page .seo-metric-stack span,
body.hotelcode-corporate-ui .seo-landing-page .seo-metric-stack small,
body.hotelcode-corporate-ui .seo-landing-page .seo-audience-grid p,
body.hotelcode-corporate-ui .seo-landing-page .seo-workflow-list p,
body.hotelcode-corporate-ui .seo-landing-page .seo-faq-list p,
body.hotelcode-corporate-ui .seo-landing-page .seo-channel-group-header span,
body.hotelcode-corporate-ui .seo-landing-page .seo-related-links span {
    color: var(--public-muted);
}

body.hotelcode-corporate-ui .home-landing-page .visual-module-card i,
body.hotelcode-corporate-ui .home-landing-page .visual-workflow-step i,
body.hotelcode-corporate-ui .seo-landing-page .visual-module-card i,
body.hotelcode-corporate-ui .seo-landing-page .seo-audience-grid i {
    color: var(--public-accent);
    border: 1px solid rgba(53, 217, 174, 0.20);
    background: var(--public-accent-soft);
}

body.hotelcode-corporate-ui .home-landing-page .pricing-pill,
body.hotelcode-corporate-ui .seo-landing-page .seo-channel-group-header small,
body.hotelcode-corporate-ui .seo-landing-page .seo-workflow-list article > span {
    color: #052e21;
    background: linear-gradient(135deg, #d8fff0, #8fffd8);
}

body.hotelcode-corporate-ui .home-landing-page .pricing-card.featured {
    border-color: rgba(53, 217, 174, 0.34);
    box-shadow: 0 1.5rem 4rem rgba(38, 194, 129, 0.12);
}

body.hotelcode-corporate-ui .home-landing-page .seo-related-links a,
body.hotelcode-corporate-ui .seo-landing-page .seo-related-links a {
    color: var(--public-text);
}

body.hotelcode-corporate-ui .home-landing-page .seo-related-links i,
body.hotelcode-corporate-ui .seo-landing-page .seo-related-links i {
    color: var(--public-accent);
}

body.hotelcode-corporate-ui .home-landing-page .market-bar div {
    background: rgba(255, 255, 255, 0.12);
}

body.hotelcode-corporate-ui .seo-landing-page .seo-keyword-list span,
body.hotelcode-corporate-ui .seo-landing-page .seo-channel-chip-list span {
    border-color: rgba(53, 217, 174, 0.20);
    color: #d9fff0;
    background: var(--public-accent-soft);
}

body.hotelcode-corporate-ui .home-landing-page .btn-outline-primary,
body.hotelcode-corporate-ui .seo-landing-page .btn-outline-primary {
    color: #d9fff0;
    border-color: rgba(53, 217, 174, 0.32);
    background: rgba(53, 217, 174, 0.08);
}

body.hotelcode-corporate-ui .home-landing-page .btn-outline-primary:hover,
body.hotelcode-corporate-ui .seo-landing-page .btn-outline-primary:hover {
    color: #052e21;
    border-color: #7ee7c0;
    background: #7ee7c0;
}

body.hotelcode-corporate-ui .home-landing-page .language-switcher,
body.hotelcode-corporate-ui .seo-landing-page .language-switcher {
    border-color: rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.06);
}

body.hotelcode-corporate-ui .home-landing-page .language-switcher-select,
body.hotelcode-corporate-ui .seo-landing-page .language-switcher-select {
    color: rgba(248, 250, 252, 0.82);
}

@media (max-width: 575.98px) {
    body.hotelcode-corporate-ui .home-landing-page .saas-hero,
    body.hotelcode-corporate-ui .seo-landing-page .seo-page-hero {
        border-radius: 1.35rem;
    }

    body.hotelcode-corporate-ui .home-landing-page .landing-section,
    body.hotelcode-corporate-ui .home-landing-page .landing-policy,
    body.hotelcode-corporate-ui .seo-landing-page .seo-content-section,
    body.hotelcode-corporate-ui .seo-landing-page .seo-related-section {
        border-radius: 1.25rem;
    }
}


/* Public landing mobile tightening and unified dark component overrides */
body.hotelcode-corporate-ui.public-dark-page {
    background:
        radial-gradient(circle at 12% 0%, rgba(38, 194, 129, 0.18), transparent 23rem),
        radial-gradient(circle at 92% 2%, rgba(13, 110, 253, 0.14), transparent 25rem),
        linear-gradient(180deg, #010403 0%, #06110e 48%, #020403 100%) !important;
}

body.hotelcode-corporate-ui.public-dark-page .landing-shell {
    width: min(1280px, calc(100% - 3rem));
    margin: 0 auto;
    padding: 1rem 0 2.5rem;
}

body.hotelcode-corporate-ui.public-dark-page .seo-breadcrumb {
    width: 100%;
    margin: 0.15rem 0 0.85rem;
    color: rgba(248, 250, 252, 0.64);
}

body.hotelcode-corporate-ui.public-dark-page .seo-breadcrumb a {
    color: #7ee7c0;
}

body.hotelcode-corporate-ui.public-dark-page .seo-breadcrumb span {
    color: rgba(248, 250, 252, 0.62);
}

body.hotelcode-corporate-ui.public-dark-page .seo-page-hero,
body.hotelcode-corporate-ui.public-dark-page .seo-content-section,
body.hotelcode-corporate-ui.public-dark-page .seo-related-section,
body.hotelcode-corporate-ui.public-dark-page .home-landing-page .saas-hero,
body.hotelcode-corporate-ui.public-dark-page .home-landing-page .landing-section,
body.hotelcode-corporate-ui.public-dark-page .home-landing-page .landing-policy {
    width: 100%;
    color: var(--public-text);
    border-color: var(--public-border);
    background:
        radial-gradient(circle at 16% 0%, rgba(78, 124, 255, 0.16), transparent 26rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.11), transparent 34rem),
        linear-gradient(135deg, rgba(7, 14, 18, 0.92), rgba(2, 6, 8, 0.82)) !important;
}

body.hotelcode-corporate-ui.public-dark-page .seo-page-hero {
    margin: 0 auto;
    padding: clamp(1.65rem, 4.2vw, 4.25rem);
    border-radius: 2rem;
    box-shadow: 0 2rem 5rem rgba(0, 0, 0, 0.34);
}

body.hotelcode-corporate-ui.public-dark-page .seo-page-hero h1 {
    color: var(--public-text);
    font-size: clamp(2.65rem, 6.2vw, 5.6rem);
    line-height: 0.94;
    letter-spacing: -0.07em;
}

body.hotelcode-corporate-ui.public-dark-page .seo-page-hero p {
    color: var(--public-muted);
}

body.hotelcode-corporate-ui.public-dark-page .seo-page-hero-card,
body.hotelcode-corporate-ui.public-dark-page .seo-metric-stack article,
body.hotelcode-corporate-ui.public-dark-page .seo-audience-grid article,
body.hotelcode-corporate-ui.public-dark-page .seo-workflow-list article,
body.hotelcode-corporate-ui.public-dark-page .seo-faq-list article,
body.hotelcode-corporate-ui.public-dark-page .seo-related-links a,
body.hotelcode-corporate-ui.public-dark-page .seo-channel-group-card {
    border-color: var(--public-border);
    background:
        radial-gradient(circle at 0% 0%, rgba(78, 124, 255, 0.10), transparent 14rem),
        rgba(255, 255, 255, 0.055) !important;
    box-shadow: 0 1.25rem 3rem rgba(0, 0, 0, 0.18);
}

body.hotelcode-corporate-ui.public-dark-page .seo-keyword-list span,
body.hotelcode-corporate-ui.public-dark-page .seo-channel-chip-list span {
    border-color: rgba(53, 217, 174, 0.22);
    background: rgba(53, 217, 174, 0.10);
    color: #d9fff0;
}

body.hotelcode-corporate-ui.public-dark-page .seo-card-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

body.hotelcode-corporate-ui.public-dark-page .seo-channel-chip-list {
    max-height: 22rem;
    overflow: auto;
    padding-right: 0.25rem;
    scrollbar-width: thin;
}

body.hotelcode-corporate-ui.public-dark-page .seo-channel-chip-list::-webkit-scrollbar {
    width: 0.35rem;
}

body.hotelcode-corporate-ui.public-dark-page .seo-channel-chip-list::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(126, 231, 192, 0.42);
}

@media (max-width: 991.98px) {
    body.hotelcode-corporate-ui.public-dark-page .landing-shell {
        width: min(100% - 1.5rem, 1280px);
        padding-top: 0.75rem;
        gap: 1rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .premium-topbar {
        position: relative;
        top: auto;
        align-items: flex-start;
        flex-direction: column;
        gap: 0.85rem;
        margin-bottom: 0.85rem;
        padding: 0.85rem;
        border-radius: 1.25rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .brand-lockup {
        width: 100%;
    }

    body.hotelcode-corporate-ui.public-dark-page .brand-nav {
        width: 100%;
        gap: 0.5rem;
        overflow-x: auto;
        padding-bottom: 0.15rem;
        scrollbar-width: none;
    }

    body.hotelcode-corporate-ui.public-dark-page .brand-nav::-webkit-scrollbar {
        display: none;
    }

    body.hotelcode-corporate-ui.public-dark-page .brand-nav a,
    body.hotelcode-corporate-ui.public-dark-page .language-switcher {
        flex: 0 0 auto;
        white-space: nowrap;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-page-hero,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page .saas-hero {
        grid-template-columns: 1fr;
        gap: 1.25rem;
        min-height: auto;
        padding: 1.4rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-page-hero-card {
        order: 2;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-page-hero h1,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page .saas-hero h1 {
        font-size: clamp(2.35rem, 10vw, 4.1rem);
        line-height: 0.96;
        letter-spacing: -0.06em;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-page-hero p,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page .landing-lead {
        font-size: 1rem;
        line-height: 1.65;
    }

    body.hotelcode-corporate-ui.public-dark-page .landing-actions {
        gap: 0.65rem;
        margin-top: 1.1rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .landing-actions .btn {
        min-height: 2.85rem;
        padding: 0.72rem 1rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .visual-module-grid,
    body.hotelcode-corporate-ui.public-dark-page .seo-card-grid,
    body.hotelcode-corporate-ui.public-dark-page .seo-audience-grid,
    body.hotelcode-corporate-ui.public-dark-page .seo-related-links {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-channel-group-header {
        align-items: flex-start;
        flex-direction: column;
        gap: 0.55rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-content-section,
    body.hotelcode-corporate-ui.public-dark-page .seo-related-section,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page .landing-section,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page .landing-policy {
        padding: 1.25rem;
        border-radius: 1.35rem;
    }
}

@media (max-width: 575.98px) {
    body.hotelcode-corporate-ui.public-dark-page .landing-shell {
        width: min(100% - 1rem, 1280px);
        padding: 0.5rem 0 1.75rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .premium-topbar {
        padding: 0.75rem;
        border-radius: 1rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .codebw-logo-image {
        width: 2.3rem;
        height: 2.3rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .codebw-brand {
        font-size: 0.72rem;
        letter-spacing: 0.08em;
    }

    body.hotelcode-corporate-ui.public-dark-page .hotelcode-brand {
        font-size: 1rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .brand-nav {
        gap: 0.42rem;
        font-size: 0.82rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .brand-nav a,
    body.hotelcode-corporate-ui.public-dark-page .language-switcher {
        padding: 0.44rem 0.62rem;
        border: 1px solid rgba(255, 255, 255, 0.10);
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.045);
    }

    body.hotelcode-corporate-ui.public-dark-page .brand-nav-cta {
        padding: 0.46rem 0.72rem !important;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-breadcrumb {
        gap: 0.38rem;
        margin: 0.05rem 0 0.65rem;
        font-size: 0.82rem;
        line-height: 1.35;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-page-hero,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page .saas-hero {
        padding: 1.05rem;
        border-radius: 1.18rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .landing-kicker {
        margin-bottom: 0.55rem;
        font-size: 0.68rem;
        letter-spacing: 0.10em;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-page-hero h1,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page .saas-hero h1 {
        font-size: clamp(2rem, 12vw, 3.05rem);
        line-height: 0.98;
        letter-spacing: -0.055em;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-page-hero p,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page .landing-lead {
        margin-top: 0.75rem;
        font-size: 0.95rem;
        line-height: 1.58;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-keyword-list {
        gap: 0.42rem;
        margin-top: 0.9rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-keyword-list span,
    body.hotelcode-corporate-ui.public-dark-page .seo-channel-chip-list span {
        padding: 0.42rem 0.62rem;
        font-size: 0.78rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .landing-actions {
        display: grid;
        grid-template-columns: 1fr;
        margin-top: 1rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .landing-actions .btn {
        width: 100%;
        justify-content: center;
        min-height: 2.8rem;
        font-size: 0.92rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-page-hero-card,
    body.hotelcode-corporate-ui.public-dark-page .visual-module-card,
    body.hotelcode-corporate-ui.public-dark-page .seo-audience-grid article,
    body.hotelcode-corporate-ui.public-dark-page .seo-channel-group-card,
    body.hotelcode-corporate-ui.public-dark-page .seo-faq-list article,
    body.hotelcode-corporate-ui.public-dark-page .seo-related-links a {
        padding: 0.9rem;
        border-radius: 1rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-metric-stack {
        gap: 0.65rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-metric-stack article {
        padding: 0.78rem;
        border-radius: 0.95rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .visual-module-grid,
    body.hotelcode-corporate-ui.public-dark-page .seo-card-grid,
    body.hotelcode-corporate-ui.public-dark-page .seo-audience-grid,
    body.hotelcode-corporate-ui.public-dark-page .seo-related-links,
    body.hotelcode-corporate-ui.public-dark-page .hero-proof-grid,
    body.hotelcode-corporate-ui.public-dark-page .market-grid,
    body.hotelcode-corporate-ui.public-dark-page .landing-stats-grid {
        grid-template-columns: 1fr;
        gap: 0.72rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-content-section,
    body.hotelcode-corporate-ui.public-dark-page .seo-related-section,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page .landing-section,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page .landing-policy {
        padding: 1rem;
        border-radius: 1.12rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .landing-section-header {
        gap: 0.75rem;
        margin-bottom: 1rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .landing-section h2,
    body.hotelcode-corporate-ui.public-dark-page .landing-policy h2,
    body.hotelcode-corporate-ui.public-dark-page .seo-content-section h2,
    body.hotelcode-corporate-ui.public-dark-page .seo-related-section h2 {
        font-size: clamp(1.65rem, 9vw, 2.35rem);
        line-height: 1.05;
        letter-spacing: -0.05em;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-workflow-list article {
        grid-template-columns: 1fr;
        gap: 0.65rem;
        padding: 0.9rem;
        border-radius: 1rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-workflow-list article > span {
        width: 2.2rem;
        height: 2.2rem;
        border-radius: 0.75rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-channel-chip-list {
        max-height: 13.5rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .seo-channel-group-header small {
        align-self: flex-start;
    }
}


/* Unified public error pages: 404 / 403 / 500 */
body.hotelcode-corporate-ui.public-dark-page .app-main.auth-main {
    display: block;
    min-height: 100vh;
    padding: 0;
    background: transparent;
}

body.hotelcode-corporate-ui.public-dark-page .auth-main .app-content {
    width: 100%;
    max-width: none;
    padding: 0;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-landing {
    width: min(1280px, calc(100% - 3rem));
    min-height: calc(100vh - 2rem);
    padding: 1rem 0 2.5rem;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-topbar {
    margin-bottom: clamp(0.85rem, 2vw, 1.35rem);
}

body.hotelcode-corporate-ui.public-dark-page .public-error-main {
    display: grid;
    gap: 0.85rem;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-breadcrumb {
    margin: 0.1rem 0 0.4rem;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 22rem);
    gap: clamp(1rem, 2vw, 1.35rem);
    width: 100%;
    min-height: clamp(24rem, 58vh, 42rem);
    align-items: stretch;
    padding: clamp(1.35rem, 4vw, 3.5rem);
    color: var(--public-text);
    border: 1px solid var(--public-border);
    border-radius: 2rem;
    background:
        radial-gradient(circle at 18% 0%, rgba(78, 124, 255, 0.16), transparent 27rem),
        radial-gradient(circle at 100% 100%, rgba(53, 217, 174, 0.12), transparent 34rem),
        linear-gradient(135deg, rgba(7, 14, 18, 0.94), rgba(2, 6, 8, 0.84)) !important;
    box-shadow: 0 2rem 5rem rgba(0, 0, 0, 0.35);
    overflow: hidden;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-panel__content {
    display: flex;
    gap: clamp(1rem, 2vw, 1.5rem);
    align-items: flex-start;
    min-width: 0;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-panel__icon {
    display: inline-grid;
    flex: 0 0 auto;
    place-items: center;
    width: clamp(4.4rem, 7vw, 5.6rem);
    height: clamp(4.4rem, 7vw, 5.6rem);
    border-radius: clamp(1.25rem, 2vw, 1.6rem);
    font-size: clamp(1.65rem, 3vw, 2.2rem);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

body.hotelcode-corporate-ui.public-dark-page .public-error-tone-danger {
    color: #ffb4b4;
    border: 1px solid rgba(248, 113, 113, 0.34);
    background:
        radial-gradient(circle at 25% 10%, rgba(255, 255, 255, 0.16), transparent 2.8rem),
        rgba(239, 68, 68, 0.12);
}

body.hotelcode-corporate-ui.public-dark-page .public-error-tone-warning {
    color: #ffdca8;
    border: 1px solid rgba(245, 158, 11, 0.34);
    background:
        radial-gradient(circle at 25% 10%, rgba(255, 255, 255, 0.16), transparent 2.8rem),
        rgba(245, 158, 11, 0.12);
}

body.hotelcode-corporate-ui.public-dark-page .public-error-tone-info {
    color: #b8d4ff;
    border: 1px solid rgba(96, 165, 250, 0.34);
    background:
        radial-gradient(circle at 25% 10%, rgba(255, 255, 255, 0.16), transparent 2.8rem),
        rgba(96, 165, 250, 0.12);
}

body.hotelcode-corporate-ui.public-dark-page .public-error-panel__copy {
    min-width: 0;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-panel__copy h1 {
    max-width: 45rem;
    margin: 0.25rem 0 1rem;
    color: var(--public-text);
    font-size: clamp(2.6rem, 6vw, 5.15rem);
    line-height: 0.94;
    letter-spacing: -0.07em;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-panel__copy p {
    max-width: 45rem;
    margin: 0;
    color: var(--public-muted);
    font-size: 1.08rem;
    line-height: 1.78;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-actions {
    margin-top: clamp(1.25rem, 2.6vw, 2rem);
}

body.hotelcode-corporate-ui.public-dark-page .public-error-aside {
    display: grid;
    gap: 0.85rem;
    align-content: start;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-aside-card {
    display: grid;
    gap: 0.45rem;
    padding: 1rem;
    border: 1px solid var(--public-border);
    border-radius: 1.25rem;
    background:
        radial-gradient(circle at 0% 0%, rgba(78, 124, 255, 0.10), transparent 14rem),
        rgba(255, 255, 255, 0.055) !important;
    box-shadow: 0 1.25rem 3rem rgba(0, 0, 0, 0.18);
    backdrop-filter: blur(18px);
}

body.hotelcode-corporate-ui.public-dark-page .public-error-aside-card span {
    color: var(--public-muted-soft);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-aside-card strong {
    color: var(--public-text);
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1;
    letter-spacing: -0.05em;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-aside-card small,
body.hotelcode-corporate-ui.public-dark-page .public-error-aside-card p {
    margin: 0;
    color: var(--public-muted);
    line-height: 1.65;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-quick-links a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.78rem 0;
    color: #d9fff0;
    border-top: 1px solid rgba(255, 255, 255, 0.09);
    font-weight: 800;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-quick-links a:first-of-type {
    border-top: 0;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-quick-links a:hover {
    color: #8fffd8;
}

body.hotelcode-corporate-ui.public-dark-page .public-error-quick-links a::after {
    content: "→";
    color: var(--public-accent);
}

@media (max-width: 991.98px) {
    body.hotelcode-corporate-ui.public-dark-page .public-error-landing {
        width: min(100% - 1.5rem, 1280px);
        padding-top: 0.75rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-error-panel {
        grid-template-columns: 1fr;
        min-height: auto;
        padding: 1.35rem;
        border-radius: 1.35rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-error-panel__copy h1 {
        font-size: clamp(2.3rem, 10vw, 4.1rem);
        line-height: 0.96;
    }
}

@media (max-width: 575.98px) {
    body.hotelcode-corporate-ui.public-dark-page .public-error-landing {
        width: min(100% - 1rem, 1280px);
        padding: 0.5rem 0 1.75rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-error-panel {
        padding: 1.05rem;
        border-radius: 1.18rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-error-panel__content {
        flex-direction: column;
        gap: 0.9rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-error-panel__icon {
        width: 3.75rem;
        height: 3.75rem;
        border-radius: 1.05rem;
        font-size: 1.45rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-error-panel__copy h1 {
        font-size: clamp(2rem, 12vw, 3.05rem);
        line-height: 0.98;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-error-panel__copy p {
        font-size: 0.95rem;
        line-height: 1.58;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-error-actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.65rem;
        margin-top: 1rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-error-actions .btn {
        width: 100%;
        justify-content: center;
        min-height: 2.8rem;
        font-size: 0.92rem;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-error-aside-card {
        padding: 0.9rem;
        border-radius: 1rem;
    }
}


/* Public landing header mobile menu: closed by default */
.public-landing-header .public-nav-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    flex: 0 0 2.75rem;
    border: 1px solid rgba(126, 231, 192, 0.26);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: #f8fafc;
    box-shadow: 0 0.75rem 1.7rem rgba(0, 0, 0, 0.16);
}

.public-landing-header .public-nav-toggle i {
    font-size: 1.28rem;
    line-height: 1;
}

.public-landing-header .public-nav-toggle:focus-visible {
    outline: 3px solid rgba(76, 224, 166, 0.35);
    outline-offset: 3px;
}

@media (min-width: 992px) {
    .public-landing-header .public-nav-toggle {
        display: none !important;
    }

    .public-landing-header .public-landing-nav {
        display: flex !important;
    }
}

@media (max-width: 991.98px) {
    .public-landing-header {
        align-items: center !important;
        flex-direction: row !important;
        flex-wrap: wrap;
        gap: 0.75rem;
    }

    .public-landing-header .brand-lockup {
        flex: 1 1 auto;
        min-width: 0;
    }

    .public-landing-header .public-nav-toggle {
        display: inline-flex !important;
    }

    .public-landing-header .public-landing-nav {
        display: none !important;
        flex: 0 0 100%;
        width: 100%;
        max-width: 100%;
        align-items: stretch !important;
        flex-direction: column !important;
        gap: 0.5rem !important;
        margin-top: 0.35rem;
        padding-top: 0.75rem;
        border-top: 1px solid rgba(126, 231, 192, 0.14);
        overflow: visible !important;
        scrollbar-width: auto;
    }

    .public-landing-header.is-public-nav-open .public-landing-nav {
        display: flex !important;
    }

    .public-landing-header .public-landing-nav a,
    .public-landing-header .public-landing-nav .language-switcher {
        width: 100% !important;
        max-width: 100%;
    }

    .public-landing-header .public-landing-nav a {
        justify-content: center;
        padding: 0.68rem 0.85rem !important;
        border: 1px solid rgba(255, 255, 255, 0.10);
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.045);
        text-align: center;
        white-space: normal !important;
    }

    .public-landing-header .public-landing-nav .brand-nav-primary,
    .public-landing-header .public-landing-nav a.brand-nav-primary {
        background: #4ce0a6 !important;
        color: #03100b !important;
        border-color: #4ce0a6 !important;
    }
}

/* Public landing header mobile placement fix: menu button stays at the top-right corner */
@media (max-width: 991.98px) {
    body.hotelcode-corporate-ui.public-dark-page .public-landing-header,
    body.hotelcode-corporate-ui .public-landing-header {
        position: relative !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        flex-direction: row !important;
        flex-wrap: wrap !important;
        gap: 0.75rem !important;
        padding-right: 4.45rem !important;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-landing-header .brand-lockup,
    body.hotelcode-corporate-ui .public-landing-header .brand-lockup {
        width: auto !important;
        max-width: 100% !important;
        flex: 1 1 auto !important;
        min-width: 0 !important;
        padding-right: 0.25rem !important;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-landing-header .public-nav-toggle,
    body.hotelcode-corporate-ui .public-landing-header .public-nav-toggle {
        position: absolute !important;
        top: 0.85rem !important;
        right: 0.85rem !important;
        z-index: 20 !important;
        display: inline-flex !important;
        margin: 0 !important;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-landing-header .public-landing-nav,
    body.hotelcode-corporate-ui .public-landing-header .public-landing-nav {
        flex: 0 0 100% !important;
        width: 100% !important;
        max-width: 100% !important;
        margin-top: 0.35rem !important;
    }
}

@media (max-width: 575.98px) {
    body.hotelcode-corporate-ui.public-dark-page .public-landing-header,
    body.hotelcode-corporate-ui .public-landing-header {
        padding-right: 3.95rem !important;
    }

    body.hotelcode-corporate-ui.public-dark-page .public-landing-header .public-nav-toggle,
    body.hotelcode-corporate-ui .public-landing-header .public-nav-toggle {
        top: 0.75rem !important;
        right: 0.75rem !important;
    }
}

/* Public landing header: Code Black & White website mobile menu pattern */
.public-landing-header {
    position: relative;
    overflow: visible;
}

.public-landing-header .public-landing-desktop-nav {
    flex: 1 1 auto;
    justify-content: flex-end;
    min-width: 0;
}

.public-landing-header .mobile-nav-panel {
    display: none;
}

.public-landing-header .brand-nav-mobile {
    display: grid;
    align-content: start;
    gap: 0.7rem;
    width: 100%;
}

.public-landing-header .brand-nav-mobile a,
.public-landing-header .brand-nav-mobile .brand-nav-cta {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    min-width: 100%;
    min-height: 3.05rem;
    padding: 0.9rem 1.05rem 0.9rem 1.2rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.92rem;
    background: rgba(255, 255, 255, 0.04);
    color: #e7f3ee;
    font-size: 0.95rem;
    font-weight: 780;
    line-height: 1.2;
    letter-spacing: 0.01em;
    text-align: left;
    white-space: normal;
    box-shadow: none;
    transition:
        color 180ms ease,
        background-color 180ms ease,
        border-color 180ms ease,
        box-shadow 180ms ease,
        transform 180ms ease;
}

.public-landing-header .brand-nav-mobile a::before {
    content: "";
    display: inline-block;
    width: 0.42rem;
    height: 0.42rem;
    margin-right: 0.72rem;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.62);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.06);
    flex: 0 0 auto;
}

.public-landing-header .brand-nav-mobile a:hover,
.public-landing-header .brand-nav-mobile a:focus-visible,
.public-landing-header .brand-nav-mobile a.is-tapping {
    border-color: rgba(120, 255, 194, 0.18);
    background: rgba(88, 255, 172, 0.10);
    color: #ffffff;
}

.public-landing-header .brand-nav-mobile .brand-nav-primary,
.public-landing-header .brand-nav-mobile a.brand-nav-primary {
    border-color: rgba(110, 231, 183, 0.34) !important;
    background: linear-gradient(135deg, rgba(110, 231, 183, 0.92), rgba(167, 243, 208, 0.84)) !important;
    color: #06131f !important;
    font-weight: 950;
    box-shadow:
        0 0 0 1px rgba(110, 231, 183, 0.14),
        0 0.5rem 1.25rem rgba(16, 185, 129, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.24) !important;
}

.public-landing-header .brand-nav-mobile .brand-nav-primary::before,
.public-landing-header .brand-nav-mobile a.brand-nav-primary::before {
    background: #0b1f16;
    box-shadow: 0 0 0 4px rgba(6, 19, 31, 0.08);
}

.public-landing-header .brand-nav-language,
.public-landing-header .brand-nav-language .language-switcher,
.public-landing-header .brand-nav-language .language-switcher-select {
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
}

.public-landing-header .brand-nav-language .language-switcher-select {
    min-height: 3.05rem;
    border-color: rgba(255, 255, 255, 0.10);
    background: rgba(255, 255, 255, 0.04);
    color: #e7f3ee;
}

body.is-public-mobile-nav-open::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 24;
    background: rgba(2, 6, 12, 0.48);
    backdrop-filter: blur(3px);
}

@media (max-width: 991.98px) {
    body.hotelcode-corporate-ui .public-landing-header,
    body.hotelcode-corporate-ui.public-dark-page .public-landing-header,
    .public-landing-header {
        position: relative !important;
        z-index: 31;
        display: block !important;
        overflow: visible !important;
        min-height: 5rem;
        padding: 1rem 1rem 0.95rem !important;
        margin-bottom: clamp(1rem, 2vw, 1.75rem);
    }

    body.hotelcode-corporate-ui .public-landing-header .brand-lockup,
    body.hotelcode-corporate-ui.public-dark-page .public-landing-header .brand-lockup,
    .public-landing-header .brand-lockup {
        display: inline-flex !important;
        align-items: center !important;
        width: auto !important;
        max-width: calc(100% - 4.35rem) !important;
        min-width: 0 !important;
        padding-right: 0.2rem !important;
        gap: 0.65rem;
    }

    body.hotelcode-corporate-ui .public-landing-header .public-mobile-menu-button,
    body.hotelcode-corporate-ui.public-dark-page .public-landing-header .public-mobile-menu-button,
    .public-landing-header .public-mobile-menu-button {
        position: absolute !important;
        top: 0.95rem !important;
        right: 0.95rem !important;
        z-index: 34 !important;
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        width: 2.9rem !important;
        height: 2.9rem !important;
        margin: 0 !important;
        border: 1px solid rgba(120, 255, 194, 0.18) !important;
        border-radius: 999px !important;
        background: rgba(88, 255, 172, 0.10) !important;
        color: #c9ffe5 !important;
        box-shadow: 0 0.9rem 2rem rgba(0, 0, 0, 0.18) !important;
        backdrop-filter: blur(14px);
    }

    .public-landing-header .public-mobile-menu-button:hover,
    .public-landing-header .public-mobile-menu-button:focus-visible {
        border-color: rgba(120, 255, 194, 0.28) !important;
        background: rgba(88, 255, 172, 0.16) !important;
        color: #e9fff4 !important;
    }

    .public-landing-header .public-mobile-menu-button i {
        font-size: 1.18rem;
        line-height: 1;
        transition: transform 200ms cubic-bezier(0.2, 0.75, 0.2, 1);
    }

    body.is-public-mobile-nav-open .public-landing-header .public-mobile-menu-button {
        border-color: rgba(120, 255, 194, 0.24) !important;
        background: rgba(88, 255, 172, 0.18) !important;
        color: #dfffee !important;
        box-shadow: 0 1rem 2.2rem rgba(0, 0, 0, 0.24) !important;
    }

    body.is-public-mobile-nav-open .public-landing-header .public-mobile-menu-button i {
        transform: rotate(90deg) scale(0.95);
    }

    .public-landing-header .public-mobile-nav-panel,
    .public-landing-header .mobile-nav-panel {
        position: absolute;
        top: calc(100% + 0.55rem);
        left: 0;
        right: 0;
        z-index: 32;
        display: block;
        width: 100%;
        max-width: 100%;
        padding: 0.9rem !important;
        border: 1px solid rgba(255, 255, 255, 0.12);
        border-radius: 1.1rem;
        background:
            radial-gradient(circle at top right, rgba(67, 233, 123, 0.09), transparent 16rem),
            linear-gradient(180deg, rgba(5, 10, 18, 0.97), rgba(9, 17, 29, 0.98));
        box-shadow: 0 1.35rem 2.8rem rgba(0, 0, 0, 0.34);
        backdrop-filter: blur(18px);
        isolation: isolate;
    }

    .public-landing-header .public-mobile-nav-panel[hidden],
    .public-landing-header .mobile-nav-panel[hidden] {
        display: none !important;
    }

    .public-landing-header .brand-nav.brand-nav-mobile,
    .public-landing-header .mobile-nav-panel .brand-nav-mobile {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        width: 100% !important;
        min-width: 100% !important;
        justify-items: stretch !important;
        align-items: stretch !important;
        gap: 0.72rem !important;
    }

    .public-landing-header .brand-nav.brand-nav-mobile > a,
    .public-landing-header .brand-nav.brand-nav-mobile > .brand-nav-language,
    .public-landing-header .mobile-nav-panel .brand-nav-mobile > a,
    .public-landing-header .mobile-nav-panel .brand-nav-mobile > .brand-nav-language {
        width: 100% !important;
        min-width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        justify-self: stretch !important;
    }
}

@media (max-width: 575.98px) {
    body.hotelcode-corporate-ui .public-landing-header,
    body.hotelcode-corporate-ui.public-dark-page .public-landing-header,
    .public-landing-header {
        padding: 0.95rem 0.9rem 0.88rem !important;
        min-height: 4.75rem;
    }

    body.hotelcode-corporate-ui .public-landing-header .brand-lockup,
    body.hotelcode-corporate-ui.public-dark-page .public-landing-header .brand-lockup,
    .public-landing-header .brand-lockup {
        max-width: calc(100% - 4.1rem) !important;
        gap: 0.55rem;
    }

    .public-landing-header .codebw-logo-image {
        width: 3rem;
        height: 3rem;
    }

    .public-landing-header .codebw-brand {
        font-size: 0.76rem;
        letter-spacing: 0.06em;
    }

    .public-landing-header .hotelcode-brand {
        font-size: 0.78rem;
        line-height: 1.15;
    }

    body.hotelcode-corporate-ui .public-landing-header .public-mobile-menu-button,
    body.hotelcode-corporate-ui.public-dark-page .public-landing-header .public-mobile-menu-button,
    .public-landing-header .public-mobile-menu-button {
        top: 0.85rem !important;
        right: 0.85rem !important;
        width: 2.8rem !important;
        height: 2.8rem !important;
    }

    .public-landing-header .public-mobile-nav-panel,
    .public-landing-header .mobile-nav-panel {
        top: calc(100% + 0.5rem);
        padding: 0.72rem !important;
        border-radius: 1rem;
    }

    .public-landing-header .brand-nav-mobile a,
    .public-landing-header .brand-nav-language .language-switcher-select {
        min-height: 2.9rem !important;
        padding: 0.85rem 1rem 0.85rem 1.1rem !important;
        font-size: 0.95rem !important;
    }
}

/* Flight Split AI comment card */
.flight-ai-comment-card {
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
    padding: 1rem;
    border: 1px solid rgba(20, 184, 166, 0.18);
    border-radius: 1.1rem;
    background:
        radial-gradient(circle at top left, rgba(20, 184, 166, 0.13), transparent 14rem),
        linear-gradient(135deg, rgba(240, 253, 250, 0.94), rgba(255, 255, 255, 0.98));
    box-shadow: 0 0.85rem 1.6rem rgba(15, 23, 42, 0.06);
}

.flight-ai-comment-icon {
    flex: 0 0 auto;
    display: inline-flex;
    width: 2.35rem;
    height: 2.35rem;
    align-items: center;
    justify-content: center;
    border-radius: 0.9rem;
    color: #047857;
    background: rgba(167, 243, 208, 0.75);
    box-shadow: inset 0 0 0 1px rgba(16, 185, 129, 0.18);
}

.flight-ai-comment-card strong {
    display: block;
    margin-bottom: 0.25rem;
    color: #0f172a;
    font-weight: 900;
}

.flight-ai-comment-card p {
    margin: 0;
    color: #334155;
    line-height: 1.55;
}

@media (max-width: 575.98px) {
    .flight-ai-comment-card {
        padding: 0.9rem;
    }
}

/* Home hero commercial coverage highlights */
.premium-landing .home-hero-proof-grid,
.home-hero-proof-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 1.35rem;
    margin-bottom: 1.25rem;
}

.home-hero-proof-grid > div {
    min-height: 7.1rem;
    position: relative;
    overflow: hidden;
}

.home-hero-proof-grid > div::after {
    content: "";
    position: absolute;
    inset: auto -2rem -3.5rem auto;
    width: 7rem;
    height: 7rem;
    border-radius: 999px;
    background: rgba(147, 255, 207, 0.10);
    pointer-events: none;
}

.home-hero-proof-grid .hero-proof-priority {
    border-color: rgba(148, 255, 210, 0.42) !important;
    background:
        radial-gradient(circle at 100% 0%, rgba(148, 255, 210, 0.24), transparent 9rem),
        rgba(148, 255, 210, 0.095) !important;
    box-shadow: 0 1.15rem 3.2rem rgba(38, 194, 129, 0.18) !important;
}

.home-hero-proof-grid .hero-proof-priority strong,
body.hotelcode-corporate-ui .home-landing-page .home-hero-proof-grid .hero-proof-priority strong {
    color: #a8ffd6;
    font-size: clamp(1.85rem, 2.2vw, 2.45rem);
    text-shadow: 0 0 1.4rem rgba(38, 194, 129, 0.32);
}

.home-hero-proof-grid .hero-market-value,
body.hotelcode-corporate-ui .home-landing-page .home-hero-proof-grid .hero-market-value {
    font-size: clamp(1.08rem, 1.5vw, 1.55rem);
    letter-spacing: -0.035em;
    color: #eafff4;
}

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

.hero-dashboard-grid .dash-card {
    min-height: 7.45rem;
}

.hero-dashboard-grid .dash-card-provider,
body.hotelcode-corporate-ui .home-landing-page .hero-dashboard-grid .dash-card-provider {
    border-color: rgba(148, 255, 210, 0.34);
    background:
        radial-gradient(circle at 90% 0%, rgba(148, 255, 210, 0.20), transparent 10rem),
        rgba(255, 255, 255, 0.085);
}

.hero-dashboard-grid .dash-card-provider strong,
body.hotelcode-corporate-ui .home-landing-page .hero-dashboard-grid .dash-card-provider strong {
    color: #a8ffd6;
    font-size: 2.2rem;
}

.hero-dashboard-grid .dash-card-market strong,
.hero-dashboard-grid .dash-card-flight-split strong {
    font-size: 1.42rem;
}

@media (max-width: 1199.98px) {
    .premium-landing .home-hero-proof-grid,
    .home-hero-proof-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .premium-landing .home-hero-proof-grid,
    .home-hero-proof-grid,
    .hero-dashboard-grid {
        grid-template-columns: 1fr;
    }

    .home-hero-proof-grid > div,
    .hero-dashboard-grid .dash-card {
        min-height: auto;
    }

    .home-hero-proof-grid .hero-proof-priority strong,
    body.hotelcode-corporate-ui .home-landing-page .home-hero-proof-grid .hero-proof-priority strong {
        font-size: 2rem;
    }
}

.hero-ai-window {
    position: relative;
    overflow: hidden;
}

.hero-ai-window::after {
    content: "";
    position: absolute;
    right: -8rem;
    bottom: -8rem;
    width: 18rem;
    height: 18rem;
    border-radius: 999px;
    background: rgba(148, 255, 210, 0.12);
    filter: blur(2px);
    pointer-events: none;
}

.hero-ai-panel-lead {
    position: relative;
    z-index: 1;
    margin: -0.35rem 0 1rem;
    max-width: 39rem;
    color: rgba(226, 232, 240, 0.72);
    font-size: 0.94rem;
    line-height: 1.55;
}

.hero-ai-dashboard-grid {
    position: relative;
    z-index: 1;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hero-ai-dashboard-grid .dash-card,
body.hotelcode-corporate-ui .home-landing-page .hero-ai-dashboard-grid .dash-card {
    min-height: 7.65rem;
    border-color: rgba(148, 163, 184, 0.20);
    background:
        radial-gradient(circle at 100% 0%, rgba(148, 255, 210, 0.08), transparent 9rem),
        rgba(255, 255, 255, 0.075);
}

.hero-ai-dashboard-grid .hero-ai-card-primary,
body.hotelcode-corporate-ui .home-landing-page .hero-ai-dashboard-grid .hero-ai-card-primary {
    border-color: rgba(148, 255, 210, 0.40);
    background:
        radial-gradient(circle at 92% 0%, rgba(148, 255, 210, 0.24), transparent 10rem),
        rgba(148, 255, 210, 0.09);
    box-shadow: inset 0 0 0 1px rgba(148, 255, 210, 0.08);
}

.hero-ai-dashboard-grid .hero-ai-card-package,
body.hotelcode-corporate-ui .home-landing-page .hero-ai-dashboard-grid .hero-ai-card-package {
    border-color: rgba(96, 165, 250, 0.34);
    background:
        radial-gradient(circle at 92% 0%, rgba(96, 165, 250, 0.20), transparent 10rem),
        rgba(255, 255, 255, 0.075);
}

.hero-ai-dashboard-grid .dash-card strong,
body.hotelcode-corporate-ui .home-landing-page .hero-ai-dashboard-grid .dash-card strong {
    font-size: clamp(1.2rem, 1.65vw, 1.65rem);
    letter-spacing: -0.045em;
}

.hero-ai-dashboard-grid .hero-ai-card-primary strong,
body.hotelcode-corporate-ui .home-landing-page .hero-ai-dashboard-grid .hero-ai-card-primary strong {
    color: #a8ffd6;
    text-shadow: 0 0 1.2rem rgba(38, 194, 129, 0.28);
}

.hero-ai-decision-strip {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.8rem;
    align-items: center;
    margin-top: 0.8rem;
    padding: 0.95rem 1rem;
    border: 1px solid rgba(148, 255, 210, 0.22);
    border-radius: 1.1rem;
    background: rgba(148, 255, 210, 0.075);
}

.hero-ai-decision-strip > span {
    display: inline-grid;
    place-items: center;
    width: 2.4rem;
    height: 2.4rem;
    border-radius: 0.85rem;
    background: linear-gradient(135deg, rgba(96, 165, 250, 0.95), rgba(148, 255, 210, 0.86));
    color: #06120d;
    font-size: 0.74rem;
    font-weight: 950;
    letter-spacing: 0.04em;
}

.hero-ai-decision-strip strong,
.hero-ai-decision-strip small {
    display: block;
}

.hero-ai-decision-strip strong {
    color: #f8fafc;
    font-size: 1rem;
    font-weight: 950;
    letter-spacing: -0.025em;
}

.hero-ai-decision-strip small {
    margin-top: 0.15rem;
    color: rgba(226, 232, 240, 0.68);
    font-size: 0.84rem;
    line-height: 1.35;
}

@media (max-width: 575.98px) {
    .hero-ai-dashboard-grid {
        grid-template-columns: 1fr;
    }

    .hero-ai-panel-lead {
        font-size: 0.9rem;
    }

    .hero-ai-dashboard-grid .dash-card,
    body.hotelcode-corporate-ui .home-landing-page .hero-ai-dashboard-grid .dash-card {
        min-height: auto;
    }
}

/* Footer duplicate address + equal column distribution final fix */
.site-footer.site-footer-public .site-footer-inner {
    display: grid;
    grid-template-columns: minmax(0, 2fr) repeat(4, minmax(0, 1fr)) !important;
    gap: clamp(1rem, 2vw, 1.65rem) !important;
    align-items: flex-start;
}

.site-footer.site-footer-public .site-footer-brand,
.site-footer.site-footer-public .site-footer-column {
    width: 100%;
    min-width: 0;
    max-width: none !important;
    justify-items: start !important;
    text-align: left !important;
}

.site-footer.site-footer-public .site-footer-brand p,
.site-footer.site-footer-public .site-footer-address,
.site-footer.site-footer-public .site-footer-social {
    width: 100%;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    text-align: left !important;
}

.site-footer.site-footer-public .site-footer-column a {
    width: 100%;
    max-width: 100%;
    margin-left: 0 !important;
    margin-right: 0 !important;
    text-align: left !important;
}

.site-footer.site-footer-public .site-footer-bottom {
    align-items: center;
}

.site-footer.site-footer-public .site-footer-bottom-links {
    justify-content: flex-end;
    margin-left: auto;
    text-align: right;
}

.lead-report-site-footer .site-footer-inner {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.lead-report-site-footer .site-footer-brand,
.lead-report-site-footer .site-footer-column {
    width: 100%;
    min-width: 0;
    max-width: none !important;
    justify-items: start !important;
    text-align: left !important;
}

.lead-report-site-footer .site-footer-column a {
    width: 100%;
    margin-left: 0 !important;
    text-align: left !important;
}

@media (max-width: 1199.98px) {
    .site-footer.site-footer-public .site-footer-inner {
        grid-template-columns: minmax(0, 2fr) repeat(2, minmax(0, 1fr)) !important;
    }

    .lead-report-site-footer .site-footer-inner {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 767.98px) {
    .site-footer.site-footer-public .site-footer-inner,
    .lead-report-site-footer .site-footer-inner {
        grid-template-columns: 1fr !important;
    }

    .site-footer.site-footer-public .site-footer-bottom,
    .lead-report-site-footer .site-footer-bottom {
        display: grid;
        gap: 0.75rem;
        justify-content: stretch;
        text-align: left;
    }

    .site-footer.site-footer-public .site-footer-bottom-links,
    .lead-report-site-footer .site-footer-bottom-links {
        justify-content: flex-start;
        margin-left: 0;
        text-align: left;
    }
}

/* CodeBlackWhite home container width parity patch */
:root {
    --cbw-public-container-max: 1480px;
    --cbw-public-container-padding: clamp(0.75rem, 2vw, 1.25rem);
    --cbw-public-container-gap: clamp(1rem, 2.4vw, 2rem);
}

body.hotelcode-corporate-ui.public-dark-page .app-main.auth-main {
    display: block;
    place-items: stretch;
    align-items: stretch;
    min-height: 100vh;
    padding: 0;
    background: transparent;
}

body.hotelcode-corporate-ui.public-dark-page .auth-main .app-content {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: var(--cbw-public-container-padding) !important;
    box-sizing: border-box;
}

body.hotelcode-corporate-ui.public-dark-page .landing-shell,
body.hotelcode-corporate-ui.public-dark-page .landing-shell.premium-landing,
body.hotelcode-corporate-ui.public-dark-page .home-landing-page,
body.hotelcode-corporate-ui.public-dark-page .seo-landing-page,
body.hotelcode-corporate-ui.public-dark-page .public-error-landing {
    width: min(100%, var(--cbw-public-container-max)) !important;
    max-width: var(--cbw-public-container-max) !important;
    margin-inline: auto !important;
    padding: 0 0 clamp(1.5rem, 2.4vw, 2.5rem) !important;
    gap: var(--cbw-public-container-gap) !important;
    box-sizing: border-box;
}

body.hotelcode-corporate-ui.public-dark-page .brand-topbar,
body.hotelcode-corporate-ui.public-dark-page .premium-topbar,
body.hotelcode-corporate-ui.public-dark-page .public-error-topbar,
body.hotelcode-corporate-ui.public-dark-page .home-landing-page .saas-hero,
body.hotelcode-corporate-ui.public-dark-page .home-landing-page .hotelcode-overview-section,
body.hotelcode-corporate-ui.public-dark-page .home-landing-page .landing-section,
body.hotelcode-corporate-ui.public-dark-page .home-landing-page .landing-policy,
body.hotelcode-corporate-ui.public-dark-page .seo-landing-page .seo-page-hero,
body.hotelcode-corporate-ui.public-dark-page .seo-landing-page .seo-content-section,
body.hotelcode-corporate-ui.public-dark-page .seo-landing-page .seo-related-section,
body.hotelcode-corporate-ui.public-dark-page .public-error-panel {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box;
}

body.hotelcode-corporate-ui.public-dark-page .auth-main .app-content > .site-footer.site-footer-public {
    width: min(100%, var(--cbw-public-container-max)) !important;
    max-width: var(--cbw-public-container-max) !important;
    margin: clamp(1rem, 2.4vw, 2rem) auto clamp(1rem, 3vw, 2rem) !important;
    box-sizing: border-box;
}

@media (min-width: 1200px) {
    body.hotelcode-corporate-ui.public-dark-page .site-footer.site-footer-public .site-footer-inner {
        grid-template-columns: minmax(0, 2fr) repeat(4, minmax(0, 1fr)) !important;
        gap: clamp(1.5rem, 3vw, 2.4rem) !important;
    }
}

@media (max-width: 1199.98px) {
    body.hotelcode-corporate-ui.public-dark-page .site-footer.site-footer-public .site-footer-inner {
        grid-template-columns: minmax(0, 1fr) repeat(2, minmax(9rem, 0.5fr)) !important;
    }

    body.hotelcode-corporate-ui.public-dark-page .site-footer.site-footer-public .site-footer-brand {
        grid-column: 1 / -1;
        max-width: 100% !important;
    }
}

@media (max-width: 991.98px) {
    body.hotelcode-corporate-ui.public-dark-page .auth-main .app-content {
        padding: 0.75rem !important;
    }

    body.hotelcode-corporate-ui.public-dark-page .landing-shell,
    body.hotelcode-corporate-ui.public-dark-page .landing-shell.premium-landing,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page,
    body.hotelcode-corporate-ui.public-dark-page .seo-landing-page,
    body.hotelcode-corporate-ui.public-dark-page .public-error-landing {
        width: 100% !important;
        max-width: var(--cbw-public-container-max) !important;
        padding-bottom: 2rem !important;
        gap: 1rem !important;
    }
}

@media (max-width: 767.98px) {
    body.hotelcode-corporate-ui.public-dark-page .site-footer.site-footer-public .site-footer-inner {
        grid-template-columns: 1fr !important;
    }

    body.hotelcode-corporate-ui.public-dark-page .site-footer.site-footer-public .site-footer-brand {
        grid-column: auto;
    }
}

@media (max-width: 575.98px) {
    body.hotelcode-corporate-ui.public-dark-page .auth-main .app-content {
        padding: 0.5rem !important;
    }

    body.hotelcode-corporate-ui.public-dark-page .landing-shell,
    body.hotelcode-corporate-ui.public-dark-page .landing-shell.premium-landing,
    body.hotelcode-corporate-ui.public-dark-page .home-landing-page,
    body.hotelcode-corporate-ui.public-dark-page .seo-landing-page,
    body.hotelcode-corporate-ui.public-dark-page .public-error-landing {
        width: 100% !important;
        padding-bottom: 1.75rem !important;
        gap: 0.85rem !important;
    }
}

/* Wide screen public layout final correction: keep only small side gutters */
:root {
    --hotelcode-public-edge-gutter: clamp(1rem, 1.65vw, 2rem);
}

body.hotelcode-corporate-ui.auth-page.public-dark-page .app-main.auth-main {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
}

body.hotelcode-corporate-ui.auth-page.public-dark-page .auth-main .app-content {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: var(--hotelcode-public-edge-gutter) !important;
    box-sizing: border-box !important;
}

body.hotelcode-corporate-ui.auth-page.public-dark-page .landing-shell,
body.hotelcode-corporate-ui.auth-page.public-dark-page .landing-shell.premium-landing,
body.hotelcode-corporate-ui.auth-page.public-dark-page .home-landing-page,
body.hotelcode-corporate-ui.auth-page.public-dark-page .seo-landing-page,
body.hotelcode-corporate-ui.auth-page.public-dark-page .public-error-landing {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
}

body.hotelcode-corporate-ui.auth-page.public-dark-page .brand-topbar,
body.hotelcode-corporate-ui.auth-page.public-dark-page .premium-topbar,
body.hotelcode-corporate-ui.auth-page.public-dark-page .public-error-topbar,
body.hotelcode-corporate-ui.auth-page.public-dark-page .home-landing-page .saas-hero,
body.hotelcode-corporate-ui.auth-page.public-dark-page .home-landing-page .hotelcode-overview-section,
body.hotelcode-corporate-ui.auth-page.public-dark-page .home-landing-page .landing-section,
body.hotelcode-corporate-ui.auth-page.public-dark-page .home-landing-page .landing-policy,
body.hotelcode-corporate-ui.auth-page.public-dark-page .seo-landing-page .seo-page-hero,
body.hotelcode-corporate-ui.auth-page.public-dark-page .seo-landing-page .seo-content-section,
body.hotelcode-corporate-ui.auth-page.public-dark-page .seo-landing-page .seo-related-section,
body.hotelcode-corporate-ui.auth-page.public-dark-page .public-error-panel,
body.hotelcode-corporate-ui.auth-page.public-dark-page .auth-main .app-content > .site-footer.site-footer-public {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
}

body.hotelcode-corporate-ui.auth-page.public-dark-page .auth-main .app-content > .site-footer.site-footer-public {
    margin-top: clamp(1rem, 2.4vw, 2rem) !important;
    margin-bottom: clamp(1rem, 3vw, 2rem) !important;
}

@media (min-width: 1600px) {
    :root {
        --hotelcode-public-edge-gutter: clamp(1.5rem, 1.45vw, 2.25rem);
    }
}

@media (min-width: 1920px) {
    :root {
        --hotelcode-public-edge-gutter: 2rem;
    }
}

@media (max-width: 991.98px) {
    :root {
        --hotelcode-public-edge-gutter: 0.75rem;
    }
}

@media (max-width: 575.98px) {
    :root {
        --hotelcode-public-edge-gutter: 0.5rem;
    }
}
