/* =====================================================
   QUICKORDER — Shopee Food Style
   ===================================================== */

/* ── CSS Variables ─────────────────────────────────── */
:root {
    --sf-primary:      #EE4D2D;
    --sf-primary-dk:   #D73211;
    --sf-primary-lt:   #FF6B4A;
    --sf-primary-bg:   #FFF4F2;
    --sf-orange-soft:  #FFF0EC;
    --sf-bg:           #F5F5F5;
    --sf-surface:      #FFFFFF;
    --sf-text:         #212121;
    --sf-text-2:       #555555;
    --sf-muted:        #9E9E9E;
    --sf-border:       #EEEEEE;
    --sf-green:        #26AA99;
    --sf-gold:         #F5A623;
    --sf-shadow:       0 2px 8px rgba(0,0,0,0.08);
    --sf-shadow-md:    0 4px 16px rgba(0,0,0,0.10);
    --sf-shadow-hover: 0 8px 24px rgba(0,0,0,0.14);
    --sf-radius:       10px;
    --sf-radius-lg:    14px;

    /* Override Bootstrap primary */
    --bs-primary:      #EE4D2D;
    --bs-primary-rgb:  238, 77, 45;

    /* Alias for legacy selectors */
    --primary-color:      #EE4D2D;
    --accent-color:       #F5A623;
    --background-color:   #F5F5F5;
    --surface-color:      #FFFFFF;
    --text-main:          #212121;
    --text-muted-color:   #9E9E9E;
    --border-color:       #EEEEEE;
}

/* ── Reset & Base ───────────────────────────────────── */
* { box-sizing: border-box; }

body {
    margin: 0;
    min-height: 100vh;
    font-family: "Inter", "Segoe UI", system-ui, -apple-system, Arial, sans-serif;
    background-color: var(--sf-bg);
    color: var(--sf-text);
    font-size: 14px;
}

/* ── Navbar ─────────────────────────────────────────── */
.navbar-glass {
    background: #FFFFFF !important;
    backdrop-filter: none;
    border-bottom: 1px solid var(--sf-border);
    box-shadow: 0 1px 6px rgba(0,0,0,0.06);
}

.navbar-brand {
    color: var(--sf-primary) !important;
    font-weight: 800 !important;
    font-size: 1.25rem !important;
}

.navbar-brand .brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 8px;
    background: var(--sf-primary-bg);
    font-size: 1rem;
}

.navbar-nav .nav-link {
    color: var(--sf-text-2) !important;
    font-weight: 500;
    font-size: 0.88rem;
    transition: color 0.18s;
}

.navbar-nav .nav-link:hover {
    color: var(--sf-primary) !important;
}

.navbar-nav .nav-link.active {
    color: var(--sf-primary) !important;
    font-weight: 600;
}

.nav-location {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.82rem;
    color: var(--sf-text-2);
    background: var(--sf-bg);
    border: 1px solid var(--sf-border);
    border-radius: 20px;
    padding: 0.28rem 0.75rem;
    white-space: nowrap;
}

.btn-admin-nav {
    background: var(--sf-primary) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 20px !important;
    padding: 0.35rem 1.1rem !important;
    font-size: 0.84rem !important;
    font-weight: 600 !important;
    transition: background 0.2s !important;
    text-decoration: none;
}
.btn-admin-nav:hover {
    background: var(--sf-primary-dk) !important;
}

/* ── Hero Banner ────────────────────────────────────── */
.hero-section {
    background: linear-gradient(rgba(0,0,0,0.45), rgba(0,0,0,0.45)),
                url('https://atm273446-s3user.vcos.cloudstorage.com.vn/dhdainam/asset/asset/fixed/jcp8yed1xqhwpu9j6hf520240528065111_thump.jpg') center/cover no-repeat;
    color: #ffffff;
    padding: 3rem 0 3.5rem;
}

.hero-section .display-4,
.hero-section .eyebrow,
.hero-section .lead,
.hero-section h1 {
    color: #ffffff !important;
}

.eyebrow {
    letter-spacing: 0.14em;
    font-size: 0.75rem;
    opacity: 0.85;
}

.hero-section .hero-card {
    background: rgba(255,255,255,0.97);
    border: none;
    border-radius: var(--sf-radius-lg);
    box-shadow: 0 8px 32px rgba(0,0,0,0.15);
}
.hero-section .hero-card * {
    color: var(--sf-text) !important;
}

.hero-section .feature-badge {
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 8px;
    font-size: 0.85rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* Hero promo tags */
.hero-promo-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: rgba(255,255,255,0.2);
    border: 1px solid rgba(255,255,255,0.35);
    color: #fff;
    border-radius: 20px;
    padding: 0.4rem 1rem;
    font-size: 0.82rem;
    font-weight: 600;
    backdrop-filter: blur(6px);
}

/* ── Category Filter Bar ────────────────────────────── */
.sf-categories {
    background: #fff;
    border-bottom: 1px solid var(--sf-border);
    padding: 0.6rem 0;
}

.sf-cat-scroll {
    display: flex;
    gap: 0.5rem;
    overflow-x: auto;
    scrollbar-width: none;
    padding: 0.2rem 0;
    -webkit-overflow-scrolling: touch;
}
.sf-cat-scroll::-webkit-scrollbar { display: none; }

.sf-cat-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    white-space: nowrap;
    background: var(--sf-bg);
    border: 1.5px solid var(--sf-border);
    color: var(--sf-text-2);
    border-radius: 20px;
    padding: 0.32rem 0.9rem;
    font-size: 0.82rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.18s;
    user-select: none;
    line-height: 1;
}
.sf-cat-pill:hover {
    border-color: var(--sf-primary);
    color: var(--sf-primary);
    background: var(--sf-orange-soft);
}
.sf-cat-pill.active {
    background: var(--sf-primary);
    border-color: var(--sf-primary);
    color: #fff;
}

/* ── Section Heading ────────────────────────────────── */
.section-title {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--sf-text);
}

/* ── Restaurant Card (Shopee Food style) ────────────── */
.sf-restaurant-card {
    background: var(--sf-surface);
    border-radius: var(--sf-radius-lg);
    overflow: hidden;
    box-shadow: var(--sf-shadow);
    transition: transform 0.22s ease, box-shadow 0.22s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
    border: 1px solid rgba(0,0,0,0.04);
    cursor: default;
}

.sf-restaurant-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sf-shadow-hover);
}

.sf-card-img-wrap {
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
}

.sf-card-img-wrap img {
    width: 100%;
    height: 175px;
    object-fit: cover;
    display: block;
    transition: transform 0.35s ease;
}

.sf-restaurant-card:hover .sf-card-img-wrap img {
    transform: scale(1.05);
}

.sf-open-badge {
    position: absolute;
    top: 9px;
    left: 9px;
    background: rgba(0,0,0,0.55);
    color: #fff;
    font-size: 0.68rem;
    font-weight: 600;
    border-radius: 5px;
    padding: 0.18rem 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    backdrop-filter: blur(4px);
}

.sf-open-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #4ade80;
    display: inline-block;
    flex-shrink: 0;
}

.sf-closed-dot {
    background: #ef4444;
}

.sf-closed-badge {
    background: rgba(0,0,0,0.65);
}

/* ── Restaurant search bar ──────────────────────────── */
.restaurant-search-wrap {
    position: relative;
    width: 220px;
}
.restaurant-search-wrap .search-icon {
    position: absolute;
    left: 0.6rem;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    font-size: 0.82rem;
    color: var(--sf-muted);
}
.restaurant-search-wrap input {
    padding-left: 1.9rem;
    border-radius: 8px;
    font-size: 0.83rem;
    border: 1.5px solid var(--sf-border);
    background: #fff;
    height: 34px;
}
.restaurant-search-wrap input:focus {
    border-color: var(--sf-primary);
    box-shadow: 0 0 0 3px rgba(238,77,45,0.1);
    outline: none;
}

/* ── Closed restaurant overlay ──────────────────────── */
.sf-card-closed .sf-card-img-wrap img {
    filter: grayscale(60%) brightness(0.85);
}
.sf-card-closed .sf-order-btn {
    background: #9E9E9E !important;
    cursor: not-allowed;
    pointer-events: none;
}

.sf-cat-label {
    position: absolute;
    bottom: 9px;
    right: 9px;
    background: var(--sf-primary);
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    border-radius: 4px;
    padding: 0.18rem 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.sf-card-body {
    padding: 0.85rem 1rem 1rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.sf-card-title {
    font-size: 0.92rem;
    font-weight: 700;
    color: var(--sf-text);
    margin: 0 0 0.35rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sf-card-meta {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.76rem;
    color: var(--sf-muted);
    margin-bottom: 0.4rem;
    flex-wrap: wrap;
}

.sf-rating { color: var(--sf-gold); font-weight: 700; }
.sf-rating-none { color: #BDBDBD; font-weight: 400; font-size: .8rem; }
.sf-meta-dot { color: #DDDDDD; }
.sf-free-ship { color: var(--sf-green); font-weight: 600; }

.sf-card-desc {
    font-size: 0.77rem;
    color: var(--sf-text-2);
    margin: 0 0 0.8rem;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    line-height: 1.45;
    flex: 1;
}

.sf-order-btn {
    display: block;
    width: 100%;
    background: var(--sf-primary);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 0.52rem 1rem;
    font-size: 0.86rem;
    font-weight: 700;
    text-align: center;
    cursor: pointer;
    transition: background 0.2s;
    margin-top: auto;
    letter-spacing: 0.01em;
}
.sf-order-btn:hover { background: var(--sf-primary-dk); }

/* ── Order Modal (Cart style) ───────────────────────── */
.modal-content {
    border-radius: var(--sf-radius-lg) !important;
    border: none !important;
    overflow: hidden;
}

.modal-header {
    background: var(--sf-primary);
    border-radius: 0 !important;
    padding: 1rem 1.25rem;
    border-bottom: none !important;
}

.modal-header .modal-title {
    color: #fff !important;
    font-weight: 700;
    font-size: 1rem;
}

.modal-header p {
    color: rgba(255,255,255,0.82) !important;
    font-size: 0.8rem;
    margin-bottom: 0;
}

.modal-header .btn-close {
    filter: invert(1) brightness(2);
    opacity: 0.85;
}

.modal-body { padding: 1.2rem 1.25rem; }
.modal-footer {
    padding: 0.9rem 1.25rem;
    border-top: 1px solid var(--sf-border) !important;
}

.form-control,
.form-select {
    border-radius: 8px !important;
    border: 1.5px solid var(--sf-border) !important;
    font-size: 0.88rem;
    color: var(--sf-text) !important;
    background-color: #fff !important;
}
.form-control:focus,
.form-select:focus {
    border-color: var(--sf-primary) !important;
    box-shadow: 0 0 0 3px rgba(238,77,45,0.12) !important;
}

.form-floating > label {
    padding: 0.85rem 1rem;
    color: var(--sf-muted);
    font-size: 0.85rem;
}
.form-floating .form-control,
.form-floating .form-select {
    padding: 1.45rem 1rem 0.6rem;
}

/* Menu items container */
#menu-items-container {
    background: var(--sf-bg) !important;
    border-radius: 10px !important;
    border: 1.5px solid var(--sf-border) !important;
    padding: 0.75rem !important;
}

.sf-menu-item {
    background: #fff;
    border-radius: 8px;
    padding: 0.6rem 0.75rem;
    margin-bottom: 0.5rem;
    border: 1px solid var(--sf-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
}
.sf-menu-item:last-child { margin-bottom: 0; }

.sf-item-label {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--sf-text);
}

.sf-item-price {
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--sf-primary);
    background: var(--sf-orange-soft);
    border-radius: 5px;
    padding: 0.15rem 0.45rem;
}

/* Total bar */
.order-total-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--sf-orange-soft);
    border: 1.5px solid rgba(238,77,45,0.18);
    border-radius: 10px;
    padding: 0.7rem 1rem;
}
.order-total-bar .total-label {
    font-weight: 600;
    color: var(--sf-text);
    font-size: 0.9rem;
}
.order-total-bar .total-amount {
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--sf-primary);
}

/* ── Bootstrap button overrides ─────────────────────── */
.btn-primary {
    --bs-btn-bg:              var(--sf-primary);
    --bs-btn-border-color:    var(--sf-primary);
    --bs-btn-hover-bg:        var(--sf-primary-dk);
    --bs-btn-hover-border-color: var(--sf-primary-dk);
    --bs-btn-active-bg:       var(--sf-primary-dk);
    --bs-btn-focus-shadow-rgb: 238, 77, 45;
    border-radius: 8px;
    font-weight: 600;
}

.btn-outline-primary {
    --bs-btn-color:              var(--sf-primary);
    --bs-btn-border-color:       var(--sf-primary);
    --bs-btn-hover-bg:           var(--sf-primary);
    --bs-btn-hover-border-color: var(--sf-primary);
    --bs-btn-hover-color:        #fff;
    --bs-btn-active-bg:          var(--sf-primary-dk);
    border-radius: 8px;
    font-weight: 600;
}

.btn-outline-secondary {
    border-radius: 8px;
}

.btn-lg { border-radius: 10px !important; }

/* ── Admin — order summary cards ────────────────────── */
.order-summary-card {
    background: var(--sf-surface);
    border: 1px solid var(--sf-border);
    border-radius: var(--sf-radius-lg);
    transition: box-shadow 0.2s;
}
.order-summary-card:hover {
    box-shadow: var(--sf-shadow-md);
}

.card {
    border: 1px solid var(--sf-border);
    border-radius: var(--sf-radius-lg) !important;
}

.table-responsive {
    border-radius: var(--sf-radius-lg);
    overflow: hidden;
}
.table-hover tbody tr:hover {
    background-color: var(--sf-orange-soft);
}

/* ── Toast ──────────────────────────────────────────── */
#new-order-toast {
    border-radius: 10px;
    box-shadow: var(--sf-shadow-md);
    min-width: 260px;
    background-color: #fff !important;
    border: 1px solid rgba(38,170,153,0.3) !important;
    color: var(--sf-text) !important;
}

/* ── Footer ─────────────────────────────────────────── */
.footer {
    background: #fff;
    border-top: 1px solid var(--sf-border) !important;
}
.footer p, .footer small { color: var(--sf-muted); font-size: 0.82rem; }

/* ── Input group qty buttons ────────────────────────── */
.input-group-sm .btn-outline-secondary {
    border-color: var(--sf-border) !important;
    color: var(--sf-text-2) !important;
    font-weight: 700;
    line-height: 1;
}
.input-group-sm .btn-outline-secondary:hover {
    background: var(--sf-primary) !important;
    border-color: var(--sf-primary) !important;
    color: #fff !important;
}
.qty-input {
    border-color: var(--sf-border) !important;
    color: var(--sf-text) !important;
    font-weight: 600;
}

/* ── Responsive ─────────────────────────────────────── */
@media (max-width: 767.98px) {
    .hero-section { padding: 2rem 0 2.5rem; }
}

/* ── Modal text visibility ──────────────────────────── */
#orderModal .modal-body,
#orderModal .form-check-label,
#orderModal .form-label,
#orderModal .form-control {
    color: var(--sf-text) !important;
}
