@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;700;800&display=swap");

:root {
    --font-main: "Manrope", "Segoe UI", sans-serif;
    --bg: #f2f5f4;
    --bg-layer: #ffffff;
    --bg-card: #ffffff;
    --text: #13281f;
    --muted: #5f7a71;
    --line: #dbe5e1;
    --primary: #0f8b64;
    --primary-strong: #0a6c4d;
    --warning: #ed8d12;
    --danger: #c73636;
    --info: #1f7bd9;
    --success: #0f8b64;
    --shadow: 0 14px 30px rgba(15, 63, 48, 0.12);
}

html[data-theme="dark"] {
    --bg: #0e1815;
    --bg-layer: #12211c;
    --bg-card: #172823;
    --text: #e3f2eb;
    --muted: #9ab8ad;
    --line: #2a3d37;
    --primary: #37c996;
    --primary-strong: #1fa777;
    --warning: #f4ac3f;
    --danger: #f16464;
    --info: #52a2f3;
    --success: #2ac989;
    --shadow: 0 16px 34px rgba(0, 0, 0, 0.35);
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    font-family: var(--font-main);
    color: var(--text);
    background:
        radial-gradient(circle at 15% 0%, rgba(15, 139, 100, 0.18), transparent 34%),
        radial-gradient(circle at 85% 100%, rgba(237, 141, 18, 0.1), transparent 30%),
        var(--bg);
}

a {
    color: var(--primary);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

h1,
h2,
h3,
h4,
p {
    margin: 0;
}

.auth-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr 1.25fr;
}

.auth-brand-panel {
    background: linear-gradient(170deg, #0f8b64, #074f38);
    color: #f2fffb;
    padding: 3rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 1.1rem;
}

.auth-content-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}


.brand-mark {
    width: 54px;
    height: 54px;
    border-radius: 16px;
    background: linear-gradient(150deg, #f8f4ea, #e7ffef);
    color: #074f38;
    font-weight: 800;
    font-size: 0.92rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.18);
    overflow: hidden;
}
.brand-mark img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    border-radius: inherit;
}

.brand-mark--large {
    width: 74px;
    height: 74px;
    border-radius: 20px;
    font-size: 1.05rem;
}

.auth-locale-switch {
    display: flex;
    gap: 0.65rem;
    margin-top: 1rem;
}

.auth-card {
    width: min(440px, 100%);
    background: var(--bg-layer);
    border: 1px solid var(--line);
    border-radius: 20px;
    padding: 1.6rem;
    display: grid;
    gap: 1.1rem;
    box-shadow: var(--shadow);
}

.auth-card--wide {
    width: min(760px, 100%);
}

.auth-card header {
    display: grid;
    gap: 0.5rem;
}

.auth-card p,
.panel p {
    color: var(--muted);
}

.form-label {
    display: block;
    margin-bottom: 0.32rem;
    font-size: 0.9rem;
    font-weight: 600;
}

.form-input {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 0.7rem 0.8rem;
    font-size: 0.95rem;
    background: var(--bg-card);
    color: var(--text);
    margin-bottom: 0.95rem;
}

.form-input:focus {
    outline: 2px solid color-mix(in srgb, var(--primary), transparent 50%);
    border-color: var(--primary);
}

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

.form-grid > div:last-child:nth-child(odd) {
    grid-column: 1 / -1;
}

.btn {
    border: 0;
    border-radius: 12px;
    font-weight: 700;
    font-size: 0.92rem;
    cursor: pointer;
    padding: 0.72rem 0.92rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.btn-primary {
    color: #f6fffb;
    background: linear-gradient(145deg, var(--primary), var(--primary-strong));
}

.btn-block {
    width: 100%;
}

.auth-card-footer {
    display: flex;
    justify-content: center;
    gap: 0.4rem;
    color: var(--muted);
    font-size: 0.9rem;
}

.dashboard-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 280px 1fr;
}

.app-sidebar {
    background: var(--bg-layer);
    border-right: 1px solid var(--line);
    padding: 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.brand-block {
    display: flex;
    gap: 0.75rem;
    align-items: center;
}

.brand-block h1 {
    font-size: 1.05rem;
}

.brand-block p {
    font-size: 0.78rem;
    color: var(--muted);
}

.tenant-pill {
    background: color-mix(in srgb, var(--primary), transparent 88%);
    border: 1px solid color-mix(in srgb, var(--primary), transparent 70%);
    border-radius: 12px;
    padding: 0.7rem 0.8rem;
    display: grid;
    gap: 0.3rem;
}

.tenant-pill__label {
    color: var(--muted);
    font-size: 0.76rem;
}

.menu-list {
    display: grid;
    gap: 0.3rem;
    overflow-y: auto;
}

.menu-item {
    border-radius: 11px;
    padding: 0.58rem 0.68rem;
    font-size: 0.92rem;
    display: flex;
    align-items: center;
    gap: 0.55rem;
    color: var(--text);
}

.menu-item:hover {
    text-decoration: none;
    background: color-mix(in srgb, var(--primary), transparent 90%);
}

.menu-item.is-active {
    background: color-mix(in srgb, var(--primary), transparent 84%);
    font-weight: 700;
}

.menu-item__dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--primary), transparent 20%);
}

.sidebar-footer {
    margin-top: auto;
    border-top: 1px solid var(--line);
    padding-top: 0.85rem;
    color: var(--muted);
    display: grid;
    gap: 0.2rem;
}

.sidebar-footer p {
    color: var(--text);
    font-weight: 700;
}

.logout-link {
    margin-top: 0.35rem;
    font-weight: 600;
}

.dashboard-main {
    display: flex;
    flex-direction: column;
}

.app-header {
    position: sticky;
    top: 0;
    z-index: 20;
    backdrop-filter: blur(8px);
    background: color-mix(in srgb, var(--bg), transparent 8%);
    border-bottom: 1px solid var(--line);
    padding: 1rem 1.2rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.eyebrow {
    color: var(--muted);
    font-size: 0.78rem;
    margin-bottom: 0.2rem;
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.chip,
.theme-toggle {
    border: 1px solid var(--line);
    background: var(--bg-card);
    color: var(--text);
    border-radius: 999px;
    padding: 0.4rem 0.65rem;
    font-size: 0.8rem;
    font-weight: 700;
}

.chip.is-active {
    border-color: color-mix(in srgb, var(--primary), transparent 35%);
    background: color-mix(in srgb, var(--primary), transparent 84%);
}

.theme-toggle {
    cursor: pointer;
}

.dashboard-content {
    padding: 1rem 1.2rem 1.5rem;
    display: grid;
    gap: 1rem;
}

.alert {
    border-radius: 12px;
    padding: 0.75rem 0.9rem;
    border: 1px solid transparent;
    font-size: 0.9rem;
}

.alert-success {
    background: color-mix(in srgb, var(--primary), transparent 86%);
    border-color: color-mix(in srgb, var(--primary), transparent 56%);
}

.alert-error {
    background: color-mix(in srgb, var(--danger), transparent 88%);
    border-color: color-mix(in srgb, var(--danger), transparent 56%);
}

.alert-warning {
    background: color-mix(in srgb, var(--warning), transparent 86%);
    border-color: color-mix(in srgb, var(--warning), transparent 58%);
}

.alert-info {
    background: color-mix(in srgb, var(--info), transparent 86%);
    border-color: color-mix(in srgb, var(--info), transparent 58%);
}

.error-list {
    margin: 0;
    padding-left: 1.2rem;
}

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

.stat-card,
.panel {
    background: var(--bg-layer);
    border-radius: 16px;
    border: 1px solid var(--line);
    box-shadow: var(--shadow);
}

.stat-card {
    padding: 1rem;
    display: grid;
    gap: 0.35rem;
}

.stat-card p {
    color: var(--muted);
    font-size: 0.84rem;
}

.stat-card h3 {
    font-size: 1.35rem;
}

.content-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: 2fr 1fr;
}

.panel {
    padding: 1rem;
    display: grid;
    gap: 0.95rem;
}

.panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

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

.quick-card {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: color-mix(in srgb, var(--primary), transparent 92%);
    padding: 0.8rem;
    display: grid;
    gap: 0.4rem;
    color: var(--text);
}

.quick-card:hover {
    text-decoration: none;
    transform: translateY(-1px);
}

.phase-card {
    border: 1px dashed color-mix(in srgb, var(--primary), transparent 45%);
    border-radius: 12px;
    padding: 0.8rem;
    display: grid;
    gap: 0.55rem;
    background: color-mix(in srgb, var(--primary), transparent 91%);
}

.badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0.22rem 0.58rem;
    font-size: 0.73rem;
    font-weight: 700;
    border: 1px solid var(--line);
}

.badge-phase {
    background: color-mix(in srgb, var(--info), transparent 82%);
    border-color: color-mix(in srgb, var(--info), transparent 52%);
}

.status-draft,
.status-in_preparation,
.status-ready,
.status-served,
.status-paid,
.status-cancelled {
    background: color-mix(in srgb, var(--primary), transparent 86%);
}

.status-cancelled {
    background: color-mix(in srgb, var(--danger), transparent 85%);
}

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

.data-table {
    width: 100%;
    border-collapse: collapse;
}
.data-table th,
.data-table td {
    border-bottom: 1px solid var(--line);
    padding: 0.62rem;
    text-align: left;
    white-space: nowrap;
    font-size: 0.86rem;
}



.table-thumb {
    width: 52px;
    height: 52px;
    border-radius: 10px;
    border: 1px solid var(--line);
    object-fit: cover;
    background: var(--bg-card);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--muted);
}

.table-thumb--empty {
    width: 52px;
    height: 52px;
}

.module-placeholder {
    max-width: 780px;
}

.module-actions {
    display: flex;
    justify-content: flex-start;
}

.error-page {
    min-height: 100vh;
    display: grid;
    place-items: center;
}

.error-shell {
    width: min(520px, 94%);
    border: 1px solid var(--line);
    background: var(--bg-layer);
    border-radius: 16px;
    padding: 1.2rem;
    display: grid;
    gap: 0.85rem;
    text-align: center;
}

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

    .content-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 980px) {
    .dashboard-shell {
        grid-template-columns: 1fr;
    }

    .app-sidebar {
        position: sticky;
        top: 0;
        z-index: 30;
        border-right: 0;
        border-bottom: 1px solid var(--line);
    }

    .menu-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-height: 240px;
    }

    .sidebar-footer {
        display: none;
    }

    .auth-shell {
        grid-template-columns: 1fr;
    }

    .auth-brand-panel {
        padding: 2rem;
    }
}

@media (max-width: 680px) {
    .form-grid,
    .quick-grid,
    .stats-grid,
    .menu-list {
        grid-template-columns: 1fr;
    }

    .app-header {
        flex-direction: column;
        align-items: flex-start;
    }
}

.btn-link {
    background: transparent;
    border: 0;
    color: var(--primary);
    font: inherit;
    padding: 0;
    cursor: pointer;
    text-align: left;
}

.btn-link:hover {
    text-decoration: underline;
}

.inline-form-grid {
    display: grid;
    gap: 0.7rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: end;
}

.inline-form-grid--compact {
    grid-template-columns: 2fr 1fr 1fr;
}

.recipe-items-panel {
    margin-top: 0.8rem;
    background: color-mix(in srgb, var(--primary), transparent 93%);
}

.recipe-preview ul {
    margin: 0.4rem 0 0;
    padding-left: 1.2rem;
}

.recipe-preview li {
    margin-bottom: 0.2rem;
    color: var(--muted);
}

@media (max-width: 860px) {
    .inline-form-grid,
    .inline-form-grid--compact {
        grid-template-columns: 1fr;
    }
}

.badge-warning {
    background: color-mix(in srgb, var(--warning), transparent 82%);
    border-color: color-mix(in srgb, var(--warning), transparent 56%);
}

.tenant-switch-form {
    margin: 0;
}

.chip-select {
    min-width: 180px;
    appearance: none;
    padding-right: 1.8rem;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}
/* POS Workspace */
.pos-layout {
    display: grid;
    gap: 1rem;
}

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

.pos-session-panel.is-warning {
    border-color: color-mix(in srgb, var(--warning), transparent 45%);
    background: color-mix(in srgb, var(--warning), transparent 90%);
}

.pos-session-meta,
.pos-open-summary {
    display: grid;
    gap: 0.45rem;
}

.pos-workspace {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1.45fr) minmax(340px, 1fr);
    align-items: start;
}

.pos-catalog-panel {
    align-content: start;
    --pos-grid-gap: 0.78rem;
    --pos-card-min-width: 172px;
    --pos-card-padding: 0.72rem;
    --pos-card-gap: 0.62rem;
    --pos-card-min-height: 228px;
    --pos-image-ratio: 16 / 10;
    --pos-image-max-height: 134px;
    --pos-title-size: 0.95rem;
    --pos-title-lines: 2;
    --pos-category-size: 0.78rem;
    --pos-price-size: 0.9rem;
    --pos-content-gap: 0.25rem;
    --pos-add-btn-min-height: 42px;
}

.pos-catalog-header {
    align-items: flex-start;
    gap: 0.75rem;
}

.pos-catalog-toolbar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.pos-counters {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.pos-density-control {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: color-mix(in srgb, var(--primary), transparent 93%);
    padding: 0.2rem 0.22rem 0.2rem 0.58rem;
}

.pos-density-control__label {
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--muted);
    white-space: nowrap;
}

.pos-density-switch {
    display: inline-flex;
    align-items: center;
    gap: 0.22rem;
}

.pos-density-btn {
    border: 1px solid transparent;
    border-radius: 999px;
    background: transparent;
    color: var(--text);
    font-size: 0.76rem;
    font-weight: 800;
    line-height: 1;
    min-height: 30px;
    padding: 0.3rem 0.58rem;
    cursor: pointer;
    white-space: nowrap;
}

.pos-density-btn:hover {
    background: color-mix(in srgb, var(--primary), transparent 90%);
}

.pos-density-btn.is-active {
    background: linear-gradient(145deg, var(--primary), var(--primary-strong));
    color: #f4fff9;
    border-color: color-mix(in srgb, var(--primary), transparent 18%);
}

.pos-density-btn:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--primary), white 20%);
    outline-offset: 2px;
}

.pos-search {
    margin: 0;
}

.pos-categories {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 0.7rem;
    background: color-mix(in srgb, var(--primary), transparent 92%);
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.pos-chip {
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 0.42rem 0.8rem;
    background: var(--bg-card);
    color: var(--text);
    font-weight: 700;
    font-size: 0.85rem;
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
    cursor: pointer;
}

.pos-chip.is-active {
    border-color: color-mix(in srgb, var(--primary), transparent 35%);
    background: color-mix(in srgb, var(--primary), transparent 82%);
}

.pos-chip img {
    width: 20px;
    height: 20px;
    border-radius: 999px;
    object-fit: cover;
    border: 1px solid var(--line);
}

.pos-product-grid {
    display: grid;
    gap: var(--pos-grid-gap);
    grid-template-columns: repeat(auto-fill, minmax(min(100%, var(--pos-card-min-width)), 1fr));
    align-items: stretch;
}

.pos-product-card {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: color-mix(in srgb, var(--primary), transparent 94%);
    padding: var(--pos-card-padding);
    min-height: var(--pos-card-min-height);
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: var(--pos-card-gap);
}

.pos-product-image-wrap {
    width: 100%;
    aspect-ratio: var(--pos-image-ratio);
    max-height: var(--pos-image-max-height);
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--line);
    background: var(--bg-card);
    display: grid;
    place-items: center;
}

.pos-product-image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pos-product-fallback {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    font-weight: 800;
    font-size: 0.95rem;
    color: var(--muted);
}

.pos-product-content {
    display: grid;
    align-content: start;
    gap: var(--pos-content-gap);
}

.pos-product-content h4 {
    font-size: var(--pos-title-size);
    line-height: 1.3;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: var(--pos-title-lines);
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.pos-product-category {
    color: var(--muted);
    font-size: var(--pos-category-size);
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.pos-product-price {
    font-weight: 800;
    font-size: var(--pos-price-size);
    margin: 0;
}

.pos-add-btn {
    width: 100%;
    min-height: var(--pos-add-btn-min-height);
    padding-block: 0.52rem;
}

.pos-add-btn.is-added {
    background: linear-gradient(145deg, var(--primary-strong), var(--primary));
}

.pos-catalog-panel[data-pos-density="compact"] {
    --pos-grid-gap: 0.6rem;
    --pos-card-min-width: 132px;
    --pos-card-padding: 0.56rem;
    --pos-card-gap: 0.5rem;
    --pos-card-min-height: 176px;
    --pos-image-ratio: 2 / 1;
    --pos-image-max-height: 82px;
    --pos-title-size: 0.83rem;
    --pos-title-lines: 2;
    --pos-category-size: 0.72rem;
    --pos-price-size: 0.84rem;
    --pos-content-gap: 0.2rem;
    --pos-add-btn-min-height: 40px;
}

.pos-catalog-panel[data-pos-density="comfortable"] {
    --pos-grid-gap: 0.78rem;
    --pos-card-min-width: 172px;
    --pos-card-padding: 0.72rem;
    --pos-card-gap: 0.62rem;
    --pos-card-min-height: 228px;
    --pos-image-ratio: 16 / 10;
    --pos-image-max-height: 134px;
    --pos-title-size: 0.95rem;
    --pos-title-lines: 2;
    --pos-category-size: 0.78rem;
    --pos-price-size: 0.9rem;
    --pos-content-gap: 0.25rem;
    --pos-add-btn-min-height: 42px;
}

.pos-catalog-panel[data-pos-density="large"] {
    --pos-grid-gap: 0.9rem;
    --pos-card-min-width: 226px;
    --pos-card-padding: 0.86rem;
    --pos-card-gap: 0.68rem;
    --pos-card-min-height: 286px;
    --pos-image-ratio: 4 / 3;
    --pos-image-max-height: 176px;
    --pos-title-size: 1rem;
    --pos-title-lines: 2;
    --pos-category-size: 0.8rem;
    --pos-price-size: 0.95rem;
    --pos-content-gap: 0.28rem;
    --pos-add-btn-min-height: 44px;
}

.pos-side-stack {
    display: grid;
    gap: 1rem;
}

.pos-bill-panel,
.pos-expense-card,
.pos-open-orders {
    align-content: start;
}

.pos-order-form {
    display: grid;
    gap: 0.8rem;
}

.pos-cart-list {
    max-height: 280px;
    overflow: auto;
    display: grid;
    gap: 0.55rem;
}

.pos-empty-cart {
    color: var(--muted);
    margin: 0;
}

.pos-cart-item {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 0.62rem;
    background: var(--bg-card);
    display: grid;
    gap: 0.42rem;
}

.pos-cart-item__head {
    display: flex;
    justify-content: space-between;
    gap: 0.45rem;
}

.pos-cart-item__controls {
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.pos-cart-item__controls button {
    border: 1px solid var(--line);
    background: color-mix(in srgb, var(--primary), transparent 88%);
    color: var(--text);
    border-radius: 8px;
    min-width: 30px;
    height: 30px;
    cursor: pointer;
    font-weight: 700;
}

.pos-cart-item__controls span {
    min-width: 34px;
    text-align: center;
    font-weight: 700;
}

.pos-cart-note {
    margin: 0;
}

.pos-summary {
    border-top: 1px dashed var(--line);
    border-bottom: 1px dashed var(--line);
    padding: 0.65rem 0;
    display: grid;
    gap: 0.34rem;
}

.pos-summary > div {
    display: flex;
    justify-content: space-between;
    gap: 0.65rem;
    font-size: 0.9rem;
}

.pos-summary .is-total {
    color: var(--primary-strong);
    font-size: 1rem;
    font-weight: 800;
}

.pos-order-details {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: color-mix(in srgb, var(--primary), transparent 94%);
    padding: 0.72rem;
}

.pos-order-details summary {
    cursor: pointer;
    font-weight: 700;
    margin-bottom: 0.65rem;
}

.pos-order-fields .form-input,
.pos-expense-form .form-input {
    margin-bottom: 0;
}

.pos-payment-methods {
    display: grid;
    gap: 0.45rem;
}

.pos-payment-grid {
    display: grid;
    gap: 0.45rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.pos-payment-chip {
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 0.52rem;
    background: color-mix(in srgb, var(--primary), transparent 90%);
    text-align: center;
    font-size: 0.82rem;
    font-weight: 700;
}

.pos-place-order {
    padding-block: 0.78rem;
}

.pos-expense-form {
    gap: 0.6rem;
}

.pos-kitchen-alert-controls {
    display: grid;
    gap: 0.42rem;
    margin-bottom: 0.6rem;
}

.pos-kitchen-alert-toggle {
    margin: 0;
}

.pos-kitchen-alert-sound-wrap {
    display: grid;
    gap: 0.2rem;
}

.pos-kitchen-alert-sound-label {
    font-size: 0.76rem;
    color: var(--muted);
    font-weight: 700;
}

.pos-kitchen-alert-sound {
    min-height: 34px;
    font-size: 0.82rem;
}
.pos-open-orders-list {
    display: grid;
    gap: 0.48rem;
}

.pos-open-order-item {
    display: flex;
    justify-content: space-between;
    gap: 0.8rem;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 0.54rem 0.62rem;
    color: inherit;
    background: color-mix(in srgb, var(--primary), transparent 93%);
}

.pos-open-order-item > div {
    min-width: 0;
}

.pos-open-order-item > div > strong {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
.pos-open-order-item:hover {
    text-decoration: none;
    border-color: color-mix(in srgb, var(--primary), transparent 45%);
}

.pos-open-order-item small {
    display: block;
    color: var(--muted);
}

.pos-muted {
    color: var(--muted);
    font-size: 0.85rem;
}

.role-editor {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 0.75rem;
    background: color-mix(in srgb, var(--primary), transparent 94%);
}

.role-editor summary {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    font-weight: 700;
}

.role-editor__title {
    font-size: 0.95rem;
}

.role-editor-form {
    margin-top: 0.75rem;
    display: grid;
    gap: 0.8rem;
}

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

.permission-module-card {
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 0.62rem;
    display: grid;
    gap: 0.42rem;
    background: var(--bg-card);
}

.permission-module-card h4 {
    font-size: 0.82rem;
    text-transform: uppercase;
    color: var(--muted);
}

.permission-checkbox {
    display: grid;
    gap: 0.15rem;
    font-size: 0.84rem;
}

.permission-checkbox input {
    margin: 0;
}

.permission-checkbox small {
    color: var(--muted);
    font-size: 0.75rem;
}

@media (max-width: 1420px) {
    .pos-workspace {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 980px) {
    .pos-head-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 1100px) {
    .permission-module-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 720px) {
    .permission-module-grid {
        grid-template-columns: 1fr;
    }

    .pos-payment-grid {
        grid-template-columns: 1fr;
    }

    .pos-categories {
        flex-wrap: nowrap;
        overflow-x: auto;
    }

    .pos-counters {
        width: 100%;
    }
}

.table-thumb {
    width: 60px;
    height: 60px;
    object-fit: cover;
    border-radius: 8px;
    border: 1px solid rgba(0,0,0,0.08);
    box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}

.table-thumb--empty {
    width: 60px;
    height: 60px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #f5f5f5;
    border-radius: 8px;
    font-size: 12px;
    color: #999;
}
.pos-quick-actions {
    display: grid;
    gap: 0.45rem;
}

.pos-action-grid {
    display: grid;
    gap: 0.45rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pos-action-btn {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--bg-card);
    color: var(--text);
    font-weight: 800;
    font-size: 0.9rem;
    min-height: 46px;
    cursor: pointer;
}

.pos-action-btn.is-active {
    background: linear-gradient(145deg, var(--primary), var(--primary-strong));
    color: #f5fff9;
    border-color: color-mix(in srgb, var(--primary), transparent 10%);
}

.pos-pay-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-weight: 700;
    color: var(--text);
}

.pos-pay-toggle input {
    width: 18px;
    height: 18px;
}

.pos-payment-chip {
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 0.65rem 0.52rem;
    background: color-mix(in srgb, var(--primary), transparent 90%);
    text-align: center;
    font-size: 0.82rem;
    font-weight: 800;
    cursor: pointer;
    min-height: 48px;
    color: var(--text);
}

.pos-payment-chip.is-active {
    background: linear-gradient(145deg, var(--primary), var(--primary-strong));
    color: #f5fff9;
    border-color: color-mix(in srgb, var(--primary), transparent 10%);
}

.pos-pay-hint {
    color: var(--muted);
}

.pos-mobile-money-field {
    display: grid;
    gap: 0.24rem;
}

.pos-mobile-money-field[hidden] {
    display: none !important;
}
@media (max-width: 720px) {
    .pos-action-grid {
        grid-template-columns: 1fr;
    }
}

.form-input::placeholder {
    color: var(--placeholder);
    opacity: 0.96;
}

.form-input:-ms-input-placeholder {
    color: var(--placeholder);
}

.form-input::-ms-input-placeholder {
    color: var(--placeholder);
}

.form-input[type="number"] {
    font-variant-numeric: tabular-nums;
    color: var(--text);
    appearance: textfield;
    -moz-appearance: textfield;
}

.form-input[type="number"]::-webkit-outer-spin-button,
.form-input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.form-input:disabled {
    opacity: 0.75;
    color: var(--muted);
}

/* Sidebar collapse */
.dashboard-shell {
    transition: grid-template-columns 0.22s ease;
}

.app-sidebar {
    transition: padding 0.22s ease;
}

.sidebar-toggle {
    cursor: pointer;
}

body.sidebar-collapsed .dashboard-shell {
    grid-template-columns: 96px 1fr;
}

body.sidebar-collapsed .app-sidebar {
    padding-inline: 0.65rem;
}

body.sidebar-collapsed .brand-block {
    justify-content: center;
}

body.sidebar-collapsed .brand-block > div,
body.sidebar-collapsed .tenant-pill__label,
body.sidebar-collapsed .menu-item span:not(.menu-item__dot),
body.sidebar-collapsed .sidebar-footer {
    display: none;
}

body.sidebar-collapsed .tenant-pill {
    place-items: center;
    padding: 0.55rem 0.35rem;
}

body.sidebar-collapsed .tenant-pill strong {
    font-size: 0.72rem;
}

body.sidebar-collapsed .menu-item {
    justify-content: center;
    padding-inline: 0.4rem;
}

body.sidebar-collapsed .menu-item__dot {
    width: 10px;
    height: 10px;
}

/* Orders list UX */
.orders-panel {
    gap: 0.9rem;
}

.orders-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.8rem;
    flex-wrap: wrap;
}

.orders-filter-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.orders-session-badge {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 0.55rem 0.7rem;
    background: color-mix(in srgb, var(--primary), transparent 92%);
    display: grid;
    gap: 0.15rem;
    min-width: 180px;
}

.orders-session-badge span {
    font-size: 0.88rem;
    font-weight: 700;
}

.orders-session-badge small {
    color: var(--muted);
}

.order-preview-list {
    display: grid;
    gap: 0.15rem;
}

.order-preview-list small {
    color: var(--muted);
    font-size: 0.76rem;
}

.order-actions-inline {
    display: grid;
    gap: 0.4rem;
    min-width: 132px;
}

.order-actions-inline .btn,
.order-actions-inline .btn-primary {
    width: 100%;
}

.order-quick-pay-form {
    margin: 0;
    display: block;
}

.orders-mobile-list {
    display: none;
    gap: 0.8rem;
}

.order-mobile-card {
    gap: 0.65rem;
}

.order-mobile-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
}

.order-mobile-meta {
    display: grid;
    gap: 0.2rem;
    color: var(--muted);
    font-size: 0.86rem;
}

/* POS visual table picker */
.pos-order-mode-panels {
    display: grid;
    gap: 0.6rem;
}

.pos-table-picker {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--bg-card);
    padding: 0.62rem;
    display: grid;
    gap: 0.55rem;
}

.pos-zone-switch {
    display: flex;
    gap: 0.45rem;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 0.2rem;
}

.pos-zone-chip {
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--bg-card);
    color: var(--text);
    font-size: 0.8rem;
    font-weight: 700;
    padding: 0.35rem 0.68rem;
    cursor: pointer;
    white-space: nowrap;
}

.pos-zone-chip.is-active {
    background: linear-gradient(145deg, var(--primary), var(--primary-strong));
    color: #f6fffb;
    border-color: color-mix(in srgb, var(--primary), transparent 10%);
}

.pos-table-grid {
    display: grid;
    gap: 0.5rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.pos-table-card {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: color-mix(in srgb, var(--primary), transparent 94%);
    color: var(--text);
    text-align: left;
    padding: 0.56rem;
    min-height: 74px;
    display: grid;
    gap: 0.18rem;
    cursor: pointer;
}

.pos-table-card strong {
    font-size: 0.94rem;
}

.pos-table-card small {
    color: var(--muted);
    font-size: 0.74rem;
}

.pos-table-card.is-selected {
    border-color: color-mix(in srgb, var(--primary), transparent 10%);
    background: linear-gradient(145deg, color-mix(in srgb, var(--primary), white 20%), var(--primary));
    color: #f5fff9;
}

.pos-table-card.is-selected small {
    color: #e8fff6;
}

.pos-table-card.is-occupied {
    border-color: color-mix(in srgb, var(--warning), transparent 30%);
    background: color-mix(in srgb, var(--warning), transparent 88%);
}

.pos-table-card.is-reserved {
    border-color: color-mix(in srgb, var(--info), transparent 35%);
    background: color-mix(in srgb, var(--info), transparent 90%);
}

.pos-table-card.is-cleaning {
    border-color: color-mix(in srgb, var(--muted), transparent 35%);
    background: color-mix(in srgb, var(--muted), transparent 86%);
}

.pos-table-empty {
    color: var(--muted);
    font-size: 0.83rem;
}

.pos-selected-table {
    color: var(--muted);
    font-size: 0.83rem;
}

.pos-table-select-fallback {
    display: none;
}

@media (max-width: 980px) {
    body.sidebar-collapsed .dashboard-shell {
        grid-template-columns: 1fr;
    }

    body.sidebar-collapsed .brand-block > div,
    body.sidebar-collapsed .tenant-pill__label,
    body.sidebar-collapsed .menu-item span:not(.menu-item__dot) {
        display: initial;
    }

    body.sidebar-collapsed .sidebar-footer {
        display: none;
    }

    .orders-table-wrap {
        display: none;
    }

    .orders-mobile-list {
        display: grid;
    }
}

@media (max-width: 860px) {
    .pos-table-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 620px) {
    .pos-table-grid {
        grid-template-columns: 1fr;
    }
}

/* POS live table ticket */
.pos-table-live-card {
    align-content: start;
}

.pos-table-live-card[hidden] {
    display: none;
}

.pos-table-live-meta {
    display: grid;
    gap: 0.25rem;
    font-size: 0.88rem;
}

.pos-table-live-meta p {
    margin: 0;
}

/* Interactive tables board */
.tables-zone-switch {
    display: flex;
    gap: 0.45rem;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 0.2rem;
}

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

.tables-board-card {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: color-mix(in srgb, var(--primary), transparent 94%);
    padding: 0.68rem;
    display: grid;
    gap: 0.48rem;
}

.tables-board-card header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.4rem;
}

.tables-board-card p {
    color: var(--muted);
    font-size: 0.82rem;
}

.tables-board-order {
    border: 1px dashed var(--line);
    border-radius: 10px;
    padding: 0.45rem 0.52rem;
    display: grid;
    gap: 0.15rem;
    background: var(--bg-card);
}

.tables-board-order small {
    color: var(--muted);
}

.tables-board-actions {
    display: grid;
}

.tables-board-card.is-occupied {
    border-color: color-mix(in srgb, var(--warning), transparent 28%);
    background: color-mix(in srgb, var(--warning), transparent 88%);
}

.tables-board-card.is-reserved {
    border-color: color-mix(in srgb, var(--info), transparent 35%);
    background: color-mix(in srgb, var(--info), transparent 90%);
}

.tables-board-card.is-cleaning {
    border-color: color-mix(in srgb, var(--muted), transparent 35%);
    background: color-mix(in srgb, var(--muted), transparent 86%);
}

@media (max-width: 1200px) {
    .tables-board-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .tables-board-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 620px) {
    .tables-board-grid {
        grid-template-columns: 1fr;
    }
}
/* Subscription */
.plan-chip {
    font-weight: 600;
}

.plan-chip strong {
    margin-left: 0.25rem;
}

.plan-chip--usage {
    opacity: 0.9;
}

.chip-upgrade {
    border-color: color-mix(in srgb, var(--primary), transparent 30%);
    background: color-mix(in srgb, var(--primary), transparent 84%);
}

.chip-max-plan {
    border-color: color-mix(in srgb, var(--success), transparent 35%);
    background: color-mix(in srgb, var(--success), transparent 88%);
}

.subscription-current-card {
    align-content: start;
}

.subscription-current-meta {
    margin: 0 0 0.6rem 0;
    color: var(--muted);
}

.subscription-usage-grid {
    display: grid;
    gap: 0.7rem;
    margin-bottom: 0.9rem;
}

.subscription-usage-item {
    display: grid;
    gap: 0.35rem;
}

.subscription-usage-head {
    display: flex;
    justify-content: space-between;
    gap: 0.6rem;
    font-size: 0.9rem;
}

.progress-track {
    width: 100%;
    height: 8px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--line), transparent 20%);
    overflow: hidden;
}

.progress-fill {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, color-mix(in srgb, var(--primary), transparent 15%), var(--primary));
}

.subscription-feature-list {
    display: grid;
    gap: 0.5rem;
    padding-left: 1rem;
}

.subscription-feature-list li {
    display: grid;
    gap: 0.1rem;
}

.subscription-feature-list small {
    color: var(--muted);
}

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

.subscription-plan-card {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 0.8rem;
    display: grid;
    gap: 0.75rem;
    background: color-mix(in srgb, var(--primary), transparent 94%);
}

.subscription-plan-card h4 {
    margin: 0;
}

.subscription-plan-card p {
    color: var(--muted);
}

.subscription-plan-limits {
    display: grid;
    gap: 0.25rem;
    font-size: 0.88rem;
}

.subscription-unlock-list {
    margin: 0;
    padding-left: 1rem;
    display: grid;
    gap: 0.2rem;
}

.subscription-unlock-list li {
    color: var(--muted);
    font-size: 0.86rem;
}

.subscription-upgrade-form {
    display: grid;
}

.subscription-dashboard-card {
    display: grid;
    gap: 0.45rem;
}

.subscription-settings-card {
    margin-bottom: 1rem;
}

@media (max-width: 1180px) {
    .subscription-plan-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .subscription-plan-grid {
        grid-template-columns: 1fr;
    }
}

/* Dashboard mobile off-canvas sidebar */
.header-title-wrap {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
}

.sidebar-toggle--mobile {
    display: none;
    border: 1px solid var(--line);
    background: var(--bg-card);
    color: var(--text);
    border-radius: 12px;
    width: 2.45rem;
    height: 2.45rem;
    padding: 0;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
}

.sidebar-toggle__icon,
.sidebar-toggle__icon::before,
.sidebar-toggle__icon::after {
    display: block;
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    transition: transform 0.24s ease, opacity 0.24s ease;
}

.sidebar-toggle__icon {
    position: relative;
}

.sidebar-toggle__icon::before,
.sidebar-toggle__icon::after {
    content: "";
    position: absolute;
    left: 0;
}

.sidebar-toggle__icon::before {
    top: -6px;
}

.sidebar-toggle__icon::after {
    top: 6px;
}

body.sidebar-mobile-open .sidebar-toggle__icon {
    background: transparent;
}

body.sidebar-mobile-open .sidebar-toggle__icon::before {
    transform: translateY(6px) rotate(45deg);
}

body.sidebar-mobile-open .sidebar-toggle__icon::after {
    transform: translateY(-6px) rotate(-45deg);
}

.sidebar-backdrop {
    position: fixed;
    inset: 0;
    border: 0;
    margin: 0;
    padding: 0;
    background: rgba(6, 16, 13, 0.64);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    z-index: 44;
    transition: opacity 0.24s ease, visibility 0.24s ease;
}

body.sidebar-mobile-open .sidebar-backdrop {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

@media (max-width: 991.98px) {
    body.sidebar-mobile-open {
        overflow: hidden;
    }

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

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

    .sidebar-toggle--desktop {
        display: none;
    }

    .sidebar-toggle--mobile {
        display: inline-flex;
    }

    .app-sidebar {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: 280px;
        max-width: min(88vw, 320px);
        border-right: 1px solid var(--line);
        border-bottom: 0;
        box-shadow: 0 20px 50px rgba(0, 0, 0, 0.25);
        transform: translate3d(-108%, 0, 0);
        transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
        overflow-y: auto;
        z-index: 45;
        will-change: transform;
    }

    body.sidebar-mobile-open .app-sidebar {
        transform: translate3d(0, 0, 0);
    }

    .menu-list {
        grid-template-columns: 1fr;
        max-height: none;
    }

    .sidebar-footer {
        display: grid;
    }

    body.sidebar-collapsed .dashboard-shell {
        grid-template-columns: 1fr;
    }

    body.sidebar-collapsed .app-sidebar {
        padding-inline: 1.2rem;
    }

    body.sidebar-collapsed .brand-block {
        justify-content: flex-start;
    }

    body.sidebar-collapsed .brand-block > div,
    body.sidebar-collapsed .tenant-pill__label {
        display: block;
    }

    body.sidebar-collapsed .menu-item span:not(.menu-item__dot) {
        display: inline;
    }

    body.sidebar-collapsed .sidebar-footer {
        display: grid;
    }
}

.sidebar-mobile-controls {
    display: none;
}

@media (max-width: 991.98px) {
    .sidebar-mobile-controls {
        display: flex;
        justify-content: flex-end;
    }

    .sidebar-toggle--mobile-text {
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }
}
/* Advanced modules */
.analytics-filter-panel {
    align-content: start;
}

.analytics-range-meta {
    color: var(--muted);
    font-size: 0.86rem;
}

.module-settings-grid {
    grid-template-columns: 1.2fr 1fr;
}

.inline-switch {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    font-weight: 700;
}

.inline-switch input {
    width: 18px;
    height: 18px;
}

.settings-switch-field {
    grid-column: 1 / -1;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 0.72rem 0.8rem;
    background: color-mix(in srgb, var(--primary), transparent 94%);
}

.settings-switch-field .form-label {
    margin-bottom: 0.45rem;
}

.settings-switch-field small {
    display: block;
    margin-top: 0.4rem;
    color: var(--muted);
    font-size: 0.8rem;
}

.module-inline-form,
.module-stacked-form {
    display: grid;
    gap: 0.65rem;
}

.module-actions-row {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.module-status-grid {
    display: grid;
    gap: 0.35rem;
}

.readonly-url {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

.token-reveal code {
    display: block;
    padding: 0.55rem 0.65rem;
    border-radius: 10px;
    background: var(--bg-card);
    border: 1px dashed var(--line);
    margin: 0.4rem 0;
    word-break: break-all;
}

/* Public QR menu */
.public-menu-page {
    min-height: 100vh;
    margin: 0;
    padding: 1rem;
}

.public-menu-shell {
    width: min(1080px, 100%);
    margin: 0 auto;
    display: grid;
    gap: 1rem;
}

.public-menu-hero {
    background: linear-gradient(140deg, color-mix(in srgb, var(--primary), white 12%), var(--primary-strong));
    color: #f4fffa;
    border-radius: 18px;
    padding: 1rem;
    border: 1px solid color-mix(in srgb, var(--primary), black 14%);
}

.public-menu-brand {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.public-menu-brand img {
    width: 68px;
    height: 68px;
    border-radius: 14px;
    object-fit: cover;
    border: 1px solid rgba(255, 255, 255, 0.35);
}

.public-menu-brand h1 {
    font-size: 1.3rem;
}

.public-menu-brand p {
    color: rgba(247, 255, 252, 0.88);
}

.public-menu-category h2 {
    font-size: 1.04rem;
}

.public-menu-products {
    display: grid;
    gap: 0.7rem;
}

.public-menu-product {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: color-mix(in srgb, var(--primary), transparent 95%);
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 0.7rem;
    padding: 0.68rem;
}

.public-menu-product-image {
    width: 100%;
    aspect-ratio: 1 / 1;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--line);
    background: var(--bg-card);
}

.public-menu-product-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.public-menu-product-body {
    display: grid;
    gap: 0.3rem;
    align-content: start;
}

.public-menu-product-head {
    display: flex;
    justify-content: space-between;
    gap: 0.65rem;
    align-items: baseline;
}

.public-menu-product-head h3 {
    font-size: 1rem;
}

.public-menu-product-head strong {
    color: var(--primary-strong);
}

.public-menu-product small {
    color: var(--muted);
}

@media (max-width: 980px) {
    .module-settings-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .public-menu-product {
        grid-template-columns: 1fr;
    }
}
/* Auth redesign */
body.auth-page {
    min-height: 100vh;
    background:
        radial-gradient(circle at 8% 12%, rgba(15, 139, 100, 0.3), transparent 32%),
        radial-gradient(circle at 88% 88%, rgba(237, 141, 18, 0.2), transparent 36%),
        linear-gradient(145deg, #f2f6f5 0%, #e9efec 42%, #eef5f2 100%);
}

html[data-theme="dark"] body.auth-page {
    background:
        radial-gradient(circle at 8% 12%, rgba(55, 201, 150, 0.24), transparent 34%),
        radial-gradient(circle at 88% 88%, rgba(244, 172, 63, 0.18), transparent 35%),
        linear-gradient(145deg, #0c1411 0%, #101b17 48%, #0f1815 100%);
}

.auth-shell {
    min-height: 100vh;
    grid-template-columns: minmax(340px, 1fr) minmax(420px, 0.9fr);
}

.auth-brand-panel {
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(162deg, #0f8b64 0%, #0b6f50 48%, #084832 100%);
    padding: 2.6rem;
}

.auth-brand-panel::before,
.auth-brand-panel::after {
    content: "";
    position: absolute;
    border-radius: 999px;
    pointer-events: none;
}

.auth-brand-panel::before {
    width: 380px;
    height: 380px;
    background: rgba(255, 255, 255, 0.08);
    top: -170px;
    right: -110px;
}

.auth-brand-panel::after {
    width: 260px;
    height: 260px;
    background: rgba(237, 141, 18, 0.24);
    bottom: -110px;
    left: -60px;
}

.auth-brand-panel__content {
    position: relative;
    z-index: 1;
    max-width: 560px;
    display: grid;
    gap: 1.05rem;
}

.auth-kicker {
    width: max-content;
    border: 1px solid rgba(255, 255, 255, 0.28);
    border-radius: 999px;
    padding: 0.38rem 0.72rem;
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(247, 255, 251, 0.94);
}

.auth-brand-panel h1 {
    margin: 0;
    font-size: clamp(1.9rem, 3vw, 2.7rem);
    line-height: 1.1;
}

.auth-tagline {
    margin: 0;
    max-width: 32ch;
    color: rgba(236, 255, 248, 0.92);
}

.auth-feature-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.55rem;
}

.auth-feature-list li {
    position: relative;
    padding-left: 1.2rem;
    color: rgba(236, 255, 248, 0.92);
    font-size: 0.93rem;
}

.auth-feature-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.48rem;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: rgba(247, 255, 251, 0.92);
}

.auth-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.65rem;
}

.auth-metrics article {
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: 12px;
    background: rgba(3, 26, 18, 0.24);
    padding: 0.62rem;
    display: grid;
    gap: 0.2rem;
}

.auth-metrics strong {
    color: #ffffff;
    font-size: 1rem;
}

.auth-metrics small {
    color: rgba(236, 255, 248, 0.87);
    font-size: 0.76rem;
}

.auth-locale-switch {
    margin-top: 0.4rem;
}

.auth-locale-switch .chip {
    border-color: rgba(255, 255, 255, 0.32);
    background: rgba(255, 255, 255, 0.09);
    color: #f2fffb;
}

.auth-locale-switch .chip.is-active {
    background: rgba(255, 255, 255, 0.98);
    color: #0a5e44;
    border-color: rgba(255, 255, 255, 0.98);
}

.auth-content-panel {
    align-items: center;
    justify-content: center;
    padding: 1.4rem;
}

.auth-content-wrap {
    width: min(760px, 100%);
    display: grid;
    gap: 0.85rem;
}

.auth-card {
    width: min(560px, 100%);
    margin-inline: auto;
    border-radius: 24px;
    border: 1px solid color-mix(in srgb, var(--line), transparent 6%);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--bg-layer), #ffffff 2%), color-mix(in srgb, var(--bg-layer), #f7fbf9 6%));
    box-shadow: 0 30px 60px rgba(11, 48, 36, 0.18);
    padding: 1.5rem;
    gap: 1.1rem;
}

.auth-card--wide {
    width: min(840px, 100%);
}

.auth-card-header {
    display: grid;
    gap: 0.45rem;
}

.auth-card-header h2 {
    margin: 0;
    font-size: clamp(1.3rem, 2.2vw, 1.85rem);
    line-height: 1.15;
}

.auth-card-header p {
    margin: 0;
    color: var(--muted);
    max-width: 60ch;
}

.auth-form {
    display: grid;
    gap: 0.92rem;
}

.auth-form-section {
    border: 1px solid color-mix(in srgb, var(--line), transparent 4%);
    border-radius: 16px;
    padding: 0.85rem;
    background: color-mix(in srgb, var(--primary), transparent 95%);
    display: grid;
    gap: 0.75rem;
}

.auth-form-section h3 {
    margin: 0;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: color-mix(in srgb, var(--text), var(--primary) 25%);
}

.auth-field {
    display: grid;
    gap: 0.28rem;
}

.auth-inline-link {
    display: flex;
    justify-content: flex-end;
    margin-top: -0.2rem;
}

.auth-inline-link a {
    font-size: 0.82rem;
    font-weight: 700;
}

.auth-card .form-label {
    margin-bottom: 0;
    font-size: 0.82rem;
    color: color-mix(in srgb, var(--text), var(--muted) 20%);
}

.auth-card .form-input {
    margin-bottom: 0;
    border-radius: 12px;
    border-color: color-mix(in srgb, var(--line), transparent 8%);
    background: color-mix(in srgb, var(--bg-card), #ffffff 8%);
}

.auth-card .form-input:focus {
    border-color: color-mix(in srgb, var(--primary), transparent 30%);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary), transparent 80%);
    outline: 0;
}

.auth-card .btn-primary {
    margin-top: 0.2rem;
    min-height: 46px;
    border-radius: 12px;
}

.auth-card-footer {
    justify-content: flex-start;
    border-top: 1px dashed var(--line);
    padding-top: 0.75rem;
}

.auth-card-footer a {
    font-weight: 700;
}

@media (max-width: 1200px) {
    .auth-shell {
        grid-template-columns: 1fr;
    }

    .auth-brand-panel {
        padding: 1.6rem;
    }

    .auth-brand-panel__content {
        max-width: none;
    }

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

    .auth-content-panel {
        padding-top: 0.8rem;
    }
}

@media (max-width: 860px) {
    .auth-brand-panel {
        padding: 1.2rem;
    }

    .auth-feature-list {
        gap: 0.4rem;
    }

    .auth-metrics {
        grid-template-columns: 1fr;
    }

    .auth-card {
        border-radius: 18px;
        padding: 1rem;
    }

    .auth-form-section {
        padding: 0.7rem;
    }
}
.auth-brand-panel .brand-mark img {
    width: 68%;
    height: 68%;
    object-fit: contain;
    filter: drop-shadow(0 6px 10px rgba(3, 26, 18, 0.25));
}

.auth-card--login {
    width: min(500px, 100%);
}
@media (max-width: 980px) {
    .pos-catalog-toolbar {
        justify-content: flex-start;
    }

    .pos-density-control {
        width: 100%;
        justify-content: space-between;
    }
}

@media (max-width: 720px) {
    .pos-catalog-panel[data-pos-density="compact"] {
        --pos-card-min-width: 142px;
    }

    .pos-catalog-panel[data-pos-density="comfortable"] {
        --pos-card-min-width: 164px;
    }

    .pos-catalog-panel[data-pos-density="large"] {
        --pos-card-min-width: 198px;
    }

    .pos-density-control {
        padding: 0.35rem;
        border-radius: 12px;
        display: grid;
        gap: 0.32rem;
    }

    .pos-density-control__label {
        font-size: 0.74rem;
    }

    .pos-density-switch {
        width: 100%;
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.3rem;
    }

    .pos-density-btn {
        min-height: 34px;
        font-size: 0.72rem;
        padding-inline: 0.2rem;
    }
}

@media (max-width: 380px) {
    .pos-catalog-panel[data-pos-density="compact"] {
        --pos-card-min-width: 100%;
    }
}
/* POS full responsive balancing */
.pos-layout,
.pos-workspace,
.pos-catalog-panel,
.pos-side-stack,
.pos-bill-panel,
.pos-order-details,
.pos-table-picker {
    min-width: 0;
}

.pos-open-orders-list {
    max-height: 260px;
    overflow: auto;
}

@media (max-width: 1200px) {
    .pos-layout {
        gap: 0.82rem;
    }

    .pos-workspace {
        gap: 0.82rem;
    }

    .pos-side-stack {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        align-items: start;
    }

    .pos-bill-panel {
        grid-column: 1 / -1;
    }
}

@media (max-width: 980px) {
    .pos-workspace {
        order: 1;
    }

    .pos-head-grid {
        order: 2;
        gap: 0.72rem;
    }

    .pos-open-summary {
        display: none;
    }

    .pos-catalog-toolbar {
        width: 100%;
        justify-content: flex-start;
    }

    .pos-catalog-toolbar .btn {
        min-height: 36px;
        padding: 0.45rem 0.7rem;
    }
}

@media (max-width: 760px) {
    .pos-layout {
        gap: 0.64rem;
    }

    .pos-layout .panel {
        padding: 0.78rem;
        gap: 0.7rem;
    }

    .pos-counters {
        width: 100%;
    }

    .pos-counters .badge {
        font-size: 0.75rem;
    }

    .pos-order-form {
        gap: 0.62rem;
    }

    .pos-cart-list {
        max-height: min(34vh, 260px);
    }

    .pos-open-orders-list {
        max-height: 180px;
    }

    .pos-order-details {
        padding: 0.58rem;
    }

    .pos-order-details[open] {
        max-height: 50vh;
        overflow: auto;
    }

    .pos-table-card {
        min-height: 68px;
        padding: 0.5rem;
    }

    .pos-table-card strong {
        font-size: 0.88rem;
    }

    .pos-table-card small {
        font-size: 0.71rem;
    }

    .pos-side-stack {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .pos-layout .panel-header {
        flex-wrap: wrap;
        align-items: flex-start;
        gap: 0.45rem;
    }

    .pos-order-details[open] {
        max-height: 56vh;
    }

    .pos-action-grid {
        grid-template-columns: 1fr;
    }

    .pos-payment-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .pos-action-grid,
    .pos-payment-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 480px) {
    .pos-action-grid,
    .pos-payment-grid {
        grid-template-columns: 1fr;
    }
}

/* POS responsive priority pass (final overrides) */
@media (max-width: 1279.98px) {
    .pos-layout {
        gap: 0.82rem;
    }

    .pos-workspace {
        grid-template-columns: minmax(0, 1fr);
        gap: 0.82rem;
    }

    .pos-side-stack {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.82rem;
    }

    .pos-bill-panel {
        grid-column: 1 / -1;
    }
}

@media (max-width: 991.98px) {
    .pos-layout {
        gap: 0.72rem;
    }

    .pos-workspace {
        order: 1;
        gap: 0.72rem;
    }

    .pos-side-stack {
        order: 2;
        grid-template-columns: 1fr;
        gap: 0.72rem;
    }

    .pos-head-grid {
        order: 3;
        grid-template-columns: 1fr;
        gap: 0.68rem;
    }

    .pos-open-summary {
        display: none;
    }

    .pos-catalog-header {
        align-items: flex-start;
        gap: 0.62rem;
    }

    .pos-catalog-toolbar {
        width: 100%;
        justify-content: flex-start;
    }

    .pos-categories {
        flex-wrap: nowrap;
        overflow-x: auto;
        gap: 0.45rem;
        padding: 0.56rem;
        scrollbar-width: thin;
    }

    .pos-chip {
        flex: 0 0 auto;
    }

    .pos-order-mode-panels > .form-input,
    .pos-table-select-fallback {
        margin-bottom: 0;
    }
}

@media (max-width: 767.98px) {
    .pos-layout .panel {
        border-radius: 14px;
        padding: 0.72rem;
        gap: 0.62rem;
    }

    .pos-catalog-panel[data-pos-density="compact"] {
        --pos-grid-gap: 0.52rem;
        --pos-card-min-width: 124px;
        --pos-card-padding: 0.5rem;
        --pos-card-gap: 0.38rem;
        --pos-card-min-height: 160px;
        --pos-image-max-height: 68px;
        --pos-title-size: 0.78rem;
        --pos-category-size: 0.68rem;
        --pos-price-size: 0.8rem;
        --pos-add-btn-min-height: 38px;
    }

    .pos-catalog-panel[data-pos-density="comfortable"] {
        --pos-grid-gap: 0.62rem;
        --pos-card-min-width: 148px;
        --pos-card-padding: 0.58rem;
        --pos-card-gap: 0.48rem;
        --pos-card-min-height: 196px;
        --pos-image-max-height: 96px;
        --pos-title-size: 0.86rem;
        --pos-category-size: 0.72rem;
        --pos-price-size: 0.86rem;
        --pos-add-btn-min-height: 40px;
    }

    .pos-catalog-panel[data-pos-density="large"] {
        --pos-grid-gap: 0.72rem;
        --pos-card-min-width: 184px;
        --pos-card-padding: 0.7rem;
        --pos-card-gap: 0.58rem;
        --pos-card-min-height: 236px;
        --pos-image-max-height: 130px;
        --pos-title-size: 0.94rem;
        --pos-category-size: 0.76rem;
        --pos-price-size: 0.9rem;
        --pos-add-btn-min-height: 42px;
    }

    .pos-density-control {
        width: 100%;
        display: grid;
        gap: 0.32rem;
        border-radius: 12px;
        padding: 0.32rem;
    }

    .pos-density-switch {
        width: 100%;
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.3rem;
    }

    .pos-density-btn {
        min-height: 34px;
        padding-inline: 0.2rem;
        font-size: 0.72rem;
    }

    .pos-counters {
        width: 100%;
        gap: 0.35rem;
    }

    .pos-counters .badge {
        font-size: 0.72rem;
    }

    .pos-order-form {
        gap: 0.56rem;
    }

    .pos-cart-list {
        max-height: min(30vh, 220px);
    }

    .pos-open-orders-list {
        max-height: min(24vh, 170px);
    }

    .pos-summary {
        padding: 0.54rem 0;
        gap: 0.28rem;
    }

    .pos-summary > div {
        font-size: 0.84rem;
    }

    .pos-summary .is-total {
        font-size: 0.94rem;
    }

    .pos-order-details {
        padding: 0.56rem;
    }

    .pos-order-details summary {
        margin-bottom: 0.48rem;
        font-size: 0.88rem;
    }

    .pos-order-details[open] {
        max-height: 44vh;
        overflow: auto;
        padding-right: 0.24rem;
    }

    .pos-table-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.42rem;
    }

    .pos-table-card {
        min-height: 64px;
        padding: 0.44rem;
        border-radius: 10px;
    }

    .pos-table-card strong {
        font-size: 0.84rem;
    }

    .pos-table-card small {
        font-size: 0.68rem;
    }

    .pos-action-grid,
    .pos-payment-grid {
        gap: 0.38rem;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pos-action-btn,
    .pos-payment-chip,
    .pos-add-btn {
        min-height: 40px;
    }
}

@media (max-width: 575.98px) {
    .pos-layout .panel-header {
        flex-wrap: wrap;
        align-items: flex-start;
        gap: 0.36rem;
    }

    .pos-catalog-toolbar .btn {
        width: 100%;
    }

    .pos-density-control__label {
        font-size: 0.68rem;
    }

    .pos-density-btn {
        font-size: 0.68rem;
    }

    .pos-action-grid,
    .pos-payment-grid,
    .pos-table-grid {
        grid-template-columns: 1fr;
    }

    .pos-categories {
        gap: 0.36rem;
        padding: 0.5rem;
    }
}

@media (max-width: 399.98px) {
    .pos-catalog-panel[data-pos-density="compact"],
    .pos-catalog-panel[data-pos-density="comfortable"],
    .pos-catalog-panel[data-pos-density="large"] {
        --pos-card-min-width: 100%;
    }
}

/* Kitchen board */
.kitchen-shell {
    display: grid;
    gap: 0.85rem;
}

.kitchen-head {
    align-items: flex-start;
    gap: 0.7rem;
}

.kitchen-subtitle {
    margin: 0.25rem 0 0;
    color: var(--muted);
}

.kitchen-head-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.kitchen-sound-field {
    display: grid;
    gap: 0.2rem;
    min-width: 168px;
}

.kitchen-sound-field > span {
    font-size: 0.72rem;
    color: var(--muted);
    font-weight: 700;
}

.kitchen-sound-field .form-input {
    min-height: 34px;
    font-size: 0.78rem;
    padding-block: 0.36rem;
}
.kitchen-stats {
    display: grid;
    gap: 0.6rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.kitchen-stat-card {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: color-mix(in srgb, var(--primary), transparent 92%);
    padding: 0.6rem 0.7rem;
    display: grid;
    gap: 0.18rem;
}

.kitchen-stat-card span {
    font-size: 0.78rem;
    color: var(--muted);
}

.kitchen-stat-card strong {
    font-size: 1.15rem;
    line-height: 1.1;
}

.kitchen-feedback {
    min-height: 1.25rem;
    font-size: 0.86rem;
}

.kitchen-feedback.is-error {
    color: var(--danger);
}

.kitchen-feedback.is-success {
    color: var(--primary-strong);
}

.kitchen-feedback.is-muted {
    color: var(--muted);
}

.kitchen-meta {
    color: var(--muted);
    font-size: 0.82rem;
}

.kitchen-columns {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
}

.kitchen-lane {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: color-mix(in srgb, var(--primary), transparent 95%);
    padding: 0.65rem;
    display: grid;
    gap: 0.55rem;
    min-width: 0;
}

.kitchen-lane__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.55rem;
}

.kitchen-lane__header h4 {
    font-size: 0.96rem;
}

.kitchen-order-list {
    display: grid;
    gap: 0.55rem;
    align-content: start;
    max-height: calc(100vh - 300px);
    overflow: auto;
    min-height: 96px;
    padding-right: 0.18rem;
}

.kitchen-empty {
    border: 1px dashed var(--line);
    border-radius: 10px;
    padding: 0.58rem;
    margin: 0;
    color: var(--muted);
    font-size: 0.82rem;
    background: var(--bg-card);
}

.kitchen-order-card {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--bg-card);
    padding: 0.6rem;
    display: grid;
    gap: 0.44rem;
}

.kitchen-order-card[data-status='draft'] {
    border-color: color-mix(in srgb, var(--warning), transparent 45%);
    background: color-mix(in srgb, var(--warning), transparent 92%);
}

.kitchen-order-card[data-status='in_preparation'] {
    border-color: color-mix(in srgb, var(--info), transparent 45%);
    background: color-mix(in srgb, var(--info), transparent 93%);
}

.kitchen-order-card[data-status='ready'] {
    border-color: color-mix(in srgb, var(--primary), transparent 34%);
    background: color-mix(in srgb, var(--primary), transparent 90%);
}

.kitchen-order-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.kitchen-order-head h5 {
    font-size: 1rem;
    margin: 0;
}

.kitchen-order-meta {
    display: grid;
    gap: 0.18rem;
    color: var(--muted);
    font-size: 0.8rem;
}

.kitchen-order-notes {
    margin: 0;
    font-size: 0.82rem;
    color: var(--text);
}

.kitchen-order-items {
    margin: 0;
    padding-left: 1rem;
    display: grid;
    gap: 0.15rem;
    font-size: 0.84rem;
}

.kitchen-order-items li {
    color: var(--text);
}

.kitchen-order-footer {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.kitchen-action-btn {
    min-height: 38px;
}

@media (max-width: 1200px) {
    .kitchen-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

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

    .kitchen-lane[data-kitchen-lane='ready'] {
        grid-column: 1 / -1;
    }
}

@media (max-width: 860px) {
    .kitchen-columns {
        grid-template-columns: 1fr;
    }

    .kitchen-lane[data-kitchen-lane='ready'] {
        grid-column: auto;
    }

    .kitchen-order-list {
        max-height: none;
    }
}

@media (max-width: 620px) {
    .kitchen-head {
        flex-wrap: wrap;
    }

    .kitchen-head-actions {
        width: 100%;
    }

    .kitchen-head-actions .btn {
        flex: 1 1 0;
    }

    .kitchen-sound-field {
        min-width: 0;
        width: 100%;
    }

    .kitchen-stats {
        grid-template-columns: 1fr;
    }
}

/* Kitchen KDS TV mode */
.kitchen-head-actions [data-kitchen-tv-toggle].is-active {
    border-color: color-mix(in srgb, var(--primary), transparent 20%);
    background: color-mix(in srgb, var(--primary), transparent 82%);
}

body.kitchen-tv-mode {
    overflow: hidden;
}

body.kitchen-tv-mode .dashboard-shell {
    grid-template-columns: 1fr !important;
}

body.kitchen-tv-mode .app-sidebar,
body.kitchen-tv-mode .sidebar-backdrop,
body.kitchen-tv-mode .sidebar-mobile-controls {
    display: none !important;
}

body.kitchen-tv-mode .app-header {
    display: none;
}

body.kitchen-tv-mode .dashboard-content {
    padding: 0.65rem;
    gap: 0.65rem;
}

body.kitchen-tv-mode .kitchen-shell {
    margin: 0;
    min-height: calc(100vh - 1.3rem);
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode {
    border-radius: 18px;
    padding: 0.95rem;
    gap: 0.95rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-head h3 {
    font-size: 1.55rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-subtitle {
    font-size: 1.02rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-stats {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-stat-card {
    padding: 0.85rem 0.95rem;
    border-radius: 14px;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-stat-card span {
    font-size: 0.92rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-stat-card strong {
    font-size: 1.7rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-columns {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.95rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-lane {
    border-radius: 16px;
    padding: 0.88rem;
    gap: 0.7rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-lane__header h4 {
    font-size: 1.18rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-lane__header .badge {
    font-size: 0.9rem;
    padding: 0.35rem 0.55rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-order-list {
    max-height: calc(100vh - 325px);
    gap: 0.72rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-order-card {
    border-radius: 14px;
    padding: 0.9rem;
    gap: 0.6rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-order-head h5 {
    font-size: 1.32rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-order-meta {
    font-size: 0.96rem;
    gap: 0.26rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-order-notes {
    font-size: 0.95rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-order-items {
    font-size: 1rem;
    gap: 0.22rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-order-footer {
    gap: 0.55rem;
}

body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-order-footer .btn,
body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-action-btn {
    min-height: 48px;
    font-size: 0.98rem;
    padding: 0.72rem 0.95rem;
}

@media (max-width: 1360px) {
    body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-columns {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 920px) {
    body.kitchen-tv-mode {
        overflow: auto;
    }

    body.kitchen-tv-mode .dashboard-content {
        padding: 0.5rem;
    }

    body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-stats,
    body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-columns {
        grid-template-columns: 1fr;
    }

    body.kitchen-tv-mode .kitchen-shell.is-tv-mode .kitchen-order-list {
        max-height: none;
    }
}



/* CRUD standardization */
.btn-secondary {
    color: var(--text);
    background: color-mix(in srgb, var(--primary), transparent 88%);
    border: 1px solid color-mix(in srgb, var(--primary), transparent 65%);
}

.btn-ghost {
    color: var(--text);
    background: transparent;
    border: 1px solid var(--line);
}

.btn-danger {
    color: #fff;
    background: linear-gradient(145deg, color-mix(in srgb, var(--danger), white 10%), var(--danger));
}

.btn-sm {
    padding: 0.44rem 0.6rem;
    font-size: 0.8rem;
    border-radius: 10px;
}

.crud-shell {
    gap: 0.85rem;
}

.crud-header {
    align-items: flex-start;
    gap: 0.8rem;
    flex-wrap: wrap;
}

.crud-title-group {
    display: grid;
    gap: 0.2rem;
}

.crud-title-group h3 {
    margin: 0;
}

.crud-header-actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-left: auto;
}

.crud-actions-cell {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.crud-inline-form {
    margin: 0;
    display: inline-flex;
}

.crud-form-grid {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.crud-form-grid .form-input,
.app-modal .form-input {
    margin-bottom: 0;
}

.app-modal {
    position: fixed;
    inset: 0;
    z-index: 72;
    display: grid;
    place-items: center;
    padding: 1rem;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.22s ease, visibility 0.22s ease;
}

.app-modal[hidden] {
    display: none !important;
}

.app-modal.is-active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.app-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(8, 20, 16, 0.66);
}

.app-modal__dialog {
    position: relative;
    width: min(760px, 100%);
    max-height: calc(100vh - 2rem);
    z-index: 1;
    transform: translateY(12px) scale(0.99);
    transition: transform 0.24s ease;
}

.app-modal.is-active .app-modal__dialog {
    transform: translateY(0) scale(1);
}

.app-modal__dialog--wide {
    width: min(1080px, 100%);
}

.app-modal__form {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    max-height: calc(100vh - 2rem);
    background: var(--bg-layer);
    border: 1px solid var(--line);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: var(--shadow);
}

.app-modal__header,
.app-modal__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    padding: 0.85rem 1rem;
    border-bottom: 1px solid var(--line);
}

.app-modal__footer {
    border-top: 1px solid var(--line);
    border-bottom: 0;
    justify-content: flex-end;
}

.app-modal__header h3 {
    margin: 0;
    font-size: 1.02rem;
}

.app-modal__body {
    padding: 0.95rem 1rem;
    overflow: auto;
    display: grid;
    gap: 0.8rem;
}

.purchase-item-stack {
    display: grid;
    gap: 0.55rem;
}

@media (max-width: 900px) {
    .crud-form-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 680px) {
    .crud-header-actions {
        width: 100%;
        margin-left: 0;
    }

    .crud-header-actions .btn {
        flex: 1 1 auto;
    }

    .app-modal {
        padding: 0.7rem;
    }

    .app-modal__header,
    .app-modal__body,
    .app-modal__footer {
        padding-inline: 0.75rem;
    }
}

body.modal-open {
    overflow: hidden;
}


.form-field {
    display: grid;
    gap: 0.35rem;
}

.form-field .form-label {
    margin-bottom: 0;
}


/* Super Admin panel */
.super-admin-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 280px 1fr;
}

.super-admin-main {
    min-width: 0;
    display: grid;
    grid-template-rows: auto 1fr;
}

.super-admin-content {
    padding: 1.25rem;
    display: grid;
    gap: 1rem;
}

.super-admin-sidebar {
    border-right: 1px solid var(--line);
}

.super-admin-pill {
    border: 1px solid var(--line);
    background: color-mix(in srgb, var(--primary), transparent 90%);
}

.super-admin-stats-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.super-admin-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.super-admin-filter-row {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin-bottom: 1rem;
    max-width: 420px;
}

.inline-form {
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.super-admin-actions-col {
    display: grid;
    gap: 0.45rem;
}

.super-admin-inline-form-stack {
    display: grid;
    gap: 0.35rem;
    margin: 0;
}

.super-admin-message-card {
    margin-top: 0.9rem;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--bg-card);
    padding: 0.9rem;
    display: grid;
    gap: 0.55rem;
}

.super-admin-replies-list {
    display: grid;
    gap: 0.75rem;
}

.super-admin-reply-item {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--bg-card);
    padding: 0.8rem;
    display: grid;
    gap: 0.45rem;
}

.super-admin-reply-item header {
    display: flex;
    justify-content: space-between;
    gap: 0.4rem;
}

.super-admin-danger-zone {
    margin-top: 0.8rem;
    border: 1px solid color-mix(in srgb, var(--danger), transparent 60%);
    background: color-mix(in srgb, var(--danger), transparent 94%);
    border-radius: 12px;
    padding: 0.8rem;
    display: grid;
    gap: 0.55rem;
}

.super-admin-danger-zone h4 {
    margin: 0;
}

@media (max-width: 1200px) {
    .super-admin-stats-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .super-admin-shell {
        grid-template-columns: 1fr;
    }

    .super-admin-sidebar {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: min(320px, 86vw);
        z-index: 41;
        transform: translateX(-100%);
        transition: transform 0.22s ease;
        border-right: 1px solid var(--line);
    }

    body.sidebar-mobile-open .super-admin-sidebar {
        transform: translateX(0);
    }

    .super-admin-content {
        padding: 1rem;
    }
}

@media (max-width: 900px) {
    .super-admin-stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .super-admin-form-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 680px) {
    .super-admin-stats-grid {
        grid-template-columns: 1fr;
    }

    .super-admin-filter-row {
        max-width: none;
        flex-direction: column;
        align-items: stretch;
    }
}

body.sidebar-collapsed .super-admin-shell {
    grid-template-columns: 96px 1fr;
}

body.sidebar-collapsed .super-admin-sidebar {
    width: 96px;
}

@media (max-width: 991.98px) {
    body.sidebar-collapsed .super-admin-shell {
        grid-template-columns: 1fr;
    }

    body.sidebar-collapsed .super-admin-sidebar {
        width: min(320px, 86vw);
    }
}

/* Sidebar secondary link */
.sidebar-secondary {
    margin-top: 0.35rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--line);
    display: grid;
    gap: 0.3rem;
}

.menu-item--secondary {
    border: 1px dashed color-mix(in srgb, var(--primary), transparent 55%);
    background: color-mix(in srgb, var(--primary), transparent 93%);
}

body.sidebar-collapsed .sidebar-secondary {
    padding-top: 0.58rem;
}

/* In-app documentation */
.docs-shell {
    gap: 1rem;
}

.docs-head {
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
}

.docs-head-actions {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.docs-search-input {
    width: min(360px, 100%);
    margin-bottom: 0;
}

.docs-nav-toggle {
    display: none;
}

.docs-layout {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(260px, 280px) minmax(0, 1fr);
}

.docs-nav {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: color-mix(in srgb, var(--primary), transparent 94%);
    padding: 0.8rem;
    display: grid;
    gap: 0.65rem;
    align-content: start;
    position: sticky;
    top: 86px;
    max-height: calc(100vh - 130px);
    overflow: auto;
}

.docs-nav-title {
    font-size: 0.78rem;
    font-weight: 800;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.docs-nav-list {
    display: grid;
    gap: 0.42rem;
}

.docs-nav-item {
    border: 1px solid transparent;
    border-radius: 12px;
    padding: 0.55rem 0.62rem;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.55rem;
    align-items: flex-start;
    color: var(--text);
    background: transparent;
}

.docs-nav-item:hover {
    text-decoration: none;
    border-color: color-mix(in srgb, var(--primary), transparent 60%);
    background: color-mix(in srgb, var(--primary), transparent 90%);
}

.docs-nav-item.is-active {
    border-color: color-mix(in srgb, var(--primary), transparent 40%);
    background: color-mix(in srgb, var(--primary), transparent 84%);
}

.docs-nav-item__icon {
    width: 24px;
    height: 24px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--primary), transparent 78%);
    color: var(--primary-strong);
    font-size: 0.78rem;
    margin-top: 0.05rem;
}

.docs-nav-item strong {
    display: block;
    font-size: 0.88rem;
    line-height: 1.2;
}

.docs-nav-item small {
    display: block;
    margin-top: 0.18rem;
    font-size: 0.75rem;
    color: var(--muted);
    line-height: 1.35;
}

.docs-content {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: color-mix(in srgb, var(--primary), transparent 95%);
    padding: 1rem;
    display: grid;
    gap: 0.85rem;
}

.docs-page-head {
    display: grid;
    gap: 0.45rem;
}

.docs-page-head h2 {
    font-size: 1.35rem;
    line-height: 1.2;
}

.docs-page-head p {
    color: var(--muted);
}

.docs-block {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--bg-layer);
    padding: 0.85rem;
    display: grid;
    gap: 0.48rem;
}

.docs-block h3 {
    font-size: 1rem;
}

.docs-block p {
    color: var(--muted);
    line-height: 1.5;
}

.docs-list {
    margin: 0;
    padding-left: 1.15rem;
    display: grid;
    gap: 0.32rem;
    color: var(--muted);
}

.docs-list--ordered {
    padding-left: 1.2rem;
}

.docs-list li {
    line-height: 1.45;
}

.docs-list strong {
    color: var(--text);
}

.docs-tip {
    border-style: dashed;
    background: color-mix(in srgb, var(--primary), transparent 90%);
}

.docs-cta {
    border-top: 1px solid var(--line);
    padding-top: 0.8rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.docs-cta p {
    color: var(--muted);
}

.docs-empty-search {
    margin: 0;
    border: 1px dashed color-mix(in srgb, var(--warning), transparent 50%);
    border-radius: 10px;
    background: color-mix(in srgb, var(--warning), transparent 90%);
    color: color-mix(in srgb, var(--text), var(--warning) 25%);
    padding: 0.62rem 0.72rem;
}

@media (max-width: 1200px) {
    .docs-layout {
        grid-template-columns: minmax(220px, 260px) minmax(0, 1fr);
    }
}

@media (max-width: 991.98px) {
    .sidebar-secondary {
        margin-top: 0.55rem;
    }

    .docs-layout {
        grid-template-columns: 1fr;
    }

    .docs-nav-toggle {
        display: inline-flex;
    }

    .docs-nav {
        display: none;
        position: static;
        max-height: none;
    }

    .docs-nav.is-open {
        display: grid;
    }
}

@media (max-width: 640px) {
    .docs-head-actions {
        width: 100%;
    }

    .docs-search-input {
        width: 100%;
    }

    .docs-nav-toggle {
        width: 100%;
        justify-content: center;
    }

    .docs-content,
    .docs-block {
        padding: 0.75rem;
    }
}

/* Onboarding + Help center */
.sidebar-aux-links {
    margin-top: 0.35rem;
    padding-top: 0.7rem;
    border-top: 1px solid var(--line);
}

.menu-item--help {
    border: 1px solid color-mix(in srgb, var(--primary), transparent 70%);
    background: color-mix(in srgb, var(--primary), transparent 92%);
    font-weight: 700;
}

.menu-item--help.is-active {
    border-color: color-mix(in srgb, var(--primary), transparent 42%);
    background: color-mix(in srgb, var(--primary), transparent 84%);
}

.title-with-help {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.help-tip-trigger {
    width: 24px;
    height: 24px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--primary), transparent 56%);
    background: color-mix(in srgb, var(--primary), transparent 88%);
    color: var(--primary-strong);
    font-weight: 800;
    font-size: 0.78rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
}

.help-tip-trigger:hover {
    background: color-mix(in srgb, var(--primary), transparent 82%);
}

.context-help-popover {
    position: absolute;
    z-index: 94;
    width: min(320px, calc(100vw - 24px));
    border-radius: 14px;
    border: 1px solid var(--line);
    background: var(--bg-layer);
    box-shadow: var(--shadow);
    padding: 0.7rem 0.8rem;
    display: grid;
    gap: 0.35rem;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.context-help-popover h5 {
    margin: 0;
    font-size: 0.9rem;
}

.context-help-popover p {
    margin: 0;
    font-size: 0.84rem;
    color: var(--muted);
    line-height: 1.45;
}

.context-help-popover.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.dashboard-onboarding-host {
    display: grid;
    gap: 1rem;
}

.onboarding-checklist-panel {
    background: linear-gradient(165deg, color-mix(in srgb, var(--primary), transparent 91%), var(--bg-layer));
}

.onboarding-checklist-panel__subtitle,
.onboarding-checklist-panel__progress-text {
    color: var(--muted);
    font-size: 0.88rem;
}

.onboarding-progress-bar {
    width: 100%;
    height: 9px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--primary), transparent 88%);
    border: 1px solid color-mix(in srgb, var(--primary), transparent 74%);
    overflow: hidden;
}

.onboarding-progress-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(145deg, var(--primary), var(--primary-strong));
    transition: width 0.22s ease;
}

.onboarding-checklist {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.45rem;
}

.onboarding-checklist li {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
}

.onboarding-checklist li.is-done {
    color: var(--primary-strong);
    font-weight: 700;
}

.onboarding-checklist__state {
    width: 20px;
    display: inline-flex;
    justify-content: center;
}

.onboarding-root {
    position: relative;
    z-index: 88;
}

.onboarding-welcome,
.onboarding-tour {
    position: fixed;
    inset: 0;
    z-index: 92;
}

.onboarding-welcome__backdrop,
.onboarding-tour__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(6, 16, 13, 0.7);
}

.onboarding-welcome__card {
    position: relative;
    width: min(620px, calc(100vw - 32px));
    margin: min(12vh, 120px) auto 0;
    border-radius: 20px;
    border: 1px solid var(--line);
    background: var(--bg-layer);
    box-shadow: var(--shadow);
    padding: 1.1rem;
    display: grid;
    gap: 0.8rem;
    animation: onboarding-pop 0.24s ease;
}

.onboarding-welcome__eyebrow {
    color: var(--primary-strong);
    font-weight: 800;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.onboarding-welcome__steps {
    margin: 0;
    padding-left: 1.1rem;
    display: grid;
    gap: 0.35rem;
}

.onboarding-welcome__actions {
    display: flex;
    gap: 0.55rem;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.onboarding-tour__spotlight {
    position: fixed;
    border-radius: 14px;
    border: 2px solid color-mix(in srgb, #fff, var(--primary) 26%);
    box-shadow:
        0 0 0 9999px rgba(6, 16, 13, 0.62),
        0 16px 36px rgba(0, 0, 0, 0.35);
    transition: all 0.2s ease;
    pointer-events: none;
}

.onboarding-tour__card {
    position: fixed;
    width: min(360px, calc(100vw - 26px));
    border-radius: 16px;
    border: 1px solid var(--line);
    background: var(--bg-layer);
    box-shadow: var(--shadow);
    padding: 0.95rem;
    display: grid;
    gap: 0.7rem;
    animation: onboarding-pop 0.22s ease;
}

.onboarding-tour__meta {
    margin: 0;
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 700;
}

.onboarding-tour__card h4 {
    margin: 0;
    font-size: 1rem;
}

.onboarding-tour__card p {
    margin: 0;
    color: var(--muted);
    line-height: 1.45;
    font-size: 0.88rem;
}

.onboarding-tour__actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.onboarding-tour-target-active {
    position: relative;
    z-index: 93;
    border-radius: 10px;
}

@keyframes onboarding-pop {
    from {
        opacity: 0;
        transform: translateY(8px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.docs-shell {
    gap: 1rem;
}

.docs-shell__header p {
    margin-top: 0.2rem;
    color: var(--muted);
}

.docs-layout {
    display: grid;
    grid-template-columns: minmax(220px, 260px) minmax(0, 1fr);
    gap: 0.9rem;
}

.docs-nav {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: color-mix(in srgb, var(--primary), transparent 94%);
    padding: 0.55rem;
    display: grid;
    gap: 0.3rem;
    align-content: start;
}

.docs-nav__item {
    border: 1px solid transparent;
    border-radius: 10px;
    padding: 0.55rem;
    display: grid;
    gap: 0.2rem;
    color: var(--text);
}

.docs-nav__item:hover {
    text-decoration: none;
    border-color: color-mix(in srgb, var(--primary), transparent 74%);
    background: color-mix(in srgb, var(--primary), transparent 88%);
}

.docs-nav__item.is-active {
    border-color: color-mix(in srgb, var(--primary), transparent 55%);
    background: color-mix(in srgb, var(--primary), transparent 82%);
}

.docs-nav__title {
    font-size: 0.9rem;
    font-weight: 700;
}

.docs-nav__summary {
    font-size: 0.77rem;
    color: var(--muted);
    line-height: 1.35;
}

.docs-content {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--bg-layer);
    padding: 0.95rem;
    display: grid;
    gap: 0.72rem;
}

.docs-content__eyebrow {
    color: var(--primary-strong);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 0.74rem;
}

.docs-content__points {
    margin: 0;
    padding-left: 1.1rem;
    display: grid;
    gap: 0.3rem;
    color: var(--muted);
}

.docs-content__tip {
    border: 1px dashed color-mix(in srgb, var(--primary), transparent 52%);
    border-radius: 10px;
    background: color-mix(in srgb, var(--primary), transparent 92%);
    padding: 0.62rem 0.68rem;
}

.docs-content__actions {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
}

@media (max-width: 991.98px) {
    .docs-layout {
        grid-template-columns: 1fr;
    }

    .context-help-popover {
        position: fixed;
        left: 12px;
        right: 12px;
        bottom: 12px;
        width: auto;
    }
}

@media (max-width: 680px) {
    .onboarding-tour__actions,
    .onboarding-welcome__actions,
    .docs-content__actions {
        width: 100%;
    }

    .onboarding-tour__actions .btn,
    .onboarding-welcome__actions .btn,
    .docs-content__actions .btn {
        flex: 1 1 0;
    }
}

/* AI assistant */
.ai-insights-panel {
    background: linear-gradient(160deg, color-mix(in srgb, var(--primary), transparent 92%), var(--bg-layer));
}

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

.ai-insight-card {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 0.75rem;
    background: var(--bg-card);
    display: grid;
    gap: 0.35rem;
}

.ai-insight-card h4 {
    margin: 0;
    font-size: 0.9rem;
}

.ai-insight-card p {
    margin: 0;
    font-size: 0.84rem;
    color: var(--muted);
    line-height: 1.45;
}

.ai-insight-card.level-info {
    border-color: color-mix(in srgb, var(--info), transparent 56%);
    background: color-mix(in srgb, var(--info), transparent 92%);
}

.ai-insight-card.level-success {
    border-color: color-mix(in srgb, var(--success), transparent 54%);
    background: color-mix(in srgb, var(--success), transparent 92%);
}

.ai-insight-card.level-warning {
    border-color: color-mix(in srgb, var(--warning), transparent 50%);
    background: color-mix(in srgb, var(--warning), transparent 92%);
}

.ai-assistant {
    position: fixed;
    right: clamp(12px, 2vw, 24px);
    bottom: clamp(12px, 2vw, 24px);
    z-index: 96;
    pointer-events: none;
}

.ai-assistant__fab {
    pointer-events: auto;
    width: 56px;
    height: 56px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--primary), transparent 25%);
    background: linear-gradient(145deg, var(--primary), var(--primary-strong));
    color: #f5fff9;
    font-weight: 800;
    font-size: 0.95rem;
    box-shadow: 0 14px 28px rgba(3, 22, 16, 0.32);
    cursor: pointer;
}

.ai-assistant__fab:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--primary), white 18%);
    outline-offset: 2px;
}

.ai-assistant__panel {
    pointer-events: auto;
    width: min(420px, calc(100vw - 24px));
    max-height: min(76vh, 720px);
    margin-top: 0.7rem;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: var(--bg-layer);
    box-shadow: var(--shadow);
    overflow: hidden;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto auto;
    transform-origin: right bottom;
    animation: ai-assistant-pop 0.2s ease;
}

.ai-assistant__panel[hidden] {
    display: none !important;
}

.ai-assistant__header {
    padding: 0.78rem 0.85rem;
    border-bottom: 1px solid var(--line);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    background: color-mix(in srgb, var(--primary), transparent 94%);
}

.ai-assistant__header h4 {
    margin: 0;
    font-size: 0.96rem;
}

.ai-assistant__header p {
    margin: 0.2rem 0 0;
    color: var(--muted);
    font-size: 0.78rem;
}

.ai-assistant__messages {
    padding: 0.75rem;
    overflow: auto;
    min-height: 220px;
    max-height: 46vh;
    display: grid;
    gap: 0.52rem;
    align-content: start;
    background:
        radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--primary), transparent 93%), transparent 42%),
        var(--bg-layer);
}

.ai-assistant__message {
    display: flex;
}

.ai-assistant__message--assistant {
    justify-content: flex-start;
}

.ai-assistant__message--user {
    justify-content: flex-end;
}

.ai-assistant__bubble {
    max-width: min(94%, 320px);
    border-radius: 13px;
    border: 1px solid var(--line);
    background: var(--bg-card);
    padding: 0.58rem 0.66rem;
    font-size: 0.84rem;
    line-height: 1.45;
}

.ai-assistant__message--assistant .ai-assistant__bubble {
    border-color: color-mix(in srgb, var(--primary), transparent 75%);
    background: color-mix(in srgb, var(--primary), transparent 93%);
}

.ai-assistant__message--user .ai-assistant__bubble {
    border-color: color-mix(in srgb, var(--info), transparent 70%);
    background: color-mix(in srgb, var(--info), transparent 92%);
}

.ai-assistant__bubble--typing {
    color: var(--muted);
    font-style: italic;
}

.ai-assistant__cards {
    display: grid;
    gap: 0.45rem;
}

.ai-assistant__card {
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 0.5rem 0.55rem;
    background: var(--bg-layer);
    display: grid;
    gap: 0.2rem;
}

.ai-assistant__card h6 {
    margin: 0;
    font-size: 0.8rem;
}

.ai-assistant__card p {
    margin: 0;
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.4;
}

.ai-assistant__card--info {
    border-color: color-mix(in srgb, var(--info), transparent 60%);
}

.ai-assistant__card--success {
    border-color: color-mix(in srgb, var(--success), transparent 58%);
}

.ai-assistant__card--warning {
    border-color: color-mix(in srgb, var(--warning), transparent 55%);
}

.ai-assistant__quick {
    padding: 0 0.75rem 0.6rem;
    display: flex;
    gap: 0.35rem;
    flex-wrap: wrap;
    border-top: 1px solid var(--line);
}

.ai-assistant__quick .chip {
    cursor: pointer;
}

.ai-assistant__form {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0.45rem;
    padding: 0.6rem 0.75rem 0.75rem;
    border-top: 1px solid var(--line);
}

.ai-assistant__form .form-input {
    margin: 0;
}

.ai-assistant__form.is-loading [data-ai-send] {
    opacity: 0.78;
    cursor: progress;
}

@keyframes ai-assistant-pop {
    from {
        opacity: 0;
        transform: translateY(8px) scale(0.98);
    }

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

@media (max-width: 1199px) {
    .ai-insights-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .ai-assistant {
        right: 10px;
        bottom: 10px;
        left: 10px;
        display: grid;
        justify-items: end;
    }

    .ai-assistant__panel {
        width: min(100%, 100vw - 20px);
        max-height: 76vh;
    }

    .ai-assistant__messages {
        max-height: 42vh;
    }
}
