@import "https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box;margin:0;padding:0}html,body{background-color:#f5f5f5;height:100dvh;font-family:Poppins,sans-serif;overflow:hidden}#root{height:100%}:root{--merah:#e53935;--merah-gelap:#c62828;--merah-muda:#ffebee;--oranye:#ff6f00;--putih:#fff;--abu-terang:#f5f5f5;--abu:#9e9e9e;--abu-gelap:#424242;--hitam:#212121;--bayangan:0 2px 12px #0000001a;--header-h:64px;--bottom-nav-h:64px;--safe-bottom:env(safe-area-inset-bottom,0px)}.halaman-sambutan{background-color:var(--merah);cursor:pointer;background-image:radial-gradient(circle,#ffffff26 1px,#0000 1px);background-size:30px 30px;flex-direction:column;justify-content:center;align-items:center;gap:24px;width:100vw;height:100vh;display:flex}.sambutan-judul{color:var(--hitam);letter-spacing:1px;font-size:2.2rem;font-weight:800}.logo-lingkaran{border-radius:50%;width:140px;height:140px;animation:3s ease-in-out infinite bernapas}@keyframes bernapas{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.logo-nama{color:var(--putih);letter-spacing:2px;text-align:center;font-size:2rem;font-weight:700}.sambutan-petunjuk{color:#fffc;margin-top:8px;font-size:1rem}.header{height:var(--header-h);background-color:var(--putih);box-shadow:var(--bayangan);z-index:10;flex-shrink:0;align-items:center;gap:16px;padding:0 20px;display:flex;position:sticky;top:0}.header-logo{cursor:pointer;flex-shrink:0;align-items:center;gap:8px;text-decoration:none;display:flex}.logo-kecil{background-color:var(--merah);border-radius:50%;width:40px;height:40px;overflow:hidden}.logo-kecil img{object-fit:cover;width:100%;height:100%}.logo-teks{color:var(--merah);letter-spacing:-.5px;font-size:1.4rem;font-weight:800}.btn-profil-ikon{z-index:100;cursor:pointer;border:1px solid #ddd;transition:transform .2s}.btn-profil-ikon:hover{transform:scale(1.1);background-color:#eee!important}.form-cari{background-color:var(--abu-terang);border:1.5px solid #e0e0e0;border-radius:12px;flex:1;max-width:500px;padding:0 16px;display:flex;position:relative}.input-cari{background:0 0;border:none;outline:none;flex:1;padding:10px 0;font-family:Poppins;font-size:.9rem}.header-pesanan{background-color:var(--merah);color:var(--putih);cursor:pointer;border-radius:12px;flex-shrink:0;align-items:center;gap:8px;padding:8px 16px;display:flex;position:relative}.header-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.halaman-beranda{flex-direction:column;height:100vh;display:flex;overflow:hidden}.konten-utama{flex:1;min-height:0;display:flex;overflow:hidden}.sidebar-kategori{background-color:var(--putih);flex-direction:column;flex-shrink:0;gap:4px;width:100px;padding:12px 8px;display:flex;overflow-y:auto;box-shadow:2px 0 8px #0000000d}.sidebar-item{cursor:pointer;border-radius:12px;flex-direction:column;align-items:center;padding:10px 4px;transition:all .1s;display:flex}.sidebar-item.aktif{background-color:var(--merah-muda);border:2px solid var(--merah)}.sidebar-item:hover{background-color:var(--merah-muda);transform:scale(1.03)}.sidebar-ikon{font-size:1.6rem}.sidebar-label{color:var(--hitam);text-align:center;font-size:.65rem;font-weight:500}.area-menu{flex:1;min-height:0;padding:16px;overflow-y:auto}.judul-kategori{color:var(--hitam);margin-bottom:12px;font-size:1.2rem;font-weight:700}.grid-menu{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.kartu-menu{background-color:var(--putih);cursor:pointer;box-shadow:var(--bayangan);border:2px solid #0000;border-radius:14px;padding:10px;transition:transform .2s,border-color .2s;position:relative}.kartu-menu:hover{border-color:var(--merah);transform:translateY(-3px)}.kartu-menu.dipilih{border-color:var(--merah);background-color:#fff8f8}.kartu-menu.tidak-tersedia{opacity:.6}.badge-promo{background-color:var(--oranye);width:26px;height:26px;color:var(--putih);border-radius:50%;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:8px;left:8px}.kartu-gambar{background-color:var(--abu-terang);aspect-ratio:1;border-radius:10px;justify-content:center;align-items:center;width:100%;margin-bottom:8px;font-size:2.5rem;display:flex;overflow:hidden}.kartu-nama{color:var(--hitam);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-bottom:4px;font-size:.78rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.kartu-harga{color:var(--merah);font-size:.82rem;font-weight:700}.kartu-harga-coret{color:var(--abu);font-size:.68rem;text-decoration:line-through;display:block}.overlay-habis{color:#fff;background:#00000073;border-radius:14px;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex;position:absolute;inset:0}.menu-kosong{text-align:center;color:var(--abu);grid-column:1/-1;padding:40px}.panel-keranjang{background-color:var(--putih);width:320px;right:0;top:var(--header-h);height:calc(100vh - var(--header-h));z-index:100;flex-direction:column;flex-shrink:0;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;transform:translate(100%);box-shadow:-4px 0 15px #0000001a}.panel-keranjang.buka{transform:translate(0)}.overlay-keranjang{z-index:90;opacity:0;visibility:hidden;inset:0;top:var(--header-h);background:#0006;transition:all .3s;position:fixed}.overlay-keranjang.buka{opacity:1;visibility:visible}.keranjang-header{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:14px;display:flex}.keranjang-header-kiri{align-items:center;gap:8px;display:flex}.keranjang-ikon{background-color:var(--merah);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.1rem;display:flex}.keranjang-judul{font-size:.82rem;font-weight:700}.keranjang-nomor{color:var(--abu);font-size:.68rem}.tombol-hapus-semua{cursor:pointer;background:0 0;border:none;font-size:1rem}.keranjang-isi{flex-direction:column;flex:1;gap:8px;padding:8px;display:flex;overflow-y:auto}.keranjang-kosong{text-align:center;color:var(--abu);padding:20px;font-size:.82rem}.item-keranjang{background-color:var(--putih);border:1px solid #ffab91;border-left:6px solid var(--oranye);border-radius:12px;align-items:center;gap:12px;padding:12px;display:flex;box-shadow:0 2px 4px #0000000d}.item-keranjang-gambar{background-color:var(--abu-terang);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex;overflow:hidden}.item-keranjang-info{flex:1;min-width:0}.item-keranjang-nama{white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:700;overflow:hidden}.item-keranjang-harga{color:var(--abu-gelap);font-size:.72rem}.tombol-jumlah{background-color:var(--merah);width:26px;height:26px;color:var(--putih);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.angka-jumlah{text-align:center;width:18px;font-size:.8rem;font-weight:700}.footer-keranjang{background-color:var(--merah);border-radius:16px;flex-shrink:0;justify-content:space-between;align-items:center;margin:12px;padding:14px 16px;display:flex}.footer-info{flex-direction:column;display:flex}.footer-jumlah{color:#fffc;font-size:.72rem;display:block}.footer-total{color:var(--putih);font-size:1.1rem;font-weight:700}.tombol-order{background-color:var(--putih);color:var(--merah);cursor:pointer;white-space:nowrap;border:none;border-radius:20px;height:42px;padding:0 18px;font-family:Poppins;font-size:.95rem;font-weight:700;box-shadow:0 3px 10px #0000001a}.overlay-modal{z-index:200;background-color:#00000080;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-metode{background-color:var(--putih);text-align:center;border-radius:20px;width:420px;max-width:100%;padding:28px 24px;position:relative;box-shadow:0 20px 60px #00000040}.modal-tutup{background-color:var(--merah);color:#fff;cursor:pointer;border:none;border-radius:50%;width:28px;height:28px;font-size:1rem;position:absolute;top:14px;right:14px}.modal-judul{color:var(--merah);margin-bottom:20px;font-size:1.2rem;font-weight:700}.modal-form{text-align:left}.form-grup{text-align:left;flex-direction:column;gap:4px;margin-bottom:12px;display:flex}.form-label{color:var(--hitam);font-size:.82rem;font-weight:600}.form-input{border:1.5px solid #e0e0e0;border-radius:10px;outline:none;width:100%;padding:11px 14px;font-family:Poppins;font-size:.9rem}.form-input:focus{border-color:var(--merah);box-shadow:0 0 0 3px #e539351a}.modal-pilihan{justify-content:center;gap:16px;margin-top:20px;display:flex}.pilihan-metode{background:var(--putih);cursor:pointer;border:2px solid #e0e0e0;border-radius:16px;width:130px;padding:16px;font-family:Poppins;transition:all .2s}.pilihan-metode:hover{border-color:var(--merah)}.pilihan-metode.aktif{border-color:var(--merah);background-color:var(--merah-muda)}.pilihan-ikon{margin-bottom:8px;font-size:2rem;display:block}.pilihan-label{font-size:.82rem;font-weight:600}.modal-success{padding:40px 24px;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.halaman-login{background-color:var(--merah);background-image:radial-gradient(circle,#ffffff1a 1px,#0000 1px);background-size:24px 24px;justify-content:center;align-items:center;width:100vw;height:100vh;padding:16px;display:flex}.login-container{background-color:var(--putih);border-radius:24px;width:420px;max-width:100%;padding:40px;animation:.4s slideUp;box-shadow:0 24px 60px #0003}.login-header{text-align:center;margin-bottom:28px}.login-logo{object-fit:cover;border-radius:50%;width:80px;height:80px;margin-bottom:16px}.login-header h2{color:var(--hitam);margin-bottom:8px;font-size:1.5rem;font-weight:700}.login-header p{color:var(--abu);font-size:.9rem}.login-form{flex-direction:column;gap:16px;display:flex}.login-form .form-grup{margin-bottom:0}.login-form label{color:var(--hitam);margin-bottom:4px;font-size:.85rem;font-weight:600;display:block}.tombol-login{background-color:var(--merah);color:var(--putih);cursor:pointer;border:none;border-radius:12px;width:100%;margin-top:8px;padding:13px;font-family:Poppins;font-size:1rem;font-weight:700;transition:background-color .2s}.tombol-login:hover{background-color:var(--merah-gelap)}.tombol-google{background-color:var(--putih);color:#444;cursor:pointer;border:1px solid #ddd;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;padding:12px;font-family:Poppins;font-size:.9rem;font-weight:600;transition:background-color .2s;display:flex}.tombol-google:hover{background-color:#f8f8f8}.user-badge-floating{z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fffffff2;border:1px solid #e5393533;border-radius:20px;align-items:center;gap:15px;padding:12px 20px;display:flex;position:absolute;top:20px;right:20px;box-shadow:0 8px 32px #0000001a}.badge-info{flex-direction:column;gap:2px;display:flex}.badge-name{color:var(--hitam);font-size:.9rem;font-weight:700}.badge-points{color:var(--merah);font-size:.85rem}.badge-code{color:#666;background:#f1f1f1;border-radius:4px;margin-top:4px;padding:2px 8px;font-size:.75rem}.btn-logout-small{cursor:pointer;color:#666;background-color:#eee;border:none;border-radius:10px;padding:6px 12px;font-family:Poppins;font-size:.75rem}.btn-logout-small:hover{background-color:#ddd}.modal-profil{background:#fff;border-radius:24px;width:420px;max-width:100%;max-height:90vh;padding:32px;animation:.3s ease-out slideUp;position:relative;overflow-y:auto}.profil-header{text-align:center;margin-bottom:24px}.profil-avatar{border:4px solid var(--putih);background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 12px;font-size:2.5rem;display:flex;box-shadow:0 4px 10px #0000001a}.status-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:4px 12px;font-size:.7rem;font-weight:700}.status-badge.member{background:var(--merah-muda);color:var(--merah)}.status-badge.admin{color:#0369a1;background:#e0f2fe}.profil-body{flex-direction:column;gap:16px;display:flex}.profil-info-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.info-item{background:#f8fafc;border-radius:12px;padding:12px}.info-item label{color:#64748b;margin-bottom:4px;font-size:.7rem;font-weight:600;display:block}.info-item p{color:#1e293b;word-break:break-all;margin:0;font-size:.95rem;font-weight:700}.admin-expl{background:#f0f9ff;border-left:4px solid #0ea5e9;border-radius:16px;padding:16px}.admin-expl h4{margin:0 0 8px;font-size:1rem}.admin-expl p{color:#334155;margin:0;font-size:.85rem;line-height:1.5}.profil-footer{margin-top:24px}.btn-logout-full{color:#ef4444;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:12px;width:100%;padding:14px;font-family:Poppins;font-size:.95rem;font-weight:700;transition:all .2s}.btn-logout-full:hover{background:#fef2f2;border-color:#fee2e2}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.admin-layout{color:#1e293b;background-color:#f8fafc;height:100vh;display:flex;overflow:hidden}.admin-sidebar{background-color:#fff;border-right:1px solid #f1f5f9;flex-direction:column;flex-shrink:0;gap:24px;width:260px;padding:24px 16px;transition:transform .3s;display:flex;overflow-y:auto;box-shadow:4px 0 24px #0000000a}.admin-logo h2{color:var(--hitam);letter-spacing:-.5px;font-size:1.4rem;font-weight:800}.admin-logo h2 span{color:var(--merah)}.admin-nav{flex-direction:column;flex:1;gap:8px;list-style:none;display:flex}.admin-nav li{color:#64748b;cursor:pointer;border-radius:12px;align-items:center;gap:10px;padding:12px 16px;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.admin-nav li:hover{color:var(--hitam);background-color:#f1f5f9}.admin-nav li.aktif{background-color:var(--merah);color:#fff;box-shadow:0 4px 12px #e5393540}.admin-main{background-color:#f8fafc;flex:1;min-width:0;overflow-y:auto}.admin-header{z-index:50;background:#fff;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:16px;padding:20px 28px;display:flex;position:sticky;top:0}.admin-header-left{align-items:center;gap:12px;min-width:0;display:flex}.header-info{min-width:0}.header-info h1{color:#0f172a;font-size:1.4rem;font-weight:800}.header-info p{color:#64748b;margin-top:2px;font-size:.85rem}.btn-refresh{cursor:pointer;color:#475569;white-space:nowrap;background:#f1f5f9;border:none;border-radius:10px;padding:10px 18px;font-family:Poppins;font-weight:600;transition:all .2s}.btn-refresh:hover{background:#e2e8f0}.btn-hamburger{cursor:pointer;color:#475569;background:0 0;border:none;border-radius:8px;flex-shrink:0;padding:4px 6px;font-size:1.4rem;display:none}.btn-hamburger:hover{background:#f1f5f9}.admin-sidebar-overlay{z-index:150;background:#00000073;display:none;position:fixed;inset:0}.admin-sidebar-overlay.terbuka{display:block}.admin-content{max-width:1400px;margin:0 auto;padding:28px}.admin-metrics{grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px;display:grid}.metric-card.premium{background:#fff;border:1px solid #f1f5f9;border-radius:20px;align-items:center;gap:16px;padding:24px;display:flex;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008}.metric-icon{background:#fef2f2;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.6rem;display:flex}.metric-body{min-width:0}.metric-body h3{color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:.8rem}.metric-value{color:#0f172a;word-break:break-all;font-size:1.5rem;font-weight:800;line-height:1}.metric-trend{color:#94a3b8;margin-top:8px;font-size:.72rem;font-weight:600;display:block}.metric-trend.up{color:#10b981}.dashboard-grid{grid-template-columns:1.5fr 1fr;gap:20px;margin-bottom:28px;display:grid}.admin-section{background:#fff;border:1px solid #f1f5f9;border-radius:20px;padding:24px;box-shadow:0 4px 6px -1px #00000005}.admin-section h2{color:#0f172a;margin-bottom:20px;font-size:1rem;font-weight:700}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.section-header h2{margin-bottom:0}.simple-bar-chart{justify-content:space-between;align-items:flex-end;gap:12px;height:200px;padding:10px 0;display:flex}.bar-item{flex-direction:column;flex:1;align-items:center;gap:10px;display:flex}.bar-wrapper{background:#f1f5f9;border-radius:6px;align-items:flex-end;width:100%;max-width:40px;height:150px;display:flex;position:relative}.bar-fill{background:linear-gradient(to top, var(--merah), #f87171);cursor:pointer;border-radius:6px;width:100%;transition:height .6s cubic-bezier(.4,0,.2,1);position:relative}.bar-fill:hover{filter:brightness(1.1)}.bar-tooltip{color:#fff;white-space:nowrap;opacity:0;pointer-events:none;background:#1e293b;border-radius:6px;padding:4px 8px;font-size:.7rem;transition:all .2s;position:absolute;top:-35px;left:50%;transform:translate(-50%)}.bar-fill:hover .bar-tooltip{opacity:1;top:-40px}.bar-label{color:#64748b;font-size:.72rem;font-weight:600}.top-products-list{flex-direction:column;gap:16px;display:flex}.top-product-item{grid-template-columns:36px 1fr auto;align-items:center;gap:10px;display:grid}.top-product-item .rank{background:#f1f5f9;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;font-weight:700;display:flex}.top-product-item .name{font-size:.88rem;font-weight:600}.top-product-item .count{color:var(--merah);font-size:.82rem;font-weight:700}.progress-bar{background:#f1f5f9;border-radius:10px;grid-column:2/4;height:6px;overflow:hidden}.progress-fill{background:var(--merah);border-radius:10px;height:100%}.table-wrapper{-webkit-overflow-scrolling:touch;border-radius:12px;overflow-x:auto}.admin-table{border-collapse:separate;border-spacing:0;width:100%;min-width:580px}.admin-table th{color:#64748b;text-transform:uppercase;text-align:left;white-space:nowrap;background-color:#f8fafc;border-bottom:1px solid #f1f5f9;padding:14px 16px;font-size:.72rem;font-weight:600}.admin-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:16px;transition:all .2s}.admin-table tr:hover td{background-color:#fcfcfc}.badge-metode{white-space:nowrap;border-radius:20px;align-items:center;gap:6px;padding:5px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-metode.dine_in{color:#1d4ed8;background:#eff6ff}.badge-metode.take_away{color:#c2410c;background:#fff7ed}.form-row{flex-wrap:wrap;align-items:flex-end;gap:16px;display:flex}.form-row .form-grup{flex:1;min-width:150px}.form-grup label{color:#64748b;margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.form-input-small{border:1.5px solid #e2e8f0;border-radius:10px;outline:none;width:100%;padding:8px 12px;font-family:Poppins;font-size:.85rem;transition:all .2s}.form-input-small:focus{border-color:var(--merah)}.form-input-file{width:100%;font-family:Poppins;font-size:.85rem}.checkbox-label{cursor:pointer;color:#475569;align-items:center;gap:8px;font-size:.85rem;font-weight:600;display:flex}.promo-check{justify-content:flex-start;align-items:center;padding-top:24px;flex-direction:row!important}.table-search .form-input-small{max-width:220px}.btn-primary{background:var(--merah);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:12px;height:44px;padding:0 24px;font-family:Poppins;font-weight:700;transition:all .2s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #e539354d}.btn-secondary{color:#475569;cursor:pointer;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:10px;padding:8px 16px;font-family:Poppins;font-size:.85rem;font-weight:600}.btn-outline{color:#64748b;cursor:pointer;background:0 0;border:1.5px solid #e2e8f0;border-radius:8px;padding:5px 12px;font-family:Poppins;font-size:.78rem;font-weight:600}.table-img{background:#f1f5f9;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.4rem;display:flex;overflow:hidden}.table-img img{object-fit:cover;width:100%;height:100%}.badge-category{text-transform:uppercase;color:#475569;background:#f1f5f9;border-radius:6px;padding:4px 10px;font-size:.68rem;font-weight:700}.btn-status{cursor:pointer;border:none;border-radius:6px;padding:5px 10px;font-family:Poppins;font-size:.62rem;font-weight:800}.promo-on{color:#059669;background:#ecfdf5}.promo-off{color:#94a3b8;background:#f1f5f9}.promo-tag{color:var(--merah);font-size:.78rem;font-weight:700}.btn-stock{cursor:pointer;background:0 0;border:none;font-family:Poppins;font-size:.82rem;font-weight:700}.available{color:#10b981}.empty{color:#ef4444}.btn-action-del{cursor:pointer;color:#ef4444;background:#fff1f2;border:none;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;display:flex}.btn-action-del:hover{background:#fecada}.btn-action-edit{cursor:pointer;background:#eff6ff;border:none;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;display:flex}.btn-action-save{cursor:pointer;background:#ecfdf5;border:none;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;display:flex}.btn-action-cancel{cursor:pointer;background:#fff1f2;border:none;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;display:flex}.loading-state{flex-direction:column;justify-content:center;align-items:center;gap:20px;height:400px;display:flex}.spinner{border:4px solid #f1f5f9;border-top:4px solid var(--merah);border-radius:50%;width:40px;height:40px;animation:1s linear infinite rotasi}@keyframes rotasi{to{transform:rotate(360deg)}}@media (width<=1024px){.grid-menu{grid-template-columns:repeat(3,1fr);gap:10px}.sidebar-kategori{width:82px;padding:10px 6px}.sidebar-ikon{font-size:1.4rem}.sidebar-label{font-size:.6rem}.btn-hamburger{display:flex}.admin-sidebar{z-index:200;width:250px;height:100vh;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:8px 0 40px #00000026}.admin-sidebar.terbuka{transform:translate(0)}.admin-content{padding:20px}.admin-header{padding:16px 20px}.header-info h1{font-size:1.2rem}.admin-metrics{grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}.dashboard-grid{grid-template-columns:1fr;gap:16px;margin-bottom:20px}.sambutan-judul{font-size:1.8rem}.logo-nama{font-size:1.6rem}.logo-lingkaran{width:120px;height:120px}.user-badge-floating{gap:10px;padding:10px 16px;top:12px;right:12px}.badge-name{font-size:.82rem}.badge-points{font-size:.78rem}}@media (width<=768px){:root{--header-h:56px}.sambutan-judul{letter-spacing:0;font-size:1.3rem}.logo-lingkaran{width:96px;height:96px}.logo-nama{font-size:1.3rem}.sambutan-petunjuk{font-size:.85rem}.header{gap:10px;padding:0 12px}.logo-teks{font-size:1.1rem}.logo-kecil{width:34px;height:34px}.form-cari,.teks-keranjang{display:none}.header-pesanan{gap:0;padding:8px 10px}.halaman-beranda{padding-bottom:calc(var(--bottom-nav-h) + var(--safe-bottom));height:100dvh}.konten-utama{height:calc(100dvh - var(--header-h) - var(--bottom-nav-h) - var(--safe-bottom));flex-direction:column}.sidebar-kategori{padding:6px 8px;padding-bottom:calc(6px + var(--safe-bottom));z-index:120;background-color:var(--putih);scrollbar-width:none;border-top:1px solid #efefef;flex-direction:row;justify-content:space-around;gap:4px;position:fixed;bottom:0;left:0;right:0;overflow:auto hidden;box-shadow:0 -3px 16px #00000014;width:100%!important;height:calc(var(--bottom-nav-h) + var(--safe-bottom))!important}.sidebar-kategori::-webkit-scrollbar{display:none}.sidebar-item{border-radius:10px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;min-width:60px;padding:4px 12px;display:flex}.sidebar-item.aktif{border-width:1.5px}.sidebar-label{margin-top:2px;font-size:.6rem}.area-menu{padding:10px 10px 4px}.judul-kategori{margin-bottom:8px;font-size:.95rem}.grid-menu{grid-template-columns:repeat(2,1fr);gap:8px}.kartu-menu{border-radius:12px;padding:8px}.kartu-gambar{border-radius:8px;font-size:2rem}.kartu-nama{font-size:.7rem}.kartu-harga{font-size:.74rem}.kartu-harga-coret{font-size:.6rem}.badge-promo{width:22px;height:22px;font-size:.58rem}.panel-keranjang{z-index:130;border-radius:24px 24px 0 0;width:100%;height:80vh;inset:auto 0 0;transform:translateY(100%);box-shadow:0 -8px 30px #00000026}.panel-keranjang.buka{transform:translateY(0)}.panel-keranjang.buka .keranjang-isi{padding-bottom:calc(8px + var(--safe-bottom))}.overlay-keranjang{z-index:125;top:0}.overlay-modal{align-items:flex-end;padding:0}.modal-metode{border-radius:24px 24px 0 0;width:100%;max-height:92vh;padding:24px 20px;overflow-y:auto}.modal-pilihan{gap:10px}.pilihan-metode{width:110px;padding:12px 8px}.pilihan-ikon{font-size:1.6rem}.modal-judul{font-size:1rem}.overlay-modal .modal-profil{border-radius:24px 24px 0 0;width:100%;max-width:100%;max-height:92vh;padding:24px 18px;overflow-y:auto}.profil-info-grid{grid-template-columns:1fr}.profil-avatar{width:68px;height:68px;font-size:2rem}.halaman-login{align-items:flex-end;padding:0}.login-container{border-radius:24px 24px 0 0;width:100%;max-height:96vh;padding:28px 20px;overflow-y:auto;box-shadow:0 -8px 40px #00000026}.login-logo{width:64px;height:64px}.login-header h2{font-size:1.25rem}.login-header p{font-size:.82rem}.user-badge-floating{top:auto;bottom:calc(var(--bottom-nav-h) + 12px);border-radius:16px;flex-direction:row;justify-content:space-between;align-items:center;gap:10px;padding:10px 14px;left:10px;right:10px}.badge-name{font-size:.78rem}.badge-points{font-size:.74rem}.btn-logout-small{padding:4px 10px;font-size:.68rem}.modal-success{padding:32px 20px}.admin-sidebar{z-index:200;width:240px;height:100vh;position:fixed;top:0;left:0;transform:translate(-100%)}.admin-sidebar.terbuka{transform:translate(0);box-shadow:8px 0 40px #0003}.btn-hamburger{display:flex}.admin-header{padding:12px 14px}.header-info h1{font-size:.95rem;line-height:1.3}.header-info p{font-size:.72rem}.btn-refresh{padding:8px 12px;font-size:.78rem}.admin-content{padding:12px}.admin-metrics{grid-template-columns:1fr;gap:10px;margin-bottom:14px}.metric-card.premium{gap:12px;padding:16px}.metric-icon{border-radius:12px;width:46px;height:46px;font-size:1.3rem}.metric-value{font-size:1.25rem}.metric-body h3{font-size:.72rem}.dashboard-grid{grid-template-columns:1fr;gap:12px;margin-bottom:12px}.admin-section{border-radius:16px;padding:14px}.admin-section h2{margin-bottom:12px;font-size:.88rem}.form-row{flex-direction:column;gap:10px}.form-row .form-grup{min-width:100%}.promo-check{padding-top:0}.btn-primary{width:100%;height:42px}.admin-table{min-width:500px}.admin-table th,.admin-table td{padding:10px 12px}.simple-bar-chart{gap:5px;height:140px}.bar-wrapper{height:100px}.bar-label{font-size:.65rem}}@media (width<=480px){.grid-menu{gap:6px}.kartu-menu{padding:7px}.kartu-gambar{font-size:1.8rem}.kartu-nama{font-size:.66rem}.kartu-harga{font-size:.7rem}.logo-teks{font-size:1rem}.judul-kategori{font-size:.88rem}.footer-keranjang{margin:8px;padding:12px}.tombol-order{height:40px;padding:0 14px;font-size:.85rem}.admin-metrics{grid-template-columns:1fr}}.layar-sukses{z-index:999;background:linear-gradient(160deg,#e53935 0%,#b71c1c 50%,#880e0e 100%);flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0;overflow:hidden}.sukses-lingkaran-1{background:#ffffff0d;border-radius:50%;width:300px;height:300px;position:absolute;top:-80px;left:-80px}.sukses-lingkaran-2{background:#ffffff0a;border-radius:50%;width:350px;height:350px;position:absolute;bottom:-100px;right:-60px}.sukses-lingkaran-3{background:#ffffff0d;border-radius:50%;width:180px;height:180px;position:absolute;top:30%;right:-40px}@keyframes successPop{0%{opacity:0;transform:scale(0)rotate(-10deg)}60%{opacity:1;transform:scale(1.15)rotate(3deg)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.sukses-ikon{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:3px solid #ffffff4d;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;margin-bottom:28px;font-size:4rem;animation:.6s cubic-bezier(.34,1.56,.64,1) forwards successPop,3s ease-in-out .6s infinite float;display:flex;box-shadow:0 20px 60px #0003}.sukses-kartu{-webkit-backdrop-filter:blur(20px);text-align:center;background:#ffffff1f;border:1px solid #ffffff40;border-radius:28px;width:100%;max-width:420px;padding:28px 32px;animation:.5s .3s both fadeSlideUp;box-shadow:0 20px 60px #0003}.sukses-judul{color:#fff;fontSize:1.8rem;letter-spacing:-.5px;margin:0 0 6px;font-weight:800}.sukses-subjudul{color:#ffffffbf;margin:0 0 24px;font-size:.95rem}.sukses-detail-container{flex-direction:column;gap:10px;margin-bottom:22px;display:flex}.sukses-detail-row{background:#ffffff1a;border-radius:12px;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.sukses-detail-label{color:#ffffffa6;font-size:.82rem}.sukses-detail-val{color:#fff;font-size:.88rem;font-weight:700}.sukses-detail-val-mono{color:#fff;letter-spacing:.5px;font-family:monospace;font-size:.78rem;font-weight:700}.sukses-total-box{background:#fff3;border:1px solid #ffffff4d;border-radius:16px;padding:16px}.sukses-total-label{color:#ffffffb3;margin:0 0 4px;font-size:.78rem}.sukses-total-val{color:#fff;letter-spacing:-1px;margin:0;font-size:2rem;font-weight:800}.sukses-petunjuk-bawah{color:#ffffff8c;text-align:center;margin-top:24px;font-size:.88rem;animation:.5s .6s both fadeSlideUp}.sukses-petunjuk-bawah.cash{color:#ffd54f;font-weight:700}.modal-error-overlay{z-index:9999;-webkit-backdrop-filter:blur(8px);background:#0006;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-error-content{text-align:center;background:#fff;border:1px solid #ffebee;border-radius:24px;width:100%;max-width:380px;padding:32px 24px;animation:.3s cubic-bezier(.34,1.56,.64,1) forwards modalDropIn;position:relative;box-shadow:0 24px 60px #0003}.modal-error-icon{color:#e53935;background:#ffebee;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 20px;font-size:2.5rem;display:flex;box-shadow:0 8px 24px #e5393526}.modal-error-title{color:#b71c1c;letter-spacing:-.3px;margin:0 0 10px;font-size:1.25rem;font-weight:800}.modal-error-desc{color:#616161;margin:0 0 24px;font-size:.9rem;line-height:1.5}.btn-error-tutup{color:#fff;cursor:pointer;background:linear-gradient(135deg,#e53935 0%,#c62828 100%);border:none;border-radius:16px;width:100%;padding:14px;font-family:Poppins,sans-serif;font-size:.95rem;font-weight:700;transition:all .2s;box-shadow:0 8px 20px #e5393540}.btn-error-tutup:hover{transform:translateY(-2px)}
