:root {
    --font-sans: "Inter", "Segoe UI", sans-serif;
    --font-display: "Space Grotesk", "Segoe UI", sans-serif;
    --bg: #f3efe7;
    --bg-elevated: rgba(255, 255, 255, 0.84);
    --bg-strong: #ffffff;
    --bg-accent: #113c48;
    --surface: #fffaf2;
    --surface-muted: #ece4d7;
    --surface-contrast: #0e2230;
    --text: #10212b;
    --text-muted: #5f6d73;
    --text-inverse: #f8f7f4;
    --line: rgba(16, 33, 43, 0.11);
    --line-strong: rgba(16, 33, 43, 0.2);
    --primary: #006d77;
    --primary-strong: #00515a;
    --accent: #d97706;
    --success: #0d8b63;
    --warning: #c77f16;
    --danger: #c24130;
    --shadow: 0 24px 80px rgba(18, 37, 46, 0.12);
    --radius-xl: 28px;
    --radius-lg: 20px;
    --radius-md: 14px;
    --sidebar-width: 296px;
}

[data-theme="dark"] {
    --bg: #0d1317;
    --bg-elevated: rgba(18, 25, 31, 0.92);
    --bg-strong: #12191f;
    --bg-accent: #d1fff3;
    --surface: #151e24;
    --surface-muted: #1b262d;
    --surface-contrast: #edf6f7;
    --text: #eef4f3;
    --text-muted: #9fb0b3;
    --text-inverse: #081014;
    --line: rgba(255, 255, 255, 0.08);
    --line-strong: rgba(255, 255, 255, 0.14);
    --primary: #66c7bf;
    --primary-strong: #8ae0da;
    --accent: #f5a524;
    --success: #50c99c;
    --warning: #f0b24d;
    --danger: #ff8378;
    --shadow: 0 24px 80px rgba(0, 0, 0, 0.34);
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    min-height: 100%;
    font-family: var(--font-sans);
    background:
        radial-gradient(circle at top left, rgba(0,109,119,.16), transparent 28%),
        radial-gradient(circle at top right, rgba(217,119,6,.12), transparent 22%),
        linear-gradient(180deg, var(--bg), color-mix(in srgb, var(--bg) 80%, white));
    color: var(--text);
    font-size: 15px;
    line-height: 1.5;
}

[hidden] { display: none !important; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }

svg.lucide,
i[data-lucide],
.icon-button svg,
.nav-link svg,
.status-banner svg,
.search-trigger svg {
    width: 1.05rem;
    height: 1.05rem;
    stroke-width: 2;
    flex-shrink: 0;
}

.app-shell { display: grid; grid-template-columns: var(--sidebar-width) 1fr; min-height: 100vh; }

.app-sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    overflow: auto;
    padding: 1.25rem;
    background: color-mix(in srgb, var(--bg-strong) 86%, transparent);
    border-right: 1px solid var(--line);
    backdrop-filter: blur(18px);
}

.brand-lockup,
.drawer-head,
.app-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

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

.app-topbar {
    position: sticky;
    top: 0;
    z-index: 10;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--line);
    background: color-mix(in srgb, var(--bg-elevated) 94%, transparent);
    backdrop-filter: blur(22px);
}

.topbar-left,
.topbar-right,
.drawer-actions,
.pagination-bar__actions,
.page-actions,
.toolbar,
.metric-grid,
.filter-grid,
.inline-actions {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.stack { display: grid; gap: 0.85rem; }
.topbar-left { min-width: 0; }
.app-content { padding: 1.4rem; }
.page-shell { display: grid; gap: 1.4rem; }
.page-actions { flex-wrap: wrap; }
.split-grid { display: grid; grid-template-columns: 2.1fr 1fr; gap: 1rem; }
.three-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1rem; }
.customer-product-grid { grid-template-columns: repeat(4, minmax(0,1fr)); }
.two-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; }
.pagination-bar { display: flex; justify-content: space-between; gap: 1rem; align-items: center; padding-top: 1rem; }
.desktop-hidden,
.mobile-only { display: none; }

.brand-mark { display: flex; gap: 0.9rem; align-items: center; }

.brand-mark__glyph {
    display: inline-flex;
    width: 3rem;
    height: 3rem;
    border-radius: 1rem;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    color: white;
    font-weight: 800;
    font-family: var(--font-display);
}

.brand-mark__logo-shell {
    display: inline-flex;
    width: 3rem;
    height: 3rem;
    border-radius: 1rem;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: color-mix(in srgb, var(--surface) 82%, var(--bg-strong));
    border: 1px solid var(--line);
}

.brand-mark__logo {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 0.35rem;
}

.brand-mark__logo--dark {
    display: none;
}

html[data-theme="dark"] .brand-mark__logo--light {
    display: none;
}

html[data-theme="dark"] .brand-mark__logo--dark {
    display: block;
}

.brand-mark strong,
.user-chip strong {
    display: block;
    font-family: var(--font-display);
}

.brand-mark small,
.user-chip small,
.nav-label,
.field-help,
.metric-card small,
.empty-state p,
.table-caption,
.panel-meta,
.eyebrow {
    color: var(--text-muted);
}

.nav-cluster { margin-top: 1.75rem; display: grid; gap: 0.35rem; }
.nav-label { margin: 0 0 0.3rem; font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; }

.nav-link,
.secondary-link {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    padding: 0.9rem 1rem;
    border-radius: 1rem;
    color: var(--text-muted);
    transition: .2s ease;
}

.nav-link:hover,
.secondary-link:hover,
.nav-link.is-active {
    background: color-mix(in srgb, var(--surface) 78%, var(--primary) 22%);
    color: var(--text);
}

.nav-link.is-active { box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary) 32%, transparent); }
.sidebar-footer { margin-top: 2rem; display: grid; gap: 0.9rem; }
.status-banner { display: flex; gap: 0.75rem; align-items: center; padding: 0.9rem 1rem; border-radius: 1rem; border: 1px solid var(--line); }
.status-banner--warning { background: color-mix(in srgb, var(--accent) 12%, var(--bg-strong)); }

.search-trigger {
    display: inline-flex;
    align-items: center;
    gap: 0.9rem;
    min-width: min(38rem, 56vw);
    justify-content: space-between;
    background: var(--bg-strong);
    border: 1px solid var(--line);
    color: var(--text-muted);
    border-radius: 999px;
    padding: 0.8rem 1rem;
    box-shadow: var(--shadow);
}

.search-trigger span { margin-right: auto; text-align: left; }

.search-trigger kbd {
    border: 1px solid var(--line);
    border-bottom-width: 2px;
    border-radius: 0.65rem;
    padding: 0.25rem 0.55rem;
    font-size: 0.78rem;
    color: var(--text-muted);
    background: var(--surface);
}

.user-chip { display: flex; gap: 0.8rem; align-items: center; }
.user-chip--button { cursor: pointer; list-style: none; }
.user-chip--button::-webkit-details-marker { display: none; }

.user-chip__avatar {
    display: inline-flex;
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 999px;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--primary), color-mix(in srgb, var(--primary) 40%, var(--accent)));
    color: white;
    font-weight: 700;
}

.user-chip__avatar--image {
    object-fit: cover;
    border: 1px solid var(--line);
    background: var(--surface);
}

.user-menu {
    position: relative;
}

.user-menu__panel {
    position: absolute;
    right: 0;
    top: calc(100% + 0.65rem);
    width: min(18rem, 86vw);
    display: none;
    background: color-mix(in srgb, var(--bg-strong) 97%, transparent);
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 0.8rem;
    z-index: 25;
}

.user-menu[open] .user-menu__panel { display: grid; gap: 0.5rem; }

.user-menu__link {
    display: block;
    width: 100%;
    padding: 0.65rem 0.8rem;
    border: 1px solid var(--line);
    border-radius: 0.8rem;
    color: var(--text);
    background: color-mix(in srgb, var(--surface) 88%, var(--bg-strong));
    text-align: left;
}

.user-menu__link:hover {
    background: color-mix(in srgb, var(--surface) 76%, var(--primary) 14%);
}

.user-menu__link--button {
    cursor: pointer;
    font: inherit;
}

.page-hero {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 1.5rem 1.6rem;
    border-radius: var(--radius-xl);
    background: linear-gradient(135deg, color-mix(in srgb, var(--bg-strong) 92%, white), color-mix(in srgb, var(--surface) 88%, var(--primary) 12%));
    border: 1px solid var(--line);
    box-shadow: var(--shadow);
}

.page-hero h1,
.hero-title {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(1.45rem, 2.1vw, 2.3rem);
}

.page-hero p { margin: 0.4rem 0 0; max-width: 48rem; color: var(--text-muted); }

.panel,
.metric-card,
.table-card,
.form-card,
.detail-card,
.auth-card,
.drawer-body,
.command-card {
    background: color-mix(in srgb, var(--bg-strong) 96%, transparent);
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
}

.panel,
.table-card,
.form-card,
.detail-card,
.auth-card { padding: 1.4rem; }

.panel-head,
.table-card__head,
.form-card__head,
.detail-card__head,
.section-title {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    margin-bottom: 1rem;
}

.section-title h2,
.panel-head h2,
.table-card__head h2,
.form-card__head h2,
.detail-card__head h2 {
    margin: 0;
    font-family: var(--font-display);
    font-size: 1.02rem;
}

.metric-grid { flex-wrap: wrap; align-items: stretch; }
.metric-grid--cards { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 1rem; }
.metric-card { padding: 1.2rem; display: grid; gap: 0.6rem; min-height: 9rem; }
.metric-card strong { font-size: 1.6rem; font-family: var(--font-display); }

.metric-card__icon {
    width: 3rem;
    height: 3rem;
    border-radius: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--primary) 16%, var(--bg-strong));
}

.table-card { overflow: hidden; }
.table-scroll { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; }
th, td { padding: 0.95rem 0.85rem; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
th { font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); }
tbody tr:hover { background: color-mix(in srgb, var(--surface) 74%, var(--primary) 6%); }

.badge,
.status-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.38rem 0.72rem;
    border-radius: 999px;
    border: 1px solid var(--line);
    font-size: 0.82rem;
    font-weight: 700;
}

.status-pill--positive { background: color-mix(in srgb, var(--success) 12%, var(--bg-strong)); color: var(--success); }
.status-pill--warning { background: color-mix(in srgb, var(--warning) 14%, var(--bg-strong)); color: var(--warning); }
.status-pill--danger { background: color-mix(in srgb, var(--danger) 12%, var(--bg-strong)); color: var(--danger); }
.status-pill--accent { background: color-mix(in srgb, var(--primary) 12%, var(--bg-strong)); color: var(--primary); }
.status-pill--neutral,
.status-pill--muted { background: color-mix(in srgb, var(--surface) 86%, var(--bg-strong)); color: var(--text-muted); }

.detail-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; align-items: stretch; }
.detail-item { padding: 1rem; border-radius: 1rem; border: 1px solid var(--line); background: color-mix(in srgb, var(--surface) 82%, var(--bg-strong)); }
.detail-item strong { display: block; margin-bottom: 0.35rem; }
.detail-card--nested { padding: 0; border: 0; box-shadow: none; background: transparent; }

.customer-variant-list { gap: 1.35rem; }

.customer-variant-card {
    padding: 1.35rem;
    border-color: color-mix(in srgb, var(--line-strong) 88%, var(--line));
    background: linear-gradient(180deg, color-mix(in srgb, var(--bg-strong) 98%, transparent), color-mix(in srgb, var(--surface) 84%, var(--bg-strong)));
}

.customer-variant-layout { align-items: start; gap: 1.5rem; }

.customer-variant-gallery {
    display: grid;
    gap: 0.9rem;
    max-width: 32rem;
}

.customer-variant-gallery__hero {
    position: relative;
    display: block;
    width: 100%;
    padding: 0;
    border: 0;
    border-radius: 1rem;
    background: transparent;
    overflow: hidden;
    cursor: zoom-in;
}

.customer-variant-gallery__hero img {
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 1rem;
    background: color-mix(in srgb, var(--surface) 76%, var(--bg-strong));
}

.customer-variant-gallery__zoom {
    position: absolute;
    right: 1rem;
    bottom: 1rem;
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    background: rgba(16, 33, 43, 0.72);
    color: white;
    font-size: 0.8rem;
    font-weight: 700;
}

.customer-variant-gallery__thumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.customer-variant-gallery__thumb {
    width: 4.5rem;
    height: 4.5rem;
    padding: 0.2rem;
    border: 1px solid var(--line);
    border-radius: 0.9rem;
    background: color-mix(in srgb, var(--bg-strong) 94%, transparent);
    cursor: pointer;
    transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}

.customer-variant-gallery__thumb:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--primary) 28%, var(--line));
}

.customer-variant-gallery__thumb.is-active {
    border-color: color-mix(in srgb, var(--primary) 46%, var(--line));
    box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--primary) 14%, transparent);
}

.customer-variant-gallery__thumb img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0.7rem;
}

.balance-chip-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr)); gap: 0.9rem; }

.balance-chip {
    display: grid;
    gap: 0.35rem;
    padding: 1rem;
    border-radius: 1rem;
    border: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 82%, var(--bg-strong));
}

.balance-chip strong { font-family: var(--font-display); font-size: 1.1rem; }

.customer-tabs-card { display: grid; gap: 1.1rem; }
.customer-tablist { display: flex; gap: 0.7rem; flex-wrap: wrap; padding-bottom: 0.2rem; border-bottom: 1px solid var(--line); }

.customer-tab {
    border: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 84%, var(--bg-strong));
    color: var(--text);
    border-radius: 999px;
    padding: 0.72rem 1rem;
    font-weight: 700;
    cursor: pointer;
    transition: .2s ease;
}

.customer-tab.is-active {
    background: color-mix(in srgb, var(--primary) 14%, var(--bg-strong));
    color: var(--primary);
    border-color: color-mix(in srgb, var(--primary) 30%, var(--line));
}

.customer-tabpanel { display: grid; gap: 1rem; }

.order-entry-layout { grid-template-columns: minmax(0, 2.4fr) minmax(18rem, 0.95fr); align-items: start; }
.order-entry-main { min-width: 0; }
.order-entry-side { position: sticky; top: 5.75rem; }
.order-preview-card { margin-top: 0.5rem; }

.auth-layout { min-height: 100vh; display: grid; place-items: center; padding: 2rem 1rem; }
.auth-card { width: min(76rem, 100%); overflow: hidden; padding: 0; display: grid; grid-template-columns: 1.05fr 0.95fr; }

.auth-showcase {
    padding: 3rem;
    background:
        radial-gradient(circle at 18% 18%, rgba(255,255,255,.16), transparent 16%),
        linear-gradient(135deg, var(--primary), color-mix(in srgb, var(--primary) 48%, var(--accent)));
    color: white;
    display: grid;
    align-content: space-between;
    gap: 2rem;
}

.auth-showcase h1 { margin: 0; font-size: clamp(2.2rem, 4vw, 4rem); font-family: var(--font-display); }
.auth-panel { padding: 2.6rem; display: grid; gap: 1.3rem; align-content: center; background: color-mix(in srgb, var(--bg-strong) 97%, transparent); }
.auth-metrics { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 0.9rem; }
.auth-metric { padding: 1rem; border-radius: 1rem; background: rgba(255,255,255,.16); }

.filters-bar {
    padding: 1rem 1.1rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 88%, var(--bg-strong));
}

.filter-grid { flex-wrap: wrap; align-items: end; }
.filter-grid > * { flex: 1 1 12rem; min-width: 11rem; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; }
.form-grid--full { grid-column: 1 / -1; }
.form-row { display: grid; gap: 0.45rem; }
.form-row--checkbox { align-self: center; }
.field-label { font-weight: 700; }
.field-required { color: var(--danger); }

.field-control {
    width: 100%;
    background: color-mix(in srgb, var(--surface) 86%, var(--bg-strong));
    border: 1px solid var(--line);
    border-radius: 1rem;
    padding: 0.9rem 1rem;
    color: var(--text);
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.field-control:focus {
    outline: none;
    border-color: color-mix(in srgb, var(--primary) 55%, white);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 18%, transparent);
}

.check-row { display: flex; align-items: start; gap: 0.8rem; }
.check-input { width: 1.1rem; height: 1.1rem; margin-top: 0.2rem; accent-color: var(--primary); }
.field-errors { color: var(--danger); font-size: 0.88rem; }

.select2-container { width: 100% !important; }

.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
    min-height: 3.4rem;
    border-radius: 1rem;
    border: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 86%, var(--bg-strong));
    color: var(--text);
    padding: 0.45rem 0.85rem;
    display: flex;
    align-items: center;
    box-shadow: none;
}

.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--multiple,
.select2-container--default.select2-container--open .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--multiple {
    border-color: color-mix(in srgb, var(--primary) 55%, white);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 18%, transparent);
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--text);
    line-height: 1.4;
    padding-left: 0;
}

.select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: var(--muted);
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 100%;
    right: 0.85rem;
}

.select2-dropdown {
    border: 1px solid var(--line);
    border-radius: 1rem;
    overflow: hidden;
    background: color-mix(in srgb, var(--surface) 94%, var(--bg));
    box-shadow: var(--shadow-lg);
}

.select2-search--dropdown {
    padding: 0.8rem;
    background: color-mix(in srgb, var(--surface) 92%, var(--bg-strong));
    border-bottom: 1px solid var(--line);
}

.select2-container--default .select2-search--dropdown .select2-search__field {
    border: 1px solid var(--line);
    border-radius: 0.8rem;
    background: var(--surface);
    color: var(--text);
    padding: 0.7rem 0.85rem;
}

.select2-results__option {
    padding: 0.8rem 0.95rem;
    color: var(--text);
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background: color-mix(in srgb, var(--primary) 16%, var(--surface));
    color: var(--text);
}

.agreement-picker {
    display: grid;
    gap: 0.75rem;
}

.selector-summary-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
}

.selector-summary-card__title {
    margin-top: 0.35rem;
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--text);
}

.agreement-option {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 1rem;
    padding: 0.95rem 1rem;
    background: color-mix(in srgb, var(--surface) 88%, var(--bg-strong));
    text-align: left;
    display: grid;
    gap: 0.3rem;
    cursor: pointer;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease, background .2s ease;
}

.agreement-option:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--primary) 32%, var(--line));
}

.agreement-option.is-selected {
    border-color: color-mix(in srgb, var(--primary) 60%, white);
    background: color-mix(in srgb, var(--primary) 10%, var(--surface));
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 12%, transparent);
}

.agreement-option__title {
    display: flex;
    align-items: baseline;
    gap: 0.55rem;
    font-weight: 700;
    color: var(--text);
}

.agreement-option__title small,
.agreement-option__meta {
    color: var(--muted);
    font-weight: 500;
}

.table-quantity-input {
    width: 5.8rem;
    padding: 0.55rem 0.7rem;
    border: 1px solid var(--line);
    border-radius: 0.8rem;
    background: color-mix(in srgb, var(--surface) 90%, var(--bg-strong));
    color: var(--text);
}

.table-quantity-input:focus {
    outline: none;
    border-color: color-mix(in srgb, var(--primary) 55%, white);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 18%, transparent);
}

.primary-button,
.secondary-button,
.ghost-button,
.danger-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    border-radius: 999px;
    padding: 0.82rem 1.15rem;
    border: 1px solid transparent;
    font-weight: 700;
    cursor: pointer;
    transition: .2s ease;
}

.primary-button { background: var(--primary); color: white; }
.primary-button:hover { background: var(--primary-strong); }
.secondary-button { background: color-mix(in srgb, var(--surface) 82%, var(--bg-strong)); border-color: var(--line); }
.ghost-button { background: transparent; border-color: var(--line); color: var(--text); }
.ghost-button--small { padding: 0.45rem 0.8rem; font-size: 0.88rem; border-radius: 999px; }
.danger-button { background: var(--danger); color: white; }

.icon-button {
    width: 2.8rem;
    height: 2.8rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: color-mix(in srgb, var(--bg-strong) 90%, transparent);
    color: var(--text);
    cursor: pointer;
}

.empty-state { display: grid; place-items: center; gap: 0.7rem; text-align: center; padding: 2.5rem 1rem; min-height: 12rem; }
.empty-state.compact { min-height: 8rem; }
.empty-state i { width: 2rem; height: 2rem; color: var(--text-muted); }
.list-stack { display: grid; gap: 0.8rem; }

.list-row {
    display: flex;
    justify-content: space-between;
    align-items: start;
    gap: 1rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 1rem;
    background: color-mix(in srgb, var(--surface) 78%, var(--bg-strong));
}

.flash-stack { position: fixed; top: 5rem; right: 1.5rem; z-index: 50; display: grid; gap: 0.7rem; max-width: 24rem; }
.flash-stack--auth { position: static; margin: 1.5rem auto 0; width: min(32rem, calc(100% - 2rem)); }
.flash { padding: 0.95rem 1rem; border-radius: 1rem; border: 1px solid var(--line); background: var(--bg-strong); }
.flash--success { border-color: color-mix(in srgb, var(--success) 30%, transparent); }
.flash--warning { border-color: color-mix(in srgb, var(--warning) 30%, transparent); }
.flash--error,
.flash--danger { border-color: color-mix(in srgb, var(--danger) 30%, transparent); }

.notification-button { position: relative; }

.notification-badge {
    position: absolute;
    top: -0.15rem;
    right: -0.15rem;
    min-width: 1.15rem;
    height: 1.15rem;
    padding: 0 0.2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--danger);
    color: white;
    font-size: 0.72rem;
    font-weight: 800;
}

.notification-drawer {
    position: fixed;
    right: 1rem;
    top: 1rem;
    bottom: 1rem;
    width: min(28rem, calc(100vw - 2rem));
    z-index: 40;
    background: color-mix(in srgb, var(--bg-strong) 96%, transparent);
    border: 1px solid var(--line);
    border-radius: 2rem;
    box-shadow: var(--shadow);
    display: grid;
    grid-template-rows: auto 1fr auto;
    transform: translateX(calc(100% + 2rem));
    transition: transform .2s ease;
}

body.is-notifications-open .notification-drawer { transform: translateX(0); }
.drawer-head,
.drawer-foot { padding: 1rem 1.1rem; border-bottom: 1px solid var(--line); }
.drawer-foot { border-top: 1px solid var(--line); border-bottom: 0; }
.drawer-body { overflow: auto; margin: 1rem; padding: 0.2rem; }
.notification-item { display: grid; grid-template-columns: 1fr auto; gap: 0.8rem; padding: 1rem; border-radius: 1rem; border: 1px solid var(--line); margin-bottom: 0.8rem; }
.notification-item--unread { border-color: color-mix(in srgb, var(--primary) 25%, transparent); background: color-mix(in srgb, var(--primary) 8%, var(--bg-strong)); }
.notification-item__body { display: grid; gap: 0.35rem; }
.notification-item__body p { margin: 0; color: var(--text-muted); }

.command-palette {
    position: fixed;
    inset: 0;
    z-index: 45;
    display: grid;
    place-items: start center;
    padding: 7vh 1rem 1rem;
    background: rgba(7, 12, 16, 0.45);
    backdrop-filter: blur(10px);
}

.command-card { width: min(46rem, 100%); overflow: hidden; }
.command-input { display: flex; gap: 0.75rem; align-items: center; padding: 1rem 1.1rem; border-bottom: 1px solid var(--line); }
.command-input input { flex: 1; border: 0; outline: none; background: transparent; color: var(--text); font-size: 1rem; }
.command-results { max-height: 55vh; overflow: auto; padding: 0.6rem; display: grid; gap: 0.45rem; }
.command-item { padding: 1rem; border-radius: 1rem; border: 1px solid transparent; display: grid; gap: 0.25rem; }
.command-item:hover { border-color: var(--line); background: color-mix(in srgb, var(--surface) 78%, var(--bg-strong)); }
.command-item span { color: var(--text-muted); font-size: 0.92rem; }

.app-overlay { position: fixed; inset: 0; background: rgba(7, 12, 16, 0.4); backdrop-filter: blur(4px); z-index: 30; }

.order-builder { position: relative; }
.order-builder .table-scroll { margin-top: 0.8rem; }

.order-item-backdrop {
    position: fixed;
    inset: 0;
    z-index: 41;
    background: rgba(7, 12, 16, 0.4);
    backdrop-filter: blur(4px);
}

.order-item-drawer {
    position: fixed;
    right: 1rem;
    top: 1rem;
    bottom: 1rem;
    width: min(38rem, calc(100vw - 2rem));
    z-index: 42;
    background: color-mix(in srgb, var(--bg-strong) 97%, transparent);
    border: 1px solid var(--line);
    border-radius: 2rem;
    box-shadow: var(--shadow);
    display: grid;
    grid-template-rows: auto 1fr auto;
}

.order-item-drawer__body {
    display: grid;
    gap: 1rem;
    align-content: start;
    padding: 1rem;
}

body.is-customer-gallery-open { overflow: hidden; }

.customer-gallery-modal {
    position: fixed;
    inset: 0;
    z-index: 55;
    display: grid;
    place-items: center;
    padding: 1rem;
}

.customer-gallery-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(7, 12, 16, 0.72);
    backdrop-filter: blur(10px);
}

.customer-gallery-modal__panel {
    position: relative;
    width: min(72rem, 100%);
    max-height: calc(100vh - 2rem);
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 1rem;
    padding: 1rem;
    border: 1px solid color-mix(in srgb, var(--line-strong) 88%, var(--line));
    border-radius: 2rem;
    background: color-mix(in srgb, var(--bg-strong) 97%, transparent);
    box-shadow: var(--shadow);
}

.customer-gallery-modal__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.customer-gallery-modal__head small { color: var(--text-muted); }

.customer-gallery-modal__body {
    position: relative;
    min-height: 0;
    display: grid;
    gap: 1rem;
}

.customer-gallery-modal__main {
    width: 100%;
    min-width: 0;
    border-radius: 1.5rem;
    overflow: hidden;
    background: color-mix(in srgb, var(--surface-contrast) 92%, black);
}

.customer-gallery-modal__main .swiper-slide {
    display: grid;
    place-items: center;
    background: color-mix(in srgb, var(--surface-contrast) 92%, black);
}

.customer-gallery-modal__main img {
    display: block;
    width: 100%;
    max-height: min(68vh, 48rem);
    object-fit: contain;
}

.customer-gallery-modal__thumbs {
    width: 100%;
    padding: 0 3.5rem;
}

.customer-gallery-modal__thumbs .swiper-slide {
    width: 5rem;
    height: 5rem;
    border: 1px solid var(--line);
    border-radius: 1rem;
    overflow: hidden;
    opacity: 0.55;
    cursor: pointer;
    transition: opacity .2s ease, border-color .2s ease, transform .2s ease;
}

.customer-gallery-modal__thumbs .swiper-slide:hover {
    opacity: 0.85;
    transform: translateY(-1px);
}

.customer-gallery-modal__thumbs .swiper-slide-thumb-active {
    opacity: 1;
    border-color: color-mix(in srgb, var(--primary) 50%, var(--line));
}

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

.customer-gallery-modal__nav {
    position: absolute;
    top: calc(50% - 3.25rem);
    z-index: 2;
    background: rgba(255, 255, 255, 0.9);
}

.customer-gallery-modal__nav--prev { left: 0.75rem; }
.customer-gallery-modal__nav--next { right: 0.75rem; }

/* Visibility helpers must come after component display rules like `.icon-button`. */
.desktop-hidden,
.mobile-only { display: none !important; }

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

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

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

    .app-sidebar {
        position: fixed;
        left: 0;
        top: 0;
        bottom: 0;
        width: min(var(--sidebar-width), calc(100vw - 3rem));
        transform: translateX(-105%);
        transition: transform .2s ease;
        z-index: 35;
    }

    body.is-sidebar-open .app-sidebar { transform: translateX(0); }
    .desktop-hidden,
    .mobile-only { display: inline-flex !important; }
    .search-trigger { min-width: 0; width: 100%; }
    .search-trigger kbd { display: none; }
    .metric-grid--cards,
    .two-grid,
    .three-grid,
    .detail-grid,
    .form-grid,
    .auth-card,
    .balance-chip-list { grid-template-columns: 1fr; }
    .notification-drawer { width: calc(100vw - 1rem); right: 0.5rem; left: 0.5rem; }
    .order-item-drawer { width: 100%; }
    .customer-gallery-modal { padding: 0.5rem; }
    .customer-gallery-modal__panel {
        width: 100%;
        max-height: calc(100vh - 1rem);
        padding: 0.85rem;
        border-radius: 1.4rem;
    }
    .customer-gallery-modal__thumbs { padding: 0 2.75rem; }
    .customer-gallery-modal__nav {
        top: calc(50% - 2.5rem);
        transform: scale(0.92);
    }
}

@media (max-width: 640px) {
    .app-content,
    .app-topbar { padding: 1rem; }

    .page-hero,
    .panel,
    .table-card,
    .form-card,
    .detail-card { padding: 1rem; }

    .topbar-right .ghost-button { display: none; }
    .flash-stack { right: 0.75rem; left: 0.75rem; max-width: none; }
    .customer-variant-gallery__thumb {
        width: 4rem;
        height: 4rem;
    }
    .customer-gallery-modal__thumbs { padding: 0 2.25rem; }
    .customer-gallery-modal__thumbs .swiper-slide {
        width: 4rem;
        height: 4rem;
    }
    .customer-gallery-modal__nav--prev { left: 0.35rem; }
    .customer-gallery-modal__nav--next { right: 0.35rem; }
}

/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji",
      "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --spacing: 0.25rem;
    --container-2xl: 42rem;
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --leading-relaxed: 1.625;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-xl: 0.75rem;
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .\@container {
    container-type: inline-size;
  }
  .collapse {
    visibility: collapse;
  }
  .invisible {
    visibility: hidden;
  }
  .visible {
    visibility: visible;
  }
  .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border-width: 0;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .static {
    position: static;
  }
  .sticky {
    position: sticky;
  }
  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }
  .\!start {
    inset-inline-start: var(--spacing) !important;
  }
  .start {
    inset-inline-start: var(--spacing);
  }
  .end {
    inset-inline-end: var(--spacing);
  }
  .top-0 {
    top: calc(var(--spacing) * 0);
  }
  .right-0 {
    right: calc(var(--spacing) * 0);
  }
  .bottom-0 {
    bottom: calc(var(--spacing) * 0);
  }
  .bottom-\[60px\] {
    bottom: 60px;
  }
  .left-0 {
    left: calc(var(--spacing) * 0);
  }
  .isolate {
    isolation: isolate;
  }
  .z-10 {
    z-index: 10;
  }
  .z-20 {
    z-index: 20;
  }
  .z-30 {
    z-index: 30;
  }
  .z-40 {
    z-index: 40;
  }
  .z-50 {
    z-index: 50;
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .my-4 {
    margin-block: calc(var(--spacing) * 4);
  }
  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }
  .mb-1 {
    margin-bottom: calc(var(--spacing) * 1);
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .ml-auto {
    margin-left: auto;
  }
  .\!hidden {
    display: none !important;
  }
  .block {
    display: block;
  }
  .contents {
    display: contents;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline {
    display: inline;
  }
  .inline-block {
    display: inline-block;
  }
  .inline-flex {
    display: inline-flex;
  }
  .table {
    display: table;
  }
  .table-caption {
    display: table-caption;
  }
  .table-cell {
    display: table-cell;
  }
  .h-4 {
    height: calc(var(--spacing) * 4);
  }
  .h-5 {
    height: calc(var(--spacing) * 5);
  }
  .h-6 {
    height: calc(var(--spacing) * 6);
  }
  .h-9 {
    height: calc(var(--spacing) * 9);
  }
  .h-\[calc\(100\%-1rem\)\] {
    height: calc(100% - 1rem);
  }
  .max-h-full {
    max-height: 100%;
  }
  .w-1\/2 {
    width: calc(1 / 2 * 100%);
  }
  .w-4 {
    width: calc(var(--spacing) * 4);
  }
  .w-5 {
    width: calc(var(--spacing) * 5);
  }
  .w-64 {
    width: calc(var(--spacing) * 64);
  }
  .w-full {
    width: 100%;
  }
  .max-w-2xl {
    max-width: var(--container-2xl);
  }
  .flex-1 {
    flex: 1;
  }
  .flex-shrink {
    flex-shrink: 1;
  }
  .grow {
    flex-grow: 1;
  }
  .-translate-x-full {
    --tw-translate-x: -100%;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-x-0 {
    --tw-translate-x: calc(var(--spacing) * 0);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-x-full {
    --tw-translate-x: 100%;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .-translate-y-full {
    --tw-translate-y: -100%;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-y-full {
    --tw-translate-y: 100%;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .rotate-180 {
    rotate: 180deg;
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .transform-none {
    transform: none;
  }
  .cursor-default {
    cursor: default;
  }
  .cursor-not-allowed {
    cursor: not-allowed;
  }
  .cursor-pointer {
    cursor: pointer;
  }
  .resize {
    resize: both;
  }
  .grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .grid-cols-7 {
    grid-template-columns: repeat(7, minmax(0, 1fr));
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .items-center {
    align-items: center;
  }
  .items-end {
    align-items: flex-end;
  }
  .items-start {
    align-items: flex-start;
  }
  .justify-between {
    justify-content: space-between;
  }
  .justify-center {
    justify-content: center;
  }
  .justify-end {
    justify-content: flex-end;
  }
  .justify-start {
    justify-content: flex-start;
  }
  .space-y-2 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-6 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-x-2 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 2) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .overflow-x-hidden {
    overflow-x: hidden;
  }
  .overflow-y-auto {
    overflow-y: auto;
  }
  .rounded {
    border-radius: 0.25rem;
  }
  .rounded-lg {
    border-radius: var(--radius-lg);
  }
  .rounded-md {
    border-radius: var(--radius-md);
  }
  .rounded-s-lg {
    border-start-start-radius: var(--radius-lg);
    border-end-start-radius: var(--radius-lg);
  }
  .rounded-e-lg {
    border-start-end-radius: var(--radius-lg);
    border-end-end-radius: var(--radius-lg);
  }
  .rounded-t {
    border-top-left-radius: 0.25rem;
    border-top-right-radius: 0.25rem;
  }
  .rounded-l-lg {
    border-top-left-radius: var(--radius-lg);
    border-bottom-left-radius: var(--radius-lg);
  }
  .rounded-r-lg {
    border-top-right-radius: var(--radius-lg);
    border-bottom-right-radius: var(--radius-lg);
  }
  .rounded-b {
    border-bottom-right-radius: 0.25rem;
    border-bottom-left-radius: 0.25rem;
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-0 {
    border-style: var(--tw-border-style);
    border-width: 0px;
  }
  .border-t {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }
  .border-b {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }
  .border-blue-600 {
    border-color: #1C64F2;
  }
  .border-blue-700 {
    border-color: #1A56DB;
  }
  .border-gray-100 {
    border-color: #F3F4F6;
  }
  .border-gray-200 {
    border-color: #E5E7EB;
  }
  .border-gray-300 {
    border-color: #D1D5DB;
  }
  .\!bg-gray-50 {
    background-color: #F9FAFB !important;
  }
  .bg-blue-700 {
    background-color: #1A56DB;
  }
  .bg-gray-100 {
    background-color: #F3F4F6;
  }
  .bg-gray-200 {
    background-color: #E5E7EB;
  }
  .bg-gray-900\/50 {
    background-color: color-mix(in oklab, #111827 50%, transparent);
  }
  .bg-transparent {
    background-color: transparent;
  }
  .bg-white {
    background-color: #ffffff;
  }
  .bg-white\/50 {
    background-color: color-mix(in oklab, #ffffff 50%, transparent);
  }
  .p-1 {
    padding: calc(var(--spacing) * 1);
  }
  .p-1\.5 {
    padding: calc(var(--spacing) * 1.5);
  }
  .p-2\.5 {
    padding: calc(var(--spacing) * 2.5);
  }
  .p-4 {
    padding: calc(var(--spacing) * 4);
  }
  .p-6 {
    padding: calc(var(--spacing) * 6);
  }
  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }
  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }
  .px-5 {
    padding-inline: calc(var(--spacing) * 5);
  }
  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }
  .py-2\.5 {
    padding-block: calc(var(--spacing) * 2.5);
  }
  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }
  .pt-2 {
    padding-top: calc(var(--spacing) * 2);
  }
  .text-center {
    text-align: center;
  }
  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }
  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }
  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }
  .text-xl {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }
  .leading-6 {
    --tw-leading: calc(var(--spacing) * 6);
    line-height: calc(var(--spacing) * 6);
  }
  .leading-9 {
    --tw-leading: calc(var(--spacing) * 9);
    line-height: calc(var(--spacing) * 9);
  }
  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }
  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }
  .text-blue-600 {
    color: #1C64F2;
  }
  .text-gray-400 {
    color: #9CA3AF;
  }
  .text-gray-500 {
    color: #6B7280;
  }
  .text-gray-800 {
    color: #1F2937;
  }
  .text-gray-900 {
    color: #111827;
  }
  .text-white {
    color: #ffffff;
  }
  .lowercase {
    text-transform: lowercase;
  }
  .uppercase {
    text-transform: uppercase;
  }
  .opacity-0 {
    opacity: 0%;
  }
  .opacity-100 {
    opacity: 100%;
  }
  .shadow {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-lg {
    --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }
  .blur {
    --tw-blur: blur(8px);
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .invert {
    --tw-invert: invert(100%);
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .\!filter {
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,) !important;
  }
  .filter {
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-opacity {
    transition-property: opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-transform {
    transition-property: transform, translate, scale, rotate;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .ease-out {
    --tw-ease: var(--ease-out);
    transition-timing-function: var(--ease-out);
  }
  .backface-hidden {
    backface-visibility: hidden;
  }
  .hover\:border-gray-300 {
    &:hover {
      @media (hover: hover) {
        border-color: #D1D5DB;
      }
    }
  }
  .hover\:bg-blue-800 {
    &:hover {
      @media (hover: hover) {
        background-color: #1E429F;
      }
    }
  }
  .hover\:bg-gray-100 {
    &:hover {
      @media (hover: hover) {
        background-color: #F3F4F6;
      }
    }
  }
  .hover\:bg-gray-200 {
    &:hover {
      @media (hover: hover) {
        background-color: #E5E7EB;
      }
    }
  }
  .hover\:bg-white {
    &:hover {
      @media (hover: hover) {
        background-color: #ffffff;
      }
    }
  }
  .hover\:text-blue-600 {
    &:hover {
      @media (hover: hover) {
        color: #1C64F2;
      }
    }
  }
  .hover\:text-gray-600 {
    &:hover {
      @media (hover: hover) {
        color: #4B5563;
      }
    }
  }
  .hover\:text-gray-900 {
    &:hover {
      @media (hover: hover) {
        color: #111827;
      }
    }
  }
  .focus\:z-10 {
    &:focus {
      z-index: 10;
    }
  }
  .focus\:ring-2 {
    &:focus {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus\:ring-4 {
    &:focus {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus\:ring-blue-300 {
    &:focus {
      --tw-ring-color: #A4CAFE;
    }
  }
  .focus\:ring-blue-500 {
    &:focus {
      --tw-ring-color: #3F83F8;
    }
  }
  .focus\:ring-gray-200 {
    &:focus {
      --tw-ring-color: #E5E7EB;
    }
  }
  .focus\:outline-none {
    &:focus {
      --tw-outline-style: none;
      outline-style: none;
    }
  }
  .md\:inset-0 {
    @media (width >= 48rem) {
      inset: calc(var(--spacing) * 0);
    }
  }
  .rtl\:rotate-180 {
    &:where(:dir(rtl), [dir="rtl"], [dir="rtl"] *) {
      rotate: 180deg;
    }
  }
  .rtl\:space-x-reverse {
    &:where(:dir(rtl), [dir="rtl"], [dir="rtl"] *) {
      :where(& > :not(:last-child)) {
        --tw-space-x-reverse: 1;
      }
    }
  }
  .dark\:border-blue-500 {
    &:is(.dark *) {
      border-color: #3F83F8;
    }
  }
  .dark\:border-gray-500 {
    &:is(.dark *) {
      border-color: #6B7280;
    }
  }
  .dark\:border-gray-600 {
    &:is(.dark *) {
      border-color: #4B5563;
    }
  }
  .dark\:border-gray-700 {
    &:is(.dark *) {
      border-color: #374151;
    }
  }
  .dark\:border-transparent {
    &:is(.dark *) {
      border-color: transparent;
    }
  }
  .dark\:\!bg-gray-700 {
    &:is(.dark *) {
      background-color: #374151 !important;
    }
  }
  .dark\:bg-blue-600 {
    &:is(.dark *) {
      background-color: #1C64F2;
    }
  }
  .dark\:bg-gray-600 {
    &:is(.dark *) {
      background-color: #4B5563;
    }
  }
  .dark\:bg-gray-700 {
    &:is(.dark *) {
      background-color: #374151;
    }
  }
  .dark\:bg-gray-800 {
    &:is(.dark *) {
      background-color: #1F2937;
    }
  }
  .dark\:bg-gray-800\/50 {
    &:is(.dark *) {
      background-color: color-mix(in oklab, #1F2937 50%, transparent);
    }
  }
  .dark\:bg-gray-900\/80 {
    &:is(.dark *) {
      background-color: color-mix(in oklab, #111827 80%, transparent);
    }
  }
  .dark\:text-blue-500 {
    &:is(.dark *) {
      color: #3F83F8;
    }
  }
  .dark\:text-gray-300 {
    &:is(.dark *) {
      color: #D1D5DB;
    }
  }
  .dark\:text-gray-400 {
    &:is(.dark *) {
      color: #9CA3AF;
    }
  }
  .dark\:text-gray-500 {
    &:is(.dark *) {
      color: #6B7280;
    }
  }
  .dark\:text-white {
    &:is(.dark *) {
      color: #ffffff;
    }
  }
  .dark\:hover\:bg-blue-700 {
    &:is(.dark *) {
      &:hover {
        @media (hover: hover) {
          background-color: #1A56DB;
        }
      }
    }
  }
  .dark\:hover\:bg-gray-600 {
    &:is(.dark *) {
      &:hover {
        @media (hover: hover) {
          background-color: #4B5563;
        }
      }
    }
  }
  .dark\:hover\:bg-gray-800 {
    &:is(.dark *) {
      &:hover {
        @media (hover: hover) {
          background-color: #1F2937;
        }
      }
    }
  }
  .dark\:hover\:text-blue-500 {
    &:is(.dark *) {
      &:hover {
        @media (hover: hover) {
          color: #3F83F8;
        }
      }
    }
  }
  .dark\:hover\:text-gray-300 {
    &:is(.dark *) {
      &:hover {
        @media (hover: hover) {
          color: #D1D5DB;
        }
      }
    }
  }
  .dark\:hover\:text-white {
    &:is(.dark *) {
      &:hover {
        @media (hover: hover) {
          color: #ffffff;
        }
      }
    }
  }
  .dark\:focus\:ring-blue-800 {
    &:is(.dark *) {
      &:focus {
        --tw-ring-color: #1E429F;
      }
    }
  }
  .dark\:focus\:ring-gray-600 {
    &:is(.dark *) {
      &:focus {
        --tw-ring-color: #4B5563;
      }
    }
  }
}
@layer base {
  .tooltip-arrow,.tooltip-arrow:before {
    position: absolute;
    width: 8px;
    height: 8px;
    background: inherit;
  }
  .tooltip-arrow {
    visibility: hidden;
  }
  .tooltip-arrow:before {
    content: "";
    visibility: visible;
    transform: rotate(45deg);
  }
  [data-tooltip-style^='light'] + .tooltip > .tooltip-arrow:before {
    border-style: solid;
    border-color: oklch(92.8% 0.006 264.531);
  }
  [data-tooltip-style^='light'] + .tooltip[data-popper-placement^='top'] > .tooltip-arrow:before {
    border-bottom-width: 1px;
    border-right-width: 1px;
  }
  [data-tooltip-style^='light'] + .tooltip[data-popper-placement^='right'] > .tooltip-arrow:before {
    border-bottom-width: 1px;
    border-left-width: 1px;
  }
  [data-tooltip-style^='light'] + .tooltip[data-popper-placement^='bottom'] > .tooltip-arrow:before {
    border-top-width: 1px;
    border-left-width: 1px;
  }
  [data-tooltip-style^='light'] + .tooltip[data-popper-placement^='left'] > .tooltip-arrow:before {
    border-top-width: 1px;
    border-right-width: 1px;
  }
  .tooltip[data-popper-placement^='top'] > .tooltip-arrow {
    bottom: -4px;
  }
  .tooltip[data-popper-placement^='bottom'] > .tooltip-arrow {
    top: -4px;
  }
  .tooltip[data-popper-placement^='left'] > .tooltip-arrow {
    right: -4px;
  }
  .tooltip[data-popper-placement^='right'] > .tooltip-arrow {
    left: -4px;
  }
  .tooltip.invisible > .tooltip-arrow:before {
    visibility: hidden;
  }
  [data-popper-arrow],[data-popper-arrow]:before {
    position: absolute;
    width: 8px;
    height: 8px;
    background: inherit;
  }
  [data-popper-arrow] {
    visibility: hidden;
  }
  [data-popper-arrow]:before {
    content: "";
    visibility: visible;
    transform: rotate(45deg);
  }
  [data-popper-arrow]:after {
    content: "";
    visibility: visible;
    transform: rotate(45deg);
    position: absolute;
    width: 9px;
    height: 9px;
    background: inherit;
  }
  [role="tooltip"] > [data-popper-arrow]:before {
    border-style: solid;
    border-color: oklch(92.8% 0.006 264.531);
  }
  .dark [role="tooltip"] > [data-popper-arrow]:before {
    border-style: solid;
    border-color: oklch(44.6% 0.03 256.802);
  }
  [role="tooltip"] > [data-popper-arrow]:after {
    border-style: solid;
    border-color: oklch(92.8% 0.006 264.531);
  }
  .dark [role="tooltip"] > [data-popper-arrow]:after {
    border-style: solid;
    border-color: oklch(44.6% 0.03 256.802);
  }
  [data-popover][role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow]:before {
    border-bottom-width: 1px;
    border-right-width: 1px;
  }
  [data-popover][role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow]:after {
    border-bottom-width: 1px;
    border-right-width: 1px;
  }
  [data-popover][role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow]:before {
    border-bottom-width: 1px;
    border-left-width: 1px;
  }
  [data-popover][role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow]:after {
    border-bottom-width: 1px;
    border-left-width: 1px;
  }
  [data-popover][role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow]:before {
    border-top-width: 1px;
    border-left-width: 1px;
  }
  [data-popover][role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow]:after {
    border-top-width: 1px;
    border-left-width: 1px;
  }
  [data-popover][role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow]:before {
    border-top-width: 1px;
    border-right-width: 1px;
  }
  [data-popover][role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow]:after {
    border-top-width: 1px;
    border-right-width: 1px;
  }
  [data-popover][role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow] {
    bottom: -5px;
  }
  [data-popover][role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow] {
    top: -5px;
  }
  [data-popover][role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow] {
    right: -5px;
  }
  [data-popover][role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow] {
    left: -5px;
  }
  [role="tooltip"].invisible > [data-popper-arrow]:before {
    visibility: hidden;
  }
  [role="tooltip"].invisible > [data-popper-arrow]:after {
    visibility: hidden;
  }
}
@layer base {
  [type='text'],[type='email'],[type='url'],[type='password'],[type='number'],[type='date'],[type='datetime-local'],[type='month'],[type='search'],[type='tel'],[type='time'],[type='week'],[multiple],textarea,select {
    appearance: none;
    background-color: #fff;
    border-color: #6B7280;
    border-width: 1px;
    border-radius: 0px;
    padding-top: 0.5rem;
    padding-right: 0.75rem;
    padding-bottom: 0.5rem;
    padding-left: 0.75rem;
    font-size: 1rem;
    line-height: 1.5rem;
    --tw-shadow: 0 0 #0000;
    &:focus {
      outline: 2px solid transparent;
      outline-offset: 2px;
      --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/);
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-color: #1C64F2;
      --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
      --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
      box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
      border-color: #1C64F2;
    }
  }
  input::placeholder,textarea::placeholder {
    color: #6B7280;
    opacity: 1;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  input[type="time"]::-webkit-calendar-picker-indicator {
    background: none;
  }
  select:not([size]) {
    background-image: url("data:image/svg+xml,%3csvg aria-hidden=%27true%27 xmlns=%27http://www.w3.org/2000/svg%27 fill=%27none%27 viewBox=%270 0 10 6%27%3e %3cpath stroke=%27%236B7280%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27 stroke-width=%272%27 d=%27m1 1 4 4 4-4%27/%3e %3c/svg%3e");
    background-position: right 0.75rem center;
    background-repeat: no-repeat;
    background-size: 0.75em 0.75em;
    padding-right: 2.5rem;
    print-color-adjust: exact;
  }
  :is([dir=rtl]) select:not([size]) {
    background-position: left 0.75rem center;
    padding-right: 0.75rem;
    padding-left: 0;
  }
  [multiple] {
    background-image: initial;
    background-position: initial;
    background-repeat: unset;
    background-size: initial;
    padding-right: 0.75rem;
    print-color-adjust: unset;
  }
  [type='checkbox'],[type='radio'] {
    appearance: none;
    padding: 0;
    print-color-adjust: exact;
    display: inline-block;
    vertical-align: middle;
    background-origin: border-box;
    user-select: none;
    flex-shrink: 0;
    height: 1rem;
    width: 1rem;
    color: #1C64F2;
    background-color: #fff;
    border-color: #6B7280;
    border-width: 1px;
    --tw-shadow: 0 0 #0000;
  }
  [type='checkbox'] {
    border-radius: 0px;
  }
  [type='radio'] {
    border-radius: 100%;
  }
  [type='checkbox']:focus,[type='radio']:focus {
    outline: 2px solid transparent;
    outline-offset: 2px;
    --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/);
    --tw-ring-offset-width: 2px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: #1C64F2;
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  [type='checkbox']:checked,[type='radio']:checked,.dark [type='checkbox']:checked,.dark [type='radio']:checked {
    border-color: transparent;
    background-color: currentColor;
    background-size: 0.55em 0.55em;
    background-position: center;
    background-repeat: no-repeat;
  }
  [type='checkbox']:checked {
    background-image: url("data:image/svg+xml,%3csvg aria-hidden=%27true%27 xmlns=%27http://www.w3.org/2000/svg%27 fill=%27none%27 viewBox=%270 0 16 12%27%3e %3cpath stroke=%27white%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27 stroke-width=%273%27 d=%27M1 5.917 5.724 10.5 15 1.5%27/%3e %3c/svg%3e");
    background-repeat: no-repeat;
    background-size: 0.55em 0.55em;
    print-color-adjust: exact;
  }
  [type='radio']:checked {
    background-image: url("data:image/svg+xml,%3csvg viewBox=%270 0 16 16%27 fill=%27white%27 xmlns=%27http://www.w3.org/2000/svg%27%3e%3ccircle cx=%278%27 cy=%278%27 r=%273%27/%3e%3c/svg%3e");
    background-size: 1em 1em;
  }
  .dark [type='radio']:checked {
    background-image: url("data:image/svg+xml,%3csvg viewBox=%270 0 16 16%27 fill=%27white%27 xmlns=%27http://www.w3.org/2000/svg%27%3e%3ccircle cx=%278%27 cy=%278%27 r=%273%27/%3e%3c/svg%3e");
    background-size: 1em 1em;
  }
  [type='checkbox']:indeterminate {
    background-image: url("data:image/svg+xml,%3csvg aria-hidden=%27true%27 xmlns=%27http://www.w3.org/2000/svg%27 fill=%27none%27 viewBox=%270 0 16 12%27%3e %3cpath stroke=%27white%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27 stroke-width=%273%27 d=%27M0.5 6h14%27/%3e %3c/svg%3e");
    background-color: currentColor;
    border-color: transparent;
    background-position: center;
    background-repeat: no-repeat;
    background-size: 0.55em 0.55em;
    print-color-adjust: exact;
  }
  [type='checkbox']:indeterminate:hover,[type='checkbox']:indeterminate:focus {
    border-color: transparent;
    background-color: currentColor;
  }
  [type='file'] {
    background: unset;
    border-color: inherit;
    border-width: 0;
    border-radius: 0;
    padding: 0;
    font-size: unset;
    line-height: inherit;
  }
  [type='file']:focus {
    outline: 1px auto inherit;
  }
  input[type=file]::file-selector-button {
    color: white;
    background: #1F2937;
    border: 0;
    font-weight: 500;
    font-size: 0.875rem;
    font-size {
      line-height: calc(1.25 / 0.875);
    }
    cursor: pointer;
    padding-top: 0.625rem;
    padding-bottom: 0.625rem;
    padding-left: 2rem;
    padding-right: 1rem;
    margin-inline-start: -1rem;
    margin-inline-end: 1rem;
    &:hover {
      background: #374151;
    }
  }
  :is([dir=rtl]) input[type=file]::file-selector-button {
    padding-right: 2rem;
    padding-left: 1rem;
  }
  .dark input[type=file]::file-selector-button {
    color: white;
    background: #4B5563;
    &:hover {
      background: #6B7280;
    }
  }
  input[type="range"]::-webkit-slider-thumb {
    height: 1.25rem;
    width: 1.25rem;
    background: #1C64F2;
    border-radius: 9999px;
    border: 0;
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
  }
  input[type="range"]:disabled::-webkit-slider-thumb {
    background: #9CA3AF;
  }
  .dark input[type="range"]:disabled::-webkit-slider-thumb {
    background: #6B7280;
  }
  input[type="range"]:focus::-webkit-slider-thumb {
    outline: 2px solid transparent;
    outline-offset: 2px;
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(164 202 254 / var(--tw-ring-opacity));
  }
  input[type="range"]::-moz-range-thumb {
    height: 1.25rem;
    width: 1.25rem;
    background: #1C64F2;
    border-radius: 9999px;
    border: 0;
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
  }
  input[type="range"]:disabled::-moz-range-thumb {
    background: #9CA3AF;
  }
  .dark input[type="range"]:disabled::-moz-range-thumb {
    background: #6B7280;
  }
  input[type="range"]::-moz-range-progress {
    background: #3F83F8;
  }
  input[type="range"]::-ms-fill-lower {
    background: #3F83F8;
  }
  input[type="range"].range-sm::-webkit-slider-thumb {
    height: 1rem;
    width: 1rem;
  }
  input[type="range"].range-lg::-webkit-slider-thumb {
    height: 1.5rem;
    width: 1.5rem;
  }
  input[type="range"].range-sm::-moz-range-thumb {
    height: 1rem;
    width: 1rem;
  }
  input[type="range"].range-lg::-moz-range-thumb {
    height: 1.5rem;
    width: 1.5rem;
  }
  .toggle-bg:after {
    content: "";
    position: absolute;
    top: 0.125rem;
    left: 0.125rem;
    background: white;
    border-color: #D1D5DB;
    border-width: 1px;
    border-radius: 9999px;
    height: 1.25rem;
    width: 1.25rem;
    transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
    transition-duration: .15s;
    box-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  }
  input:checked + .toggle-bg:after {
    transform: translateX(100%);;
    border-color: white;
  }
  input:checked + .toggle-bg {
    background: #1C64F2;
    border-color: #1C64F2;
  }
}
@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-space-x-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-leading {
  syntax: "*";
  inherits: false;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@property --tw-ease {
  syntax: "*";
  inherits: false;
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-space-y-reverse: 0;
      --tw-space-x-reverse: 0;
      --tw-border-style: solid;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-ease: initial;
    }
  }
}

/**
 * Swiper 11.2.10
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2025 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: June 28, 2025
 */

/* FONT_START */
@font-face {
  font-family: 'swiper-icons';
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA");
  font-weight: 400;
  font-style: normal;
}
/* FONT_END */
:root {
  --swiper-theme-color: #007aff;
  /*
  --swiper-preloader-color: var(--swiper-theme-color);
  --swiper-wrapper-transition-timing-function: initial;
  */
}
:host {
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  z-index: 1;
}
.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
  display: block;
}
.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}
.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  box-sizing: content-box;
}
.swiper-android .swiper-slide,
.swiper-ios .swiper-slide,
.swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}
.swiper-horizontal {
  touch-action: pan-y;
}
.swiper-vertical {
  touch-action: pan-x;
}
.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
  display: block;
}
.swiper-slide-invisible-blank {
  visibility: hidden;
}
/* Auto Height */
.swiper-autoheight,
.swiper-autoheight .swiper-slide {
  height: auto;
}
.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}
.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
/* 3D Effects */
.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}
.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}
.swiper-3d {
  perspective: 1200px;
}
.swiper-3d .swiper-slide,
.swiper-3d .swiper-cube-shadow {
  transform-style: preserve-3d;
}
/* CSS Mode */
.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  /* For Firefox */
  -ms-overflow-style: none;
  /* For Internet Explorer and Edge */
}
.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}
.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}
.swiper-css-mode.swiper-horizontal > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}
.swiper-css-mode.swiper-vertical > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}
.swiper-css-mode.swiper-free-mode > .swiper-wrapper {
  scroll-snap-type: none;
}
.swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: none;
}
.swiper-css-mode.swiper-centered > .swiper-wrapper::before {
  content: '';
  flex-shrink: 0;
  order: 9999;
}
.swiper-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always;
}
.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-centered-offset-before);
}
.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after);
}
.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-centered-offset-before);
}
.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after);
}
/* Slide styles start */
/* 3D Shadows */
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}
.swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, 0.15);
}
.swiper-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}
.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,
.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader {
  animation: swiper-preloader-spin 1s infinite linear;
}
.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff;
}
.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000;
}
@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* Slide styles end */

:root {
  --swiper-navigation-size: 44px;
  /*
  --swiper-navigation-top-offset: 50%;
  --swiper-navigation-sides-offset: 10px;
  --swiper-navigation-color: var(--swiper-theme-color);
  */
}
.swiper-button-prev,
.swiper-button-next {
  position: absolute;
  top: var(--swiper-navigation-top-offset, 50%);
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
  z-index: 10;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
}
.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
  opacity: 0.35;
  cursor: auto;
  pointer-events: none;
}
.swiper-button-prev.swiper-button-hidden,
.swiper-button-next.swiper-button-hidden {
  opacity: 0;
  cursor: auto;
  pointer-events: none;
}
.swiper-navigation-disabled .swiper-button-prev,
.swiper-navigation-disabled .swiper-button-next {
  display: none !important;
}
.swiper-button-prev svg,
.swiper-button-next svg {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transform-origin: center;
}
.swiper-rtl .swiper-button-prev svg,
.swiper-rtl .swiper-button-next svg {
  transform: rotate(180deg);
}
.swiper-button-prev,
.swiper-rtl .swiper-button-next {
  left: var(--swiper-navigation-sides-offset, 10px);
  right: auto;
}
.swiper-button-next,
.swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 10px);
  left: auto;
}
.swiper-button-lock {
  display: none;
}
/* Navigation font start */
.swiper-button-prev:after,
.swiper-button-next:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  text-transform: none !important;
  letter-spacing: 0;
  font-variant: initial;
  line-height: 1;
}
.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
  content: 'prev';
}
.swiper-button-next,
.swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 10px);
  left: auto;
}
.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
  content: 'next';
}
/* Navigation font end */


