/*
 * FoodStream Vendor Hub brand layer.
 *
 * This file is intentionally scoped to the admin and authentication body
 * classes. Operational POS, KDS, order-ready, print, receipt, and QR screens
 * load the same shared header in places but must retain their own appearance.
 */

body.vendor-hub-admin,
body.vendor-hub-auth {
    --vh-orange: #DB4A2B;
    --vh-orange-soft: #FCEBE7;
    --vh-clay: #A63A27;
    --vh-charcoal: #252321;
    --vh-cream: #F8F4ED;
    --vh-grey: #E4E2DD;
    --vh-grey-hover: #D7D3CB;
    --vh-muted: #706A65;
    --vh-green: #2F8F5B;
    --vh-green-soft: #E8F4ED;
    --vh-amber: #F4A340;
    --vh-amber-soft: #FFF3DE;
    --vh-danger: #B3261E;
    --vh-danger-soft: #FCE9E7;
    background: var(--vh-cream);
    color: var(--vh-charcoal);
}

/* Money follows its surrounding UI hierarchy rather than the editorial accent face. */
body.vendor-hub-admin .money,
body.vendor-hub-auth .money {
    font-family: var(--fs-font-body);
    font-variation-settings: normal;
}

body.vendor-hub-admin :is(h1, h2, h3, h4, h5, h6).money,
body.vendor-hub-admin :is(h1, h2, h3, h4, h5, h6) .money,
body.vendor-hub-admin :is(.card-title, .modal-title, .page-title).money,
body.vendor-hub-admin :is(.card-title, .modal-title, .page-title) .money,
body.vendor-hub-auth :is(h1, h2, h3, h4, h5, h6).money,
body.vendor-hub-auth :is(h1, h2, h3, h4, h5, h6) .money,
body.vendor-hub-auth :is(.card-title, .modal-title, .page-title).money,
body.vendor-hub-auth :is(.card-title, .modal-title, .page-title) .money {
    font-family: var(--fs-font-heading);
    font-variation-settings: normal;
}

body.vendor-hub-admin *,
body.vendor-hub-auth * {
    box-sizing: border-box;
}

body.vendor-hub-admin a,
body.vendor-hub-auth a {
    color: var(--vh-orange);
}

body.vendor-hub-admin a:hover,
body.vendor-hub-auth a:hover {
    color: var(--vh-clay);
}

body.vendor-hub-admin :focus-visible,
body.vendor-hub-auth :focus-visible {
    outline: 3px solid rgba(219, 74, 43, .27);
    outline-offset: 3px;
}

/* Shared actions: remove Materialize teal focus and hover defaults. */
body.vendor-hub-admin button:focus,
body.vendor-hub-auth button:focus,
body.vendor-hub-admin .btn:focus,
body.vendor-hub-auth .btn:focus,
body.vendor-hub-admin .btn-large:focus,
body.vendor-hub-auth .btn-large:focus,
body.vendor-hub-admin .btn-small:focus,
body.vendor-hub-auth .btn-small:focus,
body.vendor-hub-admin .btn-floating:focus,
body.vendor-hub-auth .btn-floating:focus {
    background-color: var(--vh-clay);
}

body.vendor-hub-admin .btn,
body.vendor-hub-auth .btn,
body.vendor-hub-admin .btn-large,
body.vendor-hub-auth .btn-large,
body.vendor-hub-admin .btn-small,
body.vendor-hub-auth .btn-small {
    border-radius: 12px;
    box-shadow: none;
    font-weight: 700;
    letter-spacing: .01em;
    text-transform: none;
    transition: background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}

body.vendor-hub-admin .btn:hover,
body.vendor-hub-auth .btn:hover,
body.vendor-hub-admin .btn-large:hover,
body.vendor-hub-auth .btn-large:hover,
body.vendor-hub-admin .btn-small:hover,
body.vendor-hub-auth .btn-small:hover {
    box-shadow: 0 6px 16px rgba(37, 35, 33, .11);
}

body.vendor-hub-admin .btn-primary,
body.vendor-hub-auth .btn-primary,
body.vendor-hub-admin .btn.orange,
body.vendor-hub-auth .btn.orange {
    background: var(--vh-orange) !important;
    border: 1px solid var(--vh-orange);
    color: #fff !important;
}

body.vendor-hub-admin .btn-primary:hover,
body.vendor-hub-admin .btn-primary:focus,
body.vendor-hub-auth .btn-primary:hover,
body.vendor-hub-auth .btn-primary:focus,
body.vendor-hub-admin .btn.orange:hover,
body.vendor-hub-admin .btn.orange:focus,
body.vendor-hub-auth .btn.orange:hover,
body.vendor-hub-auth .btn.orange:focus {
    background: var(--vh-clay) !important;
    border-color: var(--vh-clay);
    color: #fff !important;
}

body.vendor-hub-admin .btn-secondary,
body.vendor-hub-auth .btn-secondary {
    background: var(--vh-grey) !important;
    border: 1px solid var(--vh-grey);
    color: var(--vh-charcoal) !important;
}

body.vendor-hub-admin .btn-secondary:hover,
body.vendor-hub-admin .btn-secondary:focus,
body.vendor-hub-auth .btn-secondary:hover,
body.vendor-hub-auth .btn-secondary:focus {
    background: var(--vh-grey-hover) !important;
    border-color: var(--vh-grey-hover);
    color: var(--vh-charcoal) !important;
}

body.vendor-hub-admin .btn.red,
body.vendor-hub-auth .btn.red,
body.vendor-hub-admin button.red,
body.vendor-hub-auth button.red {
    background: var(--vh-danger) !important;
    color: #fff !important;
}

body.vendor-hub-admin .btn.red:hover,
body.vendor-hub-admin .btn.red:focus,
body.vendor-hub-auth .btn.red:hover,
body.vendor-hub-auth .btn.red:focus {
    background: #8E1E18 !important;
}

body.vendor-hub-admin .btn:disabled,
body.vendor-hub-admin .btn[disabled],
body.vendor-hub-auth .btn:disabled,
body.vendor-hub-auth .btn[disabled] {
    background: #E7E3DC !important;
    color: #9A948D !important;
    box-shadow: none;
}

/* Admin shell */
body.vendor-hub-admin {
    min-height: 100vh;
}

body.vendor-hub-admin .main {
    min-height: 100vh;
    padding: 34px 0 64px 282px;
    position: relative;
}

body.vendor-hub-admin .main::before {
    border: 2px solid rgba(219, 74, 43, .09);
    border-left: 0;
    border-radius: 0 0 0 140px;
    content: "";
    height: 190px;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    width: 260px;
}

body.vendor-hub-admin .wide-container {
    max-width: 1480px;
    position: relative;
    width: min(92%, 1480px);
    z-index: 1;
}

body.vendor-hub-admin .main h1 {
    color: var(--vh-charcoal);
    font-size: clamp(2.15rem, 3vw, 3.15rem);
    font-weight: 720;
    letter-spacing: -.035em;
    line-height: 1.12;
    margin: 12px 0 16px;
}

body.vendor-hub-admin .main h4,
body.vendor-hub-admin .main h5,
body.vendor-hub-admin .main h6,
body.vendor-hub-admin .main .card-title {
    color: var(--vh-charcoal);
    font-weight: 680;
}

body.vendor-hub-admin .main > .wide-container > .row:first-child,
body.vendor-hub-admin .main > .wide-container > .row:first-child > [class*="col"] {
    position: relative;
}

body.vendor-hub-admin hr {
    background: var(--vh-grey);
    border: 0;
    height: 1px;
}

body.vendor-hub-admin .main > .wide-container > .row:first-child > hr,
body.vendor-hub-admin .main > .wide-container > hr {
    background: linear-gradient(90deg, var(--vh-orange) 0 74px, var(--vh-grey) 74px 100%);
    height: 2px;
    margin-bottom: 28px;
}

/* Navigation */
body.vendor-hub-admin .sidenav.sidenav-fixed {
    background: #fff !important;
    border-right: 1px solid var(--vh-grey);
    box-shadow: 6px 0 24px rgba(37, 35, 33, .035);
    margin-left: 0;
    padding: 10px 14px 28px;
    width: 282px;
}

body.vendor-hub-admin .foodstream-logo {
    margin: 18px auto 8px;
    max-width: 210px;
}

body.vendor-hub-admin .version {
    color: var(--vh-muted);
    font-size: .72rem;
    letter-spacing: .025em;
}

body.vendor-hub-admin .vendor-logo {
    margin-top: 16px;
}

body.vendor-hub-admin .rest-logo {
    background: var(--vh-cream) !important;
    border: 3px solid var(--vh-grey);
    box-shadow: 0 7px 18px rgba(37, 35, 33, .1);
    height: 88px !important;
    object-fit: cover;
    width: 88px !important;
}

body.vendor-hub-admin .sidenav h5 {
    color: var(--vh-charcoal);
    font-family: var(--fs-font-heading);
    font-size: 1.05rem;
    font-weight: 650;
    margin: 10px 8px 18px;
}

body.vendor-hub-admin .nav-hr {
    background: var(--vh-grey);
    margin: 0 auto 12px;
    max-width: calc(100% - 18px);
}

body.vendor-hub-admin .nav-item {
    border-radius: 12px;
    margin: 3px 0;
    overflow: hidden;
    transition: background-color .16s ease, opacity .16s ease;
}

body.vendor-hub-admin .nav-item:hover {
    background: var(--vh-cream);
    transform: none;
}

body.vendor-hub-admin .sidenav li > a {
    align-items: center;
    border-radius: 12px;
    color: #4F4A46;
    display: flex;
    font-size: .91rem;
    font-weight: 620;
    height: 45px;
    line-height: 1.2;
    padding: 0 14px;
}

body.vendor-hub-admin .sidenav li > a > i {
    color: #7A746E;
    flex: 0 0 28px;
    font-size: 1rem !important;
    margin: 0 10px 0 0;
    text-align: center;
}

body.vendor-hub-admin .nav-item.nav-active,
body.vendor-hub-admin .nav-item.nav-active:hover {
    background: var(--vh-orange);
}

body.vendor-hub-admin .nav-item.nav-active > a,
body.vendor-hub-admin .nav-item.nav-active > a > i {
    color: #fff !important;
}

body.vendor-hub-admin .nav-item-locked {
    opacity: .5;
}

body.vendor-hub-admin .nav-item-locked:hover {
    opacity: .72;
}

body.vendor-hub-admin .nav-lock-icon {
    color: currentColor !important;
    right: 12px;
}

body.vendor-hub-admin .sidenav-trigger {
    align-items: center;
    background: #fff;
    border: 1px solid var(--vh-grey);
    border-radius: 12px;
    box-shadow: 0 6px 18px rgba(37, 35, 33, .1);
    display: none;
    height: 48px;
    justify-content: center;
    left: 18px;
    margin: 0 !important;
    padding: 0;
    position: fixed;
    top: 18px;
    width: 48px;
    z-index: 998;
}

body.vendor-hub-admin .sidenav-trigger i {
    color: var(--vh-orange) !important;
    font-size: 1.3rem !important;
}

/* Cards and surfaces */
body.vendor-hub-admin .main .card,
body.vendor-hub-admin .modal,
body.vendor-hub-auth .login-card {
    background: #fff;
    border: 1px solid var(--vh-grey);
    border-radius: 18px;
    box-shadow: 0 14px 36px rgba(37, 35, 33, .065);
}

body.vendor-hub-admin .main .card .card-content {
    padding: 24px;
}

body.vendor-hub-admin .main .card.small {
    border-radius: 18px;
}

body.vendor-hub-admin .card-panel,
body.vendor-hub-auth .card-panel {
    background: #fff;
    border: 1px solid var(--vh-grey);
    border-radius: 14px;
    box-shadow: none;
}

body.vendor-hub-admin .grey.lighten-4,
body.vendor-hub-auth .grey.lighten-4,
body.vendor-hub-admin .teal.lighten-5,
body.vendor-hub-auth .teal.lighten-5 {
    background: var(--vh-cream) !important;
}

body.vendor-hub-admin .green,
body.vendor-hub-auth .green {
    background-color: var(--vh-green) !important;
}

body.vendor-hub-admin .green.lighten-4,
body.vendor-hub-admin .green.lighten-5,
body.vendor-hub-auth .green.lighten-4,
body.vendor-hub-auth .green.lighten-5 {
    background: var(--vh-green-soft) !important;
    border-color: #B9DCC8;
}

body.vendor-hub-admin .green-text,
body.vendor-hub-auth .green-text {
    color: var(--vh-green) !important;
}

body.vendor-hub-admin .orange,
body.vendor-hub-auth .orange {
    background-color: var(--vh-orange) !important;
}

body.vendor-hub-admin .card-panel.orange.lighten-4,
body.vendor-hub-admin .card-panel.orange.lighten-5,
body.vendor-hub-auth .card-panel.orange.lighten-4,
body.vendor-hub-auth .card-panel.orange.lighten-5 {
    background: var(--vh-amber-soft) !important;
    border-color: #F0D09A;
}

body.vendor-hub-admin .orange-text,
body.vendor-hub-auth .orange-text {
    color: #9A5A00 !important;
}

body.vendor-hub-admin .red,
body.vendor-hub-auth .red {
    background-color: var(--vh-danger) !important;
}

body.vendor-hub-admin .red.lighten-4,
body.vendor-hub-admin .red.lighten-5,
body.vendor-hub-auth .red.lighten-4,
body.vendor-hub-auth .red.lighten-5 {
    background: var(--vh-danger-soft) !important;
    border-color: #E8B7B2;
}

body.vendor-hub-admin .red-text,
body.vendor-hub-auth .red-text {
    color: var(--vh-danger) !important;
}

body.vendor-hub-admin .grey-text,
body.vendor-hub-auth .grey-text {
    color: var(--vh-muted) !important;
}

/* Tables */
body.vendor-hub-admin .main table {
    background: #fff;
    border-collapse: separate;
    border-spacing: 0;
    color: var(--vh-charcoal);
}

body.vendor-hub-admin .main thead {
    background: var(--vh-cream);
}

body.vendor-hub-admin .main th {
    border-bottom: 1px solid var(--vh-grey);
    color: #5C5651;
    font-size: .76rem;
    font-weight: 750;
    letter-spacing: .055em;
    padding: 15px 14px;
    text-transform: uppercase;
}

body.vendor-hub-admin .main td {
    border-bottom: 1px solid #EEEAE4;
    padding: 15px 14px;
    vertical-align: middle;
}

body.vendor-hub-admin .main tbody tr:last-child td {
    border-bottom: 0;
}

body.vendor-hub-admin .main table.striped > tbody > tr:nth-child(odd) {
    background: #FCFAF7;
}

body.vendor-hub-admin .main tbody tr:hover {
    background: var(--vh-cream);
}

/* Forms and Materialize inputs */
body.vendor-hub-admin .input-field label,
body.vendor-hub-auth .input-field label,
body.vendor-hub-admin .helper-text,
body.vendor-hub-auth .helper-text {
    color: var(--vh-muted);
}

body.vendor-hub-admin input:not([type]),
body.vendor-hub-auth input:not([type]),
body.vendor-hub-admin input[type=text]:not(.browser-default),
body.vendor-hub-auth input[type=text]:not(.browser-default),
body.vendor-hub-admin input[type=password]:not(.browser-default),
body.vendor-hub-auth input[type=password]:not(.browser-default),
body.vendor-hub-admin input[type=email]:not(.browser-default),
body.vendor-hub-auth input[type=email]:not(.browser-default),
body.vendor-hub-admin input[type=url]:not(.browser-default),
body.vendor-hub-auth input[type=url]:not(.browser-default),
body.vendor-hub-admin input[type=tel]:not(.browser-default),
body.vendor-hub-auth input[type=tel]:not(.browser-default),
body.vendor-hub-admin input[type=number]:not(.browser-default),
body.vendor-hub-auth input[type=number]:not(.browser-default),
body.vendor-hub-admin input[type=date]:not(.browser-default),
body.vendor-hub-auth input[type=date]:not(.browser-default),
body.vendor-hub-admin input[type=time]:not(.browser-default),
body.vendor-hub-auth input[type=time]:not(.browser-default),
body.vendor-hub-admin textarea.materialize-textarea,
body.vendor-hub-auth textarea.materialize-textarea,
body.vendor-hub-admin .select-wrapper input.select-dropdown,
body.vendor-hub-auth .select-wrapper input.select-dropdown {
    border-bottom-color: #BDB7B0;
    color: var(--vh-charcoal);
}

body.vendor-hub-admin input:not([type]):focus:not([readonly]),
body.vendor-hub-auth input:not([type]):focus:not([readonly]),
body.vendor-hub-admin input[type=text]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-auth input[type=text]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-admin input[type=password]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-auth input[type=password]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-admin input[type=email]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-auth input[type=email]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-admin input[type=url]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-auth input[type=url]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-admin input[type=tel]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-auth input[type=tel]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-admin input[type=number]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-auth input[type=number]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-admin input[type=date]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-auth input[type=date]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-admin input[type=time]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-auth input[type=time]:not(.browser-default):focus:not([readonly]),
body.vendor-hub-admin textarea.materialize-textarea:focus:not([readonly]),
body.vendor-hub-auth textarea.materialize-textarea:focus:not([readonly]),
body.vendor-hub-admin .select-wrapper input.select-dropdown:focus,
body.vendor-hub-auth .select-wrapper input.select-dropdown:focus {
    border-bottom-color: var(--vh-orange);
    box-shadow: 0 1px 0 0 var(--vh-orange);
}

body.vendor-hub-admin input:focus:not([readonly]) + label,
body.vendor-hub-auth input:focus:not([readonly]) + label,
body.vendor-hub-admin textarea.materialize-textarea:focus:not([readonly]) + label,
body.vendor-hub-auth textarea.materialize-textarea:focus:not([readonly]) + label,
body.vendor-hub-admin .input-field .prefix.active,
body.vendor-hub-auth .input-field .prefix.active {
    color: var(--vh-orange);
}

body.vendor-hub-admin input.valid:not([type]),
body.vendor-hub-auth input.valid:not([type]),
body.vendor-hub-admin input.valid:not(.browser-default),
body.vendor-hub-auth input.valid:not(.browser-default),
body.vendor-hub-admin textarea.materialize-textarea.valid,
body.vendor-hub-auth textarea.materialize-textarea.valid {
    border-bottom-color: var(--vh-green);
    box-shadow: 0 1px 0 0 var(--vh-green);
}

body.vendor-hub-admin .venue-logo-upload {
    align-items: center;
    display: grid;
    gap: 22px;
    grid-template-columns: 124px minmax(0, 1fr);
    padding-top: 10px;
}

body.vendor-hub-admin .venue-logo-preview {
    align-items: center;
    background: var(--vh-cream);
    border: 1px solid var(--vh-grey);
    border-radius: 16px;
    display: flex;
    height: 96px;
    justify-content: center;
    padding: 14px;
}

body.vendor-hub-admin .venue-logo-preview-image {
    display: block;
    max-height: 68px;
    max-width: 100%;
    object-fit: contain;
}

body.vendor-hub-admin .venue-logo-file-field {
    align-items: center;
    display: flex;
    margin: 0;
    min-width: 0;
}

body.vendor-hub-admin .venue-logo-upload-button {
    flex: 0 0 auto;
    margin: 0 14px 0 0;
    overflow: hidden;
}

body.vendor-hub-admin .venue-logo-file-field .file-path-wrapper {
    flex: 1 1 auto;
    min-width: 0;
    padding-left: 0;
}

body.vendor-hub-admin .venue-logo-file-field input.file-path {
    margin-bottom: 0;
}

body.vendor-hub-admin input.invalid:not([type]),
body.vendor-hub-auth input.invalid:not([type]),
body.vendor-hub-admin input.invalid:not(.browser-default),
body.vendor-hub-auth input.invalid:not(.browser-default),
body.vendor-hub-admin textarea.materialize-textarea.invalid,
body.vendor-hub-auth textarea.materialize-textarea.invalid {
    border-bottom-color: var(--vh-danger);
    box-shadow: 0 1px 0 0 var(--vh-danger);
}

body.vendor-hub-admin .dropdown-content,
body.vendor-hub-auth .dropdown-content {
    background: #fff;
    border: 1px solid var(--vh-grey);
    border-radius: 12px;
    box-shadow: 0 14px 34px rgba(37, 35, 33, .14);
    overflow: hidden;
}

body.vendor-hub-admin .dropdown-content li > a,
body.vendor-hub-admin .dropdown-content li > span,
body.vendor-hub-auth .dropdown-content li > a,
body.vendor-hub-auth .dropdown-content li > span {
    color: var(--vh-charcoal) !important;
}

body.vendor-hub-admin .dropdown-content li:hover,
body.vendor-hub-admin .dropdown-content li.active,
body.vendor-hub-admin .dropdown-content li.selected,
body.vendor-hub-auth .dropdown-content li:hover,
body.vendor-hub-auth .dropdown-content li.active,
body.vendor-hub-auth .dropdown-content li.selected {
    background: var(--vh-cream);
}

body.vendor-hub-admin .dropdown-content li.active > span,
body.vendor-hub-admin .dropdown-content li.selected > span,
body.vendor-hub-auth .dropdown-content li.active > span,
body.vendor-hub-auth .dropdown-content li.selected > span {
    color: var(--vh-orange) !important;
}

/* Checkbox, radio, switch, and range controls. */
body.vendor-hub-admin [type="checkbox"]:checked + span:not(.lever)::before,
body.vendor-hub-auth [type="checkbox"]:checked + span:not(.lever)::before {
    border-bottom-color: var(--vh-orange);
    border-right-color: var(--vh-orange);
}

body.vendor-hub-admin [type="checkbox"].filled-in:checked + span:not(.lever)::after,
body.vendor-hub-auth [type="checkbox"].filled-in:checked + span:not(.lever)::after {
    background: var(--vh-orange);
    border-color: var(--vh-orange);
}

body.vendor-hub-admin [type="radio"]:checked + span::after,
body.vendor-hub-admin [type="radio"].with-gap:checked + span::before,
body.vendor-hub-admin [type="radio"].with-gap:checked + span::after,
body.vendor-hub-auth [type="radio"]:checked + span::after,
body.vendor-hub-auth [type="radio"].with-gap:checked + span::before,
body.vendor-hub-auth [type="radio"].with-gap:checked + span::after {
    border-color: var(--vh-orange);
}

body.vendor-hub-admin [type="radio"]:checked + span::after,
body.vendor-hub-admin [type="radio"].with-gap:checked + span::after,
body.vendor-hub-auth [type="radio"]:checked + span::after,
body.vendor-hub-auth [type="radio"].with-gap:checked + span::after {
    background: var(--vh-orange);
}

body.vendor-hub-admin .switch label input[type="checkbox"]:checked + .lever,
body.vendor-hub-auth .switch label input[type="checkbox"]:checked + .lever {
    background: #E8B6AA;
}

body.vendor-hub-admin .switch label input[type="checkbox"]:checked + .lever::after,
body.vendor-hub-auth .switch label input[type="checkbox"]:checked + .lever::after {
    background: var(--vh-orange);
}

body.vendor-hub-admin .switch label input[type="checkbox"]:checked:not(:disabled) ~ .lever:active::before,
body.vendor-hub-auth .switch label input[type="checkbox"]:checked:not(:disabled) ~ .lever:active::before {
    background: rgba(219, 74, 43, .16);
}

body.vendor-hub-admin input[type="range"]::-webkit-slider-thumb,
body.vendor-hub-auth input[type="range"]::-webkit-slider-thumb,
body.vendor-hub-admin input[type="range"]::-moz-range-thumb,
body.vendor-hub-auth input[type="range"]::-moz-range-thumb,
body.vendor-hub-admin input[type="range"] + .thumb,
body.vendor-hub-auth input[type="range"] + .thumb {
    background: var(--vh-orange);
}

body.vendor-hub-admin input[type="range"]::-webkit-slider-runnable-track,
body.vendor-hub-auth input[type="range"]::-webkit-slider-runnable-track {
    background: var(--vh-grey);
}

/* Tabs, collapsibles, collections, chips, pagination. */
body.vendor-hub-admin .tabs {
    background: transparent;
    border-bottom: 1px solid var(--vh-grey);
}

body.vendor-hub-admin .tabs .tab a,
body.vendor-hub-admin .tabs .tab a:hover,
body.vendor-hub-admin .tabs .tab a.active,
body.vendor-hub-admin .tabs .tab a:focus,
body.vendor-hub-admin .tabs .tab a:focus.active {
    background: transparent;
    color: var(--vh-orange);
}

body.vendor-hub-admin .tabs .tab a:focus,
body.vendor-hub-admin .tabs .tab a:focus.active {
    background: var(--vh-orange-soft);
}

body.vendor-hub-admin .tabs .indicator {
    background: var(--vh-orange);
    height: 3px;
}

body.vendor-hub-admin .collapsible {
    border: 1px solid var(--vh-grey);
    border-radius: 14px;
    box-shadow: none;
}

body.vendor-hub-admin .collapsible-header {
    background: #fff;
    border-bottom-color: var(--vh-grey);
    color: var(--vh-charcoal);
}

body.vendor-hub-admin .collapsible-header:hover {
    background: var(--vh-cream);
}

body.vendor-hub-admin .collapsible-body {
    background: #fff;
    border-bottom-color: var(--vh-grey);
}

body.vendor-hub-admin .collection {
    border-color: var(--vh-grey);
    border-radius: 12px;
    overflow: hidden;
}

body.vendor-hub-admin .collection .collection-item {
    background: #fff;
    border-bottom-color: var(--vh-grey);
}

body.vendor-hub-admin .collection .collection-item.active {
    background: var(--vh-orange);
    color: #fff;
}

body.vendor-hub-admin .secondary-content {
    color: var(--vh-orange);
}

body.vendor-hub-admin .chip,
body.vendor-hub-auth .chip {
    background: var(--vh-grey);
    color: var(--vh-charcoal);
}

body.vendor-hub-admin .chip:focus,
body.vendor-hub-auth .chip:focus {
    background: var(--vh-orange);
    color: #fff;
}

body.vendor-hub-admin .pagination li.active {
    background: var(--vh-orange);
}

body.vendor-hub-admin .pagination-link {
    border-radius: 10px;
}

/* Modal and picker surfaces. */
body.vendor-hub-admin .modal,
body.vendor-hub-auth .modal {
    max-height: 88%;
}

body.vendor-hub-admin .modal .modal-content,
body.vendor-hub-auth .modal .modal-content {
    padding: 28px;
}

body.vendor-hub-admin .modal .modal-footer,
body.vendor-hub-auth .modal .modal-footer {
    background: var(--vh-cream);
    border-top: 1px solid var(--vh-grey);
    padding: 4px 16px;
}

body.vendor-hub-admin .modal-overlay,
body.vendor-hub-auth .modal-overlay {
    background: var(--vh-charcoal);
}

body.vendor-hub-admin .timepicker-modal,
body.vendor-hub-auth .timepicker-modal,
body.vendor-hub-admin .datepicker-modal,
body.vendor-hub-auth .datepicker-modal {
    border-radius: 18px;
}

body.vendor-hub-admin .timepicker-digital-display,
body.vendor-hub-auth .timepicker-digital-display,
body.vendor-hub-admin .datepicker-date-display,
body.vendor-hub-auth .datepicker-date-display {
    background: var(--vh-orange);
}

body.vendor-hub-admin .timepicker-canvas line,
body.vendor-hub-auth .timepicker-canvas line {
    stroke: var(--vh-orange);
}

body.vendor-hub-admin .timepicker-canvas-bg,
body.vendor-hub-admin .timepicker-canvas-bearing,
body.vendor-hub-auth .timepicker-canvas-bg,
body.vendor-hub-auth .timepicker-canvas-bearing {
    fill: var(--vh-orange);
}

body.vendor-hub-admin .timepicker-tick.active,
body.vendor-hub-admin .timepicker-tick:hover,
body.vendor-hub-auth .timepicker-tick.active,
body.vendor-hub-auth .timepicker-tick:hover,
body.vendor-hub-admin .datepicker-table td.is-today,
body.vendor-hub-auth .datepicker-table td.is-today,
body.vendor-hub-admin .datepicker-cancel,
body.vendor-hub-admin .datepicker-clear,
body.vendor-hub-admin .datepicker-today,
body.vendor-hub-admin .datepicker-done,
body.vendor-hub-auth .datepicker-cancel,
body.vendor-hub-auth .datepicker-clear,
body.vendor-hub-auth .datepicker-today,
body.vendor-hub-auth .datepicker-done,
body.vendor-hub-admin .timepicker-close,
body.vendor-hub-auth .timepicker-close {
    color: var(--vh-orange);
}

body.vendor-hub-admin .datepicker-table td.is-selected,
body.vendor-hub-auth .datepicker-table td.is-selected {
    background: var(--vh-orange);
    color: #fff;
}

body.vendor-hub-admin .datepicker-day-button:focus,
body.vendor-hub-auth .datepicker-day-button:focus {
    background: rgba(219, 74, 43, .14);
}

/* Progress and loading states. */
body.vendor-hub-admin .progress,
body.vendor-hub-auth .progress {
    background: #F0C8BF;
}

body.vendor-hub-admin .progress .determinate,
body.vendor-hub-admin .progress .indeterminate,
body.vendor-hub-auth .progress .determinate,
body.vendor-hub-auth .progress .indeterminate {
    background: var(--vh-orange);
}

body.vendor-hub-admin .spinner-layer,
body.vendor-hub-auth .spinner-layer {
    border-color: var(--vh-orange);
}

body.vendor-hub-admin blockquote,
body.vendor-hub-auth blockquote {
    border-left-color: var(--vh-orange);
}

/* Toasts retain semantic status but never Materialize's default palette. */
body.vendor-hub-admin #toast-container,
body.vendor-hub-auth #toast-container {
    max-width: min(92vw, 520px);
}

body.vendor-hub-admin .toast,
body.vendor-hub-auth .toast {
    background: var(--vh-charcoal);
    border-radius: 12px;
    box-shadow: 0 12px 30px rgba(37, 35, 33, .2);
    color: #fff;
    font-weight: 600;
}

body.vendor-hub-admin .toast.green,
body.vendor-hub-auth .toast.green {
    background: var(--vh-green) !important;
}

body.vendor-hub-admin .toast.orange,
body.vendor-hub-auth .toast.orange {
    background: var(--vh-amber) !important;
    color: var(--vh-charcoal);
}

body.vendor-hub-admin .toast.red,
body.vendor-hub-auth .toast.red {
    background: var(--vh-danger) !important;
}

/* Authentication screens */
body.vendor-hub-auth {
    min-height: 100vh;
    overflow-x: hidden;
    position: relative;
}

body.vendor-hub-auth::before,
body.vendor-hub-auth::after {
    border: 3px solid rgba(219, 74, 43, .1);
    border-left: 0;
    border-radius: 0 0 0 180px;
    content: "";
    height: 240px;
    pointer-events: none;
    position: fixed;
    right: -40px;
    top: -30px;
    transform: rotate(-5deg);
    width: 390px;
    z-index: 0;
}

body.vendor-hub-auth::after {
    border-color: rgba(37, 35, 33, .055);
    bottom: -100px;
    left: -120px;
    right: auto;
    top: auto;
    transform: rotate(8deg);
}

body.vendor-hub-auth > .container,
body.vendor-hub-auth > main.container {
    max-width: 760px;
    min-height: 100vh;
    padding-bottom: 52px;
    position: relative;
    z-index: 1;
}

body.vendor-hub-auth .login-logo {
    padding: 64px 20px 28px;
}

body.vendor-hub-auth .login-logo img {
    height: auto;
    max-width: 300px;
    width: 100%;
}

body.vendor-hub-auth .login-card {
    margin: 0 auto;
    max-width: 580px;
    width: 100%;
}

body.vendor-hub-auth .registration-card {
    max-width: 640px;
}

body.vendor-hub-auth .login-card .card-content {
    padding: 34px 38px 36px;
}

body.vendor-hub-auth .login-card h4,
body.vendor-hub-auth .login-card h5 {
    color: var(--vh-charcoal);
    font-weight: 720;
    letter-spacing: -.025em;
    margin-top: 0;
}

body.vendor-hub-auth .login-card p {
    color: var(--vh-muted);
    line-height: 1.6;
}

body.vendor-hub-auth .login-card form {
    margin-top: 24px;
}

body.vendor-hub-auth .login-card .center .btn,
body.vendor-hub-auth .login-card .center input.btn {
    min-width: 142px;
}

body.vendor-hub-auth .accent-text {
    font-weight: 650;
}

/* Responsive shell */
@media only screen and (max-width: 992px) {
    body.vendor-hub-admin .main {
        padding: 88px 0 52px;
    }

    body.vendor-hub-admin .wide-container {
        width: calc(100% - 36px);
    }

    body.vendor-hub-admin .sidenav-trigger {
        display: flex;
    }

    body.vendor-hub-admin .sidenav.sidenav-fixed {
        box-shadow: 8px 0 28px rgba(37, 35, 33, .16);
    }
}

@media only screen and (max-width: 600px) {
    body.vendor-hub-admin .venue-logo-upload {
        gap: 14px;
        grid-template-columns: 1fr;
    }

    body.vendor-hub-admin .venue-logo-preview {
        max-width: 160px;
        width: 100%;
    }

    body.vendor-hub-admin .venue-logo-file-field {
        width: 100%;
    }

    body.vendor-hub-admin .main {
        padding-top: 78px;
    }

    body.vendor-hub-admin .wide-container {
        width: calc(100% - 24px);
    }

    body.vendor-hub-admin .main h1 {
        font-size: 2.15rem;
    }

    body.vendor-hub-admin .main .card .card-content {
        padding: 20px;
    }

    body.vendor-hub-admin .modal .modal-content,
    body.vendor-hub-auth .modal .modal-content {
        padding: 22px;
    }

    body.vendor-hub-admin .btn,
    body.vendor-hub-auth .btn {
        max-width: 100%;
    }

    body.vendor-hub-auth > .container,
    body.vendor-hub-auth > main.container {
        padding-left: 14px;
        padding-right: 14px;
        width: 100%;
    }

    body.vendor-hub-auth .login-logo {
        padding: 44px 28px 24px;
    }

    body.vendor-hub-auth .login-logo img {
        max-width: 235px;
    }

    body.vendor-hub-auth .login-card .card-content {
        padding: 28px 24px 30px;
    }

    body.vendor-hub-auth .login-card .center .btn,
    body.vendor-hub-auth .login-card .center input.btn {
        margin-left: 4px;
        margin-right: 4px;
        min-width: 120px;
    }
}

@media (prefers-reduced-motion: reduce) {
    body.vendor-hub-admin *,
    body.vendor-hub-auth * {
        scroll-behavior: auto !important;
        transition-duration: .01ms !important;
    }
}
