@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font:"Inter", -apple-system, sans-serif;--bg:#f0f4f8;--surface:#fff;--surface-2:#f8fafc;--surface-3:#eef2f7;--border:#e2e8f0;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014, 0 2px 6px #0000000d;--shadow-lg:0 8px 24px #0000001a, 0 4px 10px #0000000f;--text:#1e293b;--text-2:#475569;--text-3:#94a3b8;--primary:#ea580c;--primary-hover:#c2410c;--primary-light:#fff7ed;--primary-ring:#ea580c26;--success:#16a34a;--success-hover:#15803d;--success-light:#f0fdf4;--danger:#dc2626;--danger-light:#fef2f2;--warning:#d97706;--warning-light:#fffbeb;--info:#2563eb;--info-light:#eff6ff;--dinein:#2563eb;--dinein-bg:#eff6ff;--takeaway:#ea580c;--takeaway-bg:#fff7ed;--delivery:#7c3aed;--delivery-bg:#f5f3ff;--qsr:#0891b2;--qsr-bg:#ecfeff;--nav-bg:#fff;--nav-border:#e2e8f0;--nav-text:#1e293b;--nav-link-hover-bg:#f0f4f8;--nav-link-active-bg:#fff7ed;--nav-link-active-txt:#ea580c;--nav-shadow:0 1px 4px #0000000f;--sidebar-bg:#1a2332;--sidebar-border:#ffffff12;--sidebar-text:#cbd5e1;--sidebar-text-2:#64748b;--sidebar-active-bg:#f9731626;--sidebar-active-text:#f97316;--sidebar-hover-bg:#ffffff0d;--sidebar-section-txt:#475569;--cat-bg:#fff;--cat-border:#e2e8f0;--cat-item-hover:#f0f4f8;--cat-item-active:#fff7ed;--cat-item-active-txt:#ea580c;--cat-count-bg:#f0f4f8;--cat-count-txt:#64748b;--cart-bg:#fff;--cart-items-bg:#f8fafc;--radius:10px;--radius-sm:6px;--radius-lg:14px;--white:#fff;--text-secondary:var(--text-2);--text-muted:var(--text-3);--input-bg:var(--surface-2);--card-bg:var(--surface);--modal-bg:var(--surface);--overlay-item:var(--surface-2)}[data-theme=dark]{--bg:#0f172a;--surface:#1e293b;--surface-2:#1a2744;--surface-3:#243047;--border:#ffffff14;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--text:#f1f5f9;--text-2:#94a3b8;--text-3:#475569;--primary-light:#ea580c26;--primary-ring:#ea580c40;--success-light:#16a34a1f;--danger-light:#dc26261f;--warning-light:#d977061f;--info-light:#2563eb1f;--dinein-bg:#2563eb26;--takeaway-bg:#ea580c26;--delivery-bg:#7c3aed26;--qsr-bg:#0891b226;--nav-bg:#1e293b;--nav-border:#ffffff14;--nav-text:#f1f5f9;--nav-link-hover-bg:#ffffff0d;--nav-link-active-bg:#f9731626;--nav-link-active-txt:#f97316;--nav-shadow:0 1px 6px #0006;--sidebar-bg:#ffffff08;--sidebar-border:#ffffff0f;--white:#1e293b;--text-secondary:var(--text-2);--text-muted:var(--text-3);--input-bg:var(--surface-2);--card-bg:var(--surface);--modal-bg:var(--surface);--overlay-item:var(--surface-2);--cat-bg:#1e293b;--cat-border:#ffffff14;--cat-item-hover:#ffffff0d;--cat-item-active:#f9731626;--cat-item-active-txt:#f97316;--cat-count-bg:#ffffff14;--cat-count-txt:#94a3b8;--cart-bg:#1e293b;--cart-items-bg:#172030}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;transition:background .2s,color .2s}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}.topnav{background:var(--nav-bg);border-bottom:1px solid var(--nav-border);height:56px;box-shadow:var(--nav-shadow);z-index:50;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 20px;transition:background .2s,border-color .2s;display:flex}.topnav-brand{align-items:center;gap:10px;display:flex}.topnav-logo{color:#fff;background:linear-gradient(135deg,#ea580c,#f97316);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:17px;font-weight:800;display:flex;box-shadow:0 2px 8px #ea580c59}.topnav-title{color:var(--nav-text);letter-spacing:-.5px;font-size:19px;font-weight:800}.topnav-links{gap:2px;display:flex}.topnav-link{border-radius:var(--radius-sm);color:var(--text-2);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font);background:0 0;border:none;align-items:center;gap:5px;padding:7px 13px;text-decoration:none;transition:all .15s;display:flex}.topnav-link:hover{background:var(--nav-link-hover-bg);color:var(--nav-text)}.topnav-link.active{background:var(--nav-link-active-bg);color:var(--nav-link-active-txt)}.topnav-right{align-items:center;gap:10px;display:flex}.topnav-user-info{text-align:right}.topnav-user-name{color:var(--nav-text);font-size:13px;font-weight:700}.topnav-user-role{color:var(--text-3);text-transform:capitalize;font-size:11px}.theme-toggle{border:1px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text-2);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:17px;transition:all .2s;display:flex}.theme-toggle:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.pos-layout{background:var(--bg);height:calc(100vh - 56px);display:flex;overflow:hidden}.pos-cat-sidebar{background:var(--cat-bg);border-right:1px solid var(--cat-border);flex-direction:column;flex-shrink:0;width:196px;transition:background .2s;display:flex;box-shadow:2px 0 8px #0000000a}.pos-cat-header{letter-spacing:.07em;color:var(--text-3);text-transform:uppercase;border-bottom:1px solid var(--cat-border);flex-shrink:0;padding:14px 14px 10px;font-size:11px;font-weight:700}.pos-cat-search{border-bottom:1px solid var(--cat-border);flex-shrink:0;align-items:center;gap:7px;padding:10px 12px;display:flex}.pos-cat-search input{font-size:13px;font-family:var(--font);color:var(--text);background:0 0;border:none;outline:none;flex:1}.pos-cat-search input::placeholder{color:var(--text-3)}.pos-cat-search svg{color:var(--text-3);flex-shrink:0}.pos-cat-list{flex:1;padding:8px;overflow-y:auto}.pos-cat-item{cursor:pointer;color:var(--text-2);border-radius:7px;justify-content:space-between;align-items:center;margin-bottom:2px;padding:9px 10px;transition:all .15s;display:flex}.pos-cat-item:hover{background:var(--cat-item-hover);color:var(--text)}.pos-cat-item.active{background:var(--cat-item-active);color:var(--cat-item-active-txt);font-weight:600}.pos-cat-name{font-size:13px;line-height:1.2}.pos-cat-count{background:var(--cat-count-bg);color:var(--cat-count-txt);border-radius:10px;flex-shrink:0;margin-left:4px;padding:2px 7px;font-size:10px;font-weight:700}.pos-cat-item.active .pos-cat-count{background:var(--primary);color:#fff}.pos-main{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.pos-order-bar{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:10px 16px;transition:background .2s;display:flex}.pos-context-badges{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.pos-items-scroll{flex:1;padding:14px 16px 20px;overflow-y:auto}.pos-cat-section{margin-bottom:22px}.pos-cat-section-header{color:var(--text-2);border-bottom:2px solid var(--border);background:var(--bg);z-index:5;align-items:center;gap:8px;margin-bottom:10px;padding:6px 0;font-size:13px;font-weight:700;transition:background .2s;display:flex;position:sticky;top:-14px}.order-types{flex-wrap:wrap;gap:5px;display:flex}.order-type-btn{border-radius:var(--radius-sm);border:1.5px solid var(--border);cursor:pointer;background:var(--surface);color:var(--text-2);font-size:12px;font-weight:600;font-family:var(--font);align-items:center;gap:5px;padding:7px 15px;transition:all .15s;display:flex}.order-type-btn:hover{border-color:var(--text-3);color:var(--text)}.order-type-btn.active-dinein{background:var(--dinein-bg);color:var(--dinein);border-color:var(--dinein)}.order-type-btn.active-takeaway{background:var(--takeaway-bg);color:var(--takeaway);border-color:var(--takeaway)}.order-type-btn.active-delivery{background:var(--delivery-bg);color:var(--delivery);border-color:var(--delivery)}.order-type-btn.active-qsr{background:var(--qsr-bg);color:var(--qsr);border-color:var(--qsr)}.items-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:10px;display:grid}.item-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;flex-direction:column;min-height:105px;padding:11px 12px 10px;transition:all .18s;display:flex;position:relative}.item-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.item-card:active{transform:scale(.97)}.item-card.in-cart{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 2px var(--primary-ring)}.item-veg-dot{border:2px solid;border-radius:3px;flex-shrink:0;width:12px;height:12px;margin-bottom:7px}.item-veg-dot[data-veg=true]{background:#16a34a;border-color:#16a34a}.item-veg-dot[data-veg=false]{background:#dc2626;border-color:#dc2626}.item-card-body{flex:1}.item-name{color:var(--text);font-size:13px;font-weight:600;line-height:1.3}.item-desc{color:var(--text-3);margin-top:3px;font-size:10px;line-height:1.35}.item-bottom{justify-content:space-between;align-items:flex-end;margin-top:8px;display:flex}.item-price{color:var(--primary);font-size:15px;font-weight:800}.item-options-badge{color:var(--primary);background:var(--primary-light);border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600}.item-card .cart-qty{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:flex;position:absolute;top:-7px;right:-7px;box-shadow:0 2px 6px #ea580c66}.category-badge{background:var(--primary-light);color:var(--primary);border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.pos-cart{background:var(--cart-bg);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:370px;transition:background .2s;display:flex;box-shadow:-2px 0 12px #0000000d}.cart-header{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;padding:13px 16px;display:flex}.cart-header h2{color:var(--text);font-size:15px;font-weight:700}.cart-context{border-bottom:1px solid var(--border);background:var(--surface-2);flex-wrap:wrap;gap:5px;padding:7px 14px;display:flex}.ctx-badge{background:var(--surface-3);color:var(--text-2);border:1px solid var(--border);border-radius:4px;padding:3px 9px;font-size:11px;font-weight:600}.cart-items{background:var(--cart-items-bg);flex:1;padding:8px 10px;overflow-y:auto}.cart-empty{height:100%;color:var(--text-3);flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.cart-empty svg{opacity:.15}.cart-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);margin-bottom:7px;padding:10px 11px}.cart-item-void{opacity:.45}.cart-item-top{justify-content:space-between;align-items:flex-start;margin-bottom:7px;display:flex}.cart-item-name{color:var(--text);flex:1;font-size:13px;font-weight:600}.cart-item-total{color:var(--text);white-space:nowrap;margin-left:10px;font-size:13px;font-weight:700}.cart-item-bottom{justify-content:space-between;align-items:center;display:flex}.cart-item-unit{color:var(--text-3);font-size:11px}.qty-control{border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;display:flex;overflow:hidden}.qty-btn{cursor:pointer;border:none;justify-content:center;align-items:center;width:28px;height:26px;font-size:15px;transition:all .15s;display:flex}.qty-btn-minus{background:var(--surface-3);color:var(--text-2)}.qty-btn-minus:hover{background:var(--border)}.qty-btn-plus{background:var(--primary);color:#fff}.qty-btn-plus:hover{background:var(--primary-hover)}.qty-value{text-align:center;background:var(--surface);width:30px;color:var(--text);font-size:12px;font-weight:700}.cart-item-remove{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:4px;margin-left:6px;padding:2px;transition:all .15s}.cart-item-remove:hover{color:var(--danger);background:var(--danger-light)}.cart-footer{border-top:1px solid var(--border);background:var(--surface);padding:12px 16px;box-shadow:0 -4px 12px #0000000a}.cart-row{color:var(--text-2);justify-content:space-between;margin-bottom:5px;font-size:12px;display:flex}.cart-divider{border:none;border-top:1px dashed var(--border);margin:8px 0}.cart-total-row{justify-content:space-between;align-items:baseline;margin-bottom:12px;display:flex}.cart-total-label{color:var(--text);font-size:14px;font-weight:600}.cart-total-value{color:var(--text);font-size:24px;font-weight:800}.pay-btn{border-radius:var(--radius);color:#fff;cursor:pointer;width:100%;font-size:14px;font-weight:700;font-family:var(--font);background:linear-gradient(135deg,#16a34a,#22c55e);border:none;justify-content:center;align-items:center;gap:8px;padding:13px;transition:all .2s;display:flex;box-shadow:0 4px 12px #16a34a4d}.pay-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #16a34a66}.pay-btn:active{transform:scale(.98)}.pay-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.selection-badge{cursor:pointer;border-radius:20px;align-items:center;gap:5px;padding:5px 11px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.table-badge{background:var(--info-light);color:var(--info);border:1px solid #2563eb40}.guest-badge{background:var(--success-light);color:var(--success);border:1px solid #16a34a40}.badge-close{width:16px;height:16px;color:inherit;cursor:pointer;background:#0000001a;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:13px;line-height:1;display:flex}.badge-close:hover{background:#0003}.guest-add-btn{border:1.5px dashed var(--border);color:var(--text-3);cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font);background:0 0;border-radius:20px;padding:5px 13px;transition:all .15s}.guest-add-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;background:#00000080;justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);flex-direction:column;width:90%;max-width:480px;max-height:88vh;animation:.2s ease-out modalSlide;display:flex;overflow:hidden}.modal-lg{max-width:720px}@keyframes modalSlide{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h2{color:var(--text);margin:0;font-size:16px;font-weight:700}.modal-close{background:var(--surface-3);cursor:pointer;width:30px;height:30px;color:var(--text-2);border:none;border-radius:7px;justify-content:center;align-items:center;font-size:18px;transition:all .15s;display:flex}.modal-close:hover{background:var(--danger-light);color:var(--danger)}.modal-tabs{border-bottom:1px solid var(--border);background:var(--surface-2);flex-shrink:0;gap:4px;padding:10px 16px;display:flex;overflow-x:auto}.modal-tab{cursor:pointer;background:var(--surface-3);color:var(--text-2);white-space:nowrap;font-size:12px;font-weight:600;font-family:var(--font);border:none;border-radius:6px;padding:6px 14px;transition:all .15s}.modal-tab.active{background:var(--primary-light);color:var(--primary)}.table-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;padding:16px;display:grid;overflow-y:auto}.table-card{border:2px solid var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--surface);padding:14px;transition:all .2s}.table-card.free{background:var(--success-light);border-color:#bbf7d0}.table-card.free:hover{box-shadow:var(--shadow-md);border-color:#16a34a;transform:translateY(-2px)}.table-card.occupied{background:var(--danger-light);cursor:not-allowed;opacity:.6;border-color:#fecaca}.table-card.selected{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 3px var(--primary-ring)}.table-number{color:var(--text);font-size:17px;font-weight:800}.table-info{color:var(--text-2);margin-top:2px;font-size:12px}.table-section{color:var(--text-3);margin-top:3px;font-size:10px;font-weight:500}.guest-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:12px;padding:11px 16px;transition:all .15s;display:flex}.guest-item:hover{background:var(--primary-light)}.guest-avatar{background:linear-gradient(135deg, var(--primary), #f97316);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.form-group{margin-bottom:14px}.form-group label{color:var(--text-2);margin-bottom:5px;font-size:13px;font-weight:600;display:block}.form-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;font-size:14px;font-family:var(--font);background:var(--surface);color:var(--text);box-sizing:border-box;outline:none;padding:9px 13px;transition:border-color .15s}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.form-input::placeholder{color:var(--text-3)}.form-group input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;font-size:14px;font-family:var(--font);background:var(--surface);color:var(--text);box-sizing:border-box;outline:none;padding:9px 13px;transition:border-color .15s}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.form-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.btn-primary{border-radius:var(--radius-sm);background:var(--primary);color:#fff;cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font);border:none;padding:9px 20px;transition:all .15s}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font);padding:9px 20px;transition:all .15s}.btn-secondary:hover{background:var(--surface-3)}.kot-layout{background:#111827;flex-direction:column;height:calc(100vh - 56px);display:flex}.kot-header{color:#fff;background:linear-gradient(135deg,#1e293b,#0f172a);border-bottom:1px solid #334155;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 24px;display:flex}.kot-title{letter-spacing:2px;text-transform:uppercase;font-size:17px;font-weight:800}.kot-status{align-items:center;gap:14px;display:flex}.kot-dot{border-radius:50%;width:10px;height:10px}.kot-dot.live{background:#22c55e;animation:2s infinite pulse;box-shadow:0 0 8px #22c55e}.kot-dot.off{background:#ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.kot-status-text{color:#94a3b8;font-size:13px;font-weight:500}.kot-clock{border-radius:var(--radius-sm);color:#e2e8f0;background:#1e293b;padding:5px 13px;font-family:monospace;font-size:13px}.kot-body{flex:1;align-items:flex-start;gap:14px;padding:18px;display:flex;overflow-x:auto}.kot-empty{color:#475569;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;height:100%;display:flex}.kot-empty h3{color:#64748b;font-size:20px;font-weight:700}.kot-ticket{width:310px;min-width:310px;box-shadow:var(--shadow-lg);background:#fff;border-radius:12px;flex-shrink:0;animation:.3s ease-out slideIn;overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.kot-ticket-header{justify-content:space-between;align-items:flex-start;padding:13px 15px;display:flex}.kot-ticket-header.dinein{background:var(--dinein-bg);border-bottom:3px solid var(--dinein)}.kot-ticket-header.takeaway{background:var(--takeaway-bg);border-bottom:3px solid var(--takeaway)}.kot-ticket-header.delivery{background:var(--delivery-bg);border-bottom:3px solid var(--delivery)}.kot-ticket-type{color:#1e293b;align-items:center;gap:7px;font-size:16px;font-weight:800;display:flex}.kot-ticket-customer{opacity:.7;color:#1e293b;margin-top:3px;font-size:12px;font-weight:500}.kot-ticket-id{text-align:right;color:#1e293b;font-size:26px;font-weight:900}.kot-ticket-time{text-align:right;color:#475569;margin-top:2px;font-size:12px;font-weight:700}.kot-ticket-body table{border-collapse:collapse;width:100%}.kot-ticket-body th{text-transform:uppercase;color:#94a3b8;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:7px 11px;font-size:10px;font-weight:700}.kot-ticket-body td{vertical-align:top;border-bottom:1px solid #f1f5f9;padding:9px 11px}.kot-ticket-body tr:last-child td{border-bottom:none}.kot-qty-badge{color:#fff;background:#1e293b;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;font-size:15px;font-weight:800;display:flex}.kot-item-name{color:#1e293b;font-size:14px;font-weight:700}.kot-ticket-footer{background:#f8fafc;border-top:1px solid #e2e8f0;padding:11px 15px}.kot-ready-btn{border-radius:var(--radius-sm);color:#fff;cursor:pointer;width:100%;font-size:14px;font-weight:700;font-family:var(--font);background:linear-gradient(135deg,#16a34a,#22c55e);border:none;justify-content:center;align-items:center;gap:8px;padding:11px;transition:all .2s;display:flex;box-shadow:0 2px 8px #16a34a4d}.kot-ready-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #16a34a66}.loading-screen{height:100%;color:var(--text-2);background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:38px;height:38px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.admin-layout{height:100vh;font-family:var(--font);display:flex;overflow:hidden}.admin-sidebar{background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);flex-direction:column;flex-shrink:0;width:220px;padding:0;transition:background .2s;display:flex}.admin-sidebar-header{border-bottom:1px solid var(--sidebar-border);align-items:center;gap:10px;padding:18px 16px 16px;display:flex}.admin-sidebar-logo{color:#fff;background:linear-gradient(135deg,#ea580c,#f97316);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:17px;font-weight:800;display:flex}.admin-sidebar-brand{color:#f8fafc;font-size:14px;font-weight:700}.admin-sidebar-role{color:#3b82f6;margin-top:1px;font-size:10px;font-weight:600}.admin-sidebar-role.superadmin{color:#ef4444}.admin-nav{flex:1;padding:10px;overflow-y:auto}.admin-nav-section-label{letter-spacing:.07em;color:var(--sidebar-section-txt);text-transform:uppercase;padding:8px 8px 4px;font-size:10px;font-weight:700}.admin-nav-link{color:var(--sidebar-text);background:0 0;border-radius:7px;align-items:center;gap:8px;margin-bottom:1px;padding:8px 10px;font-size:13px;font-weight:400;text-decoration:none;transition:all .15s;display:flex}.admin-nav-link:hover{background:var(--sidebar-hover-bg);color:#e2e8f0}.admin-nav-link.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text);font-weight:600}.admin-nav-icon{flex-shrink:0;font-size:15px}.admin-sidebar-footer{border-top:1px solid var(--sidebar-border);padding:14px 16px}.admin-sidebar-user-name{color:#cbd5e1;font-size:13px;font-weight:500}.admin-sidebar-user-role{color:#3b82f6;margin-top:2px;margin-bottom:10px;font-size:11px}.admin-signout-btn{color:#f87171;cursor:pointer;width:100%;font-size:12px;font-family:var(--font);background:#ef44441a;border:1px solid #ef444433;border-radius:6px;padding:8px;transition:all .15s}.admin-signout-btn:hover{background:#ef444433}.admin-sidebar-theme-row{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.admin-sidebar-theme-label{color:var(--sidebar-text-2);font-size:12px}.admin-main{background:var(--bg);color:var(--text);flex:1;padding:28px;transition:background .2s;overflow:auto}.search-box{align-items:center;display:flex;position:relative}.search-box input{border:1px solid var(--border);border-radius:var(--radius-sm);width:220px;font-size:13px;font-family:var(--font);background:var(--surface);color:var(--text);outline:none;padding:8px 13px 8px 36px;transition:all .2s}.search-box input:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px var(--primary-ring)}.search-box svg{color:var(--text-3);position:absolute;left:11px}.veg-badge{border:1.5px solid #16a34a;border-radius:3px;justify-content:center;align-items:center;width:15px;height:15px;display:flex}.veg-badge .dot{background:#16a34a;border-radius:50%;width:7px;height:7px}.import-modal-overlay{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);z-index:2000;background:#050810d9;justify-content:center;align-items:center;animation:.25s ease-out fadeIn;display:flex;position:fixed;inset:0}.import-modal-container{background:#12192ff2;border:1px solid #ffffff1a;border-radius:16px;flex-direction:column;width:90%;max-width:900px;max-height:85vh;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex;overflow:hidden;box-shadow:0 20px 40px #0009,0 0 30px #6366f126}.import-modal-header{background:linear-gradient(90deg,#6366f11a,#a855f71a);border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.import-modal-title{color:var(--text-primary);align-items:center;gap:10px;margin:0;font-size:1.4rem;font-weight:700;display:flex}.import-modal-close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;font-size:1.5rem;transition:all .2s;display:flex}.import-modal-close-btn:hover{color:var(--text-primary);background:#ffffff14}.import-modal-body{flex-direction:column;flex:1;gap:20px;padding:24px;display:flex;overflow-y:auto}.import-template-card{background:#ffffff08;border:1px dashed #ffffff26;border-radius:12px;justify-content:space-between;align-items:center;padding:16px 20px;transition:all .25s;display:flex}.import-template-card:hover{border-color:var(--accent-indigo);background:#6366f10a}.import-template-info{flex-direction:column;gap:4px;display:flex}.import-template-name{color:var(--text-primary);font-weight:600}.import-template-desc{color:var(--text-secondary);font-size:.85rem}.import-btn-download{color:#a5b4fc;cursor:pointer;background:#6366f126;border:1px solid #6366f14d;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.import-btn-download:hover{background:var(--accent-indigo);color:#fff;box-shadow:0 0 15px #6366f166}.import-dropzone{text-align:center;cursor:pointer;background:#ffffff03;border:2px dashed #ffffff26;border-radius:12px;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;transition:all .3s;display:flex}.import-dropzone.active{border-color:var(--accent-emerald);background:#10b9810d;box-shadow:0 0 20px #10b98126}.import-dropzone-icon{font-size:2.5rem;animation:2s infinite bounce}.import-dropzone-text{color:var(--text-primary);font-size:1.05rem;font-weight:600}.import-dropzone-subtext{color:var(--text-secondary);font-size:.85rem}.import-selected-file{background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.import-file-details{align-items:center;gap:12px;display:flex}.import-file-icon{font-size:1.8rem}.import-file-name{color:var(--text-primary);font-weight:600}.import-file-size{color:var(--text-secondary);font-size:.8rem}.import-remove-file-btn{color:#ef4444;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 12px;font-size:.9rem;font-weight:600;transition:all .2s}.import-remove-file-btn:hover{background:#ef44441a}.import-preview-container{background:#0508104d;border:1px solid #ffffff14;border-radius:8px;max-height:250px;overflow:auto}.import-preview-table{border-collapse:collapse;width:100%;font-size:.85rem}.import-preview-table th{text-align:left;color:var(--text-primary);z-index:10;background:#0b1326cc;border-bottom:1px solid #ffffff1a;padding:10px 12px;font-weight:600;position:sticky;top:0}.import-preview-table td{color:var(--text-secondary);border-bottom:1px solid #ffffff0a;padding:8px 12px}.import-preview-table tr:hover td{background:#ffffff05}.import-badge{border-radius:20px;align-items:center;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.import-badge-success{color:#34d399;background:#10b98126;border:1px solid #10b9814d}.import-badge-warning{color:#fbbf24;background:#f59e0b26;border:1px solid #f59e0b4d}.import-badge-danger{color:#f87171;background:#ef444426;border:1px solid #ef44444d}.import-console-box{color:#34d399;background:#060913;border:1px solid #ffffff14;border-radius:10px;flex-direction:column;gap:4px;height:180px;padding:16px;font-family:Courier New,Courier,monospace;font-size:.85rem;display:flex;overflow-y:auto;box-shadow:inset 0 0 10px #000c}.import-console-line{white-space:pre-wrap;line-height:1.4}.import-console-line.error{color:#f87171}.import-console-line.warn{color:#fbbf24}.import-console-line.info{color:#60a5fa}.import-console-line.success{color:#34d399}.import-progress-group{flex-direction:column;gap:8px;display:flex}.import-progress-labels{color:var(--text-primary);justify-content:space-between;font-size:.9rem;font-weight:600;display:flex}.import-progress-bg{background:#ffffff14;border-radius:10px;height:8px;overflow:hidden}.import-progress-fill{background:linear-gradient(90deg, var(--accent-indigo), var(--accent-purple));border-radius:10px;height:100%;transition:width .25s ease-out;box-shadow:0 0 10px #6366f180}.import-modal-footer{background:#0b132666;border-top:1px solid #ffffff14;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.import-btn-cancel{color:var(--text-primary);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;padding:10px 20px;font-weight:600;transition:all .2s}.import-btn-cancel:hover{background:#ffffff1a}.import-btn-submit{color:#fff;cursor:pointer;background:#f97316;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 24px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 4px 12px #f973164d}.import-btn-submit:hover:not(:disabled){background:#ea580c;transform:translateY(-1px);box-shadow:0 4px 20px #f9731680}.import-btn-submit:disabled{color:#ffffff4d;cursor:not-allowed;box-shadow:none;background:#ffffff14}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}
