/* KFC NAROK - UNIFIED PLATFORM */

:root {
    --red: #E8001D;
    --red-dk: #A8001A;
    --red-glow: rgba(232,0,29,.18);
    --red-soft: rgba(232,0,29,.10);
    --black: #080808;
    --dark: #101010;
    --dark2: #161616;
    --dark3: #202020;
    --dark4: #282828;
    --line: rgba(255,255,255,.06);
    --line2: rgba(255,255,255,.11);
    --muted: rgba(255,255,255,.32);
    --muted2: rgba(255,255,255,.55);
    --white: #FFFFFF;
    --green: #00C853;
    --green-bg: rgba(0,200,83,.13);
    --orange: #FF6D00;
    --blue: #2979FF;
    --blue-bg: rgba(41,121,255,.13);
    --orange-bg: rgba(255,109,0,.13);
    --purple: #AB47BC;
    --purple-bg: rgba(41,121,255,.13);
    --fh: 'Bebas Neue','sans-serif';
    --fb: 'DM Sans', 'sans-serif';
    --ease: cubic-bezier(.23,1,.32,1);
    --dur: .22s;
    --r: 12px;
    --r-lg: 20px;
    --r-xl: 28px;
    --r-full: 9999px;
}

*,*::before,*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}

body {
    font-family: var(--fb);
    background: var(--black);
    color: var(--white);
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
} 

button {
    cursor: pointer;
    border: none;
    background: none;
    font-family: inherit;
    color: inherit;
}

input,textarea,select {
    font-family: inherit;
    outline: none;
}

a {
    color: inherit;
    text-decoration: none;
}

::-webkit-scrollbar {
    width: 3px;
}
::-webkit-scrollbar-track {
    background: transparent;
}
::-webkit-scrollbar-thumb {
    background: var(--dark4);
    border-radius: 2px;
}

/* SCREENS */
.screen {
    display: none;
    min-height: 100vh;
}
.screen.on {
    display: block;
}

/* TYPOGRAPHY */
.h1 {
    font-family: var(--fh);
    font-size: clamp(2.8rem,10vw,5rem);
    line-height: .95;
    letter-spacing: 2px;
}
.h2 {
    font-family: var(--fh);
    font-size: 1.6rem;
    letter-spacing: 1.5px;
}
.h3 {
    font-family: var(--fh);
    font-size: 1.1rem;
    letter-spacing: 1px;
}
.label {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: 1em;
    text-transform: uppercase;
    color: var(--muted);
}

/* BUTTONS */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 13px 24px;
    border-radius: var(--r-full);
    font-weight: 600;
    font-size: 0.9rem;
    transition: all var(--dur) var(--ease);
    white-space: nowrap;
    cursor: pointer;
}
.btn-primary {
    background: var(--red);
    color: var(--white);
    box-shadow: 0 4px 20px rgba(232, 0, 29, .3);
}
.btn-primary:hover {
    background: var(--red-dk);
    transform: translateY(-1px);
    box-shadow: 0 8px 28px rgba(232, 0, 29, .4);
}
.btn-primary:active {
    transform: translateY(0);
}
.btn-ghost {
    background: transparent;
    color: var(--muted2);
}
.btn-ghost:hover {
    color: var(--white);
}
.btn-green {
    background: var(--green);
    color: var(--black);
    font-weight: 700;
}
.btn-green:hover {
    filter: brightness(1.1);
}
.btn-danger {
    background: rgba(232, 0, 29, .15);
    color: var(--red);
    border: 1px solid rgba(232, 0, 29, .25);
}
.btn-full {
    width: 100%;
}
.btn-lg {
    padding: 7px 28px;
    font-size: .95rem;
}
.btn-sm {
    padding: 7px 14px;
    font-size: .78rem;
}
.btn:disabled {
    opacity: .4;
    cursor: not-allowed;
    transform: none !important;
}

/* INPUTS */
.field {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.field-lbl {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--muted);
}
.inp {
    padding: 13px 14px;
    background: var(--dark2);
    border: 1.5px solid var(--line2);
    border-radius: var(--r);
    color: var(--white);
    font-size: .92rem;
    transition: border-color var(--dur);
    width: 100%;
}
.inp:focus {
    border-color: var(--red);
}
.inp::placeholder {
    color: var(--muted);
}
.phone-row {
    display: flex;
}
.phone-pre {
    background: var(--dark3);
    border: 1.5px solid var(--line2);
    border-right: none;
    border-radius: var(--r) 0 0 var(--r);
    padding: 13px 12px;
    font-size: .85rem;
    color: var(--muted2);
    white-space: nowrap;
}
.phone-row .inp {
    border-radius: 0 var(--r) var(--r) 0;
}

/* CARD */
.card {
    background: var(--dark2);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    padding: 18px;
}
.card-t {
    font-family: var(--fh);
    font-size: 1rem;
    letter-spacing: 1px;
    margin-bottom: 14px;
}

/* BADGES */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: var(--r-full);
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
}

.b-red {
    background: var(--red-soft);
    color: var(--red);
    border: 1px solid rgba(232, 0, 29, .25);
}
.b-green {
    background: var(--green-bg);
    color: var(--green);
    border: 1px solid rgba(0, 200, 83, .25);
}
.b-orange {
    background: var(--orange-bg);
    color: var(--orange);
    border: 1px solid rgba(255, 109, 0, .25);
}
.b-blue {
    background: var(--blue-bg);
    color: var(--blue);
    border: 1px solid rgba(41, 121, 255, .25);
}
.b-muted {
    background: var(--dark3);
    color: var(--muted2);
    border: 1px solid var(--line2);
}

/* SPINNER */
.spin {
    width: 18px;
    height: 18px;
    border: 2px solid rgba(255, 255, 255, .2);
    border-top-color: #fff;
    border-radius: 50%;
    animation: sp .65s linear infinite;
    display: inline-block;
}
@keyframes sp {
    to {
        transform: rotate(360deg);
    }
}

/* DIVIDER */
.div {
    height: 1px;
    background: var(--line);
    margin: 14px 0;
}

/* TOAST */
#toasts {
    position: fixed;
    bottom: 84px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: center;
    pointer-events: none;
}
.toast {
    background: var(--dark4);
    color: var(--white);
    padding: 10px 20px;
    border-radius: var(--r-full);
    font-size: .84rem;
    font-weight: 500;
    border: 1px solid var(--line2);
    box-shadow: 0 8px 30px rgba(0, 0, 0, .5);
    animation: tin .3s var(--ease) both;
    max-width: 300px;
    text-align: center;
}
.toast.ok {
    background: rgba(0, 50, 25, .9);
    border-color: rgba(0, 200, 83, .3);
    color: var(--green);
}
.toast.err {
    background: rgba(60, 0, 10, .9);
    border-color: rgba(232, 0, 29, .3);
    color: #FF6B6B;
}
.toast.warn {
    background: rgba(50, 25, 0, .9);
    border-color: rgba(255, 109, 0, .3);
    color: var(--orange);
}

@keyframes tin {
    from{
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
@keyframes tout {
    from{
        opacity: 1;
    }
    to {
        opacity: 0;
        transform: translateY(8px);
    }
}

/* TOPBAR */
.topbar {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(8, 8, 8, .92);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--line);
    height: 54px;
    display: flex;
    align-items: center;
    padding: 0 16px;
}
.topbar-in {
    max-width: 500px;
    margin: 0;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.tb-logo {
    display: flex;
    align-items: center;
    gap: 10px;
}
.tb-mark {
    width: 32px;
    height: 32px;
    background: var(--red);
    border-radius: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--fh);
    font-size: .85rem;
    letter-spacing: .5px;
    flex-shrink: 0;
}
.tb-title {
    font-family: var(--fh);
    font-size: 1rem;
    letter-spacing: 1px;
}
.tb-right {
    display: flex;
    align-items: center;
    gap: 8px;
}
.exit-btn {
    font-size: .72rem;
    color: var(--muted);
    padding: 5px 10px;
    border-radius: var(--r-full);
    border: 1px solid var(--line2);
    transition: all var(--dur);
}
.exit-btn:hover {
    color: var(--white);
    border-color: var(--line2);
}

/* BOTTOM NAV */
.bnav {
    position: sticky;
    bottom: 0;
    background: rgba(16, 16, 16, .96);
    backdrop-filter: blur(16px);
    border-top: 1px solid var(--line);
    display: flex;
    padding: 6px 8px;
    padding-bottom: calc(6px + env(safe-area-inset-bottom));
    gap: 2px;
}
.bnav-btn {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
    padding: 8px 4px;
    border-radius: var(--r);
    font-size: .59rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted);
    transition: all var(--dur) var(--ease);
}
.bnav-btn .ni {
    font-size: 1.15rem;
    line-height: 1;
}
.bnav-btn.on {
    color: var(--white);
    background: var(--dark3);
}

/* SECTION PANELS */
.sp {
    display: none;
}
.sp.on {
    display: block;
}

/* ANIMATIONS */
@keyframes fadeUp {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
@keyframes blink {
    50% {
        opacity: .2;
    }
}
@keyframes pulse {
    0%,100% {
        box-shadow: 0 0 0 4px var(--red-glow);
    }
    50% {
        box-shadow: 0 0 0 8px rgba(232, 0, 29, .07);
    }
}
@keyframes shake {
    0%,100% {
        transform: translateX(0);
    }
    25% {
        transform: translateX(-8px);
    }
    75% {
        transform: translateX(8px);
    }
}
@keyframes alertGlow {
    from{
        box-shadow: 0 0 0 0 rgba(232, 0, 29, 0);
    }
}


/* LANDING */
#s-landing {
    background: var(--black);
    overflow: hidden;
    position: relative;
}
.land-bg {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 70% 50% at 80% 20%, rgba(232,0,29,.1) 0%, transparent 60%),radial-gradient(ellipse 50% 70% at 15% 80%, rgba(232,0,29,.06) 0%,transparent 55%);
    pointer-events: none;
}
.land-grid {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(var(--line) 1px,transparent 1px), linear-gradient(90deg,var(--line) 1px, transparent 1px);
    background-size: 44px 44px;
    pointer-events: none;
    mask-image: radial-gradient(ellipse 85% 85% at 50% 50%,black 30%,transparent 80%);
}
.land-inner {
    position: relative;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    max-width: 500px;
    margin: 0 auto;
    padding: 0 16px;
}
.land-hdr {
    padding: 28px 0 0;
    display: flex;
    align-items: center;
    gap: 12px;
}
.land-mark {
    width: 46px;
    height: 46px;
    background: var(--red);
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    letter-spacing: 1px;
    flex-shrink: 0;
    box-shadow: 0 0 24px var(--red-glow);
}
.land-brand-name {
    font-family: var(--fh);
    font-size: 1.3rem;
    letter-spacing: 1px;
}
.land-brand-sub {
    font-size: .7rem;
    color: var(--muted);
    letter-spacing: .07em;
    text-transform: uppercase;
}
.land-hero {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 32px 0;
}
.land-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--red-soft);
    border: 1px solid rgba(232, 0, 29, .3);
    border-radius: var(--r-full);
    padding: 5px 14px;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--red);
    margin-bottom: 18px;
    width: fit-content;
}
.live-dot {
    width: 6px;
    height: 6px;
    background: var(--green);
    border-radius: 50%;
    animation: blink 1.4s infinite; 
    box-shadow: 0 0 6px var(--green);
}
.land-title {
    font-family: var(--fb);
    font-size: clamp(1rem,9vw,3.5rem);
    line-height: .92;
    letter-spacing: 2px;
    margin-bottom: 16px;
}
.land-accent {
    color: var(--red);
    display: block;
    font-style: italic;
    font-family:Arial, Helvetica, sans-serif;
    font-size: large;
}
.land-sub {
    font-size: .92rem;
    color: var(--muted2);
    max-width: 360px;
    line-height: 1.65;
    margin-bottom: 36px;
}
.role-label {
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 12px;
}
.role-card {
    background: var(--dark2);
    border: 1.5px solid var(--line2);
    border-radius: var(--r-xl);
    padding: 20px 16px;
    cursor: pointer;
    transition: all var(--dur) var(--ease);
    position: relative;
    overflow: hidden;
    text-align: left;
}
.role-card::before {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity var(--dur);
}
.role-card:hover {
    transform: translateY(-3px);
}
.role-card:active {
    transform: translateY(0) scale(.98);
}
.role-card[data-r="customer"]{
    --cb: var(--red);  
    --cg: rgba(232,0,29,.08);
}
.role-card[data-r="rider"]{
    --cb: var(--blue);
    --cg: rgba(41,121,255,.08);
}
.role-card[data-r="kitchen"]{
    --cb: var(--orange);
    --cg: rgba(255,109,0,.08);
}
.role-card[data-r="admin"]{
    --cb: var(--purple);
    --cg: rgba(171,71,188,.08);
}
.role-card:hover{
    border-color:var(--cb) ;
}
.role-card:hover::before{
    background: radial-gradient(ellipse at top left,var(--cg) 0%, transparent 60%);
    opacity: 1;
}
.role-icon {
    font-size: 1.9rem;
    display: block;
    margin-bottom: 10px;
}
.role-name {
    font-family: var(--fh);
    font-size: 1.15rem;
    letter-spacing: 1px;
    margin-bottom: 3px;
}
.role-desc {
    font-size: .73rem;
    color: var(--muted);
    line-height: 1.4;
}
.land-foot {
    text-align: center;
    font-size: .73rem;
    color: var(--muted);
    padding-bottom: 24px;
}

/*AUTH GATE */
#s-auth {
    background: var(--black);
    display: none;
}
#s-auth.on {
    display: flex;
    flex-direction: column;
}
.auth-back {
    padding: 16px;
    color: var(--muted);
    font-size: .84rem;
    display: flex;
    align-items: center;
    gap: 6px;
    width: fit-content;
}
.auth-back:hover {
    color: var(--white);
}
.auth-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 32px 16px 40px;
    max-width: 400px;
    margin: 0 auto;
    width: 100%;
    animation: fedUp .35s var(--ease) both;
}
.auth-icon {
    font-size: 3rem;
    margin-bottom: 14px;
}
.auth-title {
    font-family: var(--fh);
    font-size: 2.4rem;
    letter-spacing: 2px;
    margin-bottom: 6px;
}
.auth-sub {
    font-size: .87rem;
    color: var(--muted);
    margin-bottom: 28px;
    line-height: 1.55;
}
.auth-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

/* CUSTOMER */
.c-hero {
    background: linear-gradient(135deg,var(--red-dk) 0%,var(--red) 65%, #FF1A35 100%);
    padding: 26px 16px 72px;
    position: relative;
    overflow: hidden;
}
.c-hero::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 44px;
    background: var(--black);
    clip-path: ellipse(55% 100% at 50% 100%);
}
.c-hw {
    max-width: 500px;
    margin: 0 auto;
}
.c-greet {
    font-size: .83rem;
    color: rgba(255, 255, 255, .7);
    margin-bottom: 4px;
}
.c-title {
    font-family: var(--fh);
    font-size: 2rem;
    letter-spacing: 2px;
    margin-bottom: 10px;
}
.c-pills {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.c-pill {
    background: rgba(0, 0, 0, .2);
    border-radius: var(--r-full);
    padding: 4px 12px;
    font-size: .73rem;
    color: rgba(255, 255, 255, .85);
}

.cat-bar {
    position: sticky;
    z-index: 1000;
    top: 0;
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 12px 16px;
    scrollbar-width: none;
    max-width: 500px;
    margin: 0 auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}
.cat-bar::-webkit-scrollbar {
    display: none;
}
.cat-btn {
    padding: 7px 16px;
    border-radius: var(--r-full);
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    white-space: nowrap;
    border: 1.5px solid var(--line2);
    background: var(--dark2);
    color: var(--muted2);
    transition: all var(--dur) var(--ease);
    scroll-snap-align: start;
    flex-shrink: 0;
}
.cat-btn.on {
    background: var(--red);
    color: var(--white);
    border-color: var(--red);
}
.cat-btn:hover:not(.on){
    border-color: var(--line2);
    color: var(--white);
}


.menu-wrap {
    max-width: 500px;
    margin: 0 auto;
    padding: 14px 16px 110px;
}
.menu-sec-lbl {
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 9px;
    margin-top: 18px;
}
.menu-sec-lbl:first-child {
    margin-top: 0;
}
.mi {
    background: var(--dark2);
    border: 1.5px solid var(--line);
    border-radius: var(--r-lg);
    padding: 13px;
    display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    transition: all var(--dur) var(--ease);
    margin-bottom: 8px;
    animation: fadeUp .3s var(--ease) both;
}
.mi:hover {
    border-color: var(--red);
    transform: translateY(-3px);
}
.mi-emoji {
    width: 50px;
    height: 50px;
    flex-shrink: 0;
    background: var(--dark3);
    border-radius: var(--r);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.55rem;
}
.mi-img {
    width: 80px;
    height: 80px;
    flex-shrink: 0;
    overflow: hidden;
    border-radius: var(--r);
    background: var(--dark3); 
}
.mi-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s var(--ease);
}
.mi:hover .mi-img img {
    transform: scale(1.07);
}
.mi-info {
    flex: 1;
    min-width: 0;
}
.mi-name {
    font-weight: 600;
    font-size: .9rem;
    margin-bottom: 2px;
}
.mi-desc {
    font-size: .74rem;
    color: var(--muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mi-r {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
    flex-shrink: 0;
}
.mi-price {
    font-family: var(--fh);
    font-size: 1.05rem;
    color: var(--red);
    letter-spacing: 1px;
}
.mi-add {
    width: 28px;
    height: 28px;
    background: var(--red);
    border-radius: var(--r-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    color: #fff;
    transition: transform var(--dur) var(--ease);
}
.mi-add:hover {
    transform: scale(1.18);
}

/* ── Brand New grid layout ───────────────────────────────────────── */
/* ── Brand New grid layout ───────────────────────────────────────── */
.mi-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    padding-bottom: 4px;
}
.mi-card {
    background: var(--dark2);
    border: 1.5px solid var(--line);
    border-radius: var(--r-lg);
    overflow: hidden;
    cursor: pointer;
    transition: all var(--dur) var(--ease);
    animation: fadeUp .3s var(--ease) both;
    display: flex;
    flex-direction: column;
}
.mi-card:hover {
    border-color: var(--red);
    transform: translateY(-3px);
}
.mi-card-img {
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--dark3);
}
.mi-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s var(--ease);
}
.mi-card:hover .mi-card-img img {
    transform: scale(1.07);
}
.mi-card-emoji {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
}
.mi-card-body {
    padding: 10px 10px 8px;
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 3px;
}
.mi-card-name {
    font-weight: 700;
    font-size: .82rem;
    line-height: 1.25;
}
.mi-card-desc {
    font-size: .7rem;
    color: var(--muted);
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.mi-card-foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 6px;
}
.mi-card-price {
    font-family: var(--fh);
    font-size: .95rem;
    color: var(--red);
    letter-spacing: 1px;
}
/* Cart Float */
.cart-float {
    position: fixed;
    bottom: 70px;
    left: 16px;
    right: 16px;
    z-index: 200;
    width: auto;
    background: var(--red);
    color: var(--white);
    border-radius: 50px;
    padding: 14px 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    box-shadow: 0 4px 20px rgba(0, 0, 0, .4);
    cursor: pointer;
    transition: all var(--dur) var(--ease);
    border: none;
}
.cart-float:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 50px rgba(0, 0, 0, .75);
}
.cf-l {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    font-size: .9rem;
}
.cf-cnt {
    background: var(--red);
    color: #fff;
    border-radius: var(--r-full);
    width: 22px;
    height: 22px;
    font-size: .7rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
}
.cf-p {
    font-family: var(--fh);
    font-size: 1rem;
    letter-spacing: 1px;
    white-space: nowrap; /*prevents price from wrapping */
}

/* Sheet */
.overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .72);
    z-index: 200;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--dur);
}
.overlay.on {
    opacity: 1;
    pointer-events: all;
}
.sheet {
    position: fixed;
    bottom: 0;
    right: 0;
    background: var(--dark);
    border-radius: var(--r-xl) 0 0;
    z-index: 300;
    min-height: 92vh;
    overflow-y: auto;
    transform: translateY(100%);
    transition: transform .38s var(--ease);
    padding-bottom: calc(20px + env(safe-area-inset-bottom));
}
.sheet.on {
    transform: translateY(0);
}
.sh-in {
    max-width: 500px;
    margin: 0 auto;
    padding: 0 16px;
}
.sh-handle {
    width: 36px;
    height: 4px;
    background: var(--dark4);
    border-radius: var(--r-full);
    margin: 11px auto 18px;
}
.sh-title {
    font-family: var(--fh);
    font-size: 1.3rem;
    letter-spacing: 1px;
    margin-bottom: 18px;
}
.ci {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 11px 0;
    border-bottom: 1px solid var(--line);
}
.ci:last-of-type {
    border-bottom: none;
}
.ci-info {
    flex: 1;
}
.ci-name {
    font-weight: 600;
    font-size: .88rem;
    margin-bottom: 4px;
}
.note-inp {
    width: 100%;
    background: var(--dark3);
    border: 1px solid var(--line2);
    border-radius: var(--r-sm,6px);
    padding: 7px 10px;
    font-size: .76rem;
    color: var(--muted2);
    resize: none;
    margin-top: 3px;
}
.note-inp:focus {
    border-color: var(--red);
    color: var(--white);
}
.ci-r {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
    flex-shrink: 0;
}
.ci-price {
    font-family: var(--fh);
    font-size: .95rem;
    color: var(--red);
    letter-spacing: 1px;
}
.ci-rm {
    font-size: .9rem;
    color: var(--muted);
    transition: color var(--dur);
}
.ci-rm:hover {
    color: var(--red);
}
.cart-sum {
    background: var(--dark3);
    border-radius: var(--r);
    padding: 13px;margin: 14px 0;
}
.srow {
    display: flex;
    justify-content: space-between;
    font-size: .87rem;
    padding: 3px 0;
    color: var(--muted);
}
.srow.tot {
    border-top: 1px solid var(--line2);
    margin-top: 8px;padding-top: 9px;
    font-weight: 700;
    font-size: 1rem;
    color: var(--white);
}
.srow .nt {
    font-size: .73rem;
    color: var(--muted);
}

/* Checkout steps */
.step-hdr {
    padding: 22px 16px;
    min-width: 500px;
    margin: 0 auto;
    text-align: center;
}
.step-ico {
    font-size: 2.8rem;
    margin-bottom: 10px;
}
.step-tit {
    font-family: var(--fh);
    font-size: 1.7rem;
    letter-spacing: 2px;
    margin-bottom: 5px;
}
.step-sub {
    font-size: .87rem;
    color: var(--muted);
}
.step-bod {
    max-width: 500px;
    margin: 0 auto;
    padding: 18px 16px 100px;
}
.loc-ok {
    background: var(--green-bg);
    border: 1px solid rgba(0, 200, 83, .3);
    border-radius: var(--r);
    padding: 13px;
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 14px;
}
.loc-ok-ico {
    font-size: 1.3rem;
}
.loc-ok-t {
    font-size: .87rem;
    font-weight: 600;
    color: var(--white);
}
.loc-ok-s {
    font-size: .73rem;
    color: rgba(255, 255, 255, .8);
}
.pay-big {
    font-family: var(--fh);
    font-size: 3.8rem;
    color: var(--red);
    text-align: center;
    margin: 18px 0;
    letter-spacing: 2px;
}
.pay-row {
    background: var(--dark3);
    border-radius: var(--r);
    padding: 11px 14px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: .87rem;
    margin-bottom: 8px;
}
.mpesa-chip {
    background: #00A651;
    color: #fff;
    font-weight: 800;
    font-size: .66rem;
    padding: 3px 8px;
    border-radius: 6px;
    white-space: nowrap;
}

/* Tracking */
.trk-hdr {
    background: var(--dark2);
    padding: 18px 16px;
    max-width: 500px;
    margin: 0 auto;
}
.trk-non {
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    color: var(--muted);
    text-transform: uppercase;
}
.trk-st {
    font-family: var(--fh);
    font-size: 1.9rem;
    letter-spacing: 2px;
    margin: 3px 0;
}
.trk-eta {
    font-size: .8rem;
    color: var(--muted);
}
.prog {
    display: flex;
    align-items: center;
    padding: 18px 16px;
    max-width: 500px;
    margin: 0 auto;
}
.ps {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
}
.ps::after {
    content: '';
    position: absolute;
    top: 14px;
    left: 50%;
    right: -50%;
    height: 2px;
    background: var(--line2);
    z-index: 0;
}
.ps:last-child::after {
    display: none;
}
.ps.done::after {
    background: var(--green);
}
.pd {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--dark3);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .8rem;
    z-index: 1;
    transition: all .3s;
}
.ps.done .pd {
    background: var(--green);
}
.ps.act .pd {
    background: var(--red);
    box-shadow: 0 0 0 4px var(--red-glow);
    animation: pulse 1.5s infinite;
}
.pl {
    font-size: .6rem;
    color: var(--muted);
    margin-top: 5px;
    text-align: center;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
}
.ps.act .pl {
    color: var(--red);
}
.ps.done .pl{
    color: var(--green);
}
.map-ph {
    background: linear-gradient(135deg, #0D1B2A, #162030,);
    height: 150px;
    border-radius: var(--r-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    border: 1px solid var(--line);
    margin-bottom: 14px;
}
.map-ph::before {
    content: '🗺️';
    font-size: 3rem;
    opacity: 0.25;
    position: absolute;
}
.map-link {
    position: absolute;
    bottom: 10px;
    background: var(--dark);
    border-radius: var(--r-full);
    padding: 5px 13px;
    font-size: .76rem;
    font-weight: 700;
    border: 1px solid var(--line2);
    color: var(--blue);
}
.stars {
    display: flex;
    gap: 8px;
    justify-content: center;
    margin: 4px 0;
}
.star {
    font-size: 2rem;
    cursor: pointer;
    transition: transform .1s;
    line-height: 1;
}
.star:hover {
    transform: scale(1.2);
}
.star.lit {
    filter: none;
    animation: sp2 .2s var(--ease);
}
@keyframes sp2 {
    0% {
        transform: scale(.8);
    }
    60% {
        transform: scale(1.3);
    }
    100% {
        transform: scale(1);
    }
}
.hist-item {
    background: var(--dark2);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    padding: 13px 14px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 7px;
}
.hi-num {
    font-family: var(--fh);
    font-size: .92rem;
    letter-spacing: 1px;
}
.hi-items {
    font-size: .75rem;
    color: var(--muted);
    margin-top: 2px;
}
.hi-date {
    font-size: .7rem;
    color: var(--muted);
}
.hi-p {
    font-family: var(--fh);
    font-size: .95rem;
    color: var(--red);
    letter-spacing: 1px;
}


/* RIDER */
.r-prof {
    background:var(--dark2);
    border:1px solid var(--line);
    border-radius:var(--r-xl);
    padding:18px;
    display:flex;
    gap:13px;
    align-items:center;
    margin:14px auto;
    max-width:468px;
}
.r-av {
    width:50px;
    height:50px;
    border-radius:50%;
    background:var(--red);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:1.35rem;
    flex-shrink:0;
}
.r-name {
    font-family:var(--fh);
    font-size:1.2rem;
    letter-spacing:1px
}
.r-meta {
    font-size:.76rem;
    color:var(--muted);
    margin-top:2px;
}
.toggle-c {
    background:var(--dark2);
    border:1px solid var(--line);
    border-radius:var(--r-xl);
    padding:18px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    max-width:468px;
    margin:0 auto 11px;
}
.tg-lbl {
    font-family:var(--fh);
    font-size:1.1rem;
    letter-spacing:1px;
}
.tg-sub {
    font-size:.76rem;
    color:var(--muted);
    margin-top:2px;
}
.tg-sw {
    width:50px;
    height:26px;
    border-radius:var(--r-full);
    background:var(--dark3);
    cursor:pointer;
    position:relative;
    transition:background .3s;
    border:1px solid var(--line2);
}
.tg-sw.on {
    background:var(--green);
    border-color:var(--green)
}
.tg-sw::after {
    content:'';
    position:absolute;
    width:20px;
    height:20px;
    background:#fff;
    border-radius:50%;
    top:2px;
    left:2px;
    transition:transform .3s var(--ease);
    box-shadow:0 2px 6px rgba(0,0,0,.4);
}
.tg-sw.on::after {
    transform:translateX(24px);
}
.stats2 {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:9px;
    max-width:468px;
    margin:0 auto 14px;
    padding:0 16px;
}
.sm {
    background:var(--dark2);
    border:1px solid var(--line);
    border-radius:var(--r-lg);
    padding:15px;
}
.sm-v {
    font-family:var(--fh);
    font-size:1.8rem;
    letter-spacing:1px;
}
.sm-l {
    font-size:.65rem;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:.08em;
    margin-top:2px;
    font-weight:700;
}
.o-alert {
    background:linear-gradient(135deg,var(--red-dk),var(--red));
    border-radius:var(--r-xl);
    padding:18px;
    max-width:468px;
    margin:0 auto 14px;
    animation:alertGlow 1.2s ease infinite alternate;
}
.oa-top {
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:11px;
}
.oa-title {
    font-family:var(--fh);
    font-size:1.15rem;
    letter-spacing:1px;
}
.oa-timer {
    background:rgba(0,0,0,.3);
    border-radius:var(--r-full);
    padding:4px 11px;
    font-size:.8rem;
    font-weight:700;
    font-family:var(--fh);
    letter-spacing:1px;
}
.oa-detail {
    font-size:.84rem;
    opacity:.9;
    margin-bottom:4px;
}
.oa-items {
    background:rgba(0,0,0,.2);
    border-radius:var(--r);
    padding:9px 13px;
    margin:11px 0;
    font-size:.84rem;
    line-height:1.75;
}
.oa-btns {
    display:flex;
    gap:8px;
    margin-top:11px;
}
.btn-accept {
    flex:1;
    background:rgba(0,0,0,.3);
    border:2px solid #fff;
    color:#fff;
    border-radius:var(--r-full);
    padding:11px;
    font-weight:800;
    font-size:.9rem;
    cursor:pointer;
    font-family:var(--fb);
}
.btn-decline {
    background:transparent;
    border:1.5px solid rgba(255,255,255,.3);
    color:rgba(255,255,255,.7);
    border-radius:var(--r-full);
    padding:11px 17px;
    font-weight:700;
    font-size:.84rem;
    cursor:pointer;
    font-family:var(--fb)
}
.receipt {
    background:var(--dark3);
    border:1px dashed var(--line2);
    border-radius:var(--r);
    padding:13px;
    margin:11px 0;
    font-family:monospace;
    font-size:.8rem;
    line-height:1.85;
}
.receipt-hdr {
    font-family:var(--fh);
    letter-spacing:1px;
    border-bottom:1px dashed var(--line2);
    padding-bottom:7px;
    margin-bottom:7px;
    font-size:.88rem;
}
.receipt-note {
    font-size:.7rem;
    color:var(--muted);
    margin-top:7px;
}

/* pin screen */
.pin-disp {
    display:flex;
    gap:11px;
    justify-content:center;
    margin:30px 0;
}
.pc {
    width:58px;
    height:70px;
    background:var(--dark3);
    border:2px solid var(--line2);
    border-radius:var(--r);
    display:flex;
    align-items:center;
    justify-content:center;
    font-family:var(--fh);
    font-size:2rem;
    letter-spacing:1px;
    transition:all .2s;
}
.pc.f {
    border-color:var(--red);
    background:var(--red-soft);
    color:var(--red);
}
.pc.err {
    border-color:var(--red);
    background:rgba(232,0,29,.3);
    animation:shake .4s;
}
.numpad {
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:8px;
    max-width:258px;
    margin:0 auto;
}
.nk {
   background:var(--dark2);
   border:1px solid var(--line2);
   border-radius:var(--r);
   padding:15px;
   font-family:var(--fh);
   font-size:1.5rem;
   letter-spacing:1px;
   color:#fff;
   text-align:center;
   transition:all .1s;
   cursor:pointer; 
}
.nk:active {
    background:var(--red);
    border-color:var(--red);
    transform:scale(.95);
}
.nk.bk {
    font-size:.95rem;
}
.nk.em {
    pointer-events:none;
    background:transparent;
    border:none;
}

/* Reg steps */
.reg-row {
    display:flex;
    align-items:center;
    margin-bottom:22px;
}
.reg-d {
    width:26px;
    height:26px;
    border-radius:50%;
    background:var(--dark3);
    border:2px solid var(--line2);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:.73rem;
    font-weight:700;
    flex-shrink:0;
}
.reg-d.act {
    background:var(--red);
    border-color:var(--red);
}
.reg-d.dn {
    background:var(--green);
    border-color:var(--green);
}
.reg-l {
    flex:1;height:2px;
    background:var(--line2);
}
.reg-l.dn {
    background:var(--green);
}
.upload-z {
    border:2px dashed var(--line2);
    border-radius:var(--r-lg);
    padding:30px 18px;
    text-align:center;
    cursor:pointer;
    position:relative;
    overflow:hidden;
    transition:all var(--dur);
}
.upload-z:hover {
    border-color:var(--red);
    background:var(--red-soft);
}
.upload-z.dn {
    border-color:var(--green);
    background:var(--green-bg);
}
.upload-z input {
    position:absolute;
    inset:0;
    opacity:0;
    cursor:pointer;
}
.uz-ico {
    font-size:2.4rem;
    margin-bottom:9px;
}
.uz-txt {
    font-size:.84rem;color:var(--muted);
}
.uz-name {
    font-size:.87rem;
    color:var(--green);
    font-weight:600;
}


/* KITCHEN */
.k-stats {
    background:var(--dark2);
    border-bottom:1px solid var(--line);
    padding:11px 16px;
    display:flex;
    gap:22px;
    overflow-x:auto;
    max-width:500px;
    margin:0 auto;
    scrollbar-width:none;
}
.k-stats::-webkit-scrollbar {
    display: none;
}
.ks-v {
    font-family:var(--fh);
    font-size:1.5rem;
    letter-spacing:1px;
}
.ks-l {
    font-size:.6rem;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:.08em;
    font-weight:700;
}
.k-clock {
    font-family:var(--fh);
    font-size:1.35rem;
    letter-spacing:2px;
    flex-shrink:0;
}
.k-board {
    display:grid;
    grid-template-columns:1fr;
    max-width:500px;
    margin:0 auto;
}
@media (min-width:680px){.k-board{
    grid-template-columns:1fr 1fr 1fr;
    gap:1px;
    background:var(--line);
}}
.k-col {
    background:var(--black);
}
.k-col-hdr {
    padding:12px 14px;
    border-bottom:2px solid var(--ca,var(--line));
    display:flex;
    justify-content:space-between;
    align-items:center;
    position:sticky;
    top:54px;
    background:var(--dark);
    z-index:10;
}
.k-col-t {
    font-family:var(--fh);
    font-size:.92rem;
    letter-spacing:1px;
}
.k-col-ct {
    background:var(--dark3);
    border-radius:var(--r-full);
    padding:2px 10px;
    font-size:.7rem;
    font-weight:700;
}
.k-col.cn {
    --ca:var(--orange);
}
.k-col.cc {
    --ca:var(--red);
}
.k-col.cr {
    --ca:var(--green);
}
.k-body {
    padding:11px;
    min-height:160px;
}
.kc {
    background:var(--dark2);
    border:1px solid var(--line);
    border-radius:var(--r-lg);
    margin-bottom:9px;
    overflow:hidden;
    animation:fadeUp .3s var(--ease) both;
}
.kc-top {
    padding:11px 13px;
    border-bottom:1px solid var(--line);
    display:flex;
    justify-content:space-between;
    align-items:center;
}
.kc-num {
    font-family:var(--fh);
    font-size:.92rem;
    letter-spacing:1px;
}
.kc-age {
    background:var(--dark3);
    border-radius:var(--r-full);
    padding:3px 9px;
    font-size:.7rem;
    font-weight:700;
}
.kc-age.urg {
    background:rgba(232,0,29,.2);
    color:var(--red);
    animation:blink .8s infinite;
}
.kc-items {
    padding:9px 13px;
}
.kc-item {
    font-size:.8rem;
    padding:3px 0;
    border-bottom:1px solid var(--line);
}
.kc-item:last-child {
    border-bottom:none;
}
.kc-note {
    font-size:.7rem;
    color:var(--orange);
    margin-top:2px;
}
.kc-area {
    padding:7px 13px;
    font-size:.7rem;
    color:var(--muted);
    border-top:1px solid var(--line);
}
.kc-acts {
    padding:9px 11px;
    display:flex;
    gap:7px;
}
.kb {
   flex:1;
   padding:8px;
   border-radius:var(--r-sm,6px);
   font-size:.76rem;
   font-weight:700;
   text-align:center;
   transition:all .15s;
   border:1px solid transparent;
   cursor:pointer; 
}
.kb-cook {
    background:var(--orange-bg);
    color:var(--orange);
    border-color:rgba(255,109,0,.25);
}
.kb.rdy {
    background:var(--green-bg);
    color:var(--green);
    border-color:rgba(0,200,83,.25);
}
.kb.wait {
    background:var(--blue-bg);  
    color:var(--blue);  
    border-color:rgba(41,121,255,.25);
    font-size:.7rem;
}
.kb:hover {
    filter:brightness(1.2);
}
.kb:active {
    transform:scale(.97);
}


/* ADMIN */
.a-tabs {
    display:flex;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap:6px;
    padding-bottom:2px;
    max-width:500px;
    margin:0 auto 14px;
}

.a-tabs::-webkit-scrollbar {
    display: none;
}
.a-tab {
    flex:1;
    min-width:calc(20% - 4px);
    padding:9px 6px;
    border-radius:var(--r);
    font-size:.67rem;
    font-weight:700;
    letter-spacing:.04em;
    text-transform:uppercase;
    text-align:center;
    background:var(--dark2);
    color:var(--muted);
    border:1px solid var(--line);
    transition:all var(--dur);
    cursor:pointer;
    white-space:nowrap;
    flex-shrink: 0;
}
.a-tab.on {
    background:var(--red);
    color:var(--white);
    border-color:var(--red);
}
.a-metrics {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:9px;
    padding:14px 16px;
    max-width:500px;
    margin:0 auto;
}
.a-mc {
    background:var(--dark2);
    border:1px solid var(--line);
    border-radius:var(--r-lg);
    padding:15px;
}
.a-mc-ico {
    font-size:1.35rem;
    margin-bottom:7px;
}
.a-mc-v {
    font-family:var(--fh);
    font-size:2rem;
    letter-spacing:1px;
}
.a-mc-l {
    font-size:.64rem;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:.08em;
    font-weight:700;
    margin-top:2px;
}
.a-sec {
    max-width:500px;
    margin:0 auto;
    padding:0 16px 16px;
}
.a-sec-t {
    font-family:var(--fh);
    font-size:.95rem;
    letter-spacing:1px;
    margin:18px 0 11px;
    display:flex;
    justify-content:space-between;
    align-items:center;
}
.o-row {
    background:var(--dark2);
    border:1px solid var(--line);
    border-radius:var(--r);
    padding:11px 13px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:6px;
}
.or-l {
    flex:1;
    min-width:0;
}
.or-num {
    font-family:var(--fh);
    font-size:.88rem;
    letter-spacing:1px;
}
.or-m {
    font-size:.7rem;
    color:var(--muted);
    margin-top:2px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.or-r {
    text-align:right;
    flex-shrink:0;
}
.or-p {
    font-family:var(--fh);
    font-size:.88rem;
    color:var(--red);
    letter-spacing:1px;
}
.rider-rev {
    background:var(--dark2);
    border:1px solid var(--line);
    border-radius:var(--r-xl);
    padding:18px;
    margin-bottom:11px;
}
.rr-top {
    display:flex;
    align-items:center;
    gap:11px;
    margin-bottom:14px;
}
.rr-av {
    width:46px;
    height:46px;
    background:var(--dark3);
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:1.25rem;
    flex-shrink:0;
}
.rr-name {
    font-weight:700;
    font-size:.93rem;
}
.rr-phone {
    font-size:.76rem;
    color:var(--muted);
    margin-top:2px;
}
.doc-row {
   display:flex;
   gap:7px;
   margin-bottom:11px ;
}
.dc {
    flex:1;
    background:var(--dark3);
    border:1px solid var(--line2);
    border-radius:var(--r);
    padding:9px 7px;
    text-align:center;
    cursor:pointer;
    transition:all var(--dur);
    font-size:.7rem;
    color:var(--muted);
}
.dc:hover {
    border-color:var(--red);
    color:var(--white);
}
.dc-e {
    font-size:1.35rem;
    display:block;
    margin-bottom:4px;
}
.rr-btns {
    display:flex;
    gap:7px;
}
.menu-toggle-item {
    background:var(--dark2);
    border:1px solid var(--line);
    border-radius:var(--r);
    padding:12px 14px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:6px;
}
.mt-info {
    flex:1;
}

.mt-name {
    font-weight:600;
    font-size:.88rem;
}
.mt-cat {
    font-size:.73rem;
    color:var(--muted);
    margin-top:2px;
}
.mt-price {
    font-family:var(--fh);
    font-size:.9rem;
    color:var(--red);
    margin-right:12px;
}
.toggle-sm {
    width:40px;
    height:22px;
    border-radius:var(--r-full);
    background:var(--dark3);
    cursor:pointer;
    position:relative;
    transition:background .3s;
    border:1px solid var(--line2);
    flex-shrink:0;
}
.toggle-sm.on {
    background:var(--green);
    border-color:var(--green);
}
.toggle-sm::after {
    content:'';
    position:absolute;
    width:16px;
    height:16px;
    background:#fff;
    border-radius:50%;
    top:2px;
    left:2px;
    transition:transform .3s var(--ease);
    box-shadow:0 1px 4px rgba(0,0,0,.4);
}
.toggle-sm.on::after {
    transform:translateX(18px);
}

/* EMPTY */
.empty {
    text-align:center;
    padding:60px 20px;
    color:var(--muted);
}
.ei {
    font-size:2.6rem;
    margin-bottom:11px;
    opacity:.5;
}
.empty h3 {
    font-family:var(--fh);
    font-size:1.05rem;
    color:var(--muted2);
    margin-bottom:5px;
    letter-spacing:1px;
}
.empty p {
    font-size:.83rem;
}
@media(max-width:360px){
    .role-grid{grid-template-columns:1fr};
}

/* CLASSES TO REPLACE INLINE STYLES */

/* App shell — wraps each role's full screen */
.app-shell {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* Scrollable content area inside each role */
.app-scroll {
  flex: 1;
  overflow-y: auto;
}


/* Auth buttons spacing */
.auth-submit-btn { margin-top: 14px; }
.auth-cancel-btn { margin-top: 8px; }

/* Button margin helpers */
.btn-mt-sm  { margin-top: 9px; }
.btn-mt-lg  { margin-top: 16px; }

/* Cart sheet top row */
.sh-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
}

/* History page wrapper */
.hist-wrap {
  max-width: 500px;
  margin: 0 auto;
  padding: 18px 16px 100px;
}

/* History section heading */
.section-title {
  letter-spacing: 2px;
  margin-bottom: 14px;
}

/* Location error box */
.loc-err {
  background: rgba(232,0,29,.08);
  border: 1px solid rgba(232,0,29,.3);
  border-radius: var(--r);
  padding: 13px;
  margin-bottom: 13px;
  font-size: .87rem;
  color: var(--red);
}

/* Payment hint text */
.pay-note {
  font-size: .74rem;
  color: var(--muted);
  margin-top: 11px;
  text-align: center;
}

/* Card with bottom margin (rating screen) */
.card-mb { margin-bottom: 12px; }

/* Kitchen stat colours */
.ks-red    { color: var(--red); }
.ks-orange { color: var(--orange); }
.ks-green  { color: var(--green); }

/* Admin purple badge */
.b-purple {
  background: var(--purple-bg);
  color: var(--purple);
  border: 1px solid rgba(171,71,188,.25);
}

/* Admin panels that start with top padding */
.a-sec-top { padding-top: 14px; }

/* Admin section title with no top margin */
.a-sec-t-flush { margin-top: 0; }

/*  Admin Login Screen */
.auth-wrap  {
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:100vh;
    padding:24px;
}
.auth-card  {
    background:var(--card);
    border:1px solid var(--border);
    border-radius:18px;
    padding:36px 28px;
    width:100%;
    max-width:420px;
    text-align:center;
}
.full-w {   
    width:100%;
    margin-top:14px;
}
.auth-err   {
    background:rgba(220,38,38,.15);
    border:1px solid rgba(220,38,38,.4);
    color:#f87171;
    border-radius:8px;
    padding:10px 14px;
    font-size:.83rem;
    text-align:left;
    margin-bottom:10px;
}

/* ── Location Map Picker ───────────────────────────────────────────── */
#loc-map .leaflet-container {
    background: var(--dark3);
    font-family: var(--fb);
}
/* Make Leaflet controls match dark theme */
#loc-map .leaflet-control-zoom a {
    background: var(--dark2);
    color: var(--white);
    border-color: var(--line2);
}
#loc-map .leaflet-control-zoom a:hover {
    background: var(--dark3);
}
/* Search results dropdown */
#loc-search-results::-webkit-scrollbar { width: 4px; }
#loc-search-results::-webkit-scrollbar-thumb { background: var(--line2); border-radius: 4px; }

/* Error box in loc panel */
#loc-err-box {
    background: rgba(220,38,38,.15);
    border: 1px solid rgba(220,38,38,.4);
    color: #f87171;
    border-radius: 8px;
    padding: 10px 14px;
    font-size: .82rem;
}