/* ============================================================
   CUL FOOD — Design System v2 — Dark Theme
   culconsults.com | CyberSmart quality
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=DM+Serif+Display:ital@0;1&display=swap');

:root {
  --bg:      #080E1A;
  --bg2:     #0D1525;
  --bg3:     #111B2E;
  --surface: #0D1525;
  --orange:      #E67E22;
  --orange-dark: #CA6F1E;
  --orange-lt:   #F39C12;
  --orange-bg:   rgba(230,126,34,.10);
  --orange-bdr:  rgba(230,126,34,.22);
  --orange-glow: rgba(230,126,34,.25);
  --green:     #4ADE80;
  --green-bg:  rgba(22,163,74,.10);
  --green-bdr: rgba(22,163,74,.20);
  --red:       #F87171;
  --red-bg:    rgba(220,38,38,.10);
  --red-bdr:   rgba(220,38,38,.20);
  --blue:      #60A5FA;
  --blue-bg:   rgba(37,99,235,.10);
  --blue-bdr:  rgba(37,99,235,.20);
  --yellow:    #FCD34D;
  --yellow-bg: rgba(252,211,77,.10);
  --yellow-bdr:rgba(252,211,77,.20);
  --purple:    #A78BFA;
  --purple-bg: rgba(124,58,237,.10);
  --purple-bdr:rgba(124,58,237,.20);
  --text:    #E2E8F0;
  --muted:   #64748B;
  --border:  rgba(255,255,255,.07);
  --border2: rgba(255,255,255,.12);
  --font:      'Plus Jakarta Sans', sans-serif;
  --font-serif:'DM Serif Display', serif;
  --sidebar-w: 240px;
  --topbar-h:  56px;
  --r:  10px;
  --r2: 14px;
  --r3: 18px;
  --shadow:    0 4px 16px rgba(0,0,0,.4);
  --shadow-md: 0 8px 32px rgba(0,0,0,.5);
  --shadow-o:  0 6px 20px rgba(230,126,34,.3);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit}
ul,ol{list-style:none}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4,h5,h6{color:#fff;font-weight:700;line-height:1.3}
p{color:var(--text);font-size:.9rem}
small{font-size:.78rem;color:var(--muted)}

/* ADMIN SHELL */
.admin-shell{display:flex;min-height:100vh}

/* SIDEBAR */
.sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);position:fixed;top:0;left:0;height:100vh;overflow-y:auto;overflow-x:hidden;z-index:200;display:flex;flex-direction:column;transition:transform .3s;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}
.sidebar::-webkit-scrollbar{width:3px}
.sidebar::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
.sidebar-logo{padding:16px 18px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);flex-shrink:0}
.sidebar-logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--orange),var(--orange-lt));border-radius:9px;display:grid;place-items:center;font-size:1.1rem;box-shadow:0 4px 14px var(--orange-glow);flex-shrink:0}
.sidebar-logo-text strong{display:block;font-size:1rem;font-weight:800;color:#fff}
.sidebar-logo-text span{font-size:.6rem;color:rgba(255,255,255,.25);text-transform:uppercase;letter-spacing:.5px}
.sidebar-nav{padding:8px 0;flex:1}
.nav-section{padding:14px 18px 4px}
.nav-section-label{font-size:.6rem;font-weight:800;color:rgba(255,255,255,.22);text-transform:uppercase;letter-spacing:1.2px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 18px;color:rgba(255,255,255,.8);font-size:.82rem;font-weight:500;transition:all .15s;border-left:3px solid transparent}
.nav-item:hover{background:rgba(255,255,255,.05);color:rgba(255,255,255,.9)}
.nav-item.active{background:var(--orange-bg);color:#fff;border-left-color:var(--orange)}
.nav-icon{font-size:.9rem;width:18px;text-align:center;flex-shrink:0;opacity:.7}
.nav-item.active .nav-icon{opacity:1}
.nav-badge{margin-left:auto;background:var(--orange-bg);color:var(--orange);border:1px solid var(--orange-bdr);font-size:.6rem;font-weight:700;padding:2px 7px;border-radius:999px}
.sidebar-footer{padding:14px 18px;border-top:1px solid var(--border);flex-shrink:0}
.sidebar-user{display:flex;align-items:center;gap:9px;padding:9px 12px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r)}
.sidebar-user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--orange-lt));display:grid;place-items:center;font-family:var(--font-serif);font-size:.72rem;font-weight:900;color:var(--bg);flex-shrink:0}
.sidebar-user-info{flex:1;min-width:0}
.sidebar-user-info strong{display:block;font-size:.78rem;color:rgba(255,255,255,.85);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-info span{font-size:.62rem;color:rgba(255,255,255,.28);text-transform:capitalize}
.sidebar-user-logout{color:rgba(255,255,255,.25);font-size:.85rem;transition:color .2s;flex-shrink:0}
.sidebar-user-logout:hover{color:var(--red)}

/* MAIN */
.main-content{margin-left:var(--sidebar-w);flex:1;min-width:0;display:flex;flex-direction:column}

/* TOPBAR */
.topbar{height:var(--topbar-h);background:rgba(8,14,26,.95);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 22px;gap:12px;position:sticky;top:0;z-index:100}
.topbar-toggle{display:none;background:none;border:none;font-size:1.1rem;color:var(--muted);padding:5px;border-radius:7px;transition:.15s}
.topbar-toggle:hover{background:rgba(255,255,255,.06);color:#fff}
.topbar-title{font-size:.85rem;font-weight:600;color:rgba(255,255,255,.75);flex:1}
.topbar-title strong{color:#fff}
.topbar-actions{display:flex;align-items:center;gap:8px}
.topbar-btn{background:none;border:1px solid var(--border2);border-radius:8px;padding:6px 11px;font-size:.76rem;color:var(--muted);display:inline-flex;align-items:center;gap:5px;transition:.15s;text-decoration:none;white-space:nowrap;cursor:pointer}
.topbar-btn:hover{border-color:var(--orange-bdr);color:var(--orange)}
.topbar-notif-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;background:var(--red);border-radius:50%;border:2px solid var(--bg)}

/* PAGE */
.page-content{padding:22px;flex:1;animation:fadeInUp .25s ease}
@keyframes fadeInUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.page-header-left{flex:1;min-width:0}
.page-title{font-family:var(--font-serif);font-size:1.5rem;font-weight:900;color:#fff;line-height:1.2;letter-spacing:-.02em}
.page-subtitle{font-size:.8rem;color:var(--muted);margin-top:3px}
.page-header-actions{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}

/* CARDS */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.card-header{padding:13px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-title{font-size:.88rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:7px}
.card-title i{color:var(--orange)}
.card-body{padding:16px}
.card-footer{padding:12px 18px;border-top:1px solid var(--border)}

/* STAT CARDS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:16px;transition:border-color .2s,transform .2s}
.stat-card:hover{border-color:var(--orange-bdr);transform:translateY(-1px)}
.stat-card-label{font-size:.68rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.stat-card-value{font-family:var(--font-serif);font-size:1.65rem;font-weight:900;color:#fff;line-height:1;letter-spacing:-.02em}
.stat-card-change{font-size:.7rem;margin-top:5px;display:flex;align-items:center;gap:4px}
.stat-card-change.up{color:var(--green)}
.stat-card-change.down{color:var(--red)}
.stat-card-icon{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-size:1rem;flex-shrink:0;margin-bottom:10px;border:1px solid}
.stat-card-icon.orange{background:var(--orange-bg);border-color:var(--orange-bdr);color:var(--orange)}
.stat-card-icon.green{background:var(--green-bg);border-color:var(--green-bdr);color:var(--green)}
.stat-card-icon.blue{background:var(--blue-bg);border-color:var(--blue-bdr);color:var(--blue)}
.stat-card-icon.purple{background:var(--purple-bg);border-color:var(--purple-bdr);color:var(--purple)}
.stat-card-icon.red{background:var(--red-bg);border-color:var(--red-bdr);color:var(--red)}
.stat-card-icon.yellow{background:var(--yellow-bg);border-color:var(--yellow-bdr);color:var(--yellow)}

/* DASHBOARD BANNER */
.dashboard-banner{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:20px 22px;margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;position:relative;overflow:hidden}
.dashboard-banner::before{content:'';position:absolute;right:-40px;top:-40px;width:150px;height:150px;background:var(--orange);border-radius:50%;opacity:.04}
.dashboard-banner h2{font-size:1.15rem;font-weight:800;color:#fff;margin-bottom:3px}
.dashboard-banner p{font-size:.8rem;color:var(--muted);margin:0}
.dashboard-banner-emoji{font-size:2.2rem;position:relative;z-index:1;opacity:.6}

/* QUICK ACTIONS */
.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:18px}
.quick-action{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:14px;text-align:center;transition:all .15s;text-decoration:none;display:block}
.quick-action:hover{border-color:var(--orange-bdr);background:var(--orange-bg)}
.quick-action-icon{font-size:1.4rem;margin-bottom:6px;display:block}
.quick-action-label{font-size:.73rem;font-weight:700;color:rgba(255,255,255,.7)}
.quick-action:hover .quick-action-label{color:#fff}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:.8rem;font-weight:700;border:none;cursor:pointer;transition:all .15s;white-space:nowrap;text-decoration:none;line-height:1.4;font-family:var(--font)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-sm{padding:5px 12px;font-size:.75rem}
.btn-lg{padding:10px 20px;font-size:.88rem;border-radius:9px}
.btn-xl{padding:13px 28px;font-size:.95rem;border-radius:10px;font-weight:800}
.btn-icon{width:32px;height:32px;padding:0}
.btn-icon-sm{width:27px;height:27px;padding:0;font-size:.75rem}
.btn-primary{background:linear-gradient(135deg,var(--orange),var(--orange-lt));color:var(--bg)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-o)}
.btn-success{background:var(--green-bg);color:var(--green);border:1px solid var(--green-bdr)}
.btn-success:hover{background:rgba(22,163,74,.18)}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid var(--red-bdr)}
.btn-danger:hover{background:rgba(220,38,38,.18)}
.btn-info{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-bdr)}
.btn-info:hover{background:rgba(37,99,235,.18)}
.btn-secondary{background:rgba(255,255,255,.06);color:var(--text);border:1px solid var(--border2)}
.btn-secondary:hover{background:rgba(255,255,255,.1);color:#fff}
.btn-outline{background:transparent;color:var(--orange);border:1px solid var(--orange-bdr)}
.btn-outline:hover{background:var(--orange-bg)}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}
.btn-ghost:hover{background:rgba(255,255,255,.04);color:var(--text)}

/* FORMS */
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:.68rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px}
.form-label .req{color:var(--red);margin-left:2px}
.form-control{width:100%;padding:9px 13px;border:1px solid var(--border2);border-radius:9px;font-size:.86rem;font-family:var(--font);color:#fff;background:rgba(255,255,255,.04);transition:border-color .18s;outline:none;-webkit-appearance:none}
.form-control:focus{border-color:var(--orange)}
.form-control::placeholder{color:rgba(255,255,255,.18)}
.form-control:disabled{opacity:.5;cursor:not-allowed}
.form-control.is-invalid{border-color:var(--red)}
textarea.form-control{resize:vertical;min-height:90px}
select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748B' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
select.form-control option{background:var(--bg3);color:#fff}
.form-hint{font-size:.7rem;color:var(--muted);margin-top:4px}
.form-error{font-size:.7rem;color:var(--red);margin-top:4px;font-weight:600}
.form-row{display:grid;gap:12px}
.form-row-2{grid-template-columns:1fr 1fr}
.form-row-3{grid-template-columns:1fr 1fr 1fr}
.input-group{position:relative}
.input-group .input-prefix,.input-group .input-suffix{position:absolute;top:50%;transform:translateY(-50%);color:var(--muted);font-size:.85rem;pointer-events:none}
.input-group .input-prefix{left:12px}
.input-group .input-suffix{right:12px}
.input-group .form-control{padding-left:36px}
.input-group.has-suffix .form-control{padding-right:36px}

/* TOGGLE */
.toggle-wrap{display:flex;align-items:center;gap:10px}
.toggle{position:relative;display:inline-block;width:40px;height:22px}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.1);border-radius:999px;transition:.25s;border:1px solid var(--border2)}
.toggle-slider::before{content:"";position:absolute;width:16px;height:16px;left:2px;bottom:2px;background:var(--muted);border-radius:50%;transition:.25s}
.toggle input:checked + .toggle-slider{background:var(--orange-bg);border-color:var(--orange-bdr)}
.toggle input:checked + .toggle-slider::before{transform:translateX(18px);background:var(--orange)}
.toggle-label{font-size:.84rem;font-weight:500;color:var(--text)}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:.65rem;font-weight:700;letter-spacing:.03em;white-space:nowrap}
.badge-orange{background:var(--orange-bg);color:var(--orange);border:1px solid var(--orange-bdr)}
.badge-green{background:var(--green-bg);color:var(--green);border:1px solid var(--green-bdr)}
.badge-red{background:var(--red-bg);color:var(--red);border:1px solid var(--red-bdr)}
.badge-blue{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-bdr)}
.badge-yellow{background:var(--yellow-bg);color:var(--yellow);border:1px solid var(--yellow-bdr)}
.badge-purple{background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-bdr)}
.badge-grey{background:rgba(148,163,184,.08);color:var(--muted);border:1px solid rgba(148,163,184,.15)}

/* TABLES */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse}
thead th{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:9px 13px;text-align:left;background:rgba(255,255,255,.02);border-bottom:1px solid var(--border);white-space:nowrap}
tbody tr{transition:background .12s}
tbody tr:hover td{background:rgba(255,255,255,.02)}
tbody td{padding:10px 13px;font-size:.83rem;color:var(--text);border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
.td-actions{display:flex;gap:6px;align-items:center}

/* ALERTS */
.alert{padding:11px 15px;border-radius:9px;font-size:.83rem;font-weight:500;display:flex;align-items:flex-start;gap:9px;margin-bottom:16px;border:1px solid transparent;animation:slideDown .25s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}
.alert-success{background:var(--green-bg);color:var(--green);border-color:var(--green-bdr)}
.alert-danger{background:var(--red-bg);color:var(--red);border-color:var(--red-bdr)}
.alert-info{background:var(--orange-bg);color:var(--orange);border-color:var(--orange-bdr)}
.alert-warning{background:var(--yellow-bg);color:var(--yellow);border-color:var(--yellow-bdr)}

/* TOAST */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{background:var(--bg3);color:var(--text);padding:11px 16px;border-radius:9px;font-size:.83rem;font-weight:500;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:9px;min-width:260px;max-width:340px;pointer-events:auto;animation:slideInRight .25s ease;border:1px solid var(--border);border-left:3px solid var(--orange)}
.toast.toast-success{border-left-color:var(--green)}
.toast.toast-error{border-left-color:var(--red)}
.toast.toast-info{border-left-color:var(--blue)}
@keyframes slideInRight{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1000;display:none;place-items:center;padding:20px;backdrop-filter:blur(6px)}
.modal-overlay.open{display:grid;animation:fadeIn .2s ease}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r2);box-shadow:var(--shadow-md);width:100%;max-width:540px;max-height:90vh;overflow-y:auto;animation:slideUp .25s cubic-bezier(.4,0,.2,1)}
.modal-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:1rem;font-weight:700;color:#fff}
.modal-close{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.06);border:none;display:grid;place-items:center;font-size:.8rem;color:var(--muted);cursor:pointer;transition:all .15s}
.modal-close:hover{background:var(--red-bg);color:var(--red)}
.modal-body{padding:20px}
.modal-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}

/* IMG UPLOAD */
.img-upload-wrap{border:1.5px dashed var(--border2);border-radius:var(--r);padding:32px 20px;text-align:center;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.img-upload-wrap:hover,.img-upload-wrap.drag{border-color:var(--orange);background:var(--orange-bg)}
.img-upload-preview{width:100%;height:160px;object-fit:cover;border-radius:8px;display:none}
.img-upload-preview.show{display:block}
.img-upload-icon{font-size:1.8rem;color:var(--muted);margin-bottom:8px}
.img-upload-text{font-size:.82rem;color:var(--muted)}
.img-upload-text strong{color:var(--orange)}

/* EMPTY STATE */
.empty-state{text-align:center;padding:48px 20px;color:var(--muted)}
.empty-state-icon{font-size:2.5rem;margin-bottom:12px;opacity:.4}
.empty-state-title{font-size:1rem;font-weight:700;color:rgba(255,255,255,.8);margin-bottom:6px}
.empty-state-text{font-size:.84rem;max-width:280px;margin:0 auto 20px;line-height:1.6}

/* PAGINATION */
.pagination{display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.page-link{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;font-size:.8rem;font-weight:600;color:var(--muted);border:1px solid var(--border);background:transparent;transition:all .15s;cursor:pointer;text-decoration:none}
.page-link:hover{border-color:var(--orange-bdr);color:var(--orange);background:var(--orange-bg)}
.page-link.active{background:var(--orange-bg);color:var(--orange);border-color:var(--orange-bdr)}
.page-link.disabled{opacity:.3;pointer-events:none}

/* SEARCH */
.search-wrap{position:relative}
.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:.85rem;pointer-events:none}
.search-wrap .form-control{padding-left:36px}

/* COLOR PICKER */
.color-options{display:flex;gap:8px;flex-wrap:wrap}
.color-option{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .15s,border-color .15s}
.color-option:hover{transform:scale(1.15)}
.color-option.selected{border-color:#fff;transform:scale(1.1)}

/* HOURS */
.hours-grid{display:flex;flex-direction:column;gap:8px}
.hours-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.hours-day{width:100px;font-size:.84rem;font-weight:600;color:var(--text);flex-shrink:0}
.hours-times{display:flex;align-items:center;gap:8px;flex:1}
.hours-times .form-control{max-width:110px}
.hours-sep{color:var(--muted);font-size:.78rem}

/* ADDONS */
.addon-group-card{border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:10px}
.addon-group-header{background:rgba(255,255,255,.03);padding:11px 14px;display:flex;align-items:center;gap:8px;cursor:pointer}
.addon-group-title{font-size:.88rem;font-weight:700;flex:1;color:#fff}
.addon-group-meta{font-size:.72rem;color:var(--muted)}
.addon-options-list{padding:8px 14px}
.addon-option-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border)}
.addon-option-row:last-child{border-bottom:none}
.addon-option-name{flex:1;font-size:.84rem;color:var(--text)}
.addon-option-price{font-size:.84rem;font-weight:600;color:var(--green);min-width:70px;text-align:right}

/* FOOD CARDS */
.food-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.food-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:border-color .2s,transform .2s}
.food-card:hover{border-color:var(--orange-bdr);transform:translateY(-2px)}
.food-card-img{width:100%;height:150px;object-fit:cover;background:var(--bg3)}
.food-card-img-placeholder{width:100%;height:150px;background:rgba(230,126,34,.06);display:grid;place-items:center;font-size:2.2rem}
.food-card-body{padding:12px}
.food-card-name{font-size:.9rem;font-weight:700;color:#fff;margin-bottom:3px}
.food-card-location{font-size:.73rem;color:var(--muted);margin-bottom:7px}
.food-card-price{font-size:1rem;font-weight:800;color:var(--orange);font-family:var(--font-serif)}
.food-card-footer{padding:10px 12px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.02)}

/* LOCATION CARDS */
.location-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:border-color .2s}
.location-card:hover{border-color:var(--orange-bdr)}
.location-card-banner{height:70px;background:var(--bg3);display:flex;align-items:center;padding:14px}
.location-card-code{font-size:.62rem;font-weight:800;color:var(--orange);text-transform:uppercase;letter-spacing:1.5px;background:var(--orange-bg);padding:3px 8px;border-radius:999px;border:1px solid var(--orange-bdr)}
.location-card-body{padding:12px}
.location-card-name{font-size:.92rem;font-weight:700;color:#fff;margin-bottom:3px}
.location-card-desc{font-size:.75rem;color:var(--muted);margin-bottom:8px;line-height:1.5}
.location-card-footer{padding:9px 12px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}

/* SIDEBAR OVERLAY */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:199;backdrop-filter:blur(3px)}

/* FLASH */
.flash{padding:11px 15px;border-radius:9px;margin-bottom:16px;font-size:.82rem;font-weight:500;display:flex;align-items:center;gap:8px;animation:slideDown .25s ease;border:1px solid transparent}
.flash-success{background:var(--green-bg);color:var(--green);border-color:var(--green-bdr)}
.flash-error{background:var(--red-bg);color:var(--red);border-color:var(--red-bdr)}
.flash-info{background:var(--orange-bg);color:var(--orange);border-color:var(--orange-bdr)}

/* PROGRESS */
.progress{height:4px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden}
.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--orange),var(--orange-lt))}

/* TABS */
.tabs{display:flex;gap:2px;background:rgba(255,255,255,.04);border-radius:9px;padding:3px;margin-bottom:16px;flex-wrap:wrap;border:1px solid var(--border)}
.tab-btn{flex:1;padding:7px 14px;border:none;background:none;border-radius:7px;font-size:.8rem;font-weight:600;color:var(--muted);cursor:pointer;transition:all .15s;white-space:nowrap}
.tab-btn.active{background:rgba(255,255,255,.08);color:#fff}

/* DIVIDER */
.divider{border:none;border-top:1px solid var(--border);margin:16px 0}

/* UTILITIES */
.d-flex{display:flex}.d-grid{display:grid}.d-none{display:none}
.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-sm{gap:8px}.gap{gap:16px}.gap-lg{gap:24px}.flex-1{flex:1}
.text-center{text-align:center}.text-right{text-align:right}
.text-muted{color:var(--muted)}.text-orange{color:var(--orange)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-white{color:#fff}
.font-bold{font-weight:700}.font-800{font-weight:800}.font-serif{font-family:var(--font-serif)}
.mt-sm{margin-top:8px}.mt{margin-top:16px}.mt-lg{margin-top:24px}
.mb-sm{margin-bottom:8px}.mb{margin-bottom:16px}.mb-lg{margin-bottom:24px}
.w-full{width:100%}.rounded{border-radius:var(--r)}.rounded-full{border-radius:999px}
.overflow-hidden{overflow:hidden}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cursor-pointer{cursor:pointer}.opacity-50{opacity:.5}

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

/* SKELETON */
.skeleton{background:linear-gradient(90deg,var(--bg2) 25%,var(--bg3) 50%,var(--bg2) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:6px}
@keyframes shimmer{to{background-position:-200% 0}}

/* PRINT */
@media print{.sidebar,.topbar,.page-header-actions,.btn{display:none!important}.main-content{margin:0}body{background:#fff;color:#000}}

/* RESPONSIVE */
@media(max-width:1024px){:root{--sidebar-w:220px}.form-row-3{grid-template-columns:1fr 1fr}}
@media(max-width:768px){
  :root{--sidebar-w:240px}
  .sidebar{transform:translateX(-100%);box-shadow:var(--shadow-md)}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay.open{display:block}
  .main-content{margin-left:0}
  .topbar-toggle{display:flex}
  .page-content{padding:14px}
  .form-row-2,.form-row-3{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .food-grid{grid-template-columns:1fr}
  .modal{max-width:100%;border-radius:var(--r3) var(--r3) 0 0;position:fixed;bottom:0;left:0;right:0;max-height:95vh;animation:slideUpMobile .25s ease}
  .modal-overlay{align-items:flex-end;padding:0}
  @keyframes slideUpMobile{from{transform:translateY(100%)}to{transform:translateY(0)}}
  .page-header{flex-direction:column}
  .page-header-actions{width:100%}
  .quick-actions{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.quick-actions{grid-template-columns:1fr 1fr}}

/* ── Compat aliases for student layout ───────────────────── */
:root {
  --body:         var(--text);
  --orange-light: var(--orange-lt);
  --gap:          16px;
  --gap-sm:       8px;
  --gap-lg:       24px;
  --gap-md:       20px;
  --gap-xl:       32px;
  --gap-2xl:      48px;
  --r-sm:         8px;
  --r-md:         14px;
  --r-lg:         18px;
  --r-xl:         24px;
  --r-full:       999px;
  --shadow-sm:    0 1px 3px rgba(0,0,0,.3);
  --dark:         var(--bg2);
  --dark2:        var(--bg3);
}

/* Student content area — slightly lighter than pure dark */
.student-shell .main-content,
.desktop-topbar {
  background: #0A1020;
}
.desktop-topbar {
  border-bottom: 1px solid var(--border);
}
.dtb-title { color: var(--text) !important; }
.dtb-btn {
  background: var(--bg2) !important;
  border-color: var(--border) !important;
  color: var(--muted) !important;
}
.dtb-btn:hover {
  border-color: var(--orange-bdr) !important;
  color: var(--orange) !important;
  background: var(--orange-bg) !important;
}

/* Student page body */
body.student-page { background: #0A1020; }

/* ── Extra compat for student.css ────────────────────────── */
:root {
  --orange-xlight:  rgba(230,126,34,.06);
  --red-light:      var(--red-bg);
  --surface:        var(--bg2);
  --orange-dark:    var(--orange-dark, #CA6F1E);
  --green-light:    var(--green-bg);
  --blue-light:     var(--blue-bg);
  --purple-light:   var(--purple-bg);
  --yellow-light:   var(--yellow-bg);
  --bg2-alt:        #111B2E;
}
