* { -webkit-tap-highlight-color: transparent; }
body { font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
.opacity-60 { opacity: .6; }
.pointer-events-none { pointer-events: none; }
.app-toast {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: .75rem;
    width: min(24rem, calc(100vw - 2rem));
    overflow: hidden;
    border: 1px solid #e2e8f0;
    border-radius: .85rem;
    background: #fff;
    padding: .9rem .95rem 1rem;
    box-shadow: 0 18px 60px rgba(15, 23, 42, .12);
    color: #047857;
    transform-origin: top right;
    animation: toast-in .18s ease both;
}
.app-toast-error {
    color: #b91c1c;
}
.app-toast-content {
    min-width: 0;
    color: currentColor;
    font-size: .9rem;
    font-weight: 800;
    line-height: 1.35;
}
.app-toast-close {
    display: inline-grid;
    width: 1.55rem;
    height: 1.55rem;
    place-items: center;
    border: 1px solid transparent;
    border-radius: .5rem;
    color: #64748b;
    font-size: 1.2rem;
    font-weight: 800;
    line-height: 1;
    transition: background .16s ease, color .16s ease, border-color .16s ease;
}
.app-toast-close:hover {
    border-color: #e2e8f0;
    background: #f8fafc;
    color: #0f172a;
}
.app-toast-progress {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    height: .22rem;
    background: currentColor;
    opacity: .9;
    transform-origin: left center;
    animation: toast-progress var(--toast-duration, 3400ms) linear forwards;
}
.app-toast.is-leaving {
    pointer-events: none;
    animation: toast-out .18s ease forwards;
}
.app-toast.is-leaving .app-toast-progress {
    animation-play-state: paused;
}
@keyframes toast-in {
    from { opacity: 0; transform: translateY(-.35rem) scale(.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes toast-out {
    to { opacity: 0; transform: translateY(-.35rem) scale(.98); }
}
@keyframes toast-progress {
    from { transform: scaleX(1); }
    to { transform: scaleX(0); }
}
.brand-lockup {
    display: inline-flex;
    min-width: 0;
    align-items: center;
    gap: .75rem;
    color: inherit;
    text-decoration: none;
}
.brand-lockup > span:last-child {
    display: grid;
    min-width: 0;
    gap: .05rem;
}
.brand-lockup strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #0f172a;
    font-size: .98rem;
    font-weight: 900;
    line-height: 1.05;
}
.brand-lockup em {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #64748b;
    font-size: .68rem;
    font-style: normal;
    font-weight: 850;
    letter-spacing: .05em;
    line-height: 1.1;
    text-transform: uppercase;
}
.brand-mark {
    display: inline-grid;
    width: 2.35rem;
    height: 2.35rem;
    flex: none;
    place-items: center;
    border-radius: .85rem;
    overflow: hidden;
    background: #fff;
    color: #fff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, .18);
}
.brand-mark-pro {
    background: #fff;
}
.brand-mark img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.nav-link { display: block; border-radius: .6rem; padding: .65rem .85rem; font-size: .925rem; font-weight: 600; white-space: nowrap; }
.icon-btn {
    display: inline-grid;
    width: 2.45rem;
    height: 2.45rem;
    flex: none;
    place-items: center;
    border-radius: .7rem;
    border: 1px solid transparent;
    font-size: .95rem;
    transition: transform .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease, border-color .16s ease;
}
.icon-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 28px rgba(15, 23, 42, .12);
}
.icon-btn-primary {
    background: #0f172a;
    color: #fff;
}
.icon-btn-secondary {
    border-color: #e2e8f0;
    background: #fff;
    color: #334155;
}
.icon-btn-secondary:hover {
    border-color: #cbd5e1;
    color: #0f172a;
}
.icon-btn-danger {
    background: #fee2e2;
    color: #991b1b;
}
.icon-btn-danger:hover {
    background: #fecaca;
}
.btn-primary i,
.btn-secondary i,
.btn-danger i {
    font-size: .95em;
}
.pro-shell {
    background:
        radial-gradient(circle at top right, rgba(15, 23, 42, .06), transparent 24rem),
        #f8fafc;
}
.pro-shell > main {
    flex: 1 1 auto;
    width: 100%;
}
.pro-sidebar {
    position: sticky;
    top: 0;
    z-index: 40;
    border-bottom: 1px solid #e2e8f0;
}
.pro-sidebar-head {
    display: flex;
    min-width: 0;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .95rem 1rem .7rem;
}
.pro-restaurant-lockup {
    display: grid;
    min-width: 0;
    color: inherit;
    text-decoration: none;
}
.pro-restaurant-lockup strong {
    overflow: hidden;
    color: #0f172a;
    font-size: 1.05rem;
    font-weight: 950;
    line-height: 1.05;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.pro-restaurant-lockup span {
    margin-top: .2rem;
    color: #64748b;
    font-size: .68rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.pro-logout-mobile {
    display: grid;
    width: 2.35rem;
    height: 2.35rem;
    flex: none;
    place-items: center;
    border: 1px solid #e2e8f0;
    border-radius: 999px;
    color: #475569;
}
.pro-logout-mobile svg {
    width: 1.15rem;
    height: 1.15rem;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2.2;
}
.pro-nav {
    display: flex;
    gap: .45rem;
    overflow-x: auto;
    padding: 0 1rem .85rem;
    scrollbar-width: none;
}
.pro-nav::-webkit-scrollbar { display: none; }
.pro-nav .nav-link {
    flex: 0 0 auto;
    border-radius: 999px;
    padding: .58rem .82rem;
    font-size: .82rem;
    font-weight: 850;
}
.pro-topbar {
    position: relative;
    z-index: 30;
    border-bottom: 1px solid rgba(226, 232, 240, .9);
    background: rgba(255, 255, 255, .86);
    backdrop-filter: blur(18px);
}
.pro-topbar-inner {
    display: flex;
    box-sizing: border-box;
    width: 100%;
    min-height: 4rem;
    align-items: center;
    justify-content: space-between;
    gap: .85rem;
    padding: .75rem 1rem;
}
.pro-content {
    box-sizing: border-box;
    width: 100%;
    padding: 1rem;
}
.pro-dashboard-hero {
    display: grid;
    gap: 1.25rem;
    border: 1px solid #e2e8f0;
    border-radius: 1.1rem;
    background:
        linear-gradient(135deg, #ffffff 0%, #f8fafc 52%, #ffffff 100%);
    padding: 1.15rem;
    box-shadow: 0 18px 60px rgba(15, 23, 42, .06);
}
.pro-dashboard-hero h2 {
    color: #0f172a;
    font-size: clamp(1.7rem, 6vw, 3rem);
    font-weight: 950;
    letter-spacing: 0;
    line-height: .95;
}
.pro-dashboard-actions {
    display: grid;
    gap: .6rem;
}
.pro-stat-grid {
    display: grid;
    gap: .85rem;
    margin-top: 1rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.pro-stat-card {
    display: grid;
    min-width: 0;
    gap: .35rem;
    border: 1px solid #e2e8f0;
    border-radius: 1rem;
    background: #fff;
    padding: 1rem;
    box-shadow: 0 14px 38px rgba(15, 23, 42, .05);
}
.pro-stat-card span {
    color: #64748b;
    font-size: .78rem;
    font-weight: 900;
    text-transform: uppercase;
}
.pro-stat-card strong {
    color: #0f172a;
    font-size: 2rem;
    font-weight: 950;
    line-height: 1;
}
.pro-stat-card small {
    width: fit-content;
    border-radius: 999px;
    background: #ecfdf5;
    padding: .25rem .55rem;
    color: #047857;
    font-size: .72rem;
    font-weight: 900;
}
.pro-stat-card em {
    color: #64748b;
    font-size: .78rem;
    font-style: normal;
    font-weight: 700;
    line-height: 1.35;
}
.pro-alert-grid {
    display: grid;
    gap: .7rem;
    margin-top: 1rem;
}
.pro-alert-card {
    display: flex;
    gap: .75rem;
    align-items: flex-start;
    border: 1px solid #fde68a;
    border-radius: .95rem;
    background: #fffbeb;
    padding: .9rem;
    color: inherit;
    text-decoration: none;
}
.pro-alert-card > span {
    width: .55rem;
    height: .55rem;
    margin-top: .38rem;
    flex: none;
    border-radius: 999px;
    background: #f59e0b;
}
.pro-alert-card strong {
    color: #78350f;
    font-size: .9rem;
    font-weight: 900;
}
.pro-alert-card p {
    margin-top: .15rem;
    color: #92400e;
    font-size: .82rem;
    font-weight: 650;
    line-height: 1.45;
}
.pro-monitor-card {
    display: grid;
    gap: .9rem;
    margin-top: 1rem;
    border: 1px solid #fecaca;
    border-radius: 1.1rem;
    background: linear-gradient(135deg, #fff7ed, #fff 64%);
    padding: 1rem;
    box-shadow: 0 18px 44px rgba(127, 29, 29, .07);
}
.pro-monitor-card-head {
    display: flex;
    min-width: 0;
    gap: .8rem;
    align-items: flex-start;
}
.pro-monitor-icon {
    display: grid;
    width: 2.4rem;
    height: 2.4rem;
    flex: none;
    place-items: center;
    border-radius: .85rem;
    background: #fee2e2;
    color: #b91c1c;
}
.pro-monitor-card-head strong {
    color: #7f1d1d;
    font-size: .98rem;
    font-weight: 950;
}
.pro-monitor-card-head p,
.pro-monitor-more {
    margin-top: .15rem;
    color: #991b1b;
    font-size: .86rem;
    font-weight: 700;
    line-height: 1.5;
}
.pro-monitor-list {
    display: grid;
    gap: .55rem;
}
.pro-monitor-item {
    display: flex;
    min-width: 0;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    border: 1px solid rgba(254, 202, 202, .9);
    border-radius: .9rem;
    background: rgba(255, 255, 255, .78);
    padding: .75rem;
}
.pro-monitor-item > div {
    min-width: 0;
}
.pro-monitor-item strong {
    display: block;
    overflow: hidden;
    color: #0f172a;
    font-size: .9rem;
    font-weight: 900;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.pro-monitor-item span {
    display: block;
    margin-top: .1rem;
    color: #64748b;
    font-size: .78rem;
    font-weight: 750;
}
.pro-section-head {
    display: grid;
    gap: .85rem;
    border-bottom: 1px solid #e2e8f0;
    padding: 1rem;
}
.pro-section-head-inline {
    margin: -1rem -1rem 1rem;
    align-items: center;
}
.pro-section-head h2,
.pro-qr-summary h2,
.qr-side-panel h3 {
    color: #0f172a;
    font-size: 1.08rem;
    font-weight: 950;
}
.pro-section-head p,
.pro-qr-summary p,
.qr-side-panel p {
    margin-top: .2rem;
    color: #64748b;
    font-size: .86rem;
    font-weight: 650;
    line-height: 1.5;
}
.pro-recent-grid {
    display: grid;
    gap: .75rem;
    padding: 1rem;
}
.promo-popup-form .form-actions {
    justify-content: flex-end;
}
.promo-popup-switch {
    display: flex;
    align-items: center;
    gap: .75rem;
    border-radius: .95rem;
    background: #f8fafc;
    padding: .85rem;
    color: #0f172a;
    font-size: .9rem;
    font-weight: 850;
}
.pro-menu-card {
    display: grid;
    grid-template-columns: 4.5rem minmax(0, 1fr);
    gap: .85rem;
    align-items: center;
    border: 1px solid #e2e8f0;
    border-radius: .95rem;
    padding: .75rem;
}
.pro-menu-card img,
.pro-menu-card-placeholder {
    width: 4.5rem;
    height: 4.5rem;
    border-radius: .8rem;
    object-fit: cover;
}
.pro-menu-card-placeholder {
    display: grid;
    place-items: center;
    background: #f1f5f9;
    color: #64748b;
    font-size: 1.4rem;
    font-weight: 950;
}
.pro-menu-card h3 {
    overflow: hidden;
    color: #0f172a;
    font-size: .95rem;
    font-weight: 900;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.pro-menu-card p {
    overflow: hidden;
    color: #64748b;
    font-size: .82rem;
    font-weight: 700;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.pro-menu-card strong {
    flex: none;
    color: #0f172a;
    font-size: .9rem;
    font-weight: 950;
}
.pro-qr-summary img {
    width: min(15rem, 100%);
    margin: 1.2rem auto;
    border-radius: 1rem;
    background: #fff;
    padding: .75rem;
    box-shadow: inset 0 0 0 1px #e2e8f0;
}
.pro-url-pill {
    overflow-wrap: anywhere;
    border-radius: .85rem;
    background: #f8fafc;
    padding: .75rem;
    color: #475569;
    font-size: .78rem;
    font-weight: 800;
}
.identity-image-preview {
    display: grid;
    width: 100%;
    place-items: center;
    overflow: hidden;
    border: 1px solid #e2e8f0;
    border-radius: .95rem;
    background: #f8fafc;
    color: #94a3b8;
    font-size: .82rem;
    font-weight: 850;
    text-align: center;
}
.identity-logo-preview {
    min-height: 8rem;
    padding: 1rem;
}
.identity-logo-preview img {
    max-width: 100%;
    max-height: 7rem;
    object-fit: contain;
}
.identity-cover-preview {
    aspect-ratio: 16 / 9;
}
.identity-cover-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.upload-status {
    min-height: 1rem;
    margin-top: .45rem;
    color: #64748b;
    font-size: .75rem;
    font-weight: 800;
}
.restaurant-photo-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .75rem;
    margin-top: 1rem;
}
.restaurant-photo-card {
    position: relative;
    overflow: hidden;
    border-radius: .8rem;
    background: #f1f5f9;
}
.restaurant-photo-card img {
    width: 100%;
    height: 6rem;
    object-fit: cover;
}
.restaurant-photo-delete {
    position: absolute;
    top: .35rem;
    right: .35rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, .94);
    padding: .28rem .52rem;
    color: #991b1b;
    font-size: .7rem;
    font-weight: 900;
    box-shadow: 0 10px 24px rgba(15, 23, 42, .12);
}
.restaurant-photo-delete.icon-btn {
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: 1px solid rgba(254, 202, 202, .9);
}
.menu-board-tools {
    display: grid;
    gap: .75rem;
    margin-bottom: 1rem;
}
.menu-category-stack {
    display: grid;
    gap: 1rem;
}
.menu-subcategory-stack {
    display: grid;
    gap: .8rem;
    padding: 1rem;
}
.menu-category-panel {
    border: 1px solid #e2e8f0;
    border-radius: 1rem;
    background: #fff;
    box-shadow: 0 18px 60px rgba(15, 23, 42, .05);
}
.menu-category-parent-panel {
    background: #f8fafc;
}
.menu-subcategory-panel {
    box-shadow: none;
}
.menu-category-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .85rem;
    border-bottom: 1px solid #e2e8f0;
    padding: 1rem;
}
.menu-category-parent-label {
    display: block;
    margin-bottom: .2rem;
    color: #64748b;
    font-size: .68rem;
    font-weight: 900;
    text-transform: uppercase;
}
.menu-category-head h3 {
    color: #0f172a;
    font-size: 1.05rem;
    font-weight: 950;
}
.menu-category-head p {
    margin-top: .15rem;
    color: #64748b;
    font-size: .78rem;
    font-weight: 800;
}
.menu-category-empty,
.menu-board-empty {
    margin: 1rem;
    border: 1px dashed #cbd5e1;
    border-radius: .85rem;
    background: #f8fafc;
    padding: 1rem;
    color: #64748b;
    font-size: .9rem;
    font-weight: 800;
    text-align: center;
}
.menu-board-empty.is-hidden {
    display: none;
}
.menu-item-card-grid {
    display: grid;
    gap: .8rem;
    padding: 1rem;
}
.menu-sort-hint {
    display: flex;
    align-items: center;
    gap: .45rem;
    margin: .9rem 1rem 0;
    border: 1px dashed #cbd5e1;
    border-radius: .75rem;
    background: #f8fafc;
    padding: .65rem .8rem;
    color: #64748b;
    font-size: .78rem;
    font-weight: 800;
}
.menu-sort-hint [data-sort-filtered] {
    display: none;
}
.menu-sort-hint.is-filtered {
    border-color: #fed7aa;
    background: #fff7ed;
    color: #9a3412;
}
.menu-sort-hint.is-filtered [data-sort-ready] {
    display: none;
}
.menu-sort-hint.is-filtered [data-sort-filtered] {
    display: inline;
}
.menu-item-card-grid.is-sort-disabled .menu-drag-handle {
    cursor: not-allowed;
    opacity: .45;
}
.menu-item-card-grid.is-saving-order .menu-management-card {
    pointer-events: none;
}
.menu-management-card {
    position: relative;
    display: grid;
    grid-template-columns: auto 5.2rem minmax(0, 1fr);
    gap: .85rem;
    align-items: center;
    border: 1px solid #e2e8f0;
    border-radius: .9rem;
    padding: .75rem;
    background: #fff;
    transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.menu-management-card.is-drag-chosen,
.menu-management-card:hover {
    border-color: #cbd5e1;
    box-shadow: 0 18px 42px rgba(15, 23, 42, .08);
}
.menu-management-card.is-dashboard-target {
    border-color: #f59e0b;
    box-shadow: 0 0 0 4px rgba(245, 158, 11, .18), 0 18px 44px rgba(245, 158, 11, .16);
}
.menu-management-card.is-dragging {
    transform: none;
}
.menu-management-card.is-drag-ghost {
    opacity: .55;
}
.menu-management-card.is-drag-fallback {
    box-shadow: 0 22px 56px rgba(15, 23, 42, .18);
    opacity: .98;
}
.menu-drag-handle {
    display: inline-grid;
    width: 2.25rem;
    height: 5.2rem;
    flex: none;
    place-items: center;
    border: 1px solid #e2e8f0;
    border-radius: .7rem;
    background: #f8fafc;
    color: #94a3b8;
    cursor: grab;
    touch-action: none;
}
.menu-drag-handle:active {
    cursor: grabbing;
}
.menu-drag-handle:hover,
.menu-management-card.is-drag-chosen .menu-drag-handle {
    border-color: #94a3b8;
    color: #0f172a;
}
.menu-management-photo {
    width: 5.2rem;
    height: 5.2rem;
    border-radius: .75rem;
    object-fit: cover;
}
.menu-management-photo-empty {
    display: grid;
    place-items: center;
    background: #f1f5f9;
    color: #64748b;
    font-size: 1.5rem;
    font-weight: 950;
}
.menu-management-body {
    display: grid;
    min-width: 0;
    gap: .55rem;
}
.menu-management-body h4 {
    overflow: hidden;
    color: #0f172a;
    font-size: .98rem;
    font-weight: 950;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.menu-management-body p {
    display: -webkit-box;
    overflow: hidden;
    color: #64748b;
    font-size: .8rem;
    font-weight: 700;
    line-height: 1.35;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}
.menu-management-body strong {
    flex: none;
    color: #0f172a;
    font-size: .9rem;
    font-weight: 950;
    white-space: nowrap;
}
.menu-management-tags,
.menu-management-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    align-items: center;
}
.menu-management-actions .btn-secondary,
.menu-management-actions .btn-danger {
    padding: .48rem .7rem;
    font-size: .78rem;
}
.menu-management-actions .icon-btn {
    width: 2.2rem;
    height: 2.2rem;
    border-radius: .62rem;
    font-size: .86rem;
}
#menu-items-board.is-loading {
    opacity: .55;
    pointer-events: none;
}
.menu-item-card-grid.is-saving-order {
    opacity: .72;
    pointer-events: none;
}
.is-menu-sorting {
    user-select: none;
}
.btn-primary { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; border-radius: .6rem; background: #0f172a; color: #fff; padding: .65rem 1rem; font-weight: 700; font-size: .9rem; transition: .18s ease; }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 12px 30px rgba(15, 23, 42, .18); }
.btn-secondary { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; border-radius: .6rem; background: #fff; color: #334155; border: 1px solid #e2e8f0; padding: .6rem .9rem; font-weight: 700; font-size: .875rem; }
.btn-danger { display: inline-flex; align-items: center; justify-content: center; border-radius: .6rem; background: #fee2e2; color: #991b1b; padding: .55rem .85rem; font-weight: 700; font-size: .875rem; }
.btn-primary,
.btn-secondary,
.btn-danger {
    min-width: 0;
    max-width: 100%;
    text-align: center;
}
.btn-primary span,
.btn-secondary span,
.btn-danger span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.input { width: 100%; border-radius: .7rem; border: 1px solid #cbd5e1; background: #fff; padding: .75rem .9rem; outline: none; transition: .16s ease; }
.input:focus { border-color: #0f172a; box-shadow: 0 0 0 4px rgba(15, 23, 42, .08); }
.label { display: block; margin-bottom: .4rem; font-size: .8rem; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; color: #64748b; }
.landing-page {
    min-height: 100vh;
    overflow-x: hidden;
    background:
        radial-gradient(circle at 12% 44rem, rgba(34, 211, 238, .1), transparent 22rem),
        radial-gradient(circle at 88% 70rem, rgba(245, 158, 11, .09), transparent 24rem),
        linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
    color: #0f172a;
}
.landing-nav {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 30;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem clamp(1rem, 4vw, 3rem);
    background: rgba(255, 255, 255, .9);
    border-bottom: 1px solid rgba(226, 232, 240, .88);
    backdrop-filter: blur(18px);
}
.landing-nav nav {
    display: flex;
    align-items: center;
    gap: .7rem;
}
.landing-nav-link {
    color: #334155;
    font-size: .88rem;
    font-weight: 850;
}
.landing-nav-link:hover {
    color: #0f172a;
}
.landing-hero {
    position: relative;
    display: flex;
    min-height: clamp(560px, 76vh, 700px);
    align-items: center;
    padding: 7rem clamp(1rem, 5vw, 4rem) 4rem;
    overflow: hidden;
    background: url('https://images.unsplash.com/photo-1555396273-367ea4eb4db5?auto=format&fit=crop&w=1800&q=82') center/cover no-repeat;
    color: #fff;
}
.landing-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(15, 23, 42, .72), rgba(15, 23, 42, .46) 46%, rgba(15, 23, 42, .12));
}
.landing-hero-copy {
    position: relative;
    z-index: 1;
    width: min(100%, 46rem);
}
.landing-hero h1 {
    max-width: 16ch;
    font-size: clamp(2.35rem, 4.8vw, 4.15rem);
    font-weight: 950;
    line-height: 1;
}
.landing-hero p {
    max-width: 42rem;
    margin-top: 1.35rem;
    color: rgba(255, 255, 255, .86);
    font-size: clamp(1rem, 1.8vw, 1.22rem);
    font-weight: 650;
    line-height: 1.7;
}
.landing-proof-row {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
    margin-top: 1.25rem;
}
.landing-proof-row span {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    border: 1px solid rgba(255, 255, 255, .22);
    border-radius: 999px;
    background: rgba(255, 255, 255, .12);
    padding: .42rem .68rem;
    color: rgba(255, 255, 255, .9);
    font-size: .82rem;
    font-weight: 850;
}
.landing-proof-row i {
    color: #fde68a;
    font-size: .78rem;
}
.landing-hero-actions {
    position: relative;
    z-index: 2;
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
    margin-top: 2rem;
}
.landing-hero-actions .btn-primary {
    min-width: 11.5rem;
    background: #fff;
    color: #0f172a;
    box-shadow: 0 14px 34px rgba(15, 23, 42, .22);
}
.landing-hero-actions .btn-secondary {
    min-width: 11.5rem;
    border-color: rgba(255, 255, 255, .26);
    background: rgba(255, 255, 255, .12);
    color: #fff;
}
.landing-seo-section,
.landing-faq-section {
    width: min(100%, 76rem);
    margin: 0 auto;
    padding: clamp(4.75rem, 8vw, 6.5rem) clamp(1rem, 3vw, 1.5rem) 0;
}
.landing-seo-section {
    display: grid;
    grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr);
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: start;
}
.landing-seo-copy {
    display: grid;
    gap: .9rem;
}
.landing-seo-copy span,
.landing-faq-head span {
    color: #b45309;
    font-size: .8rem;
    font-weight: 950;
    letter-spacing: .12em;
    text-transform: uppercase;
}
.landing-seo-copy h2,
.landing-faq-head h2 {
    color: #0f172a;
    font-size: clamp(1.75rem, 3vw, 2.7rem);
    font-weight: 950;
    line-height: 1.08;
}
.landing-seo-copy p {
    color: #64748b;
    font-size: 1rem;
    font-weight: 650;
    line-height: 1.75;
}
.landing-seo-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}
.landing-seo-grid article,
.landing-faq-list article {
    min-width: 0;
    border: 1px solid rgba(148, 163, 184, .22);
    border-radius: 1rem;
    background: rgba(255, 255, 255, .76);
    padding: 1rem;
    box-shadow: 0 18px 50px rgba(15, 23, 42, .055);
}
.landing-seo-grid i {
    display: inline-grid;
    width: 2.15rem;
    height: 2.15rem;
    place-items: center;
    margin-bottom: .85rem;
    border-radius: .75rem;
    background: #ecfeff;
    color: #0e7490;
}
.landing-seo-grid strong,
.landing-faq-list h3 {
    display: block;
    color: #0f172a;
    font-size: 1rem;
    font-weight: 950;
    line-height: 1.25;
}
.landing-seo-grid p,
.landing-faq-list p {
    margin-top: .45rem;
    color: #64748b;
    font-size: .91rem;
    font-weight: 650;
    line-height: 1.6;
}
.landing-feature-band {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(18rem, .75fr);
    align-items: center;
    gap: clamp(1.2rem, 4vw, 3rem);
    width: min(100%, 76rem);
    margin: -3.25rem auto 0;
    overflow: hidden;
    border: 1px solid rgba(148, 163, 184, .24);
    border-radius: 1.35rem;
    background:
        radial-gradient(circle at 82% 12%, rgba(34, 211, 238, .16), transparent 17rem),
        radial-gradient(circle at 12% 88%, rgba(245, 158, 11, .13), transparent 18rem),
        linear-gradient(135deg, rgba(255, 255, 255, .98), rgba(248, 250, 252, .94));
    padding: clamp(1.2rem, 3vw, 2rem);
    position: relative;
    z-index: 3;
    box-shadow: 0 28px 90px rgba(15, 23, 42, .1);
}
.landing-feature-band::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(15, 23, 42, .045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(15, 23, 42, .045) 1px, transparent 1px);
    background-size: 3rem 3rem;
    mask-image: linear-gradient(90deg, rgba(0, 0, 0, .68), transparent 80%);
    pointer-events: none;
}
.landing-feature-band::after {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    border: 1px solid rgba(255, 255, 255, .72);
    pointer-events: none;
}
.landing-console-content,
.landing-console-preview {
    position: relative;
    z-index: 1;
}
.landing-console-kicker {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    color: #0e7490;
    font-size: .78rem;
    font-weight: 950;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.landing-console-kicker::before {
    content: "";
    width: .55rem;
    height: .55rem;
    border-radius: 999px;
    background: #22c55e;
    box-shadow: 0 0 0 .25rem rgba(34, 197, 94, .14), 0 0 1.1rem rgba(34, 197, 94, .56);
}
.landing-console-content h2 {
    max-width: 40rem;
    margin-top: .75rem;
    color: #0f172a;
    font-size: clamp(1.55rem, 3vw, 2.45rem);
    font-weight: 950;
    line-height: 1.08;
}
.landing-console-lines {
    display: grid;
    gap: .85rem;
    margin-top: 1.45rem;
}
.landing-feature-band article {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: .85rem;
    align-items: start;
    min-width: 0;
    border: 1px solid rgba(148, 163, 184, .28);
    border-radius: 1rem;
    background: rgba(255, 255, 255, .68);
    padding: .95rem;
    backdrop-filter: blur(18px);
    transition: border-color .22s ease, box-shadow .22s ease, transform .22s ease;
}
.landing-feature-band article.is-active {
    border-color: rgba(14, 116, 144, .32);
    box-shadow: 0 16px 36px rgba(14, 116, 144, .12);
    transform: translateY(-2px);
}
.landing-feature-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    border: 1px solid rgba(14, 116, 144, .18);
    border-radius: .75rem;
    background: #ecfeff;
    color: #0e7490;
    font-size: .92rem;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .04), 0 0 28px rgba(34, 211, 238, .12);
}
.landing-feature-band strong {
    display: block;
    color: #0f172a;
    font-size: 1rem;
    font-weight: 950;
}
.landing-feature-band p {
    margin-top: .35rem;
    color: #64748b;
    font-size: .9rem;
    font-weight: 650;
    line-height: 1.55;
}
.landing-console-preview {
    display: grid;
    justify-items: center;
}
.landing-preview-phone {
    position: relative;
    width: min(100%, 18rem);
    overflow: hidden;
    border: 1px solid rgba(148, 163, 184, .28);
    border-radius: 1.6rem;
    background: rgba(255, 255, 255, .76);
    padding: 1rem;
    box-shadow: 0 28px 70px rgba(15, 23, 42, .12), 0 0 40px rgba(34, 211, 238, .14);
}
.landing-preview-phone::before {
    content: "";
    position: absolute;
    inset: auto 1.2rem 1.2rem;
    height: 5rem;
    border-radius: 999px;
    background: rgba(34, 211, 238, .2);
    filter: blur(32px);
}
.landing-preview-scan {
    position: absolute;
    right: 1rem;
    left: 1rem;
    top: 1rem;
    z-index: 2;
    height: 2.8rem;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(34, 211, 238, 0), rgba(34, 211, 238, .34), rgba(34, 211, 238, 0));
    opacity: 0;
    pointer-events: none;
    transform: translateY(1.5rem);
}
.landing-preview-top,
.landing-preview-status,
.landing-preview-qr,
.landing-preview-menu {
    position: relative;
    z-index: 1;
}
.landing-preview-top {
    display: flex;
    gap: .35rem;
    margin-bottom: 1rem;
}
.landing-preview-top span {
    width: .45rem;
    height: .45rem;
    border-radius: 999px;
    background: rgba(100, 116, 139, .32);
}
.landing-preview-status {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    border: 1px solid rgba(148, 163, 184, .28);
    border-radius: 1rem;
    background: rgba(248, 250, 252, .82);
    padding: .8rem;
}
.landing-preview-status span {
    color: #64748b;
    font-size: .72rem;
    font-weight: 900;
    text-transform: uppercase;
}
.landing-preview-status strong {
    border-radius: 999px;
    background: rgba(34, 197, 94, .16);
    padding: .25rem .55rem;
    color: #86efac;
    font-size: .72rem;
    font-weight: 950;
    transition: box-shadow .22s ease, transform .22s ease;
}
.landing-preview-status strong.is-pulsing {
    box-shadow: 0 0 0 .3rem rgba(34, 197, 94, .1), 0 0 24px rgba(34, 197, 94, .28);
    transform: translateY(-1px);
}
.landing-preview-qr {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: .35rem;
    width: 8.5rem;
    margin: 1.1rem auto;
    border-radius: 1rem;
    background: #0f172a;
    padding: .75rem;
}
.landing-preview-qr span {
    aspect-ratio: 1;
    border-radius: .2rem;
    background: #fff;
}
.landing-preview-qr span:nth-child(2),
.landing-preview-qr span:nth-child(5),
.landing-preview-qr span:nth-child(7),
.landing-preview-qr span:nth-child(10),
.landing-preview-qr span:nth-child(12),
.landing-preview-qr span:nth-child(15) {
    opacity: .2;
}
.landing-preview-menu {
    display: grid;
    gap: .45rem;
}
.landing-preview-menu span {
    height: .72rem;
    border-radius: 999px;
    background: rgba(100, 116, 139, .16);
}
.landing-preview-menu span:nth-child(1) { width: 88%; }
.landing-preview-menu span:nth-child(2) { width: 66%; }
.landing-preview-menu span:nth-child(3) { width: 78%; }
.landing-steps {
    width: min(100%, 76rem);
    margin: 0 auto;
    padding: clamp(4.75rem, 8vw, 6.5rem) clamp(1rem, 3vw, 1.5rem) 0;
}
.landing-steps-head {
    display: grid;
    gap: .7rem;
    max-width: 44rem;
}
.landing-steps-head span {
    color: #b45309;
    font-size: .8rem;
    font-weight: 950;
    letter-spacing: .12em;
    text-transform: uppercase;
}
.landing-steps-head h2 {
    color: #0f172a;
    font-size: clamp(1.8rem, 3vw, 2.65rem);
    font-weight: 950;
    line-height: 1.08;
}
.landing-step-grid {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1rem, 3vw, 2rem);
    margin-top: 2rem;
}
.landing-step-grid::before {
    content: "";
    position: absolute;
    top: 1rem;
    right: 11%;
    left: 11%;
    height: 1px;
    background: linear-gradient(90deg, rgba(180, 83, 9, .2), rgba(34, 211, 238, .8), rgba(180, 83, 9, .2));
}
.landing-step-progress {
    position: absolute;
    top: 1rem;
    right: 11%;
    left: 11%;
    height: 1px;
    background: linear-gradient(90deg, rgba(245, 158, 11, .35), rgba(14, 116, 144, .95), rgba(245, 158, 11, .35));
    transform: scaleX(0);
    transform-origin: left center;
}
.landing-step-grid article {
    position: relative;
    display: grid;
    align-content: start;
    min-width: 0;
    padding-top: 3.1rem;
    transition: transform .22s ease;
}
.landing-step-grid article.is-active {
    transform: translateY(-3px);
}
.landing-step-grid article > span {
    position: absolute;
    top: 0;
    left: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 999px;
    border: 1px solid rgba(103, 232, 249, .48);
    background: #0f172a;
    color: #fff;
    font-size: .9rem;
    font-weight: 950;
    box-shadow: 0 0 0 .4rem #f8fafc, 0 0 24px rgba(34, 211, 238, .3);
    transition: background .22s ease, border-color .22s ease, box-shadow .22s ease, color .22s ease;
}
.landing-step-grid article.is-active > span {
    border-color: rgba(14, 116, 144, .55);
    background: #0e7490;
    box-shadow: 0 0 0 .4rem #f8fafc, 0 0 34px rgba(34, 211, 238, .42);
}
.landing-step-grid strong {
    display: block;
    color: #0f172a;
    font-size: 1.05rem;
    font-weight: 950;
}
.landing-step-grid p {
    max-width: 21rem;
    margin-top: .55rem;
    color: #64748b;
    font-size: .92rem;
    font-weight: 650;
    line-height: 1.6;
}
.landing-quote-section {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, .78fr) minmax(0, 1.22fr);
    gap: clamp(1.25rem, 4vw, 3rem);
    width: min(100%, 76rem);
    margin: 0 auto;
    padding: clamp(4rem, 8vw, 6rem) clamp(1rem, 3vw, 1.5rem);
}
.landing-faq-section {
    display: grid;
    grid-template-columns: minmax(0, .75fr) minmax(0, 1.25fr);
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: start;
}
.landing-faq-head {
    display: grid;
    gap: .8rem;
}
.landing-faq-list {
    display: grid;
    gap: .85rem;
}
.landing-section-heading {
    align-self: start;
    position: sticky;
    top: 6rem;
    overflow: hidden;
    border: 1px solid rgba(148, 163, 184, .22);
    border-radius: 1.25rem;
    background:
        radial-gradient(circle at top right, rgba(34, 211, 238, .16), transparent 14rem),
        radial-gradient(circle at bottom left, rgba(245, 158, 11, .1), transparent 12rem),
        rgba(255, 255, 255, .78);
    padding: clamp(1.15rem, 3vw, 1.6rem);
    box-shadow: 0 24px 70px rgba(15, 23, 42, .09);
}
.landing-section-heading::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(15, 23, 42, .045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(15, 23, 42, .045) 1px, transparent 1px);
    background-size: 2.2rem 2.2rem;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, .75), transparent);
    pointer-events: none;
}
.landing-section-heading > * {
    position: relative;
    z-index: 1;
}
.landing-section-heading span {
    color: #0e7490;
    font-size: .8rem;
    font-weight: 950;
    letter-spacing: .12em;
    text-transform: uppercase;
}
.landing-section-heading h2 {
    margin-top: .8rem;
    color: #0f172a;
    font-size: clamp(2rem, 4vw, 3.4rem);
    font-weight: 950;
    line-height: 1;
}
.landing-section-heading p {
    margin-top: 1rem;
    color: #64748b;
    font-size: 1rem;
    font-weight: 650;
    line-height: 1.7;
}
.landing-quote-points {
    display: grid;
    gap: .6rem;
    margin-top: 1.25rem;
}
.landing-quote-points span {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    color: #334155;
    font-size: .92rem;
    font-weight: 850;
}
.landing-quote-points i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.65rem;
    height: 1.65rem;
    border-radius: 999px;
    background: #ecfeff;
    color: #0e7490;
    font-size: .78rem;
}
.landing-quote-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    border: 1px solid #e2e8f0;
    border-radius: 1.2rem;
    background: #fff;
    padding: clamp(1rem, 3vw, 1.5rem);
    box-shadow: 0 24px 70px rgba(15, 23, 42, .08);
}
.landing-form-wide,
.landing-form-actions {
    grid-column: 1 / -1;
}
.landing-quote-form textarea.input {
    min-height: 9rem;
    resize: vertical;
}
.landing-form-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-top: 1px solid #e2e8f0;
    padding-top: 1rem;
}
.landing-form-actions p {
    color: #64748b;
    font-size: .85rem;
    font-weight: 700;
}
.landing-honeypot {
    position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}
.landing-footer {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.5rem;
    width: min(100%, 76rem);
    margin: 0 auto;
    border-top: 1px solid #e2e8f0;
    padding: 1.5rem clamp(1rem, 3vw, 1.5rem) 2rem;
}
.landing-footer > div {
    display: grid;
    gap: .75rem;
    min-width: 0;
}
.landing-footer p {
    color: #64748b;
    font-size: .88rem;
    font-weight: 700;
}
.landing-footer small {
    color: #94a3b8;
    font-size: .8rem;
    font-weight: 700;
}
.landing-footer nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .7rem 1rem;
}
.landing-footer nav a {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    color: #334155;
    font-size: .86rem;
    font-weight: 850;
}
.landing-footer nav a:hover {
    color: #0f172a;
    text-decoration: underline;
    text-underline-offset: .2em;
}
@media (max-width: 900px) {
    .landing-nav {
        align-items: flex-start;
        padding: .85rem 1rem;
    }
    .landing-nav nav {
        gap: .45rem;
    }
    .landing-nav-link {
        display: none;
    }
    .landing-hero {
        min-height: 600px;
        padding-top: 7rem;
    }
    .landing-hero::before {
        background: linear-gradient(180deg, rgba(15, 23, 42, .7), rgba(15, 23, 42, .5));
    }
    .landing-feature-band {
        grid-template-columns: minmax(0, 1fr);
        margin-top: -1.5rem;
    }
    .landing-seo-section,
    .landing-faq-section {
        grid-template-columns: minmax(0, 1fr);
    }
    .landing-console-preview {
        justify-items: stretch;
    }
    .landing-preview-phone {
        width: 100%;
    }
    .landing-step-grid {
        grid-template-columns: minmax(0, 1fr);
        gap: 1.15rem;
    }
    .landing-step-grid::before {
        top: .15rem;
        bottom: .15rem;
        left: 1.05rem;
        width: 1px;
        height: auto;
        background: linear-gradient(180deg, rgba(180, 83, 9, .2), rgba(34, 211, 238, .8), rgba(180, 83, 9, .2));
    }
    .landing-step-progress {
        top: .15rem;
        bottom: .15rem;
        left: 1.05rem;
        width: 1px;
        height: auto;
        right: auto;
        transform: scaleY(0);
        transform-origin: top center;
        background: linear-gradient(180deg, rgba(245, 158, 11, .35), rgba(14, 116, 144, .95), rgba(245, 158, 11, .35));
    }
    .landing-step-grid article {
        padding: 0 0 0 3.55rem;
    }
    .landing-step-grid article > span {
        left: 0;
    }
    .landing-quote-section {
        grid-template-columns: minmax(0, 1fr);
        padding-top: 3.5rem;
    }
    .landing-section-heading {
        position: static;
    }
    .landing-footer {
        flex-direction: column;
    }
    .landing-footer nav {
        justify-content: flex-start;
    }
}
@media (max-width: 640px) {
    .landing-nav .brand-lockup em {
        display: none;
    }
    .landing-nav .btn-secondary {
        padding: .55rem .72rem;
        font-size: .78rem;
    }
    .landing-hero-actions,
    .landing-form-actions {
        align-items: stretch;
        flex-direction: column;
    }
    .landing-proof-row span {
        flex: 1 1 calc(50% - .55rem);
        justify-content: center;
    }
    .landing-hero-actions .btn-primary,
    .landing-hero-actions .btn-secondary,
    .landing-form-actions .btn-primary {
        width: 100%;
    }
    .landing-quote-form {
        grid-template-columns: minmax(0, 1fr);
    }
    .landing-seo-grid {
        grid-template-columns: minmax(0, 1fr);
    }
}
.card { border-radius: .85rem; border: 1px solid #e2e8f0; background: #fff; box-shadow: 0 18px 60px rgba(15, 23, 42, .06); }
.badge { display: inline-flex; align-items: center; gap: .35rem; border-radius: 999px; padding: .25rem .55rem; font-size: .75rem; font-weight: 800; }
.password-field {
    position: relative;
}
.password-field .input {
    padding-right: 3rem;
}
.password-toggle {
    position: absolute;
    top: 50%;
    right: .55rem;
    display: grid;
    width: 2.1rem;
    height: 2.1rem;
    place-items: center;
    border-radius: .65rem;
    color: #64748b;
    transform: translateY(-50%);
    transition: background .15s ease, color .15s ease;
}
.password-toggle:hover {
    background: #f1f5f9;
    color: #0f172a;
}
.modal-backdrop { position: fixed; inset: 0; z-index: 60; display: none; align-items: center; justify-content: center; background: rgba(15, 23, 42, .56); padding: 1rem; }
.modal-backdrop.is-open { display: flex; }
.modal-panel { width: min(920px, 100%); max-height: 92vh; overflow: auto; border-radius: 1rem; background: #fff; box-shadow: 0 24px 80px rgba(0, 0, 0, .25); }
.confirm-modal-backdrop {
    z-index: 90;
}
.confirm-modal-panel {
    display: grid;
    position: relative;
    width: min(440px, 100%);
    gap: 1rem;
    overflow: visible;
    padding: 1.3rem;
    text-align: center;
}
.confirm-modal-close {
    position: absolute;
    top: .75rem;
    right: .75rem;
}
.confirm-modal-icon {
    display: grid;
    width: 3rem;
    height: 3rem;
    place-items: center;
    justify-self: center;
    border-radius: 999px;
    background: #fee2e2;
    color: #991b1b;
    font-size: 1.15rem;
}
.confirm-modal-copy h3 {
    color: #0f172a;
    font-size: 1.05rem;
    font-weight: 950;
}
.confirm-modal-copy p {
    margin-top: .35rem;
    color: #64748b;
    font-size: .9rem;
    font-weight: 650;
    line-height: 1.45;
}
.confirm-modal-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .65rem;
}
.confirm-modal-actions .btn-secondary,
.confirm-modal-actions .btn-danger {
    min-width: 8.5rem;
}
.modal-close-button {
    display: inline-grid;
    width: 2.45rem;
    height: 2.45rem;
    flex: none;
    place-items: center;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 999px;
    background: rgba(255, 255, 255, .92);
    color: #475569;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .08);
    transition: transform .16s ease, color .16s ease, background .16s ease, box-shadow .16s ease;
}
.modal-close-button:hover {
    transform: translateY(-1px);
    background: #0f172a;
    color: #fff;
    box-shadow: 0 18px 36px rgba(15, 23, 42, .18);
}
.modal-close-button svg {
    width: 1.1rem;
    height: 1.1rem;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.35;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.menu-item-modal-panel {
    width: min(1040px, 100%);
    padding: 0 !important;
}
.menu-item-modal-head {
    position: sticky;
    top: 0;
    z-index: 2;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid #e2e8f0;
    background: rgba(255, 255, 255, .96);
    padding: 1.2rem;
    backdrop-filter: blur(14px);
}
.menu-item-form {
    display: grid;
    gap: 1rem;
    padding: 1rem;
}
.menu-form-section {
    display: grid;
    gap: 1rem;
    border: 1px solid #e2e8f0;
    border-radius: .95rem;
    background: #fff;
    padding: 1rem;
}
.menu-form-section-title {
    display: flex;
    min-width: 0;
    gap: .75rem;
    align-items: flex-start;
}
.menu-form-section-title > span {
    display: inline-grid;
    width: 2rem;
    height: 2rem;
    flex: none;
    place-items: center;
    border-radius: .7rem;
    background: #0f172a;
    color: #fff;
    font-size: .82rem;
    font-weight: 950;
}
.menu-form-section-title h4 {
    color: #0f172a;
    font-size: .98rem;
    font-weight: 950;
}
.menu-form-section-title p {
    margin-top: .12rem;
    color: #64748b;
    font-size: .8rem;
    font-weight: 700;
    line-height: 1.4;
}
.menu-form-grid {
    display: grid;
    gap: .9rem;
}
.menu-form-wide {
    min-width: 0;
}
.menu-check-grid {
    display: grid;
    gap: .55rem;
    max-height: 13rem;
    overflow: auto;
    border-radius: .85rem;
    background: #f8fafc;
    padding: .8rem;
}
.menu-check-grid label:not(.menu-switch) {
    display: flex;
    align-items: center;
    gap: .45rem;
    min-width: 0;
    color: #334155;
    font-weight: 750;
}
.menu-switch {
    display: grid;
    grid-template-columns: 2.55rem minmax(0, 1fr);
    align-items: center;
    gap: .65rem;
    min-width: 0;
    border: 1px solid transparent;
    border-radius: .75rem;
    padding: .32rem .38rem;
    color: #334155;
    font-size: .88rem;
    font-weight: 800;
    line-height: 1.25;
    cursor: pointer;
    transition: background .16s ease, border-color .16s ease, color .16s ease;
}
.menu-switch:hover {
    border-color: #e2e8f0;
    background: #fff;
}
.menu-switch input {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}
.menu-switch-control {
    position: relative;
    display: block;
    width: 2.45rem;
    height: 1.36rem;
    border-radius: 999px;
    background: #cbd5e1;
    box-shadow: inset 0 0 0 1px rgba(15, 23, 42, .05);
    transition: background .18s ease, box-shadow .18s ease;
}
.menu-switch-control::after {
    content: "";
    position: absolute;
    top: .18rem;
    left: .2rem;
    width: 1rem;
    height: 1rem;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 2px 6px rgba(15, 23, 42, .2);
    transition: transform .18s ease;
}
.menu-switch input:checked + .menu-switch-control {
    background: #0f172a;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .12);
}
.menu-switch input:checked + .menu-switch-control::after {
    transform: translateX(1.04rem);
}
.menu-switch:has(input:checked) {
    border-color: #cbd5e1;
    background: #fff;
    color: #0f172a;
}
.menu-switch input:focus-visible + .menu-switch-control {
    outline: 2px solid #0f172a;
    outline-offset: 2px;
}
.menu-switch-text {
    min-width: 0;
    overflow-wrap: anywhere;
}
.menu-switch-row {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
    min-width: 0;
}
.menu-switch-inline {
    grid-template-columns: 2.55rem auto;
    border-color: #e2e8f0;
    background: #f8fafc;
    padding: .5rem .65rem;
}
.menu-unavailable-until-field {
    display: grid;
    min-width: min(100%, 17rem);
    gap: .3rem;
    color: #64748b;
    font-size: .75rem;
    font-weight: 900;
}
.menu-unavailable-until-field .input {
    min-height: 2.55rem;
}
.menu-form-footer {
    position: sticky;
    bottom: 0;
    z-index: 2;
    border-top: 1px solid #e2e8f0;
    background: rgba(255, 255, 255, .96);
    padding: 1rem;
    backdrop-filter: blur(14px);
}
.availability-modal-panel {
    width: min(640px, 100%);
    padding: 0 !important;
}
.availability-modal-body {
    display: grid;
    gap: 1rem;
    padding: 1rem;
}
.availability-shortcut-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(8.5rem, 1fr));
    gap: .55rem;
}
.availability-shortcut-grid button {
    min-height: 2.65rem;
    border: 1px solid #e2e8f0;
    border-radius: .75rem;
    background: #f8fafc;
    color: #334155;
    font-size: .83rem;
    font-weight: 900;
    transition: border-color .16s ease, background .16s ease, color .16s ease, transform .16s ease;
}
.availability-shortcut-grid button:hover,
.availability-shortcut-grid button.is-active {
    transform: translateY(-1px);
    border-color: #0f172a;
    background: #0f172a;
    color: #fff;
}
.availability-date-field span {
    color: #64748b;
    font-size: .86rem;
    font-weight: 700;
    line-height: 1.45;
}
.availability-date-field {
    display: grid;
    gap: .45rem;
}
.availability-modal-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .6rem;
}
.availability-modal-actions .btn-secondary,
.availability-modal-actions .btn-primary {
    min-width: 9rem;
}
.hours-editor {
    display: grid;
    gap: 1rem;
}
.hours-preview-card {
    border: 1px solid #e2e8f0;
    border-radius: .9rem;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    padding: 1rem;
}
.hours-preview-card > span {
    display: block;
    margin-bottom: .75rem;
    color: #64748b;
    font-size: .75rem;
    font-weight: 900;
    letter-spacing: .05em;
    text-transform: uppercase;
}
.hours-preview-list {
    display: grid;
    gap: .55rem;
}
.hours-preview-line,
.pm-hours-line {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    border-radius: .75rem;
    background: rgba(248, 250, 252, .95);
    padding: .72rem .82rem;
}
.hours-preview-line strong,
.pm-hours-line strong {
    min-width: 0;
    color: #0f172a;
    font-size: .88rem;
    font-weight: 850;
}
.hours-preview-line em,
.pm-hours-line em {
    flex: none;
    color: #64748b;
    font-size: .82rem;
    font-style: normal;
    font-weight: 800;
    text-align: right;
}
.address-autocomplete {
    position: relative;
}
.address-suggestions {
    position: absolute;
    right: 0;
    left: 0;
    z-index: 30;
    display: none;
    margin-top: .45rem;
    overflow: hidden;
    border: 1px solid #e2e8f0;
    border-radius: .9rem;
    background: #fff;
    box-shadow: 0 18px 45px rgba(15, 23, 42, .12);
}
.address-suggestions.is-open {
    display: grid;
}
.address-suggestions button {
    display: grid;
    gap: .1rem;
    padding: .78rem .95rem;
    text-align: left;
}
.address-suggestions button + button {
    border-top: 1px solid #f1f5f9;
}
.address-suggestions button:hover {
    background: #f8fafc;
}
.address-suggestions strong {
    color: #0f172a;
    font-size: .9rem;
    font-weight: 850;
}
.address-suggestions span {
    color: #64748b;
    font-size: .78rem;
    font-weight: 700;
}
.qr-page {
    display: grid;
    gap: 1.1rem;
}
.qr-page-intro {
    display: grid;
    gap: .35rem;
}
.qr-page-intro h2 {
    color: #0f172a;
    font-size: clamp(1.75rem, 6vw, 2.7rem);
    font-weight: 950;
    line-height: 1;
}
.qr-page-intro p {
    max-width: 42rem;
    color: #64748b;
    font-size: .95rem;
    font-weight: 700;
    line-height: 1.55;
}
.qr-page-grid {
    display: grid;
    gap: 1rem;
}
.qr-print-sheet {
    display: grid;
    place-items: center;
}
.qr-print-card {
    aspect-ratio: 1 / 1;
    width: min(100%, 380px);
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1.1rem;
    border: 1px solid #e2e8f0;
    border-radius: 1.25rem;
    background: #fff;
    padding: 1.15rem;
    color: #0f172a;
    box-shadow: 0 22px 70px rgba(15, 23, 42, .08);
}
.qr-print-card:not(:first-child) {
    display: none;
}
.qr-card-logo {
    display: grid;
    min-height: 4.7rem;
    place-items: center;
}
.qr-card-logo img {
    max-width: min(13rem, 76%);
    max-height: 4.7rem;
    object-fit: contain;
}
.qr-card-logo strong {
    max-width: 14rem;
    overflow: hidden;
    color: #0f172a;
    font-size: 1.5rem;
    font-weight: 950;
    line-height: 1.05;
    text-align: center;
    text-overflow: ellipsis;
}
.qr-print-card .qr-print-image {
    width: 68%;
    max-width: 17rem;
    border-radius: .75rem;
    background: #fff;
}
.qr-code-wrap {
    position: relative;
    display: grid;
    place-items: center;
}
.qr-card-text,
.qr-card-url,
.qr-center-logo {
    display: none;
}
.qr-format-logo-centre {
    gap: .75rem;
}
.qr-format-grand-logo {
    gap: .9rem;
}
.qr-format-grand-logo .qr-card-logo {
    min-height: 6.4rem;
}
.qr-format-grand-logo .qr-card-logo img {
    max-width: min(17rem, 86%);
    max-height: 6.4rem;
}
.qr-format-grand-logo .qr-card-logo strong {
    max-width: 17rem;
    font-size: 1.85rem;
}
.qr-format-grand-logo .qr-print-image {
    width: 58%;
    max-width: 14.5rem;
}
.qr-format-logo-centre .qr-card-logo {
    display: none;
}
.qr-format-logo-centre .qr-print-image {
    width: 72%;
    max-width: 17rem;
}
.qr-format-logo-centre .qr-center-logo {
    position: absolute;
    left: 50%;
    top: 50%;
    display: grid;
    width: 6.1rem;
    height: 6.1rem;
    place-items: center;
    padding: .82rem;
    transform: translate(-50%, -50%);
    border: 1px solid #e2e8f0;
    border-radius: 1.2rem;
    background: #fff;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .12);
}
.qr-format-logo-centre .qr-center-logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}
.qr-format-logo-centre .qr-center-logo span {
    color: #0f172a;
    font-size: 1.4rem;
    font-weight: 950;
}
.qr-format-carre-logo-dessus {
    gap: .9rem;
}
.qr-format-carre-logo-dessus .qr-card-logo {
    min-height: 6rem;
}
.qr-format-carre-logo-dessus .qr-card-logo img {
    max-width: min(18rem, 90%);
    max-height: 6rem;
}
.qr-format-carre-logo-dessus .qr-card-logo strong {
    max-width: 18rem;
    font-size: 1.7rem;
}
.qr-format-carre-logo-dessus .qr-print-image {
    width: 66%;
    max-width: 16rem;
}
.qr-format-carre-grand-logo {
    gap: .75rem;
}
.qr-format-carre-grand-logo .qr-card-logo {
    min-height: 7rem;
}
.qr-format-carre-grand-logo .qr-card-logo img {
    max-width: min(19rem, 92%);
    max-height: 7rem;
}
.qr-format-carre-grand-logo .qr-card-logo strong {
    max-width: 19rem;
    font-size: 1.95rem;
}
.qr-format-carre-grand-logo .qr-print-image {
    width: 58%;
    max-width: 14.5rem;
}
.qr-format-carre-logo-centre .qr-card-logo {
    display: none;
}
.qr-format-carre-logo-centre .qr-print-image {
    width: 82%;
    max-width: 19rem;
}
.qr-format-carre-logo-centre .qr-center-logo {
    position: absolute;
    left: 50%;
    top: 50%;
    display: grid;
    width: 7rem;
    height: 7rem;
    place-items: center;
    padding: .95rem;
    transform: translate(-50%, -50%);
    border: 1px solid #e2e8f0;
    border-radius: 1.35rem;
    background: #fff;
    box-shadow: 0 14px 32px rgba(15, 23, 42, .14);
}
.qr-format-carre-logo-centre .qr-center-logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}
.qr-format-carre-logo-centre .qr-center-logo span {
    color: #0f172a;
    font-size: 1.7rem;
    font-weight: 950;
}
.qr-format-invitation {
    gap: .7rem;
    padding: 1rem;
}
.qr-format-invitation .qr-card-logo {
    min-height: 3.25rem;
}
.qr-format-invitation .qr-card-logo img {
    max-height: 3.25rem;
}
.qr-format-invitation .qr-card-logo strong {
    font-size: 1.15rem;
}
.qr-format-invitation .qr-card-text {
    display: grid;
    max-width: 17rem;
    gap: .2rem;
    text-align: center;
}
.qr-format-invitation .qr-card-text span {
    color: #64748b;
    font-size: .72rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}
.qr-format-invitation .qr-card-text strong {
    color: #0f172a;
    font-size: clamp(1.1rem, 4vw, 1.45rem);
    font-weight: 950;
    line-height: 1.05;
}
.qr-format-invitation .qr-card-text small {
    color: #64748b;
    font-size: .8rem;
    font-weight: 800;
}
.qr-format-invitation .qr-print-image {
    width: 48%;
    max-width: 12.5rem;
}
.qr-format-minimal {
    gap: .85rem;
    border-style: solid;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .06);
}
.qr-format-minimal .qr-card-logo {
    min-height: 2.6rem;
}
.qr-format-minimal .qr-card-logo img {
    max-height: 2.6rem;
}
.qr-format-minimal .qr-card-logo strong {
    max-width: 15rem;
    font-size: 1rem;
}
.qr-format-minimal .qr-print-image {
    width: 76%;
    max-width: 18rem;
}
.qr-format-minimal .qr-card-url {
    display: block;
    max-width: 17rem;
    overflow: hidden;
    color: #64748b;
    font-size: .72rem;
    font-weight: 800;
    text-align: center;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.qr-print-actions {
    display: grid;
    gap: .6rem;
    margin-top: 1rem;
}
.qr-print-only {
    display: none;
}
.qr-print-frame {
    position: fixed;
    right: 0;
    bottom: 0;
    width: 0;
    height: 0;
    border: 0;
    opacity: 0;
    pointer-events: none;
}
.qr-side-panel {
    align-self: start;
}
.qr-format-picker {
    display: grid;
    gap: .9rem;
    margin-top: 1rem;
}
.qr-format-group {
    display: grid;
    gap: .45rem;
}
.qr-format-group > p {
    color: #64748b;
    font-size: .72rem;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.qr-format-options {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .55rem;
}
.qr-format-option {
    min-height: 3rem;
    border: 1px solid #e2e8f0;
    border-radius: .75rem;
    background: #fff;
    color: #334155;
    font-size: .86rem;
    font-weight: 900;
    text-align: center;
    transition: .16s ease;
}
.qr-format-option:hover {
    border-color: #94a3b8;
    color: #0f172a;
}
.qr-format-option.is-active {
    border-color: #0f172a;
    background: #0f172a;
    color: #fff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, .18);
}
.qr-format-note {
    margin-top: 1rem;
    color: #64748b;
    font-size: .85rem;
    font-weight: 700;
    line-height: 1.45;
}
.qr-side-panel .pro-url-pill {
    margin-top: 1rem;
}
.menu-scroll::-webkit-scrollbar { display: none; }
.fade-up { animation: fadeUp .35s ease both; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }

.public-menu-app {
    min-height: 100vh;
    background:
        radial-gradient(circle at top left, rgba(154, 106, 56, .16), transparent 28rem),
        linear-gradient(180deg, #fafaf9 0%, #f5f5f4 58%, #ffffff 100%);
    color: #0f172a;
    font-family: "Plus Jakarta Sans", Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-feature-settings: "ss01" 1, "ss02" 1, "cv01" 1;
    padding-bottom: 1.5rem;
}
.public-menu-app button,
.public-menu-app a { touch-action: manipulation; }
.public-menu-topbar {
    position: sticky;
    top: 0;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    padding: .62rem max(1rem, calc((100vw - 72rem) / 2 + 1rem));
    border-bottom: 1px solid rgba(214, 211, 209, .76);
    background: rgba(250, 250, 249, .86);
    backdrop-filter: blur(18px);
}
.pm-brand {
    display: flex;
    min-width: 0;
    align-items: center;
    color: inherit;
    text-decoration: none;
}
.pm-brand span {
    display: grid;
    min-width: 0;
}
.pm-brand strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #1c1917;
    font-size: clamp(1rem, 3.6vw, 1.25rem);
    font-weight: 700;
    letter-spacing: -.015em;
    line-height: 1;
}
.pm-icon-btn {
    display: grid;
    width: 2.35rem;
    height: 2.35rem;
    place-items: center;
    border-radius: .85rem;
    background: #fff;
    box-shadow: 0 10px 30px rgba(15, 23, 42, .08);
}
.pm-icon-btn svg {
    width: 1.25rem;
    height: 1.25rem;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
}
.pm-full-menu {
    position: fixed;
    inset: 0;
    z-index: 90;
    display: none;
    width: 100vw;
    height: 100dvh;
    background: #fff;
}
.pm-full-menu.is-open {
    display: block;
}
.pm-full-menu-backdrop {
    display: none;
}
.pm-full-menu-panel {
    position: fixed;
    inset: 0;
    display: flex;
    flex-direction: column;
    width: 100vw;
    min-height: 100dvh;
    gap: 1.25rem;
    overflow: auto;
    background:
        radial-gradient(circle at top right, rgba(41, 37, 36, .08), transparent 22rem),
        linear-gradient(180deg, #ffffff 0%, #fafaf9 100%),
        #fff;
    padding: 1rem;
    animation: pmMenuIn .2s ease both;
}
.pm-full-menu-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}
.pm-full-menu-head span,
.pm-full-menu-categories > span {
    display: block;
    color: #78716c;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.pm-full-menu-head strong {
    display: block;
    margin-top: .25rem;
    color: #1c1917;
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2.4rem, 13vw, 5.5rem);
    font-weight: 600;
    letter-spacing: -.035em;
    line-height: .86;
}
.pm-full-menu-close {
    display: grid;
    width: 2.65rem;
    height: 2.65rem;
    flex: none;
    place-items: center;
    border-radius: 999px;
    background: #1c1917;
    color: #fff;
}
.pm-full-menu-close svg {
    width: 1.1rem;
    height: 1.1rem;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2.4;
}
.pm-full-menu-main {
    display: grid;
    gap: .65rem;
    margin-top: auto;
}
.pm-full-menu-main button {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: .15rem .85rem;
    border: 1px solid #e7e5e4;
    border-radius: 1.05rem;
    background: #fafaf9;
    padding: 1rem;
    text-align: left;
}
.pm-full-menu-main button span {
    grid-row: span 2;
    color: #a8a29e;
    font-size: .75rem;
    font-weight: 700;
}
.pm-full-menu-main button strong {
    color: #1c1917;
    font-size: clamp(1.45rem, 8vw, 2.5rem);
    font-weight: 700;
    letter-spacing: -.045em;
    line-height: 1;
}
.pm-full-menu-main button em {
    color: #78716c;
    font-size: .84rem;
    font-style: normal;
    font-weight: 500;
    line-height: 1.45;
}
.pm-full-menu-categories {
    display: grid;
    gap: .75rem;
}
.pm-full-menu-categories > div {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.pm-full-menu-categories button {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    border: 1px solid #e7e5e4;
    border-radius: 999px;
    background: #fff;
    padding: .62rem .78rem;
    color: #292524;
    font-size: .84rem;
    font-weight: 700;
    box-shadow: 0 10px 26px rgba(15, 23, 42, .05);
}
.pm-full-menu-categories button em {
    display: grid;
    min-width: 1.35rem;
    height: 1.35rem;
    place-items: center;
    border-radius: 999px;
    background: #1c1917;
    color: #fff;
    font-size: .68rem;
    font-style: normal;
}
.pm-menu-lock {
    overflow: hidden;
}
.pm-hero {
    position: relative;
    display: grid;
    min-height: min(74vh, 44rem);
    overflow: hidden;
    background: #0f172a;
}
.pm-hero-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.pm-hero-shade {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(15, 23, 42, .18), rgba(15, 23, 42, .72) 48%, rgba(15, 23, 42, .96));
}
.pm-hero-content {
    position: relative;
    display: flex;
    width: min(100%, 72rem);
    margin: 0 auto;
    flex-direction: column;
    justify-content: end;
    padding: 7rem 1rem 2rem;
    color: #fff;
}
.pm-live-pill {
    width: fit-content;
    border-radius: 999px;
    background: rgba(255, 255, 255, .16);
    padding: .42rem .72rem;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    backdrop-filter: blur(12px);
}
.pm-hero h1 {
    margin-top: .85rem;
    max-width: 48rem;
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(3rem, 13vw, 6.8rem);
    font-weight: 600;
    letter-spacing: -.035em;
    line-height: .86;
}
.pm-hero p {
    margin-top: 1rem;
    max-width: 40rem;
    color: rgba(255, 255, 255, .86);
    font-size: clamp(.96rem, 2vw, 1.12rem);
    font-weight: 500;
    line-height: 1.65;
}
.pm-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
    margin-top: 1.25rem;
}
.pm-hero-actions a,
.pm-hero-actions button {
    border-radius: 999px;
    background: #fff;
    color: #0f172a;
    padding: .78rem 1rem;
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: -.01em;
}
.pm-hero-actions a:not(:first-child),
.pm-hero-actions button:not(:first-child) {
    background: rgba(255, 255, 255, .14);
    color: #fff;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .22);
}
.public-menu-app .pm-attention-pulse {
    animation: pmAttentionPulse 1.9s ease-in-out infinite;
    transform-origin: center;
    will-change: transform;
}
.pm-info-panel,
.pm-gallery-wrap,
.pm-category-launcher,
.pm-menu-workspace {
    width: min(100%, 72rem);
    margin: 0 auto;
    padding-inline: 1rem;
}
.pm-info-panel {
    display: grid;
    gap: .75rem;
    margin-top: 1rem;
    position: relative;
    z-index: 3;
}
.pm-info-panel > div {
    border: 1px solid #e7e5e4;
    border-radius: 1.1rem;
    background: #fff;
    padding: 1.05rem;
    box-shadow: 0 22px 60px rgba(15, 23, 42, .11);
}
.pm-info-panel span {
    cursor: pointer;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--pm-brand);
}
.pm-info-panel p {
    margin-top: .45rem;
    color: #57534e;
    font-size: .88rem;
    font-weight: 500;
    line-height: 1.55;
}
.pm-hours-card {
    display: grid;
    gap: .65rem;
}
.pm-hours-list {
    display: grid;
    gap: .32rem;
}
.pm-hours-line {
    border: 1px solid #f1f5f9;
    border-radius: .8rem;
    background: #f8fafc;
    padding: .62rem .72rem;
}
.pm-hours-line + .pm-hours-line {
    border-top: 1px solid #f1f5f9;
}
.pm-hours-line strong {
    color: #292524;
    font-size: .82rem;
    font-weight: 650;
}
.pm-hours-line em {
    color: #57534e;
    font-size: .78rem;
    font-weight: 600;
}
.pm-map-card {
    overflow: hidden;
    padding: 0 !important;
}
.pm-map-frame {
    position: relative;
    overflow: hidden;
    background: #f8fafc;
}
.pm-map-frame::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    height: 1.8rem;
    background: linear-gradient(180deg, rgba(248, 250, 252, 0), #f8fafc 72%);
    pointer-events: none;
}
.pm-map-frame iframe {
    display: block;
    width: 100%;
    height: 11.5rem;
    margin: -.35rem 0 -1.2rem;
    border: 0;
    filter: saturate(.92) contrast(.96) grayscale(.08);
    pointer-events: none;
}
.pm-map-card > div:not(.pm-map-frame) {
    padding: 1rem 1.05rem 1.05rem;
}
.pm-gallery-wrap {
    position: relative;
    z-index: 3;
    margin-top: -1.1rem;
}
.pm-gallery-wrap + .pm-info-panel-hours {
    margin-top: .95rem;
}
.pm-hero + .pm-info-panel-hours {
    margin-top: -1.1rem;
}
.pm-info-panel-hours + .pm-category-launcher,
.pm-gallery-wrap + .pm-category-launcher {
    margin-top: 1.75rem;
}
.pm-hero + .pm-category-launcher {
    margin-top: 1.4rem;
}
.pm-info-panel-map {
    margin-top: 1.6rem;
}
.pm-gallery .swiper-slide {
    overflow: hidden;
    border-radius: 1.15rem;
    background: #e7e5e4;
}
.pm-gallery img {
    width: 100%;
    height: 11rem;
    object-fit: cover;
}
.pm-category-launcher {
    position: sticky;
    top: 3.65rem;
    z-index: 35;
    padding-top: .85rem;
    padding-bottom: .6rem;
    scroll-margin-top: 4.2rem;
}
.pm-category-launcher::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: rgba(250, 250, 249, .96);
    border-bottom: 1px solid rgba(231, 229, 228, .86);
    box-shadow: 0 18px 34px rgba(15, 23, 42, .06);
    backdrop-filter: blur(16px);
}
.pm-section-heading {
    margin: 0;
}
.pm-section-heading span,
.pm-page-head span {
    display: block;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--pm-brand);
}
.pm-section-heading h2,
.pm-page-head h2 {
    margin-top: .25rem;
    font-size: clamp(1.45rem, 4vw, 2.15rem);
    font-weight: 700;
    letter-spacing: -.035em;
    line-height: 1.02;
}
.pm-category-grid {
    display: flex;
    gap: .5rem;
    margin: .62rem -1rem 0;
    overflow-x: auto;
    padding: 0 1rem .18rem;
    scrollbar-width: none;
}
.pm-category-grid::-webkit-scrollbar {
    display: none;
}
.pm-category-card {
    display: inline-flex;
    min-width: max-content;
    align-items: center;
    gap: .55rem;
    border: 1px solid rgba(214, 211, 209, .88);
    border-radius: 999px;
    background: #fff;
    padding: .62rem .82rem;
    text-align: left;
    box-shadow: 0 10px 26px rgba(15, 23, 42, .05);
    transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.pm-category-card.is-active {
    border-color: #1c1917;
    background: #1c1917;
    color: #fff;
}
.pm-category-card em {
    color: var(--pm-brand);
    font-size: .68rem;
    font-style: normal;
    font-weight: 700;
    opacity: .88;
}
.pm-category-card strong {
    display: inline;
    font-size: .86rem;
    font-weight: 700;
    letter-spacing: -.012em;
    line-height: 1;
    white-space: nowrap;
}
.pm-category-card.is-active em { color: #f5d0a3; }
.pm-menu-workspace {
    padding-top: 1rem;
}
.pm-subcategory-nav {
    display: none;
    margin-top: .45rem;
}
.pm-subcategory-nav.is-active {
    display: flex;
}
.pm-subcategory-stack {
    display: grid;
    gap: 1.2rem;
}
.pm-subcategory-section {
    scroll-margin-top: 8.8rem;
}
.pm-subcategory-head {
    display: flex;
    align-items: flex-start;
    margin-bottom: .8rem;
    padding-top: .15rem;
}
.pm-subcategory-head h3 {
    color: #1c1917;
    font-size: 1.05rem;
    font-weight: 800;
}
.pm-subcategory-head p {
    margin-top: .25rem;
    color: #78716c;
    font-size: .83rem;
    font-weight: 500;
    line-height: 1.4;
}
.pm-menu-swiper {
    margin-top: .8rem;
    overflow: visible;
}
.pm-category-page {
    min-height: 28rem;
}
.pm-page-head {
    display: flex;
    align-items: flex-start;
    gap: .85rem;
    margin-bottom: 1rem;
}
.pm-page-head p {
    margin-top: .35rem;
    color: #78716c;
    font-size: .88rem;
    font-weight: 500;
    line-height: 1.45;
}
.pm-items-list {
    display: grid;
    gap: .85rem;
}
.pm-item-card {
    display: grid;
    border: 1px solid rgba(214, 211, 209, .9);
    border-radius: 1.15rem;
    background: rgba(255, 255, 255, .94);
    padding: .95rem;
    cursor: pointer;
    transition: transform .16s ease, opacity .16s ease;
}
.pm-item-card:active { transform: scale(.985); }
.pm-item-card.is-unavailable {
    opacity: .58;
    filter: grayscale(.45);
}
.pm-item-main { min-width: 0; }
.pm-item-title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: .75rem;
}
.pm-item-title-row h3 {
    min-width: 0;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -.02em;
    line-height: 1.2;
}
.pm-price {
    flex: none;
    text-align: right;
}
.pm-price del {
    display: block;
    color: #a8a29e;
    font-size: .72rem;
    font-weight: 500;
}
.pm-price strong {
    color: var(--pm-brand);
    font-size: .95rem;
    font-weight: 800;
    letter-spacing: -.025em;
}
.pm-item-main p {
    display: -webkit-box;
    margin-top: .35rem;
    overflow: hidden;
    color: #6b7280;
    font-size: .82rem;
    font-weight: 500;
    line-height: 1.42;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}
.pm-mini-badges,
.pm-detail-badges {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    margin-top: .55rem;
}
.pm-mini-badges span,
.pm-tag,
.pm-allergen {
    border-radius: 999px;
    background: #f5f5f4;
    padding: .28rem .5rem;
    color: #57534e;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: -.005em;
}
.pm-tag {
    color: var(--tag-color, #57534e);
}
.pm-allergen {
    background: #fffbeb;
    color: #92400e;
}
.pm-empty-global {
    display: none;
    border: 1px dashed #d6d3d1;
    border-radius: 1rem;
    background: #fff;
    padding: 1.25rem;
    text-align: center;
    color: #78716c;
}
.pm-empty-global {
    display: block;
}
.pm-empty-global strong {
    display: block;
    color: #0f172a;
    font-size: 1rem;
    font-weight: 700;
}
.pm-pager {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .75rem;
    margin-top: 1rem;
}
.pm-pager button {
    border-radius: 999px;
    background: #fff;
    padding: .75rem 1rem;
    color: #1c1917;
    font-size: .85rem;
    font-weight: 700;
    box-shadow: 0 12px 30px rgba(15, 23, 42, .06);
}
.pm-public-footer {
    display: grid;
    gap: 1rem;
    width: min(100%, 72rem);
    margin: 2.4rem auto 0;
    padding: 1.15rem 1rem 0;
}
.pm-public-footer > div {
    display: grid;
    gap: .25rem;
    border-top: 1px solid #e7e5e4;
    padding-top: 1.1rem;
}
.pm-public-footer strong {
    color: #1c1917;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -.02em;
}
.pm-public-footer span {
    color: #78716c;
    font-size: .78rem;
    font-weight: 600;
}
.pm-public-footer nav {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.pm-public-footer a,
.pm-public-footer button {
    border: 1px solid #e7e5e4;
    border-radius: 999px;
    background: #fff;
    padding: .62rem .78rem;
    color: #292524;
    font-size: .8rem;
    font-weight: 700;
}
.pm-public-footer .pm-credit-link {
    border: 0;
    border-radius: 0;
    background: transparent;
    padding: 0;
    color: inherit;
    font-size: inherit;
    font-weight: 800;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: .16em;
}
.pm-public-footer .pm-credit-link:hover {
    color: #1c1917;
}
.pm-reservation-sheet {
    position: fixed;
    inset: 0;
    z-index: 88;
    display: none;
    padding: 1rem;
}
.pm-reservation-sheet.is-open {
    display: grid;
    place-items: center;
}
.pm-reservation-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, .64);
    backdrop-filter: blur(10px);
}
.pm-reservation-panel {
    position: relative;
    width: min(94vw, 34rem);
    max-height: 90vh;
    overflow: auto;
    border-radius: 1.35rem;
    background: #fff;
    padding: 1.15rem;
    color: #1c1917;
    box-shadow: 0 26px 80px rgba(15, 23, 42, .32);
    animation: pmPromoIn .22s ease both;
}
.pm-reservation-close {
    position: absolute;
    top: .85rem;
    right: .85rem;
    display: grid;
    width: 2.35rem;
    height: 2.35rem;
    place-items: center;
    border-radius: 999px;
    background: #f5f5f4;
    color: #292524;
}
.pm-reservation-close svg {
    width: 1.05rem;
    height: 1.05rem;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2.35;
}
.pm-reservation-kicker {
    display: block;
    color: var(--pm-brand);
    font-size: .72rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}
.pm-reservation-panel h2 {
    margin-top: .4rem;
    padding-right: 2.6rem;
    color: #1c1917;
    font-family: "Cormorant Garamond", serif;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
}
.pm-reservation-panel > p,
.pm-reservation-success p {
    margin-top: .65rem;
    color: #57534e;
    font-size: .9rem;
    font-weight: 600;
    line-height: 1.55;
}
.pm-reservation-form {
    margin-top: 1rem;
}
.pm-booking-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    overflow: hidden;
    border: 1px solid #d6d3d1;
    border-radius: 999px;
    background: #fff;
}
.pm-booking-summary button {
    display: inline-flex;
    min-width: 0;
    align-items: center;
    justify-content: center;
    gap: .35rem;
    border-right: 1px solid #d6d3d1;
    padding: .72rem .45rem;
    color: #292524;
    font-size: .78rem;
    font-weight: 850;
}
.pm-booking-summary button:last-child {
    border-right: 0;
}
.pm-booking-summary button.is-active {
    background: #e7ded5;
}
.pm-booking-summary span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.pm-booking-stage {
    display: none;
    margin-top: .95rem;
}
.pm-booking-stage.is-active {
    display: block;
}
.pm-booking-month-head {
    display: grid;
    grid-template-columns: 2.4rem 1fr 2.4rem;
    align-items: center;
    gap: .5rem;
    margin-bottom: .75rem;
}
.pm-booking-month-head strong {
    text-align: center;
    color: #1c1917;
    font-size: 1.04rem;
    font-weight: 900;
}
.pm-booking-month-head button {
    display: grid;
    width: 2.4rem;
    height: 2.4rem;
    place-items: center;
    border-radius: 999px;
    color: #292524;
}
.pm-booking-month-head button:disabled {
    color: #d6d3d1;
}
.pm-booking-weekdays,
.pm-booking-calendar {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: .28rem;
}
.pm-booking-calendar {
    touch-action: pan-y;
}
.pm-booking-weekdays {
    margin-bottom: .35rem;
    color: #78716c;
    font-size: .62rem;
    font-weight: 950;
    text-align: center;
    text-transform: uppercase;
}
.pm-booking-day,
.pm-booking-day-spacer {
    min-height: 2.85rem;
    border-radius: .45rem;
}
.pm-booking-day {
    border: 1px solid #e7e5e4;
    background: #fff;
    color: #1c1917;
    font-size: .94rem;
    font-weight: 850;
}
.pm-booking-day strong {
    font-weight: 850;
}
.pm-booking-day.is-today {
    border-color: #a8a29e;
}
.pm-booking-day.is-active {
    border-color: #b88b64;
    background: #fff8f1;
    color: #111827;
}
.pm-booking-day.is-disabled {
    background: #f1f1f1;
    color: #a8a29e;
}
.pm-booking-calendar > p,
.pm-booking-slots > p {
    grid-column: 1 / -1;
    margin: .7rem 0 0;
    color: #78716c;
    font-size: .86rem;
    font-weight: 800;
    text-align: center;
}
.pm-booking-party-grid,
.pm-booking-slot-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .5rem;
}
.pm-booking-party-grid button,
.pm-booking-slot-grid button {
    min-height: 3.2rem;
    border: 1px solid #e7e5e4;
    border-radius: .45rem;
    background: #fff;
    color: #1c1917;
    font-size: .95rem;
    font-weight: 850;
}
.pm-booking-party-grid button.is-active,
.pm-booking-slot-grid button.is-active {
    border-color: #b88b64;
    background: #fff8f1;
}
.pm-booking-custom-party {
    margin-top: .75rem;
}
.pm-booking-slot-group {
    display: grid;
    gap: .55rem;
    padding-top: .2rem;
}
.pm-booking-slot-group + .pm-booking-slot-group {
    margin-top: .9rem;
    border-top: 1px solid #e7e5e4;
    padding-top: .9rem;
}
.pm-booking-slot-group h3 {
    color: #57534e;
    font-size: .76rem;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.pm-booking-slot-grid button {
    display: grid;
    gap: .1rem;
    align-content: center;
    padding: .45rem;
}
.pm-booking-slot-grid button span {
    color: #78716c;
    font-size: .66rem;
    font-weight: 800;
}
.pm-reservation-grid {
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.pm-reservation-wide {
    grid-column: 1 / -1;
}
.pm-reservation-form label {
    display: block;
    margin-bottom: .35rem;
    color: #78716c;
    font-size: .72rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.pm-reservation-form input,
.pm-reservation-form select,
.pm-reservation-form textarea {
    width: 100%;
    border: 1px solid #d6d3d1;
    border-radius: .82rem;
    background: #fff;
    padding: .72rem .78rem;
    color: #1c1917;
    font-size: 16px;
    font-weight: 650;
    outline: none;
}
.pm-reservation-form input:focus,
.pm-reservation-form select:focus,
.pm-reservation-form textarea:focus {
    border-color: #292524;
    box-shadow: 0 0 0 4px rgba(41, 37, 36, .08);
}
.pm-reservation-hp {
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    opacity: 0 !important;
}
.pm-reservation-status {
    min-height: 1.2rem;
    margin-top: .75rem;
    color: #57534e;
    font-size: .82rem;
    font-weight: 850;
}
.pm-reservation-status.is-error {
    color: #b91c1c;
}
.pm-reservation-status.is-success {
    color: #047857;
}
.pm-reservation-submit,
.pm-reservation-success button {
    display: inline-flex;
    width: 100%;
    align-items: center;
    justify-content: center;
    border-radius: .9rem;
    background: #111827;
    padding: .82rem 1rem;
    color: #fff;
    font-size: .9rem;
    font-weight: 900;
}
.pm-reservation-submit:disabled {
    opacity: .6;
}
.pm-reservation-success {
    margin-top: 1rem;
    border: 1px solid #bbf7d0;
    border-radius: 1rem;
    background: #f0fdf4;
    padding: 1rem;
}
.pm-reservation-success strong {
    color: #166534;
    font-size: 1rem;
    font-weight: 950;
}
.pm-reservation-success button {
    margin-top: .9rem;
    background: #166534;
}
.pm-promo-popup {
    position: fixed;
    inset: 0;
    z-index: 85;
    display: none;
    padding: 1rem;
}
.pm-promo-popup.is-open {
    display: grid;
    place-items: center;
}
.pm-promo-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, .62);
    backdrop-filter: blur(10px);
}
.pm-promo-panel {
    position: relative;
    width: min(92vw, 30rem);
    max-height: 88vh;
    overflow: auto;
    border: 1px solid rgba(255, 255, 255, .76);
    border-radius: 1.55rem;
    background:
        radial-gradient(circle at top left, rgba(245, 158, 11, .16), transparent 36%),
        #fff;
    padding: 1.4rem;
    box-shadow: 0 28px 90px rgba(15, 23, 42, .28);
    animation: pmPromoIn .24s ease both;
}
.pm-promo-close {
    position: absolute;
    top: .85rem;
    right: .85rem;
    display: grid;
    width: 2.45rem;
    height: 2.45rem;
    place-items: center;
    border-radius: 999px;
    background: rgba(15, 23, 42, .08);
    color: #0f172a;
}
.pm-promo-close svg {
    width: 1.05rem;
    height: 1.05rem;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.35;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.pm-promo-kicker {
    display: inline-flex;
    margin-right: 2.6rem;
    border-radius: 999px;
    background: #fffbeb;
    padding: .38rem .65rem;
    color: #92400e;
    font-size: .72rem;
    font-weight: 850;
    letter-spacing: .1em;
    text-transform: uppercase;
}
.pm-promo-panel h2 {
    margin-top: 1rem;
    color: #0f172a;
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(2rem, 9vw, 3.1rem);
    font-weight: 700;
    letter-spacing: -.045em;
    line-height: .98;
}
.pm-promo-panel p {
    margin-top: .9rem;
    color: #57534e;
    font-size: .98rem;
    font-weight: 560;
    line-height: 1.7;
}
.pm-promo-action {
    display: inline-flex;
    margin-top: 1.15rem;
    border-radius: 999px;
    background: #0f172a;
    padding: .82rem 1.05rem;
    color: #fff;
    font-size: .88rem;
    font-weight: 850;
    text-decoration: none;
}
.pm-sheet {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: none;
}
.pm-sheet.is-open { display: block; }
.pm-sheet-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, .56);
}
.pm-sheet-panel {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    max-height: 88vh;
    overflow: auto;
    border-radius: 1.35rem 1.35rem 0 0;
    background: #fff;
    box-shadow: 0 -24px 70px rgba(15, 23, 42, .25);
    animation: pmSheetIn .22s ease both;
}
.pm-sheet-lock { overflow: hidden; }
.pm-sheet-handle {
    width: 3rem;
    height: .32rem;
    margin: .7rem auto .35rem;
    border-radius: 999px;
    background: #d6d3d1;
}
.pm-sheet-close {
    position: sticky;
    top: .55rem;
    z-index: 2;
    float: right;
    display: grid;
    width: 2.55rem;
    height: 2.55rem;
    place-items: center;
    margin-right: .8rem;
    border-radius: 999px;
    background: rgba(28, 25, 23, .9);
    color: #fff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, .22);
    backdrop-filter: blur(14px);
}
.pm-sheet-close svg {
    width: 1.12rem;
    height: 1.12rem;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.35;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.pm-detail-photo {
    width: 100%;
    height: min(45vh, 24rem);
    object-fit: cover;
}
.pm-detail-body {
    padding: 1rem 1rem 1.4rem;
}
.pm-detail-title {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}
.pm-detail-title span {
    color: var(--pm-brand);
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.pm-detail-title h3 {
    margin-top: .2rem;
    font-size: clamp(1.55rem, 7vw, 2.45rem);
    font-weight: 700;
    letter-spacing: -.04em;
    line-height: 1.02;
}
.pm-detail-description {
    margin-top: .9rem;
    color: #57534e;
    font-size: .95rem;
    font-weight: 500;
    line-height: 1.7;
}
.pm-detail-note,
.pm-unavailable-banner {
    margin-top: .8rem;
    border-radius: .9rem;
    background: #fffbeb;
    padding: .8rem;
    color: #92400e;
    font-size: .88rem;
    font-weight: 700;
}
.pm-detail-section {
    margin-top: 1.1rem;
}
.pm-detail-section h4 {
    margin-bottom: .5rem;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .13em;
    text-transform: uppercase;
    color: #78716c;
}
.pm-variant-line {
    display: flex;
    justify-content: space-between;
    gap: .75rem;
    border-radius: .85rem;
    background: #f5f5f4;
    padding: .78rem;
    color: #44403c;
    font-size: .9rem;
    font-weight: 500;
}
.pm-variant-line + .pm-variant-line {
    margin-top: .45rem;
}
@keyframes pmSheetIn {
    from { transform: translateY(26px); opacity: .65; }
    to { transform: translateY(0); opacity: 1; }
}
@keyframes pmMenuIn {
    from { opacity: .7; transform: scale(.985) translateY(8px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}
@keyframes pmPromoIn {
    from { opacity: 0; transform: translateY(18px) scale(.97); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes pmAttentionPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.055); }
}
@media (prefers-reduced-motion: reduce) {
    .public-menu-app .pm-attention-pulse {
        animation: none;
    }
}
.admin-shell,
.pro-shell {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: clip;
}
.admin-main,
.admin-content {
    width: 100%;
    max-width: 100%;
    min-width: 0;
}
.admin-main {
    overflow-x: hidden;
}
.admin-content {
    overflow-x: clip;
}
.admin-sidebar,
.pro-sidebar {
    width: 100%;
    max-width: 100vw;
}
.admin-topbar {
    width: 100%;
    max-width: 100%;
}
.admin-nav,
.pro-nav {
    max-width: 100%;
    scroll-padding-inline: 1rem;
}
.admin-nav {
    scrollbar-width: none;
}
.admin-nav::-webkit-scrollbar {
    display: none;
}
.admin-content .card,
.admin-content table {
    max-width: 100%;
}
.admin-content .overflow-x-auto {
    max-width: 100%;
    -webkit-overflow-scrolling: touch;
}
.admin-topbar h1,
.pro-topbar h1 {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.admin-mobile-card {
    display: grid;
    min-width: 0;
    gap: .8rem;
    border: 1px solid #e2e8f0;
    border-radius: .9rem;
    background: #fff;
    padding: .95rem;
}
.admin-mobile-card strong {
    display: block;
    overflow: hidden;
    color: #0f172a;
    font-size: .98rem;
    font-weight: 900;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.admin-mobile-card span {
    overflow-wrap: anywhere;
}
.admin-mobile-card > div > span:not(.badge) {
    display: block;
    margin-top: .18rem;
    color: #64748b;
    font-size: .78rem;
    font-weight: 750;
}
.admin-mobile-card-meta,
.admin-mobile-card-actions {
    display: flex;
    min-width: 0;
    flex-wrap: wrap;
    gap: .55rem;
    align-items: center;
}
.admin-mobile-card-actions .btn-primary,
.admin-mobile-card-actions .btn-secondary,
.admin-mobile-card-actions .btn-danger,
.admin-mobile-card-actions form {
    flex: 1 1 10rem;
}
.admin-mobile-card-actions button,
.admin-mobile-card-actions a {
    width: 100%;
}
.admin-reset-form {
    display: grid;
    flex: 1 1 100%;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: .5rem;
}
.pro-page-heading,
.menu-board-heading {
    display: grid;
    min-width: 0;
    gap: .8rem;
}
.pro-page-heading h2,
.menu-board-heading h2 {
    color: #0f172a;
    font-size: 1.22rem;
    font-weight: 950;
}
.pro-page-heading > .btn-primary,
.menu-board-heading > .btn-primary,
.pro-dashboard-actions .btn-primary,
.pro-dashboard-actions .btn-secondary,
.pro-dashboard-actions .icon-btn,
.qr-print-actions .btn-primary,
.qr-print-actions .btn-secondary,
.qr-print-actions .icon-btn {
    width: 100%;
}
.category-card-inner {
    display: grid;
    gap: 1rem;
}
.category-card-list {
    display: grid;
    gap: .8rem;
}
.category-group {
    display: grid;
    gap: .65rem;
}
.category-sub-list {
    display: grid;
    gap: .55rem;
    margin-left: 1rem;
    border-left: 2px solid #e2e8f0;
    padding-left: 1rem;
}
.category-sub-list:empty {
    display: none;
}
.category-card-list.is-saving-order,
.category-sub-list.is-saving-order {
    opacity: .72;
    pointer-events: none;
}
.category-sort-hint {
    display: flex;
    align-items: center;
    gap: .45rem;
    margin-bottom: .85rem;
    border: 1px dashed #cbd5e1;
    border-radius: .75rem;
    background: #f8fafc;
    padding: .72rem .85rem;
    color: #64748b;
    font-size: .82rem;
    font-weight: 850;
}
.category-card {
    transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.category-card-child {
    background: #f8fafc;
}
.category-card.is-drag-chosen,
.category-card:hover {
    border-color: #cbd5e1;
    box-shadow: 0 18px 42px rgba(15, 23, 42, .08);
}
.category-card.is-drag-ghost {
    opacity: .55;
}
.category-card.is-drag-fallback {
    box-shadow: 0 22px 56px rgba(15, 23, 42, .18);
    opacity: .98;
}
.category-card.is-dragging {
    transform: none;
}
.category-drag-handle {
    display: inline-grid;
    width: 2.25rem;
    height: 2.75rem;
    flex: none;
    place-items: center;
    border: 1px solid #e2e8f0;
    border-radius: .7rem;
    background: #f8fafc;
    color: #94a3b8;
    cursor: grab;
    touch-action: none;
}
.category-drag-handle:active {
    cursor: grabbing;
}
.category-drag-handle:hover,
.category-card.is-drag-chosen .category-drag-handle {
    border-color: #94a3b8;
    color: #0f172a;
}
.category-modal-panel {
    width: min(680px, 100%);
    padding: 0 !important;
}
.category-form {
    display: grid;
    gap: 1rem;
}
.category-card h3,
.allergen-card h3 {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.category-card p,
.allergen-card p {
    overflow-wrap: anywhere;
}
.category-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.category-card-actions .icon-btn {
    flex: 1 1 2.4rem;
}
.allergen-grid {
    display: grid;
    gap: .9rem;
}
.allergen-card {
    min-width: 0;
}
.reservation-online-switch {
    display: flex;
    align-items: center;
    gap: .75rem;
    border-radius: .95rem;
    background: #fff;
    padding: .85rem;
    color: #0f172a;
    font-size: .9rem;
    font-weight: 850;
}
.reservation-services-editor h4,
.reservation-create-panel h3,
.reservation-toolbar h3 {
    color: #0f172a;
    font-size: .98rem;
    font-weight: 950;
}
.reservation-services-editor p,
.reservation-create-panel p,
.reservation-toolbar p {
    margin-top: .15rem;
    color: #64748b;
    font-size: .82rem;
    font-weight: 700;
    line-height: 1.45;
}
.reservation-service-row {
    display: grid;
    gap: .6rem;
    align-items: center;
    border-top: 1px solid #e2e8f0;
    padding: .7rem 0;
}
.reservation-service-active {
    display: flex;
    min-width: 0;
    align-items: center;
    gap: .5rem;
    color: #0f172a;
    font-size: .82rem;
    font-weight: 900;
}
.reservation-tabs {
    display: inline-flex;
    gap: .35rem;
    border: 1px solid #e2e8f0;
    border-radius: .85rem;
    background: #fff;
    padding: .25rem;
}
.reservation-tabs a {
    border-radius: .65rem;
    padding: .55rem .8rem;
    color: #64748b;
    font-size: .86rem;
    font-weight: 900;
    text-decoration: none;
}
.reservation-tabs a.is-active {
    background: #0f172a;
    color: #fff;
}
.reservation-service-tabs {
    display: inline-flex;
    flex-wrap: wrap;
    gap: .35rem;
    align-items: center;
    border: 1px solid #e2e8f0;
    border-radius: .85rem;
    background: #fff;
    padding: .25rem;
}
.reservation-service-tabs a {
    border-radius: .65rem;
    padding: .55rem .78rem;
    color: #64748b;
    font-size: .84rem;
    font-weight: 900;
    text-decoration: none;
}
.reservation-service-tabs a.is-active {
    background: #0f172a;
    color: #fff;
}
[data-pro-reservations-app].is-loading {
    opacity: .72;
    pointer-events: none;
}
.reservation-ajax-feedback {
    margin-bottom: 1rem;
    border-radius: .9rem;
    padding: .8rem 1rem;
    font-size: .86rem;
    font-weight: 850;
}
.reservation-page-grid {
    display: grid;
    gap: 1rem;
}
.reservation-toolbar,
.reservation-filters {
    display: grid;
    gap: .8rem;
    border-bottom: 1px solid #e2e8f0;
    padding: 1rem;
}
.reservation-toolbar-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.reservation-planning,
.reservation-list {
    display: grid;
    gap: 1rem;
    padding: 1rem;
}
.reservation-day-group {
    display: grid;
    gap: .75rem;
}
.reservation-day-group > h3 {
    color: #0f172a;
    font-size: 1.05rem;
    font-weight: 950;
}
.reservation-slot-group {
    display: grid;
    gap: .65rem;
    border: 1px solid #e2e8f0;
    border-radius: .95rem;
    background: #f8fafc;
    padding: .75rem;
}
.reservation-slot-time {
    width: fit-content;
    border-radius: 999px;
    background: #0f172a;
    padding: .32rem .62rem;
    color: #fff;
    font-size: .76rem;
    font-weight: 950;
}
.reservation-slot-cards {
    display: grid;
    gap: .7rem;
}
.reservation-card {
    display: grid;
    gap: .85rem;
    border: 1px solid #e2e8f0;
    border-radius: .95rem;
    background: #fff;
    padding: .9rem;
    box-shadow: 0 14px 38px rgba(15, 23, 42, .05);
}
.reservation-card-head {
    display: flex;
    min-width: 0;
    align-items: flex-start;
    justify-content: space-between;
    gap: .75rem;
}
.reservation-card-head strong {
    display: block;
    color: #0f172a;
    font-size: .98rem;
    font-weight: 950;
}
.reservation-card-head span:not(.badge) {
    display: block;
    margin-top: .1rem;
    color: #64748b;
    font-size: .8rem;
    font-weight: 800;
}
.reservation-meta-grid {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    margin-top: .65rem;
}
.reservation-meta-grid span {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    border-radius: 999px;
    background: #f8fafc;
    padding: .32rem .55rem;
    color: #475569;
    font-size: .76rem;
    font-weight: 850;
}
.reservation-message {
    margin-top: .65rem;
    border-left: 3px solid #e2e8f0;
    padding-left: .75rem;
    color: #475569;
    font-size: .86rem;
    font-weight: 700;
    line-height: 1.5;
}
.reservation-card-actions,
.reservation-note-form {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.reservation-card-actions form,
.reservation-card-actions button {
    flex: 1 1 auto;
}
.reservation-note-form textarea {
    min-width: 0;
    flex: 1 1 12rem;
}
.reservation-stat-grid {
    grid-template-columns: repeat(auto-fit, minmax(10.5rem, 1fr));
}
.reservation-top-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: .8rem;
    margin-top: 1.5rem;
}
.reservation-legend {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-top: 1rem;
    color: #475569;
    font-size: .76rem;
    font-weight: 850;
}
.reservation-legend span {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    border: 1px solid #e2e8f0;
    border-radius: 999px;
    background: #fff;
    padding: .35rem .6rem;
}
.reservation-dot {
    display: inline-block;
    width: .58rem;
    height: .58rem;
    border-radius: 999px;
}
.reservation-status-badge {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: .34rem .58rem;
    font-size: .72rem;
    font-weight: 950;
    white-space: nowrap;
}
.reservation-status-pending {
    background: #fef3c7;
    color: #92400e;
}
.reservation-status-confirmed {
    background: #dbeafe;
    color: #1d4ed8;
}
.reservation-status-seated {
    background: #dcfce7;
    color: #166534;
}
.reservation-status-late {
    background: #fee2e2;
    color: #b91c1c;
}
.reservation-status-rejected {
    background: #ffe4e6;
    color: #be123c;
}
.reservation-status-cancelled {
    background: #f1f5f9;
    color: #64748b;
}
.reservation-status-no_show {
    background: #ffedd5;
    color: #c2410c;
}
.reservation-workspace {
    margin-top: 1rem;
}
.reservation-planning-compact,
.reservation-history-list {
    display: grid;
    gap: 1rem;
    padding: 1rem;
}
.reservation-day-compact {
    display: grid;
    gap: .75rem;
}
.reservation-day-compact > h3 {
    color: #0f172a;
    font-size: 1rem;
    font-weight: 950;
}
.reservation-service-block {
    display: grid;
    gap: .65rem;
    border: 1px solid #e2e8f0;
    border-left-width: 5px;
    border-radius: .95rem;
    background: #f8fafc;
    padding: .75rem;
}
.reservation-service-block + .reservation-service-block {
    margin-top: .25rem;
}
.reservation-service-midi {
    border-left-color: #0ea5e9;
}
.reservation-service-soir {
    border-left-color: #6366f1;
}
.reservation-service-block-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
}
.reservation-service-block-head strong {
    color: #0f172a;
    font-size: .88rem;
    font-weight: 950;
    text-transform: uppercase;
}
.reservation-service-block-head span {
    color: #64748b;
    font-size: .78rem;
    font-weight: 850;
}
.reservation-time-cluster {
    display: grid;
    grid-template-columns: 4rem minmax(0, 1fr);
    gap: .75rem;
    align-items: flex-start;
}
.reservation-time-label {
    position: sticky;
    top: 5rem;
    width: fit-content;
    border-radius: 999px;
    background: #0f172a;
    padding: .35rem .58rem;
    color: #fff;
    font-size: .74rem;
    font-weight: 950;
}
.reservation-row-stack {
    display: grid;
    gap: .5rem;
}
.reservation-row {
    display: grid;
    grid-template-columns: 4.3rem minmax(10rem, 1fr) minmax(9rem, auto) auto;
    gap: .75rem;
    align-items: center;
    width: 100%;
    border: 1px solid #e2e8f0;
    border-left: 5px solid #cbd5e1;
    border-radius: .85rem;
    background: #fff;
    padding: .7rem .8rem;
    text-align: left;
    box-shadow: 0 10px 28px rgba(15, 23, 42, .045);
    transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}
.reservation-row:hover {
    transform: translateY(-1px);
    border-color: #cbd5e1;
    box-shadow: 0 16px 36px rgba(15, 23, 42, .08);
}
.reservation-row.reservation-status-pending {
    border-left-color: #f59e0b;
}
.reservation-row.reservation-status-confirmed {
    border-left-color: #3b82f6;
}
.reservation-row.reservation-status-seated {
    border-left-color: #22c55e;
}
.reservation-row.reservation-status-late {
    border-left-color: #ef4444;
    background: #fff7f7;
}
.reservation-row.reservation-status-rejected {
    border-left-color: #f43f5e;
}
.reservation-row.reservation-status-cancelled {
    border-left-color: #94a3b8;
}
.reservation-row.reservation-status-no_show {
    border-left-color: #f97316;
}
.reservation-row-time {
    display: inline-flex;
    width: fit-content;
    border-radius: 999px;
    background: #0f172a;
    padding: .32rem .52rem;
    color: #fff;
    font-size: .75rem;
    font-weight: 950;
}
.reservation-row.is-late .reservation-row-time {
    animation: reservationPulse 1.05s ease-in-out infinite;
}
.reservation-time-cluster:has(.reservation-row.is-late) .reservation-time-label {
    animation: reservationPulse 1.05s ease-in-out infinite;
}
@keyframes reservationPulse {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(239, 68, 68, .42);
        background: #b91c1c;
    }
    50% {
        box-shadow: 0 0 0 .42rem rgba(239, 68, 68, 0);
        background: #ef4444;
    }
}
.reservation-row-main {
    min-width: 0;
}
.reservation-row-main strong {
    display: block;
    overflow: hidden;
    color: #0f172a;
    font-size: .92rem;
    font-weight: 950;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.reservation-row-main em {
    display: block;
    margin-top: .1rem;
    overflow: hidden;
    color: #64748b;
    font-size: .75rem;
    font-style: normal;
    font-weight: 800;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.reservation-row-meta {
    display: flex;
    min-width: 0;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .35rem;
}
.reservation-row-meta span {
    display: inline-flex;
    max-width: 16rem;
    min-width: 0;
    align-items: center;
    gap: .3rem;
    overflow: hidden;
    border-radius: 999px;
    background: #f8fafc;
    padding: .28rem .48rem;
    color: #475569;
    font-size: .7rem;
    font-weight: 850;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.reservation-create-modal,
.reservation-detail-modal {
    z-index: 78;
}
.reservation-create-panel-modal,
.reservation-detail-panel {
    width: min(96vw, 45rem);
    max-height: 90vh;
    overflow: auto;
    border-radius: 1.1rem;
    background: #fff;
    padding: 1.2rem;
    box-shadow: 0 26px 70px rgba(15, 23, 42, .24);
}
.reservation-create-panel-modal {
    padding: 0;
}
.reservation-detail-panel {
    width: min(96vw, 58rem);
    padding: 0;
}
.reservation-create-panel-modal form {
    padding: 1rem 1.2rem 1.2rem;
}
.reservation-modal-kicker {
    display: block;
    color: #64748b;
    font-size: .72rem;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.reservation-create-panel-modal h3,
.reservation-detail-head h3 {
    margin-top: .25rem;
    padding-right: 2.5rem;
    color: #0f172a;
    font-size: 1.35rem;
    font-weight: 950;
    line-height: 1.1;
}
.reservation-create-head h3 {
    padding-right: 0;
}
.reservation-create-steps {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    overflow: hidden;
    margin-top: 1rem;
    border: 1px solid #e2e8f0;
    border-radius: .95rem;
    background: #fff;
}
.reservation-create-steps button {
    display: inline-flex;
    min-width: 0;
    align-items: center;
    justify-content: center;
    gap: .35rem;
    border-right: 1px solid #e2e8f0;
    padding: .7rem .45rem;
    color: #64748b;
    font-size: .76rem;
    font-weight: 900;
}
.reservation-create-steps button:last-child {
    border-right: 0;
}
.reservation-create-steps button.is-active {
    background: #0f172a;
    color: #fff;
}
.reservation-create-steps span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.reservation-create-stage {
    display: none;
    margin-top: 1rem;
}
.reservation-create-stage.is-active {
    display: block;
}
.reservation-party-grid,
.reservation-create-slot-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .5rem;
}
.reservation-party-grid button,
.reservation-create-slot-grid button {
    min-height: 3rem;
    border: 1px solid #e2e8f0;
    border-radius: .7rem;
    background: #fff;
    color: #0f172a;
    font-size: .9rem;
    font-weight: 900;
}
.reservation-party-grid button.is-active,
.reservation-create-slot-grid button.is-active {
    border-color: #0f172a;
    background: #0f172a;
    color: #fff;
}
.reservation-create-slots > p {
    border: 1px dashed #cbd5e1;
    border-radius: .9rem;
    padding: 1rem;
    color: #64748b;
    font-size: .86rem;
    font-weight: 850;
    text-align: center;
}
.reservation-create-slot-group {
    display: grid;
    gap: .5rem;
}
.reservation-create-slot-group + .reservation-create-slot-group {
    margin-top: .9rem;
    border-top: 1px solid #e2e8f0;
    padding-top: .9rem;
}
.reservation-create-slot-group h4,
.reservation-detail-grid h4,
.reservation-events h4 {
    color: #475569;
    font-size: .76rem;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.reservation-create-slot-grid button {
    display: grid;
    gap: .1rem;
    align-content: center;
    padding: .45rem;
}
.reservation-create-slot-grid span {
    color: inherit;
    opacity: .72;
    font-size: .66rem;
    font-weight: 800;
}
.reservation-detail-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .8rem;
}
.reservation-detail-form-wide {
    grid-column: 1 / -1;
}
.reservation-detail-content {
    position: relative;
}
.reservation-detail-head {
    position: sticky;
    top: 0;
    z-index: 3;
    display: flex;
    min-width: 0;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid #e2e8f0;
    background: rgba(255, 255, 255, .96);
    padding: 1.2rem;
    backdrop-filter: blur(14px);
}
.reservation-detail-head-actions {
    display: flex;
    flex: none;
    align-items: center;
    justify-content: flex-end;
    gap: .6rem;
}
.reservation-detail-head > div:first-child {
    min-width: 0;
}
.reservation-detail-head h3 {
    overflow-wrap: anywhere;
    padding-right: 0;
}
.reservation-detail-content > .reservation-late-alert,
.reservation-detail-content > .reservation-detail-grid,
.reservation-detail-content > .reservation-detail-actions,
.reservation-detail-content > .reservation-detail-forms,
.reservation-detail-content > .reservation-events {
    margin-right: 1.2rem;
    margin-left: 1.2rem;
}
.reservation-detail-content > .reservation-events {
    margin-bottom: 1.2rem;
}
.reservation-detail-head p {
    margin-top: .25rem;
    color: #64748b;
    font-size: .86rem;
    font-weight: 800;
}
.reservation-late-alert {
    display: flex;
    align-items: center;
    gap: .55rem;
    margin-top: 1rem;
    border: 1px solid #fecaca;
    border-radius: .85rem;
    background: #fef2f2;
    padding: .75rem .85rem;
    color: #991b1b;
    font-size: .86rem;
    font-weight: 900;
}
.reservation-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}
.reservation-detail-grid section,
.reservation-detail-forms form,
.reservation-events {
    border: 1px solid #e2e8f0;
    border-radius: .95rem;
    background: #fff;
    padding: .9rem;
}
.reservation-detail-lines {
    display: grid;
    gap: .55rem;
    margin-top: .7rem;
}
.reservation-detail-lines p {
    display: flex;
    gap: .55rem;
    color: #334155;
    font-size: .86rem;
    font-weight: 750;
    line-height: 1.45;
}
.reservation-detail-lines i {
    width: 1rem;
    padding-top: .15rem;
    color: #64748b;
}
.reservation-detail-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-top: 1rem;
}
.reservation-detail-actions form,
.reservation-detail-actions button {
    flex: 1 1 auto;
}
.reservation-detail-forms {
    display: grid;
    grid-template-columns: minmax(0, .75fr) minmax(0, 1.25fr);
    gap: 1rem;
    margin-top: 1rem;
}
.reservation-inline-form {
    display: flex;
    gap: .5rem;
}
.reservation-inline-form .input {
    min-width: 0;
    flex: 1 1 auto;
}
.reservation-events {
    display: grid;
    gap: .65rem;
    margin-top: 1rem;
}
.reservation-events > p {
    color: #64748b;
    font-size: .86rem;
    font-weight: 800;
}
.reservation-events article {
    position: relative;
    border-left: 3px solid #e2e8f0;
    padding-left: .75rem;
}
.reservation-events article span {
    color: #0f172a;
    font-size: .82rem;
    font-weight: 950;
}
.reservation-events article strong,
.reservation-events article small {
    display: block;
    color: #64748b;
    font-size: .72rem;
    font-weight: 850;
}
.reservation-events article p,
.reservation-events article em {
    display: block;
    margin-top: .15rem;
    color: #475569;
    font-size: .78rem;
    font-style: normal;
    font-weight: 750;
}
.reservation-detail-loading {
    padding: 2rem;
    color: #64748b;
    font-size: .9rem;
    font-weight: 900;
    text-align: center;
}
.client-autocomplete-field {
    position: relative;
}
.client-suggestions {
    position: absolute;
    z-index: 90;
    top: calc(100% + .35rem);
    right: 0;
    left: 0;
    display: none;
    max-height: 15rem;
    overflow: auto;
    border: 1px solid #dbe3ef;
    border-radius: .85rem;
    background: #fff;
    padding: .35rem;
    box-shadow: 0 18px 44px rgba(15, 23, 42, .14);
}
.client-suggestions.is-open {
    display: grid;
    gap: .25rem;
}
.client-suggestions button {
    display: grid;
    gap: .12rem;
    width: 100%;
    border-radius: .62rem;
    padding: .55rem .6rem;
    color: #0f172a;
    text-align: left;
}
.client-suggestions button:hover {
    background: #f8fafc;
}
.client-suggestions strong {
    font-size: .84rem;
    font-weight: 950;
}
.client-suggestions span {
    overflow: hidden;
    color: #64748b;
    font-size: .72rem;
    font-weight: 800;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.client-autofill-summary {
    display: grid;
    gap: .3rem;
    border: 1px solid #dbeafe;
    border-radius: .85rem;
    background: #eff6ff;
    padding: .75rem;
    color: #1e3a8a;
    font-size: .8rem;
    font-weight: 850;
}
.client-autofill-summary[hidden] {
    display: none;
}
.client-autofill-summary strong {
    color: #0f172a;
    font-size: .9rem;
    font-weight: 950;
}
.client-autofill-summary em,
.client-autofill-summary p {
    color: #475569;
    font-style: normal;
}
.clients-layout {
    display: grid;
    grid-template-columns: minmax(17rem, .8fr) minmax(0, 1.45fr);
    gap: 1rem;
}
.clients-list-panel,
.clients-detail-panel {
    padding: 1rem;
}
.clients-search {
    display: flex;
    gap: .5rem;
}
.clients-search .input {
    min-width: 0;
}
.clients-list {
    display: grid;
    gap: .5rem;
    margin-top: 1rem;
}
.client-list-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: .45rem .75rem;
    border: 1px solid #e2e8f0;
    border-radius: .85rem;
    background: #fff;
    padding: .72rem;
    text-decoration: none;
}
.client-list-row:hover,
.client-list-row.is-active {
    border-color: #0f172a;
    background: #f8fafc;
}
.client-list-row strong {
    display: block;
    overflow: hidden;
    color: #0f172a;
    font-size: .9rem;
    font-weight: 950;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.client-list-row em,
.client-list-row small {
    color: #64748b;
    font-size: .74rem;
    font-style: normal;
    font-weight: 850;
}
.client-tags {
    display: flex;
    flex-wrap: wrap;
    gap: .3rem;
    grid-column: 1 / -1;
}
.client-tags b {
    border-radius: 999px;
    background: #eef2ff;
    padding: .22rem .48rem;
    color: #3730a3;
    font-size: .68rem;
    font-weight: 950;
}
.clients-detail-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid #e2e8f0;
    padding-bottom: 1rem;
}
.clients-detail-head span {
    color: #64748b;
    font-size: .72rem;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.clients-detail-head h3 {
    margin-top: .2rem;
    color: #0f172a;
    font-size: 1.35rem;
    font-weight: 950;
}
.client-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .65rem;
    margin-top: 1rem;
}
.client-stat-grid article {
    border: 1px solid #e2e8f0;
    border-radius: .85rem;
    background: #f8fafc;
    padding: .75rem;
}
.client-stat-grid span {
    display: block;
    color: #64748b;
    font-size: .7rem;
    font-weight: 900;
}
.client-stat-grid strong {
    display: block;
    margin-top: .2rem;
    color: #0f172a;
    font-size: .9rem;
    font-weight: 950;
}
.client-edit-form,
.client-history {
    margin-top: 1rem;
}
.client-history h4 {
    color: #475569;
    font-size: .76rem;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.client-history > p {
    margin-top: .7rem;
    color: #64748b;
    font-size: .86rem;
    font-weight: 850;
}
@media (max-width: 820px) {
    .reservation-time-cluster,
    .reservation-row,
    .reservation-detail-grid,
    .reservation-detail-forms,
    .reservation-detail-form-grid,
    .clients-layout,
    .client-stat-grid {
        grid-template-columns: 1fr;
    }
    .reservation-time-label {
        position: static;
    }
    .reservation-row-meta {
        justify-content: flex-start;
    }
    .reservation-row .reservation-status-badge {
        justify-self: flex-start;
    }
    .reservation-create-steps {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        border-radius: .85rem;
    }
    .reservation-create-steps button:nth-child(2) {
        border-right: 0;
    }
    .reservation-create-steps button:nth-child(-n+2) {
        border-bottom: 1px solid #e2e8f0;
    }
    .reservation-party-grid,
    .reservation-create-slot-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
@media (max-width: 520px) {
    .reservation-top-actions,
    .reservation-toolbar-actions,
    .reservation-detail-actions,
    .clients-detail-head,
    .clients-search {
        align-items: stretch;
        flex-direction: column;
    }
    .reservation-party-grid,
    .reservation-create-slot-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .reservation-inline-form {
        flex-direction: column;
    }
    .reservation-service-tabs {
        width: 100%;
    }
    .reservation-service-tabs a {
        flex: 1;
        text-align: center;
    }
}
.pro-settings-form {
    display: grid;
    gap: 1.1rem;
}
.pro-media-column {
    min-width: 0;
}
.settings-section-head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: .85rem;
    margin-bottom: 1rem;
}
.settings-section-head h3 {
    color: #0f172a;
    font-size: 1.05rem;
    font-weight: 950;
    letter-spacing: -.01em;
}
.settings-section-head p,
.settings-sub-panel p {
    margin-top: .18rem;
    max-width: 48rem;
    color: #64748b;
    font-size: .84rem;
    font-weight: 700;
    line-height: 1.45;
}
.settings-sub-panel {
    border: 1px solid #e2e8f0;
    border-radius: .9rem;
    background: #f8fafc;
    padding: 1rem;
}
.settings-sub-panel h4 {
    color: #0f172a;
    font-size: .9rem;
    font-weight: 950;
}
.reservation-rules-panel {
    border: 1px solid #e2e8f0;
    border-radius: .85rem;
    background: #f8fafc;
}
.reservation-rules-panel summary {
    display: flex;
    cursor: pointer;
    list-style: none;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    padding: .75rem .9rem;
    color: #0f172a;
    font-size: .86rem;
    font-weight: 950;
}
.reservation-rules-panel summary::-webkit-details-marker {
    display: none;
}
.reservation-rules-panel summary::after {
    content: "+";
    display: grid;
    width: 1.55rem;
    height: 1.55rem;
    place-items: center;
    border: 1px solid #e2e8f0;
    border-radius: 999px;
    background: #fff;
    color: #64748b;
}
.reservation-rules-panel[open] summary::after {
    content: "-";
}
.reservation-rules-panel summary em {
    margin-left: auto;
    color: #64748b;
    font-size: .78rem;
    font-style: normal;
    font-weight: 800;
}
.reservation-rules-grid {
    display: grid;
    gap: .7rem;
    border-top: 1px solid #e2e8f0;
    padding: .9rem;
}
.reservation-week-editor {
    display: grid;
    gap: .4rem;
}
.reservation-compact-head,
.reservation-compact-row {
    display: grid;
    grid-template-columns: minmax(7.5rem, .7fr) minmax(13rem, 1fr) minmax(13rem, 1fr) minmax(9rem, auto);
    gap: .55rem;
    align-items: stretch;
}
.reservation-compact-head {
    padding: 0 .55rem .25rem;
    color: #64748b;
    font-size: .72rem;
    font-weight: 950;
    text-transform: uppercase;
}
.weekly-day-card {
    min-width: 0;
    border: 1px solid #e2e8f0;
    border-radius: .85rem;
    background: #fff;
    padding: .55rem;
    transition: border-color .16s ease, box-shadow .16s ease, background .16s ease, opacity .16s ease;
}
.weekly-day-card.is-open {
    border-color: #bfdbfe;
    background: #fbfdff;
    box-shadow: 0 10px 24px rgba(15, 23, 42, .045);
}
.weekly-day-card.is-closed {
    background: #f8fafc;
}
.weekly-day-card.is-closed .reservation-compact-service {
    opacity: .55;
}
.weekly-day-head {
    display: grid;
    gap: .25rem;
    align-content: center;
}
.weekly-toggle,
.reservation-service-toggle {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    color: #0f172a;
    font-size: .84rem;
    font-weight: 950;
}
.weekly-toggle input,
.reservation-service-toggle input {
    width: 1rem;
    height: 1rem;
    accent-color: #0f172a;
}
.reservation-compact-day small {
    color: #64748b;
    font-size: .72rem;
    font-weight: 850;
}
.reservation-compact-service {
    display: grid;
    gap: .45rem;
    min-width: 0;
    border: 1px solid #e2e8f0;
    border-radius: .75rem;
    background: #f8fafc;
    padding: .45rem;
}
.reservation-compact-service.is-active {
    border-color: #bfdbfe;
    background: #fff;
}
.reservation-service-pill {
    justify-content: flex-start;
}
.reservation-service-pill span {
    line-height: 1;
}
.reservation-compact-fields {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 4.3rem;
    gap: .35rem;
}
.reservation-compact-fields label {
    display: grid;
    min-width: 0;
    gap: .18rem;
}
.reservation-compact-fields label span {
    color: #64748b;
    font-size: .66rem;
    font-weight: 900;
    text-transform: uppercase;
}
.reservation-compact-fields .input {
    min-height: 2.15rem;
    padding: .42rem .48rem;
    font-size: .82rem;
}
.weekly-card-actions {
    display: flex;
    flex-wrap: wrap;
    align-content: center;
    justify-content: flex-end;
    gap: .3rem;
}
.weekly-small-action {
    min-height: 1.95rem;
    border: 1px solid #e2e8f0;
    border-radius: .65rem;
    background: #fff;
    padding: .32rem .5rem;
    color: #475569;
    font-size: .7rem;
    font-weight: 900;
    transition: border-color .16s ease, background .16s ease, color .16s ease, transform .16s ease;
}
.weekly-small-action:hover {
    transform: translateY(-1px);
    border-color: #0f172a;
    background: #0f172a;
    color: #fff;
}
.form-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: stretch;
    gap: .75rem;
}
.form-actions .btn-primary,
.form-actions .btn-secondary,
.form-actions .btn-danger,
.form-actions > button,
.form-actions > a {
    width: 100%;
}
.form-actions-split {
    align-items: center;
    justify-content: space-between;
}
.form-actions-split > .flex,
.form-actions-split > .menu-switch-row {
    min-width: 0;
}
.menu-board-tools .input {
    min-width: 0;
}
.menu-category-head {
    flex-wrap: wrap;
}
.menu-category-head > div {
    min-width: 0;
}
.menu-category-head h3 {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.menu-management-card {
    min-width: 0;
}
.menu-management-actions {
    width: 100%;
}
.menu-management-actions .icon-btn,
.menu-management-actions .btn-secondary,
.menu-management-actions .btn-danger {
    flex: 1 1 2.4rem;
}
.modal-backdrop {
    overscroll-behavior: contain;
}
.modal-panel {
    max-width: 100%;
}
.qr-print-actions {
    margin-top: 1rem;
}
@media (max-width: 640px) {
    .admin-content {
        padding-inline: 1rem !important;
    }
    .admin-mobile-card-actions .btn-primary,
    .admin-mobile-card-actions .btn-secondary,
    .admin-mobile-card-actions .btn-danger,
    .admin-mobile-card-actions form {
        flex-basis: 100%;
        min-width: 0;
    }
    .admin-reset-form {
        grid-template-columns: minmax(0, 1fr);
    }
    .admin-reset-form .input {
        min-width: 0;
    }
    .admin-topbar .text-sm,
    .pro-topbar .text-xs {
        max-width: 72vw;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    .pro-dashboard-hero,
    .card.p-5,
    .card.p-6 {
        border-radius: .95rem;
    }
    .pro-stat-grid {
        grid-template-columns: 1fr;
    }
    .pro-menu-card,
    .menu-management-card {
        grid-template-columns: auto 4rem minmax(0, 1fr);
        gap: .72rem;
    }
    .pro-menu-card img,
    .pro-menu-card-placeholder,
    .menu-management-photo {
        width: 4rem;
        height: 4rem;
    }
    .menu-drag-handle {
        width: 2rem;
        height: 4rem;
    }
    .menu-switch-row {
        width: 100%;
    }
    .menu-switch-inline {
        flex: 1 1 100%;
    }
    .menu-management-body h4 {
        white-space: normal;
    }
    .menu-management-body strong {
        white-space: normal;
        text-align: right;
    }
    .hours-preview-line,
    .pm-hours-line {
        align-items: flex-start;
        flex-direction: column;
        gap: .25rem;
    }
    .hours-preview-line em,
    .pm-hours-line em {
        text-align: left;
    }
    .settings-section-head {
        align-items: stretch;
        flex-direction: column;
    }
    .reservation-rules-panel summary {
        flex-wrap: wrap;
    }
    .reservation-rules-panel summary span {
        flex: 1 1 auto;
    }
    .reservation-rules-panel summary em {
        order: 3;
        flex: 1 0 100%;
        margin-left: 0;
    }
    .reservation-compact-head {
        display: none;
    }
    .reservation-compact-row {
        grid-template-columns: minmax(0, 1fr);
    }
    .reservation-compact-day {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: .75rem;
    }
    .weekly-card-actions {
        justify-content: flex-start;
    }
    .reservation-compact-fields {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 4.5rem;
    }
    .modal-backdrop {
        align-items: flex-end;
        padding: .6rem;
    }
    .modal-panel {
        max-height: min(92vh, 760px);
        border-radius: 1rem 1rem .85rem .85rem;
        padding: 1rem !important;
    }
    .menu-item-modal-panel,
    .reservation-create-panel-modal,
    .reservation-detail-panel {
        padding: 0 !important;
    }
    .modal-panel .grid.sm\:grid-cols-2 {
        grid-template-columns: minmax(0, 1fr);
    }
    .pm-reservation-grid {
        grid-template-columns: minmax(0, 1fr);
    }
    .pm-booking-party-grid,
    .pm-booking-slot-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .admin-reset-form {
        grid-template-columns: minmax(0, 1fr);
    }
}
@media (min-width: 768px) {
    .pro-topbar {
        position: sticky;
        top: 0;
    }
    .pro-sidebar-head { padding: 1.25rem 1.25rem .95rem; }
    .pro-topbar-inner { min-height: 4.5rem; padding-inline: 1.75rem; }
    .pro-content { padding: 1.5rem; }
    .pro-dashboard-hero {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        padding: 1.4rem;
    }
    .pro-dashboard-actions {
        grid-template-columns: auto auto auto;
        align-items: center;
    }
    .pro-stat-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .pro-alert-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .pro-section-head {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        padding: 1.25rem;
    }
    .pro-recent-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .menu-form-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .menu-form-wide {
        grid-column: 1 / -1;
    }
    .menu-check-grid-compact {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .pro-page-heading,
    .menu-board-heading {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
    }
    .reservation-service-row {
        grid-template-columns: 7.5rem minmax(0, 1fr) 8rem 8rem 7rem;
    }
    .reservation-toolbar {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
    }
    .reservation-filters {
        grid-template-columns: minmax(0, 1fr) 10rem 12rem auto;
        align-items: end;
    }
    .reservation-page-grid {
        grid-template-columns: minmax(0, 1fr) 340px;
        align-items: start;
    }
    .pro-page-heading > .btn-primary,
    .menu-board-heading > .btn-primary,
    .pro-dashboard-actions .btn-primary,
    .pro-dashboard-actions .btn-secondary,
    .pro-dashboard-actions .icon-btn,
    .qr-print-actions .btn-primary,
    .qr-print-actions .btn-secondary,
    .qr-print-actions .icon-btn {
        width: auto;
    }
    .category-card-inner {
        grid-template-columns: auto minmax(0, 1fr) auto;
        align-items: center;
    }
    .allergen-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .form-actions {
        justify-content: flex-end;
    }
    .form-actions .btn-primary,
    .form-actions .btn-secondary,
    .form-actions .btn-danger,
    .form-actions > button,
    .form-actions > a {
        width: auto;
    }
    .menu-board-tools { grid-template-columns: minmax(0, 1fr) 14rem 13rem; }
    .menu-item-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .qr-page-grid { grid-template-columns: minmax(0, 420px) minmax(18rem, 1fr); align-items: start; }
    .hours-editor { grid-template-columns: minmax(0, 1.25fr) minmax(18rem, .75fr); }
    .reservation-rules-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
    .pro-settings-form { grid-template-columns: minmax(0, 1fr); }
    .restaurant-photo-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .pm-info-panel { grid-template-columns: minmax(0, 1fr); }
    .pm-full-menu-panel {
        padding: 1.25rem;
    }
    .pm-public-footer {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: end;
    }
    .pm-public-footer nav {
        justify-content: flex-end;
    }
    .pm-items-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .pm-sheet-panel {
        right: max(1.5rem, calc((100vw - 44rem) / 2));
        left: max(1.5rem, calc((100vw - 44rem) / 2));
        bottom: 1.5rem;
        border-radius: 1.35rem;
    }
}
@media (min-width: 1024px) {
    .pro-shell > main {
        width: calc(100% - 18rem);
    }
    .pro-sidebar {
        position: fixed;
        top: 0;
        border-bottom: 0;
    }
    .pro-sidebar-head {
        height: 5rem;
        padding: 1.5rem 1.35rem 1rem;
    }
    .pro-nav {
        display: grid;
        gap: .35rem;
        overflow: visible;
        padding: .5rem 1rem 1rem;
    }
    .pro-nav .nav-link {
        border-radius: .75rem;
        padding: .75rem .9rem;
        font-size: .93rem;
    }
    .pro-content { padding: 2rem; }
    .allergen-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .pro-settings-form { grid-template-columns: minmax(0, 1fr) 360px; align-items: start; }
}
@media (max-width: 420px) {
    .pm-price strong { font-size: .86rem; }
    .pm-booking-summary button { font-size: .7rem; }
    .pm-booking-party-grid,
    .pm-booking-slot-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media print {
    @page {
        size: A4 portrait;
        margin: 10mm;
    }
    *,
    *::before,
    *::after {
        box-sizing: border-box !important;
    }
    html,
    body {
        width: 190mm !important;
        min-height: 0 !important;
        margin: 0 !important;
        overflow: visible !important;
        background: #fff !important;
    }
    body * {
        visibility: hidden !important;
    }
    #qr-print-area,
    #qr-print-area * {
        visibility: visible !important;
    }
    .pro-shell,
    .pro-shell > main,
    .pro-content,
    .qr-page,
    .qr-page-grid,
    .qr-page-grid > .card {
        display: block !important;
        width: auto !important;
        min-width: 0 !important;
        max-width: none !important;
        min-height: 0 !important;
        height: auto !important;
        margin: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        box-shadow: none !important;
        background: transparent !important;
    }
    #qr-print-area {
        position: static !important;
        inset: auto !important;
        width: 190mm !important;
        height: 276mm !important;
        overflow: hidden !important;
        display: block !important;
        background: #fff !important;
    }
    .qr-print-sheet {
        visibility: visible !important;
        width: 190mm !important;
        height: 276mm !important;
        min-height: 0 !important;
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        grid-auto-rows: 85mm !important;
        gap: 5mm !important;
        align-content: start !important;
        justify-items: stretch !important;
        padding: 0 !important;
        margin: 0 !important;
    }
    .qr-print-card {
        display: flex !important;
        width: auto !important;
        height: 85mm !important;
        aspect-ratio: auto !important;
        box-shadow: none !important;
        border: 1px dashed #cbd5e1 !important;
        border-radius: 4mm !important;
        gap: 5mm !important;
        padding: 7mm !important;
        break-inside: avoid !important;
        page-break-inside: avoid !important;
    }
    .qr-card-logo {
        min-height: 18mm !important;
    }
    .qr-card-logo img {
        max-width: 43mm !important;
        max-height: 18mm !important;
    }
    .qr-card-logo strong {
        max-width: 44mm !important;
        font-size: 14pt !important;
    }
    .qr-print-card .qr-print-image {
        width: 43mm !important;
        max-width: 43mm !important;
        height: 43mm !important;
    }
    .qr-card-text,
    .qr-card-url,
    .qr-center-logo {
        display: none !important;
    }
    .qr-code-wrap {
        position: relative !important;
        display: grid !important;
        place-items: center !important;
    }
    .qr-format-logo-centre {
        gap: 2mm !important;
    }
    .qr-format-grand-logo {
        gap: 4mm !important;
    }
    .qr-format-grand-logo .qr-card-logo {
        min-height: 25mm !important;
    }
    .qr-format-grand-logo .qr-card-logo img {
        max-width: 52mm !important;
        max-height: 25mm !important;
    }
    .qr-format-grand-logo .qr-card-logo strong {
        max-width: 52mm !important;
        font-size: 18pt !important;
    }
    .qr-format-grand-logo .qr-print-image {
        width: 36mm !important;
        max-width: 36mm !important;
        height: 36mm !important;
    }
    .qr-format-logo-centre .qr-card-logo {
        display: none !important;
    }
    .qr-format-logo-centre .qr-print-image {
        width: 50mm !important;
        max-width: 50mm !important;
        height: 50mm !important;
    }
    .qr-format-logo-centre .qr-center-logo {
        position: absolute !important;
        inset: 50% auto auto 50% !important;
        display: grid !important;
        width: 19mm !important;
        height: 19mm !important;
        place-items: center !important;
        padding: 2.6mm !important;
        transform: translate(-50%, -50%) !important;
        border: 1px solid #e2e8f0 !important;
        border-radius: 4mm !important;
        background: #fff !important;
    }
    .qr-format-logo-centre .qr-center-logo img {
        max-width: 14mm !important;
        max-height: 14mm !important;
        object-fit: contain !important;
    }
    .qr-format-logo-centre .qr-center-logo span {
        font-size: 18pt !important;
        font-weight: 900 !important;
    }
    .qr-format-carre-logo-dessus {
        gap: 4mm !important;
        padding: 6mm !important;
    }
    .qr-format-carre-logo-dessus .qr-card-logo {
        min-height: 18mm !important;
    }
    .qr-format-carre-logo-dessus .qr-card-logo img {
        max-width: 62mm !important;
        max-height: 18mm !important;
    }
    .qr-format-carre-logo-dessus .qr-card-logo strong {
        max-width: 62mm !important;
        font-size: 16pt !important;
    }
    .qr-format-carre-logo-dessus .qr-print-image {
        width: 50mm !important;
        max-width: 50mm !important;
        height: 50mm !important;
    }
    .qr-format-carre-grand-logo {
        gap: 3mm !important;
        padding: 6mm !important;
    }
    .qr-format-carre-grand-logo .qr-card-logo {
        min-height: 25mm !important;
    }
    .qr-format-carre-grand-logo .qr-card-logo img {
        max-width: 66mm !important;
        max-height: 25mm !important;
    }
    .qr-format-carre-grand-logo .qr-card-logo strong {
        max-width: 66mm !important;
        font-size: 19pt !important;
    }
    .qr-format-carre-grand-logo .qr-print-image {
        width: 43mm !important;
        max-width: 43mm !important;
        height: 43mm !important;
    }
    .qr-format-carre-logo-centre {
        gap: 0 !important;
        padding: 6mm !important;
    }
    .qr-format-carre-logo-centre .qr-card-logo {
        display: none !important;
    }
    .qr-format-carre-logo-centre .qr-print-image {
        width: 62mm !important;
        max-width: 62mm !important;
        height: 62mm !important;
    }
    .qr-format-carre-logo-centre .qr-center-logo {
        position: absolute !important;
        inset: 50% auto auto 50% !important;
        display: grid !important;
        width: 23mm !important;
        height: 23mm !important;
        place-items: center !important;
        padding: 3mm !important;
        transform: translate(-50%, -50%) !important;
        border: 1px solid #e2e8f0 !important;
        border-radius: 5mm !important;
        background: #fff !important;
    }
    .qr-format-carre-logo-centre .qr-center-logo img {
        max-width: 17mm !important;
        max-height: 17mm !important;
        object-fit: contain !important;
    }
    .qr-format-carre-logo-centre .qr-center-logo span {
        font-size: 22pt !important;
        font-weight: 900 !important;
    }
    .qr-format-invitation {
        gap: 2.5mm !important;
        padding: 6mm !important;
    }
    .qr-format-invitation .qr-card-logo {
        min-height: 12mm !important;
    }
    .qr-format-invitation .qr-card-logo img {
        max-width: 34mm !important;
        max-height: 12mm !important;
    }
    .qr-format-invitation .qr-card-logo strong {
        font-size: 11pt !important;
    }
    .qr-format-invitation .qr-card-text {
        display: grid !important;
        max-width: 48mm !important;
        gap: 1mm !important;
        text-align: center !important;
    }
    .qr-format-invitation .qr-card-text span {
        color: #64748b !important;
        font-size: 7pt !important;
        font-weight: 800 !important;
        letter-spacing: .12em !important;
        text-transform: uppercase !important;
    }
    .qr-format-invitation .qr-card-text strong {
        font-size: 12pt !important;
        font-weight: 900 !important;
        line-height: 1.05 !important;
    }
    .qr-format-invitation .qr-card-text small {
        color: #64748b !important;
        font-size: 8pt !important;
        font-weight: 700 !important;
    }
    .qr-format-invitation .qr-print-image {
        width: 34mm !important;
        max-width: 34mm !important;
        height: 34mm !important;
    }
    .qr-format-minimal {
        gap: 3mm !important;
        border-style: solid !important;
        padding: 6mm !important;
    }
    .qr-format-minimal .qr-card-logo {
        min-height: 9mm !important;
    }
    .qr-format-minimal .qr-card-logo img {
        max-width: 28mm !important;
        max-height: 9mm !important;
    }
    .qr-format-minimal .qr-card-logo strong {
        max-width: 45mm !important;
        font-size: 9pt !important;
    }
    .qr-format-minimal .qr-print-image {
        width: 49mm !important;
        max-width: 49mm !important;
        height: 49mm !important;
    }
    .qr-format-minimal .qr-card-url {
        display: block !important;
        max-width: 50mm !important;
        overflow: hidden !important;
        color: #64748b !important;
        font-size: 6.5pt !important;
        font-weight: 700 !important;
        text-align: center !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }
    .qr-print-actions,
    .qr-side-panel,
    .qr-page-intro,
    .pro-sidebar,
    .pro-topbar,
    #toast-root,
    .qr-screen-only {
        display: none !important;
    }
    .qr-print-only {
        display: block !important;
    }
}
