:root {
    --hotel-primary: #0f6b5f;
    --hotel-secondary: #d88b36;
    --hotel-primary-soft: rgba(15, 107, 95, 0.14);
    --hotel-secondary-soft: rgba(216, 139, 54, 0.16);
    --hotel-primary-strong: #0b544a;
    --hotel-secondary-strong: #8a4d13;
    --hotel-primary-contrast: #ffffff;
    --hotel-secondary-contrast: #16211f;
    --guest-ink: #18211f;
    --guest-muted: #67726e;
    --guest-line: #d8e1dc;
    --guest-soft: #f4f7f3;
    --guest-card: rgba(255, 255, 255, 0.94);
    --guest-theme: var(--hotel-primary);
    --guest-theme-soft: var(--hotel-primary-soft);
    --guest-theme-strong: var(--hotel-primary-strong);
    --guest-theme-contrast: var(--hotel-primary-contrast);
    --guest-ui-primary: #195e54;
    --guest-ui-primary-soft: rgba(25, 94, 84, 0.1);
    --guest-ui-primary-strong: #124840;
    --guest-ui-primary-contrast: #ffffff;
    --portal-hero-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --portal-title-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --portal-text-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --portal-hero-weight: 500;
    --portal-title-weight: 500;
    --portal-text-weight: 500;
    --portal-hero-scale: 1;
    --portal-title-scale: 1;
    --portal-text-scale: 1;
    --portal-hero-shadow-color: #000000;
    --portal-hero-shadow-size: 0;
    --portal-hero-gradient-color: #000000;
    --portal-hero-gradient-size: 0;
    --portal-type-xs: calc(0.72rem * var(--portal-text-scale));
    --portal-type-sm: calc(0.82rem * var(--portal-text-scale));
    --portal-type-md: calc(0.94rem * var(--portal-text-scale));
    --portal-type-lg: calc(1.08rem * var(--portal-text-scale));
    --portal-type-xl: calc(1.24rem * var(--portal-text-scale));
    --portal-type-title-xs: calc(0.72rem * var(--portal-title-scale));
    --portal-type-title-sm: calc(0.82rem * var(--portal-title-scale));
    --portal-type-title-md: calc(0.94rem * var(--portal-title-scale));
    --portal-type-title-lg: calc(1.08rem * var(--portal-title-scale));
    --portal-type-title-xl: calc(1.24rem * var(--portal-title-scale));
    --portal-type-h4: calc(1.18rem * var(--portal-title-scale));
    --portal-type-h3: calc(1.34rem * var(--portal-title-scale));
    --portal-type-h2: calc(1.62rem * var(--portal-title-scale));
    --portal-type-h1: calc(2.25rem * var(--portal-title-scale));
    --hotel-standard-icon-bg-top: #eef8f4;
    --hotel-standard-icon-bg-bottom: #dcefe9;
    --hotel-standard-icon-color: #0a4d45;
    --guest-bg-color: #f4f7f3;
    --guest-bg-whiteness: 0;
    --guest-bg-whiteness-alpha: 0;
    --guest-bg-overlay-alpha: 0;
    --guest-bg-blur: 0px;
    --guest-bg-blur-scale: 1;
    --guest-glass-bg-alpha: 0.59;
    --guest-glass-strong-bg-alpha: 0.71;
    --guest-glass-blur: 17px;
    --guest-glass-saturate: 145%;
    --guest-glass-border-alpha: 0.26;
    --guest-glass-shadow-alpha: 0.11;
    --guest-glass-highlight-alpha: 0.11;
    --guest-glass-dark-alpha: 0.04;
    --guest-ui-tag-bg: rgba(24, 33, 31, 0.06);
    --guest-ui-tag-text: #54635f;
    --guest-shadow: 0 22px 54px rgba(18, 36, 32, 0.09);
    --guest-shadow-soft: 0 14px 32px rgba(18, 36, 32, 0.06);
}

body {
    background: var(--guest-soft);
}

body:has(.guest-portal-stage) {
    background: var(--guest-bg-color, var(--guest-soft));
}

html:has(body.admin-preview-page),
html.admin-preview-root,
body.admin-preview-page {
    overflow-x: hidden;
    scrollbar-width: none;
    scrollbar-gutter: auto;
    user-select: none;
}

html:has(body.admin-preview-page) *,
html.admin-preview-root *,
body.admin-preview-page * {
    scrollbar-width: none;
}

html:has(body.admin-preview-page)::-webkit-scrollbar,
html:has(body.admin-preview-page) *::-webkit-scrollbar,
html.admin-preview-root::-webkit-scrollbar,
html.admin-preview-root *::-webkit-scrollbar,
body.admin-preview-page::-webkit-scrollbar,
body.admin-preview-page *::-webkit-scrollbar {
    width: 0;
    height: 0;
    background: transparent;
}

html:has(body.admin-preview-page)::-webkit-scrollbar-track,
html:has(body.admin-preview-page) *::-webkit-scrollbar-track,
html:has(body.admin-preview-page)::-webkit-scrollbar-track-piece,
html:has(body.admin-preview-page) *::-webkit-scrollbar-track-piece,
html.admin-preview-root::-webkit-scrollbar-track,
html.admin-preview-root *::-webkit-scrollbar-track,
html.admin-preview-root::-webkit-scrollbar-track-piece,
html.admin-preview-root *::-webkit-scrollbar-track-piece,
body.admin-preview-page::-webkit-scrollbar-track,
body.admin-preview-page *::-webkit-scrollbar-track,
body.admin-preview-page::-webkit-scrollbar-track-piece,
body.admin-preview-page *::-webkit-scrollbar-track-piece {
    background: transparent;
    border: 0;
    box-shadow: none;
}

html:has(body.admin-preview-page)::-webkit-scrollbar-thumb,
html:has(body.admin-preview-page) *::-webkit-scrollbar-thumb,
html.admin-preview-root::-webkit-scrollbar-thumb,
html.admin-preview-root *::-webkit-scrollbar-thumb,
body.admin-preview-page::-webkit-scrollbar-thumb,
body.admin-preview-page *::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(205, 201, 215, 0.72);
    border: 0;
    box-shadow: none;
}

html:has(body.admin-preview-page)::-webkit-scrollbar-thumb:hover,
html:has(body.admin-preview-page) *::-webkit-scrollbar-thumb:hover,
html.admin-preview-root::-webkit-scrollbar-thumb:hover,
html.admin-preview-root *::-webkit-scrollbar-thumb:hover,
body.admin-preview-page::-webkit-scrollbar-thumb:hover,
body.admin-preview-page *::-webkit-scrollbar-thumb:hover {
    background: rgba(226, 222, 235, 0.86);
}

html:has(body.admin-preview-page)::-webkit-scrollbar-corner,
html:has(body.admin-preview-page) *::-webkit-scrollbar-corner,
html.admin-preview-root::-webkit-scrollbar-corner,
html.admin-preview-root *::-webkit-scrollbar-corner,
body.admin-preview-page::-webkit-scrollbar-corner,
body.admin-preview-page *::-webkit-scrollbar-corner {
    background: transparent;
}

.admin-preview-scroll-pill {
    position: fixed;
    top: 0;
    right: 1px;
    z-index: 999;
    width: 4px;
    min-height: 44px;
    border-radius: 999px;
    background: var(--portal-main-font-color, #17211f);
    opacity: 0;
    pointer-events: none;
    transition: opacity 160ms ease;
}

.admin-preview-scroll-pill.is-visible {
    opacity: 0.5;
}

.admin-preview-scroll-pill[hidden] {
    display: none;
}

body.admin-preview-dock-page {
    padding-bottom: calc(88px + env(safe-area-inset-bottom, 0px) + var(--admin-preview-viewport-bottom-inset, 0px));
}

body.admin-preview-wizard-page {
    --admin-preview-viewport-bottom-inset: 72px;
    padding-bottom: calc(88px + env(safe-area-inset-bottom, 0px) + var(--admin-preview-viewport-bottom-inset, 0px));
}

.admin-preview-wizard-footer {
    position: fixed;
    right: auto;
    bottom: max(8px, env(safe-area-inset-bottom, 0px));
    left: 50%;
    z-index: 1200;
    display: grid;
    grid-template-columns: minmax(82px, 1fr) auto;
    align-items: center;
    gap: 10px;
    width: min(calc(100% - 18px), 410px);
    min-height: 64px;
    padding: 10px;
    border: 1px solid rgba(219, 228, 242, 0.92);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.96);
    color: #081444;
    box-shadow: 0 18px 44px rgba(8, 20, 68, 0.16);
    font-family: "Plus Jakarta Sans", "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    pointer-events: auto;
    transform: translateX(-50%);
    backdrop-filter: blur(18px);
}

.admin-preview-wizard-footer-step,
.admin-preview-wizard-footer-actions,
.admin-preview-wizard-button {
    display: flex;
    align-items: center;
}

.admin-preview-wizard-footer-step {
    gap: 9px;
    min-width: 0;
}

.admin-preview-wizard-footer-step > .dashboard-symbol {
    display: none;
}

.admin-preview-wizard-footer-icon {
    display: inline-grid;
    width: 32px;
    height: 32px;
    flex: 0 0 32px;
    place-items: center;
    border: 1px solid rgba(8, 90, 239, 0.12);
    border-radius: 999px;
    background: rgba(8, 90, 239, 0.07);
    color: #085aef;
}

.admin-preview-wizard-footer-icon svg,
.admin-preview-wizard-button svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.admin-preview-wizard-footer-step span:last-child {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.admin-preview-wizard-footer-step small {
    color: #64748b;
    font-size: 0.72rem;
    font-weight: 800;
    line-height: 1.15;
}

.admin-preview-wizard-footer-step strong {
    color: #081444;
    font-size: 0.88rem;
    font-weight: 850;
    line-height: 1.2;
}

.admin-preview-wizard-footer-actions {
    justify-content: flex-end;
    gap: 6px;
}

.admin-preview-wizard-button {
    justify-content: center;
    gap: 6px;
    min-width: 74px;
    min-height: 40px;
    padding: 9px 11px;
    border: 1px solid #dbe4f2;
    border-radius: 8px;
    background: #fff;
    color: #081444;
    font-size: 0.875rem;
    font-weight: 800;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
}

.admin-preview-wizard-button.is-primary {
    border-color: #085aef;
    background: #085aef;
    color: #fff;
    box-shadow: 0 8px 18px rgba(8, 90, 239, 0.18);
}

.admin-preview-wizard-button.is-primary {
    min-width: 126px;
}

@media (max-width: 380px) {
    .admin-preview-wizard-footer {
        grid-template-columns: minmax(72px, 1fr) auto;
        gap: 7px;
        padding: 8px;
    }

    .admin-preview-wizard-footer-step {
        gap: 7px;
    }

    .admin-preview-wizard-footer-icon {
        width: 30px;
        height: 30px;
        flex-basis: 30px;
    }

    .admin-preview-wizard-button {
        min-width: 66px;
        padding-inline: 9px;
    }

    .admin-preview-wizard-button.is-primary {
        min-width: 112px;
    }
}

.guest-portal-stage {
    position: relative;
    min-height: 100vh;
}

.public-activation-overlay {
    position: fixed;
    inset: 0;
    z-index: 60;
    display: grid;
    place-items: center;
    padding: 20px;
    background:
        radial-gradient(circle at center, rgba(255, 255, 255, 0.16), transparent 34%),
        rgba(12, 19, 26, 0.58);
    backdrop-filter: blur(8px) saturate(88%);
}

body:has(.public-activation-overlay) .guest-portal-shell,
body:has(.public-activation-overlay) .guest-footer {
    filter: blur(3px);
    pointer-events: none;
    user-select: none;
}

.public-activation-card {
    display: grid;
    justify-items: center;
    gap: 18px;
    width: min(calc(100vw - 32px), 500px);
    max-width: calc(100% - 32px);
    padding: 28px 24px;
    border: 1px solid rgba(226, 232, 240, 0.94);
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 28px 72px rgba(8, 20, 68, 0.28);
    text-align: center;
}

.public-activation-copy {
    display: grid;
    gap: 10px;
}

.public-activation-copy h1 {
    margin: 0;
    color: #111827;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: clamp(1.12rem, 4.5vw, 1.34rem);
    line-height: 1.12;
    white-space: nowrap;
}

.public-activation-copy p,
.public-activation-powered span {
    margin: 0;
    color: #111827;
    font-size: 0.92rem;
    line-height: 1.52;
}

.public-activation-powered {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding-top: 4px;
}

.public-activation-powered span {
    color: #4b5563;
    font-size: 0.8rem;
    font-weight: 750;
}

.public-activation-powered a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: inherit;
    text-decoration: none;
}

.public-activation-powered img {
    display: block;
    width: 34px;
    height: auto;
    transform: translateY(-2px);
}

.public-activation-powered strong {
    display: inline-flex;
    align-items: baseline;
    font-family: "Carmen Sans", "Plus Jakarta Sans", "Inter", ui-sans-serif, system-ui, sans-serif;
    font-size: 0.92rem;
    font-weight: 800;
    letter-spacing: -0.035em;
    line-height: 1;
}

.public-activation-powered strong span:first-child {
    color: #081444;
}

.public-activation-powered strong span:last-child {
    color: #085AEF;
}

@media (max-width: 520px) {
    .public-activation-overlay {
        padding: 16px;
    }

    .public-activation-card {
        width: min(100%, 360px);
        max-width: 100%;
        padding: 24px 18px;
        border-radius: 20px;
    }

    .public-activation-copy h1 {
        white-space: normal;
        font-size: 1.18rem;
    }
}

.guest-portal-stage-ambient,
.guest-portal-canvas-bg {
    display: none;
}

.guest-shell {
    position: relative;
    isolation: isolate;
    width: min(100% - 16px, 920px);
    margin: 0 auto;
    padding: 14px 0 44px;
    min-width: 0;
    max-width: 100%;
    overflow-x: visible;
}

.guest-shell::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        radial-gradient(circle at top left, var(--guest-theme-soft), transparent 28%),
        radial-gradient(circle at top right, var(--guest-theme-soft), transparent 24%),
        linear-gradient(180deg, var(--guest-theme-soft), rgba(245, 247, 243, 0) 280px),
        var(--guest-soft);
}

.guest-hero,
.page-hero {
    padding: 22px;
    border: 1px solid rgba(221, 229, 224, 0.82);
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.92));
    box-shadow: var(--guest-shadow);
}

.hero-topline,
.page-hero-topline {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: flex-start;
    justify-content: space-between;
}

.guest-brand {
    --header-title-font-size: clamp(1.85rem, 8vw, 3.4rem);
    --header-title-line-height: 1.16;
    --header-title-line-gap: 0.24rem;
    --header-title-line-box: calc(var(--header-title-font-size) * var(--header-title-line-height));
    --header-icon-max-size: calc(var(--header-title-line-box) + var(--header-title-line-box) + var(--header-title-line-gap));
    --header-icon-size: min(56px, var(--header-icon-max-size));
    display: flex;
    align-items: center;
    gap: 12px;
}

.admin-preview-ui {
    --admin-preview-surface: #171922;
    --admin-preview-surface-border: rgba(255, 255, 255, 0.14);
    position: fixed;
    left: 50%;
    bottom: calc(max(14px, env(safe-area-inset-bottom, 0px)) + var(--admin-preview-viewport-bottom-inset, 0px));
    z-index: 1000;
    display: grid;
    width: min(calc(100% - 18px), 410px);
    gap: 8px;
    font-family: "Plus Jakarta Sans", "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    transform: translateX(-50%);
    pointer-events: none;
}

.admin-preview-dock,
.admin-preview-theme-tray {
    pointer-events: auto;
    border: 1px solid var(--admin-preview-surface-border);
    background: var(--admin-preview-surface);
    color: #fff;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.22);
}

.admin-preview-dock {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    min-height: 48px;
    padding: 7px;
    border-radius: 999px;
}

.admin-preview-label,
.admin-preview-button,
.admin-preview-theme-option,
.admin-preview-category-option {
    font: inherit;
    font-size: 0.78rem;
    font-weight: 820;
}

.admin-preview-label {
    padding: 0 6px 0 8px;
    color: rgba(255, 255, 255, 0.84);
    white-space: nowrap;
}

.admin-preview-button,
.admin-preview-theme-option,
.admin-preview-category-option {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.09);
    color: #fff;
    text-decoration: none;
    cursor: pointer;
}

.admin-preview-button {
    min-width: 68px;
    padding: 7px 12px;
    border-radius: 999px;
}

.admin-preview-apply-form {
    display: contents;
}

.admin-preview-apply-form[hidden] {
    display: none;
}

.admin-preview-button:hover,
.admin-preview-button:focus-visible,
.admin-preview-theme-option:hover,
.admin-preview-theme-option:focus-visible {
    outline: 0;
    border-color: rgba(255, 255, 255, 0.34);
    background: rgba(255, 255, 255, 0.16);
}

.admin-preview-button.is-active {
    border-color: rgba(255, 255, 255, 0.62);
    background: #fff;
    color: #17211f;
}

.admin-preview-theme-tray {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    padding: 8px;
    border-radius: 18px;
}

.admin-preview-theme-tray[hidden] {
    display: none;
}

.admin-preview-theme-scroller {
    position: relative;
    display: block;
    min-width: 0;
}

.admin-preview-theme-scroller::before,
.admin-preview-theme-scroller::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 1;
    width: 18px;
    pointer-events: none;
    opacity: 0;
    transition: opacity 120ms ease;
}

.admin-preview-theme-scroller::before {
    left: 0;
    background: linear-gradient(90deg, var(--admin-preview-surface) 0, rgba(23, 25, 34, 0));
}

.admin-preview-theme-scroller::after {
    right: 0;
    background: linear-gradient(270deg, var(--admin-preview-surface) 0, rgba(23, 25, 34, 0));
}

.admin-preview-theme-options,
.admin-preview-category-options {
    --theme-scroll-fade-left: #000;
    --theme-scroll-fade-right: #000;
    display: flex;
    gap: 8px;
    min-width: 0;
    overflow-x: auto;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -webkit-mask-image: linear-gradient(90deg, var(--theme-scroll-fade-left), #000 6px, #000 calc(100% - 6px), var(--theme-scroll-fade-right));
    mask-image: linear-gradient(90deg, var(--theme-scroll-fade-left), #000 6px, #000 calc(100% - 6px), var(--theme-scroll-fade-right));
}

.admin-preview-theme-options::-webkit-scrollbar,
.admin-preview-category-options::-webkit-scrollbar {
    display: none;
}

.admin-preview-theme-option {
    flex: 0 0 auto;
    padding: 7px 12px;
    border-radius: 999px;
    white-space: nowrap;
}

.admin-preview-theme-option.is-selected {
    border-color: rgba(255, 255, 255, 0.62);
    background: #fff;
    color: #17211f;
}

.admin-preview-theme-card-options {
    align-items: stretch;
    padding: 1px;
}

.admin-preview-theme-card {
    flex-basis: 138px;
    display: grid;
    grid-template-rows: 58px minmax(0, auto);
    align-items: stretch;
    justify-content: stretch;
    gap: 0;
    min-height: 108px;
    padding: 0;
    border-color: rgba(255, 255, 255, 0.12);
    border-radius: 10px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.025)),
        #111723;
    color: #fff;
    overflow: hidden;
    text-align: left;
    white-space: normal;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 10px 22px rgba(0, 0, 0, 0.18);
}

.admin-preview-theme-card[hidden] {
    display: none;
}

.admin-preview-theme-card.is-selected {
    border-color: #0b6bff;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.035)),
        #151c2b;
    color: #fff;
    box-shadow:
        inset 0 0 0 1px rgba(11, 107, 255, 0.76),
        0 0 0 1px rgba(11, 107, 255, 0.28),
        0 12px 26px rgba(11, 107, 255, 0.18);
}

.admin-preview-theme-card-preview {
    position: relative;
    display: grid;
    place-items: center;
    min-width: 0;
    height: 58px;
    border-radius: 0;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--preview-card-accent, #0f4f43) 24%, transparent), transparent 56%),
        linear-gradient(135deg, var(--preview-card-bg, #f4f7f3), var(--preview-card-container, #fff));
    color: var(--preview-card-accent, #0f4f43);
    overflow: hidden;
}

.admin-preview-theme-card-preview img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.admin-preview-theme-card-preview > span {
    position: relative;
    z-index: 1;
    color: currentColor;
    font-size: 0.9rem;
    font-weight: 800;
    letter-spacing: 0;
}

.admin-preview-theme-card-placeholder {
    display: grid;
    place-items: center;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.admin-preview-theme-card-placeholder .dashboard-symbol {
    color: var(--preview-card-accent, #0f4f43);
    font-family: "Material Symbols Outlined";
    font-size: 34px;
    font-style: normal;
    font-weight: normal;
    line-height: 1;
    letter-spacing: normal;
    text-transform: none;
    white-space: nowrap;
    word-wrap: normal;
    direction: ltr;
    -webkit-font-feature-settings: "liga";
    -webkit-font-smoothing: antialiased;
    font-feature-settings: "liga";
    font-variation-settings: "FILL" 1, "wght" 450, "GRAD" 0, "opsz" 32;
}

.admin-preview-theme-card-copy {
    display: grid;
    gap: 6px;
    min-width: 0;
    padding: 7px 8px 8px;
}

.admin-preview-theme-card-copy > span {
    min-width: 0;
    overflow: hidden;
    color: inherit;
    font-size: 0.76rem;
    font-weight: 820;
    line-height: 1.15;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.admin-preview-theme-card-palette {
    display: flex;
    gap: 4px;
    min-width: 0;
}

.admin-preview-theme-card-palette i {
    width: 10px;
    height: 10px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 999px;
    background: var(--preview-card-accent, #0f4f43);
}

.admin-preview-theme-card-palette i:nth-child(1) {
    background: var(--preview-card-container, #fff);
}

.admin-preview-theme-card-palette i:nth-child(2) {
    background: var(--preview-card-text, #18362f);
}

.admin-preview-theme-card-palette i:nth-child(3) {
    background: var(--preview-card-accent, #0f4f43);
}

.admin-preview-theme-card-palette i:nth-child(4) {
    background: var(--preview-card-icon, #0a4d45);
}

.admin-preview-category-options {
    gap: 7px;
}

.admin-preview-category-option {
    flex: 0 0 auto;
    padding: 7px 11px;
    border-radius: 999px;
    white-space: nowrap;
}

.admin-preview-category-option.is-selected {
    border-color: rgba(255, 255, 255, 0.62);
    background: #fff;
    color: #17211f;
}

.admin-preview-theme-scroller.has-left-overflow .admin-preview-theme-options {
    --theme-scroll-fade-left: transparent;
}

.admin-preview-theme-scroller.has-right-overflow .admin-preview-theme-options {
    --theme-scroll-fade-right: transparent;
}

.admin-preview-theme-scroller.has-left-overflow::before,
.admin-preview-theme-scroller.has-right-overflow::after {
    opacity: 1;
}

.admin-preview-theme-arrow {
    position: absolute;
    top: 50%;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    background: var(--admin-preview-surface);
    color: #fff;
    cursor: pointer;
    transform: translateY(-50%);
}

.admin-preview-theme-arrow[data-preview-theme-scroll="left"] {
    left: 0;
}

.admin-preview-theme-arrow[data-preview-theme-scroll="right"] {
    right: 0;
}

.admin-preview-theme-arrow[hidden] {
    display: none;
}

.admin-preview-theme-arrow span {
    font-size: 1.3rem;
    line-height: 1;
    transform: translateY(-1px);
}

.page-hero-main {
    display: grid;
    gap: 8px;
    min-width: 0;
    flex: 1 1 360px;
    width: 100%;
}

.hotel-logo,
.hotel-logo-fallback {
    width: var(--header-icon-size, 56px);
    height: var(--header-icon-size, 56px);
    flex: 0 0 auto;
    border-radius: 18px;
}

.hotel-logo {
    object-fit: cover;
    background: #fff;
    border: 1px solid rgba(221, 229, 224, 0.9);
}

.hotel-logo-fallback {
    --icon-badge-base-size: var(--header-icon-size, 56px);
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    display: grid;
    place-items: center;
    background:
        linear-gradient(
            180deg,
            rgba(var(--hotel-standard-icon-bg-top-rgb, 238, 248, 244), var(--hotel-standard-icon-bg-visible-alpha, var(--hotel-standard-icon-bg-opacity-alpha, 1))),
            rgba(var(--hotel-standard-icon-bg-bottom-rgb, 220, 239, 233), var(--hotel-standard-icon-bg-visible-alpha, var(--hotel-standard-icon-bg-opacity-alpha, 1)))
        );
    color: var(--hotel-standard-icon-color);
    box-shadow: 0 10px 22px rgba(18, 36, 32, 0.06);
}

.guest-eyebrow {
    margin: 0 0 8px;
    color: var(--guest-ui-primary);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.guest-hero h1,
.page-hero h1 {
    margin: 0;
    color: var(--guest-ink);
    font-size: calc(clamp(1.85rem, 8vw, 3.4rem) * var(--portal-hero-scale));
    font-weight: var(--portal-hero-weight);
    line-height: var(--header-title-line-height, 1.16);
    letter-spacing: -0.05em;
}

.hotel-description,
.page-subtitle {
    margin: 14px 0 0;
    max-width: 760px;
    color: var(--guest-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
    line-height: 1.58;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.language-dropdown {
    display: grid;
    position: relative;
    place-items: center;
    min-width: 52px;
    min-height: 34px;
    border: 1px solid var(--guest-line);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 247, 0.98));
    color: var(--guest-ink);
    box-shadow: none;
}

.language-dropdown-label {
    grid-area: 1 / 1;
    padding: 0 12px;
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: 1.1;
    pointer-events: none;
}

.language-dropdown select {
    grid-area: 1 / 1;
    width: 100%;
    min-width: 100%;
    min-height: 34px;
    padding: 0;
    border: 0;
    border-radius: inherit;
    background: transparent;
    color: transparent;
    font: inherit;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
}

.language-dropdown select option {
    color: var(--guest-ink);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    text-align: center;
}

.language-dropdown:focus-within {
    outline: 0;
    border-color: var(--guest-ui-primary);
    box-shadow: 0 0 0 4px var(--guest-ui-primary-soft);
}

.language-dropdown-compact {
    min-width: 52px;
    min-height: 32px;
    border-radius: 999px;
    background-color: rgba(255, 255, 255, 0.84);
    backdrop-filter: blur(10px);
}

.language-dropdown-compact select {
    min-height: 32px;
}

.guest-actions {
    display: grid;
    gap: 10px;
}

.guest-action-row {
    display: flex;
    gap: calc(10px * var(--action-tight-scale, 1));
    align-items: stretch;
    min-width: 0;
    --action-tight-scale: 1;
}

.guest-action {
    flex: var(--action-grow, 100) 1 0;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: calc(var(--action-gap, 10px) * var(--action-tight-scale, 1) * var(--hotel-standard-icon-gap-factor, 1));
    min-width: 0;
    min-height: calc(var(--action-min-height, 0px) * var(--action-tight-scale, 1));
    padding:
        calc(var(--action-padding-y, 12px) * var(--action-tight-scale, 1))
        calc(var(--action-padding-x, 14px) * var(--action-tight-scale, 1));
    border: 1px solid rgba(var(--portal-main-font-rgb, 23, 37, 31), 0.14);
    border-radius: 14px;
    background: rgba(var(--portal-container-color-rgb, 255, 255, 255), var(--portal-container-transparency, 0.59));
    color: var(--portal-main-font-color, var(--guest-ink));
    text-decoration: none;
    cursor: pointer;
    font: inherit;
    text-align: left;
    transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.guest-action:hover,
.guest-action:focus-visible {
    transform: translateY(-1px);
    border-color: var(--portal-highlight-color, var(--guest-ui-primary));
}

.guest-actions .guest-action-icon {
    --action-title-base-size: 0.98rem;
    --action-title-line-height: 1.2;
    --action-title-line-gap: 3px;
    --action-icon-radius: 12px;
    --icon-badge-base-size: calc((var(--action-title-base-size) * var(--action-title-line-height) * 2) + var(--action-title-line-gap));
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    flex: 0 0 auto;
    width: var(--icon-badge-size);
    min-width: var(--icon-badge-size);
    max-width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    min-height: var(--icon-badge-size);
    max-height: var(--icon-badge-size);
    padding: 0;
    border-radius: calc(var(--icon-badge-size) * 0.32);
}

.guest-actions .guest-action-icon svg {
    width: calc(var(--icon-badge-size) * 0.56);
    height: calc(var(--icon-badge-size) * 0.56);
}

.guest-actions .guest-action-icon.standard-icon-badge svg {
    width: var(--hotel-standard-icon-action-glyph-size, calc(var(--icon-badge-size) * 0.56));
    height: var(--hotel-standard-icon-action-glyph-size, calc(var(--icon-badge-size) * 0.56));
}

.guest-action-copy {
    display: grid;
    gap: calc(3px * var(--action-tight-scale, 1));
    min-width: 0;
    text-align: left;
    justify-items: start;
}

.guest-action-copy strong,
.guest-action-copy small {
    overflow-wrap: anywhere;
}

.guest-action-copy strong {
    font-family: var(--portal-title-font);
    font-size: calc(var(--action-title-base-size, 0.98rem) * var(--action-tight-scale, 1) * var(--portal-title-scale));
    font-weight: var(--portal-title-weight);
    line-height: var(--action-title-line-height, 1.2);
    color: var(--portal-main-font-color, var(--guest-ink));
}

.guest-action-copy-multiline {
    text-align: left;
    justify-items: start;
}

.guest-action-copy small {
    color: var(--portal-main-font-muted, rgba(23, 37, 31, 0.68));
    font-size: calc(0.84rem * var(--action-tight-scale, 1) * var(--portal-text-scale));
    line-height: 1.35;
}

.guest-actions-layout-large_cards .guest-action {
    --action-min-height: 62px;
    align-items: center;
}

.guest-actions-layout-large_cards .guest-action-icon {
    --action-title-base-size: 0.98rem;
    --action-title-line-height: 1.2;
    --action-icon-radius: 13px;
}

.guest-actions-centered .guest-action:not(.guest-action-no-icon) {
    justify-content: flex-start;
}

.guest-actions-centered .guest-action-copy {
    text-align: center;
    justify-items: center;
}

.guest-actions-no-icon-bg .guest-action-icon {
    background: transparent !important;
    background-image: none !important;
    border: 0;
    box-shadow: none !important;
}

.guest-actions-no-icon-bg .guest-action-icon svg {
    width: 82%;
    height: 82%;
}

.guest-actions-layout-compact_buttons .guest-action {
    --action-min-height: 46px;
    --action-gap: 6px;
    --action-padding-y: 5px;
    --action-padding-x: 6px;
    align-items: center;
    border-radius: 15px;
}

.guest-actions-layout-compact_buttons .guest-action-icon {
    --action-title-base-size: 0.9rem;
    --action-title-line-height: 1.22;
    --action-icon-radius: 9px;
    align-self: center;
}

.guest-actions-layout-compact_buttons .guest-action-copy small {
    display: none;
}

.guest-actions-layout-divider_row .guest-action-copy strong {
    --action-title-base-size: 0.9rem;
    --action-title-line-height: 1.22;
    font-family: var(--portal-text-font);
    font-weight: max(var(--portal-text-weight), 500);
}

.guest-actions-layout-compact_buttons .guest-action-copy strong {
    --action-title-base-size: 0.98rem;
    --action-title-line-height: 1.22;
    font-family: var(--portal-text-font);
    font-size: calc(var(--action-title-base-size) * var(--action-tight-scale, 1) * var(--portal-text-scale));
    font-weight: max(var(--portal-text-weight), 500);
}

.guest-actions-layout-divider_row {
    gap: 0;
}

.guest-actions-layout-divider_row .guest-action-row {
    position: relative;
    gap: 0;
}

.guest-actions-layout-divider_row .guest-action {
    --action-min-height: 46px;
    --action-gap: 5px;
    --action-padding-y: 5px;
    --action-padding-x: 6px;
    position: relative;
    align-items: center;
    border: 0;
    border-radius: 0;
    background: transparent;
    text-align: center;
    transform: none;
}

.guest-actions-layout-divider_row .guest-action + .guest-action::before {
    content: "";
    position: absolute;
    left: 0;
    top: 15%;
    width: 1px;
    height: 70%;
    background: rgba(var(--portal-main-font-rgb, 23, 37, 31), 0.12);
    pointer-events: none;
}

.guest-actions-layout-divider_row .guest-action-icon {
    --action-title-base-size: 0.9rem;
    --action-title-line-height: 1.22;
    --action-icon-radius: 8px;
    align-self: center;
}

.guest-actions-layout-divider_row .guest-action-copy small {
    display: none;
}

.guest-action-no-icon {
    justify-content: center;
    align-items: center;
    text-align: center;
}

.guest-action-no-icon .guest-action-copy {
    text-align: center;
    justify-items: center;
}

.guest-action-disabled {
    cursor: not-allowed;
    opacity: 0.62;
}

.guest-action.is-copied {
    border-color: var(--portal-highlight-color, var(--guest-ui-primary));
}

.page-hero-language-desktop {
    border-color: var(--portal-glass-border);
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
            rgba(255, 255, 255, 0.04)
        ),
        var(--portal-glass-bg);
    background-position:
        0 0;
    background-size:
        100% 100%;
    background-repeat: no-repeat;
    color: var(--portal-main-font-color);
    box-shadow:
        var(--portal-shadow-soft),
        inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
    backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    -webkit-backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
}

.guest-summary-grid {
    display: grid;
    gap: 10px;
    margin-top: 16px;
}

.guest-summary-card {
    display: grid;
    gap: 4px;
    padding: 14px;
    border: 1px solid rgba(221, 229, 224, 0.84);
    border-radius: 18px;
    background: rgba(248, 251, 248, 0.92);
    box-shadow: var(--guest-shadow-soft);
}

.guest-summary-card span {
    color: var(--guest-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-sm);
    font-weight: max(var(--portal-text-weight), 500);
    text-transform: uppercase;
}

.guest-summary-card strong {
    color: var(--guest-ink);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: max(var(--portal-text-weight), 500);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.guest-summary-card.is-link strong {
    color: var(--guest-ui-primary);
}

.portal-card-grid,
.content-stack {
    display: grid;
    gap: 14px;
    margin-top: 14px;
    min-width: 0;
}

.portal-card-grid-compact {
    gap: 12px;
}

.portal-card {
    --header-title-font-size: 1.2rem;
    --header-title-line-height: 1.12;
    --header-title-line-gap: 0.2rem;
    --header-title-line-box: 1.344rem;
    --header-icon-max-size: calc(var(--header-title-line-box) + var(--header-title-line-box) + var(--header-title-line-gap));
    --header-icon-size: min(48px, var(--header-icon-max-size, 48px));
    --icon-badge-base-size: var(--header-icon-size);
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    display: grid;
    grid-template-columns: minmax(0, var(--icon-badge-size)) minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    min-height: 0;
    padding: 18px;
    border: 1px solid var(--guest-line);
    border-radius: 20px;
    background: var(--guest-card);
    box-shadow: var(--guest-shadow-soft);
    transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.portal-card:hover {
    transform: translateY(-2px);
    border-color: var(--guest-theme-soft);
    box-shadow: var(--guest-shadow);
}

.portal-card-compact {
    --header-title-font-size: 1.06rem;
    --header-icon-size: min(44px, var(--header-icon-max-size));
    --icon-badge-base-size: var(--header-icon-size);
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    grid-template-columns: minmax(0, var(--icon-badge-size)) minmax(0, 1fr);
    gap: 10px;
    padding: 16px;
    border-radius: 18px;
}

.portal-card-compact .portal-card-icon,
.portal-element-link-card .portal-card-icon {
    --icon-badge-base-size: var(--header-icon-size, 44px);
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    border-radius: calc(var(--icon-badge-size) * 0.32);
}

.portal-card-compact h2 {
    font-size: 1.06rem;
}

.portal-card-compact p {
    font-size: 0.88rem;
}

.portal-card-icon {
    display: grid;
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex: 0 0 var(--icon-badge-size);
    align-self: start;
    justify-self: start;
    place-items: center;
    padding: 0;
    overflow: hidden;
    border-radius: calc(var(--icon-badge-size) * 0.32);
    background:
        linear-gradient(
            180deg,
            rgba(var(--hotel-standard-icon-bg-top-rgb, 238, 248, 244), var(--hotel-standard-icon-bg-visible-alpha, var(--hotel-standard-icon-bg-opacity-alpha, 1))),
            rgba(var(--hotel-standard-icon-bg-bottom-rgb, 220, 239, 233), var(--hotel-standard-icon-bg-visible-alpha, var(--hotel-standard-icon-bg-opacity-alpha, 1)))
        );
    color: var(--hotel-standard-icon-color);
    box-shadow: 0 10px 22px rgba(18, 36, 32, 0.06);
}

.portal-card-compact > .portal-card-icon {
    transform: translateY(-6px);
}

.portal-card-compact > .portal-card-icon + * {
    transform: translateY(4px);
}

.portal-element-link-card.portal-card > .portal-card-icon,
.portal-element-link-card.portal-card > .portal-element-heading,
.portal-element-heading.has-icon > .portal-card-icon,
.portal-element-heading.has-icon .portal-element-heading-copy {
    transform: none;
}

.hotel-logo-fallback,
.page-hero-icon-fallback,
.icon-letter-fallback {
    font-size: calc(var(--icon-badge-size, 48px) * var(--hotel-standard-icon-letter-ratio, 0.38));
    font-weight: 500;
    line-height: 1;
    letter-spacing: -0.01em;
}

.standard-icon-badge {
    place-items: center;
    background:
        linear-gradient(
            180deg,
            rgba(var(--hotel-standard-icon-bg-top-rgb, 238, 248, 244), var(--hotel-standard-icon-bg-visible-alpha, var(--hotel-standard-icon-bg-opacity-alpha, 1))),
            rgba(var(--hotel-standard-icon-bg-bottom-rgb, 220, 239, 233), var(--hotel-standard-icon-bg-visible-alpha, var(--hotel-standard-icon-bg-opacity-alpha, 1)))
        ) !important;
    color: var(--hotel-standard-icon-color) !important;
}

.standard-icon-badge svg {
    flex: 0 0 auto;
    width: var(--hotel-standard-icon-glyph-size, 64%);
    height: var(--hotel-standard-icon-glyph-size, 64%);
    display: block;
    stroke: currentColor;
}

.custom-image-icon-badge img {
    width: 100%;
    height: 100%;
    border-radius: inherit;
    object-fit: cover;
}

.portal-card-icon.standard-icon-badge,
.portal-card-icon.custom-image-icon-badge,
.page-hero-icon.standard-icon-badge,
.page-hero-icon.custom-image-icon-badge {
    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.portal-card h2 {
    margin: 0;
    color: var(--guest-ink);
    font-family: var(--portal-title-font);
    font-size: var(--portal-type-h3);
    font-weight: var(--portal-title-weight);
    line-height: 1.12;
    letter-spacing: -0.03em;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.portal-card-kicker {
    margin: 0 0 8px;
    color: var(--guest-ui-tag-text);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.portal-card p {
    margin: 6px 0 0;
    color: var(--guest-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
    line-height: 1.48;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.portal-card-highlights {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.portal-card-highlights span {
    display: inline-flex;
    align-items: center;
    padding: 6px 10px;
    border-radius: 999px;
    background: var(--guest-ui-tag-bg);
    color: var(--guest-ui-tag-text);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.translation-note {
    display: inline-flex;
    margin-top: 10px;
    color: var(--guest-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-sm);
    font-weight: var(--portal-text-weight);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.detail-note {
    margin-bottom: 0;
}

.back-link {
    display: inline-flex;
    margin-bottom: 12px;
    color: var(--guest-ui-primary);
    font-family: var(--portal-title-font);
    font-weight: var(--portal-title-weight);
    font-size: var(--portal-type-title-md);
    text-decoration: none;
}

.back-link-icon {
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    margin-bottom: 8px;
    border: 1px solid color-mix(in srgb, var(--guest-ui-primary) 12%, transparent);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    transition: border-color 160ms ease, background 160ms ease, color 160ms ease, transform 160ms ease;
}

.page-hero-back-desktop,
.page-hero-mobile-bar .page-hero-back-mobile {
    margin-bottom: 0;
    border-color: var(--portal-glass-border);
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
            rgba(255, 255, 255, 0.04)
        ),
        var(--portal-glass-bg);
    color: var(--portal-main-font-color);
    box-shadow:
        var(--portal-shadow-soft),
        inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
    backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    -webkit-backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
}

.back-link-icon svg {
    width: 17px;
    height: 17px;
}

.back-link-icon:hover,
.back-link-icon:focus-visible {
    transform: translateY(-1px);
    border-color: var(--portal-divider-color);
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
            rgba(255, 255, 255, 0.04)
        ),
        var(--portal-glass-bg);
    color: var(--portal-main-font-color);
    box-shadow:
        var(--portal-shadow),
        inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
}

.portal-top-card {
    padding: 18px 18px 16px;
    border: 1px solid var(--guest-line);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.76);
    box-shadow: none;
}

.portal-top-card .hero-topline,
.portal-top-card .page-hero-topline {
    gap: calc(12px * var(--hotel-standard-icon-gap-factor, 1));
}

.portal-top-card .guest-brand {
    --header-title-font-size: clamp(1.6rem, 6vw, 2.4rem);
    --header-title-line-height: 1.16;
    --header-icon-size: min(48px, var(--header-icon-max-size));
    gap: 10px;
}

.portal-top-card .page-hero-title-row {
    --header-title-font-size: clamp(1.6rem, 6vw, 2.4rem);
    --header-title-line-height: 1.16;
    --header-icon-size: min(52px, var(--header-icon-max-size));
}

.portal-top-card .hotel-logo,
.portal-top-card .hotel-logo-fallback {
    --icon-badge-base-size: var(--header-icon-size, 48px);
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    border-radius: calc(var(--icon-badge-size) * 0.32);
}

.portal-top-card .hotel-logo-fallback {
    box-shadow: none;
}

.portal-top-card .guest-eyebrow {
    margin-bottom: 6px;
}

.portal-top-card .language-dropdown-compact {
    min-width: 52px;
    min-height: 30px;
    border-color: var(--guest-line);
    background-color: rgba(255, 255, 255, 0.72);
}

.portal-top-card .language-dropdown-compact select {
    min-height: 30px;
}

.page-hero-heading-row {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    min-width: 0;
}

.page-hero-layout {
    display: block;
    position: relative;
    width: 100%;
    min-width: 0;
    overflow: visible;
    --desktop-back-left: 8px;
    --mobile-bar-left: 0px;
    --mobile-bar-width: 100%;
}

.page-hero-layout > .portal-top-card,
.page-hero-layout > .guest-hero,
.page-hero-layout > .page-hero {
    display: block;
    width: 100%;
    min-width: 0;
}

.page-hero-back-desktop {
    display: none;
}

.page-hero-back-mobile {
    display: none;
}

.page-hero-copy {
    display: grid;
    gap: 6px;
    min-width: 0;
    flex: 1 1 auto;
    width: 100%;
    max-width: none;
}

.page-hero-heading-row h1,
.page-hero-copy h1 {
    min-width: 0;
}

.page-hero-title-row {
    --header-title-font-size: clamp(1.6rem, 6vw, 2.4rem);
    --header-title-line-height: 1.16;
    --header-title-line-gap: 0.24rem;
    --header-title-line-box: calc(var(--header-title-font-size) * var(--header-title-line-height));
    --header-icon-max-size: calc(var(--header-title-line-box) + var(--header-title-line-box) + var(--header-title-line-gap));
    --header-icon-size: min(52px, var(--header-icon-max-size));
    --portal-hero-shadow-visual-height: calc(var(--header-title-line-box) * 1.48 + (var(--portal-hero-shadow-size, 0) * 0.22px));
    position: relative;
    isolation: isolate;
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.page-hero-title-row h1:not(.page-hero-title-lines-enhanced)::before {
    content: "";
    position: absolute;
    z-index: 0;
    left: 50%;
    top: 55%;
    width: max(
        calc(var(--header-title-font-size) * 9.2),
        calc(100% + (var(--portal-hero-shadow-size, 0) * 2.2px))
    );
    height: calc(var(--header-title-line-box) * 2.05 + (var(--portal-hero-shadow-size, 0) * 0.46px));
    padding: 10px 18px;
    box-sizing: content-box;
    transform: translate(-50%, -50%);
    --portal-hero-shadow-strength: calc(
        (var(--portal-hero-shadow-size, 0) * 0.57%) +
        min(calc(var(--portal-hero-shadow-size, 0) * 3.5%), 28%)
    );
    background: radial-gradient(
        ellipse 61% 72% at center 50%,
        color-mix(in srgb, var(--portal-hero-shadow-color, #000000) var(--portal-hero-shadow-strength), transparent) 0%,
        color-mix(in srgb, var(--portal-hero-shadow-color, #000000) calc(var(--portal-hero-shadow-strength) * 0.94), transparent) 26%,
        color-mix(in srgb, var(--portal-hero-shadow-color, #000000) calc(var(--portal-hero-shadow-strength) * 0.55), transparent) 48%,
        color-mix(in srgb, var(--portal-hero-shadow-color, #000000) calc(var(--portal-hero-shadow-strength) * 0.18), transparent) 68%,
        transparent 88%
    );
    background-position: center;
    background-repeat: no-repeat;
    background-size: 100% var(--portal-hero-shadow-visual-height);
    -webkit-mask-image: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.22) 28%, #000 62%, #000 100%);
    mask-image: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.22) 28%, #000 62%, #000 100%);
    pointer-events: none;
}

.page-hero-title-row h1:not(.page-hero-title-lines-enhanced)::after {
    content: "";
    position: absolute;
    z-index: 0;
    left: 50%;
    top: 55%;
    width: max(
        calc(var(--header-title-font-size) * 9.2),
        calc(100% + (var(--portal-hero-shadow-size, 0) * 2.2px))
    );
    height: calc(var(--header-title-line-box) * 2.05 + (var(--portal-hero-shadow-size, 0) * 0.46px));
    transform: translate(-50%, -50%);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    -webkit-mask-image:
        linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.22) 28%, #000 62%, #000 100%),
        radial-gradient(ellipse 61% 72% at center 50%, #000 0%, #000 26%, rgba(0, 0, 0, 0.72) 48%, rgba(0, 0, 0, 0.24) 68%, transparent 88%);
    mask-image:
        linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.22) 28%, #000 62%, #000 100%),
        radial-gradient(ellipse 61% 72% at center 50%, #000 0%, #000 26%, rgba(0, 0, 0, 0.72) 48%, rgba(0, 0, 0, 0.24) 68%, transparent 88%);
    -webkit-mask-composite: source-in;
    mask-composite: intersect;
    pointer-events: none;
}

.page-hero-title-row h1 {
    position: relative;
    isolation: isolate;
    min-width: 0;
    flex: 0 1 auto;
    width: max-content;
    max-width: 100%;
    font-size: calc(var(--header-title-font-size) * var(--portal-hero-scale));
    font-weight: var(--portal-hero-weight);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.page-hero-title-row h1.page-hero-title-lines-enhanced {
    width: min(100%, var(--hero-title-enhanced-width, 100%));
    max-width: none !important;
    flex: 0 0 auto !important;
    contain: layout style;
}

.page-hero-title-text {
    position: relative;
    z-index: 1;
    display: inline;
    color: inherit;
    font-family: inherit;
    font-weight: inherit;
}

.page-hero-title-lines-enhanced .page-hero-title-text {
    display: inline-block;
    width: min(100%, var(--hero-title-enhanced-width, 100%));
    overflow: visible;
}

.page-hero-effect-lines-enhanced .page-hero-effect-text {
    display: block;
    width: 100%;
    max-width: 100%;
    overflow: visible;
    text-align: center;
}

.page-hero-title-line,
.page-hero-effect-line {
    position: relative;
    isolation: isolate;
    display: flex;
    justify-content: center;
    width: max-content;
    max-width: 100%;
    margin-inline: auto;
    text-align: center;
    white-space: nowrap;
}

.guest-portal-shell .portal-top-card-banner .page-hero-title-line,
.guest-portal-shell .portal-top-card-no-icon .page-hero-title-line,
.guest-portal-shell .portal-top-card-banner .page-hero-effect-line,
.guest-portal-shell .portal-top-card-no-icon .page-hero-effect-line {
    margin-inline: auto;
}

.page-hero-title-line::before,
.page-hero-title-line::after,
.page-hero-effect-line::before,
.page-hero-effect-line::after {
    --portal-hero-line-scale: clamp(0.38, calc(1em / 42px), 1);
    --portal-hero-line-halo-x: min(
        max(
            calc(100% * (0.48 + (0.22 * var(--portal-hero-line-scale)))),
            calc(1em * (2.82 + (0.86 * var(--portal-hero-line-scale))))
        ),
        max(
            calc(var(--header-title-font-size, 1em) * 1.42),
            calc(var(--portal-hero-shadow-size, 0) * 2.28px * var(--portal-hero-line-scale))
        )
    );
    content: "";
    position: absolute;
    z-index: 0;
    left: 50%;
    top: 60%;
    width: calc(100% + var(--portal-hero-line-halo-x));
    height: calc(1em * 1.34 + var(--portal-hero-line-shadow-y, calc(var(--portal-hero-shadow-size, 0) * 0.28px * var(--portal-hero-line-scale))));
    transform: translate(-50%, -50%);
    pointer-events: none;
}

.page-hero-title-line::before,
.page-hero-effect-line::before {
    --portal-hero-shadow-strength: calc(
        (var(--portal-hero-shadow-size, 0) * 0.57%) +
        min(calc(var(--portal-hero-shadow-size, 0) * 3.5%), 28%)
    );
    background: radial-gradient(
        ellipse 86% 58% at center 50%,
        color-mix(in srgb, var(--portal-hero-shadow-color, #000000) var(--portal-hero-shadow-strength), transparent) 0%,
        color-mix(in srgb, var(--portal-hero-shadow-color, #000000) calc(var(--portal-hero-shadow-strength) * 0.94), transparent) 26%,
        color-mix(in srgb, var(--portal-hero-shadow-color, #000000) calc(var(--portal-hero-shadow-strength) * 0.55), transparent) 48%,
        color-mix(in srgb, var(--portal-hero-shadow-color, #000000) calc(var(--portal-hero-shadow-strength) * 0.18), transparent) 68%,
        transparent 88%
    );
    background-position: center;
    background-repeat: no-repeat;
    background-size: 100% var(--portal-hero-shadow-visual-height, calc(1em * 1.48 + (var(--portal-hero-shadow-size, 0) * 0.22px)));
    -webkit-mask-image:
        linear-gradient(90deg, transparent 0%, rgba(0, 0, 0, 0.58) 8%, #000 16%, #000 84%, rgba(0, 0, 0, 0.58) 92%, transparent 100%),
        linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.18) 22%, #000 54%, rgba(0, 0, 0, 0.82) 76%, transparent 100%);
    mask-image:
        linear-gradient(90deg, transparent 0%, rgba(0, 0, 0, 0.58) 8%, #000 16%, #000 84%, rgba(0, 0, 0, 0.58) 92%, transparent 100%),
        linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.18) 22%, #000 54%, rgba(0, 0, 0, 0.82) 76%, transparent 100%);
    -webkit-mask-composite: source-in;
    mask-composite: intersect;
}

.page-hero-title-line::after,
.page-hero-effect-line::after {
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    -webkit-mask-image:
        linear-gradient(90deg, transparent 0%, rgba(0, 0, 0, 0.58) 8%, #000 16%, #000 84%, rgba(0, 0, 0, 0.58) 92%, transparent 100%),
        linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.18) 22%, #000 54%, rgba(0, 0, 0, 0.82) 76%, transparent 100%),
        radial-gradient(ellipse 86% 58% at center 50%, #000 0%, #000 26%, rgba(0, 0, 0, 0.72) 48%, rgba(0, 0, 0, 0.24) 68%, transparent 88%);
    mask-image:
        linear-gradient(90deg, transparent 0%, rgba(0, 0, 0, 0.58) 8%, #000 16%, #000 84%, rgba(0, 0, 0, 0.58) 92%, transparent 100%),
        linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.18) 22%, #000 54%, rgba(0, 0, 0, 0.82) 76%, transparent 100%),
        radial-gradient(ellipse 86% 58% at center 50%, #000 0%, #000 26%, rgba(0, 0, 0, 0.72) 48%, rgba(0, 0, 0, 0.24) 68%, transparent 88%);
    -webkit-mask-composite: source-in;
    mask-composite: intersect;
}

.page-hero-title-line-text,
.page-hero-effect-line-text {
    position: relative;
    z-index: 1;
    display: inline-block;
    flex: 0 0 auto;
    color: inherit;
    font-family: inherit;
    font-weight: inherit;
}

.page-subtitle.page-hero-effect-lines-enhanced {
    position: relative;
    contain: layout style;
    isolation: isolate;
    text-align: center;
}

.guest-portal-shell .portal-top-card .page-subtitle.page-hero-effect-lines-enhanced {
    justify-self: stretch;
    width: 100%;
    min-width: 0;
    max-width: none;
}

.guest-portal-shell .portal-top-card-banner .page-subtitle.page-hero-effect-lines-enhanced {
    width: min(75%, 62ch);
    max-width: 62ch;
    justify-self: center;
}

.page-hero-mobile-bar {
    display: none;
}

.page-hero-mobile-bar-title {
    opacity: 0;
}

.page-hero-icon {
    --icon-badge-base-size: var(--header-icon-size, 52px);
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    display: grid;
    place-items: center;
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex: 0 0 var(--icon-badge-size);
    align-self: start;
    justify-self: start;
    overflow: hidden;
    border: 0;
    border-radius: calc(var(--icon-badge-size) * 0.32);
    background:
        linear-gradient(
            180deg,
            rgba(var(--hotel-standard-icon-bg-top-rgb, 238, 248, 244), var(--hotel-standard-icon-bg-visible-alpha, var(--hotel-standard-icon-bg-opacity-alpha, 1))),
            rgba(var(--hotel-standard-icon-bg-bottom-rgb, 220, 239, 233), var(--hotel-standard-icon-bg-visible-alpha, var(--hotel-standard-icon-bg-opacity-alpha, 1)))
        );
    color: var(--hotel-standard-icon-color);
    box-shadow: 0 10px 22px rgba(18, 36, 32, 0.06);
}

.page-hero-icon[hidden] {
    display: none !important;
}

.page-hero-icon-kind-group {
    --group-title-font-size: clamp(1.6rem, 6vw, 2.4rem);
    --group-title-line-height: 1.16;
    --group-title-line-gap: 0.24rem;
    --group-title-line-box: calc(var(--group-title-font-size) * var(--group-title-line-height));
    --icon-badge-base-size: min(52px, calc(var(--group-title-line-box) + var(--group-title-line-box) + var(--group-title-line-gap)));
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
}

.page-hero-icon img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.page-hero-icon-fallback {
    display: grid;
    place-items: center;
    width: 100%;
    height: 100%;
    background:
        linear-gradient(
            180deg,
            rgba(var(--hotel-standard-icon-bg-top-rgb, 238, 248, 244), var(--hotel-standard-icon-bg-visible-alpha, var(--hotel-standard-icon-bg-opacity-alpha, 1))),
            rgba(var(--hotel-standard-icon-bg-bottom-rgb, 220, 239, 233), var(--hotel-standard-icon-bg-visible-alpha, var(--hotel-standard-icon-bg-opacity-alpha, 1)))
        );
    color: var(--hotel-standard-icon-color);
}

.page-hero-icon.standard-icon-badge {
    border: 0;
    background: transparent;
}

.page-hero-icon.standard-icon-badge svg {
    width: var(--hotel-standard-icon-glyph-size, 64%);
    height: var(--hotel-standard-icon-glyph-size, 64%);
}

.page-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin: 0;
    color: var(--guest-ui-primary);
    font-family: var(--portal-title-font);
    font-size: var(--portal-type-title-xs);
    font-weight: var(--portal-title-weight);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.page-hero-topline > *,
.page-hero-main > *,
.page-hero-copy > * {
    min-width: 0;
}

.page-breadcrumb a,
.page-breadcrumb span {
    color: inherit;
    text-decoration: none;
}

.page-breadcrumb a:hover,
.page-breadcrumb a:focus-visible {
    color: var(--guest-ui-primary-strong);
}

.page-breadcrumb a:not(:last-child)::after,
.page-breadcrumb span:not(:last-child)::after {
    content: ">";
    margin-left: 6px;
}

.page-hero-desktop-meta {
    display: none;
}

.page-hero-language-desktop {
    display: none;
}

.page-hero-detail {
    margin: 10px 0 0;
    color: var(--guest-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-sm);
    font-weight: var(--portal-text-weight);
    line-height: 1.5;
}

.page-hero-simple {
    display: grid;
    gap: 8px;
}

.page-hero-simple h1 {
    font-size: calc(clamp(1.6rem, 6vw, 2.4rem) * var(--portal-hero-scale));
    line-height: var(--header-title-line-height, 1.16);
}

.page-hero-simple .page-subtitle,
.page-hero-simple .page-hero-detail {
    margin-top: 0;
    max-width: none;
}

.page-tab-nav {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(140px, 1fr);
    gap: 8px;
    margin-top: 12px;
    overflow-x: auto;
    padding-bottom: 4px;
}

.page-tab-nav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 9px 12px;
    border: 1px solid var(--guest-line);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.9);
    color: var(--guest-muted);
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-sm) * 1.06);
    font-weight: max(var(--portal-text-weight), 500);
    text-align: center;
}

.page-tab-nav a.is-active {
    border-color: color-mix(in srgb, var(--guest-ui-primary) 18%, transparent);
    background: var(--guest-ui-primary-soft);
    color: var(--guest-ui-primary);
}

.public-element-nav {
    --category-scroll-fade-left: #000;
    --category-scroll-fade-right: #000;
    --scroll-fade-edge-size: var(--portal-content-edge-inset-x, 14px);
    --scroll-fade-width: 16px;
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    margin-top: 10px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 3px 0 1px;
    scrollbar-width: none;
    touch-action: pan-x;
    overscroll-behavior-inline: contain;
    -webkit-overflow-scrolling: touch;
    -webkit-mask-image: linear-gradient(90deg, transparent 0, var(--category-scroll-fade-left) var(--scroll-fade-edge-size), #000 calc(var(--scroll-fade-edge-size) + var(--scroll-fade-width)), #000 calc(100% - var(--scroll-fade-edge-size) - var(--scroll-fade-width)), var(--category-scroll-fade-right) calc(100% - var(--scroll-fade-edge-size)), transparent 100%);
    mask-image: linear-gradient(90deg, transparent 0, var(--category-scroll-fade-left) var(--scroll-fade-edge-size), #000 calc(var(--scroll-fade-edge-size) + var(--scroll-fade-width)), #000 calc(100% - var(--scroll-fade-edge-size) - var(--scroll-fade-width)), var(--category-scroll-fade-right) calc(100% - var(--scroll-fade-edge-size)), transparent 100%);
}

.public-element-nav::-webkit-scrollbar {
    display: none;
}

.public-element-nav.has-left-overflow {
    --category-scroll-fade-left: transparent;
}

.public-element-nav.has-right-overflow {
    --category-scroll-fade-right: transparent;
}

.public-element-nav a {
    justify-content: center;
    flex: 0 0 auto;
    text-align: center;
    text-decoration: none;
    white-space: nowrap;
}

.portal-element-card,
.empty-state {
    padding: 18px;
    border: 1px solid rgba(221, 229, 224, 0.84);
    border-radius: 14px;
    background: var(--guest-card);
    box-shadow: none;
}

.portal-group-card {
    background: var(--guest-card);
    min-width: 0;
}

.portal-group-element-card {
    --group-title-font-size: var(--portal-type-title-xl);
    --group-title-line-height: 1.12;
    --group-title-line-gap: calc(2px * var(--portal-text-rhythm-scale, 1));
    --group-title-line-box: calc(var(--group-title-font-size) * var(--group-title-line-height));
    --group-header-icon-size: calc(var(--group-title-line-box) + var(--group-title-line-box) + var(--group-title-line-gap));
    font-size: var(--group-title-font-size);
    line-height: var(--group-title-line-height);
    --header-icon-size: var(--group-header-icon-size);
    --icon-badge-base-size: var(--header-icon-size, var(--group-header-icon-size));
    --icon-badge-size: var(--icon-badge-base-size);
    grid-template-columns: minmax(0, var(--icon-badge-size)) minmax(0, 1fr);
    align-items: center;
}

.portal-group-element-card > .portal-card-icon,
.portal-group-element-card > .portal-card-icon + * {
    transform: none;
}

.portal-group-element-card .portal-group-card-title {
    font-size: var(--group-title-font-size);
    line-height: var(--group-title-line-height);
}

.portal-group-grid .portal-card {
    padding: 16px;
    border-width: 1px;
    border-radius: 18px;
    background: var(--guest-card);
}

.portal-group-element-card .portal-group-header-icon {
    --icon-badge-base-size: var(--group-header-icon-size);
    --icon-badge-size: var(--icon-badge-base-size);
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
}

.portal-group-header-icon {
    --group-title-font-size: var(--portal-type-title-xl);
    --group-title-line-height: 1.12;
    --group-title-line-gap: calc(2px * var(--portal-text-rhythm-scale, 1));
    --group-title-line-box: calc(var(--group-title-font-size) * var(--group-title-line-height));
    --icon-badge-base-size: calc(var(--group-title-line-box) + var(--group-title-line-box) + var(--group-title-line-gap));
    --icon-badge-size: var(--icon-badge-base-size);
    font-size: var(--group-title-font-size);
    line-height: var(--group-title-line-height);
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
}

.portal-group-header-icon.standard-icon-badge svg {
    width: var(--hotel-standard-icon-group-glyph-size, var(--hotel-standard-icon-glyph-size, 64%));
    height: var(--hotel-standard-icon-group-glyph-size, var(--hotel-standard-icon-glyph-size, 64%));
}

.portal-group-header-icon.icon-letter-fallback {
    font-size: var(--hotel-standard-icon-letter-size, calc(var(--icon-badge-size, 48px) * 0.38));
}

.portal-group-grid .portal-card:hover,
.portal-group-grid .portal-card:focus-visible {
    transform: scale(0.99);
    border-color: var(--guest-line);
    box-shadow: none;
}

.portal-element-card {
    border-radius: 14px;
    background: rgba(251, 252, 250, 0.82);
    min-width: 0;
    scroll-margin-top: 18px;
}

.legacy-element-anchor {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    pointer-events: none;
}

.portal-element-link-card {
    color: inherit;
    text-decoration: none;
}

.portal-element-card-link {
    padding: 0;
}

.portal-element-link-card.portal-card {
    display: grid;
    width: 100%;
    min-height: 0;
    padding: 16px;
    align-items: center;
    border: 0;
    border-radius: inherit;
    background: transparent;
    box-shadow: none;
}

.portal-element-link-card--no-icon.portal-card {
    grid-template-columns: minmax(0, 1fr);
}

.portal-element-link-card.portal-card:has(.portal-element-summary) {
    align-items: start;
}

.portal-element-link-card .portal-element-heading {
    margin-bottom: 0;
}

.portal-element-link-card:hover .portal-element-title,
.portal-element-link-card:focus-visible .portal-element-title {
    color: var(--guest-ui-primary);
}

.portal-element-link-card.portal-card:hover,
.portal-element-link-card.portal-card:focus-visible {
    transform: none;
    border-color: transparent;
    box-shadow: none;
}

.portal-element-heading {
    --header-title-font-size: 1.28rem;
    --header-title-line-height: 1.12;
    --header-title-line-gap: 0.2rem;
    --header-title-line-box: 1.4336rem;
    --header-icon-max-size: calc(var(--header-title-line-box) + var(--header-title-line-box) + var(--header-title-line-gap));
    --header-icon-size: min(44px, var(--header-icon-max-size));
    display: grid;
    gap: 6px;
    margin-bottom: 12px;
    scroll-margin-top: 18px;
}

.portal-element-heading.has-icon {
    grid-template-columns: auto minmax(0, 1fr);
    column-gap: calc(10px * var(--hotel-standard-icon-gap-factor, 1));
    align-items: center;
}

.portal-element-heading.has-icon:has(.portal-element-summary) {
    align-items: start;
}

.portal-element-heading-icon {
    --icon-badge-base-size: var(--header-icon-size, 44px);
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    border-radius: calc(var(--icon-badge-size) * 0.32);
}

.portal-card-icon.icon-letter-fallback,
.portal-group-header-icon.icon-letter-fallback,
.portal-element-heading-icon.icon-letter-fallback {
    font-size: calc(var(--icon-badge-size, 48px) * var(--hotel-standard-icon-letter-ratio, 0.38));
}

.portal-element-heading-copy {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.portal-element-heading h2,
.empty-state h2 {
    margin: 0;
    color: var(--guest-ink);
    font-family: var(--portal-title-font);
    font-size: var(--portal-type-h3);
    font-weight: var(--portal-title-weight);
    line-height: 1.12;
    letter-spacing: -0.03em;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.portal-element-title {
    margin: 0;
    color: var(--guest-ink);
    font-family: var(--portal-title-font);
    font-size: var(--portal-type-lg);
    font-weight: var(--portal-title-weight);
    line-height: 1.2;
    letter-spacing: -0.02em;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.portal-element-summary,
.empty-state p {
    margin: 0;
    color: var(--guest-muted);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.portal-label-list {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin-top: 9px;
}

.portal-label-list-header {
    margin-top: 6px;
}

.portal-label-chip {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 5px 10px;
    border: 1px solid color-mix(in srgb, var(--guest-ui-primary) 12%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--guest-ui-primary) 6%, transparent);
    color: var(--portal-highlight-color);
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-sm) * 1.06);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: 1.1;
    max-width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

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

.guest-menu-element {
    display: grid;
    gap: 14px;
    min-width: 0;
}

.guest-menu-category-rail {
    position: sticky;
    top: var(--guest-menu-sticky-top, 0);
    z-index: 14;
    align-self: start;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    margin: 0;
    padding: 4px 0 10px;
    box-sizing: border-box;
    overflow-x: hidden;
    background: transparent;
    backdrop-filter: none;
}

.guest-menu-category-nav {
    --category-scroll-fade-left: #000;
    --category-scroll-fade-right: #000;
    --scroll-fade-edge-size: 0px;
    --scroll-fade-width: 16px;
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    width: 100%;
    min-width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 2px 2px 6px;
    box-sizing: border-box;
    scroll-behavior: smooth;
    scrollbar-width: none;
    overscroll-behavior-x: contain;
    touch-action: pan-x;
    -webkit-overflow-scrolling: touch;
    -webkit-mask-image: linear-gradient(90deg, transparent 0, var(--category-scroll-fade-left) var(--scroll-fade-edge-size), #000 calc(var(--scroll-fade-edge-size) + var(--scroll-fade-width)), #000 calc(100% - var(--scroll-fade-edge-size) - var(--scroll-fade-width)), var(--category-scroll-fade-right) calc(100% - var(--scroll-fade-edge-size)), transparent 100%);
    mask-image: linear-gradient(90deg, transparent 0, var(--category-scroll-fade-left) var(--scroll-fade-edge-size), #000 calc(var(--scroll-fade-edge-size) + var(--scroll-fade-width)), #000 calc(100% - var(--scroll-fade-edge-size) - var(--scroll-fade-width)), var(--category-scroll-fade-right) calc(100% - var(--scroll-fade-edge-size)), transparent 100%);
}

.guest-menu-category-nav::-webkit-scrollbar {
    display: none;
}

.guest-menu-category-nav.has-left-overflow {
    --category-scroll-fade-left: transparent;
}

.guest-menu-category-nav.has-right-overflow {
    --category-scroll-fade-right: transparent;
}

.guest-menu-category-nav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    min-width: 120px;
    max-width: min(44vw, 180px);
    min-height: 42px;
    padding: 9px 14px;
    border: 1px solid var(--portal-main-font-muted);
    border-radius: 14px;
    background: transparent;
    color: var(--portal-main-font-color);
    font-size: 0.88rem;
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-sm) * 1.06);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: 1.15;
    text-align: center;
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    box-shadow: none;
    transition: border-color 160ms ease, color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}

.guest-menu-category-nav a.is-active {
    border: 1px solid var(--portal-highlight-color);
    background: transparent;
    color: var(--portal-highlight-color);
    box-shadow: none;
}

.guest-menu-category-nav a:active {
    transform: translateY(1px);
}

.menu-category-stack {
    display: grid;
    gap: 20px;
}

.menu-category-group {
    display: grid;
    gap: 10px;
    scroll-margin-top: 20vh;
}

[id^="group-"],
[id^="element-"],
[id^="detail-"] {
    scroll-margin-top: 20vh;
}

.menu-category-group > h3,
.menu-category-group > h4 {
    margin: 0;
    color: var(--portal-highlight-color);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-lg);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: var(--portal-text-compact-line-height-rhythm);
}

.menu-category-group .item-list {
    gap: 12px;
}

.content-item {
    display: grid;
    gap: 10px;
    padding: 14px;
    border: 1px solid var(--guest-line);
    border-radius: 16px;
    background: rgba(247, 250, 247, 0.75);
}

.content-item:first-child {
    padding-top: 14px;
}

.content-item:last-child {
    padding-bottom: 14px;
}

.schedule-item,
.menu-item,
.contact-item,
.faq-item {
    border-radius: 18px;
}

.menu-item {
    gap: calc(12px * var(--hotel-standard-icon-gap-factor, 1));
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(246, 249, 246, 0.88));
    box-shadow: 0 12px 26px rgba(18, 36, 32, 0.05);
}

.menu-item-trigger {
    width: 100%;
    color: inherit;
    font: inherit;
    text-align: left;
    cursor: pointer;
    appearance: none;
    transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.menu-item-trigger:hover,
.menu-item-trigger:focus-visible {
    border-color: color-mix(in srgb, var(--portal-highlight-color) 34%, var(--guest-line));
    box-shadow: 0 18px 34px rgba(18, 36, 32, 0.09);
    transform: translateY(-1px);
}

.menu-item-trigger:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--portal-highlight-color) 22%, transparent);
    outline-offset: 3px;
}

.guest-shell .schedule-item {
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
    padding: 7px 9px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.72);
    box-shadow: none;
}

.guest-shell .schedule-main {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.guest-shell .schedule-top-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.guest-shell .schedule-main h3 {
    margin: 0;
    color: var(--guest-ink);
    font-family: var(--portal-title-font);
    font-size: var(--portal-type-title-sm);
    font-weight: var(--portal-title-weight);
    line-height: 1.16;
    overflow-wrap: anywhere;
}

.guest-shell .schedule-sub-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 3px 6px;
    min-width: 0;
}

.guest-shell .schedule-main p {
    margin: 0;
    color: var(--guest-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: var(--portal-text-weight);
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.guest-shell .schedule-badge {
    padding: 2px 6px;
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: 1.2;
}

.time-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    width: fit-content;
    padding: 6px 10px;
    border-radius: 999px;
    background: var(--guest-ui-tag-bg);
    color: var(--guest-ui-tag-text);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-sm);
    font-weight: max(var(--portal-text-weight), 500);
}

.guest-shell .schedule-item .time-pill {
    justify-self: end;
    gap: 4px;
    padding: 2px 6px;
    background: color-mix(in srgb, var(--guest-ui-primary) 8%, transparent);
    color: var(--guest-ui-primary);
    font-size: 0.72rem;
    line-height: 1.2;
    white-space: nowrap;
}

.menu-item-title {
    margin: 0;
    color: var(--portal-main-font-color);
    font-size: 1.02rem;
    line-height: 1.22;
    letter-spacing: -0.01em;
}

.menu-item-title-badge {
    color: var(--portal-highlight-color);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: 1.2;
}

.menu-item-meta-row {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 5px 10px;
    margin-top: 10px;
}

.menu-item-meta-row:empty {
    display: none;
}

.menu-item-price,
.menu-item-label {
    font-size: var(--portal-type-sm);
    line-height: 1.2;
}

.menu-item-price {
    color: var(--guest-ink);
    font-family: var(--portal-text-font);
    font-weight: max(var(--portal-text-weight), 500);
}

.menu-item-label {
    color: var(--portal-highlight-color);
    font-family: var(--portal-text-font);
    font-weight: max(var(--portal-text-weight), 500);
}

.menu-item-image {
    width: 88px;
    height: 88px;
    flex: 0 0 88px;
    margin-left: auto;
    border-radius: 12px;
    object-fit: cover;
}

.guest-menu-compact {
    display: grid;
    gap: calc(var(--portal-text-list-gap, 12px) * 0.86);
}

.guest-menu-compact .menu-category-stack {
    gap: calc(var(--portal-text-list-gap, 12px) * 1.05);
}

.guest-menu-no-category-headings .menu-category-stack {
    gap: 0;
}

.guest-menu-compact .menu-category-group {
    gap: 8px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.guest-menu-compact .menu-category-group > h3 {
    color: var(--portal-highlight-color);
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-md) * 1.02);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: 1.16;
}

.guest-menu-compact .menu-category-group .item-list {
    gap: 0;
}

.guest-menu-no-category-headings .menu-category-group {
    gap: 0;
}

.guest-menu-compact .menu-item {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: center;
    gap: calc(10px * var(--hotel-standard-icon-gap-factor, 1));
    min-height: 46px;
    padding: 5px 0;
}

.guest-menu-compact .menu-item:not(:has(.menu-item-image)) {
    grid-template-columns: 42px minmax(0, 1fr);
}

.guest-menu-compact .menu-item:not(:has(.menu-item-image)) .item-main {
    grid-column: 2;
}

.guest-menu-compact .menu-item:not(:has(.menu-item-image)) .menu-item-compact-dot {
    display: block;
}

.guest-menu-compact .menu-item-image {
    grid-column: 1;
    grid-row: 1;
    width: 42px;
    height: 42px;
    max-width: 42px;
    max-height: 42px;
    min-width: 42px;
    min-height: 42px;
    margin: 0;
    border-radius: calc(var(--portal-radius-sm, 12px) * 0.78);
    box-shadow: 0 8px 18px rgba(20, 35, 30, calc(var(--guest-glass-shadow-alpha, 0.11) * 0.9));
}

.guest-menu-compact .menu-item-compact-dot {
    display: block;
    grid-column: 1;
    grid-row: 1;
    place-self: center;
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: var(--portal-highlight-color);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--portal-highlight-color) 10%, transparent);
}

.guest-menu-compact .item-main {
    grid-column: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 3px 12px;
    min-width: 0;
}

.guest-menu-compact .menu-item-title {
    grid-column: 1;
    margin: 0;
    display: flex;
    align-items: baseline;
    gap: 6px;
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-md) * 1.02);
    font-weight: var(--portal-text-weight);
    line-height: 1.16;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.guest-menu-compact .menu-item-title > span:first-child {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}

.guest-menu-compact .menu-item-title-badge {
    flex: 0 0 auto;
    font-size: var(--portal-type-xs);
}

.guest-menu-compact .item-description {
    grid-column: 1;
    margin: 0;
    font-size: var(--portal-type-md);
    line-height: 1.25;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.guest-menu-compact .menu-item-meta-row {
    grid-column: 2;
    grid-row: 1 / span 2;
    justify-self: end;
    align-self: center;
    justify-content: flex-end;
    margin: 0;
    text-align: right;
}

.guest-menu-compact .menu-item-price {
    color: var(--portal-main-font-color);
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-md) * 1.02);
    font-weight: var(--portal-text-weight);
    line-height: 1.15;
    white-space: nowrap;
}

.guest-menu-compact .menu-item-label {
    max-width: 10ch;
    color: var(--portal-highlight-color);
    font-size: var(--portal-type-xs);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.guest-menu-compact .menu-item-trigger:hover,
.guest-menu-compact .menu-item-trigger:focus-visible {
    transform: none;
    box-shadow: none;
}

@media (max-width: 420px) {
    .guest-menu-compact .menu-category-group {
        padding: 12px;
    }

    .guest-menu-compact .menu-item {
        grid-template-columns: 38px minmax(0, 1fr);
        gap: 8px;
    }

    .guest-menu-compact .menu-item:not(:has(.menu-item-image)) {
        grid-template-columns: 38px minmax(0, 1fr);
    }

    .guest-menu-compact .menu-item-image {
        width: 38px;
        height: 38px;
        max-width: 38px;
        max-height: 38px;
        min-width: 38px;
        min-height: 38px;
    }

    .guest-menu-compact .item-main {
        column-gap: 8px;
    }
}

.portal-menu-modal-open,
.portal-gallery-lightbox-open.portal-menu-modal-open {
    overflow: hidden;
}

.guest-menu-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: grid;
    place-items: center;
    padding: max(18px, env(safe-area-inset-top)) 14px max(18px, env(safe-area-inset-bottom));
    background:
        radial-gradient(circle at 50% 0, color-mix(in srgb, var(--portal-highlight-color) 22%, transparent), transparent 42%),
        color-mix(in srgb, var(--portal-background-color, #0b0f14) 18%, rgba(4, 6, 10, 0.78));
    opacity: 0;
    backdrop-filter: blur(0);
    transition: opacity 180ms ease, backdrop-filter 180ms ease;
}

.guest-menu-modal-overlay.is-visible {
    opacity: 1;
    backdrop-filter: blur(14px);
}

.guest-menu-modal-shell {
    display: grid;
    width: min(100%, 520px);
    max-height: min(90vh, 760px);
    transform: translateY(16px) scale(0.985);
    transition: transform 220ms cubic-bezier(0.2, 0.82, 0.2, 1);
}

.guest-menu-modal-overlay.is-visible .guest-menu-modal-shell {
    transform: translateY(0) scale(1);
}

.guest-menu-modal-card {
    --menu-modal-container-bg: rgb(var(--portal-container-color-rgb, 255, 255, 255));
    position: relative;
    display: grid;
    max-height: min(90vh, 760px);
    overflow: hidden;
    border: 1px solid var(--portal-glass-border, var(--guest-line));
    border-radius: 28px;
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
            rgba(255, 255, 255, 0.04)
        ),
        var(--menu-modal-container-bg);
    color: var(--portal-main-font-color);
    box-shadow:
        var(--portal-shadow, 0 14px 38px rgba(31, 41, 55, var(--guest-glass-shadow-alpha, 0.11))),
        inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
    backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    -webkit-backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
}

.guest-menu-modal-card::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    border-radius: inherit;
    background:
        linear-gradient(
            135deg,
            rgba(255, 255, 255, calc(var(--guest-glass-highlight-alpha, 0.11) * 0.24)),
            rgba(255, 255, 255, 0) 34%
        ),
        rgba(15, 18, 16, var(--guest-glass-dark-alpha, 0.04));
}

.guest-menu-modal-card > * {
    position: relative;
    z-index: 1;
}

.guest-menu-modal-close {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 2;
    display: grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border: 1px solid var(--portal-glass-border, color-mix(in srgb, var(--portal-main-font-color) 24%, transparent));
    border-radius: 999px;
    overflow: hidden;
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
            rgba(255, 255, 255, 0.04)
        ),
        var(--portal-glass-bg, var(--menu-modal-container-bg));
    color: var(--portal-main-font-color);
    font-size: 1.45rem;
    line-height: 1;
    cursor: pointer;
    box-shadow:
        0 10px 22px rgba(20, 35, 30, var(--guest-glass-shadow-alpha, 0.11)),
        inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
    backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    -webkit-backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    transition: background 160ms ease, transform 160ms ease;
}

.guest-menu-modal-close::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    border-radius: inherit;
    pointer-events: none;
    background:
        linear-gradient(
            135deg,
            rgba(255, 255, 255, calc(var(--guest-glass-highlight-alpha, 0.11) * 0.24)),
            rgba(255, 255, 255, 0) 34%
        ),
        rgba(15, 18, 16, var(--guest-glass-dark-alpha, 0.04));
}

.guest-menu-modal-close:hover,
.guest-menu-modal-close:focus-visible {
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
            rgba(255, 255, 255, 0.04)
        ),
        color-mix(in srgb, var(--portal-highlight-color) 14%, var(--portal-glass-bg, var(--menu-modal-container-bg)));
    transform: translateY(-1px);
}

.guest-menu-modal-media {
    position: relative;
    min-height: 230px;
    max-height: 42vh;
    margin: 0;
    overflow: hidden;
    background: color-mix(in srgb, var(--portal-main-font-color) 14%, var(--portal-glass-bg, #fff));
}

.guest-menu-modal-media::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 42%;
    background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--portal-glass-bg, #fff) 92%, transparent));
    pointer-events: none;
}

.guest-menu-modal-media img {
    width: 100%;
    height: 100%;
    min-height: inherit;
    object-fit: cover;
}

.guest-menu-modal-body {
    display: grid;
    gap: 14px;
    min-height: 0;
    overflow-y: auto;
    padding: 24px;
    scrollbar-width: thin;
}

.guest-menu-modal-kicker {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    color: var(--portal-highlight-color);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    letter-spacing: 0;
}

.guest-menu-modal-kicker span {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 4px 9px;
    border: 1px solid color-mix(in srgb, var(--portal-highlight-color) 30%, var(--portal-divider-color, transparent));
    border-radius: 999px;
    background: color-mix(in srgb, var(--portal-highlight-color) 10%, transparent);
}

.guest-menu-modal-title-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 12px;
}

.guest-menu-modal-title-row h2 {
    margin: 0;
    color: var(--portal-main-font-color);
    font-family: var(--portal-title-font);
    font-size: clamp(1.55rem, 7vw, 2.25rem);
    font-weight: var(--portal-title-weight);
    line-height: 1.16;
    letter-spacing: 0;
    overflow-wrap: anywhere;
}

.guest-menu-modal-price {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 7px 11px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--portal-highlight-color) 16%, transparent);
    color: var(--portal-highlight-color);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: max(var(--portal-text-weight), 500);
    white-space: nowrap;
}

.guest-menu-modal-description,
.guest-menu-modal-extra p {
    margin: 0;
    color: var(--portal-main-font-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
    line-height: 1.6;
}

.guest-menu-modal-extra {
    display: grid;
    gap: calc(10px * var(--hotel-standard-icon-gap-factor, 1));
    padding-top: 14px;
    border-top: 1px solid var(--portal-divider-color);
}

.guest-menu-modal-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 42px;
    padding: 10px 16px;
    border-radius: 999px;
    background: var(--portal-highlight-color);
    color: var(--portal-surface-color, var(--portal-background-color, #fff));
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-sm) * 1.06);
    font-weight: max(var(--portal-text-weight), 500);
    text-decoration: none;
}

@media (max-width: 560px) {
    .guest-menu-modal-overlay {
        place-items: center;
        padding: 12px 10px max(10px, env(safe-area-inset-bottom));
    }

    .guest-menu-modal-shell,
    .guest-menu-modal-card {
        width: 100%;
        max-height: 92vh;
    }

    .guest-menu-modal-card {
        border-radius: 26px;
    }

    .guest-menu-modal-media {
        min-height: 210px;
        max-height: 38vh;
    }

    .guest-menu-modal-body {
        padding: 22px 18px 24px;
    }

    .guest-menu-modal-title-row {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .guest-menu-modal-price {
        justify-self: start;
    }
}

.item-image {
    width: 100%;
    max-height: 180px;
    border-radius: 14px;
    object-fit: cover;
}

.item-main {
    min-width: 0;
}

.item-title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.item-title-row h3 {
    margin: 0;
    color: var(--guest-ink);
    font-family: var(--portal-title-font);
    font-size: var(--portal-type-title-lg);
    font-weight: var(--portal-title-weight);
    line-height: 1.24;
}

.item-title-row h4 {
    margin: 0;
    color: var(--guest-ink);
    font-family: var(--portal-title-font);
    font-size: var(--portal-type-title-lg);
    font-weight: var(--portal-title-weight);
    line-height: 1.24;
}

.item-title-aside {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.item-badge,
.item-price {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 5px 9px;
    border-radius: 999px;
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
}

.item-badge {
    background: var(--guest-ui-tag-bg);
    color: var(--guest-ui-tag-text);
}

.item-price {
    background: color-mix(in srgb, var(--guest-ui-primary) 8%, transparent);
    color: var(--guest-ui-primary);
}

.item-value,
.item-description,
.muted-text {
    margin: 6px 0 0;
    color: var(--guest-muted);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.item-value {
    color: var(--guest-ink);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
}

.portal-richtext {
    display: grid;
    gap: 12px;
    min-width: 0;
}

.portal-richtext > * {
    margin: 0;
    max-width: 100%;
}

.portal-richtext p,
.portal-richtext li,
.portal-richtext blockquote {
    color: var(--guest-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
    line-height: 1.62;
}

.portal-richtext h2,
.portal-richtext h3 {
    margin: 4px 0 0;
    color: var(--guest-ink);
    font-family: var(--portal-title-font);
    font-weight: var(--portal-title-weight);
    line-height: 1.12;
    letter-spacing: -0.03em;
}

.portal-richtext h2 {
    font-size: var(--portal-type-h4);
}

.portal-richtext h3 {
    font-size: var(--portal-type-title-lg);
}

.portal-richtext ul,
.portal-richtext ol {
    display: grid;
    gap: 6px;
    padding-left: 20px;
}

.portal-richtext a {
    color: var(--guest-ui-primary);
    text-decoration-thickness: 0.08em;
    text-underline-offset: 0.12em;
    overflow-wrap: anywhere;
}

.portal-richtext blockquote {
    padding: 14px 16px;
    border-left: 3px solid color-mix(in srgb, var(--guest-ui-primary) 22%, transparent);
    border-radius: 0 16px 16px 0;
    background: transparent;
}

.portal-richtext hr {
    width: 100%;
    height: 1px;
    border: 0;
    background: var(--portal-divider-color);
}

.portal-embedded-image {
    margin: 0;
    display: grid;
    place-items: center;
    overflow: hidden;
    border-radius: 18px;
    padding: 10px;
}

.portal-embedded-image img,
.portal-gallery-slide img {
    display: block;
    width: 100%;
    height: auto;
    max-width: 100%;
    max-height: 100%;
    margin: auto;
    border-radius: 10px;
    object-fit: contain;
    object-position: center;
}

.portal-gallery {
    display: grid;
    gap: 10px;
    min-width: 0;
    overflow: hidden;
}

.portal-gallery-viewport {
    display: grid;
    place-items: center;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    border-radius: 18px;
}

.portal-gallery-track {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    height: 100%;
    transition: transform 220ms ease;
    will-change: transform;
    touch-action: pan-y;
}

.portal-gallery-slide {
    flex: 0 0 100%;
    width: 100%;
    min-width: 0;
    height: 100%;
    display: grid;
    place-items: center;
    padding: 10px;
    overflow: hidden;
}

.portal-gallery-controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.portal-gallery-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: 1px solid color-mix(in srgb, var(--guest-ui-primary) 12%, transparent);
    border-radius: 999px;
    background: transparent;
    color: var(--guest-ui-primary);
    font: inherit;
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1;
    padding: 0;
    cursor: pointer;
    box-shadow: none;
}

.portal-gallery-status {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--guest-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-sm);
    font-weight: max(var(--portal-text-weight), 500);
}

.portal-gallery-dots {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
}

.portal-gallery-dot {
    width: 8px;
    height: 8px;
    border: 0;
    border-radius: 999px;
    background: var(--portal-divider-color);
    padding: 0;
    cursor: pointer;
}

.portal-gallery-dot.is-active {
    background: var(--guest-ui-primary);
}

.guest-gallery-caption {
    display: grid;
    gap: 4px;
    margin-bottom: 12px;
}

.guest-gallery-caption h3,
.guest-gallery-caption p {
    margin: 0;
}

.guest-gallery .portal-gallery-main {
    position: relative;
    min-width: 0;
}

.guest-gallery .portal-gallery-viewport {
    background: var(--portal-glass-bg, rgba(var(--portal-container-color-rgb, 255, 255, 255), var(--portal-container-transparency, 0.59)));
}

.guest-gallery-fixed-aspect .portal-gallery-viewport {
    aspect-ratio: var(--guest-gallery-fixed-aspect-ratio);
}

.guest-gallery .portal-gallery-slide {
    border: 0;
    background: transparent;
    cursor: zoom-in;
}

.guest-gallery-fit-cover .portal-gallery-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.guest-gallery-fit-contain .portal-gallery-slide img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.guest-gallery-aspect-adaptive .portal-gallery-slide img {
    width: 100%;
    height: auto;
    object-fit: contain;
}

.guest-portal-shell .guest-gallery-aspect-adaptive .portal-gallery-slide {
    padding-inline: 0;
}

.guest-gallery-fixed-aspect .portal-gallery-slide {
    position: relative;
    display: block;
    padding: 0;
}

.guest-gallery-fixed-aspect .portal-gallery-slide img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    margin: 0;
    object-fit: cover;
    object-position: center center;
}

.guest-gallery-fixed-aspect .portal-gallery-slide img.is-top-anchored-crop {
    object-position: center top;
}

.guest-gallery .portal-gallery-arrow,
.guest-gallery .portal-gallery-status {
    position: absolute;
    z-index: 5;
    border: 1px solid rgba(var(--portal-main-font-rgb, 23, 37, 31), 0.14);
    background: rgba(var(--portal-container-color-rgb, 255, 255, 255), min(calc(var(--portal-container-transparency, 0.59) + 0.16), 0.92));
    color: var(--portal-main-font-color, var(--guest-ink));
    box-shadow: 0 10px 22px rgba(18, 36, 32, 0.08);
}

.guest-gallery .portal-gallery-arrow {
    top: 50%;
    overflow: visible;
    opacity: 1;
    visibility: visible;
    transform: translateY(-50%);
}

.guest-gallery .portal-gallery-arrow.is-prev {
    left: var(--portal-content-inset-unit, 12px);
}

.guest-gallery .portal-gallery-arrow.is-next {
    right: var(--portal-content-inset-unit, 12px);
}

.guest-gallery .portal-gallery-status {
    right: 16px;
    bottom: 16px;
    padding: 9px 13px;
    border-radius: 999px;
}

.portal-gallery-thumbnails-wrap {
    position: relative;
    display: block;
    min-width: 0;
    box-sizing: border-box;
}

.portal-gallery-thumbnails {
    display: flex;
    justify-content: center;
    gap: 8px;
    min-width: 0;
    overflow-x: auto;
    padding: 0;
    box-sizing: border-box;
    scroll-padding-inline: 0;
    scroll-snap-type: x proximity;
    scrollbar-width: none;
}

.portal-gallery-thumbnails-wrap.has-overflow .portal-gallery-thumbnails {
    justify-content: flex-start;
}

.portal-gallery-thumbnails::-webkit-scrollbar {
    display: none;
}

.portal-gallery-thumbnail {
    flex: 0 0 76px;
    width: 76px;
    aspect-ratio: 4 / 3;
    padding: 0;
    border: 2px solid transparent;
    border-radius: 10px;
    background: transparent;
    overflow: hidden;
    cursor: pointer;
    scroll-snap-align: center;
}

.portal-gallery-thumbnail img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.portal-gallery-thumbnail img.is-top-anchored-thumbnail-crop,
.portal-gallery-lightbox-thumb img.is-top-anchored-thumbnail-crop {
    object-position: center top;
}

.guest-gallery-carousel_thumbnails .portal-gallery-thumbnail.is-active {
    border-color: var(--portal-highlight-color);
}

.portal-gallery-thumb-arrow {
    position: absolute;
    top: 50%;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transform: translateY(-50%);
    width: 34px;
    height: 34px;
    border: 1px solid rgba(var(--portal-main-font-rgb, 23, 37, 31), 0.14);
    border-radius: 999px;
    background: rgba(var(--portal-container-color-rgb, 255, 255, 255), min(calc(var(--portal-container-transparency, 0.59) + 0.16), 0.92));
    color: var(--portal-main-font-color, var(--guest-ink));
    font-size: 1.34rem;
    font-weight: 600;
    line-height: 1;
    padding: 0;
    cursor: pointer;
    box-shadow: 0 10px 22px rgba(18, 36, 32, 0.08);
}

.portal-gallery-thumb-arrow.is-prev {
    left: 8px;
}

.portal-gallery-thumb-arrow.is-next {
    right: 8px;
}

.portal-gallery-thumb-arrow[hidden] {
    display: none;
}

.guest-gallery-mini_gallery .portal-gallery-thumbnails-wrap {
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.portal-gallery-lightbox-open {
    overflow: hidden;
}

.portal-gallery-lightbox {
    --portal-gallery-lightbox-top-clearance: 88px;
    --portal-gallery-lightbox-bottom-clearance: 88px;
    position: fixed;
    inset: 0;
    z-index: 20000;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
    align-items: stretch;
    justify-items: stretch;
    overflow: hidden;
    background: rgba(0, 0, 0, 0.92);
    color: #fff;
}

.portal-gallery-lightbox-bar {
    position: absolute;
    left: 0;
    right: 0;
    z-index: 3;
    display: flex;
    align-items: center;
    padding: 16px 18px;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.44), rgba(0, 0, 0, 0));
}

.portal-gallery-lightbox-bar.is-top {
    top: 0;
    justify-content: flex-end;
}

.portal-gallery-lightbox-bar.is-bottom {
    bottom: 0;
    align-items: flex-end;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.52), rgba(0, 0, 0, 0));
}

.portal-gallery-lightbox-close,
.portal-gallery-lightbox-arrow {
    border: 0;
    background: rgba(255, 255, 255, 0.16);
    color: #fff;
    cursor: pointer;
}

.portal-gallery-lightbox-close {
    width: 38px;
    height: 38px;
    border-radius: 999px;
    font-size: 1.45rem;
    backdrop-filter: none;
}

.portal-gallery-lightbox-arrow {
    position: absolute;
    top: 50%;
    z-index: 3;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    font-size: 2rem;
    transform: translateY(-50%);
}

.portal-gallery-lightbox-arrow.is-prev {
    left: 18px;
}

.portal-gallery-lightbox-arrow.is-next {
    right: 18px;
}

.portal-gallery-lightbox-stage {
    position: relative;
    margin: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    touch-action: none;
    padding: var(--portal-gallery-lightbox-top-clearance) 72px var(--portal-gallery-lightbox-bottom-clearance);
}

.portal-gallery-lightbox-stage img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    transition: transform 180ms ease;
    will-change: transform;
    user-select: none;
}

.portal-gallery-lightbox-stage img.is-zoomed {
    cursor: zoom-out;
}

.portal-gallery-lightbox-thumbs {
    width: min(100%, var(--portal-content-max-width, 720px));
    margin: 0 auto;
    display: flex;
    justify-content: center;
    gap: 8px;
    overflow-x: auto;
    padding: 0 14px;
    box-sizing: border-box;
    scroll-padding-inline: 14px;
    scrollbar-width: none;
}

.portal-gallery-lightbox-thumbs.has-overflow {
    justify-content: flex-start;
}

.portal-gallery-lightbox-thumbs::-webkit-scrollbar {
    display: none;
}

.portal-gallery-lightbox-thumb {
    flex: 0 0 72px;
    width: 72px;
    aspect-ratio: 4 / 3;
    padding: 0;
    border: 2px solid transparent;
    border-radius: 8px;
    background: transparent;
    overflow: hidden;
}

.portal-gallery-lightbox-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.portal-gallery-lightbox-thumb.is-active {
    border-color: var(--portal-highlight-color);
}

.portal-gallery-lightbox.is-ui-hidden .portal-gallery-lightbox-bar,
.portal-gallery-lightbox.is-ui-hidden .portal-gallery-lightbox-arrow {
    opacity: 0;
    pointer-events: none;
}

@media (max-width: 679px) {
    .portal-gallery-lightbox {
        --portal-gallery-lightbox-top-clearance: 92px;
        --portal-gallery-lightbox-bottom-clearance: 92px;
        background: #000;
    }

    .portal-gallery-lightbox-bar {
        padding: 12px;
    }

    .portal-gallery-lightbox-close,
    .portal-gallery-lightbox-arrow {
        background: rgba(255, 255, 255, 0.12);
    }

    .portal-gallery-lightbox-arrow.is-prev {
        left: 10px;
    }

    .portal-gallery-lightbox-arrow.is-next {
        right: 10px;
    }

    .portal-gallery-lightbox-stage {
        min-height: 100dvh;
        padding: var(--portal-gallery-lightbox-top-clearance) 0 var(--portal-gallery-lightbox-bottom-clearance);
    }

    .portal-gallery-lightbox-stage img {
        width: 100%;
        max-height: 100%;
    }
}

.portal-richtext .portal-gallery,
.portal-richtext .portal-embedded-image {
    width: 100%;
}

.portal-richtext .portal-embedded-image {
    display: grid;
    place-items: center;
    padding: 10px;
}

.item-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.item-meta span,
.item-meta a {
    display: inline-flex;
    align-items: center;
    padding: 7px 10px;
    border-radius: 11px;
    border: 1px solid color-mix(in srgb, var(--portal-main-font-color) 18%, transparent);
    background: transparent;
    color: var(--guest-ui-primary);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-sm);
    font-weight: max(var(--portal-text-weight), 500);
}

.item-link-button {
    border: 1px solid transparent;
    background: var(--guest-ui-primary);
    color: var(--guest-ui-primary-contrast);
}

.item-link-button:hover,
.item-link-button:focus-visible {
    background: var(--guest-ui-primary-strong);
    color: #fff;
}

@media (max-width: 560px) {
    .page-hero-title-row {
        --header-title-font-size: clamp(1.4rem, 7vw, 1.9rem);
        --header-icon-size: min(46px, var(--header-icon-max-size));
        gap: 10px;
    }

    .page-hero-icon {
        --icon-badge-base-size: var(--header-icon-size, 46px);
        --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
        border-radius: calc(var(--icon-badge-size) * 0.32);
    }

    .portal-top-card {
        padding: 16px 16px 14px;
    }

    .page-hero-simple h1 {
        font-size: calc(clamp(1.4rem, 7vw, 1.9rem) * var(--portal-hero-scale));
    }
}

.guest-footer {
    width: min(100% - 16px, 900px);
    margin: 0 auto;
    padding: 16px 0 24px;
    color: var(--guest-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-sm);
    font-weight: var(--portal-text-weight);
    text-align: center;
}

.guest-footer p {
    margin: 0 0 4px;
    color: var(--guest-ink);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-sm);
    font-weight: max(var(--portal-text-weight), 500);
}

.back-to-top-button {
    position: fixed;
    right: 14px;
    bottom: calc(env(safe-area-inset-bottom, 0px) + 16px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border: 1px solid color-mix(in srgb, var(--guest-ui-primary) 12%, transparent);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--guest-ui-primary);
    font-size: 1rem;
    font-weight: 800;
    cursor: pointer;
    box-shadow: 0 14px 28px rgba(18, 36, 32, 0.12);
    backdrop-filter: blur(12px);
    opacity: 0;
    pointer-events: none;
    transform: translateY(10px);
    transition: opacity 160ms ease, transform 160ms ease, background 160ms ease;
    z-index: 24;
}

.back-to-top-button svg {
    display: block;
    stroke-width: 2.4;
}

.back-to-top-button.is-visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.page-hero-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}

.page-hero-summary span {
    display: inline-flex;
    align-items: center;
    padding: 7px 10px;
    border-radius: 12px;
    background: var(--guest-ui-tag-bg);
    color: var(--guest-ui-tag-text);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-sm);
    font-weight: max(var(--portal-text-weight), 500);
}

@media (max-width: 560px) {
    .guest-menu-category-rail {
        padding-inline: 16px;
    }

.guest-menu-category-nav a {
        min-width: 104px;
        max-width: min(52vw, 156px);
        min-height: 40px;
        padding-inline: 12px;
        font-size: var(--portal-type-title-sm);
    }

    .menu-category-group > h3,
    .menu-category-group > h4 {
        font-size: var(--portal-type-title-md);
    }

    .back-to-top-button {
        right: 12px;
        bottom: calc(env(safe-area-inset-bottom, 0px) + 12px);
        width: 40px;
        height: 40px;
    }

    .guest-shell .schedule-item {
        padding: 6px 8px;
        border-radius: 10px;
    }

    .guest-shell .schedule-main {
        gap: 2px;
    }

    .guest-shell .schedule-top-row {
        gap: 6px;
    }

    .guest-shell .schedule-main h3 {
        font-size: 0.84rem;
    }

    .guest-shell .schedule-main p {
        font-size: 0.72rem;
    }

    .guest-shell .schedule-item .time-pill {
        padding: 2px 5px;
        font-size: 0.68rem;
    }

    .guest-shell .schedule-badge {
        padding: 2px 5px;
        font-size: 0.62rem;
    }

    .menu-item-image {
        width: var(--portal-detail-image-size, 76px);
        height: var(--portal-detail-image-size, 76px);
        flex-basis: var(--portal-detail-image-size, 76px);
        border-radius: 12px;
    }

    .menu-item-meta-row {
        margin-top: 6px;
    }
}

@media (min-width: 680px) {
    .guest-shell {
        padding-top: 22px;
    }

    .page-hero-desktop-meta {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 16px;
        min-width: 0;
        margin: 0 0 10px;
    }

    .page-hero-desktop-meta .page-breadcrumb {
        flex: 1 1 auto;
        min-width: 0;
    }

    .page-hero-language-desktop {
        display: grid;
        flex: 0 0 auto;
        margin-left: auto;
    }

    .page-hero-back-desktop {
        display: inline-flex;
        position: fixed;
        top: 18px;
        z-index: 30;
        left: var(--desktop-back-left);
        width: 40px;
        margin-top: 0;
        transform: none;
    }

    .page-hero-back-desktop:hover,
    .page-hero-back-desktop:focus-visible {
        transform: none;
    }

    .page-hero-language-desktop,
    .page-hero-mobile-bar .page-hero-language-mobile {
        border-color: var(--portal-glass-border);
        background:
            linear-gradient(
                180deg,
                rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
                rgba(255, 255, 255, 0.04)
            ),
            var(--portal-glass-bg);
        background-position:
            0 0;
        background-size:
            100% 100%;
        background-repeat: no-repeat;
        color: var(--portal-main-font-color);
        box-shadow:
            var(--portal-shadow-soft),
            inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
        backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
        -webkit-backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    }

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

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

    .guest-menu-category-nav a {
        min-width: 144px;
    }

    .guest-menu-category-rail {
        pointer-events: none;
    }

    .guest-menu-category-nav {
        pointer-events: auto;
        touch-action: pan-x;
    }

}

@media (min-width: 820px) {
    .guest-hero,
    .page-hero,
    .portal-element-card,
    .empty-state {
        padding: 24px;
    }

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

    .portal-card {
        align-content: start;
    }

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

    .schedule-item {
        grid-template-columns: auto minmax(0, 1fr);
        align-items: start;
        gap: 16px;
    }
}

@media (max-width: 679px) {
    .page-breadcrumb {
        display: none;
    }

    .page-hero-back-desktop {
        display: none;
    }

    .page-hero-topline {
        position: relative;
        display: block;
        width: 100%;
    }

    .page-hero-main {
        position: relative;
        width: 100%;
        min-width: 0;
    }

.page-hero-mobile-bar {
    --page-hero-mobile-bar-padding-top: 12px;
    --page-hero-mobile-bar-padding-x: 16px;
    --page-hero-mobile-bar-padding-bottom: 10px;
    position: fixed;
    top: 0;
    left: var(--mobile-bar-left, 0px);
        right: auto;
        z-index: 40;
        display: grid;
        gap: 10px;
        width: var(--mobile-bar-width, 100vw);
    min-width: 0;
    box-sizing: border-box;
    min-height: 40px;
    padding: calc(env(safe-area-inset-top, 0px) + var(--page-hero-mobile-bar-padding-top)) var(--page-hero-mobile-bar-padding-x) 0;
    border: 1px solid transparent;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    transition: background 180ms ease, border-color 180ms ease, box-shadow 180ms ease, backdrop-filter 180ms ease, -webkit-backdrop-filter 180ms ease, padding 160ms ease, gap 160ms ease;
    pointer-events: none;
    transform: none;
}

    .page-hero-mobile-bar-main {
        position: relative;
        display: grid;
        grid-template-columns: 40px minmax(0, 1fr) auto;
        align-items: center;
        gap: 10px;
        min-width: 0;
        min-height: 40px;
    }

.page-hero-mobile-bar.is-fixed {
        position: fixed;
        top: 0;
        left: var(--mobile-bar-left, 0px);
        right: auto;
        width: var(--mobile-bar-width, 100vw);
        padding: calc(env(safe-area-inset-top, 0px) + var(--page-hero-mobile-bar-padding-top)) var(--page-hero-mobile-bar-padding-x) var(--page-hero-mobile-bar-padding-bottom);
        pointer-events: none;
        box-sizing: border-box;
        transform: none;
        z-index: 40;
        border-radius: 0 0 8px 8px;
        border-color: rgba(255, 255, 255, calc(var(--guest-glass-border-alpha, 0.26) * var(--mobile-bar-opacity, 0)));
        background:
            linear-gradient(
                180deg,
                rgba(255, 255, 255, calc(var(--guest-glass-highlight-alpha, 0.11) * var(--mobile-bar-opacity, 0))),
                rgba(255, 255, 255, 0)
            ),
            rgba(var(--portal-container-color-rgb, 255, 255, 255), calc(var(--portal-container-transparency, 0.59) * var(--mobile-bar-opacity, 0)));
        box-shadow:
            0 12px 28px rgba(20, 35, 30, calc(var(--guest-glass-shadow-alpha, 0.11) * var(--mobile-bar-opacity, 0))),
            inset 0 1px 0 rgba(255, 255, 255, calc(var(--guest-glass-highlight-alpha, 0.11) * var(--mobile-bar-opacity, 0)));
        backdrop-filter: blur(calc(var(--guest-glass-blur, 17px) * var(--mobile-bar-opacity, 0))) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
        -webkit-backdrop-filter: blur(calc(var(--guest-glass-blur, 17px) * var(--mobile-bar-opacity, 0))) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    }

    .page-hero-mobile-bar.has-categories {
        gap: 10px;
    }

    .page-hero-mobile-bar-main {
        pointer-events: none;
    }

    .page-hero-mobile-bar-categories {
        min-width: 0;
        max-height: calc(var(--mobile-category-slot-opacity, 0) * 56px);
        overflow: hidden;
        opacity: var(--mobile-category-slot-opacity, 0);
        pointer-events: none;
        transition: max-height 160ms ease, opacity 160ms ease;
    }

    .page-hero-mobile-bar .page-hero-back-mobile,
    .page-hero-mobile-bar .page-hero-language-mobile,
    .page-hero-mobile-bar-categories .guest-menu-category-nav,
    .page-hero-mobile-bar-categories .guest-menu-category-nav a {
        pointer-events: auto;
    }

    .page-hero-back-mobile {
        display: inline-flex;
        position: relative;
        z-index: 1;
        transform: none;
    }

    .page-hero-back-mobile:hover,
    .page-hero-back-mobile:focus-visible {
        transform: none;
    }

    .page-hero-mobile-bar-title {
        position: absolute;
        left: 50%;
        width: calc(100% - 132px);
        overflow: hidden;
        color: var(--portal-main-font-color);
        font-family: var(--portal-title-font);
        font-size: var(--portal-type-title-md);
        font-weight: var(--portal-title-weight);
        line-height: 1.1;
        text-align: center;
        white-space: nowrap;
        text-overflow: ellipsis;
        opacity: 0;
        transform: translateX(-50%);
        transition: opacity 180ms ease;
        pointer-events: none;
    }

    .page-hero-mobile-bar.show-title .page-hero-mobile-bar-title {
        opacity: 1;
    }

    .page-hero-language-mobile {
        min-width: 52px;
        max-width: calc(100% - 64px);
        justify-self: end;
        pointer-events: auto;
        margin-left: auto;
    }

    .page-hero-mobile-bar .page-hero-back-mobile {
        margin-bottom: 0;
        border-color: var(--portal-glass-border);
        background:
            linear-gradient(
                180deg,
                rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
                rgba(255, 255, 255, 0.04)
            ),
            var(--portal-glass-bg);
        color: var(--portal-main-font-color);
        box-shadow:
            var(--portal-shadow-soft),
            inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
        backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
        -webkit-backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    }

    .page-hero-mobile-bar .page-hero-back-mobile:hover,
    .page-hero-mobile-bar .page-hero-back-mobile:focus-visible {
        border-color: var(--portal-divider-color);
        background:
            linear-gradient(
                180deg,
                rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
                rgba(255, 255, 255, 0.04)
            ),
            var(--portal-glass-bg);
        color: var(--portal-main-font-color);
        box-shadow:
            var(--portal-shadow),
            inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
    }

    .page-hero-mobile-bar .page-hero-language-mobile {
        border-color: var(--portal-glass-border);
        background:
            linear-gradient(
                180deg,
                rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
                rgba(255, 255, 255, 0.04)
            ),
            var(--portal-glass-bg);
        background-position:
            0 0;
        background-size:
            100% 100%;
        background-repeat: no-repeat;
        color: var(--portal-main-font-color);
        box-shadow:
            var(--portal-shadow-soft),
            inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
        backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
        -webkit-backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    }

    .page-hero-mobile-bar-categories[hidden] {
        display: none;
    }

    .page-hero-mobile-bar-categories .guest-menu-category-nav {
        width: 100%;
        min-width: 0;
        max-width: none;
        padding: 0 0 2px;
        overflow-x: auto;
        overflow-y: hidden;
        pointer-events: auto;
    }

    .public-element-nav {
        width: 100vw;
        max-width: none;
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
        padding-left: 16px;
        padding-right: 16px;
        box-sizing: border-box;
    }

    .public-element-nav {
        overflow-x: auto;
        padding-top: 3px;
        padding-bottom: 1px;
        position: relative;
        z-index: 12;
    }

    .guest-menu-category-rail {
        position: static;
        top: auto;
        width: 100%;
        max-width: 100%;
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
        overflow-x: hidden;
        overflow-y: visible;
        background: transparent;
        isolation: auto;
        opacity: var(--mobile-category-rail-opacity, 1);
        transition: opacity 160ms ease;
    }

    .guest-menu-category-rail.is-mobile-docked {
        position: relative;
        top: auto;
        z-index: 0;
        pointer-events: var(--mobile-category-rail-pointer-events, auto);
    }

    .guest-menu-category-nav {
        width: 100%;
        min-width: 100%;
        max-width: none;
        padding-left: 0;
        padding-right: 0;
    }

    .page-hero-language-desktop {
        display: none;
    }

    .page-hero-copy {
        width: 100%;
        min-width: 0;
        max-width: none;
        padding-top: 0;
    }

    .page-hero-title-row,
    .page-hero-copy .page-subtitle,
    .page-hero-copy .portal-label-list {
        width: 100%;
        min-width: 0;
        max-width: none;
    }

    .guest-shell {
        width: min(100% - 12px, 980px);
    }

    .guest-portal-shell {
        padding-top: calc(var(--guest-mobile-topbar-height, 48px) + 14px);
    }

    .guest-hero,
    .page-hero,
    .portal-element-card,
    .empty-state {
        padding: 16px;
        border-radius: 18px;
    }

    .portal-top-card {
        border-radius: 14px;
    }

    .portal-card {
        border-radius: 18px;
    }

    .item-title-row {
        flex-direction: column;
    }

    .item-title-aside {
        justify-content: flex-start;
    }
}

/* Frosted Glass Minimal theme layer */
:root {
    --portal-highlight-color: #0f4f43;
    --portal-highlight-hover: #0b3d34;
    --portal-highlight-soft: rgba(15, 79, 67, 0.12);
    --portal-highlight-shadow: rgba(15, 79, 67, 0.22);
    --portal-main-font-color: #18362f;
    --portal-main-font-rgb: 24, 54, 47;
    --portal-main-font-muted: rgba(24, 54, 47, 0.68);
    --portal-main-font-subtle: rgba(24, 54, 47, 0.62);
    --portal-title-border-color: #000000;
    --portal-title-border-size: 0;
    --portal-title-border-width: 0px;
    --portal-text-border-color: #000000;
    --portal-text-border-size: 0;
    --portal-text-border-width: 0px;
    --portal-title-border-optical-width: var(--portal-title-border-width);
    --portal-text-border-optical-width: var(--portal-text-border-width);
    --portal-hero-border-strong-optical-width: var(--portal-top-card-text-border-strong-width, 0px);
    --portal-title-border-outline-color: color-mix(in srgb, var(--portal-title-border-color, #000) calc(var(--portal-title-border-size, 0) * 0.82%), transparent);
    --portal-text-border-outline-color: color-mix(in srgb, var(--portal-text-border-color, #000) calc(var(--portal-text-border-size, 0) * 0.82%), transparent);
    --portal-top-card-text-border-outline-color: color-mix(in srgb, var(--portal-top-card-text-border-color, #000) calc(var(--portal-top-card-text-border-size, 0) * 0.82%), transparent);
    --portal-title-border-outside-shadow:
        calc(var(--portal-title-border-optical-width) * 0.5) 0 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -0.5) 0 0 var(--portal-title-border-outline-color),
        0 calc(var(--portal-title-border-optical-width) * 0.5) 0 var(--portal-title-border-outline-color),
        0 calc(var(--portal-title-border-optical-width) * -0.5) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * 0.36) calc(var(--portal-title-border-optical-width) * 0.36) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -0.36) calc(var(--portal-title-border-optical-width) * 0.36) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * 0.36) calc(var(--portal-title-border-optical-width) * -0.36) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -0.36) calc(var(--portal-title-border-optical-width) * -0.36) 0 var(--portal-title-border-outline-color),
        var(--portal-title-border-optical-width) 0 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -1) 0 0 var(--portal-title-border-outline-color),
        0 var(--portal-title-border-optical-width) 0 var(--portal-title-border-outline-color),
        0 calc(var(--portal-title-border-optical-width) * -1) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * 0.72) calc(var(--portal-title-border-optical-width) * 0.72) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -0.72) calc(var(--portal-title-border-optical-width) * 0.72) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * 0.72) calc(var(--portal-title-border-optical-width) * -0.72) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -0.72) calc(var(--portal-title-border-optical-width) * -0.72) 0 var(--portal-title-border-outline-color);
    --portal-text-border-outside-shadow:
        calc(var(--portal-text-border-optical-width) * 0.5) 0 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -0.5) 0 0 var(--portal-text-border-outline-color),
        0 calc(var(--portal-text-border-optical-width) * 0.5) 0 var(--portal-text-border-outline-color),
        0 calc(var(--portal-text-border-optical-width) * -0.5) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * 0.36) calc(var(--portal-text-border-optical-width) * 0.36) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -0.36) calc(var(--portal-text-border-optical-width) * 0.36) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * 0.36) calc(var(--portal-text-border-optical-width) * -0.36) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -0.36) calc(var(--portal-text-border-optical-width) * -0.36) 0 var(--portal-text-border-outline-color),
        var(--portal-text-border-optical-width) 0 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -1) 0 0 var(--portal-text-border-outline-color),
        0 var(--portal-text-border-optical-width) 0 var(--portal-text-border-outline-color),
        0 calc(var(--portal-text-border-optical-width) * -1) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * 0.72) calc(var(--portal-text-border-optical-width) * 0.72) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -0.72) calc(var(--portal-text-border-optical-width) * 0.72) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * 0.72) calc(var(--portal-text-border-optical-width) * -0.72) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -0.72) calc(var(--portal-text-border-optical-width) * -0.72) 0 var(--portal-text-border-outline-color);
    --portal-top-card-text-border-outside-shadow:
        var(--portal-hero-border-strong-optical-width) 0 0 var(--portal-top-card-text-border-outline-color),
        calc(var(--portal-hero-border-strong-optical-width) * -1) 0 0 var(--portal-top-card-text-border-outline-color),
        0 var(--portal-hero-border-strong-optical-width) 0 var(--portal-top-card-text-border-outline-color),
        0 calc(var(--portal-hero-border-strong-optical-width) * -1) 0 var(--portal-top-card-text-border-outline-color),
        calc(var(--portal-hero-border-strong-optical-width) * 0.72) calc(var(--portal-hero-border-strong-optical-width) * 0.72) 0 var(--portal-top-card-text-border-outline-color),
        calc(var(--portal-hero-border-strong-optical-width) * -0.72) calc(var(--portal-hero-border-strong-optical-width) * 0.72) 0 var(--portal-top-card-text-border-outline-color),
        calc(var(--portal-hero-border-strong-optical-width) * 0.72) calc(var(--portal-hero-border-strong-optical-width) * -0.72) 0 var(--portal-top-card-text-border-outline-color),
        calc(var(--portal-hero-border-strong-optical-width) * -0.72) calc(var(--portal-hero-border-strong-optical-width) * -0.72) 0 var(--portal-top-card-text-border-outline-color);
    --portal-top-card-text-border-outside-filter:
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * 0.5) 0 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -0.5) 0 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(0 calc(var(--portal-hero-border-strong-optical-width) * 0.5) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(0 calc(var(--portal-hero-border-strong-optical-width) * -0.5) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * 0.36) calc(var(--portal-hero-border-strong-optical-width) * 0.36) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -0.36) calc(var(--portal-hero-border-strong-optical-width) * 0.36) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * 0.36) calc(var(--portal-hero-border-strong-optical-width) * -0.36) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -0.36) calc(var(--portal-hero-border-strong-optical-width) * -0.36) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(var(--portal-hero-border-strong-optical-width) 0 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -1) 0 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(0 var(--portal-hero-border-strong-optical-width) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(0 calc(var(--portal-hero-border-strong-optical-width) * -1) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * 0.72) calc(var(--portal-hero-border-strong-optical-width) * 0.72) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -0.72) calc(var(--portal-hero-border-strong-optical-width) * 0.72) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * 0.72) calc(var(--portal-hero-border-strong-optical-width) * -0.72) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -0.72) calc(var(--portal-hero-border-strong-optical-width) * -0.72) 0 var(--portal-top-card-text-border-outline-color));
    --portal-hero-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --portal-title-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --portal-text-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --portal-hero-weight: 500;
    --portal-title-weight: 500;
    --portal-text-weight: 500;
    --portal-hero-scale: 1;
    --portal-title-scale: 1;
    --portal-text-scale: 1;
    --portal-type-xs: calc(0.72rem * var(--portal-text-scale));
    --portal-type-sm: calc(0.82rem * var(--portal-text-scale));
    --portal-type-md: calc(0.94rem * var(--portal-text-scale));
    --portal-type-lg: calc(1.08rem * var(--portal-text-scale));
    --portal-type-xl: calc(1.24rem * var(--portal-text-scale));
    --portal-type-title-xs: calc(0.72rem * var(--portal-title-scale));
    --portal-type-title-sm: calc(0.82rem * var(--portal-title-scale));
    --portal-type-title-md: calc(0.94rem * var(--portal-title-scale));
    --portal-type-title-lg: calc(1.08rem * var(--portal-title-scale));
    --portal-type-title-xl: calc(1.24rem * var(--portal-title-scale));
    --portal-type-h4: calc(1.18rem * var(--portal-title-scale));
    --portal-type-h3: calc(1.34rem * var(--portal-title-scale));
    --portal-type-h2: calc(1.62rem * var(--portal-title-scale));
    --portal-type-h1: calc(2.25rem * var(--portal-title-scale));
    --portal-divider-color: rgba(24, 54, 47, 0.18);
    --portal-accent: var(--portal-highlight-color);
    --portal-accent-hover: var(--portal-highlight-hover);
    --portal-accent-soft: var(--portal-highlight-soft);
    --portal-text: var(--portal-main-font-color);
    --portal-muted: var(--portal-main-font-muted);
    --portal-container-color: #ffffff;
    --portal-container-color-rgb: 255, 255, 255;
    --portal-container-transparency: 0.59;
    --portal-container-transparency-strong: 0.71;
    --portal-glass-bg: rgba(var(--portal-container-color-rgb), var(--portal-container-transparency));
    --portal-glass-bg-strong: rgba(var(--portal-container-color-rgb), var(--portal-container-transparency-strong));
    --portal-glass-border: rgba(255, 255, 255, var(--guest-glass-border-alpha));
    --portal-shadow: 0 14px 38px rgba(31, 41, 55, var(--guest-glass-shadow-alpha));
    --portal-shadow-soft: 0 10px 26px rgba(31, 41, 55, calc(var(--guest-glass-shadow-alpha) * 0.72));
    --portal-radius-lg: 24px;
    --portal-radius-md: 18px;
    --portal-radius-sm: 999px;
    --portal-background-fallback: linear-gradient(145deg, #f5efe3, #dfe8df);
}

.guest-portal-shell {
    color: var(--portal-main-font-color);
    font-family: var(--portal-text-font);
}

.guest-footer {
    font-family: var(--portal-text-font);
}

.guest-portal-shell :where(*),
.guest-footer :where(*) {
    font-family: var(--portal-text-font);
}

.guest-portal-shell :where(
    .page-hero-title-row h1,
    .page-hero-title-row h1 .page-hero-title-text,
    .page-hero-title-row h1 .page-hero-title-line,
    .page-hero-title-row h1 .page-hero-title-line-text,
    .portal-top-card h1,
    .portal-top-card-title
) {
    font-family: var(--portal-hero-font);
    font-weight: var(--portal-hero-weight);
    --portal-hero-fill-color: var(--portal-top-card-font-color, var(--portal-main-font-color));
    --portal-hero-gradient-stop: calc(100% - (var(--portal-hero-gradient-size, 0) * 1%));
    --portal-hero-gradient-mixed-color: color-mix(
        in srgb,
        var(--portal-hero-gradient-color, #000000) calc(var(--portal-hero-gradient-size, 0) * 1%),
        var(--portal-hero-fill-color)
    );
    color: var(--portal-hero-fill-color);
    text-shadow: none;
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
    .guest-portal-shell :where(
        .page-hero-title-row h1 .page-hero-title-text,
        .page-hero-title-row h1 .page-hero-title-line-text,
        .portal-top-card-title
    ) {
        background-image: linear-gradient(
            180deg,
            var(--portal-hero-fill-color) 0%,
            var(--portal-hero-fill-color) var(--portal-hero-gradient-stop),
            var(--portal-hero-gradient-mixed-color) 100%
        );
        background-clip: text;
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
}

.guest-portal-shell :where(
    h1,
    h2,
    h3,
    h4,
    h5,
    h6,
    .portal-card-title,
    .portal-card-heading,
    .portal-element-title,
    .portal-element-heading,
    .portal-group-title,
    .group-title,
    .element-title,
    .item-title,
    .item-title-aside,
    .page-title,
    .feed-post-title,
    .feed-title,
    .menu-title,
    .menu-item-title,
    .gallery-title,
    .modal-title,
    .sticky-bar-title,
    .guest-action-title,
    .guest-action-copy strong,
    .table-heading
) {
    font-family: var(--portal-title-font);
    font-weight: var(--portal-title-weight);
}

.guest-portal-shell :where(
    .portal-label-chip,
    .portal-label,
    .content-label,
    .guest-action-label,
    .category-pill,
    .language-pill,
    .guest-feed-load-more
) {
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-sm) * 1.06);
    font-weight: max(var(--portal-text-weight), 500);
    -webkit-text-stroke: var(--portal-text-border-optical-width, 0px) var(--portal-text-border-color, #000);
    paint-order: stroke fill;
    text-shadow: none;
}

.guest-portal-shell :where(
    .page-hero-title-row h1,
    .portal-top-card h1,
    .portal-top-card-title
) {
    font-family: var(--portal-hero-font);
    font-weight: var(--portal-hero-weight);
}

.guest-portal-shell :where(
    p,
    small,
    li,
    dd,
    td,
    th,
    input,
    select,
    textarea,
    figcaption,
    button,
    .button,
    .guest-button,
    .portal-card-description,
    .portal-card-subtitle,
    .portal-element-description,
    .portal-element-subtitle,
    .portal-group-description,
    .guest-hero-copy,
    .page-hero-copy,
    .content-item-description,
    .content-item-value,
    .menu-item-description,
    .feed-post-body,
    .feed-post-summary,
    .table-cell,
    .helper-text,
    .note,
    .guest-note,
    .secondary-text
) {
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
}

.guest-portal-shell :where(
    small,
    .helper-text,
    .note,
    .guest-note,
    .secondary-text,
    .guest-action-copy small
) {
    font-size: var(--portal-type-sm);
}

.guest-portal-shell :where(.public-content-stack) :where(
    h1,
    h2,
    h3,
    .portal-element-heading h2,
    .empty-state h2,
    .portal-group-title,
    .group-title,
    .feed-title,
    .gallery-title,
    .modal-title,
    .page-title
) {
    font-size: var(--portal-type-h3);
}

.guest-portal-shell :where(.public-content-stack) :where(
    .portal-element-title,
    .portal-card-title,
    .portal-card-heading,
    .element-title,
    .item-title,
    .item-title-aside,
    .feed-post-title,
    .menu-title,
    .menu-item-title,
    .guest-action-title,
    .table-heading
) {
    font-size: var(--portal-type-lg);
}

.guest-portal-shell :where(.public-element-nav, .public-content-stack) :where(
    p,
    li,
    dd,
    td,
    th,
    figcaption,
    .portal-element-summary,
    .portal-card-description,
    .portal-card-subtitle,
    .portal-element-description,
    .portal-element-subtitle,
    .portal-group-description,
    .content-item-description,
    .content-item-value,
    .menu-item-description,
    .feed-post-body,
    .feed-post-summary,
    .table-cell,
    .helper-text,
    .note,
    .guest-note,
    .secondary-text
) {
    font-size: var(--portal-type-md);
}

.guest-portal-shell :where(.public-element-nav, .public-content-stack) :where(
    .sticky-bar-title
) {
    font-size: var(--portal-type-title-sm);
}

.guest-portal-shell :where(.public-element-nav, .public-content-stack) :where(
    small,
    .page-subtitle
) {
    font-size: var(--portal-type-sm);
}

.guest-portal-shell :where(.public-element-nav, .public-content-stack) :where(
    h1,
    h2,
    h3,
    h4,
    h5,
    h6,
    .portal-card-title,
    .portal-card-heading,
    .portal-element-title,
    .portal-element-heading,
    .portal-group-title,
    .group-title,
    .element-title,
    .item-title,
    .item-title-aside,
    .page-title,
    .feed-post-title,
    .feed-title,
    .menu-title,
    .menu-item-title,
    .gallery-title,
    .modal-title,
    .sticky-bar-title,
    .guest-action-title,
    .guest-action-copy strong,
    .table-heading
) {
    -webkit-text-stroke: var(--portal-title-border-optical-width, 0px) var(--portal-title-border-color, #000);
    paint-order: stroke fill;
    text-shadow: none;
}

.guest-portal-shell :where(.public-element-nav, .public-content-stack) :where(
    .page-subtitle,
    p,
    small,
    li,
    dd,
    td,
    th,
    input,
    select,
    textarea,
    figcaption,
    .portal-card-description,
    .portal-card-subtitle,
    .portal-element-description,
    .portal-element-subtitle,
    .portal-group-description,
    .guest-hero-copy,
    .page-hero-copy,
    .content-item-description,
    .content-item-value,
    .menu-item-description,
    .feed-post-body,
    .feed-post-summary,
    .table-cell,
    .helper-text,
    .note,
    .guest-note,
    .secondary-text
),
.guest-footer :where(strong, b, a, button, p, span, small, li) {
    -webkit-text-stroke: var(--portal-text-border-optical-width, 0px) var(--portal-text-border-color, #000);
    paint-order: stroke fill;
    text-shadow: none;
}

.guest-portal-shell::before {
    z-index: -2;
    background: var(--guest-bg-color, var(--guest-soft));
    filter: none;
    transform: none;
}

.guest-portal-shell::after {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        linear-gradient(
            rgba(var(--guest-bg-wrapper-color-rgb, 255, 255, 255), var(--guest-bg-overlay-alpha, 0)),
            rgba(var(--guest-bg-wrapper-color-rgb, 255, 255, 255), var(--guest-bg-overlay-alpha, 0))
        ),
        var(--portal-background-image, none);
    background-attachment: fixed;
    background-position: center top;
    background-size: cover;
    filter: blur(var(--guest-bg-blur, 0px));
    transform: scale(var(--guest-bg-blur-scale, 1));
    transform-origin: center top;
}

.guest-portal-shell .guest-hero,
.guest-portal-shell .page-hero,
.guest-portal-shell .portal-top-card,
.guest-portal-shell .portal-card,
.guest-portal-shell .portal-element-card,
.guest-portal-shell .empty-state,
.guest-portal-shell .guest-summary-card,
.guest-portal-shell .content-item,
.guest-portal-shell .menu-item,
.guest-portal-shell .schedule-item,
.guest-portal-shell .contact-item,
.guest-portal-shell .faq-item,
.guest-portal-shell .portal-group-grid .portal-card {
    position: relative;
    overflow: hidden;
    border-color: var(--portal-glass-border);
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, var(--guest-glass-highlight-alpha)),
            rgba(255, 255, 255, 0.04)
        ),
        var(--portal-glass-bg);
    box-shadow:
        var(--portal-shadow),
        inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha));
    backdrop-filter: blur(var(--guest-glass-blur)) saturate(var(--guest-glass-saturate)) contrast(1.06);
    -webkit-backdrop-filter: blur(var(--guest-glass-blur)) saturate(var(--guest-glass-saturate)) contrast(1.06);
}

.guest-portal-shell .guest-hero::before,
.guest-portal-shell .page-hero::before,
.guest-portal-shell .portal-top-card::before,
.guest-portal-shell .portal-card::before,
.guest-portal-shell .portal-element-card::before,
.guest-portal-shell .empty-state::before,
.guest-portal-shell .guest-summary-card::before,
.guest-portal-shell .content-item::before,
.guest-portal-shell .menu-item::before,
.guest-portal-shell .schedule-item::before,
.guest-portal-shell .contact-item::before,
.guest-portal-shell .faq-item::before,
.guest-portal-shell .portal-group-grid .portal-card::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    border-radius: inherit;
    background:
        linear-gradient(
            135deg,
            rgba(255, 255, 255, calc(var(--guest-glass-highlight-alpha) * 0.24)),
            rgba(255, 255, 255, 0) 34%
        ),
        rgba(15, 18, 16, var(--guest-glass-dark-alpha));
}

.guest-portal-shell .guest-hero > *,
.guest-portal-shell .page-hero > *,
.guest-portal-shell .portal-top-card > *,
.guest-portal-shell .portal-card > *,
.guest-portal-shell .portal-element-card > *,
.guest-portal-shell .empty-state > *,
.guest-portal-shell .guest-summary-card > *,
.guest-portal-shell .content-item > *,
.guest-portal-shell .menu-item > *,
.guest-portal-shell .schedule-item > *,
.guest-portal-shell .contact-item > *,
.guest-portal-shell .faq-item > *,
.guest-portal-shell .portal-group-grid .portal-card > * {
    position: relative;
    z-index: 1;
}

.guest-portal-shell .portal-top-card,
.guest-portal-shell .guest-hero,
.guest-portal-shell .page-hero {
    border-radius: var(--portal-radius-lg);
}

.guest-portal-shell .portal-card,
.guest-portal-shell .portal-element-card,
.guest-portal-shell .empty-state,
.guest-portal-shell .guest-summary-card,
.guest-portal-shell .portal-top-card,
.guest-portal-shell .portal-element-card,
.guest-portal-shell .empty-state {
    box-shadow: var(--portal-shadow);
}

.guest-portal-shell .portal-embedded-image,
.guest-portal-shell .portal-gallery,
.guest-portal-shell .portal-gallery-viewport,
.guest-portal-shell .portal-gallery-slide,
.guest-portal-shell .portal-richtext blockquote {
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.guest-portal-shell .portal-group-grid .portal-card:hover,
.guest-portal-shell .portal-group-grid .portal-card:focus-visible {
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, var(--guest-glass-highlight-alpha)),
            rgba(255, 255, 255, 0.04)
        ),
        var(--portal-glass-bg);
}

.guest-portal-shell .portal-card:hover {
    border-color: var(--portal-divider-color);
    box-shadow: 0 22px 54px rgba(20, 35, 30, 0.22);
}

.guest-portal-shell .portal-top-card {
    color: var(--portal-top-card-font-color, var(--portal-main-font-color));
}

.guest-portal-shell .portal-top-card :where(
    h1,
    h2,
    h3,
    p,
    span,
    strong,
    a,
    small,
    label,
    button,
    select,
    .page-subtitle,
    .portal-label-chip,
    .guest-summary-card,
    .guest-summary-card span,
    .guest-summary-card strong
) {
    color: inherit;
}

.guest-portal-shell .portal-top-card .portal-label-chip {
    color: var(--portal-highlight-color);
}

.guest-portal-shell .portal-top-card .guest-summary-card span {
    color: var(--portal-highlight-color);
}

.guest-portal-shell .portal-top-card .guest-summary-card strong {
    color: var(--portal-top-card-font-color, var(--portal-main-font-color));
}

.guest-portal-shell .portal-top-card .guest-summary-card {
    border-color: color-mix(in srgb, var(--guest-ui-primary) 12%, transparent);
    background: color-mix(in srgb, var(--guest-ui-primary) 6%, transparent);
}

.guest-portal-shell .portal-top-card-banner {
    overflow: visible;
    padding: 28px 18px 18px;
    border-color: transparent;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.guest-portal-shell .portal-top-card-banner::before {
    display: none;
}

.guest-portal-shell .portal-top-card-banner .page-hero-topline,
.guest-portal-shell .portal-top-card-banner .hero-topline,
.guest-portal-shell .portal-top-card-banner .page-hero-main,
.guest-portal-shell .portal-top-card-banner .page-hero-copy {
    justify-content: center;
    justify-items: center;
    text-align: center;
}

.guest-portal-shell .portal-top-card-banner .page-hero-copy {
    gap: 10px;
}

.guest-portal-shell .portal-top-card-banner .page-hero-title-row {
    order: 1;
}

.guest-portal-shell .portal-top-card-banner .portal-label-list-header {
    order: 2;
}

.guest-portal-shell .portal-top-card-banner .guest-summary-grid {
    order: 3;
}

.guest-portal-shell .portal-top-card-banner .page-subtitle {
    order: 4;
}

.guest-portal-shell .portal-top-card-banner .page-hero-title-row {
    justify-content: center;
    justify-items: center;
}

.guest-portal-shell .portal-top-card-banner .page-hero-title-row h1 {
    flex: 0 1 auto;
}

.guest-portal-shell .portal-top-card-banner .page-subtitle {
    width: 75%;
    max-width: 62ch;
    margin-inline: auto;
    justify-self: center;
}

.guest-portal-shell .portal-top-card-banner .portal-label-list,
.guest-portal-shell .portal-top-card-banner .guest-summary-grid {
    justify-content: center;
    justify-items: center;
}

.guest-portal-shell .portal-top-card-banner .portal-label-chip,
.guest-portal-shell .portal-top-card-banner .guest-summary-card,
.guest-portal-shell .public-element-nav .portal-label-chip {
    border-color: var(--portal-glass-border);
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, var(--guest-glass-highlight-alpha)),
            rgba(255, 255, 255, 0.04)
        ),
        var(--portal-glass-bg);
    color: var(--portal-highlight-color);
    box-shadow:
        0 10px 22px rgba(20, 35, 30, var(--guest-glass-shadow-alpha)),
        inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha));
    backdrop-filter: blur(var(--guest-glass-blur)) saturate(var(--guest-glass-saturate)) contrast(1.06);
    -webkit-backdrop-filter: blur(var(--guest-glass-blur)) saturate(var(--guest-glass-saturate)) contrast(1.06);
}

.guest-portal-shell .portal-top-card-banner .guest-summary-grid {
    width: 100%;
}

.guest-portal-shell .portal-top-card-banner .portal-label-chip {
    font-size: calc(var(--portal-type-sm) * 1.219);
}

.guest-portal-shell .public-element-nav .portal-label-chip {
    color: var(--portal-main-font-color);
}

.guest-portal-shell .portal-top-card-banner .guest-summary-card {
    justify-items: center;
    text-align: center;
}

.guest-portal-shell .portal-top-card-banner .guest-summary-card::before {
    display: none;
}

.guest-portal-shell .portal-top-card-banner :where(
    a,
    label,
    button,
    select
) {
    font-weight: var(--portal-text-weight);
}

.guest-portal-shell .portal-top-card-banner h1 {
    font-weight: var(--portal-hero-weight);
}

.guest-portal-shell .portal-top-card-banner .page-subtitle {
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
}

.guest-portal-shell .portal-top-card-text-border :where(
    .page-hero-title-row h1:not(.page-hero-title-lines-enhanced) > .page-hero-title-text,
    .page-hero-title-row h1 .page-hero-title-line-text,
    .portal-top-card-title
) {
    position: relative;
    isolation: isolate;
    -webkit-text-stroke: 0 transparent;
    color: transparent;
    paint-order: fill;
    text-shadow: none;
    filter: none;
}

.guest-portal-shell .portal-top-card-text-border :where(
    .page-hero-title-row h1:not(.page-hero-title-lines-enhanced) > .page-hero-title-text,
    .page-hero-title-row h1 .page-hero-title-line-text,
    .portal-top-card-title
) {
    -webkit-text-stroke-width: 0;
    text-shadow: none;
    filter: none;
}

.guest-portal-shell .portal-top-card-text-border :where(
    .page-hero-title-row h1:not(.page-hero-title-lines-enhanced) > .page-hero-title-text,
    .page-hero-title-row h1 .page-hero-title-line-text,
    .portal-top-card-title
)::before {
    content: attr(data-hero-outline-text);
    position: absolute;
    inset: 0;
    z-index: -1;
    color: transparent;
    -webkit-text-fill-color: transparent;
    -webkit-text-stroke: var(--portal-hero-border-strong-optical-width, 0px) var(--portal-top-card-text-border-color, #000);
    paint-order: stroke fill;
    pointer-events: none;
}

.guest-portal-shell .portal-top-card-text-border :where(
    .page-hero-title-row h1:not(.page-hero-title-lines-enhanced) > .page-hero-title-text,
    .page-hero-title-row h1 .page-hero-title-line-text,
    .portal-top-card-title
)::after {
    content: attr(data-hero-outline-text);
    position: absolute;
    inset: 0;
    z-index: 1;
    color: var(--portal-hero-fill-color);
    -webkit-text-stroke: 0 transparent;
    pointer-events: none;
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
    .guest-portal-shell .portal-top-card-text-border :where(
        .page-hero-title-row h1:not(.page-hero-title-lines-enhanced) > .page-hero-title-text,
        .page-hero-title-row h1 .page-hero-title-line-text,
        .portal-top-card-title
    )::after {
        background-image: linear-gradient(
            180deg,
            var(--portal-hero-fill-color) 0%,
            var(--portal-hero-fill-color) var(--portal-hero-gradient-stop),
            var(--portal-hero-gradient-mixed-color) 100%
        );
        background-clip: text;
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
}

.guest-portal-shell .portal-top-card-text-border :where(.page-subtitle, .hotel-description) {
    -webkit-text-stroke: var(--portal-text-border-optical-width, 0px) var(--portal-text-border-color, #000);
    paint-order: stroke fill;
    text-shadow: none;
}

.guest-portal-shell .portal-top-card-no-icon .page-hero-title-row {
    justify-content: center;
}

.guest-portal-shell :where(.public-content-stack) :where(
    .portal-element-heading h2,
    .empty-state h2,
    .portal-group-title,
    .group-title,
    .feed-title,
    .gallery-title,
    .modal-title,
    .page-title
) {
    font-family: var(--portal-title-font);
    font-size: var(--portal-type-h3);
    font-weight: var(--portal-title-weight);
}

.guest-portal-shell :where(.public-content-stack) :where(
    .portal-element-title,
    .portal-card-title,
    .portal-card-heading,
    .element-title,
    .item-title,
    .item-title-aside,
    .feed-post-title,
    .menu-title,
    .menu-item-title,
    .guest-action-copy strong,
    .table-heading
) {
    font-family: var(--portal-title-font);
    font-size: var(--portal-type-lg);
    font-weight: var(--portal-title-weight);
}

.guest-portal-shell :where(.public-element-nav, .public-content-stack) :where(
    p,
    li,
    dd,
    td,
    th,
    figcaption,
    .portal-element-summary,
    .portal-card-description,
    .portal-card-subtitle,
    .portal-element-description,
    .portal-element-subtitle,
    .portal-group-description,
    .content-item-description,
    .content-item-value,
    .menu-item-description,
    .feed-post-body,
    .feed-post-summary,
    .table-cell,
    .helper-text,
    .note,
    .guest-note,
    .secondary-text,
    .guest-action-copy small
) {
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
}

.guest-portal-shell :where(.public-element-nav, .public-content-stack) :where(
    .guest-summary-card span,
    .guest-summary-card strong
) {
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-sm);
    font-weight: max(var(--portal-text-weight), 500);
}

.guest-portal-shell :where(.public-element-nav, .public-content-stack) :where(
    small,
    .page-subtitle
) {
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-sm);
    font-weight: var(--portal-text-weight);
}

.guest-portal-shell .guest-menu-category-rail {
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.guest-portal-shell .page-hero-mobile-bar.is-fixed {
    border-color: rgba(255, 255, 255, calc(var(--guest-glass-border-alpha, 0.26) * var(--mobile-bar-opacity, 0)));
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, calc(var(--guest-glass-highlight-alpha, 0.11) * var(--mobile-bar-opacity, 0))),
            rgba(255, 255, 255, 0)
        ),
        rgba(var(--portal-container-color-rgb, 255, 255, 255), calc(var(--portal-container-transparency, 0.59) * var(--mobile-bar-opacity, 0)));
    box-shadow:
        0 12px 28px rgba(20, 35, 30, calc(var(--guest-glass-shadow-alpha, 0.11) * var(--mobile-bar-opacity, 0))),
        inset 0 1px 0 rgba(255, 255, 255, calc(var(--guest-glass-highlight-alpha, 0.11) * var(--mobile-bar-opacity, 0)));
    backdrop-filter: blur(calc(var(--guest-glass-blur, 17px) * var(--mobile-bar-opacity, 0))) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    -webkit-backdrop-filter: blur(calc(var(--guest-glass-blur, 17px) * var(--mobile-bar-opacity, 0))) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
}

.guest-portal-shell .portal-richtext blockquote,
.guest-portal-shell .content-item + .content-item::before,
.guest-portal-shell .menu-item-trigger + template + .menu-item-trigger::before,
.guest-portal-shell .public-element-nav,
.guest-portal-shell .guest-menu-category-nav,
.guest-portal-shell .portal-richtext hr,
.guest-portal-shell .menu-category-group > h3 {
    border-color: var(--portal-divider-color);
}

.guest-portal-shell .content-item + .content-item::before {
    background: var(--portal-divider-color);
}

.guest-portal-shell .menu-item-trigger + template + .menu-item-trigger::before {
    background: var(--portal-divider-color);
}

.guest-portal-shell .portal-page-list,
.guest-portal-shell .portal-group-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 12px;
}

.portal-content-element .item-list,
.portal-content-element .menu-category-group .item-list {
    gap: 0;
}

.guest-portal-shell .portal-content-element .content-item,
.guest-portal-shell .portal-content-element .menu-item,
.guest-portal-shell .portal-content-element .schedule-item,
.guest-portal-shell .portal-content-element .contact-item,
.guest-portal-shell .portal-content-element .faq-item {
    position: relative;
    overflow: visible;
    gap: 8px;
    padding: 12px 0;
    border: 0;
    border-radius: 0;
    background: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

.guest-portal-shell .portal-content-element .content-item::before,
.guest-portal-shell .portal-content-element .menu-item::before,
.guest-portal-shell .portal-content-element .schedule-item::before,
.guest-portal-shell .portal-content-element .contact-item::before,
.guest-portal-shell .portal-content-element .faq-item::before {
    content: none;
    background: transparent;
}

.guest-portal-shell .portal-content-element .content-item + .content-item::before {
    content: "";
    position: absolute;
    top: 0;
    left: 12px;
    right: 12px;
    height: 1px;
    background: var(--portal-divider-color);
}

.guest-portal-shell .portal-content-element .menu-item-trigger + template + .menu-item-trigger::before {
    content: "";
    position: absolute;
    top: 0;
    left: 12px;
    right: 12px;
    height: 1px;
    background: var(--portal-divider-color);
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-trigger + template + .menu-item-trigger::before {
    left: 0;
    right: 0;
}

.portal-content-element .menu-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
}

.portal-content-element .menu-item-compact-dot {
    display: none;
}

.portal-content-element .menu-item .item-main {
    flex: 1 1 auto;
}

.portal-content-element .menu-item-image,
.guest-portal-shell .portal-content-element .menu-item-image {
    width: var(--portal-detail-image-size, 88px);
    min-width: var(--portal-detail-image-size, 88px);
    max-width: var(--portal-detail-image-size, 88px);
    height: var(--portal-detail-image-size, 88px);
    min-height: var(--portal-detail-image-size, 88px);
    max-height: var(--portal-detail-image-size, 88px);
    flex: 0 0 var(--portal-detail-image-size, 88px);
    margin-left: auto;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

.guest-table-element {
    display: grid;
    gap: 10px;
    color: var(--portal-main-font-color);
}

.guest-table-grid {
    display: grid;
    gap: 0;
    overflow-x: auto;
    border-radius: 14px;
}

.guest-table-overlap-tight .guest-table-grid {
    overflow-x: hidden;
}

.guest-table-element.has-outer-grid .guest-table-grid {
    border: 1px solid var(--portal-divider-color);
}

.guest-table-header-row,
.guest-table-grid-row {
    display: grid;
    grid-template-columns: repeat(var(--table-columns, 3), minmax(120px, 1fr));
    min-width: calc(var(--table-columns, 3) * 120px);
}

.guest-table-overlap-tight .guest-table-header-row,
.guest-table-overlap-tight .guest-table-grid-row {
    grid-template-columns: repeat(var(--table-columns, 3), minmax(0, 1fr));
    min-width: 0;
}

.guest-table-header-cell,
.guest-table-grid-cell {
    min-width: 0;
    padding: 10px 12px;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.guest-table-overlap-tight .guest-table-header-cell,
.guest-table-overlap-tight .guest-table-grid-cell {
    padding: clamp(6px, 1.2vw, 10px) clamp(6px, 1.4vw, 12px);
    font-size: calc(clamp(0.74rem, 2.3vw, 0.94rem) * var(--portal-text-scale));
}

.guest-table-element.has-columns-grid .guest-table-header-cell,
.guest-table-element.has-columns-grid .guest-table-grid-cell {
    border-right: 1px solid var(--portal-divider-color);
}

.guest-table-element.has-rows-grid .guest-table-header-cell,
.guest-table-element.has-rows-grid .guest-table-grid-cell {
    border-bottom: 1px solid var(--portal-divider-color);
}

.guest-table-element.has-columns-grid .guest-table-header-cell:last-child,
.guest-table-element.has-columns-grid .guest-table-grid-cell:last-child {
    border-right: 0;
}

.guest-table-header-cell {
    background: var(--portal-accent-soft);
    color: var(--portal-main-font-color);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    text-transform: uppercase;
}

.guest-table-element.has-rows-grid .guest-table-grid-row:last-child .guest-table-grid-cell {
    border-bottom: 0;
}

.guest-table-grid-cell {
    display: grid;
    color: var(--portal-main-font-color);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
    line-height: 1.4;
}

.guest-table-grid-cell.align-h-left,
.guest-table-card-cell.align-h-left {
    justify-items: start;
    text-align: left;
}

.guest-table-grid-cell.align-h-center,
.guest-table-card-cell.align-h-center {
    justify-items: center;
    text-align: center;
}

.guest-table-grid-cell.align-h-right,
.guest-table-card-cell.align-h-right {
    justify-items: end;
    text-align: right;
}

.guest-table-grid-cell.align-v-top,
.guest-table-card-cell.align-v-top {
    align-items: start;
}

.guest-table-grid-cell.align-v-middle,
.guest-table-card-cell.align-v-middle {
    align-items: center;
}

.guest-table-grid-cell.align-v-bottom,
.guest-table-card-cell.align-v-bottom {
    align-items: end;
}

.guest-table-cell-value {
    width: 100%;
    min-width: 0;
}

.guest-table-cell-value.portal-richtext {
    --table-richtext-line-height: 1.24;
    gap: 0 !important;
    line-height: var(--table-richtext-line-height) !important;
}

.guest-table-cell-value.portal-richtext > *,
.guest-table-cell-value.portal-richtext :where(h1, h2, h3, h4, h5, h6, p, ul, ol, li, blockquote, hr, div) {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    line-height: var(--table-richtext-line-height) !important;
}

.guest-table-cell-value.portal-richtext :where(p, ul, ol, li, blockquote) {
    line-height: var(--table-richtext-line-height) !important;
}

.guest-table-cell-value.portal-richtext :where(h1, h2, h3, h4, h5, h6) {
    margin: 0 !important;
    color: var(--guest-ink);
    font-family: var(--portal-title-font);
    font-weight: var(--portal-title-weight);
    line-height: var(--table-richtext-line-height) !important;
    letter-spacing: 0 !important;
}

.guest-table-cell-value.portal-richtext p,
.guest-table-cell-value.portal-richtext li,
.guest-table-cell-value.portal-richtext blockquote {
    font-size: inherit;
    line-height: var(--table-richtext-line-height) !important;
}

.guest-table-cell-value.portal-richtext h1 {
    font-size: 1.06em;
}

.guest-table-cell-value.portal-richtext h2 {
    font-size: 1.04em;
}

.guest-table-cell-value.portal-richtext h3 {
    font-size: 1.02em;
}

.guest-table-cell-value.portal-richtext h4,
.guest-table-cell-value.portal-richtext h5,
.guest-table-cell-value.portal-richtext h6 {
    font-size: 1em;
}

.guest-table-cell-value.portal-richtext ul,
.guest-table-cell-value.portal-richtext ol {
    gap: 0 !important;
    padding-left: 16px !important;
}

.guest-table-cell-value.portal-richtext li > :where(p, ul, ol) {
    margin-block: 0 !important;
}

.guest-table-cell-value.portal-richtext blockquote {
    padding: 2px 8px;
    border-radius: 0 10px 10px 0;
}

.guest-table-cell-value.portal-richtext blockquote > * {
    margin-block: 0 !important;
    line-height: var(--table-richtext-line-height) !important;
}

.guest-table-cell-value.portal-richtext hr {
    margin: 1px 0 !important;
}

.guest-table-cell-value > :first-child {
    margin-top: 0 !important;
}

.guest-table-cell-value > :last-child {
    margin-bottom: 0 !important;
}

.guest-table-row-card {
    display: block;
    padding: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.guest-table-mode-cards {
    gap: 0;
}

.guest-table-mode-cards.has-outer-grid {
    overflow: hidden;
    border: 1px solid var(--portal-divider-color);
    border-radius: 14px;
}

.guest-table-overlap-tight .guest-table-row-card {
    font-size: calc(clamp(0.76rem, 2.3vw, 0.94rem) * var(--portal-text-scale));
}

.guest-table-card-fields {
    display: grid;
    grid-template-columns: repeat(var(--table-columns, 3), minmax(0, 1fr));
    gap: 0;
    border-radius: 0;
    overflow: visible;
}

.guest-table-card-header-row {
    display: grid;
    grid-template-columns: repeat(var(--table-columns, 3), minmax(0, 1fr));
    min-width: 0;
    background: var(--portal-accent-soft);
}

.guest-table-card-header-cell {
    min-width: 0;
    padding: 8px 9px;
    color: var(--portal-main-font-color);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: 1.2;
    text-transform: uppercase;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.guest-table-mode-cards.has-headers .guest-table-card-cell > span {
    display: none;
}

.guest-table-element.has-rows-grid .guest-table-row-card + .guest-table-row-card {
    border-top: 1px solid var(--portal-divider-color);
}

.guest-table-mode-cards.has-rows-grid .guest-table-card-header-row {
    border-bottom: 1px solid var(--portal-divider-color);
}

.guest-table-mode-cards.has-columns-grid .guest-table-card-header-cell + .guest-table-card-header-cell {
    border-left: 1px solid var(--portal-divider-color);
}

.guest-table-mode-cards.has-outer-grid .guest-table-card-fields {
    border: 0;
}

.guest-table-mode-cards:not(.has-outer-grid) .guest-table-card-fields {
    border: 1px solid var(--portal-divider-color);
}

.guest-table-mode-cards.has-headers:not(.has-outer-grid) .guest-table-card-header-row {
    border: 1px solid var(--portal-divider-color);
    border-bottom: 0;
    border-top-left-radius: 14px;
    border-top-right-radius: 14px;
    overflow: hidden;
}

.guest-table-mode-cards.has-headers:not(.has-outer-grid) .guest-table-row-card:first-of-type .guest-table-card-fields {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

.guest-table-mode-cards.has-rows-grid:not(.has-outer-grid) .guest-table-row-card + .guest-table-row-card .guest-table-card-fields {
    border-top: 0;
}

.guest-table-mode-cards:not(.has-outer-grid) .guest-table-row-card:first-child .guest-table-card-fields {
    border-top-left-radius: 14px;
    border-top-right-radius: 14px;
}

.guest-table-mode-cards:not(.has-outer-grid) .guest-table-row-card:last-child .guest-table-card-fields {
    border-bottom-left-radius: 14px;
    border-bottom-right-radius: 14px;
}

.guest-table-card-cell {
    display: grid;
    grid-column: span var(--cell-span, 1);
    gap: 4px;
    min-width: 0;
    padding: 8px 9px;
    border-radius: 0;
    background: transparent;
}

.guest-table-element.has-columns-grid .guest-table-card-cell + .guest-table-card-cell {
    border-left: 1px solid var(--portal-divider-color);
}

.guest-table-card-cell span {
    color: var(--portal-main-font-color);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    text-transform: uppercase;
}

.guest-table-card-cell .guest-table-cell-value {
    color: var(--portal-main-font-color);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
    line-height: 1.35;
    overflow-wrap: anywhere;
    word-break: break-word;
}

@media (max-width: 560px) {
    .guest-table-mode-cards {
        gap: calc(var(--portal-content-inset-unit, 12px) * 0.8);
    }

    .guest-table-mode-cards.has-outer-grid {
        overflow: visible;
        border: 0;
        border-radius: 0;
    }

    .guest-table-mode-cards .guest-table-row-card + .guest-table-row-card {
        margin-top: calc(var(--portal-content-inset-unit, 12px) * 0.8);
        border-top: 0;
    }

    .guest-table-card-header-row {
        display: none;
    }

    .guest-table-mode-cards.has-headers .guest-table-card-cell > span {
        display: block;
    }

    .guest-table-card-fields {
        grid-template-columns: minmax(0, 1fr);
        border-radius: 14px;
    }

    .guest-table-mode-cards.has-outer-grid .guest-table-card-fields {
        border: 1px solid var(--portal-divider-color);
    }


    .guest-table-card-cell {
        grid-column: auto;
    }

    .guest-table-element.has-columns-grid .guest-table-card-cell + .guest-table-card-cell {
        border-top: 1px solid var(--portal-divider-color);
        border-left: 0;
    }
}

.guest-feed-element {
    display: grid;
    gap: 12px;
    --feed-collapsed-post-height: 8.75rem;
    --feed-post-gap: 0px;
    --feed-load-more-allowance: 3.8rem;
}

.guest-feed-load-more {
    --feed-load-more-title-base-size: 0.9rem;
    --feed-load-more-title-line-height: 1.22;
    min-height: 38px;
    padding: 8px 18px;
    border: 1px solid color-mix(in srgb, var(--portal-highlight-color) 82%, transparent);
    border-radius: 999px;
    background: var(--portal-highlight-color);
    color: var(--guest-ui-primary-contrast);
    font-family: var(--portal-text-font);
    font-size: calc(var(--feed-load-more-title-base-size) * var(--portal-text-scale));
    font-weight: max(var(--portal-text-weight), 500);
    line-height: var(--feed-load-more-title-line-height);
    cursor: pointer;
    box-shadow: 0 10px 22px color-mix(in srgb, var(--portal-highlight-color) 24%, transparent);
    transition: background 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}

.guest-feed-load-more:hover,
.guest-feed-load-more:focus-visible {
    border-color: var(--portal-highlight-hover);
    background: var(--portal-highlight-hover);
    color: var(--guest-ui-primary-contrast);
    box-shadow: 0 12px 26px color-mix(in srgb, var(--portal-highlight-color) 30%, transparent);
}

.guest-feed-load-more:active {
    transform: translateY(1px);
}

.guest-feed-posts-scroll {
    overflow: visible;
}

.guest-feed-element.is-height-limited .guest-feed-posts-scroll {
    max-height: min(
        calc(
            (var(--feed-visible-posts, 3) * var(--feed-collapsed-post-height)) +
            ((var(--feed-visible-posts, 3) - 1) * var(--feed-post-gap)) +
            var(--feed-load-more-allowance)
        ),
        78vh
    );
    overflow-y: auto;
    overscroll-behavior: contain;
    padding-right: 3px;
    scroll-behavior: smooth;
    scrollbar-width: thin;
}

.guest-feed-list {
    display: grid;
    gap: var(--feed-post-gap);
}

.guest-feed-post {
    position: relative;
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.guest-feed-post + .guest-feed-post::before {
    content: "";
    position: absolute;
    top: 0;
    left: 12px;
    right: 12px;
    height: 1px;
    background: var(--portal-divider-color);
    opacity: 0.78;
}

.guest-feed-post[hidden] {
    display: none;
}

.guest-feed-post-link {
    display: block;
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    color: inherit;
    font: inherit;
    text-align: left;
    cursor: pointer;
    text-decoration: none;
}

.guest-feed-post-preview {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
        "meta"
        "title"
        "excerpt";
    column-gap: 10px;
    row-gap: 7px;
    align-items: start;
    height: var(--feed-collapsed-post-height);
    min-height: var(--feed-collapsed-post-height);
    padding: 13px 12px 14px;
    border-radius: 0;
    background: transparent;
}

.guest-feed-post-preview.has-image {
    grid-template-columns: minmax(0, 1fr) var(--portal-detail-image-size, 88px);
    grid-template-areas:
        "meta meta"
        "title image"
        "excerpt image";
}

.guest-feed-preview-image {
    grid-area: image;
    align-self: start;
    justify-self: end;
    width: var(--portal-detail-image-size, 88px);
    height: var(--portal-detail-image-size, 88px);
    aspect-ratio: 1 / 1;
    min-height: var(--portal-detail-image-size, 88px);
    min-width: var(--portal-detail-image-size, 88px);
    max-height: var(--portal-detail-image-size, 88px);
    max-width: var(--portal-detail-image-size, 88px);
    border-radius: 12px;
    object-fit: cover;
}

.guest-feed-preview-copy {
    display: contents;
    min-width: 0;
}

.guest-feed-meta-row {
    grid-area: meta;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    color: var(--portal-main-font-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: 1;
}

.guest-feed-meta-row time,
.guest-feed-meta-row span,
.guest-feed-pin {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 22px;
    padding: 4px 8px;
    border-radius: 999px;
    line-height: 1;
}

.guest-feed-meta-row time {
    padding-left: 0;
    background: transparent;
    color: var(--portal-main-font-muted);
}

.guest-feed-meta-row span,
.guest-feed-pin {
    background: var(--guest-ui-tag-bg);
    color: var(--guest-ui-tag-text);
}

.guest-feed-post h3 {
    grid-area: title;
    margin: 0;
    color: var(--portal-main-font-color);
    font-family: var(--portal-title-font);
    font-size: var(--portal-type-title-lg);
    font-weight: var(--portal-title-weight);
    line-height: 1.16;
}

.guest-feed-post p {
    margin: 0;
    color: var(--portal-main-font-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
    line-height: 1.45;
}

.guest-feed-preview-copy p {
    grid-area: excerpt;
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}

.guest-feed-gallery {
    display: grid;
    gap: 6px;
    margin-top: 10px;
}

.guest-feed-gallery figure {
    margin: 0;
    overflow: hidden;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.18);
}

.guest-feed-gallery img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 112px;
    object-fit: cover;
}

.guest-feed-gallery .is-primary {
    min-height: 210px;
}

.guest-feed-gallery .is-primary img {
    min-height: 210px;
}

.guest-feed-gallery figure:not(.is-primary) {
    min-height: 96px;
}

.guest-feed-gallery-count-2,
.guest-feed-gallery-count-3,
.guest-feed-gallery-count-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.guest-feed-gallery-count-2 .is-primary,
.guest-feed-gallery-count-3 .is-primary,
.guest-feed-gallery-count-4 .is-primary {
    grid-column: 1 / -1;
}

.guest-feed-gallery-count-5,
.guest-feed-gallery-count-6,
.guest-feed-gallery-count-7,
.guest-feed-gallery-count-8,
.guest-feed-gallery-count-9,
.guest-feed-gallery-count-10 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.guest-feed-gallery-count-5 .is-primary,
.guest-feed-gallery-count-6 .is-primary,
.guest-feed-gallery-count-7 .is-primary,
.guest-feed-gallery-count-8 .is-primary,
.guest-feed-gallery-count-9 .is-primary,
.guest-feed-gallery-count-10 .is-primary {
    grid-column: 1 / -1;
}

.guest-feed-cta {
    width: fit-content;
    margin-top: 10px;
}

.guest-feed-load-more {
    justify-self: center;
    min-width: 132px;
    margin: 2px 0 4px;
}

.guest-feed-post-detail {
    display: grid;
    gap: 14px;
    min-width: 0;
    color: var(--portal-main-font-color);
}

.guest-feed-post-detail-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    color: var(--portal-main-font-muted);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-xs);
    font-weight: max(var(--portal-text-weight), 500);
}

.guest-feed-post-detail-meta span,
.guest-feed-post-detail-meta time {
    display: inline-flex;
    width: fit-content;
    padding: 5px 9px;
    border-radius: 999px;
    background: var(--guest-ui-tag-bg);
    color: var(--guest-ui-tag-text);
}

.guest-feed-post-detail h1 {
    margin: 0;
    color: var(--portal-main-font-color);
    font-family: var(--portal-title-font);
    font-size: calc(clamp(1.65rem, 7vw, 2.5rem) * var(--portal-title-scale));
    font-weight: var(--portal-title-weight);
    line-height: 1.16;
}

.guest-feed-post-detail-body {
    color: var(--portal-main-font-color);
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
}

.guest-feed-post-detail-gallery {
    margin-top: 2px;
}

@media (max-width: 380px) {
    .guest-feed-post-preview.has-image {
        grid-template-columns: minmax(0, 1fr) var(--portal-detail-image-size, 84px);
    }

    .guest-feed-preview-image {
        height: var(--portal-detail-image-size, 80px);
        min-height: var(--portal-detail-image-size, 80px);
        max-height: var(--portal-detail-image-size, 80px);
    }
}

@media (max-width: 560px) {
    .portal-content-element .menu-item-image,
    .guest-portal-shell .portal-content-element .menu-item-image {
        width: var(--portal-detail-image-size, 76px);
        min-width: var(--portal-detail-image-size, 76px);
        max-width: var(--portal-detail-image-size, 76px);
        height: var(--portal-detail-image-size, 76px);
        min-height: var(--portal-detail-image-size, 76px);
        max-height: var(--portal-detail-image-size, 76px);
        flex-basis: var(--portal-detail-image-size, 76px);
    }
}

@media (max-width: 679px) {
    .guest-portal-shell::after {
        background-attachment: scroll;
    }

    .guest-portal-shell .page-hero-mobile-bar {
        color: var(--portal-main-font-color);
    }

    .guest-portal-shell .page-hero-mobile-bar.is-fixed {
        background:
            linear-gradient(
                180deg,
                rgba(255, 255, 255, calc(var(--guest-glass-highlight-alpha, 0.11) * var(--mobile-bar-opacity, 0))),
                rgba(255, 255, 255, 0)
            ),
            rgba(var(--portal-container-color-rgb, 255, 255, 255), calc(var(--portal-container-transparency, 0.59) * var(--mobile-bar-opacity, 0)));
    }
}

@media (min-width: 641px) {
    .guest-portal-stage {
        overflow-x: clip;
    }

    .guest-portal-stage-ambient {
        position: fixed;
        pointer-events: none;
    }

    .guest-portal-stage-ambient {
        display: block;
        inset: 0;
        z-index: -4;
        background: var(--guest-bg-color, var(--guest-soft));
    }

    .guest-portal-stage-ambient::before,
    .guest-portal-stage-ambient::after {
        content: "";
        position: absolute;
        pointer-events: none;
    }

    .guest-portal-stage-ambient::before {
        inset: -72px;
        background: var(--portal-background-image, none);
        background-position: center;
        background-size: cover;
        filter: blur(44px) saturate(118%);
        opacity: 0.5;
        transform: scale(1.08);
        transform-origin: center;
        -webkit-mask-image:
            radial-gradient(ellipse at center, #000 0 34%, rgba(0, 0, 0, 0.84) 52%, transparent 82%),
            linear-gradient(180deg, transparent 0, #000 14%, #000 86%, transparent 100%);
        mask-image:
            radial-gradient(ellipse at center, #000 0 34%, rgba(0, 0, 0, 0.84) 52%, transparent 82%),
            linear-gradient(180deg, transparent 0, #000 14%, #000 86%, transparent 100%);
        -webkit-mask-composite: source-in;
        mask-composite: intersect;
    }

    .guest-portal-stage-ambient::after {
        inset: 0;
        background:
            radial-gradient(ellipse at center, rgba(255, 255, 255, 0.08), transparent 56%),
            linear-gradient(180deg, rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.12)),
            linear-gradient(90deg, var(--guest-bg-color, var(--guest-soft)) 0, transparent 18%, transparent 82%, var(--guest-bg-color, var(--guest-soft)) 100%);
    }

    .guest-portal-shell {
        --portal-viewport-left: calc((100vw - min(100vw, 640px)) / 2);
        --portal-viewport-width: min(100vw, 640px);
        --portal-viewport-right-gap: calc((100vw - var(--portal-viewport-width)) / 2);
        width: min(100%, 640px);
        max-width: 640px;
        box-sizing: border-box;
        overflow: clip;
        padding-inline: 14px;
        box-shadow: 0 34px 90px rgba(0, 0, 0, 0.12);
    }

    .guest-portal-shell::before {
        position: absolute;
        inset: 0;
        z-index: -3;
        border-radius: 28px;
        background: var(--guest-bg-color, var(--guest-soft));
    }

    .guest-portal-shell::after {
        content: none;
    }

    .guest-portal-canvas-bg {
        display: block;
        position: fixed;
        top: 0;
        left: var(--portal-viewport-left, calc((100vw - min(100vw, 640px)) / 2));
        width: var(--portal-viewport-width, min(100vw, 640px));
        height: 100dvh;
        z-index: -2;
        overflow: hidden;
        pointer-events: none;
        box-shadow:
            inset 1px 0 rgba(255, 255, 255, 0.08),
            inset -1px 0 rgba(255, 255, 255, 0.08);
    }

    .guest-portal-canvas-bg::before {
        content: "";
        position: absolute;
        inset: 0;
        background:
            linear-gradient(
                rgba(var(--guest-bg-wrapper-color-rgb, 255, 255, 255), var(--guest-bg-overlay-alpha, 0)),
                rgba(var(--guest-bg-wrapper-color-rgb, 255, 255, 255), var(--guest-bg-overlay-alpha, 0))
            ),
            var(--portal-background-image, none);
        background-position: center top;
        background-size: cover;
        filter: blur(var(--guest-bg-blur, 0px));
        transform: scale(var(--guest-bg-blur-scale, 1));
        transform-origin: center;
    }

    .guest-footer {
        width: min(100%, 640px);
    }

    .portal-group-element-card {
        padding-left: 24px;
        gap: 8px;
    }

    .guest-portal-shell .portal-page-list,
    .guest-portal-shell .portal-group-grid {
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        gap: 12px;
    }
}

/* Typography rhythm normalization layer */
.guest-portal-shell {
    --portal-hero-rhythm-scale: 1;
    --portal-hero-icon-rhythm-scale: clamp(0.86, calc(0.54 + (var(--portal-hero-scale) * 0.46)), 1.5);
    --portal-title-rhythm-scale: clamp(0.58, calc(0.58 + (var(--portal-title-scale-slider, 50) * 0.0084)), 1.42);
    --portal-title-spacing-scale: clamp(0.08, calc(0.08 + (var(--portal-title-scale-slider, 50) * 0.0184)), 1.48);
    --portal-title-subtle-rhythm-scale: clamp(0.78, calc(0.78 + (var(--portal-title-scale-slider, 50) * 0.0044)), 1.22);
    --portal-title-icon-rhythm-scale: clamp(0.72, calc(0.72 + (var(--portal-title-scale-slider, 50) * 0.0056)), 1.28);
    --portal-text-rhythm-scale: clamp(0.9, calc(0.78 + (var(--portal-text-scale) * 0.22)), 1.16);
    --portal-title-line-height-rhythm: clamp(1.14, calc(1.18 - ((var(--portal-title-scale) - 1) * 0.04)), 1.22);
    --portal-title-comfort-line-height-rhythm: clamp(1.16, calc(1.2 - ((var(--portal-title-scale) - 1) * 0.04)), 1.24);
    --portal-text-line-height-rhythm: clamp(1.281, calc(1.335 + ((var(--portal-text-scale) - 1) * 0.094)), 1.429);
    --portal-text-rich-line-height-rhythm: clamp(1.335, calc(1.415 + ((var(--portal-text-scale) - 1) * 0.08)), 1.496);
    --portal-text-compact-line-height-rhythm: clamp(1.134, calc(1.201 + ((var(--portal-text-scale) - 1) * 0.08)), 1.295);
    --portal-hero-border-optical-width: calc(var(--portal-top-card-text-border-width, 0px) * var(--portal-hero-rhythm-scale));
    --portal-hero-border-strong-optical-width: calc(var(--portal-top-card-text-border-strong-width, 0px) * var(--portal-hero-rhythm-scale));
    --portal-title-border-optical-width: calc(var(--portal-title-border-width, 0px) * var(--portal-title-rhythm-scale));
    --portal-text-border-optical-width: calc(var(--portal-text-border-width, 0px) * var(--portal-text-rhythm-scale));
    --portal-title-border-outline-color: color-mix(in srgb, var(--portal-title-border-color, #000) calc(var(--portal-title-border-size, 0) * 0.82%), transparent);
    --portal-text-border-outline-color: color-mix(in srgb, var(--portal-text-border-color, #000) calc(var(--portal-text-border-size, 0) * 0.82%), transparent);
    --portal-top-card-text-border-outline-color: color-mix(in srgb, var(--portal-top-card-text-border-color, #000) calc(var(--portal-top-card-text-border-size, 0) * 0.82%), transparent);
    --portal-title-border-outside-shadow:
        calc(var(--portal-title-border-optical-width) * 0.5) 0 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -0.5) 0 0 var(--portal-title-border-outline-color),
        0 calc(var(--portal-title-border-optical-width) * 0.5) 0 var(--portal-title-border-outline-color),
        0 calc(var(--portal-title-border-optical-width) * -0.5) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * 0.36) calc(var(--portal-title-border-optical-width) * 0.36) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -0.36) calc(var(--portal-title-border-optical-width) * 0.36) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * 0.36) calc(var(--portal-title-border-optical-width) * -0.36) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -0.36) calc(var(--portal-title-border-optical-width) * -0.36) 0 var(--portal-title-border-outline-color),
        var(--portal-title-border-optical-width) 0 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -1) 0 0 var(--portal-title-border-outline-color),
        0 var(--portal-title-border-optical-width) 0 var(--portal-title-border-outline-color),
        0 calc(var(--portal-title-border-optical-width) * -1) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * 0.72) calc(var(--portal-title-border-optical-width) * 0.72) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -0.72) calc(var(--portal-title-border-optical-width) * 0.72) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * 0.72) calc(var(--portal-title-border-optical-width) * -0.72) 0 var(--portal-title-border-outline-color),
        calc(var(--portal-title-border-optical-width) * -0.72) calc(var(--portal-title-border-optical-width) * -0.72) 0 var(--portal-title-border-outline-color);
    --portal-text-border-outside-shadow:
        calc(var(--portal-text-border-optical-width) * 0.5) 0 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -0.5) 0 0 var(--portal-text-border-outline-color),
        0 calc(var(--portal-text-border-optical-width) * 0.5) 0 var(--portal-text-border-outline-color),
        0 calc(var(--portal-text-border-optical-width) * -0.5) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * 0.36) calc(var(--portal-text-border-optical-width) * 0.36) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -0.36) calc(var(--portal-text-border-optical-width) * 0.36) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * 0.36) calc(var(--portal-text-border-optical-width) * -0.36) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -0.36) calc(var(--portal-text-border-optical-width) * -0.36) 0 var(--portal-text-border-outline-color),
        var(--portal-text-border-optical-width) 0 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -1) 0 0 var(--portal-text-border-outline-color),
        0 var(--portal-text-border-optical-width) 0 var(--portal-text-border-outline-color),
        0 calc(var(--portal-text-border-optical-width) * -1) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * 0.72) calc(var(--portal-text-border-optical-width) * 0.72) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -0.72) calc(var(--portal-text-border-optical-width) * 0.72) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * 0.72) calc(var(--portal-text-border-optical-width) * -0.72) 0 var(--portal-text-border-outline-color),
        calc(var(--portal-text-border-optical-width) * -0.72) calc(var(--portal-text-border-optical-width) * -0.72) 0 var(--portal-text-border-outline-color);
    --portal-top-card-text-border-outside-shadow:
        var(--portal-hero-border-strong-optical-width) 0 0 var(--portal-top-card-text-border-outline-color),
        calc(var(--portal-hero-border-strong-optical-width) * -1) 0 0 var(--portal-top-card-text-border-outline-color),
        0 var(--portal-hero-border-strong-optical-width) 0 var(--portal-top-card-text-border-outline-color),
        0 calc(var(--portal-hero-border-strong-optical-width) * -1) 0 var(--portal-top-card-text-border-outline-color),
        calc(var(--portal-hero-border-strong-optical-width) * 0.72) calc(var(--portal-hero-border-strong-optical-width) * 0.72) 0 var(--portal-top-card-text-border-outline-color),
        calc(var(--portal-hero-border-strong-optical-width) * -0.72) calc(var(--portal-hero-border-strong-optical-width) * 0.72) 0 var(--portal-top-card-text-border-outline-color),
        calc(var(--portal-hero-border-strong-optical-width) * 0.72) calc(var(--portal-hero-border-strong-optical-width) * -0.72) 0 var(--portal-top-card-text-border-outline-color),
        calc(var(--portal-hero-border-strong-optical-width) * -0.72) calc(var(--portal-hero-border-strong-optical-width) * -0.72) 0 var(--portal-top-card-text-border-outline-color);
    --portal-top-card-text-border-outside-filter:
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * 0.5) 0 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -0.5) 0 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(0 calc(var(--portal-hero-border-strong-optical-width) * 0.5) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(0 calc(var(--portal-hero-border-strong-optical-width) * -0.5) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * 0.36) calc(var(--portal-hero-border-strong-optical-width) * 0.36) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -0.36) calc(var(--portal-hero-border-strong-optical-width) * 0.36) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * 0.36) calc(var(--portal-hero-border-strong-optical-width) * -0.36) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -0.36) calc(var(--portal-hero-border-strong-optical-width) * -0.36) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(var(--portal-hero-border-strong-optical-width) 0 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -1) 0 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(0 var(--portal-hero-border-strong-optical-width) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(0 calc(var(--portal-hero-border-strong-optical-width) * -1) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * 0.72) calc(var(--portal-hero-border-strong-optical-width) * 0.72) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -0.72) calc(var(--portal-hero-border-strong-optical-width) * 0.72) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * 0.72) calc(var(--portal-hero-border-strong-optical-width) * -0.72) 0 var(--portal-top-card-text-border-outline-color))
        drop-shadow(calc(var(--portal-hero-border-strong-optical-width) * -0.72) calc(var(--portal-hero-border-strong-optical-width) * -0.72) 0 var(--portal-top-card-text-border-outline-color));
    --portal-space-2xs: calc(2.6px * var(--portal-text-rhythm-scale));
    --portal-space-xs: calc(3.9px * var(--portal-text-rhythm-scale));
    --portal-space-sm: calc(5.2px * var(--portal-text-rhythm-scale));
    --portal-space-md: calc(7.8px * var(--portal-text-rhythm-scale));
    --portal-space-lg: calc(10.4px * var(--portal-text-rhythm-scale));
    --portal-title-gap-xs: calc(3.25px * var(--portal-text-rhythm-scale));
    --portal-title-gap-sm: calc(5.2px * var(--portal-text-rhythm-scale));
    --portal-title-gap-md: calc(7.8px * var(--portal-text-rhythm-scale));
    --portal-title-gap-lg: calc(10.4px * var(--portal-text-rhythm-scale));
    --portal-title-copy-gap: calc(3.9px * var(--portal-text-rhythm-scale));
    --portal-title-interval: var(--portal-text-interval);
    --portal-text-interval: calc(var(--portal-type-md) * (var(--portal-text-line-height-rhythm) - 1));
    --portal-title-description-gap: calc(var(--portal-text-interval) * 0.65);
    --portal-card-title-description-gap: var(--portal-title-description-gap);
    --portal-after-short-content-gap: calc(var(--portal-text-interval) * 1.3);
    --portal-title-hero-copy-gap: calc(9.1px * var(--portal-text-rhythm-scale));
    --portal-title-after-gap: calc(6.5px * var(--portal-text-rhythm-scale));
    --portal-title-section-gap: calc(9.1px * var(--portal-text-rhythm-scale));
    --portal-title-stack-gap: calc(13px * var(--portal-text-rhythm-scale));
    --portal-category-content-gap: calc(var(--portal-text-interval) * 1.3);
    --portal-category-nav-block-pad: calc(1.95px * var(--portal-text-rhythm-scale));
    --portal-detail-image-size: clamp(72px, calc(88px * var(--portal-title-icon-rhythm-scale)), 108px);
    --portal-hero-gap-sm: calc(8px * var(--portal-hero-rhythm-scale));
    --portal-hero-gap-md: calc(12px * var(--portal-hero-rhythm-scale));
    --portal-hero-gap-lg: calc(18px * var(--portal-hero-rhythm-scale));
    --portal-title-icon-sm: clamp(30px, calc(36px * var(--portal-title-icon-rhythm-scale)), 46px);
    --portal-title-icon-md: clamp(36px, calc(44px * var(--portal-title-icon-rhythm-scale)), 58px);
    --portal-title-icon-lg: clamp(42px, calc(52px * var(--portal-title-icon-rhythm-scale)), 66px);
    --portal-hero-icon-md: clamp(40px, calc(52px * var(--portal-hero-icon-rhythm-scale)), 76px);
    --portal-hero-icon-lg: clamp(44px, calc(56px * var(--portal-hero-icon-rhythm-scale)), 84px);
}

.guest-portal-shell :where(.guest-hero, .page-hero) {
    padding: calc(22px * var(--portal-hero-rhythm-scale));
}

.guest-portal-shell .portal-top-card {
    padding:
        calc(var(--portal-content-inset-unit) + 4px)
        14px
        calc(var(--portal-content-inset-unit) + 2px);
}

.guest-portal-shell .portal-top-card-banner {
    padding:
        calc(var(--portal-content-inset-unit) * 2)
        14px
        calc(var(--portal-content-inset-unit) + 4px);
}

.guest-portal-shell :where(.hero-topline, .page-hero-topline, .page-hero-heading-row, .page-hero-title-row) {
    gap: calc(var(--portal-hero-gap-md) * var(--hotel-standard-icon-gap-factor, 1));
}

.guest-portal-shell :where(.guest-brand, .portal-top-card .guest-brand) {
    --header-icon-size: var(--portal-hero-icon-lg);
    gap: calc(var(--portal-hero-gap-md) * var(--hotel-standard-icon-gap-factor, 1));
}

.guest-portal-shell :where(.page-hero-title-row, .portal-top-card .page-hero-title-row) {
    --header-icon-size: var(--portal-hero-icon-md);
}

.guest-portal-shell :where(.page-hero-icon, .portal-top-card .hotel-logo, .portal-top-card .hotel-logo-fallback) {
    --icon-badge-base-size: var(--header-icon-size, var(--portal-hero-icon-md));
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
    border-radius: calc(var(--icon-badge-size) * 0.32);
}

.guest-portal-shell .page-hero-icon-kind-group {
    --icon-badge-base-size: var(--portal-hero-icon-md);
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
}

.guest-portal-shell .page-hero-copy {
    gap: var(--portal-hero-gap-sm);
}

.guest-portal-shell :where(.page-hero-detail, .page-subtitle, .hotel-description) {
    margin-top: var(--portal-space-sm);
    line-height: var(--portal-text-line-height-rhythm);
}

.guest-portal-shell .guest-summary-grid {
    gap: var(--portal-title-gap-sm);
    margin-top: var(--portal-hero-gap-lg);
}

.guest-portal-shell .guest-summary-card {
    gap: var(--portal-space-2xs);
    padding: calc(14px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell :where(.portal-card-grid, .content-stack) {
    gap: calc(14px * var(--portal-text-rhythm-scale));
    margin-top: calc(14px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell :where(.portal-page-list, .portal-group-grid) {
    gap: var(--portal-title-gap-md);
    margin-top: var(--portal-title-gap-md);
}

.guest-portal-shell :where(.portal-card, .portal-element-card, .empty-state, .portal-group-grid .portal-card) {
    gap: var(--portal-title-gap-md);
    padding: calc(18px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell :where(.portal-card-compact, .portal-element-link-card.portal-card) {
    gap: var(--portal-title-gap-sm);
    padding: calc(16px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell :where(.portal-card, .portal-group-element-card, .portal-element-heading) {
    --header-icon-size: var(--portal-title-icon-md);
}

.guest-portal-shell .portal-group-element-card {
    --group-title-line-height: var(--portal-title-line-height-rhythm);
    --group-title-line-box: calc(var(--group-title-font-size) * var(--group-title-line-height));
    --group-description-font-size: var(--portal-type-md);
    --group-description-line-box: calc(var(--group-description-font-size) * var(--portal-text-line-height-rhythm));
    --group-label-row-height: calc(28px * var(--portal-pill-rhythm-scale, var(--portal-text-rhythm-scale)));
    --group-header-icon-size: calc(var(--group-title-line-box) + var(--group-description-line-box) + var(--portal-card-title-description-gap) + var(--portal-title-description-gap));
    --group-card-copy-min-height: calc(var(--group-title-line-box) + var(--portal-title-gap-sm) + var(--group-label-row-height));
    --group-card-copy-max-height: calc(var(--group-title-line-box) + (var(--group-description-line-box) * 2) + var(--portal-card-title-description-gap) + var(--portal-title-gap-sm) + var(--group-label-row-height));
    --header-icon-size: var(--group-header-icon-size);
    --icon-badge-base-size: var(--group-header-icon-size);
    --icon-badge-size: var(--group-header-icon-size);
    grid-template-columns: minmax(0, var(--icon-badge-size)) minmax(0, 1fr);
    min-height: calc((var(--portal-content-edge-inset-y) * 2) + var(--group-card-copy-min-height));
    align-items: center;
}

.guest-portal-shell :where(.portal-card-icon, .portal-element-heading-icon, .portal-group-header-icon) {
    --icon-badge-base-size: var(--header-icon-size, var(--portal-title-icon-md));
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
    border-radius: calc(var(--icon-badge-size) * 0.32);
}

.guest-portal-shell .portal-group-element-card .portal-group-header-icon,
.guest-portal-shell .portal-group-header-icon {
    --icon-badge-base-size: var(--group-header-icon-size, var(--portal-title-icon-md));
    --icon-badge-size: var(--icon-badge-base-size);
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
    align-self: start;
}

.guest-portal-shell :where(.portal-element-heading, .portal-element-heading-copy, .guest-gallery-caption) {
    gap: var(--portal-title-gap-xs);
}

.guest-portal-shell .portal-element-heading {
    margin-bottom: var(--portal-title-gap-md);
}

.guest-portal-shell .portal-element-heading.has-icon {
    column-gap: calc(var(--portal-title-gap-sm) * var(--hotel-standard-icon-gap-factor, 1));
}

.guest-portal-shell :where(
    .portal-card h2,
    .portal-element-heading h2,
    .empty-state h2,
    .portal-element-title,
    .guest-feed-post-detail h1
) {
    line-height: var(--portal-title-line-height-rhythm);
}

.guest-portal-shell :where(
    .menu-category-group > h3,
    .menu-category-group > h4,
    .item-title-row h3,
    .item-title-row h4,
    .guest-feed-post h3
) {
    line-height: var(--portal-title-comfort-line-height-rhythm);
}

.guest-portal-shell :where(.portal-card p, .portal-element-summary, .empty-state p, .item-value, .item-description, .muted-text) {
    margin-top: var(--portal-space-xs);
    line-height: var(--portal-text-line-height-rhythm);
}

.guest-portal-shell .portal-card h2 + p {
    margin-top: var(--portal-title-description-gap);
}

.guest-portal-shell .portal-group-element-card .portal-group-card-title + p {
    margin-top: var(--portal-card-title-description-gap);
    line-height: var(--portal-text-line-height-rhythm);
}

.guest-portal-shell .portal-group-element-card .portal-group-card-copy {
    display: flex;
    min-width: 0;
    max-height: var(--group-card-copy-max-height);
    flex-direction: column;
    justify-content: center;
    align-self: center;
    overflow: hidden;
}

.guest-portal-shell .portal-group-element-card .portal-group-card-title {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.guest-portal-shell .portal-group-element-card .portal-group-card-title + p {
    display: -webkit-box;
    max-width: 100%;
    max-height: calc(var(--group-description-line-box) * 2);
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.guest-portal-shell .portal-group-element-card .portal-group-card-copy > p + .portal-label-list {
    margin-top: var(--portal-title-gap-sm);
}

.guest-portal-shell .portal-group-element-card .portal-group-card-copy:has(> .portal-label-list):not(:has(> p)) {
    height: var(--group-card-copy-min-height);
    justify-content: flex-start;
}

.guest-portal-shell .portal-group-element-card .portal-group-card-copy:has(> .portal-label-list):not(:has(> p)) > .portal-group-card-title {
    margin-top: max(0px, calc((var(--group-card-copy-min-height) - var(--group-title-line-box) - var(--portal-title-gap-sm) - var(--group-label-row-height)) / 2));
}

.guest-portal-shell :where(.portal-card-kicker, .portal-label-list-header) {
    margin-bottom: var(--portal-title-gap-sm);
}

.guest-portal-shell :where(.portal-card-highlights, .portal-label-list, .item-meta, .menu-item-meta-row, .guest-feed-meta-row, .guest-feed-post-detail-meta) {
    gap: var(--portal-title-gap-xs);
}

.guest-portal-shell :where(.portal-card-highlights, .portal-label-list, .item-meta) {
    margin-top: var(--portal-title-gap-sm);
}

.guest-portal-shell :where(
    .portal-card-highlights span,
    .portal-label-chip,
    .item-badge,
    .item-price,
    .item-meta span,
    .item-meta a,
    .guest-feed-meta-row time,
    .guest-feed-meta-row span,
    .guest-feed-pin,
    .guest-feed-post-detail-meta span,
    .guest-feed-post-detail-meta time,
    .time-pill,
    .schedule-badge
) {
    min-height: calc(26px * var(--portal-text-rhythm-scale));
    padding:
        calc(5px * var(--portal-text-rhythm-scale))
        calc(9px * var(--portal-text-rhythm-scale));
    line-height: 1.16;
}

.guest-portal-shell :where(.page-tab-nav, .public-element-nav, .guest-menu-category-nav) {
    gap: var(--portal-title-gap-sm);
    margin-top: var(--portal-title-gap-sm);
    cursor: grab;
    user-select: none;
    -webkit-user-select: none;
}

.guest-portal-shell :where(.page-tab-nav a, .public-element-nav a, .guest-menu-category-nav a) {
    min-height: calc(40px * var(--portal-text-rhythm-scale));
    padding:
        calc(8px * var(--portal-text-rhythm-scale))
        calc(12px * var(--portal-text-rhythm-scale));
    line-height: var(--portal-text-compact-line-height-rhythm);
    -webkit-user-drag: none;
}

.guest-portal-shell :where(.page-tab-nav, .public-element-nav, .guest-menu-category-nav).is-drag-scroll-dragging,
.guest-portal-shell :where(.page-tab-nav, .public-element-nav, .guest-menu-category-nav).is-drag-scroll-dragging * {
    cursor: grabbing;
}

.guest-portal-shell .guest-menu-category-rail {
    padding:
        calc(4px * var(--portal-text-rhythm-scale))
        0
        calc(10px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .guest-menu-element {
    gap: calc(14px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .menu-category-stack {
    gap: calc(20px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .menu-category-group {
    gap: calc(10px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .menu-category-group .item-list,
.guest-portal-shell .item-list {
    gap: var(--portal-text-gap, var(--portal-space-md));
}

.guest-portal-shell :where(.content-item, .schedule-item, .menu-item, .contact-item, .faq-item) {
    gap: var(--portal-space-md);
    padding: calc(14px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .portal-content-element :where(.schedule-item, .contact-item, .faq-item) {
    gap: var(--portal-space-sm);
    padding: calc(12px * var(--portal-text-rhythm-scale)) 0;
}

.guest-portal-shell .schedule-top-row {
    gap: var(--portal-title-gap-sm);
}

.guest-portal-shell .schedule-main,
.guest-portal-shell .schedule-sub-row {
    gap: var(--portal-space-2xs);
}

.guest-portal-shell :where(.schedule-main p, .menu-item-description, .item-description) {
    line-height: var(--portal-text-compact-line-height-rhythm);
}

.guest-portal-shell .item-title-row {
    gap: var(--portal-title-gap-md);
}

.guest-portal-shell .item-title-aside {
    gap: var(--portal-title-gap-xs);
}

.guest-portal-shell :where(.menu-item-image, .guest-feed-preview-image) {
    width: var(--portal-detail-image-size);
    min-width: var(--portal-detail-image-size);
    max-width: var(--portal-detail-image-size);
    height: var(--portal-detail-image-size);
    min-height: var(--portal-detail-image-size);
    max-height: var(--portal-detail-image-size);
    flex-basis: var(--portal-detail-image-size);
}

.guest-portal-shell .portal-richtext {
    gap: var(--portal-space-md);
}

.guest-portal-shell .portal-richtext :where(p, li, blockquote) {
    line-height: var(--portal-text-rich-line-height-rhythm);
}

.guest-portal-shell .portal-richtext :where(h2, h3) {
    margin-top: var(--portal-title-gap-xs);
    line-height: var(--portal-title-line-height-rhythm);
}

.guest-portal-shell .portal-richtext :where(ul, ol) {
    gap: var(--portal-space-xs);
    padding-left: calc(20px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .portal-richtext blockquote {
    padding:
        calc(14px * var(--portal-text-rhythm-scale))
        calc(16px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell :where(.portal-gallery, .guest-gallery-caption, .portal-gallery-controls, .portal-gallery-thumbnails, .guest-feed-gallery) {
    gap: var(--portal-space-sm);
}

.guest-portal-shell :where(.portal-gallery-arrow, .portal-gallery-lightbox-close, .portal-gallery-lightbox-arrow, .back-link-icon, .back-to-top-button) {
    width: calc(40px * var(--portal-text-rhythm-scale));
    height: calc(40px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell :where(.back-link-icon svg, .portal-gallery-arrow svg, .back-to-top-button svg) {
    width: calc(17px * var(--portal-text-rhythm-scale));
    height: calc(17px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .portal-gallery-arrow {
    font-size: calc(1.5rem * var(--portal-text-rhythm-scale));
    font-weight: 600;
}

.guest-portal-shell .guest-gallery .portal-gallery-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 6;
    opacity: 1;
    visibility: visible;
}

.guest-portal-shell .portal-gallery-status {
    gap: var(--portal-space-xs);
}

.guest-portal-shell .portal-gallery-thumbnail {
    flex-basis: clamp(60px, calc(76px * var(--portal-text-rhythm-scale)), 88px);
    width: clamp(60px, calc(76px * var(--portal-text-rhythm-scale)), 88px);
}

.guest-portal-shell .portal-gallery-thumb-arrow:not([hidden]) {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: calc(1.34rem * var(--portal-text-rhythm-scale));
    font-weight: 600;
    line-height: 1;
    padding: 0;
}

.guest-portal-shell .portal-gallery-thumb-arrow[hidden] {
    display: none;
}

.guest-portal-shell .guest-actions {
    gap: var(--portal-title-gap-sm);
}

.guest-portal-shell .guest-action-row {
    gap: calc(10px * var(--portal-text-rhythm-scale) * var(--action-tight-scale, 1));
}

.guest-portal-shell .guest-action {
    gap: calc(var(--action-gap, 10px) * var(--portal-text-rhythm-scale) * var(--action-tight-scale, 1) * var(--hotel-standard-icon-gap-factor, 1));
    min-height: calc(var(--action-min-height, 0px) * var(--portal-text-rhythm-scale) * var(--action-tight-scale, 1));
    padding:
        calc(var(--action-padding-y, 12px) * var(--portal-text-rhythm-scale) * var(--action-tight-scale, 1))
        calc(var(--action-padding-x, 14px) * var(--portal-text-rhythm-scale) * var(--action-tight-scale, 1));
}

.guest-portal-shell .guest-actions .guest-action-icon {
    --icon-badge-base-size: clamp(
        34px,
        calc((var(--action-title-base-size, 0.98rem) * var(--portal-text-scale) * var(--action-title-line-height, 1.2) * 2) + (var(--action-title-line-gap, 3px) * var(--portal-text-rhythm-scale))),
        64px
    );
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    flex: 0 0 var(--icon-badge-size);
    width: var(--icon-badge-size);
    min-width: var(--icon-badge-size);
    max-width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    min-height: var(--icon-badge-size);
    max-height: var(--icon-badge-size);
    aspect-ratio: 1 / 1;
    border-radius: calc(var(--icon-badge-size) * 0.32);
}

.guest-portal-shell .guest-action-copy {
    gap: calc(3px * var(--portal-text-rhythm-scale) * var(--action-tight-scale, 1));
}

.guest-portal-shell .guest-action-copy strong {
    line-height: var(--portal-text-compact-line-height-rhythm);
}

.guest-portal-shell .guest-action-copy small {
    line-height: var(--portal-text-compact-line-height-rhythm);
}

.guest-portal-shell .guest-table-element {
    gap: var(--portal-space-md);
}

.guest-portal-shell :where(.guest-table-header-cell, .guest-table-card-header-cell) {
    padding:
        calc(8px * var(--portal-text-rhythm-scale))
        calc(10px * var(--portal-text-rhythm-scale));
    line-height: var(--portal-text-compact-line-height-rhythm);
}

.guest-portal-shell :where(.guest-table-grid-cell, .guest-table-card-cell) {
    gap: var(--portal-space-xs);
    padding:
        calc(10px * var(--portal-text-rhythm-scale))
        calc(12px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell :where(.guest-table-grid-cell, .guest-table-card-cell .guest-table-cell-value, .guest-table-cell-value.portal-richtext) {
    line-height: var(--portal-text-compact-line-height-rhythm);
}

.guest-portal-shell .guest-table-overlap-tight :where(.guest-table-header-cell, .guest-table-grid-cell) {
    padding:
        calc(6px * var(--portal-text-rhythm-scale))
        calc(8px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .guest-feed-element {
    --feed-collapsed-post-height: clamp(7.4rem, calc(8.75rem * var(--portal-text-rhythm-scale)), 10.5rem);
    --feed-load-more-allowance: clamp(3.2rem, calc(3.8rem * var(--portal-text-rhythm-scale)), 4.6rem);
    gap: var(--portal-space-md);
}

.guest-portal-shell .guest-feed-post-preview {
    column-gap: var(--portal-title-gap-sm);
    row-gap: var(--portal-space-xs);
    padding:
        calc(13px * var(--portal-text-rhythm-scale))
        calc(12px * var(--portal-text-rhythm-scale))
        calc(14px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell :where(.guest-feed-meta-row time, .guest-feed-meta-row span, .guest-feed-pin) {
    align-items: center;
    justify-content: center;
    min-height: calc(24px * var(--portal-text-rhythm-scale));
    padding:
        calc(3px * var(--portal-text-rhythm-scale))
        calc(8px * var(--portal-text-rhythm-scale));
    font-weight: max(var(--portal-text-weight), 600);
    line-height: 1;
}

.guest-portal-shell .guest-feed-meta-row time {
    padding-left: 0;
    font-weight: max(var(--portal-text-weight), 500);
}

.guest-portal-shell .guest-feed-post-detail {
    gap: var(--portal-space-lg);
}

.guest-portal-shell .guest-feed-load-more {
    min-height: calc(38px * var(--portal-text-rhythm-scale));
    padding:
        calc(8px * var(--portal-text-rhythm-scale))
        calc(18px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .portal-gallery-lightbox {
    --portal-gallery-lightbox-top-clearance: calc(88px * var(--portal-text-rhythm-scale));
    --portal-gallery-lightbox-bottom-clearance: calc(88px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .portal-gallery-lightbox-bar {
    padding:
        calc(16px * var(--portal-text-rhythm-scale))
        calc(18px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .portal-gallery-lightbox-thumbs {
    gap: var(--portal-space-sm);
    padding: 0 calc(14px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .portal-gallery-lightbox-thumb {
    flex-basis: clamp(58px, calc(72px * var(--portal-text-rhythm-scale)), 86px);
    width: clamp(58px, calc(72px * var(--portal-text-rhythm-scale)), 86px);
}

.guest-portal-shell :where(.public-element-nav, .public-content-stack) :where(
    h1,
    h2,
    h3,
    h4,
    h5,
    h6,
    .portal-card-title,
    .portal-card-heading,
    .portal-element-title,
    .portal-element-heading,
    .portal-group-title,
    .group-title,
    .element-title,
    .item-title,
    .item-title-aside,
    .page-title,
    .feed-post-title,
    .feed-title,
    .menu-title,
    .menu-item-title,
    .gallery-title,
    .modal-title,
    .sticky-bar-title,
    .guest-action-title,
    .guest-action-copy strong,
    .table-heading
) {
    -webkit-text-stroke-width: var(--portal-title-border-optical-width, 0px);
    text-shadow: none;
}

.guest-portal-shell :where(.public-element-nav, .public-content-stack) :where(
    .page-subtitle,
    p,
    small,
    li,
    dd,
    td,
    th,
    input,
    select,
    textarea,
    figcaption,
    .portal-card-description,
    .portal-card-subtitle,
    .portal-element-description,
    .portal-element-subtitle,
    .portal-group-description,
    .guest-hero-copy,
    .page-hero-copy,
    .content-item-description,
    .content-item-value,
    .menu-item-description,
    .feed-post-body,
    .feed-post-summary,
    .table-cell,
    .helper-text,
    .note,
    .guest-note,
    .secondary-text
),
.guest-footer :where(strong, b, a, button, p, span, small, li) {
    -webkit-text-stroke-width: var(--portal-text-border-optical-width, 0px);
    text-shadow: none;
}

.guest-portal-shell .portal-top-card-text-border :where(
    .page-hero-title-row h1:not(.page-hero-title-lines-enhanced) > .page-hero-title-text,
    .page-hero-title-row h1 .page-hero-title-line-text,
    .portal-top-card-title
) {
    -webkit-text-stroke-width: 0;
    text-shadow: none;
    filter: none;
}

.guest-portal-shell .portal-top-card-text-border :where(.page-subtitle, .hotel-description) {
    -webkit-text-stroke-width: var(--portal-text-border-optical-width, 0px);
    text-shadow: none;
}

@media (max-width: 560px) {
    .guest-portal-shell {
        --portal-hero-rhythm-scale: 1;
        --portal-title-icon-rhythm-scale: clamp(0.76, calc(0.76 + (var(--portal-title-scale-slider, 50) * 0.0048)), 1.24);
        --portal-detail-image-size: clamp(64px, calc(76px * var(--portal-title-icon-rhythm-scale)), 92px);
    }

    .guest-portal-shell :where(.menu-item-image, .guest-feed-preview-image),
    .guest-portal-shell .portal-content-element .menu-item-image {
        width: var(--portal-detail-image-size);
        min-width: var(--portal-detail-image-size);
        max-width: var(--portal-detail-image-size);
        height: var(--portal-detail-image-size);
        min-height: var(--portal-detail-image-size);
        max-height: var(--portal-detail-image-size);
        flex-basis: var(--portal-detail-image-size);
    }
}

/* Typography scaling regression fixes */
.guest-portal-shell {
    --portal-pill-rhythm-scale: var(--portal-text-rhythm-scale);
    --portal-page-pill-rhythm-scale: var(--portal-pill-rhythm-scale);
    --portal-category-pill-scale: var(--portal-text-rhythm-scale);
}

.guest-portal-shell :where(
    .portal-card-icon,
    .portal-element-heading-icon,
    .portal-element-heading.has-icon > .portal-card-icon,
    .portal-element-link-card .portal-card-icon,
    .portal-group-element-card > .portal-card-icon
) {
    --header-icon-size: var(--portal-title-icon-md);
    --icon-badge-base-size: var(--portal-title-icon-md);
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
    min-width: var(--icon-badge-size);
}

.guest-portal-shell .portal-group-element-card {
    column-gap: var(--portal-content-edge-inset-x);
}

.guest-portal-shell .portal-group-element-card .portal-group-header-icon,
.guest-portal-shell .portal-group-header-icon {
    --header-icon-size: var(--group-header-icon-size, var(--portal-title-icon-md));
    --icon-badge-base-size: var(--group-header-icon-size, var(--portal-title-icon-md));
    --icon-badge-size: var(--icon-badge-base-size);
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
    min-width: var(--icon-badge-size);
    align-self: start;
}

.guest-portal-shell .portal-group-element-card:not(:has(.portal-group-card-title + p)) .portal-group-header-icon {
    align-self: center;
}

.guest-portal-shell .portal-group-header-icon.standard-icon-badge svg {
    width: var(--hotel-standard-icon-group-glyph-size, var(--hotel-standard-icon-glyph-size, 64%));
    height: var(--hotel-standard-icon-group-glyph-size, var(--hotel-standard-icon-glyph-size, 64%));
}

.guest-portal-shell .portal-group-header-icon.icon-letter-fallback {
    font-size: var(--hotel-standard-icon-letter-size, calc(var(--icon-badge-size, 48px) * 0.38));
}

.guest-portal-shell .page-hero-icon-kind-group.standard-icon-badge svg {
    width: var(--hotel-standard-icon-group-glyph-size, var(--hotel-standard-icon-glyph-size, 64%));
    height: var(--hotel-standard-icon-group-glyph-size, var(--hotel-standard-icon-glyph-size, 64%));
}

.guest-portal-shell .page-hero-icon-kind-group .icon-letter-fallback,
.guest-portal-shell .page-hero-icon-kind-group.icon-letter-fallback {
    font-size: var(--hotel-standard-icon-group-letter-size, var(--hotel-standard-icon-letter-size, calc(var(--icon-badge-size, 48px) * 0.38)));
}

.guest-portal-shell .portal-card-compact .portal-card-icon,
.guest-portal-shell .portal-element-link-card .portal-card-icon,
.guest-portal-shell .portal-element-heading.has-icon > .portal-card-icon {
    --header-icon-size: var(--portal-title-icon-md);
    --icon-badge-base-size: var(--portal-title-icon-md);
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
    min-width: var(--icon-badge-size);
}

.guest-portal-shell .portal-group-element-card .portal-group-header-icon,
.guest-portal-shell .portal-group-header-icon {
    --header-icon-size: var(--group-header-icon-size, var(--portal-title-icon-md));
    --icon-badge-base-size: var(--group-header-icon-size, var(--portal-title-icon-md));
    --icon-badge-size: var(--icon-badge-base-size);
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
    min-width: var(--icon-badge-size);
}

.guest-portal-shell .portal-group-element-card .portal-group-header-icon.standard-icon-badge svg {
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
}

.guest-portal-shell .portal-group-element-card .portal-group-header-icon.icon-letter-fallback {
    font-size: calc(var(--icon-badge-size) * var(--hotel-standard-icon-letter-ratio, 0.38));
}

.guest-portal-shell .guest-actions-layout-compact_buttons .guest-action-icon,
.guest-portal-shell .guest-actions-layout-divider_row .guest-action-icon {
    --header-icon-size: var(--portal-title-icon-sm);
    --icon-badge-base-size: var(--portal-title-icon-sm);
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    flex-basis: var(--icon-badge-size);
    min-width: var(--icon-badge-size);
}

.guest-portal-shell :where(
    .page-tab-nav a,
    .public-element-nav a,
    .public-element-nav .portal-label-chip,
    .guest-menu-category-nav a,
    .page-hero-mobile-bar-categories .guest-menu-category-nav a,
    .portal-label-chip,
    .category-pill,
    .language-pill
) {
    min-height: calc(28px * var(--portal-pill-rhythm-scale));
    padding:
        calc(5px * var(--portal-pill-rhythm-scale))
        calc(10px * var(--portal-pill-rhythm-scale));
    border-radius: calc(999px * var(--portal-pill-rhythm-scale));
    font-size: calc(0.82rem * var(--portal-pill-rhythm-scale));
    line-height: 1.14;
}

.guest-portal-shell .page-tab-nav a,
.guest-portal-shell .public-element-nav a,
.guest-portal-shell .public-element-nav .portal-label-chip,
.guest-portal-shell .guest-menu-category-nav a,
.guest-portal-shell .page-hero-mobile-bar-categories .guest-menu-category-nav a {
    min-height: calc(28px * var(--portal-pill-rhythm-scale));
    padding:
        calc(5px * var(--portal-pill-rhythm-scale))
        calc(10px * var(--portal-pill-rhythm-scale));
    border-radius: calc(999px * var(--portal-pill-rhythm-scale));
    font-size: calc(0.82rem * var(--portal-pill-rhythm-scale));
    line-height: 1.14;
}

.guest-portal-shell :where(
    .page-tab-nav a.is-active,
    .public-element-nav a.is-active,
    .public-element-nav .portal-label-chip.is-active,
    .guest-menu-category-nav a.is-active,
    .page-hero-mobile-bar-categories .guest-menu-category-nav a.is-active
) {
    border-width: 1px;
}

.guest-portal-shell .guest-menu-category-nav a.is-active {
    border-width: 1px;
}

.guest-portal-shell .page-tab-nav a.is-active,
.guest-portal-shell .public-element-nav a.is-active,
.guest-portal-shell .public-element-nav .portal-label-chip.is-active,
.guest-portal-shell .guest-menu-category-nav a.is-active,
.guest-portal-shell .page-hero-mobile-bar-categories .guest-menu-category-nav a.is-active {
    border-width: 1px;
}

.guest-portal-shell .guest-menu-category-nav a.is-active {
    border-color: var(--portal-highlight-color);
}

.guest-portal-shell :where(.portal-label-list, .public-element-nav, .guest-menu-category-nav, .page-tab-nav) {
    gap: calc(7px * var(--portal-pill-rhythm-scale));
}

.guest-portal-shell .public-element-nav,
.guest-portal-shell .guest-menu-category-nav {
    padding-bottom: calc(5px * var(--portal-pill-rhythm-scale));
}

.guest-portal-shell :where(
    .portal-element-heading,
    .portal-card-kicker + h2,
    .portal-element-heading + .portal-richtext,
    .portal-element-heading + .item-list,
    .portal-element-heading + .guest-menu-element,
    .portal-element-heading + .guest-table-element,
    .portal-element-heading + .guest-feed-element,
    .portal-element-heading + .guest-gallery,
    .menu-category-group > h3 + .item-list,
    .menu-category-group > h4 + .item-list,
    .guest-gallery-caption + .portal-gallery-main,
    .guest-feed-post-detail h1 + .guest-feed-post-detail-body
) {
    margin-top: 0;
}

.guest-portal-shell :where(
    .portal-element-heading,
    .guest-gallery-caption,
    .menu-category-group > h3,
    .menu-category-group > h4,
    .guest-feed-post-detail h1
) {
    margin-bottom: var(--portal-title-gap-sm);
}

.guest-portal-shell :where(
    .portal-element-heading + *,
    .guest-gallery-caption + *,
    .menu-category-group > h3 + *,
    .menu-category-group > h4 + *,
    .guest-feed-post-detail h1 + *
) {
    margin-top: 0;
}

@media (max-width: 560px) {
    .guest-portal-shell :where(
        .page-tab-nav a,
        .public-element-nav a,
        .public-element-nav .portal-label-chip,
        .guest-menu-category-nav a,
        .page-hero-mobile-bar-categories .guest-menu-category-nav a,
        .portal-label-chip,
        .category-pill,
        .language-pill
    ) {
        min-height: calc(26px * var(--portal-pill-rhythm-scale));
        padding:
            calc(4px * var(--portal-pill-rhythm-scale))
            calc(9px * var(--portal-pill-rhythm-scale));
    }
}

/* Restore original category/nav pill visuals while keeping scale-aware sizing. */
.guest-portal-shell .guest-menu-category-nav a,
.guest-portal-shell .page-hero-mobile-bar-categories .guest-menu-category-nav a {
    min-width: 10ch;
    max-width: min(52vw, 18ch);
    min-height: calc(24px * var(--portal-pill-rhythm-scale));
    padding:
        calc(4px * var(--portal-pill-rhythm-scale))
        calc(9px * var(--portal-pill-rhythm-scale));
    border: 1px solid var(--portal-main-font-muted);
    border-radius: 999px;
    background: transparent;
    color: var(--portal-main-font-color);
    font-family: var(--portal-text-font);
    font-size: calc(0.82rem * var(--portal-pill-rhythm-scale));
    font-weight: max(var(--portal-text-weight), 500);
    line-height: 1.14;
    box-shadow: none;
}

.guest-portal-shell .guest-menu-category-nav a.is-active,
.guest-portal-shell .page-hero-mobile-bar-categories .guest-menu-category-nav a.is-active {
    border: 1px solid var(--portal-highlight-color);
    background: transparent;
    color: var(--portal-highlight-color);
    box-shadow: none;
}

.guest-portal-shell .page-tab-nav a {
    min-height: calc(42px * var(--portal-pill-rhythm-scale));
    padding:
        calc(9px * var(--portal-pill-rhythm-scale))
        calc(12px * var(--portal-pill-rhythm-scale));
    border: 1px solid var(--guest-line);
    border-radius: calc(12px * var(--portal-pill-rhythm-scale));
    background: rgba(255, 255, 255, 0.9);
    color: var(--guest-muted);
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-sm) * 1.06);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: normal;
    box-shadow: none;
}

.guest-portal-shell .page-tab-nav a.is-active {
    border-color: color-mix(in srgb, var(--guest-ui-primary) 18%, transparent);
    background: var(--guest-ui-primary-soft);
    color: var(--guest-ui-primary);
    box-shadow: none;
}

.guest-portal-shell .page-tab-nav a,
.guest-portal-shell .public-element-nav a,
.guest-portal-shell .guest-menu-category-nav a,
.guest-portal-shell .page-hero-mobile-bar-categories .guest-menu-category-nav a,
.guest-portal-shell .category-pill,
.guest-portal-shell .language-pill,
.guest-portal-shell .portal-label-chip,
.guest-portal-shell .public-element-nav .portal-label-chip {
    min-height: calc(28px * var(--portal-text-rhythm-scale));
    padding:
        calc(5px * var(--portal-text-rhythm-scale))
        calc(10px * var(--portal-text-rhythm-scale));
    border-radius: calc(999px * var(--portal-text-rhythm-scale));
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-sm) * 1.06);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: var(--portal-text-compact-line-height-rhythm);
    -webkit-text-stroke-width: var(--portal-text-border-optical-width, 0px);
    text-shadow: none;
}

.guest-portal-shell .page-tab-nav a {
    min-height: calc(42px * var(--portal-text-rhythm-scale));
    border-radius: calc(12px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell :where(
    dt,
    .language-dropdown label,
    .language-dropdown select,
    .language-dropdown select option,
    .portal-card-kicker,
    .portal-label-list-header,
    .portal-card-highlights span,
    .guest-summary-card span,
    .item-badge,
    .item-meta span,
    .item-meta a,
    .menu-item-title-badge,
    .menu-item-label,
    .guest-feed-meta-row time,
    .guest-feed-meta-row span,
    .guest-feed-pin,
    .guest-feed-post-detail-meta span,
    .guest-feed-post-detail-meta time,
    .time-pill,
    .schedule-badge,
    .guest-table-card-cell span
) {
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-sm) * 1.06);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: var(--portal-text-compact-line-height-rhythm);
    -webkit-text-stroke: var(--portal-text-border-optical-width, 0px) var(--portal-text-border-color, #000);
    paint-order: stroke fill;
    text-shadow: none;
}

.guest-portal-shell :where(
    .guest-summary-card strong,
    .item-price,
    .menu-item-price
) {
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: var(--portal-text-compact-line-height-rhythm);
    -webkit-text-stroke: var(--portal-text-border-optical-width, 0px) var(--portal-text-border-color, #000);
    paint-order: stroke fill;
    text-shadow: none;
}

.guest-portal-shell :where(
    .language-dropdown,
    .language-dropdown-label,
    .language-dropdown select,
    .language-dropdown select option
) {
    font-size: 0.72rem;
    font-weight: 500;
    -webkit-text-stroke: 0 transparent;
    -webkit-text-stroke-width: 0;
    paint-order: fill;
    text-shadow: none;
}

.guest-portal-shell .language-pill {
    font-size: 0.869rem;
    font-weight: 500;
    -webkit-text-stroke: 0 transparent;
    -webkit-text-stroke-width: 0;
    paint-order: fill;
    text-shadow: none;
}

.guest-portal-shell .portal-top-card-banner .portal-label-chip {
    font-size: calc(var(--portal-type-sm) * 1.219);
}

.guest-portal-shell .portal-top-card :where(.page-subtitle, .hotel-description) {
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-md);
    font-weight: var(--portal-text-weight);
    line-height: var(--portal-text-line-height-rhythm);
}

.guest-portal-shell .menu-category-group > :where(h3, h4),
.guest-portal-shell .portal-content-element .menu-category-group > :where(h3, h4),
.guest-portal-shell .menu-category-title,
.guest-portal-shell .portal-content-element .menu-category-title {
    font-family: var(--portal-text-font);
    font-size: var(--portal-type-lg);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: var(--portal-text-compact-line-height-rhythm);
    -webkit-text-stroke: var(--portal-text-border-optical-width, 0px) var(--portal-text-border-color, #000);
    paint-order: stroke fill;
    text-shadow: none;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-category-group > h3 {
    font-size: calc(var(--portal-type-md) * 1.02);
}

.guest-portal-shell .public-element-nav {
    gap: calc(7px * var(--portal-text-rhythm-scale));
    padding-bottom: calc(5px * var(--portal-text-rhythm-scale));
}

@media (max-width: 560px) {
    .guest-portal-shell .guest-menu-category-nav a,
    .guest-portal-shell .page-hero-mobile-bar-categories .guest-menu-category-nav a {
        min-width: 10ch;
        max-width: min(52vw, 18ch);
        min-height: calc(24px * var(--portal-pill-rhythm-scale));
        padding-inline: calc(9px * var(--portal-pill-rhythm-scale));
    }
}

@media (min-width: 680px) {
    .guest-portal-shell .guest-menu-category-nav a,
    .guest-portal-shell .page-hero-mobile-bar-categories .guest-menu-category-nav a {
        min-width: 10ch;
    }
}

/* Title-scale spacing hardening: keep title-adjacent rhythm on Title scale only. */
.guest-portal-shell .page-hero-copy {
    gap: var(--portal-title-hero-copy-gap);
}

.guest-portal-shell .portal-top-card .page-hero-copy {
    gap: var(--portal-content-inset-unit);
}

.guest-portal-shell :where(.page-hero-title-row + .page-subtitle, .page-hero-title-row + .hotel-description) {
    margin-top: 0;
}

.guest-portal-shell :where(.hotel-description, .page-subtitle) {
    line-height: var(--portal-text-line-height-rhythm);
}

.guest-portal-shell .portal-element-heading {
    gap: 0;
    margin-bottom: var(--portal-title-after-gap);
}

.guest-portal-shell .portal-element-heading-copy {
    gap: 0;
}

.guest-portal-shell .portal-element-summary {
    line-height: var(--portal-text-line-height-rhythm);
}

.guest-portal-shell :where(.portal-element-title + .portal-element-summary, .portal-element-heading h2 + .portal-element-summary) {
    margin-top: var(--portal-card-title-description-gap);
}

.guest-portal-shell :where(
    .portal-element-heading + *,
    .portal-card-kicker + h2,
    .guest-gallery-caption + *,
    .guest-feed-post-detail h1 + *
) {
    margin-top: 0;
}

.guest-portal-shell :where(.content-stack, .portal-card-grid) {
    gap: var(--portal-title-section-gap);
    margin-top: var(--portal-title-section-gap);
}

.guest-portal-shell :where(.public-element-nav, .guest-menu-category-nav, .page-tab-nav) {
    gap: var(--portal-title-gap-sm);
    margin-top: var(--portal-title-gap-sm);
}

.guest-portal-shell .guest-menu-category-rail {
    padding:
        var(--portal-category-nav-block-pad)
        0
        0;
}

.guest-portal-shell .guest-menu-category-nav {
    padding:
        var(--portal-category-nav-block-pad)
        calc(2px * var(--portal-title-subtle-rhythm-scale))
        var(--portal-category-nav-block-pad);
}

.guest-portal-shell .portal-content-element .guest-menu-category-rail {
    padding-block: 0;
}

.guest-portal-shell .portal-content-element .guest-menu-category-nav {
    margin-top: 0;
    padding-block: 0;
}

.guest-portal-shell .guest-menu-element {
    gap: var(--portal-category-nav-list-gap);
}

.guest-portal-shell .guest-feed-element {
    gap: var(--portal-category-nav-list-gap);
}

.guest-portal-shell .menu-category-stack {
    gap: 0;
}

.guest-portal-shell .menu-category-group {
    gap: var(--portal-title-after-gap);
    position: relative;
}

.guest-portal-shell :where(.menu-category-group > h3, .menu-category-group > h4) {
    margin-bottom: 0;
    padding-inline: 0;
    text-align: left;
}

.guest-portal-shell .menu-category-group .menu-item-title {
    color: var(--portal-main-font-color);
}

.guest-portal-shell .menu-category-group + .menu-category-group {
    padding-top: calc(
        var(--portal-detail-divider-before-gap) +
        1px +
        var(--portal-detail-divider-after-gap)
    );
}

.guest-portal-shell .menu-category-group + .menu-category-group::before {
    content: "";
    position: absolute;
    top: var(--portal-detail-divider-before-gap);
    left: 0;
    right: 0;
    height: 1px;
    background: var(--portal-divider-color);
}

.guest-portal-shell :where(.menu-category-group > h3 + .item-list, .menu-category-group > h4 + .item-list) {
    margin-top: 0;
}

.guest-portal-shell .portal-content-element :where(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item) {
    gap: var(--portal-title-copy-gap);
}

.guest-portal-shell .portal-content-element :where(.item-list, .menu-category-group .item-list) > :where(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item):first-child {
    padding-top: 0;
}

.guest-portal-shell :where(.menu-item-title + .item-description, .item-title-row + .item-description, .item-title-row + .item-value) {
    margin-top: var(--portal-title-copy-gap);
}

.guest-portal-shell .menu-item-meta-row {
    margin-top: var(--portal-title-after-gap);
}

.guest-portal-shell .item-title-row {
    gap: var(--portal-title-gap-md);
}

.guest-portal-shell .guest-feed-post-preview {
    row-gap: var(--portal-title-copy-gap);
}

.guest-portal-shell .guest-feed-gallery {
    margin-top: var(--portal-title-after-gap);
}

/* Keep action buttons on their pre-rhythm sizing model. */
.guest-portal-shell .guest-actions {
    gap: 10px;
}

.guest-portal-shell .guest-action-row {
    gap: calc(10px * var(--action-tight-scale, 1));
}

.guest-portal-shell .guest-action {
    gap: calc(var(--action-gap, 10px) * var(--action-tight-scale, 1) * var(--hotel-standard-icon-gap-factor, 1));
    min-height: calc(var(--action-min-height, 0px) * var(--action-tight-scale, 1));
    padding:
        calc(var(--action-padding-y, 12px) * var(--action-tight-scale, 1))
        calc(var(--action-padding-x, 14px) * var(--action-tight-scale, 1));
}

.guest-portal-shell .guest-actions .guest-action-icon {
    --action-icon-title-font-size: calc(var(--action-title-base-size, 0.98rem) * var(--portal-text-scale));
    --icon-badge-base-size: calc((var(--action-icon-title-font-size) * var(--action-title-line-height, 1.2) * 2) + (var(--action-title-line-gap, 3px) * var(--portal-text-rhythm-scale)));
    --icon-badge-size: calc(var(--icon-badge-base-size) * var(--hotel-standard-icon-scale-factor, 1));
    flex: 0 0 var(--icon-badge-size);
    width: var(--icon-badge-size);
    min-width: var(--icon-badge-size);
    max-width: var(--icon-badge-size);
    height: var(--icon-badge-size);
    min-height: var(--icon-badge-size);
    max-height: var(--icon-badge-size);
    aspect-ratio: 1 / 1;
    border-radius: calc(var(--icon-badge-size) * 0.32);
}

.guest-portal-shell .guest-action-copy {
    gap: calc(3px * var(--action-tight-scale, 1));
}

.guest-portal-shell .guest-action-copy strong {
    font-size: calc(var(--action-title-base-size, 0.98rem) * var(--action-tight-scale, 1) * var(--portal-title-scale));
    line-height: var(--action-title-line-height, 1.2);
}

.guest-portal-shell .guest-actions-layout-compact_buttons .guest-action-copy strong {
    font-size: calc(var(--action-title-base-size, 0.98rem) * var(--action-tight-scale, 1) * var(--portal-text-scale));
}

.guest-portal-shell .guest-actions-layout-divider_row .guest-action-copy strong {
    font-size: calc(var(--action-title-base-size, 0.9rem) * var(--action-tight-scale, 1) * var(--portal-text-scale));
    line-height: var(--action-title-line-height, 1.22);
}

.guest-portal-shell :where(.guest-actions-layout-compact_buttons, .guest-actions-layout-divider_row) .guest-action-copy strong {
    -webkit-text-stroke: var(--portal-text-border-optical-width, 0px) var(--portal-text-border-color, #000);
    paint-order: stroke fill;
    text-shadow: none;
}

.guest-portal-shell .guest-action-copy small {
    font-size: calc(0.84rem * var(--action-tight-scale, 1) * var(--portal-text-scale));
    line-height: 1.35;
}

/* Horizontal title/icon rhythm follows glyph size, not the aggressive vertical spacing scale. */
.guest-portal-shell :where(.page-hero-title-row, .portal-top-card .page-hero-title-row) {
    column-gap: clamp(8px, calc(var(--header-title-font-size, 2rem) * var(--portal-hero-scale) * 0.34), 18px);
}

.guest-portal-shell :where(.portal-card, .portal-element-card, .empty-state, .portal-group-grid .portal-card) {
    column-gap: clamp(8px, calc(var(--header-title-font-size, 1.2rem) * var(--portal-text-scale) * 0.62), 16px);
}

.guest-portal-shell :where(.portal-card-compact, .portal-element-link-card.portal-card) {
    column-gap: calc(clamp(7px, calc(var(--header-title-font-size, 1.06rem) * var(--portal-text-scale) * 0.6), 14px) * var(--hotel-standard-icon-gap-factor, 1));
}

.guest-portal-shell .portal-element-heading.has-icon {
    column-gap: calc(clamp(7px, calc(var(--header-title-font-size, 1.28rem) * var(--portal-text-scale) * 0.48), 14px) * var(--hotel-standard-icon-gap-factor, 1));
}

.guest-portal-shell .portal-element-link-card.portal-card:has(.portal-element-summary),
.guest-portal-shell .portal-element-heading.has-icon:has(.portal-element-summary) {
    align-items: start;
}

.guest-portal-shell .portal-element-link-card.portal-card:has(.portal-element-summary) > .portal-element-heading,
.guest-portal-shell .portal-element-heading.has-icon:has(.portal-element-summary) .portal-element-heading-copy {
    transform: translateY(max(0px, calc((((var(--portal-title-icon-md) * var(--hotel-standard-icon-scale-factor, 1)) - (var(--portal-type-lg) * var(--portal-title-line-height-rhythm))) / 2) - (var(--portal-type-lg) * 0.12))));
}

.guest-portal-shell .portal-group-element-card {
    column-gap: var(--portal-content-edge-inset-x);
}

.guest-portal-shell :where(.public-element-nav, .guest-menu-category-nav, .page-tab-nav) {
    column-gap: clamp(6px, calc(0.5rem * var(--portal-text-scale)), 10px);
    row-gap: var(--portal-title-gap-sm);
}

.guest-portal-shell .public-element-nav {
    gap: calc(var(--portal-content-inset-unit) * 0.5);
    padding-inline: var(--portal-content-edge-inset-x);
}

.guest-portal-shell .public-element-nav {
    column-gap: calc(7px * var(--portal-text-rhythm-scale));
    row-gap: calc(7px * var(--portal-text-rhythm-scale));
    padding-bottom: calc(5px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .public-element-nav + .public-content-stack {
    margin-top: calc(var(--portal-content-inset-unit) * 0.8);
}

.guest-portal-shell .portal-content-element .menu-item {
    column-gap: clamp(10px, calc(0.875rem * var(--portal-text-scale)), 18px);
    row-gap: var(--portal-title-copy-gap);
}

.guest-portal-shell :where(.schedule-top-row, .item-title-row) {
    column-gap: clamp(8px, calc(0.75rem * var(--portal-text-scale)), 16px);
    row-gap: var(--portal-title-copy-gap);
}

.guest-portal-shell .guest-shell .schedule-top-row {
    column-gap: clamp(6px, calc(0.5rem * var(--portal-text-scale)), 10px);
}

.guest-portal-shell .guest-feed-post-preview {
    column-gap: clamp(7px, calc(0.625rem * var(--portal-text-scale)), 14px);
}

@media (min-width: 680px) {
    .guest-portal-shell .portal-group-element-card {
        column-gap: var(--portal-content-edge-inset-x);
    }
}

/* Scaling changes vertical density only; container side padding stays anchored. */
.guest-portal-shell :where(.guest-hero, .page-hero) {
    padding-block: calc(22px * var(--portal-hero-rhythm-scale));
    padding-inline: 16px;
}

.guest-portal-shell .portal-top-card {
    padding-block:
        calc(var(--portal-content-inset-unit) + 4px)
        calc(var(--portal-content-inset-unit) + 2px);
    padding-inline: 14px;
}

.guest-portal-shell .portal-top-card-banner {
    padding-block:
        calc(var(--portal-content-inset-unit) * 2)
        calc(var(--portal-content-inset-unit) + 4px);
    padding-inline: 14px;
}

.guest-portal-shell .guest-summary-card {
    padding-block: calc(14px * var(--portal-text-rhythm-scale));
    padding-inline: 10px;
}

.guest-portal-shell :where(.portal-card, .portal-element-card, .empty-state, .portal-group-grid .portal-card) {
    padding-block: var(--portal-content-edge-inset-y);
    padding-inline: var(--portal-content-edge-inset-x);
}

.guest-portal-shell :where(.portal-card-compact, .portal-element-link-card.portal-card) {
    padding-block: var(--portal-content-edge-inset-y);
    padding-inline: var(--portal-content-edge-inset-x);
}

.guest-portal-shell :where(.content-item, .schedule-item, .menu-item, .contact-item, .faq-item) {
    padding-block: calc(14px * var(--portal-text-rhythm-scale));
    padding-inline: 10px;
}

.guest-portal-shell .portal-content-element :where(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item) {
    padding-block: var(--portal-text-row-pad-y);
    padding-inline: 0;
}

.guest-portal-shell .portal-content-element :where(.item-list, .menu-category-group .item-list) {
    gap: 0;
}

.guest-portal-shell .portal-content-element :where(.item-list, .menu-category-group .item-list) > :where(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item):first-child {
    padding-top: var(--portal-text-row-pad-y);
}

.guest-portal-shell .portal-content-element .content-item + .content-item::before {
    top: 0;
    left: 0;
    right: 0;
}

.guest-portal-shell .portal-richtext blockquote {
    padding-block: calc(14px * var(--portal-text-rhythm-scale));
    padding-inline: 12px;
}

.guest-portal-shell .portal-richtext :where(ul, ol) {
    padding-left: 16px;
}

.guest-portal-shell :where(.guest-table-header-cell, .guest-table-card-header-cell) {
    padding-block: calc(8px * var(--portal-text-rhythm-scale));
    padding-inline: 8px;
}

.guest-portal-shell :where(.guest-table-grid-cell, .guest-table-card-cell) {
    padding-block: calc(10px * var(--portal-text-rhythm-scale));
    padding-inline: 10px;
}

.guest-portal-shell .guest-table-mode-cards.has-headers .guest-table-card-cell {
    gap: var(--portal-title-description-gap);
    padding-top: var(--portal-text-table-pad-y);
}

.guest-portal-shell .guest-table-overlap-tight :where(.guest-table-header-cell, .guest-table-grid-cell) {
    padding-block: calc(6px * var(--portal-text-rhythm-scale));
    padding-inline: 8px;
}

.guest-portal-shell .guest-feed-post-preview {
    padding-block:
        calc(13px * var(--portal-text-rhythm-scale))
        calc(14px * var(--portal-text-rhythm-scale));
    padding-inline: 10px;
}

.guest-portal-shell .guest-feed-load-more {
    padding-block: calc(8px * var(--portal-text-rhythm-scale));
    padding-inline: 14px;
    border-color: color-mix(in srgb, var(--portal-highlight-color) 82%, transparent);
    background: var(--portal-highlight-color);
    color: var(--guest-ui-primary-contrast);
    font-family: var(--portal-text-font);
    font-size: calc(var(--feed-load-more-title-base-size, 0.9rem) * var(--portal-text-scale));
    font-weight: max(var(--portal-text-weight), 500);
    line-height: var(--portal-text-compact-line-height-rhythm);
}

.guest-portal-shell .guest-feed-load-more:hover,
.guest-portal-shell .guest-feed-load-more:focus-visible {
    border-color: var(--portal-highlight-hover);
    background: var(--portal-highlight-hover);
    color: var(--guest-ui-primary-contrast);
}

.guest-portal-shell .portal-gallery-lightbox-bar {
    padding-block: calc(16px * var(--portal-text-rhythm-scale));
    padding-inline: 14px;
}

.guest-portal-shell .portal-gallery-lightbox-thumbs {
    padding-inline: 10px;
}

.guest-shell {
    width: min(100% - 10px, 920px);
}

@media (min-width: 641px) {
    .guest-portal-shell {
        width: min(100%, 640px);
        max-width: 640px;
    }

    .guest-footer {
        width: min(100%, 640px);
    }

    .guest-portal-shell .back-to-top-button {
        right: calc(var(--portal-viewport-right-gap, max(16px, calc((100vw - 640px) / 2))) + 16px);
        bottom: calc(env(safe-area-inset-bottom, 0px) + 16px);
    }

    .portal-gallery-lightbox-viewport {
        left: var(--portal-viewport-left, calc((100vw - min(100vw, 640px)) / 2));
        right: auto;
        width: var(--portal-viewport-width, min(100vw, 640px));
    }
}

@media (min-width: 641px) {
    .guest-portal-shell[data-portal-layout="mobile"] {
        padding-top: calc(var(--guest-mobile-topbar-height, 48px) + 14px);
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-layout {
        --mobile-bar-left: var(--portal-viewport-left, calc((100vw - min(100vw, 640px)) / 2));
        --mobile-bar-width: var(--portal-viewport-width, min(100vw, 640px));
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-desktop-meta,
    .guest-portal-shell[data-portal-layout="mobile"] .page-breadcrumb,
    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-language-desktop,
    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-back-desktop {
        display: none;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-topline {
        position: relative;
        display: block;
        width: 100%;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-main,
    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-copy,
    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-title-row,
    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-copy .page-subtitle,
    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-copy .portal-label-list {
        width: 100%;
        min-width: 0;
        max-width: none;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-copy {
        padding-top: 0;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar {
        --page-hero-mobile-bar-padding-top: 12px;
        --page-hero-mobile-bar-padding-x: 16px;
        --page-hero-mobile-bar-padding-bottom: 10px;
        position: fixed;
        top: 0;
        left: var(--mobile-bar-left, 0px);
        right: auto;
        z-index: 40;
        display: grid;
        gap: 10px;
        width: var(--mobile-bar-width, min(100vw, 640px));
        min-width: 0;
        box-sizing: border-box;
        min-height: 40px;
        padding: calc(env(safe-area-inset-top, 0px) + var(--page-hero-mobile-bar-padding-top)) var(--page-hero-mobile-bar-padding-x) 0;
        border: 1px solid transparent;
        background: transparent;
        box-shadow: none;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        transition: background 180ms ease, border-color 180ms ease, box-shadow 180ms ease, backdrop-filter 180ms ease, -webkit-backdrop-filter 180ms ease, padding 160ms ease, gap 160ms ease;
        pointer-events: none;
        transform: none;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar-main {
        position: relative;
        display: grid;
        grid-template-columns: 40px minmax(0, 1fr) auto;
        align-items: center;
        gap: 10px;
        min-width: 0;
        min-height: 40px;
        pointer-events: none;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar.is-fixed {
        padding: calc(env(safe-area-inset-top, 0px) + var(--page-hero-mobile-bar-padding-top)) var(--page-hero-mobile-bar-padding-x) var(--page-hero-mobile-bar-padding-bottom);
        border-radius: 0 0 8px 8px;
        border-color: rgba(255, 255, 255, calc(var(--guest-glass-border-alpha, 0.26) * var(--mobile-bar-opacity, 0)));
        background:
            linear-gradient(
                180deg,
                rgba(255, 255, 255, calc(var(--guest-glass-highlight-alpha, 0.11) * var(--mobile-bar-opacity, 0))),
                rgba(255, 255, 255, 0)
            ),
            rgba(var(--portal-container-color-rgb, 255, 255, 255), calc(var(--portal-container-transparency, 0.59) * var(--mobile-bar-opacity, 0)));
        box-shadow:
            0 12px 28px rgba(20, 35, 30, calc(var(--guest-glass-shadow-alpha, 0.11) * var(--mobile-bar-opacity, 0))),
            inset 0 1px 0 rgba(255, 255, 255, calc(var(--guest-glass-highlight-alpha, 0.11) * var(--mobile-bar-opacity, 0)));
        backdrop-filter: blur(calc(var(--guest-glass-blur, 17px) * var(--mobile-bar-opacity, 0))) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
        -webkit-backdrop-filter: blur(calc(var(--guest-glass-blur, 17px) * var(--mobile-bar-opacity, 0))) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar.has-categories {
        gap: 10px;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar-categories {
        min-width: 0;
        max-height: calc(var(--mobile-category-slot-opacity, 0) * 56px);
        overflow: hidden;
        opacity: var(--mobile-category-slot-opacity, 0);
        pointer-events: none;
        transition: max-height 160ms ease, opacity 160ms ease;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar-categories[hidden] {
        display: none;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar .page-hero-back-mobile,
    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar .page-hero-language-mobile,
    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar-categories .guest-menu-category-nav,
    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar-categories .guest-menu-category-nav a {
        pointer-events: auto;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-back-mobile {
        display: inline-flex;
        position: relative;
        z-index: 1;
        transform: none;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar-title {
        position: absolute;
        left: 50%;
        width: calc(100% - 132px);
        overflow: hidden;
        color: var(--portal-main-font-color);
        font-family: var(--portal-title-font);
        font-size: var(--portal-type-title-md);
        font-weight: var(--portal-title-weight);
        line-height: 1.1;
        text-align: center;
        white-space: nowrap;
        text-overflow: ellipsis;
        opacity: 0;
        transform: translateX(-50%);
        transition: opacity 180ms ease;
        pointer-events: none;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar.show-title .page-hero-mobile-bar-title {
        opacity: 1;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-language-mobile {
        min-width: 52px;
        max-width: calc(100% - 64px);
        justify-self: end;
        margin-left: auto;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar .page-hero-back-mobile,
    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar .page-hero-language-mobile {
        border-color: var(--portal-glass-border);
        background:
            linear-gradient(
                180deg,
                rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
                rgba(255, 255, 255, 0.04)
            ),
            var(--portal-glass-bg);
        color: var(--portal-main-font-color);
        box-shadow:
            var(--portal-shadow-soft),
            inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
        backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
        -webkit-backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    }

    .guest-portal-shell[data-portal-layout="mobile"] .public-element-nav {
        width: 100%;
        max-width: none;
        margin-left: 0;
        margin-right: 0;
        padding: 3px 16px 1px;
        box-sizing: border-box;
        overflow-x: auto;
        position: relative;
        z-index: 12;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .guest-menu-category-rail {
        position: static;
        top: auto;
        width: 100%;
        max-width: 100%;
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
        overflow-x: hidden;
        overflow-y: visible;
        background: transparent;
        isolation: auto;
        opacity: var(--mobile-category-rail-opacity, 1);
        pointer-events: auto;
        transition: opacity 160ms ease;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .guest-menu-category-rail.is-mobile-docked {
        position: relative;
        top: auto;
        z-index: 0;
        pointer-events: var(--mobile-category-rail-pointer-events, auto);
    }

    .guest-portal-shell[data-portal-layout="mobile"] .guest-menu-category-nav {
        width: 100%;
        min-width: 100%;
        max-width: none;
        padding-left: 0;
        padding-right: 0;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar-categories .guest-menu-category-nav {
        min-width: 0;
        padding: 0 0 2px;
        overflow-x: auto;
        overflow-y: hidden;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .guest-summary-grid,
    .guest-portal-shell[data-portal-layout="mobile"] .portal-card-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .guest-portal-shell[data-portal-layout="mobile"] :where(.schedule-item, .content-item) {
        grid-template-columns: minmax(0, 1fr);
    }

    .guest-portal-shell[data-portal-layout="mobile"] .item-title-row {
        flex-direction: column;
    }

    .guest-portal-shell[data-portal-layout="mobile"] .item-title-aside {
        justify-content: flex-start;
    }
}

/* Content spacing follows text rhythm; title scale is reserved for title-font elements. */
.guest-portal-shell {
    --portal-section-stack-gap: calc(9.1px * var(--portal-text-rhythm-scale));
    --portal-detail-list-gap: calc(6.5px * var(--portal-text-rhythm-scale));
    --portal-detail-inner-gap: calc(4.55px * var(--portal-text-rhythm-scale));
    --portal-detail-tight-gap: calc(2.6px * var(--portal-text-rhythm-scale));
    --portal-media-stack-gap: clamp(4.55px, calc(var(--portal-text-line-unit) * 0.34), 8.45px);
    --portal-gallery-caption-gap: var(--portal-title-description-gap);
    --portal-gallery-caption-after-gap: calc(var(--portal-title-interval) * 1.3);
    --portal-gallery-inner-gap: clamp(3.9px, calc(var(--portal-text-line-unit) * 0.29), 7.8px);
    --portal-gallery-control-gap: clamp(3.25px, calc(var(--portal-text-line-unit) * 0.23), 6.5px);
    --portal-gallery-slide-pad: clamp(3.9px, calc(var(--portal-text-line-unit) * 0.38), 7.8px);
    --portal-gallery-thumb-gap: clamp(3.25px, calc(var(--portal-text-line-unit) * 0.25), 6.5px);
    --portal-title-meta-gap: calc(3.9px * var(--portal-text-rhythm-scale));
    --portal-text-line-unit: calc(var(--portal-type-md) * var(--portal-text-compact-line-height-rhythm));
    --portal-text-list-gap: clamp(1.3px, calc(var(--portal-text-line-unit) * 0.18), 6.5px);
    --portal-text-row-gap: clamp(1.3px, calc(var(--portal-text-line-unit) * 0.21), 7.15px);
    --portal-text-row-pad-y: clamp(1.95px, calc(var(--portal-text-line-unit) * 0.23), 7.15px);
    --portal-text-table-pad-y: clamp(2.6px, calc(var(--portal-text-line-unit) * 0.22), 6.5px);
    --portal-text-button-gap: clamp(1.95px, calc(var(--portal-text-line-unit) * 0.14), 4.55px);
    --portal-text-button-pad-y: clamp(3.25px, calc(var(--portal-text-line-unit) * 0.29), 7.8px);
    --portal-content-inset-unit: clamp(8px, 2.4vw, 14px);
    --portal-content-edge-inset-x: var(--portal-content-inset-unit);
    --portal-content-edge-inset-y: var(--portal-content-inset-unit);
    --portal-content-start-gap: var(--portal-content-inset-unit);
    --portal-category-nav-list-gap: var(--portal-content-inset-unit);
    --portal-category-list-gap: var(--portal-content-inset-unit);
    --portal-detail-divider-before-gap: var(--portal-content-inset-unit);
    --portal-feed-divider-before-gap: var(--portal-content-inset-unit);
    --portal-detail-divider-after-gap: var(--portal-content-inset-unit);
    --portal-element-heading-copy-block: calc(
        (var(--portal-type-lg) * 1.2) +
        var(--portal-title-description-gap) +
        (var(--portal-type-md) * var(--portal-text-line-height-rhythm))
    );
    --portal-element-heading-icon-overhang: max(
        0px,
        calc((var(--portal-title-icon-md) * var(--hotel-standard-icon-scale-factor, 1)) - var(--portal-element-heading-copy-block))
    );
    --portal-text-meta-gap: clamp(1.3px, calc(var(--portal-type-sm) * var(--portal-text-scale) * 0.21), 4.55px);
    --portal-text-heading-line-gap: calc(0.585rem * var(--portal-text-scale) * (var(--portal-text-compact-line-height-rhythm) - 1));
    --portal-text-detail-title-gap: clamp(2.6px, calc(var(--portal-text-line-unit) * 0.18), 5.2px);
    --portal-text-body-gap: clamp(3.25px, calc(var(--portal-text-line-unit) * 0.23), 6.5px);
    --portal-text-list-item-gap: clamp(1.95px, calc(var(--portal-text-line-unit) * 0.16), 4.55px);
    --portal-text-body-divider-gap: clamp(4.55px, calc(var(--portal-text-line-unit) * 0.33), 7.8px);
    --portal-text-body-media-gap: clamp(4.55px, calc(var(--portal-text-line-unit) * 0.34), 8.45px);
    --portal-text-body-inset-y: clamp(5.2px, calc(var(--portal-text-line-unit) * 0.4), 9.1px);
    --portal-text-body-inset-x: clamp(10px, calc(var(--portal-text-line-unit) * 0.72), 16px);
    --portal-text-heading-before-gap: clamp(3.9px, calc(var(--portal-text-line-unit) * 0.31), 7.8px);
    --portal-text-heading-after-gap: clamp(1.95px, calc(var(--portal-text-line-unit) * 0.16), 4.55px);
    --portal-divider-gap: clamp(2.6px, calc(var(--portal-text-line-unit) * 0.18), 5.85px);
    --portal-text-divider-gap: clamp(6.5px, calc(var(--portal-text-line-unit) * 0.38), 9.1px);
    --portal-feed-divider-gap: clamp(6.5px, calc(var(--portal-text-line-unit) * 0.38), 9.1px);
    --portal-menu-divider-gap: clamp(6.5px, calc(var(--portal-text-line-unit) * 0.38), 9.1px);
}

@supports (width: round(nearest, 2.4vw, 2px)) {
    .guest-portal-shell {
        --portal-content-inset-unit: clamp(8px, round(nearest, 2.4vw, 2px), 14px);
        --portal-content-edge-inset-x: var(--portal-content-inset-unit);
        --portal-content-edge-inset-y: var(--portal-content-inset-unit);
        --portal-content-start-gap: var(--portal-content-inset-unit);
        --portal-category-nav-list-gap: var(--portal-content-inset-unit);
        --portal-category-list-gap: var(--portal-content-inset-unit);
        --portal-detail-divider-before-gap: var(--portal-content-inset-unit);
        --portal-feed-divider-before-gap: var(--portal-content-inset-unit);
        --portal-detail-divider-after-gap: var(--portal-content-inset-unit);
        --portal-element-heading-copy-block: calc(
            (var(--portal-type-lg) * 1.2) +
            var(--portal-title-description-gap) +
            (var(--portal-type-md) * var(--portal-text-line-height-rhythm))
        );
        --portal-element-heading-icon-overhang: max(
            0px,
            calc((var(--portal-title-icon-md) * var(--hotel-standard-icon-scale-factor, 1)) - var(--portal-element-heading-copy-block))
        );
    }
}

.guest-portal-shell :where(
    .public-content-stack,
    .content-stack,
    .portal-card-grid,
    .portal-page-list,
    .portal-group-grid
) {
    gap: var(--portal-section-stack-gap);
}

.guest-portal-shell .portal-content-element {
    --element-title-zone-gap: var(--portal-text-row-gap);
    --element-title-zone-after-gap: var(--portal-text-line-unit);
    display: grid;
    gap: 0;
}

.guest-portal-shell .portal-content-element > .portal-element-heading {
    margin-bottom: 0;
    gap: var(--element-title-zone-gap);
}

.guest-portal-shell .portal-content-element > .portal-element-heading .portal-element-heading-copy {
    gap: var(--element-title-zone-gap);
}

.guest-portal-shell .portal-content-element > .portal-element-heading + * {
    margin-top: var(--element-title-zone-after-gap);
}

.guest-portal-shell .portal-content-element > .portal-element-heading:not(:has(.portal-element-summary)) + * {
    margin-top: var(--element-title-zone-after-gap);
}

.guest-portal-shell .portal-content-element > .portal-element-heading.has-icon:has(.portal-element-summary) + * {
    margin-top: var(--element-title-zone-after-gap);
}

.guest-portal-shell .portal-element-text > .portal-element-heading + .item-list {
    margin-top: var(--element-title-zone-after-gap);
}

.guest-portal-shell .portal-element-text > .portal-element-heading.has-icon:has(.portal-element-summary) + .item-list {
    margin-top: var(--element-title-zone-after-gap);
}

.guest-portal-shell .portal-content-element > .portal-element-heading:has(.portal-element-summary),
.guest-portal-shell .portal-content-element > .portal-element-heading:has(.portal-element-summary) .portal-element-heading-copy {
    gap: 0;
}

.guest-portal-shell .portal-content-element > .portal-element-heading :where(.portal-element-title + .portal-element-summary, h2 + .portal-element-summary) {
    margin-top: var(--portal-card-title-description-gap);
}

.guest-portal-shell .portal-content-element .item-main {
    display: grid;
    gap: var(--portal-text-row-gap);
}

.guest-portal-shell .portal-content-element .item-main > :where(
    .item-description,
    .item-value,
    .portal-richtext,
    .menu-item-meta-row
) {
    margin-top: 0;
}

.guest-portal-shell :where(.content-stack, .portal-card-grid, .portal-page-list, .portal-group-grid) {
    margin-top: var(--portal-section-stack-gap);
}

.guest-portal-shell :where(
    .portal-content-element .item-list,
    .portal-content-element .menu-category-group .item-list,
    .guest-feed-list,
    .guest-table-mode-cards,
    .guest-table-card-fields,
    .guest-actions,
    .guest-gallery,
    .portal-gallery,
    .portal-gallery-thumbnails,
    .guest-feed-gallery
) {
    gap: var(--portal-text-list-gap);
}

.guest-portal-shell .portal-content-element :is(
    .item-list,
    .menu-category-group .item-list,
    .guest-feed-list
) {
    gap: 0;
}

.guest-portal-shell :where(.guest-gallery, .portal-gallery) {
    gap: var(--portal-gallery-inner-gap);
}

.guest-portal-shell :where(.portal-gallery-controls, .portal-gallery-dots, .portal-gallery-thumbnails) {
    gap: var(--portal-gallery-control-gap);
}

.guest-portal-shell .portal-gallery-thumbnails {
    gap: var(--portal-gallery-thumb-gap);
}

.guest-portal-shell :where(
    .portal-content-element .content-item,
    .portal-content-element .menu-item,
    .portal-content-element .schedule-item,
    .portal-content-element .contact-item,
    .portal-content-element .faq-item,
    .guest-table-card-cell,
    .guest-table-grid-cell,
    .guest-feed-post-preview,
    .guest-feed-post-detail,
    .guest-feed-preview-copy,
    .guest-gallery-caption,
    .portal-richtext
) {
    gap: var(--portal-text-row-gap);
}

.guest-portal-shell :where(
    .schedule-main,
    .schedule-sub-row,
    .item-title-aside,
    .menu-item-meta-row,
    .item-meta,
    .guest-feed-meta-row,
    .guest-feed-post-detail-meta,
    .portal-card-highlights,
    .portal-label-list
) {
    gap: var(--portal-text-meta-gap);
}

.guest-portal-shell .portal-group-element-card .portal-label-list {
    --group-label-fade-width: 18px;
    flex-wrap: nowrap;
    max-width: 100%;
    overflow: hidden;
    row-gap: var(--portal-text-meta-gap);
    -webkit-mask-image: linear-gradient(90deg, #000 0, #000 calc(100% - var(--group-label-fade-width)), transparent 100%);
    mask-image: linear-gradient(90deg, #000 0, #000 calc(100% - var(--group-label-fade-width)), transparent 100%);
}

.guest-portal-shell .portal-group-element-card .portal-label-chip {
    flex: 0 0 auto;
    line-height: var(--portal-text-line-height-rhythm);
    overflow-wrap: normal;
    white-space: nowrap;
    word-break: normal;
}

.guest-portal-shell :where(
    .portal-richtext ul,
    .portal-richtext ol,
    .guest-table-cell-value.portal-richtext,
    .guest-table-cell-value.portal-richtext :where(ul, ol)
) {
    gap: var(--portal-text-meta-gap);
}

.guest-portal-shell :where(
    .portal-richtext h2,
    .portal-richtext h3,
    .guest-feed-gallery,
    .guest-feed-cta,
    .guest-feed-post-detail-gallery,
    .portal-embedded-image + *,
    .portal-gallery + *,
    .guest-gallery-caption + .portal-gallery-main
) {
    margin-top: var(--portal-detail-inner-gap);
}

.guest-portal-shell .guest-gallery-caption {
    gap: var(--portal-gallery-caption-gap);
    margin-bottom: var(--portal-gallery-caption-after-gap);
}

.guest-portal-shell .guest-gallery-caption h3 {
    padding-inline: var(--portal-content-edge-inset-x);
}

.guest-portal-shell .guest-gallery-caption + .portal-gallery {
    margin-top: 0;
}

.guest-portal-shell .portal-gallery-slide,
.guest-portal-shell .portal-embedded-image {
    padding: var(--portal-gallery-slide-pad);
}

.guest-portal-shell .guest-gallery-aspect-adaptive .portal-gallery-slide {
    padding-inline: 0;
}

.guest-portal-shell :where(.menu-item-meta-row, .guest-feed-gallery, .guest-feed-cta) {
    margin-top: var(--portal-text-meta-gap);
}

.guest-portal-shell .portal-content-element .item-main > .menu-item-meta-row {
    margin-top: 0;
}

.guest-portal-shell :where(
    .guest-table-row-card + .guest-table-row-card,
    .guest-table-element.has-rows-grid .guest-table-row-card + .guest-table-row-card .guest-table-card-fields
) {
    margin-top: 0;
}

.guest-portal-shell .content-item + .content-item::before {
    top: calc(var(--portal-text-list-gap) * -0.5);
}

.guest-portal-shell .guest-action-row + .guest-action-row {
    margin-top: 0;
}

.guest-portal-shell .guest-table-element {
    gap: var(--portal-text-list-gap);
}

.guest-portal-shell :where(.guest-table-header-cell, .guest-table-card-header-cell) {
    padding-block: calc(var(--portal-text-table-pad-y) * 0.82);
    padding-inline: 8px;
}

.guest-portal-shell :where(.guest-table-grid-cell, .guest-table-card-cell) {
    gap: var(--portal-text-meta-gap);
    padding-block: var(--portal-text-table-pad-y);
    padding-inline: 10px;
}

.guest-portal-shell .guest-table-mode-cards.has-headers .guest-table-card-cell {
    gap: var(--portal-title-description-gap);
    padding-top: calc(10px * var(--portal-text-rhythm-scale));
}

.guest-portal-shell .guest-table-overlap-tight :where(.guest-table-header-cell, .guest-table-grid-cell) {
    padding-block: calc(var(--portal-text-table-pad-y) * 0.72);
    padding-inline: 8px;
}

.guest-portal-shell .guest-table-card-fields,
.guest-portal-shell .guest-table-mode-cards {
    gap: 0;
}

@media (max-width: 560px) {
    .guest-portal-shell .guest-table-mode-cards .guest-table-row-card + .guest-table-row-card {
        margin-top: calc(var(--portal-content-inset-unit) * 0.8);
        border-top: 0;
    }

    .guest-portal-shell .guest-table-mode-cards.has-outer-grid {
        overflow: visible;
        border: 0;
        border-radius: 0;
    }

    .guest-portal-shell .guest-table-mode-cards .guest-table-card-fields {
        border-radius: 14px;
    }

    .guest-portal-shell .guest-table-mode-cards.has-outer-grid .guest-table-card-fields {
        border: 1px solid var(--portal-divider-color);
    }
}

.guest-portal-shell .portal-richtext:not(.guest-table-cell-value) {
    gap: 0;
}

.guest-portal-shell .portal-richtext:not(.guest-table-cell-value) :where(h1, h2, h3, h4, h5, h6) {
    margin-top: 0;
    margin-bottom: 0;
    line-height: var(--portal-title-comfort-line-height-rhythm);
}

.guest-portal-shell .portal-richtext:not(.guest-table-cell-value) :where(h1, h2) {
    font-size: var(--portal-type-h4);
}

.guest-portal-shell .portal-richtext:not(.guest-table-cell-value) h3 {
    font-size: calc(0.9rem * var(--portal-title-scale));
}

.guest-portal-shell .portal-richtext:not(.guest-table-cell-value) :where(h4, h5, h6) {
    font-size: calc(0.84rem * var(--portal-title-scale));
}

.guest-portal-shell .portal-richtext:not(.guest-table-cell-value) :where(h1, h2, h3, h4, h5, h6)
    + :where(h1, h2, h3, h4, h5, h6) {
    margin-top: var(--portal-title-interval);
}

.guest-portal-shell .portal-richtext:not(.guest-table-cell-value) :where(h1, h2, h3, h4, h5, h6)
    + :where(p, ul, ol, blockquote) {
    margin-top: var(--portal-text-heading-line-gap);
}

.guest-portal-shell .portal-richtext:not(.guest-table-cell-value) :where(p, ul, ol, blockquote)
    + :where(h1, h2, h3, h4, h5, h6) {
    margin-top: var(--portal-text-interval);
}

.guest-portal-shell .portal-richtext:not(.guest-table-cell-value) :where(p, ul, ol, blockquote)
    + :where(p, ul, ol, blockquote) {
    margin-top: var(--portal-text-body-gap);
}

.guest-portal-shell .guest-table-cell-value.portal-richtext {
    --table-richtext-line-height: var(--portal-text-compact-line-height-rhythm);
}

.guest-portal-shell .guest-table-cell-value.portal-richtext > :where(h1, h2, h3, h4, h5, h6):not(:first-child) {
    margin-top: var(--portal-title-description-gap) !important;
}

.guest-portal-shell .guest-actions:not(.guest-actions-layout-divider_row) {
    row-gap: calc(var(--portal-content-inset-unit) * 0.75);
    column-gap: calc(var(--portal-content-inset-unit) * 0.5);
}

.guest-portal-shell .guest-action-row {
    gap: calc(var(--portal-content-inset-unit) * 0.5);
}

.guest-portal-shell .guest-action {
    gap: var(--portal-text-button-gap);
    padding-block: calc(var(--portal-text-button-pad-y) * var(--action-tight-scale, 1));
    padding-inline: calc(var(--action-padding-x, 14px) * var(--action-tight-scale, 1));
}

.guest-portal-shell .guest-actions-layout-compact_buttons .guest-action,
.guest-portal-shell .guest-actions-layout-divider_row .guest-action {
    padding-block: clamp(3px, calc(var(--portal-text-button-pad-y) * 0.62), 7px);
    padding-inline: calc(var(--action-padding-x, 6px) * var(--action-tight-scale, 1));
}

.guest-portal-shell .guest-actions-layout-divider_row,
.guest-portal-shell .guest-actions-layout-divider_row .guest-action-row {
    gap: 0;
}

.guest-portal-shell .guest-action-copy {
    gap: var(--portal-text-meta-gap);
}

.guest-portal-shell .guest-actions-centered .guest-action:not(.guest-action-no-icon) {
    justify-content: flex-start;
}

.guest-portal-shell .guest-actions-centered .guest-action-copy {
    flex: 1 1 auto;
    width: 100%;
    justify-items: center;
    text-align: center;
}

.guest-portal-shell .portal-content-element :is(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item) {
    padding-top: 0;
    padding-bottom: 0;
}

.guest-portal-shell .portal-element-text .item-main {
    gap: var(--portal-text-heading-line-gap);
}

.guest-portal-shell .portal-element-text .item-main > h3 {
    margin: 0;
    padding-inline: var(--portal-content-edge-inset-x);
    line-height: var(--portal-title-comfort-line-height-rhythm);
}

.guest-portal-shell .portal-element-text .portal-richtext {
    gap: 0;
}

.guest-portal-shell .portal-element-text .portal-richtext :where(p, li, blockquote) {
    line-height: var(--portal-text-rich-line-height-rhythm);
}

.guest-portal-shell .portal-element-text .portal-richtext :where(ul, ol) {
    gap: var(--portal-text-list-item-gap);
    padding-left: var(--portal-text-body-inset-x);
}

.guest-portal-shell .portal-element-text .portal-richtext :where(h1, h2, h3, h4, h5, h6) {
    margin-top: 0;
    margin-bottom: 0;
    padding-inline: var(--portal-content-edge-inset-x);
    line-height: var(--portal-title-comfort-line-height-rhythm);
}

.guest-portal-shell .portal-element-text .portal-richtext > :where(h1, h2, h3, h4, h5, h6):first-child {
    margin-top: 0;
}

.guest-portal-shell .portal-element-text .portal-richtext :where(h1, h2) {
    font-size: var(--portal-type-h4);
}

.guest-portal-shell .portal-element-text .portal-richtext h3 {
    font-size: calc(0.9rem * var(--portal-title-scale));
}

.guest-portal-shell .portal-element-text .portal-richtext :where(h4, h5, h6) {
    font-size: calc(0.84rem * var(--portal-title-scale));
}

.guest-portal-shell .portal-element-text .portal-richtext :where(h1, h2, h3, h4, h5, h6)
    + :where(h1, h2, h3, h4, h5, h6) {
    margin-top: var(--portal-title-interval);
}

.guest-portal-shell .portal-element-text .portal-richtext :where(h1, h2, h3, h4, h5, h6)
    + :where(p, ul, ol, blockquote) {
    margin-top: var(--portal-text-heading-line-gap);
}

.guest-portal-shell .portal-element-text .portal-richtext :where(p, ul, ol, blockquote)
    + :where(h1, h2, h3, h4, h5, h6) {
    margin-top: var(--portal-text-interval);
}

.guest-portal-shell .portal-element-text .portal-richtext :where(p, ul, ol, blockquote)
    + :where(p, ul, ol, blockquote) {
    margin-top: var(--portal-text-body-gap);
}

.guest-portal-shell .portal-element-text .portal-richtext blockquote {
    padding:
        var(--portal-text-body-inset-y)
        var(--portal-text-body-inset-x);
}

.guest-portal-shell .portal-element-text .portal-richtext hr {
    margin-block: var(--portal-text-body-divider-gap);
}

.guest-portal-shell .portal-element-text .portal-richtext :where(.portal-gallery, .portal-embedded-image) {
    margin-block: var(--portal-text-body-media-gap);
}

.guest-portal-shell .portal-element-text .portal-richtext .portal-embedded-image {
    padding: var(--portal-text-body-inset-y);
}

.guest-portal-shell .portal-content-element :is(.item-list, .menu-category-group .item-list) > :is(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item):first-child {
    padding-top: 0;
}

.guest-portal-shell .portal-content-element :is(.item-list, .menu-category-group .item-list) > :is(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item):last-child {
    padding-bottom: 0;
}

.guest-portal-shell .portal-content-element :is(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item)
    + :is(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item)::before {
    content: "";
    position: absolute;
    top: var(--portal-detail-divider-before-gap);
    left: 0;
    right: 0;
    height: 1px;
    background: var(--portal-divider-color);
}

.guest-portal-shell .portal-content-element .menu-item-trigger + template + .menu-item-trigger::before {
    content: "";
    position: absolute;
    top: var(--portal-detail-divider-before-gap);
    left: 0;
    right: 0;
    height: 1px;
    background: var(--portal-divider-color);
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-trigger + template + .menu-item-trigger::before {
    left: 52px;
    top: 0;
}

.guest-portal-shell .guest-feed-post + .guest-feed-post::before {
    content: "";
    position: absolute;
    top: var(--portal-feed-divider-before-gap);
    left: var(--portal-content-edge-inset-x);
    right: var(--portal-content-edge-inset-x);
    height: 1px;
    background: var(--portal-divider-color);
}

.guest-portal-shell .portal-content-element :is(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item)
    + :is(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item) {
    padding-top: calc(
        var(--portal-detail-divider-before-gap) +
        1px +
        var(--portal-detail-divider-after-gap)
    );
}

.guest-portal-shell .portal-content-element .menu-item-trigger + template + .menu-item-trigger {
    padding-top: calc(
        var(--portal-detail-divider-before-gap) +
        1px +
        var(--portal-detail-divider-after-gap)
    );
}

.guest-portal-shell .portal-content-element :where(.item-list, .menu-category-group .item-list) {
    padding-inline: 0;
}

.guest-portal-shell .portal-content-element .menu-item,
.guest-portal-shell .portal-content-element .menu-item-trigger {
    padding-left: 0;
    padding-right: 0;
}

.guest-portal-shell .portal-content-element .menu-item + .menu-item::before,
.guest-portal-shell .portal-content-element .menu-item-trigger + template + .menu-item-trigger::before {
    left: 0;
    right: 0;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-trigger + template + .menu-item-trigger {
    padding-top: 7px;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-category-group + .menu-category-group {
    position: relative;
    padding-top: 7px;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-category-group + .menu-category-group::before {
    content: "";
    position: absolute;
    top: 0;
    left: 52px;
    right: 0;
    height: 1px;
    background: var(--portal-divider-color);
}

.guest-portal-shell .portal-content-element .guest-menu-compact.guest-menu-no-category-headings .menu-category-group + .menu-category-group {
    padding-top: 0;
}

.guest-portal-shell .portal-content-element .guest-menu-compact.guest-menu-no-category-headings .menu-category-group + .menu-category-group::before {
    content: none;
}

.guest-portal-shell .portal-content-element .guest-menu-compact.guest-menu-no-category-headings .menu-category-group + .menu-category-group .menu-item:first-of-type {
    padding-top: 7px;
}

.guest-portal-shell .portal-content-element .guest-menu-compact.guest-menu-no-category-headings .menu-category-group + .menu-category-group .menu-item:first-of-type::before {
    content: "";
    position: absolute;
    top: 0;
    left: 52px;
    right: 0;
    height: 1px;
    background: var(--portal-divider-color);
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    min-height: 46px;
    padding-top: 5px;
    padding-bottom: 5px;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item:not(:has(.menu-item-image)) {
    grid-template-columns: 42px minmax(0, 1fr);
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-image {
    grid-column: 1;
    grid-row: 1;
    width: 42px;
    height: 42px;
    max-width: 42px;
    max-height: 42px;
    min-width: 42px;
    min-height: 42px;
    margin: 0;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-compact-dot {
    grid-column: 1;
    grid-row: 1;
    place-self: center;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .item-main {
    grid-column: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 3px 12px;
    min-width: 0;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item:not(:has(.menu-item-image)) .item-main {
    grid-column: 2;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item:not(:has(.menu-item-image)) .menu-item-compact-dot {
    display: block;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-title,
.guest-portal-shell .portal-content-element .guest-menu-compact .item-description {
    grid-column: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-title {
    display: flex;
    align-items: baseline;
    gap: 6px;
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-md) * 1.02);
    font-weight: var(--portal-text-weight);
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-title > span:first-child {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-meta-row {
    grid-column: 2;
    grid-row: 1 / span 2;
    justify-self: end;
    align-self: center;
    justify-content: flex-end;
    margin: 0;
    text-align: right;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-price {
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-md) * 1.02);
    font-weight: var(--portal-text-weight);
    line-height: 1.15;
}

.guest-portal-shell .portal-content-element .guest-menu-compact .menu-category-group > h3 {
    font-family: var(--portal-text-font);
    font-size: calc(var(--portal-type-md) * 1.02);
    font-weight: max(var(--portal-text-weight), 500);
    line-height: 1.16;
}

@media (max-width: 420px) {
    .guest-portal-shell .portal-content-element .guest-menu-compact .menu-item {
        grid-template-columns: 38px minmax(0, 1fr);
        gap: 8px;
        min-height: 44px;
        padding-top: 5px;
        padding-bottom: 5px;
    }

    .guest-portal-shell .portal-content-element .guest-menu-compact .menu-item:not(:has(.menu-item-image)) {
        grid-template-columns: 38px minmax(0, 1fr);
    }

    .guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-image {
        width: 38px;
        height: 38px;
        max-width: 38px;
        max-height: 38px;
        min-width: 38px;
        min-height: 38px;
    }

    .guest-portal-shell .portal-content-element .guest-menu-compact .menu-item-trigger + template + .menu-item-trigger::before {
        left: 46px;
    }

    .guest-portal-shell .portal-content-element .guest-menu-compact .menu-category-group + .menu-category-group::before {
        left: 46px;
    }

    .guest-portal-shell .portal-content-element .guest-menu-compact.guest-menu-no-category-headings .menu-category-group + .menu-category-group .menu-item:first-of-type::before {
        left: 46px;
    }
}

body.admin-preview-page .guest-portal-shell .portal-content-element .guest-menu-compact .menu-category-group {
    padding: 0;
}

.guest-portal-shell .guest-feed-post-preview {
    padding-top: 0;
    padding-bottom: 0;
    height: auto;
    min-height: 0;
}

.guest-portal-shell .guest-feed-post:first-child .guest-feed-post-preview {
    padding-top: 0;
}

.guest-portal-shell .guest-feed-post:last-child .guest-feed-post-preview {
    padding-bottom: 0;
}

.guest-portal-shell .guest-feed-post + .guest-feed-post .guest-feed-post-preview {
    padding-top: calc(
        var(--portal-feed-divider-before-gap) +
        1px +
        var(--portal-detail-divider-after-gap)
    );
}

.guest-portal-shell .guest-feed-post-preview.has-image {
    min-height: min-content;
}

.guest-portal-shell .portal-content-element :where(.content-item, .menu-item, .schedule-item, .contact-item, .faq-item) {
    min-height: 0;
}

.guest-portal-shell .guest-gallery + .guest-gallery,
.guest-portal-shell .portal-gallery + .guest-gallery-caption {
    margin-top: var(--portal-detail-divider-before-gap);
    padding-top: var(--portal-detail-divider-after-gap);
    border-top: 1px solid var(--portal-divider-color);
}

.guest-portal-shell :where(
    .page-hero-mobile-bar,
    .page-hero-mobile-bar *,
    .page-hero-back-desktop,
    .back-to-top-button
) {
    --portal-title-scale: 1;
    --portal-title-rhythm-scale: 1;
    --portal-title-spacing-scale: 1;
    --portal-title-subtle-rhythm-scale: 1;
    --portal-title-icon-rhythm-scale: 1;
    --portal-pill-rhythm-scale: 1;
    --portal-category-pill-scale: 1;
}

.guest-portal-shell .page-hero-mobile-bar-categories,
.guest-portal-shell .page-hero-mobile-bar-categories * {
    --portal-pill-rhythm-scale: var(--portal-page-pill-rhythm-scale);
}

.guest-portal-shell .page-hero-mobile-bar-title {
    font-size: 0.94rem;
}

.guest-portal-shell :where(.page-hero-back-desktop, .page-hero-mobile-bar .page-hero-back-mobile) {
    width: 40px;
    height: 40px;
}

.guest-portal-shell :where(.page-hero-back-desktop svg, .page-hero-mobile-bar .page-hero-back-mobile svg) {
    width: 17px;
    height: 17px;
}

.guest-portal-shell .page-hero-mobile-bar .page-hero-language-mobile select {
    min-height: 32px;
    font-size: 0.82rem;
}

.guest-portal-shell .back-to-top-button {
    width: 42px;
    height: 42px;
    border-color: var(--portal-glass-border);
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
            rgba(255, 255, 255, 0.04)
        ),
        var(--portal-glass-bg);
    color: var(--portal-main-font-color);
    font-size: 1rem;
    box-shadow:
        var(--portal-shadow-soft),
        inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
    backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
    -webkit-backdrop-filter: blur(var(--guest-glass-blur, 17px)) saturate(var(--guest-glass-saturate, 145%)) contrast(1.06);
}

.guest-portal-shell .back-to-top-button:hover,
.guest-portal-shell .back-to-top-button:focus-visible {
    border-color: var(--portal-divider-color);
    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11)),
            rgba(255, 255, 255, 0.04)
        ),
        var(--portal-glass-bg);
    color: var(--portal-main-font-color);
    box-shadow:
        var(--portal-shadow),
        inset 0 1px 0 rgba(255, 255, 255, var(--guest-glass-highlight-alpha, 0.11));
}

@media (max-width: 560px) {
    .guest-portal-shell .back-to-top-button {
        width: 40px;
        height: 40px;
    }
}

@media (min-width: 641px) {
    html:has(body.public-portal-page:not(.admin-preview-page)),
    body.public-portal-page:not(.admin-preview-page) {
        min-height: 100%;
        overflow-x: hidden;
        overflow-y: auto;
        overscroll-behavior-y: auto;
    }

    body.public-portal-page:not(.admin-preview-page) {
        background: var(--guest-bg-color, var(--guest-soft));
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-stage {
        --portal-shell-width: min(calc(100% - 32px), 640px);
        --portal-viewport-left: calc((100% - var(--portal-shell-width)) / 2);
        --portal-viewport-width: var(--portal-shell-width);
        --portal-viewport-right-gap: calc((100% - var(--portal-viewport-width)) / 2);
        --portal-bg-image-feather: clamp(2px, 0.35vw, 4px);
        --portal-bg-side-space: max(0px, var(--portal-viewport-left));
        --portal-bg-side-image-width: min(var(--portal-bg-side-space), max(96px, calc(var(--portal-bg-side-space) * 0.42)));
        position: relative;
        display: grid;
        place-items: start center;
        width: 100%;
        min-height: 100dvh;
        overflow-x: hidden;
        overflow-y: visible;
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-stage-ambient {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 0;
        pointer-events: none;
        background: var(--guest-bg-color, var(--guest-soft));
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-stage-ambient::before,
    body.public-portal-page:not(.admin-preview-page) .guest-portal-stage-ambient::after {
        content: "";
        position: absolute;
        pointer-events: none;
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-stage-ambient::before {
        top: -72px;
        bottom: -72px;
        left: 0;
        width: 100%;
        background:
            linear-gradient(
                rgba(var(--guest-bg-wrapper-color-rgb, 255, 255, 255), var(--guest-bg-overlay-alpha, 0)),
                rgba(var(--guest-bg-wrapper-color-rgb, 255, 255, 255), var(--guest-bg-overlay-alpha, 0))
            ),
            var(--portal-background-image, none),
            var(--guest-bg-color, var(--guest-soft));
        background-position: center top;
        background-repeat: no-repeat;
        background-size: cover;
        filter: blur(calc(38px + var(--guest-bg-blur, 0px))) saturate(106%);
        opacity: 0.42;
        transform: none;
        transform-origin: center;
        -webkit-mask-image:
            linear-gradient(
                90deg,
                transparent 0,
                transparent calc(var(--portal-viewport-left) - var(--portal-bg-side-image-width)),
                rgba(0, 0, 0, 0.06) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.92)),
                rgba(0, 0, 0, 0.14) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.8)),
                rgba(0, 0, 0, 0.24) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.66)),
                rgba(0, 0, 0, 0.36) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.52)),
                rgba(0, 0, 0, 0.5) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.38)),
                rgba(0, 0, 0, 0.66) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.24)),
                rgba(0, 0, 0, 0.84) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.1)),
                #000 var(--portal-viewport-left),
                #000 calc(var(--portal-viewport-left) + var(--portal-bg-image-feather)),
                transparent calc(var(--portal-viewport-left) + var(--portal-bg-image-feather) + 1px),
                transparent calc(var(--portal-viewport-left) + var(--portal-viewport-width) - var(--portal-bg-image-feather) - 1px),
                #000 calc(var(--portal-viewport-left) + var(--portal-viewport-width) - var(--portal-bg-image-feather)),
                #000 calc(var(--portal-viewport-left) + var(--portal-viewport-width)),
                rgba(0, 0, 0, 0.84) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.1)),
                rgba(0, 0, 0, 0.66) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.24)),
                rgba(0, 0, 0, 0.5) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.38)),
                rgba(0, 0, 0, 0.36) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.52)),
                rgba(0, 0, 0, 0.24) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.66)),
                rgba(0, 0, 0, 0.14) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.8)),
                rgba(0, 0, 0, 0.06) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.92)),
                transparent calc(var(--portal-viewport-left) + var(--portal-viewport-width) + var(--portal-bg-side-image-width)),
                transparent 100%
            );
        mask-image:
            linear-gradient(
                90deg,
                transparent 0,
                transparent calc(var(--portal-viewport-left) - var(--portal-bg-side-image-width)),
                rgba(0, 0, 0, 0.06) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.92)),
                rgba(0, 0, 0, 0.14) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.8)),
                rgba(0, 0, 0, 0.24) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.66)),
                rgba(0, 0, 0, 0.36) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.52)),
                rgba(0, 0, 0, 0.5) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.38)),
                rgba(0, 0, 0, 0.66) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.24)),
                rgba(0, 0, 0, 0.84) calc(var(--portal-viewport-left) - (var(--portal-bg-side-image-width) * 0.1)),
                #000 var(--portal-viewport-left),
                #000 calc(var(--portal-viewport-left) + var(--portal-bg-image-feather)),
                transparent calc(var(--portal-viewport-left) + var(--portal-bg-image-feather) + 1px),
                transparent calc(var(--portal-viewport-left) + var(--portal-viewport-width) - var(--portal-bg-image-feather) - 1px),
                #000 calc(var(--portal-viewport-left) + var(--portal-viewport-width) - var(--portal-bg-image-feather)),
                #000 calc(var(--portal-viewport-left) + var(--portal-viewport-width)),
                rgba(0, 0, 0, 0.84) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.1)),
                rgba(0, 0, 0, 0.66) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.24)),
                rgba(0, 0, 0, 0.5) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.38)),
                rgba(0, 0, 0, 0.36) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.52)),
                rgba(0, 0, 0, 0.24) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.66)),
                rgba(0, 0, 0, 0.14) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.8)),
                rgba(0, 0, 0, 0.06) calc(var(--portal-viewport-left) + var(--portal-viewport-width) + (var(--portal-bg-side-image-width) * 0.92)),
                transparent calc(var(--portal-viewport-left) + var(--portal-viewport-width) + var(--portal-bg-side-image-width)),
                transparent 100%
            );
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-stage-ambient::after {
        top: calc(var(--guest-bg-blur, 0px) * -2);
        bottom: calc(var(--guest-bg-blur, 0px) * -2);
        left: calc(var(--portal-viewport-left, calc((100% - min(100%, 640px)) / 2)) - (var(--guest-bg-blur, 0px) * 2));
        width: calc(var(--portal-viewport-width, min(100%, 640px)) + (var(--guest-bg-blur, 0px) * 4));
        background:
            linear-gradient(
                rgba(var(--guest-bg-wrapper-color-rgb, 255, 255, 255), var(--guest-bg-overlay-alpha, 0)),
                rgba(var(--guest-bg-wrapper-color-rgb, 255, 255, 255), var(--guest-bg-overlay-alpha, 0))
            ),
            var(--portal-background-image, none),
            var(--guest-bg-color, var(--guest-soft));
        background-position: center top;
        background-repeat: no-repeat;
        background-size: 100% 100%, cover, 100% 100%;
        filter: blur(var(--guest-bg-blur, 0px));
        transform: scale(var(--guest-bg-blur-scale, 1));
        transform-origin: center top;
        box-shadow: none;
        -webkit-mask-image:
            linear-gradient(
                90deg,
                transparent 0,
                #000 var(--portal-bg-image-feather),
                #000 calc(100% - var(--portal-bg-image-feather)),
                transparent 100%
            );
        mask-image:
            linear-gradient(
                90deg,
                transparent 0,
                #000 var(--portal-bg-image-feather),
                #000 calc(100% - var(--portal-bg-image-feather)),
                transparent 100%
            );
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell {
        position: relative;
        z-index: 1;
        width: var(--portal-viewport-width) !important;
        max-width: 640px;
        min-height: 100dvh;
        margin: 0 auto;
        box-sizing: border-box;
        padding: 0 16px 44px;
        overflow: hidden;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
        isolation: isolate;
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell::before {
        content: none;
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell::after {
        content: none;
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell > * {
        position: relative;
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell :where(.public-element-nav, .guest-menu-category-nav, .page-tab-nav) {
        overflow-x: auto !important;
        overflow-y: hidden;
        touch-action: auto !important;
        overscroll-behavior-inline: contain;
        -webkit-overflow-scrolling: touch;
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell .guest-menu-category-rail {
        overflow-x: hidden;
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell .portal-gallery-track {
        touch-action: auto !important;
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell[data-portal-layout="mobile"] {
        padding-top: calc(var(--guest-mobile-topbar-height, 48px) + 14px) !important;
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell[data-portal-layout="mobile"] .page-hero-layout {
        --mobile-bar-left: var(--portal-viewport-left, 0px);
        --mobile-bar-width: var(--portal-viewport-width, 100vw);
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar {
        position: fixed;
        top: 0;
        left: var(--mobile-bar-left, 0px);
        right: auto;
        width: var(--mobile-bar-width, min(100vw, 640px));
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar.is-fixed {
        border-radius: 0 0 8px 8px;
    }

    body.public-portal-page:not(.admin-preview-page) .guest-portal-shell .back-to-top-button {
        left: calc(var(--portal-viewport-left, 0px) + var(--portal-viewport-width, 100vw) - 58px);
        right: auto;
        bottom: calc(env(safe-area-inset-bottom, 0px) + 16px);
    }

    body.public-portal-page:not(.admin-preview-page) .guest-footer {
        display: none;
    }

    html:has(body.admin-preview-dock-page),
    body.admin-preview-dock-page {
        min-height: 100%;
        overflow-x: hidden;
        overflow-y: auto;
        overscroll-behavior-y: auto;
        background: var(--guest-bg-color, var(--guest-soft));
    }

    body.admin-preview-dock-page .guest-portal-stage {
        --portal-shell-width: min(calc(100% - 32px), 640px);
        --portal-viewport-left: calc((100% - var(--portal-shell-width)) / 2);
        --portal-viewport-width: var(--portal-shell-width);
        --portal-viewport-right-gap: calc((100% - var(--portal-viewport-width)) / 2);
        position: relative;
        display: grid;
        place-items: start center;
        width: 100%;
        min-height: 100dvh;
        overflow-x: hidden;
        overflow-y: visible;
    }

    body.admin-preview-dock-page .guest-portal-stage-ambient {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 0;
        pointer-events: none;
        background: var(--guest-bg-color, var(--guest-soft));
    }

    body.admin-preview-dock-page .guest-portal-shell {
        position: relative;
        z-index: 1;
        width: var(--portal-viewport-width) !important;
        max-width: 640px;
        min-height: 100dvh;
        margin: 0 auto;
        box-sizing: border-box;
        padding: 0 16px 44px;
        overflow: hidden;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
        isolation: isolate;
    }

    body.admin-preview-dock-page .guest-portal-shell::before,
    body.admin-preview-dock-page .guest-portal-shell::after {
        content: none;
    }

    body.admin-preview-dock-page .guest-portal-shell > * {
        position: relative;
    }

    body.admin-preview-dock-page .guest-portal-shell :where(.public-element-nav, .guest-menu-category-nav, .page-tab-nav) {
        overflow-x: auto !important;
        overflow-y: hidden;
        touch-action: auto !important;
        overscroll-behavior-inline: contain;
        -webkit-overflow-scrolling: touch;
    }

    body.admin-preview-dock-page .guest-portal-shell .guest-menu-category-rail {
        overflow-x: hidden;
    }

    body.admin-preview-dock-page .guest-portal-shell .portal-gallery-track {
        touch-action: auto !important;
    }

    body.admin-preview-dock-page .guest-portal-shell[data-portal-layout="mobile"] {
        padding-top: calc(var(--guest-mobile-topbar-height, 48px) + 14px) !important;
    }

    body.admin-preview-dock-page .guest-portal-shell[data-portal-layout="mobile"] .page-hero-layout {
        --mobile-bar-left: var(--portal-viewport-left, 0px);
        --mobile-bar-width: var(--portal-viewport-width, 100vw);
    }

    body.admin-preview-dock-page .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar {
        position: fixed;
        top: 0;
        left: var(--mobile-bar-left, 0px);
        right: auto;
        width: var(--mobile-bar-width, min(100vw, 640px));
    }

    body.admin-preview-dock-page .guest-portal-shell[data-portal-layout="mobile"] .page-hero-mobile-bar.is-fixed {
        border-radius: 0 0 8px 8px;
    }

    body.admin-preview-dock-page .guest-portal-shell .back-to-top-button {
        left: calc(var(--portal-viewport-left, 0px) + var(--portal-viewport-width, 100vw) - 58px);
        right: auto;
        bottom: calc(env(safe-area-inset-bottom, 0px) + 16px);
    }

    body.admin-preview-dock-page .guest-footer {
        display: none;
    }
}
