:root{--primary:#0B5FFF;--primary-light:#E8F1FF;--primary-dark:#0046C5;--accent:#12B886;--accent-dark:#0F8A67;--success:#12B886;--success-light:#E8F8F2;--warning:#FFB020;--danger:#E24A3B;--danger-light:#FFE7E4;--gray-50:#F7F8FA;--gray-100:#EFF1F4;--gray-200:#E3E6EB;--gray-300:#D3D8E0;--gray-400:#B7BECA;--gray-500:#8B93A5;--gray-600:#6B7280;--gray-700:#4B5563;--gray-800:#27303F;--gray-900:#111827;--white:#FFFFFF;--gold:#D4A84B;--surface:#FFFFFF;--ink:#0F172A;--sidebar-width:240px}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Space Grotesk',-apple-system,sans-serif;background:
radial-gradient(1200px 600px at 10% -10%,rgba(11,95,255,0.12),transparent 55%),
radial-gradient(900px 500px at 90% 0%,rgba(18,184,134,0.12),transparent 55%),
var(--gray-50);color:var(--ink);font-size:14px;line-height:1.5}
h1,h2,h3,.card-title,.kpi-title{font-family:'Fraunces',serif;letter-spacing:0.2px}
::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:4px}
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:
radial-gradient(800px 400px at 15% 0%,rgba(255,255,255,0.12),transparent 60%),
linear-gradient(135deg,#0B5FFF 0%,#0B3EA8 100%);padding:20px}
.login-container{width:100%;max-width:420px;background:var(--white);border-radius:20px;padding:48px 40px;box-shadow:0 30px 80px rgba(10,20,40,0.35);border:1px solid rgba(255,255,255,0.2)}
.login-logo{text-align:center;margin-bottom:32px}
.login-logo img{width:140px;margin-bottom:16px}
.login-logo h1{font-size:24px;font-weight:700}
.login-logo p{color:var(--gray-600);font-size:14px;margin-top:4px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:13px;font-weight:500;color:var(--gray-700);margin-bottom:6px}
.input-field{width:100%;padding:12px 14px;background:var(--white);border:1px solid var(--gray-300);border-radius:10px;font-size:14px;font-family:inherit;color:var(--gray-900);transition:all 0.2s}
.input-field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(11,95,255,0.15)}
.btn{padding:12px 24px;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer;transition:all 0.2s;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none}
.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--white);box-shadow:0 10px 24px rgba(11,95,255,0.25)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 30px rgba(11,95,255,0.28)}
.btn-secondary{background:var(--white);border:1px solid var(--gray-300);color:var(--gray-800)}
.btn-secondary:hover{background:var(--gray-100)}
.btn-sm{padding:8px 16px;font-size:13px}
.btn-block{width:100%}
.btn-icon{width:36px;height:36px;padding:0}
.app-container{display:none;min-height:100vh}
.app-container.active{display:flex}
.sidebar{width:var(--sidebar-width);background:
linear-gradient(180deg,#FFFFFF 0%,#F7F9FC 100%);border-right:1px solid var(--gray-200);height:100vh;position:fixed;left:0;top:0;overflow-y:auto;z-index:100}
.sidebar-header{padding:20px;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;gap:12px}
.sidebar-header img{width:110px}
.sidebar-nav{padding:12px 0}
.nav-item{display:flex;align-items:center;gap:12px;padding:12px 20px;color:var(--gray-700);cursor:pointer;transition:all 0.2s;font-size:14px}
.nav-item:hover{background:var(--gray-100);color:var(--gray-900)}
.nav-item.active{background:linear-gradient(90deg,rgba(11,95,255,0.12),transparent);color:var(--primary);font-weight:600}
.nav-item svg{width:20px;height:20px;flex-shrink:0}
.nav-item-arrow{margin-left:auto;transition:transform 0.2s}
.nav-item.expanded .nav-item-arrow{transform:rotate(90deg)}
.nav-submenu{display:none;padding-left:32px}
.nav-submenu.show{display:block}
.nav-submenu .nav-item{font-size:13px;padding:10px 20px}
.main-content{margin-left:var(--sidebar-width);flex:1;display:flex;flex-direction:column}
.top-bar{height:64px;background:rgba(255,255,255,0.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--gray-200);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:50}
.global-search{flex:1;max-width:600px;position:relative}
.global-search input{width:100%;padding:10px 16px 10px 44px;background:var(--white);border:1px solid var(--gray-200);border-radius:999px;font-size:14px;box-shadow:0 2px 8px rgba(15,23,42,0.04)}
.global-search input:focus{outline:none;border-color:var(--primary);background:var(--white)}
.global-search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--gray-500)}
.top-bar-actions{display:flex;align-items:center;gap:12px;margin-left:auto}
.icon-btn{width:40px;height:40px;border-radius:12px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-600);position:relative;transition:all 0.2s}
.icon-btn:hover{background:var(--gray-100)}
.icon-btn svg{width:20px;height:20px}
.badge{position:absolute;top:4px;right:4px;background:var(--danger);color:white;font-size:10px;font-weight:600;min-width:16px;height:16px;border-radius:8px;display:none;align-items:center;justify-content:center}
.user-menu{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:8px;cursor:pointer;transition:all 0.2s}
.user-menu:hover{background:var(--gray-100)}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:white;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px}
.user-info{text-align:left}
.user-name{font-size:13px;font-weight:500;color:var(--gray-900)}
.user-role{font-size:11px;color:var(--gray-500)}
.content-area{flex:1;padding:28px;overflow-y:auto}
.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}
.page-header h1{font-size:26px;font-weight:700;margin-bottom:4px}
.page-header p{color:var(--gray-600);font-size:14px}
.card{background:var(--surface);border-radius:16px;border:1px solid var(--gray-200);overflow:hidden;box-shadow:0 10px 24px rgba(15,23,42,0.06)}
.card-header{padding:16px 20px;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;gap:12px}
.card-title{font-weight:600;font-size:15px}
.card-body{padding:20px}
.card-body.no-padding{padding:0}
.welcome-banner{background:
radial-gradient(400px 200px at 10% 10%,rgba(255,255,255,0.25),transparent 60%),
linear-gradient(135deg,var(--primary) 0%,#123D9D 100%);color:white;padding:32px;border-radius:18px;margin-bottom:24px;box-shadow:0 20px 40px rgba(11,95,255,0.22)}
.welcome-banner h2{font-size:24px;margin-bottom:8px}
.welcome-banner p{opacity:0.9;margin-bottom:20px}
.quick-actions{display:flex;gap:12px;flex-wrap:wrap}
.quick-action-btn{background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.3);color:white;padding:10px 20px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all 0.2s}
.quick-action-btn:hover{background:rgba(255,255,255,0.25)}
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}
.stat-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:20px}
.stat-card-title{font-size:13px;color:var(--gray-600);margin-bottom:8px}
.stat-card-value{font-size:28px;font-weight:600;color:var(--gray-900)}
.stat-card-label{font-size:12px;color:var(--gray-500);margin-top:4px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:2fr 1fr;gap:24px}
.tabs{display:flex;gap:0;border-bottom:1px solid var(--gray-200);padding:0 20px}
.tab{padding:12px 16px;font-size:13px;font-weight:500;color:var(--gray-600);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all 0.2s}
.tab:hover{color:var(--gray-900)}
.tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.filter-bar{padding:16px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--gray-200);flex-wrap:wrap}
.filter-select{padding:8px 12px;border:1px solid var(--gray-300);border-radius:6px;font-size:13px;background:var(--white)}
.filter-search{position:relative;flex:1;min-width:200px}
.filter-search input{width:100%;padding:8px 12px 8px 36px;border:1px solid var(--gray-300);border-radius:6px;font-size:13px}
.filter-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--gray-500)}
.clear-search{background:none;border:none;color:var(--primary);font-size:12px;font-weight:600;cursor:pointer;text-transform:uppercase}
.table-container{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--gray-200)}
th{background:var(--gray-50);font-weight:600;font-size:12px;text-transform:uppercase;color:var(--gray-600);letter-spacing:0.5px}
td{font-size:14px}
tr:hover{background:var(--gray-50)}
.table-link{color:var(--primary);text-decoration:none;font-weight:500}
.table-link:hover{text-decoration:underline}
.table-secondary{font-size:12px;color:var(--gray-500);margin-top:2px}
.status{display:inline-flex;align-items:center;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}
.status-shipped{background:#E8F5E9;color:#2E7D32}
.status-pending{background:#FFF3E0;color:#E65100}
.status-open{background:#FFEBEE;color:#C62828}
.status-closed{background:#E3F2FD;color:#1565C0}
.view-btn{background:none;border:none;color:var(--primary);font-size:13px;cursor:pointer;display:flex;align-items:center;gap:4px}
.view-btn:hover{text-decoration:underline}
.action-btns{display:flex;gap:8px}
.action-btn{background:none;border:none;color:var(--gray-600);font-size:13px;cursor:pointer;display:flex;align-items:center;gap:4px}
.action-btn:hover{color:var(--gray-900)}
.pagination{padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--gray-200)}
.pagination-info{font-size:13px;color:var(--gray-600)}
.pagination-buttons{display:flex;gap:8px}
.page-btn{padding:8px 14px;border:1px solid var(--gray-300);border-radius:6px;background:var(--white);font-size:13px;cursor:pointer}
.page-btn:hover:not(:disabled){background:var(--gray-50)}
.page-btn:disabled{opacity:0.5;cursor:not-allowed}
.page-btn.active{background:var(--primary);color:white;border-color:var(--primary)}
.vendors-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:16px}
.vendor-logo{height:60px;background:var(--gray-50);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--gray-600);font-size:13px}
.see-all{display:block;padding:12px 20px;text-align:center;color:var(--primary);font-size:13px;font-weight:500;border-top:1px solid var(--gray-200)}
.cart-sidebar{position:fixed;right:-400px;top:0;width:400px;height:100vh;background:var(--white);box-shadow:-4px 0 20px rgba(0,0,0,0.1);z-index:200;transition:right 0.3s;display:flex;flex-direction:column}
.cart-sidebar.open{right:0}
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.3);z-index:150;opacity:0;visibility:hidden;transition:all 0.3s}
.cart-overlay.open{opacity:1;visibility:visible}
.cart-header{padding:20px;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center}
.cart-header h3{font-size:18px}
.cart-items{flex:1;overflow-y:auto;padding:16px}
.cart-item{padding:16px;background:var(--gray-50);border-radius:8px;margin-bottom:12px}
.cart-item-header{display:flex;justify-content:space-between;margin-bottom:12px}
.cart-item-title{font-weight:500;font-size:14px}
.cart-item-meta{font-size:12px;color:var(--gray-500)}
.cart-item-controls{display:flex;justify-content:space-between;align-items:center}
.quantity-control{display:flex;align-items:center;gap:8px}
.quantity-btn{width:28px;height:28px;border:1px solid var(--gray-300);border-radius:6px;background:var(--white);cursor:pointer;font-size:16px}
.cart-item-price{text-align:right}
.cart-item-unit{font-size:12px;color:var(--gray-500)}
.cart-item-total{font-weight:600}
.cart-footer{padding:20px;border-top:1px solid var(--gray-200)}
.cart-total{display:flex;justify-content:space-between;font-size:18px;font-weight:600;margin-bottom:16px}
.modal{position:fixed;inset:0;z-index:300;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,0.5);padding:20px}
.modal.active{display:flex}
.modal-content{background:var(--white);border-radius:12px;width:100%;max-width:900px;max-height:90vh;overflow:auto}
.modal-header{padding:20px;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center}
.modal-header h3{font-size:18px}
.modal-close{width:32px;height:32px;border:none;background:var(--gray-100);border-radius:6px;cursor:pointer;font-size:18px}
.modal-body{padding:20px}
.upload-zone{border:2px dashed var(--gray-300);border-radius:12px;padding:48px;text-align:center;cursor:pointer;transition:all 0.2s}
.upload-zone:hover{border-color:var(--primary);background:var(--primary-light)}
.upload-zone input{display:none}
.upload-zone p{color:var(--gray-600);margin-top:12px}
.progress-bar{height:8px;background:var(--gray-200);border-radius:4px;margin-top:16px;overflow:hidden;display:none}
.progress-fill{height:100%;background:var(--primary);width:0;transition:width 0.3s}
.sync-indicator{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--gray-600);padding:6px 10px;border:1px solid var(--gray-200);border-radius:999px;background:var(--white)}
.sync-dot{width:8px;height:8px;border-radius:50%;background:var(--gray-400)}
.sync-indicator.syncing .sync-dot{background:var(--warning);animation:pulse 1s infinite}
.sync-indicator.success .sync-dot{background:var(--success)}
.sync-indicator.error .sync-dot{background:var(--danger)}
.sync-progress{width:120px;height:6px;background:var(--gray-200);border-radius:999px;overflow:hidden}
.sync-progress-fill{height:100%;width:0;background:var(--primary);transition:width 0.2s}
@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.25)}100%{transform:scale(1)}}
.notification{position:fixed;top:80px;right:24px;padding:16px 20px;background:var(--white);border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,0.15);display:flex;align-items:center;gap:12px;z-index:400;transform:translateX(120%);transition:transform 0.3s}
.notification.show{transform:translateX(0)}
.notification.success{border-left:4px solid var(--success)}
.notification.error{border-left:4px solid var(--danger)}
.notification.warning{border-left:4px solid var(--warning)}
.empty-state{text-align:center;padding:48px 20px}
.empty-state svg{width:64px;height:64px;color:var(--gray-300);margin-bottom:16px}
.empty-state h3{font-size:18px;margin-bottom:8px}
.empty-state p{color:var(--gray-500)}
.order-header{padding:20px;border-bottom:1px solid var(--gray-200)}
.order-header h2{font-size:20px;margin-bottom:12px}
.order-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--gray-600)}
.order-meta strong{color:var(--gray-900)}
.breadcrumb{font-size:13px;color:var(--gray-500);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.breadcrumb a{color:var(--primary);text-decoration:none}
.tracking-box{padding:20px}
.tracking-header{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--gray-200)}
.tracking-link{color:var(--primary);text-decoration:none}
.invoice-header-info{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:20px;border-bottom:1px solid var(--gray-200)}
.invoice-header-info h4{font-size:12px;color:var(--gray-500);margin-bottom:4px;text-transform:uppercase}
.invoice-header-info p{font-size:14px}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.kpi-card{background:var(--white);border:1px solid var(--gray-200);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:6px;box-shadow:0 10px 24px rgba(15,23,42,0.06);animation:fadeUp 0.6s ease both}
.kpi-title{font-size:12px;color:var(--gray-500);text-transform:uppercase;letter-spacing:0.4px}
.kpi-value{font-size:22px;font-weight:600}
.kpi-change{font-size:12px;font-weight:600}
.kpi-change.up{color:var(--success)}
.kpi-change.down{color:var(--danger)}
.chart-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin-bottom:24px}
.chart-card{background:var(--white);border:1px solid var(--gray-200);border-radius:16px;overflow:hidden;box-shadow:0 10px 24px rgba(15,23,42,0.06);animation:fadeUp 0.6s ease both}
.chart-header{padding:16px 20px;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between}
.chart-title{font-weight:600;font-size:15px}
.chart-subtitle{font-size:12px;color:var(--gray-500)}
.chart-body{padding:16px 20px}
.sparkline{width:100%;height:120px}
.sparkline .grid{stroke:var(--gray-200);stroke-width:1}
.sparkline .line{stroke:var(--primary);stroke-width:2;fill:none}
.sparkline .area{fill:rgba(0,102,204,0.12)}
.bar-chart{display:grid;gap:10px}
.bar-row{display:grid;grid-template-columns:140px 1fr 60px;align-items:center;gap:10px}
.bar-label{font-size:12px;color:var(--gray-600)}
.bar-track{height:10px;background:var(--gray-100);border-radius:999px;overflow:hidden}
.bar-fill{height:100%;border-radius:999px}
.donut{width:140px;height:140px;margin:0 auto;display:block}
.donut-label{text-align:center;margin-top:8px;font-size:12px;color:var(--gray-600)}
.mini-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-top:12px}
.mini-kpi{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:10px;padding:12px}
.mini-kpi .kpi-value{font-size:18px}
.tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;background:var(--gray-100);color:var(--gray-700)}
.tag-primary{background:var(--primary-light);color:var(--primary)}
.tag-success{background:var(--success-light);color:var(--success)}
.tag-warning{background:rgba(255,176,32,0.15);color:var(--warning)}
.tag-danger{background:var(--danger-light);color:var(--danger)}
.list-card{background:var(--white);border:1px solid var(--gray-200);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:10px;box-shadow:0 10px 24px rgba(15,23,42,0.06)}
.list-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px}
.list-card-title{font-weight:600}
.list-card-meta{font-size:12px;color:var(--gray-500)}
.info-row{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--gray-600)}
.info-row span{background:var(--gray-50);border:1px solid var(--gray-200);padding:4px 8px;border-radius:999px}
.resource-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--gray-200)}
.resource-item:last-child{border-bottom:none}
.resource-title{font-weight:600}
.resource-meta{font-size:12px;color:var(--gray-500)}
.event-card{display:flex;gap:16px;align-items:center}
.event-date{background:var(--primary-light);color:var(--primary);border-radius:12px;padding:10px 14px;text-align:center;min-width:72px}
.event-date strong{display:block;font-size:16px}
.event-date span{font-size:11px}
.card,.welcome-banner,.table-container,.filter-bar{animation:fadeUp 0.6s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:1024px){
.grid-2,.grid-3{grid-template-columns:1fr}
.sidebar{transform:translateX(-100%);transition:transform 0.3s ease}
.sidebar.open{transform:translateX(0)}
.main-content{margin-left:0}
.kpi-grid{grid-template-columns:repeat(2,1fr)}
}

/* ================================================================== */
/*  Mobile (phones)                                                     */
/* ================================================================== */
.hamburger-btn{display:none;width:40px;height:40px;border:none;background:transparent;cursor:pointer;color:var(--gray-700);border-radius:8px;align-items:center;justify-content:center;flex-shrink:0}
.hamburger-btn:hover{background:var(--gray-100)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:99;opacity:0;transition:opacity 0.3s}
.sidebar-overlay.active{display:block;opacity:1}

@media(max-width:768px){
/* Hamburger visible */
.hamburger-btn{display:flex}
/* Sidebar as drawer */
.sidebar{position:fixed;left:0;top:0;width:280px;height:100vh;z-index:100;transform:translateX(-100%);transition:transform 0.3s ease;box-shadow:none}
.sidebar.open{transform:translateX(0);box-shadow:8px 0 30px rgba(0,0,0,0.15)}
.main-content{margin-left:0}
/* Top bar */
.top-bar{padding:0 12px;gap:8px;height:56px}
.global-search{max-width:none}
.global-search input{padding:8px 12px 8px 38px;font-size:13px}
.user-info{display:none}
.user-avatar{width:34px;height:34px;font-size:14px}
.icon-btn{width:36px;height:36px}
/* Content area */
.content-area{padding:16px}
/* Page header */
.page-header{flex-direction:column;gap:12px;margin-bottom:16px}
.page-header h1{font-size:20px}
/* KPI cards */
.kpi-grid{grid-template-columns:1fr 1fr;gap:12px}
.kpi-card{padding:14px}
.kpi-value{font-size:20px}
.kpi-title{font-size:11px}
/* Stats row */
.stats-row{grid-template-columns:1fr 1fr;gap:10px}
.stat-card{padding:14px}
.stat-card-value{font-size:22px}
/* Grids */
.grid-2,.grid-3{grid-template-columns:1fr;gap:16px}
/* Cards */
.card{border-radius:12px}
.card-header{padding:12px 16px}
.card-body{padding:16px}
/* Welcome banner */
.welcome-banner{padding:20px;border-radius:14px;margin-bottom:16px}
.welcome-banner h2{font-size:18px}
.quick-actions{gap:8px}
.quick-action-btn{padding:8px 14px;font-size:12px}
/* Tables */
.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -16px;padding:0 16px}
table{min-width:600px}
th,td{padding:10px 12px;font-size:13px}
th{font-size:11px}
/* Filter bar */
.filter-bar{flex-direction:column;gap:10px;padding:12px 16px}
.filter-select{width:100%}
.filter-search{min-width:100%}
/* Pagination */
.pagination{flex-direction:column;gap:10px;padding:12px 16px}
.pagination-info{font-size:12px}
/* Modals */
.modal-content{width:95%;max-width:none;margin:8px;border-radius:12px}
/* Login */
.login-container{padding:28px 24px;max-width:100%;margin:12px;border-radius:16px}
.login-logo img{width:100px}
.login-logo h1{font-size:20px}
/* Cart sidebar */
.cart-sidebar{width:100%}
/* Checkout grid */
[style*="grid-template-columns: 1fr 350px"],
[style*="grid-template-columns:1fr 350px"]{display:flex !important;flex-direction:column !important}
/* User dropdown */
.user-dropdown{right:-12px !important;min-width:200px !important}
/* Order pipeline grid fix */
[style*="grid-template-columns:repeat(3"]{grid-template-columns:repeat(3,1fr) !important;gap:8px !important}
[style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}
/* My Profile grid */
[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important}
/* Charts */
.chart-grid{grid-template-columns:1fr}
.chart-card{margin-bottom:12px}
/* Buttons */
.btn{padding:10px 18px;font-size:13px}
.btn-sm{padding:7px 12px;font-size:12px}
}

@media(max-width:380px){
.kpi-grid,.stats-row{grid-template-columns:1fr}
.content-area{padding:12px}
.top-bar{padding:0 8px}
table{min-width:500px}
.welcome-banner h2{font-size:16px}
}

/* ================================================================== */
/*  Firebase Auth — Login Enhancements                                 */
/* ================================================================== */
.login-divider{display:flex;align-items:center;gap:16px;margin:20px 0;color:var(--gray-400);font-size:13px}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--gray-200)}
.btn-google{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:12px;background:#fff;color:#333;border:1px solid var(--gray-300);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}
.btn-google:hover{background:var(--gray-50);border-color:var(--gray-400);box-shadow:0 2px 8px rgba(0,0,0,0.08)}
.btn-google svg{flex-shrink:0}
.login-error{color:var(--danger);font-size:13px;text-align:center;margin-top:12px;min-height:20px}
.login-links{display:flex;justify-content:space-between;margin-top:16px;font-size:13px}
.login-links a{color:var(--primary);text-decoration:none;cursor:pointer}
.login-links a:hover{text-decoration:underline}
.login-badge{display:inline-flex;align-items:center;gap:6px;background:var(--primary-light);color:var(--primary);padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;margin-top:16px}
.login-badge svg{width:14px;height:14px}

/* ============================================
   O|CONNECT — Professional Modal System v2
   ============================================ */
.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(10,15,30,0.6);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.modal.active{display:flex}
@keyframes modalSlideIn{from{opacity:0;transform:translateY(-20px) scale(0.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal-content{background:#fff;border-radius:16px;width:95%;max-width:780px;max-height:90vh;overflow:hidden;box-shadow:0 25px 60px rgba(0,0,0,0.15),0 0 0 1px rgba(0,0,0,0.05);animation:modalSlideIn 0.25s ease;display:flex;flex-direction:column}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #f0f0f5;flex-shrink:0}
.modal-header h2,.modal-header h3{font-size:17px;font-weight:700;color:#0a1628;margin:0;letter-spacing:-0.2px}
.modal-close{width:32px;height:32px;border-radius:8px;border:none;background:#f4f5f7;color:#6b7280;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s;flex-shrink:0}
.modal-close:hover{background:#ef4444;color:#fff}
.modal-body{padding:24px;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}
.od-header{margin-bottom:24px}
.od-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:12px}
.od-title{font-size:20px;font-weight:800;color:#0a1628;letter-spacing:-0.3px;margin:0}
.od-status{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px}
.od-status.pending{background:#fef3c7;color:#92400e}
.od-status.confirmed{background:#dbeafe;color:#1e40af}
.od-status.processing{background:#e0e7ff;color:#3730a3}
.od-status.shipped,.od-status.delivered,.od-status.completed{background:#d1fae5;color:#065f46}
.od-status.cancelled{background:#fee2e2;color:#991b1b}
.od-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;background:#f8f9fb;border-radius:12px;padding:16px;border:1px solid #f0f0f5}
.od-info-item{display:flex;flex-direction:column;gap:4px}
.od-info-label{font-size:11px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:0.5px}
.od-info-value{font-size:14px;font-weight:600;color:#1f2937}
.od-tracking{display:inline-flex;align-items:center;gap:8px;margin-top:12px;padding:10px 16px;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #a7f3d0;border-radius:10px;font-size:13px;color:#065f46;font-weight:600}
.od-items-section{margin:24px 0}
.od-section-title{font-size:13px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:0.8px;margin-bottom:12px}
.od-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid #f0f0f5;border-radius:12px;overflow:hidden}
.od-table thead th{background:#f8f9fb;padding:12px 16px;font-size:11px;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:0.5px;text-align:left;border-bottom:1px solid #f0f0f5}
.od-table thead th.r{text-align:right}
.od-table thead th.c{text-align:center}
.od-table tbody td{padding:14px 16px;font-size:13.5px;color:#374151;border-bottom:1px solid #f8f8fa;vertical-align:middle}
.od-table tbody tr:last-child td{border-bottom:none}
.od-table tbody tr:hover{background:#fafbfc}
.od-table .prod-name{font-weight:600;color:#0a1628;display:block}
.od-table .prod-ean{font-size:11px;color:#9ca3af;margin-top:2px;display:block;font-family:'SF Mono',Consolas,monospace}
.od-table td.r{text-align:right;font-variant-numeric:tabular-nums}
.od-table td.c{text-align:center}
.od-totals{margin-top:16px;padding:16px 20px;background:#f8f9fb;border-radius:12px;border:1px solid #f0f0f5}
.od-total-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13.5px;color:#6b7280}
.od-total-row span:last-child{font-weight:600;color:#374151;font-variant-numeric:tabular-nums}
.od-total-row.grand{padding-top:12px;margin-top:8px;border-top:2px solid #e5e7eb;font-size:16px;font-weight:700;color:#0a1628}
.od-total-row.grand span:last-child{font-size:18px;font-weight:800;color:#059669}
.od-invoice{margin-top:16px;padding:14px 18px;background:linear-gradient(135deg,#eef2ff,#e8e8ff);border:1px solid #c7d2fe;border-radius:10px;font-size:13px;color:#3730a3;display:flex;align-items:center;gap:10px}
.od-history{margin-top:24px}
.od-history-title{font-size:13px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:0.8px;margin-bottom:12px}
.od-history-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f4f5f7;font-size:13px}
.od-history-item:last-child{border-bottom:none}
.od-history-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.od-history-dot.pending{background:#f59e0b}
.od-history-dot.confirmed{background:#3b82f6}
.od-history-dot.processing{background:#6366f1}
.od-history-dot.shipped,.od-history-dot.delivered,.od-history-dot.completed{background:#059669}
.od-history-dot.cancelled{background:#ef4444}
.od-history-status{font-weight:700;color:#1f2937;min-width:90px}
.od-history-date{color:#9ca3af;font-size:12px}
.od-history-by{color:#9ca3af;font-size:12px;font-style:italic}
.od-history-note{color:#6b7280;font-size:12px;font-style:italic;margin-left:auto}
.od-actions{margin-top:20px;padding-top:20px;border-top:1px solid #f0f0f5;display:flex;flex-wrap:wrap;gap:8px}
.od-action-btn{padding:8px 16px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;color:#374151;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.15s}
.od-action-btn:hover{background:#f8f9fb;border-color:#d1d5db}
.od-action-btn.primary{background:var(--primary,#6366f1);color:#fff;border-color:transparent}
.od-action-btn.primary:hover{opacity:0.9}
.od-action-btn.danger{color:#ef4444;border-color:#fecaca}
.od-action-btn.danger:hover{background:#fef2f2}
.od-edit-input{width:70px;padding:6px 8px;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;text-align:right;font-variant-numeric:tabular-nums}
.od-edit-input:focus{outline:none;border-color:var(--primary,#6366f1);box-shadow:0 0 0 3px rgba(99,102,241,0.1)}
@media(max-width:640px){.modal-content{width:100%;max-height:95vh;border-radius:12px;margin:8px}.modal-body{padding:16px}.od-info-grid{grid-template-columns:1fr 1fr}.od-table thead th,.od-table tbody td{padding:10px 12px}.od-title{font-size:17px}.od-actions{flex-direction:column}.od-action-btn{text-align:center}}
