/* style.css – KITM Canteen Leaderboard */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:wght@300;400;500&display=swap');

:root {
    --blue-900: #0a1628;
    --blue-800: #0d1f3c;
    --blue-700: #1a3a6b;
    --blue-600: #1565C0;
    --blue-500: #1976D2;
    --blue-400: #42A5F5;
    --blue-100: #E3F2FD;
    --blue-50:  #F0F7FF;
    --accent:   #00B4FF;
    --white:    #ffffff;
    --text-main:#0a1628;
    --text-sub: #5a7299;
    --gold:     #F5A623;
    --silver:   #9E9E9E;
    --bronze:   #CD7F32;
    --success:  #2E7D32;
    --success-bg:#E8F5E9;
    --error:    #C62828;
    --error-bg: #FFEBEE;
    --radius:   14px;
    --shadow:   0 4px 24px rgba(10,22,40,0.10);
    --shadow-lg:0 8px 40px rgba(10,22,40,0.15);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
    font-family: 'DM Sans', sans-serif;
    background: var(--blue-50);
    color: var(--text-main);
    min-height: 100vh;
    overflow-x: hidden;
}

/* ── BACKGROUND ── */
.bg-grid {
    position: fixed; inset: 0; z-index: -2;
    background-color: #f0f7ff;
    background-image:
        linear-gradient(rgba(21,101,192,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(21,101,192,0.06) 1px, transparent 1px);
    background-size: 40px 40px;
}
.bg-orb { position: fixed; z-index: -1; border-radius: 50%; filter: blur(80px); opacity: 0.3; pointer-events: none; }
.orb-1 { width:600px;height:600px;top:-200px;right:-200px;background:radial-gradient(circle,#1565C0,transparent 70%);animation:floatOrb 12s ease-in-out infinite; }
.orb-2 { width:400px;height:400px;bottom:-100px;left:-100px;background:radial-gradient(circle,#00B4FF,transparent 70%);animation:floatOrb 16s ease-in-out infinite reverse; }
@keyframes floatOrb { 0%,100%{transform:translate(0,0)}50%{transform:translate(30px,30px)} }

.container { max-width:1200px; margin:0 auto; padding:0 24px; }

/* ═══ KITM NAV — SELF-CONTAINED ═══ */
































/* Mobile panel — hidden by default always */

















/* ── RESPONSIVE ── */
@media(max-width:960px){
    
    
    
    
    
    
}
@media(min-width:961px){
    
    
}



/* ── HERO ── */
.hero { padding:60px 0 40px;text-align:center; }
.hero-badge { display:inline-flex;align-items:center;gap:8px;background:rgba(21,101,192,0.08);border:1px solid rgba(21,101,192,0.2);color:var(--blue-600);font-size:13px;font-weight:600;padding:6px 16px;border-radius:100px;margin-bottom:20px;text-transform:uppercase;letter-spacing:1px; }
.pulse-dot { width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:0.6} }
.hero-title { font-family:'Syne',sans-serif;font-size:clamp(40px,6vw,72px);font-weight:800;color:var(--blue-800);letter-spacing:-2px;line-height:1.05;margin-bottom:12px; }
.hero-sub { font-size:17px;color:var(--text-sub);margin-bottom:28px; }
.date-picker-wrap { display:inline-flex;align-items:center;background:white;border:1.5px solid rgba(21,101,192,0.2);border-radius:12px;padding:10px 16px;gap:12px;box-shadow:var(--shadow); }
.date-picker-wrap label { font-size:13px;color:var(--text-sub);font-weight:500; }
.date-picker-wrap input[type="date"] { border:none;outline:none;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--blue-700);cursor:pointer;background:transparent; }
.btn-sm { background:var(--blue-600);color:white;border:none;border-radius:8px;padding:6px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background 0.2s; }
.btn-sm:hover { background:var(--blue-700); }

/* ── STATS BAR ── */
.stats-bar { background:white;border-top:1px solid rgba(21,101,192,0.08);border-bottom:1px solid rgba(21,101,192,0.08);padding:20px 0; }
.stats-grid { display:flex;align-items:center;justify-content:center;flex-wrap:wrap; }
.stat-item { padding:8px 40px;text-align:center; }
.stat-value { font-family:'Syne',sans-serif;font-size:28px;font-weight:800;color:var(--blue-700);letter-spacing:-1px; }
.stat-label { font-size:12px;color:var(--text-sub);font-weight:500;letter-spacing:0.5px;text-transform:uppercase;margin-top:2px; }
.stat-divider { width:1px;height:40px;background:rgba(21,101,192,0.15); }

/* ── MAIN ── */
.main { padding:48px 0 80px; }

/* ── PODIUM ── */
.podium-section { margin-bottom:56px; }
.section-title { font-family:'Syne',sans-serif;font-size:22px;font-weight:700;color:var(--blue-800);margin-bottom:24px;letter-spacing:-0.5px; }
.row-count { font-size:14px;font-weight:400;color:var(--text-sub);margin-left:8px; }
.podium { display:flex;align-items:flex-end;justify-content:center;gap:16px;flex-wrap:wrap; }
.podium-card { background:white;border-radius:20px;padding:28px 24px 0;text-align:center;width:240px;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:transform 0.3s,box-shadow 0.3s;animation:riseUp 0.6s ease backwards; }
.podium-card:hover { transform:translateY(-4px);box-shadow:var(--shadow-lg); }
.podium-card.center { width:260px;z-index:1; }
.podium-card.gold   { border-top:4px solid var(--gold);animation-delay:0.1s; }
.podium-card.silver { border-top:4px solid var(--silver);animation-delay:0.2s; }
.podium-card.bronze { border-top:4px solid var(--bronze);animation-delay:0.3s; }
@keyframes riseUp { from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)} }
.podium-medal { font-size:32px;margin-bottom:12px; }
.podium-avatar { width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--blue-600),var(--blue-400));color:white;font-size:22px;font-weight:800;font-family:'Syne',sans-serif;display:flex;align-items:center;justify-content:center;margin:0 auto 12px; }
.podium-card.gold .podium-avatar   { background:linear-gradient(135deg,#F5A623,#FFD700); }
.podium-card.silver .podium-avatar { background:linear-gradient(135deg,#9E9E9E,#CFD8DC); }
.podium-card.bronze .podium-avatar { background:linear-gradient(135deg,#CD7F32,#E8A95C); }
.podium-name   { font-family:'Syne',sans-serif;font-size:16px;font-weight:700;color:var(--blue-800);margin-bottom:2px; }
.podium-amount { font-family:'Syne',sans-serif;font-size:22px;font-weight:800;color:var(--blue-700);margin-bottom:4px; }
.podium-txn    { font-size:12px;color:var(--text-sub);margin-bottom:16px; }
.podium-block  { background:linear-gradient(135deg,var(--blue-700),var(--blue-500));margin:0 -24px;padding:10px; }
.podium-card.gold .podium-block   { background:linear-gradient(135deg,#D4890A,#F5A623); }
.podium-card.silver .podium-block { background:linear-gradient(135deg,#757575,#9E9E9E); }
.podium-card.bronze .podium-block { background:linear-gradient(135deg,#A0522D,#CD7F32); }
.podium-rank { color:white;font-family:'Syne',sans-serif;font-size:18px;font-weight:800; }

/* ── TABLE ── */
.table-section { margin-bottom:56px; }
.table-header { display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px; }
.online-badge { background:rgba(21,101,192,0.08);border:1px solid rgba(21,101,192,0.2);color:var(--blue-600);font-size:12px;font-weight:600;padding:6px 14px;border-radius:100px;text-transform:uppercase;letter-spacing:0.5px; }
.table-wrap { background:white;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;overflow-x:auto; }
.leaderboard-table { width:100%;border-collapse:collapse;min-width:540px; }
.leaderboard-table thead tr { background:linear-gradient(135deg,var(--blue-800),var(--blue-700)); }
.leaderboard-table th { padding:16px 20px;font-family:'Syne',sans-serif;font-size:12px;font-weight:700;color:rgba(255,255,255,0.8);text-transform:uppercase;letter-spacing:1px;text-align:left; }
.table-row { border-bottom:1px solid rgba(21,101,192,0.06);animation:fadeSlideIn 0.4s ease backwards;animation-delay:var(--delay);transition:background 0.2s; }
.table-row:hover { background:var(--blue-50); }
.table-row:last-child { border-bottom:none; }
.editing-row { background:rgba(21,101,192,0.06)!important;outline:2px solid var(--blue-400); }
@keyframes fadeSlideIn { from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)} }
.leaderboard-table td { padding:14px 20px;font-size:14px;color:var(--text-main); }
.rank-cell { width:60px; }
.rank-badge { display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-family:'Syne',sans-serif;font-size:14px;font-weight:800;color:white; }
.rank-1 { background:linear-gradient(135deg,#D4890A,#F5A623);box-shadow:0 2px 8px rgba(245,166,35,0.4); }
.rank-2 { background:linear-gradient(135deg,#757575,#9E9E9E); }
.rank-3 { background:linear-gradient(135deg,#A0522D,#CD7F32); }
.rank-num { font-size:14px;font-weight:600;color:var(--text-sub);padding-left:8px; }
.rank-gold   { background:linear-gradient(90deg,rgba(245,166,35,0.07),transparent); }
.rank-silver { background:linear-gradient(90deg,rgba(158,158,158,0.07),transparent); }
.rank-bronze { background:linear-gradient(90deg,rgba(205,127,50,0.07),transparent); }
.name-cell { display:flex;align-items:center;gap:10px; }
.name-avatar { width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--blue-600),var(--blue-400));color:white;font-size:14px;font-weight:700;font-family:'Syne',sans-serif;display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.name-avatar.sm { width:28px;height:28px;font-size:12px; }
.amount-cell { font-family:'Syne',sans-serif;font-weight:700;color:var(--blue-700); }
.txn-cell,.avg-cell,.time-cell { color:var(--text-sub); }
.mode-badge { display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px; }
.mode-online { background:var(--blue-100);color:var(--blue-700); }
.mode-cash   { background:#F5F5F5;color:#757575; }

/* ── ACTION BUTTONS ── */
.actions-cell { white-space:nowrap; }
.btn-edit,.btn-delete { display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;text-decoration:none;font-size:16px;transition:all 0.2s;cursor:pointer; }
.btn-edit   { background:#E3F2FD; }
.btn-edit:hover { background:#BBDEFB;transform:scale(1.1); }
.btn-delete { background:#FFEBEE;margin-left:4px; }
.btn-delete:hover { background:#FFCDD2;transform:scale(1.1); }

/* ── EMPTY STATE ── */
.empty-state { padding:80px 24px;text-align:center;background:white;border-radius:var(--radius);box-shadow:var(--shadow); }
.empty-icon  { font-size:56px;margin-bottom:16px; }
.empty-title { font-family:'Syne',sans-serif;font-size:22px;font-weight:700;color:var(--blue-800);margin-bottom:8px; }
.empty-sub   { color:var(--text-sub);margin-bottom:24px; }
.btn-primary { display:inline-flex;align-items:center;background:var(--blue-600);color:white;text-decoration:none;padding:12px 28px;border-radius:10px;font-size:15px;font-weight:600;transition:background 0.2s,transform 0.2s; }
.btn-primary:hover { background:var(--blue-700);transform:translateY(-2px); }

/* ── PAGINATION ── */
.pagination { display:flex;gap:8px;justify-content:center;padding:24px 0 8px;flex-wrap:wrap; }
.page-btn { display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;text-decoration:none;font-size:14px;font-weight:600;color:var(--blue-600);background:white;border:1.5px solid rgba(21,101,192,0.2);transition:all 0.2s; }
.page-btn:hover { background:var(--blue-100); }
.page-btn.active { background:var(--blue-600);color:white;border-color:var(--blue-600); }

/* ── INSTRUCTIONS ── */
.instructions-section { background:white;border-radius:var(--radius);padding:36px;box-shadow:var(--shadow);border:1px solid rgba(21,101,192,0.08); }
.instructions-header { display:flex;align-items:center;gap:12px;margin-bottom:28px; }
.instructions-header h2 { font-family:'Syne',sans-serif;font-size:20px;font-weight:700;color:var(--blue-800); }
.info-icon { font-size:22px; }
.instructions-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px; }
.instruction-card { display:flex;gap:14px;align-items:flex-start;padding:18px;border-radius:12px;border:1px solid transparent;transition:transform 0.2s,box-shadow 0.2s; }
.instruction-card:hover { transform:translateY(-2px);box-shadow:0 4px 16px rgba(21,101,192,0.08); }
.instruction-card.gift    { background:#FFF8EC;border-color:rgba(245,166,35,0.2); }
.instruction-card.online  { background:#EFF6FF;border-color:rgba(21,101,192,0.2); }
.instruction-card.cash    { background:#F5F5F5;border-color:rgba(0,0,0,0.1); }
.instruction-card.reset   { background:#E8F5E9;border-color:rgba(46,125,50,0.2); }
.instruction-card.announce{ background:#FFF3E0;border-color:rgba(239,108,0,0.2); }
.instruction-card.fraud   { background:#FFEBEE;border-color:rgba(198,40,40,0.2); }
.instruction-card.receipt { background:#F3E5F5;border-color:rgba(123,31,162,0.2); }
.ic-icon { font-size:24px;flex-shrink:0; }
.ic-text { font-size:14px;color:var(--text-main);line-height:1.5; }
.ic-text strong { color:var(--blue-700); }

/* ── FOOTER ── */
.footer { background:var(--blue-900);padding:28px 0;color:rgba(255,255,255,0.6); }
.footer-inner { display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px; }
.footer-brand { font-family:'Syne',sans-serif;font-weight:700;color:white;font-size:16px; }
.footer-note { font-size:13px; }

/* ── LOGIN ── */
.login-wrap { min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px; }
.login-card { background:white;border-radius:20px;padding:48px 44px;width:100%;max-width:440px;box-shadow:var(--shadow-lg);border:1px solid rgba(21,101,192,0.1); }
.login-logo { display:flex;align-items:center;gap:14px;margin-bottom:32px; }
.login-title { font-family:'Syne',sans-serif;font-size:28px;font-weight:800;color:var(--blue-800);letter-spacing:-0.5px;margin-bottom:6px; }
.login-sub { color:var(--text-sub);font-size:15px;margin-bottom:28px; }
.login-back { text-align:center;margin-top:24px; }
.login-back a { color:var(--text-sub);font-size:13px;text-decoration:none; }
.login-back a:hover { color:var(--blue-600); }
.pass-wrap { position:relative; }
.pass-wrap input { padding-right:44px; }
.toggle-pass { position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:16px;padding:4px; }

/* ── ADMIN FORM ── */
.admin-main { padding:48px 0 80px; }
.admin-header { text-align:center;margin-bottom:40px; }
.page-title { font-family:'Syne',sans-serif;font-size:40px;font-weight:800;color:var(--blue-800);letter-spacing:-1.5px;margin-bottom:8px; }
.page-sub { color:var(--text-sub);font-size:16px; }
.alert { padding:14px 20px;border-radius:10px;font-size:15px;font-weight:500;margin-bottom:24px;animation:fadeSlideIn 0.3s ease; }
.alert-success { background:var(--success-bg);color:var(--success);border:1px solid rgba(46,125,50,0.3); }
.alert-error   { background:var(--error-bg);color:var(--error);border:1px solid rgba(198,40,40,0.3); }
.admin-grid { display:grid;grid-template-columns:1fr 300px;gap:28px;margin-bottom:40px; }
.form-card { background:white;border-radius:var(--radius);padding:36px;box-shadow:var(--shadow); }
.form-card-header { display:flex;align-items:center;gap:12px;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid rgba(21,101,192,0.08); }
.form-card-icon { font-size:24px; }
.form-card-header h2 { font-family:'Syne',sans-serif;font-size:18px;font-weight:700;color:var(--blue-800); }
.form-group { margin-bottom:20px; }
.form-row { display:grid;grid-template-columns:1fr 1fr;gap:16px; }
label { display:block;font-size:13px;font-weight:600;color:var(--blue-800);margin-bottom:7px;text-transform:uppercase;letter-spacing:0.5px; }
.req { color:var(--error); }
input[type="text"],input[type="email"],input[type="number"],input[type="date"],input[type="password"] {
    width:100%;padding:12px 16px;border:1.5px solid rgba(21,101,192,0.2);border-radius:10px;
    font-family:'DM Sans',sans-serif;font-size:15px;color:var(--text-main);background:white;
    transition:border-color 0.2s,box-shadow 0.2s;outline:none;
}
input:focus { border-color:var(--blue-600);box-shadow:0 0 0 3px rgba(21,101,192,0.10); }
input::placeholder { color:#9EAFC0; }
.input-prefix { position:relative; }
.input-prefix span { position:absolute;left:14px;top:50%;transform:translateY(-50%);font-weight:600;color:var(--blue-600);font-size:15px;pointer-events:none; }
.input-prefix input { padding-left:32px; }
.payment-toggle { display:grid;grid-template-columns:1fr 1fr;gap:12px; }
.payment-option input { display:none; }
.payment-card { border:2px solid rgba(21,101,192,0.15);border-radius:12px;padding:16px;cursor:pointer;text-align:center;transition:all 0.2s;position:relative;background:white; }
.payment-card:hover { border-color:var(--blue-400);background:var(--blue-50); }
.payment-option input:checked + .payment-card { border-color:var(--blue-600);background:var(--blue-50);box-shadow:0 0 0 3px rgba(21,101,192,0.12); }
.pay-check { position:absolute;top:8px;right:8px;width:20px;height:20px;border-radius:50%;background:var(--blue-600);color:white;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 0.2s; }
.payment-option input:checked + .payment-card .pay-check { opacity:1; }
.pay-icon  { font-size:24px;display:block;margin-bottom:6px; }
.pay-label { font-family:'Syne',sans-serif;font-weight:700;font-size:16px;color:var(--blue-800);display:block; }
.pay-note  { font-size:11px;color:var(--text-sub);display:block;margin-top:3px; }
.form-info { background:rgba(21,101,192,0.06);border-left:3px solid var(--blue-600);padding:10px 14px;border-radius:0 8px 8px 0;font-size:13px;color:var(--blue-700);margin-bottom:24px; }
.form-actions { display:flex;gap:12px;align-items:center; }
.btn-submit { flex:1;display:flex;align-items:center;justify-content:center;gap:10px;background:linear-gradient(135deg,var(--blue-600),var(--blue-500));color:white;border:none;padding:15px 24px;border-radius:12px;font-family:'Syne',sans-serif;font-size:16px;font-weight:700;cursor:pointer;transition:all 0.25s;box-shadow:0 4px 16px rgba(21,101,192,0.3); }
.btn-submit:hover { background:linear-gradient(135deg,var(--blue-700),var(--blue-600));transform:translateY(-2px);box-shadow:0 6px 20px rgba(21,101,192,0.4); }
.btn-cancel { padding:15px 24px;border-radius:12px;background:#f5f5f5;color:var(--text-sub);text-decoration:none;font-weight:600;font-size:15px;transition:background 0.2s;white-space:nowrap; }
.btn-cancel:hover { background:#e0e0e0; }
.admin-side { display:flex;flex-direction:column;gap:20px; }
.info-card { background:white;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow); }
.info-card h3 { font-family:'Syne',sans-serif;font-size:16px;font-weight:700;color:var(--blue-800);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(21,101,192,0.08); }
.filter-form { margin-bottom:16px; }
.filter-form input { width:100%; }
.quick-stats { display:flex;flex-direction:column;gap:12px;margin-bottom:20px; }
.qs-item { display:flex;justify-content:space-between;align-items:center; }
.qs-label { font-size:13px;color:var(--text-sub); }
.qs-val { font-family:'Syne',sans-serif;font-weight:700;font-size:16px;color:var(--blue-700); }
.qs-val.online { color:var(--blue-600); }
.qs-val.cash   { color:var(--silver); }
.btn-view { display:block;text-align:center;background:var(--blue-100);color:var(--blue-700);text-decoration:none;padding:10px;border-radius:8px;font-size:14px;font-weight:600;transition:background 0.2s; }
.btn-view:hover { background:#BBDEFB; }
.rules-card { background:var(--blue-900); }
.rules-card h3 { color:white;border-color:rgba(255,255,255,0.1); }
.rules-list { list-style:none;display:flex;flex-direction:column;gap:10px; }
.rules-list li { font-size:13px;color:rgba(255,255,255,0.7);padding-left:16px;position:relative; }
.rules-list li::before { content:'→';position:absolute;left:0;color:var(--accent); }
.recent-section { margin-top:8px; }

/* ── RESPONSIVE ── */
@media(max-width:900px) {
    .admin-grid { grid-template-columns:1fr; }
    .admin-side { display:grid;grid-template-columns:1fr 1fr; }
}
@media(max-width:700px) {
    .hero { padding:40px 0 28px; }
    .hero-title { letter-spacing:-1px; }
    .stats-grid { gap:0; }
    .stat-item { padding:8px 20px; }
    .podium { gap:10px; }
    .podium-card,.podium-card.center { width:100%;max-width:300px; }
    .form-row { grid-template-columns:1fr; }
    .admin-side { grid-template-columns:1fr; }
    .instructions-grid { grid-template-columns:1fr; }
    .instructions-section,.form-card { padding:24px 20px; }
    .login-card { padding:32px 24px; }
    .form-actions { flex-direction:column; }
    .btn-cancel { width:100%;text-align:center; }
}
@media(max-width:480px) {
    .container { padding:0 16px; }
    .date-picker-wrap { flex-wrap:wrap;justify-content:center; }
}

/* ── NAME SUGGESTIONS / CHIPS ── */
.name-input-wrap { position: relative; }
.name-suggestions {
    background: white;
    border: 1.5px solid rgba(21,101,192,0.2);
    border-radius: 12px;
    padding: 14px;
    margin-top: 8px;
    box-shadow: 0 4px 20px rgba(21,101,192,0.10);
}
.ns-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-sub);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    margin-bottom: 10px;
}
.ns-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.ns-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--blue-50);
    border: 1.5px solid rgba(21,101,192,0.18);
    color: var(--blue-700);
    border-radius: 100px;
    padding: 5px 14px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.18s;
    font-family: 'DM Sans', sans-serif;
}
.ns-chip:hover {
    background: var(--blue-600);
    color: white;
    border-color: var(--blue-600);
    transform: translateY(-1px);
    box-shadow: 0 3px 10px rgba(21,101,192,0.25);
}
.ns-chip::before {
    content: '👤';
    font-size: 11px;
}

/* ── LEADERBOARD PREVIEW SIDEBAR ── */
.lb-preview-card { border: 1.5px solid rgba(21,101,192,0.12); }
.lb-preview { display: flex; flex-direction: column; gap: 8px; }
.lb-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 10px;
    background: var(--blue-50);
    font-size: 13px;
    transition: background 0.2s;
}
.lb-row:hover { background: var(--blue-100); }
.lb-row.lb-top { background: rgba(245,166,35,0.07); }
.lb-medal { font-size: 16px; flex-shrink: 0; min-width: 24px; }
.lb-name  { flex: 1; font-weight: 600; color: var(--blue-800); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lb-amt   { font-family: 'Syne', sans-serif; font-weight: 700; color: var(--blue-700); font-size: 13px; white-space: nowrap; }
.lb-edit-btn {
    text-decoration: none;
    font-size: 14px;
    padding: 2px 6px;
    border-radius: 6px;
    background: white;
    border: 1px solid rgba(21,101,192,0.15);
    transition: all 0.2s;
    flex-shrink: 0;
}
.lb-edit-btn:hover { background: var(--blue-100); transform: scale(1.1); }

/* Row clickable cursor */
.leaderboard-table tbody .table-row { cursor: pointer; }
.actions-cell { cursor: default; }

/* ══════════ SECTION DIVIDER ══════════ */
.section-divider {
    display: flex; align-items: center; gap: 16px;
    margin: 60px 0 40px;
}
.section-divider::before, .section-divider::after {
    content: ''; flex: 1; height: 2px;
    background: linear-gradient(90deg, transparent, rgba(21,101,192,0.2), transparent);
}
.section-divider span {
    font-family: 'Syne', sans-serif; font-size: 20px; font-weight: 800;
    color: var(--blue-700); white-space: nowrap; padding: 0 8px;
}

/* ══════════ MONTHLY SECTION ══════════ */
.monthly-section { margin-bottom: 20px; }
.monthly-header {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 16px; margin-bottom: 28px;
}
.month-picker-form {
    display: inline-flex; align-items: center; gap: 10px;
    background: white; border: 1.5px solid rgba(21,101,192,0.2);
    border-radius: 12px; padding: 10px 16px; box-shadow: var(--shadow);
}
.month-picker-form label { font-size: 13px; color: var(--text-sub); font-weight: 500; }
.month-picker-form input[type="month"] {
    border: none; outline: none; font-family: 'DM Sans', sans-serif;
    font-size: 14px; color: var(--blue-700); background: transparent; cursor: pointer;
}
.monthly-stats-bar {
    display: flex; align-items: stretch; background: white;
    border-radius: var(--radius); box-shadow: var(--shadow);
    overflow: hidden; margin-bottom: 36px; flex-wrap: wrap;
}
.mstat {
    flex: 1; padding: 20px 24px; text-align: center; min-width: 120px;
    border-right: 1px solid rgba(21,101,192,0.08);
}
.mstat:last-child { border-right: none; }
.mstat-val { font-family: 'Syne', sans-serif; font-size: 24px; font-weight: 800; color: var(--blue-700); }
.mstat-label { font-size: 11px; color: var(--text-sub); font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; margin-top: 4px; }
.monthly-card { border-top-width: 5px !important; }

/* Gift banner */
.gift-banner {
    background: linear-gradient(135deg, #FFF8EC, #FFF3CD);
    border: 1.5px solid rgba(245,166,35,0.35);
    border-radius: 14px; padding: 18px 24px;
    text-align: center; font-size: 15px; color: #7A4F00;
    margin-top: 28px; line-height: 1.6;
}
.gift-banner strong { color: #D4890A; }

/* ══════════ REVIEWS SECTION ══════════ */
.reviews-section { margin-bottom: 60px; }
.reviews-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 28px;
    align-items: start;
}

/* Review form card */
.review-form-card {
    background: white; border-radius: var(--radius);
    padding: 36px; box-shadow: var(--shadow);
}
.review-intro { font-size: 14px; color: var(--text-sub); margin-bottom: 24px; line-height: 1.5; }

/* Category chips */
.category-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.cat-chip input { display: none; }
.cat-chip span {
    display: inline-flex; align-items: center; gap: 4px;
    background: var(--blue-50); border: 1.5px solid rgba(21,101,192,0.15);
    color: var(--blue-700); border-radius: 100px; padding: 6px 14px;
    font-size: 13px; font-weight: 500; cursor: pointer; transition: all 0.18s;
}
.cat-chip span:hover { background: var(--blue-100); }
.cat-chip input:checked + span {
    background: var(--blue-600); color: white; border-color: var(--blue-600);
    box-shadow: 0 3px 10px rgba(21,101,192,0.25);
}

/* Star rating input */
.star-rating {
    display: flex; flex-direction: row-reverse; gap: 4px;
    justify-content: flex-end; margin-bottom: 6px;
}
.star-rating input { display: none; }
.star-rating label {
    font-size: 32px; color: #ddd; cursor: pointer;
    transition: color 0.15s, transform 0.15s;
    text-transform: none; letter-spacing: 0; font-weight: 400;
    margin-bottom: 0; padding: 0;
}
.star-rating label:hover,
.star-rating label:hover ~ label,
.star-rating input:checked ~ label { color: #F5A623; }
.star-rating label:hover { transform: scale(1.2); }
.star-label { font-size: 13px; color: var(--text-sub); font-weight: 600; height: 20px; }

/* Textarea */
textarea {
    width: 100%; padding: 12px 16px;
    border: 1.5px solid rgba(21,101,192,0.2); border-radius: 10px;
    font-family: 'DM Sans', sans-serif; font-size: 15px; color: var(--text-main);
    background: white; resize: vertical; outline: none;
    transition: border-color 0.2s, box-shadow 0.2s; line-height: 1.5;
}
textarea:focus { border-color: var(--blue-600); box-shadow: 0 0 0 3px rgba(21,101,192,0.10); }
textarea::placeholder { color: #9EAFC0; }
.char-count { text-align: right; font-size: 12px; color: var(--text-sub); margin-top: 4px; }

/* Reviews list */
.reviews-list-wrap {
    background: white; border-radius: var(--radius);
    padding: 28px; box-shadow: var(--shadow);
}
.reviews-summary { margin-bottom: 24px; }
.avg-rating-block { display: flex; align-items: center; gap: 14px; padding: 16px; background: var(--blue-50); border-radius: 12px; }
.avg-rating-num { font-family: 'Syne', sans-serif; font-size: 42px; font-weight: 800; color: var(--blue-700); line-height: 1; }
.avg-stars { display: flex; gap: 2px; }
.star-filled { color: #F5A623; font-size: 20px; }
.star-empty  { color: #ddd;    font-size: 20px; }
.avg-label { font-size: 13px; color: var(--text-sub); }
.reviews-list-title { font-family: 'Syne', sans-serif; font-size: 16px; font-weight: 700; color: var(--blue-800); margin-bottom: 16px; }
.reviews-list { display: flex; flex-direction: column; gap: 14px; max-height: 520px; overflow-y: auto; padding-right: 4px; }
.reviews-list::-webkit-scrollbar { width: 4px; }
.reviews-list::-webkit-scrollbar-track { background: var(--blue-50); border-radius: 4px; }
.reviews-list::-webkit-scrollbar-thumb { background: rgba(21,101,192,0.2); border-radius: 4px; }

.review-card {
    background: var(--blue-50); border-radius: 12px; padding: 16px;
    border: 1px solid rgba(21,101,192,0.08);
    animation: fadeSlideIn 0.3s ease backwards;
}
.review-top { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.review-avatar {
    width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0;
    background: linear-gradient(135deg, var(--blue-600), var(--blue-400));
    color: white; font-size: 14px; font-weight: 700;
    font-family: 'Syne', sans-serif;
    display: flex; align-items: center; justify-content: center;
}
.review-meta { flex: 1; }
.review-name { font-weight: 700; font-size: 14px; color: var(--blue-800); }
.review-date { font-size: 12px; color: var(--text-sub); }
.review-right { text-align: right; }
.review-stars { display: flex; gap: 1px; justify-content: flex-end; }
.review-stars .star-filled, .review-stars .star-empty { font-size: 14px; }
.review-categ { font-size: 11px; color: var(--text-sub); margin-top: 2px; }
.review-text { font-size: 14px; color: var(--text-main); line-height: 1.6; }

/* ══════════ RESPONSIVE ══════════ */
@media (max-width: 900px) {
    .reviews-grid { grid-template-columns: 1fr; }
    .monthly-stats-bar { display: grid; grid-template-columns: 1fr 1fr; }
    .mstat { border-right: none; border-bottom: 1px solid rgba(21,101,192,0.08); }
}
@media (max-width: 600px) {
    .monthly-header { flex-direction: column; align-items: flex-start; }
    .month-picker-form { flex-wrap: wrap; }
    .section-divider span { font-size: 16px; }
    .monthly-stats-bar { grid-template-columns: 1fr 1fr; }
}

/* ══════════ STAR PICKER (reviews.php) ══════════ */
.star-picker {
    display: flex; gap: 8px; margin-bottom: 10px;
}
.star-btn {
    background: none; border: 2px solid rgba(21,101,192,0.2);
    border-radius: 10px; width: 52px; height: 52px;
    font-size: 28px; cursor: pointer; color: #ddd;
    transition: all 0.18s; line-height: 1;
    display: flex; align-items: center; justify-content: center;
}
.star-btn:hover, .star-btn.hover {
    color: var(--blue-400); border-color: var(--blue-400);
    transform: scale(1.12);
}
.star-btn.active {
    color: white; background: var(--blue-600);
    border-color: var(--blue-600);
    box-shadow: 0 4px 12px rgba(21,101,192,0.35);
    transform: scale(1.08);
}
.star-feedback {
    font-size: 15px; font-weight: 600; color: var(--text-sub);
    min-height: 24px; transition: all 0.2s;
}
.star-feedback.active { color: var(--blue-700); }
.star-feedback.sf-1 { color: #E53935; }
.star-feedback.sf-2 { color: #FB8C00; }
.star-feedback.sf-3 { color: #FDD835; }
.star-feedback.sf-4 { color: #43A047; }
.star-feedback.sf-5 { color: var(--blue-600); }

/* Rating summary card */
.rating-summary-card {
    background: white; border-radius: var(--radius);
    padding: 24px; box-shadow: var(--shadow);
    margin-bottom: 24px;
}
.avg-big { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; }
.avg-number {
    font-family: 'Syne', sans-serif; font-size: 56px; font-weight: 800;
    color: var(--blue-700); line-height: 1;
}
.avg-stars-row { display: flex; gap: 3px; margin-bottom: 4px; }
.star-filled { color: var(--blue-500); font-size: 20px; }
.star-empty  { color: #ddd; font-size: 20px; }
.avg-count { font-size: 13px; color: var(--text-sub); }
.rating-bars { display: flex; flex-direction: column; gap: 8px; }
.rb-row { display: flex; align-items: center; gap: 10px; }
.rb-label { font-size: 13px; font-weight: 600; color: var(--blue-700); width: 24px; text-align: right; flex-shrink: 0; }
.rb-track { flex: 1; height: 8px; background: var(--blue-50); border-radius: 100px; overflow: hidden; }
.rb-fill { height: 100%; background: linear-gradient(90deg, var(--blue-600), var(--blue-400)); border-radius: 100px; transition: width 1s ease; }
.rb-count { font-size: 12px; color: var(--text-sub); width: 20px; flex-shrink: 0; }

/* Review cards */
.review-emoji-label {
    font-size: 13px; font-weight: 600; color: var(--blue-600);
    margin-bottom: 8px;
}
.review-stars-row { display: flex; gap: 2px; justify-content: flex-end; }
.review-stars-row .star-filled { font-size: 15px; color: var(--blue-500); }
.review-stars-row .star-empty  { font-size: 15px; color: #ddd; }
.review-categ-badge {
    font-size: 11px; color: var(--text-sub);
    background: var(--blue-50); padding: 2px 8px;
    border-radius: 100px; margin-top: 4px;
    display: inline-block;
}

/* Gift banner */
.gift-banner {
    background: linear-gradient(135deg,#FFF8EC,#FFF3CD);
    border: 1.5px solid rgba(245,166,35,0.35);
    border-radius: 14px; padding: 18px 24px;
    text-align: center; font-size: 15px; color: #7A4F00;
    margin-top: 28px; line-height: 1.6;
}
.gift-banner strong { color: #D4890A; }

/* Monthly stats bar */
.monthly-stats-bar {
    display: flex; align-items: stretch; background: white;
    border-radius: var(--radius); box-shadow: var(--shadow);
    overflow: hidden; margin-bottom: 36px; flex-wrap: wrap;
}
.mstat { flex:1; padding:20px 24px; text-align:center; min-width:120px; border-right:1px solid rgba(21,101,192,0.08); }
.mstat:last-child { border-right:none; }
.mstat-val { font-family:'Syne',sans-serif; font-size:24px; font-weight:800; color:var(--blue-700); }
.mstat-label { font-size:11px; color:var(--text-sub); font-weight:600; text-transform:uppercase; letter-spacing:0.5px; margin-top:4px; }


/* ════════════════════════════════════════════════════
   SWIGGY-STYLE MENU PAGE
════════════════════════════════════════════════════ */
.menu-page-wrap {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 0;
    min-height: 70vh;
    background: #f7f9fc;
}

/* ── SIDEBAR ── */
.menu-sidebar {
    background: white;
    border-right: 1px solid #eef2f7;
    position: sticky;
    top: 64px;
    height: calc(100vh - 64px);
    overflow-y: auto;
    scrollbar-width: thin;
}
.menu-sidebar::-webkit-scrollbar { width: 4px; }
.menu-sidebar::-webkit-scrollbar-thumb { background: rgba(21,101,192,0.15); border-radius:4px; }
.menu-sidebar-inner { padding: 16px 0 40px; }

.menu-sidebar-search { padding: 0 12px 12px; }
.menu-sidebar-search input {
    width: 100%; padding: 9px 12px; border-radius: 8px;
    border: 1.5px solid rgba(21,101,192,0.15);
    font-family: 'DM Sans', sans-serif; font-size: 13px;
    color: var(--text-main); outline: none;
    background: #f7f9fc; transition: border-color 0.2s;
}
.menu-sidebar-search input:focus { border-color: #1565C0; background: white; }

.menu-cat-nav { display: flex; flex-direction: column; }
.mcat-btn {
    display: flex; align-items: center; gap: 10px;
    padding: 13px 16px; border: none; background: none;
    cursor: pointer; font-family: 'DM Sans', sans-serif;
    text-align: left; width: 100%; transition: all 0.15s;
    border-left: 3px solid transparent;
    position: relative;
}
.mcat-btn:hover { background: #f0f6ff; }
.mcat-btn.active {
    background: #e8f0fe;
    border-left-color: #1565C0;
}
.mcat-btn.active .mcat-label { color: #1565C0; font-weight: 700; }
.mcat-icon { font-size: 20px; flex-shrink: 0; }
.mcat-label { font-size: 14px; font-weight: 500; color: #444; flex: 1; }
.mcat-count {
    background: #eef2f7; color: #888;
    font-size: 11px; font-weight: 700;
    padding: 2px 7px; border-radius: 100px;
}
.mcat-btn.active .mcat-count { background: rgba(21,101,192,0.12); color: #1565C0; }

.menu-veg-toggle {
    margin: 12px 16px 0;
    padding: 12px;
    background: #f7f9fc;
    border-radius: 10px;
    border: 1px solid #eef2f7;
}
.veg-toggle-label {
    display: flex; align-items: center; gap: 10px;
    cursor: pointer; font-size: 13px; font-weight: 600; color: #2E7D32;
}
.veg-toggle-wrap { position: relative; width: 38px; height: 20px; flex-shrink: 0; }
.veg-toggle-wrap input { opacity: 0; width: 0; height: 0; position: absolute; }
.veg-toggle-track {
    width: 38px; height: 20px; background: #ddd;
    border-radius: 100px; transition: background 0.2s; cursor: pointer;
    position: relative;
}
.veg-toggle-thumb {
    position: absolute; top: 3px; left: 3px;
    width: 14px; height: 14px; border-radius: 50%;
    background: white; transition: transform 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.veg-toggle-wrap input:checked ~ .veg-toggle-track { background: #43A047; }
.veg-toggle-wrap input:checked ~ .veg-toggle-track .veg-toggle-thumb { transform: translateX(18px); }

/* ── CONTENT AREA ── */
.menu-content { padding: 24px 28px; }

.menu-section { margin-bottom: 44px; }
.menu-section-header {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 20px; padding-bottom: 12px;
    border-bottom: 2px solid #eef2f7;
}
.menu-sec-icon { font-size: 22px; }
.menu-sec-title {
    font-family: 'Syne', sans-serif;
    font-size: 20px; font-weight: 800;
    color: var(--blue-800); margin: 0; flex: 1;
}
.menu-sec-count {
    font-size: 12px; color: var(--text-sub);
    background: #eef2f7; padding: 3px 10px; border-radius: 100px; font-weight: 600;
}

/* ── ITEM CARDS GRID (Swiggy style) ── */
.menu-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 16px;
}

.menu-item-card {
    background: white;
    border-radius: 16px;
    border: 1px solid #eef2f7;
    display: flex;
    gap: 14px;
    padding: 16px;
    transition: box-shadow 0.2s, transform 0.2s;
    animation: riseUp 0.4s ease backwards;
    cursor: default;
    position: relative;
    overflow: hidden;
}
.menu-item-card:hover {
    box-shadow: 0 6px 24px rgba(21,101,192,0.12);
    transform: translateY(-2px);
}

/* Emoji image area (mimics Swiggy food photo circle) */
.mic-img-wrap {
    flex-shrink: 0;
    width: 96px; height: 96px;
    border-radius: 12px;
    background: linear-gradient(135deg, #f0f6ff, #e8f0fe);
    display: flex; align-items: center; justify-content: center;
    position: relative;
    overflow: hidden;
}
.mic-emoji-display { font-size: 48px; line-height: 1; }

/* Veg/Non-veg badge (green/red square dot like Swiggy) */
.mic-veg-badge {
    position: absolute; top: 6px; right: 6px;
    width: 14px; height: 14px;
    border-radius: 3px;
    border: 2px solid;
}
.badge-veg    { background: #43A047; border-color: #43A047; }
.badge-nonveg { background: #E53935; border-color: #E53935; }

/* Info area */
.mic-info { flex: 1; display: flex; flex-direction: column; min-width: 0; }
.mic-name {
    font-family: 'Syne', sans-serif;
    font-size: 15px; font-weight: 700;
    color: var(--blue-800); margin-bottom: 5px;
    line-height: 1.3;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.mic-desc {
    font-size: 12px; color: var(--text-sub);
    line-height: 1.5; flex: 1; margin-bottom: 12px;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.mic-footer {
    display: flex; align-items: center;
    justify-content: space-between; gap: 8px; margin-top: auto;
}
.mic-price {
    font-family: 'Syne', sans-serif;
    font-size: 17px; font-weight: 800;
    color: var(--blue-800);
}
.mic-add-btn {
    background: white; color: var(--blue-600);
    border: 1.5px solid var(--blue-600);
    padding: 7px 18px; border-radius: 8px;
    font-size: 13px; font-weight: 700;
    cursor: pointer; transition: all 0.18s;
    font-family: 'DM Sans', sans-serif;
    white-space: nowrap;
}
.mic-add-btn:hover { background: #E3F2FD; }
.mic-add-btn.added { background: #E8F5E9; color: #2E7D32; border-color: #43A047; }

/* No results */
.menu-no-results {
    display: flex; flex-direction: column; align-items: center;
    justify-content: center; padding: 80px 20px; gap: 12px;
}

/* Notice */
.menu-notice {
    display: flex; gap: 12px; align-items: flex-start;
    background: white; border-radius: 12px;
    padding: 18px 22px; font-size: 14px;
    color: var(--text-main); line-height: 1.6;
    box-shadow: var(--shadow); border: 1px solid #eef2f7;
    margin-top: 8px;
}

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
    .menu-page-wrap { grid-template-columns: 1fr; }
    .menu-sidebar {
        position: static; height: auto;
        border-right: none; border-bottom: 1px solid #eef2f7;
    }
    .menu-cat-nav { flex-direction: row; flex-wrap: nowrap; overflow-x: auto; padding: 0 12px 8px; gap: 4px; }
    .mcat-btn { border-left: none; border-bottom: 3px solid transparent; min-width: auto; padding: 10px 14px; white-space: nowrap; border-radius: 8px 8px 0 0; }
    .mcat-btn.active { border-bottom-color: #1565C0; border-left-color: transparent; background: #e8f0fe; }
    .menu-veg-toggle { display: flex; justify-content: flex-start; margin: 0 12px 12px; }
    .menu-content { padding: 20px 16px; }
    .menu-cards-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
    .menu-cards-grid { grid-template-columns: 1fr; }
    .mic-img-wrap { width: 80px; height: 80px; }
    .mic-emoji-display { font-size: 38px; }
}
/* ════════════════════════════════════════════════════
   ADMIN TABS + MENU MANAGEMENT
════════════════════════════════════════════════════ */
.admin-tabs {
    display:flex; gap:4px; background:white;
    border-radius:12px; padding:6px;
    box-shadow:var(--shadow); margin-bottom:28px;
    width:fit-content;
}
.admin-tab {
    padding:10px 24px; border-radius:8px;
    font-size:14px; font-weight:700;
    font-family:'Syne',sans-serif;
    color:var(--text-sub); text-decoration:none;
    transition:all 0.2s;
}
.admin-tab:hover { background:var(--blue-50); color:var(--blue-700); }
.admin-tab.active { background:var(--blue-600); color:white; box-shadow:0 3px 10px rgba(21,101,192,0.25); }

.menu-admin-layout {
    display:grid; grid-template-columns:360px 1fr;
    gap:24px; align-items:start;
}
.menu-admin-list .table-section { margin-bottom:0; }
.row-inactive { opacity:0.5; }
.form-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

/* Responsive */
@media (max-width:1000px) {
    .ab-page-grid { grid-template-columns:1fr; }
    .ab-form-card { position:static; }
    .menu-admin-layout { grid-template-columns:1fr; }
}
@media (max-width:700px) {
    .ab-big-stars-row { gap:4px; }
    .ab-bigstar { width:42px; height:42px; font-size:22px; }
    .ab-cri-row { grid-template-columns:1fr; gap:8px; }
    .ab-overall-row { flex-direction:column; align-items:flex-start; }
    .menu-grid-flat { grid-template-columns:1fr; }
    .form-row-2 { grid-template-columns:1fr; }
    .ab-hero-inner { flex-direction:column; }
}

/* ═══════════════════════════════════════════════════════
   SWIGGY / ZOMATO STYLE MENU
═══════════════════════════════════════════════════════ */

/* Hero */
.menu-page-hero {
    background: white;
    border-bottom: 1px solid #EEF2F7;
    padding: 24px 0 20px;
    position: sticky; top: 64px; z-index: 40;
    box-shadow: 0 2px 12px rgba(21,101,192,0.06);
}
.menu-hero-inner {
    display: flex; align-items: center;
    justify-content: space-between; gap: 20px; flex-wrap: wrap;
}
.menu-hero-title {
    font-family: 'Syne', sans-serif;
    font-size: clamp(20px, 3vw, 26px); font-weight: 800;
    color: var(--blue-800); margin: 0 0 4px;
}
.menu-hero-sub { font-size: 13px; color: var(--text-sub); margin: 0; }

/* Search box */
.menu-search-wrap { min-width: 260px; }
.menu-search-box {
    display: flex; align-items: center; gap: 10px;
    background: #F5F7FA; border: 1.5px solid #E0E7EF;
    border-radius: 12px; padding: 10px 16px;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.menu-search-box:focus-within {
    border-color: var(--blue-400);
    box-shadow: 0 0 0 3px rgba(21,101,192,0.08);
    background: white;
}
.search-icon { width: 18px; height: 18px; flex-shrink: 0; }
.menu-search-box input {
    border: none; background: transparent; outline: none;
    font-family: 'DM Sans', sans-serif; font-size: 14px;
    color: var(--text-main); width: 100%;
}
.menu-search-box input::placeholder { color: #9EAFC0; }

/* Layout */
.menu-page-body { padding: 32px 0 0; }
.menu-layout {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 28px;
    align-items: start;
}

/* Category sidebar */
.menu-cat-nav {
    position: sticky; top: 148px;
    background: white; border-radius: 14px;
    box-shadow: var(--shadow); overflow: hidden;
    padding-bottom: 16px;
}
.cat-nav-title {
    font-family: 'Syne', sans-serif; font-weight: 800;
    font-size: 13px; color: var(--text-sub);
    text-transform: uppercase; letter-spacing: 1px;
    padding: 16px 16px 10px;
}
.cat-nav-item {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 16px; text-decoration: none;
    color: var(--text-main); font-size: 14px; font-weight: 500;
    transition: all 0.15s; border-left: 3px solid transparent;
    cursor: pointer;
}
.cat-nav-item:hover { background: var(--blue-50); color: var(--blue-700); }
.cat-nav-item.active {
    background: #EBF3FD; color: var(--blue-700);
    border-left-color: var(--blue-600); font-weight: 700;
}
.cat-nav-icon { font-size: 18px; flex-shrink: 0; }
.cat-nav-label { flex: 1; }
.cat-nav-count {
    font-size: 11px; background: #EEF2F7; color: var(--text-sub);
    padding: 2px 7px; border-radius: 100px; font-weight: 600;
}
.cat-nav-item.active .cat-nav-count { background: rgba(21,101,192,0.12); color: var(--blue-600); }

.cat-nav-divider { height: 1px; background: #EEF2F7; margin: 12px 0; }
.cat-filter-label {
    font-size: 11px; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.8px; color: var(--text-sub);
    padding: 0 16px 8px;
}
.cat-filter-btn {
    display: block; width: calc(100% - 32px); margin: 0 16px 6px;
    padding: 8px 12px; border-radius: 8px;
    border: 1.5px solid #E0E7EF; background: white;
    font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 600;
    color: var(--text-sub); cursor: pointer; text-align: left;
    transition: all 0.15s;
}
.cat-filter-btn:hover { background: var(--blue-50); border-color: var(--blue-300); color: var(--blue-700); }
.cat-filter-btn.active { background: var(--blue-600); border-color: var(--blue-600); color: white; }
.cat-filter-btn.veg.active { background: #43A047; border-color: #43A047; }
.cat-filter-btn.nonveg.active { background: #E53935; border-color: #E53935; }

/* Section header */
.menu-section { margin-bottom: 40px; scroll-margin-top: 160px; }
.menu-section-header {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 18px; padding-bottom: 12px;
    border-bottom: 2px solid #EEF2F7;
}
.menu-section-icon { font-size: 22px; }
.menu-section-title {
    font-family: 'Syne', sans-serif; font-size: 20px; font-weight: 800;
    color: var(--blue-800); margin: 0; flex: 1;
}
.menu-section-count {
    font-size: 12px; color: var(--text-sub);
    background: #EEF2F7; padding: 3px 10px; border-radius: 100px; font-weight: 600;
}

/* Cards grid */
.menu-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
    gap: 16px;
}

/* ── THE SWIGGY CARD ── */
.swiggy-card {
    background: white; border-radius: 14px;
    border: 1px solid #E8EEF5;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
    padding: 16px; position: relative;
    display: flex; flex-direction: column; gap: 0;
    transition: box-shadow 0.2s, transform 0.2s;
    animation: riseUp 0.45s ease backwards;
    overflow: hidden;
}
.swiggy-card:hover {
    box-shadow: 0 8px 28px rgba(21,101,192,0.13);
    transform: translateY(-3px);
}

/* Veg/NonVeg badge top-right */
.sc-veg-badge {
    position: absolute; top: 12px; right: 12px;
    width: 20px; height: 20px; border-radius: 4px;
    border: 2px solid; display: flex; align-items: center; justify-content: center;
}
.sc-veg-badge.sc-veg { border-color: #43A047; }
.sc-veg-badge.sc-nonveg { border-color: #E53935; }
.sc-veg-dot {
    width: 10px; height: 10px; border-radius: 50%;
}
.sc-veg .sc-veg-dot { background: #43A047; }
.sc-nonveg .sc-veg-dot { background: #E53935; }

/* Image circle */
.sc-img-wrap {
    display: flex; justify-content: center;
    margin-bottom: 14px;
}
.sc-img-circle {
    width: 90px; height: 90px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.bg-veg    { background: linear-gradient(135deg, #E8F5E9, #C8E6C9); }
.bg-nonveg { background: linear-gradient(135deg, #FFF3E0, #FFCCBC); }
.sc-emoji  { font-size: 46px; line-height: 1; }

/* Info */
.sc-info { flex: 1; margin-bottom: 14px; }
.sc-name {
    font-family: 'Syne', sans-serif; font-weight: 700;
    font-size: 15px; color: var(--blue-900, #0D1B2A);
    margin-bottom: 5px; line-height: 1.3;
    /* truncate at 2 lines */
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.sc-desc {
    font-size: 12px; color: var(--text-sub); line-height: 1.5;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}

/* Footer */
.sc-footer {
    display: flex; align-items: center;
    justify-content: space-between; gap: 8px;
    border-top: 1px solid #F0F3F8; padding-top: 12px;
    margin-top: auto;
}
.sc-price {
    font-family: 'Syne', sans-serif;
    font-size: 17px; font-weight: 800;
    color: var(--blue-800);
}
.sc-add-btn {
    background: white; border: 1.5px solid var(--blue-600);
    color: var(--blue-600); font-family: 'Syne', sans-serif;
    font-size: 13px; font-weight: 700;
    padding: 7px 18px; border-radius: 8px;
    cursor: pointer; transition: all 0.18s;
    white-space: nowrap;
}
.sc-add-btn:hover { background: var(--blue-600); color: white; box-shadow: 0 4px 12px rgba(21,101,192,0.25); }
.sc-add-btn.added { background: #43A047; border-color: #43A047; color: white; }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
    .menu-layout { grid-template-columns: 1fr; }
    .menu-cat-nav { position: static; display: flex; flex-wrap: wrap; gap: 6px; padding: 12px; border-radius: 12px; }
    .cat-nav-title, .cat-nav-divider, .cat-filter-label { display: none; }
    .cat-nav-item { padding: 8px 14px; border-radius: 100px; border-left: none; font-size: 13px; background: #F5F7FA; }
    .cat-nav-item.active { background: var(--blue-600); color: white; border-left: none; }
    .cat-filter-btn { width: auto; margin: 0; display: inline-flex; }
    .menu-page-hero { position: static; }
    .menu-section { scroll-margin-top: 20px; }
}
@media (max-width: 600px) {
    .menu-cards-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
    .sc-img-circle { width: 70px; height: 70px; }
    .sc-emoji { font-size: 36px; }
    .menu-hero-inner { flex-direction: column; align-items: flex-start; }
    .menu-search-wrap { width: 100%; }
}
@media (max-width: 400px) {
    .menu-cards-grid { grid-template-columns: 1fr; }
}
