:root{--primary: #4932BE;--primary-dark: #22007C;--primary-deep: #140152;--primary-electric: #0D00A4;--primary-light: #6B5CE7;--primary-glow: rgba(73, 50, 190, .3);--secondary: #424369;--blue-grey: #5E95D4;--purple: #730286;--accent: #D90368;--accent-dark: #B30255;--accent-light: #F23D8F;--danger: #DF3319;--warning: #F59E0B;--success: #10B981;--info: #5E95D4;--bg-dark: #0C0130;--bg-card: #110040;--bg-card-hover: #1A0065;--bg-surface: #0D003D;--bg-input: #150050;--text-primary: #F0ECEB;--text-secondary: #A8A4C8;--text-muted: #6860A0;--border: rgba(73, 50, 190, .2);--border-hover: rgba(73, 50, 190, .4);--sidebar-width: 260px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 22px;--shadow-card: 0 4px 24px rgba(0, 0, 0, .4);--shadow-glow: 0 0 24px var(--primary-glow);--shadow-soft: 0 2px 12px rgba(0, 0, 0, .2)}[data-theme=light]{--bg-dark: #EDE8F5;--bg-card: #FFFFFF;--bg-card-hover: #F3EFFC;--bg-surface: #F7F5FB;--bg-input: #F0ECF8;--text-primary: #140152;--text-secondary: #424369;--text-muted: #7A7698;--border: rgba(73, 50, 190, .12);--border-hover: rgba(73, 50, 190, .25);--primary-glow: rgba(73, 50, 190, .15);--shadow-card: 0 4px 20px rgba(73, 50, 190, .08);--shadow-glow: 0 0 20px rgba(73, 50, 190, .12);--shadow-soft: 0 2px 10px rgba(73, 50, 190, .06)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Verdana,system-ui,-apple-system,sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:32px;min-height:100vh;animation:fadeIn .3s ease}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-dark) 0%,var(--primary-deep) 40%,var(--primary-dark) 80%,var(--bg-dark) 100%);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(73,50,190,.25),transparent 70%);top:-200px;right:-200px;animation:float 6s ease-in-out infinite}.login-page:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(217,3,104,.12),transparent 70%);bottom:-100px;left:-100px;animation:float 8s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-30px)}}.login-card{background:#110040e0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-xl);padding:48px;width:100%;max-width:440px;position:relative;z-index:1;box-shadow:0 20px 60px #00000080}.login-logo{text-align:center;margin-bottom:32px}.login-logo .logo-icon{font-size:48px;display:block;margin-bottom:8px}.login-logo h1{font-size:28px;font-weight:800;letter-spacing:2px;text-transform:uppercase;background:linear-gradient(135deg,var(--primary-light),var(--blue-grey));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-logo p{color:var(--text-secondary);font-size:14px;margin-top:4px}[data-theme=light] .login-page{background:linear-gradient(135deg,#ede8f5,#d6cfef,#c9bfea 80%,#ede8f5)}[data-theme=light] .login-page:before{background:radial-gradient(circle,rgba(73,50,190,.12),transparent 70%)}[data-theme=light] .login-page:after{background:radial-gradient(circle,rgba(217,3,104,.06),transparent 70%)}[data-theme=light] .login-card{background:#ffffffeb;box-shadow:0 20px 60px #4932be1f}[data-theme=light] .login-logo h1{background:linear-gradient(135deg,var(--primary),var(--primary-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:15px;font-family:inherit;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.form-group input::placeholder{color:var(--text-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .3s ease;text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:0 4px 15px var(--primary-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--primary-glow)}.btn-primary:active{transform:scale(.97);transition:transform .1s}.btn-accent{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff}.btn-accent:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d903684d}.btn-danger{background:linear-gradient(135deg,var(--danger),#b52a14);color:#fff}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-primary)}.btn-outline:hover{background:var(--bg-card);border-color:var(--border-hover)}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.skeleton{background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-card-hover) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:skeletonPulse 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-text{height:14px;margin-bottom:8px;width:80%}.skeleton-text.short{width:40%}.skeleton-card{height:120px;border-radius:var(--radius-md)}@keyframes skeletonPulse{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:24px;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;animation:fadeInUp .4s ease both}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-glow);border-color:var(--border-hover)}.stat-card .stat-icon{font-size:28px;margin-bottom:12px}.stat-card .stat-value{font-size:32px;font-weight:800;background:linear-gradient(135deg,#FFFFFF,var(--blue-grey));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card .stat-label{font-size:13px;color:var(--text-secondary);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.data-table{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.data-table table{width:100%;border-collapse:collapse}.data-table th{background:#4932be1f;padding:14px 16px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:1px solid var(--border)}.data-table td{padding:12px 16px;font-size:14px;border-bottom:1px solid var(--border);color:var(--text-primary)}.data-table tr:hover td{background:#4932be0f}.data-table tr:last-child td{border-bottom:none}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.page-header h1{font-size:28px;font-weight:700}.page-header p{color:var(--text-secondary);margin-top:4px}.section-title{font-size:18px;font-weight:600;margin-bottom:16px}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px;margin-bottom:32px}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:24px;transition:transform .25s ease,box-shadow .25s ease;animation:fadeInUp .5s ease both}.chart-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}.chart-card h3{font-size:16px;font-weight:600;margin-bottom:16px;color:var(--text-secondary)}.scanner-container{max-width:600px;margin:0 auto}.scanner-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;text-align:center}.scanner-box video{width:100%;max-width:400px;border-radius:var(--radius-md);margin:16px 0}.scan-result{background:var(--bg-surface);border:1px solid var(--accent);border-radius:var(--radius-md);padding:20px;margin-top:20px;animation:slideUp .3s ease}.scan-result.success{border-color:var(--success)}.scan-result.error{border-color:var(--danger)}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.qr-preview{background:#fff;border-radius:var(--radius-md);padding:24px;text-align:center;display:inline-block;margin:20px 0}.qr-preview .qr-name{color:#333;font-weight:700;font-size:14px;margin-top:8px}.qr-preview .qr-company{color:#666;font-size:12px}.alert{padding:14px 18px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px;display:flex;align-items:center;gap:10px;animation:slideUp .3s ease}.alert-success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--success)}.alert-error{background:#df33191a;border:1px solid rgba(223,51,25,.3);color:var(--danger)}.alert-warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:var(--warning)}.alert-info{background:#5e95d41a;border:1px solid rgba(94,149,212,.3);color:var(--info)}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.modal h2{margin-bottom:24px;font-size:20px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes toastSlideIn{0%{opacity:0;transform:translate(80px)}to{opacity:1;transform:translate(0)}}.badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-active{background:#10b98126;color:var(--success)}.badge-inactive{background:#df331926;color:var(--danger)}.badge-vendor{background:#4932be26;color:var(--primary-light)}.badge-admin{background:#5e95d426;color:var(--info)}.badge-registrar{background:#f59e0b26;color:var(--warning)}.register-panel{max-width:800px;margin:0 auto}.register-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px}html{-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch}input,select,textarea{font-size:16px!important}.main-content{padding-bottom:env(safe-area-inset-bottom,16px)}@media(max-width:768px){.main-content{margin-left:0;padding:16px;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));overflow-x:hidden}.page-header{flex-direction:column;align-items:stretch!important;gap:12px}.page-header h1{font-size:20px;line-height:1.2}.page-header p{font-size:13px}.page-header>div{width:100%}.page-header>div:last-child{display:flex;flex-wrap:wrap;gap:8px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}.stat-card{padding:14px;border-radius:12px}.stat-card .stat-icon{font-size:22px;margin-bottom:8px}.stat-card .stat-value{font-size:22px}.stat-card .stat-label{font-size:10px}.stats-grid[style*="minmax(300px"]{grid-template-columns:1fr!important}.charts-grid{grid-template-columns:1fr;gap:14px;margin-bottom:20px}.chart-card{padding:16px}.chart-card h3{font-size:14px;margin-bottom:10px}.form-row{grid-template-columns:1fr;gap:0}.form-group{margin-bottom:12px}.form-group label{font-size:11px;margin-bottom:4px}.form-group input,.form-group select,.form-group textarea{padding:12px 14px;border-radius:10px;min-height:48px}.btn{min-height:48px;padding:12px 20px;font-size:14px;border-radius:12px;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97)}.data-table{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -16px;width:calc(100% + 32px);border-radius:0;border-left:none;border-right:none}.data-table table{min-width:500px}.data-table th{padding:10px 12px;font-size:10px;position:sticky;top:0;z-index:5}.data-table td{padding:10px 12px;font-size:13px;white-space:nowrap}.login-page{padding:16px;padding:env(safe-area-inset-top,16px) 16px env(safe-area-inset-bottom,16px)}.login-card{margin:0;padding:28px 20px;border-radius:20px;max-width:100%}.login-logo .logo-icon{font-size:40px}.login-logo h1{font-size:24px}.login-logo p{font-size:13px}.modal-overlay{align-items:flex-end;padding:0}.modal{margin:0;border-radius:24px 24px 0 0;max-height:90vh;max-width:100%;width:100%;padding:24px 20px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));animation:slideUpModal .3s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUpModal{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.modal h2{font-size:18px;margin-bottom:16px}.modal-actions{flex-direction:column-reverse;gap:8px;margin-top:20px}.modal-actions .btn{width:100%}.badge{padding:3px 10px;font-size:10px}.alert{padding:12px 14px;font-size:13px;border-radius:12px}.scanner-container{max-width:100%}.scanner-box{padding:20px;border-radius:16px}.scanner-box video{max-width:100%;border-radius:12px}.register-panel{max-width:100%}.register-form{padding:20px;border-radius:16px}.qr-preview{padding:16px}.section-title{font-size:16px;margin-bottom:12px}[style*=maxWidth],[style*=max-width]{max-width:100%!important}[style*="gap: 20px"],[style*="gap: 24px"],[style*="gap: 32px"]{gap:10px!important}input[type=text][style*=maxWidth],input[type=text][style*=max-width],input[style*="width: 100%"][style*=maxWidth]{max-width:100%!important;width:100%!important}}@media(max-width:480px){.main-content{padding:12px;padding-bottom:calc(76px + env(safe-area-inset-bottom,0px))}.page-header h1{font-size:18px}.stats-grid{grid-template-columns:1fr;gap:8px}.stat-card{padding:12px 14px;display:flex;align-items:center;gap:12px;flex-direction:row}.stat-card .stat-icon{font-size:22px;margin-bottom:0;flex-shrink:0}.stat-card .stat-value{font-size:20px}.stat-card .stat-label{font-size:10px}.login-card{margin:8px;padding:24px 16px}.login-logo h1{font-size:22px}.modal{padding:20px 16px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px));max-height:95vh}.data-table table{min-width:400px}.data-table td{font-size:12px;padding:8px 10px}.data-table th{font-size:9px;padding:8px 10px}}@media(max-width:768px){.b2b-filters{flex-direction:column!important;gap:8px!important;padding:12px!important}.b2b-search-input,.b2b-filter-select{flex:unset!important;width:100%!important;min-width:0!important;min-height:48px}.b2b-history-item{flex-direction:column!important;align-items:flex-start!important;gap:6px!important}}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:50;transition:all .3s ease}.sidebar-header{padding:24px 20px;border-bottom:1px solid var(--border)}.sidebar-logo{display:flex;align-items:center;gap:10px;margin-bottom:20px}.logo-icon-fi{font-size:22px;color:var(--primary-light)}.sidebar-logo h2{font-size:22px;font-weight:800;letter-spacing:2px;background:linear-gradient(135deg,var(--primary-light),var(--blue-grey));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-user{display:flex;align-items:center;gap:12px}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-electric));display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}.user-info{display:flex;flex-direction:column}.user-name{font-size:14px;font-weight:600}.user-role{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s ease;margin-bottom:4px}.nav-item:hover{background:var(--bg-card-hover);color:var(--text-primary)}.nav-item.active{background:#4932be33;color:var(--primary-light)}.nav-icon-fi{font-size:17px;width:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-footer{padding:16px 12px;border-top:1px solid var(--border)}.logout-btn{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);color:var(--text-secondary);background:none;border:none;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;width:100%;transition:all .2s ease}.logout-btn:hover{background:#4932be1a;color:var(--text-primary)}.logout-btn-danger{color:var(--danger)}.logout-btn-danger:hover{background:#df33191a;color:var(--danger)}.theme-toggle-btn{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);color:var(--text-secondary);background:none;border:none;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;width:100%;transition:all .2s ease;margin-bottom:4px}.theme-toggle-btn i{font-size:17px;width:24px;display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.theme-toggle-btn:hover{background:#4932be1a;color:var(--primary-light)}.theme-toggle-btn:hover i{transform:rotate(20deg)}[data-theme=light] .sidebar{box-shadow:2px 0 20px #4932be0f}[data-theme=light] .bottom-nav{box-shadow:0 -2px 16px #4932be14}.bottom-nav,.sidebar-backdrop{display:none}@media(max-width:768px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--bg-card);border-top:1px solid var(--border);padding:4px 0;padding-bottom:calc(4px + env(safe-area-inset-bottom,0px));justify-content:space-around;align-items:stretch;box-shadow:0 -4px 20px #0006}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 4px;flex:1;text-decoration:none;color:var(--text-muted);font-size:10px;font-weight:500;font-family:inherit;background:none;border:none;cursor:pointer;transition:color .2s;-webkit-tap-highlight-color:transparent}.bottom-nav-item i{font-size:20px;line-height:1;transition:transform .2s,color .2s}.bottom-nav-item span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70px}.bottom-nav-item.active{color:var(--primary-light)}.bottom-nav-item.active i{transform:scale(1.15)}.bottom-nav-item:active i{transform:scale(.9)}.bottom-nav-more{color:var(--text-muted)}.bottom-nav-more.active{color:var(--accent)}.sidebar{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);width:calc(100vw - 40px);max-width:340px;height:auto;max-height:75vh;border-radius:24px;border:1px solid rgba(73,50,190,.2);box-shadow:0 20px 60px #0009,0 0 0 1px #4932be4d;z-index:100;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.34,1.56,.64,1);overflow:hidden}.sidebar.open{opacity:1;transform:translate(-50%,-50%) scale(1);pointer-events:auto}.sidebar-backdrop{display:block;position:fixed;inset:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:90;animation:fadeIn .2s ease}.sidebar .sidebar-header{padding:20px}.sidebar .sidebar-logo{margin-bottom:14px}.sidebar .sidebar-logo .logo-icon-fi,.sidebar .sidebar-logo h2{font-size:20px}.sidebar .user-avatar{width:36px;height:36px;font-size:12px}.sidebar .user-name{font-size:13px}.sidebar .user-role{font-size:10px}.sidebar .sidebar-nav{padding:8px 12px}.sidebar .nav-item{padding:14px 16px;font-size:15px;border-radius:12px;margin-bottom:2px;min-height:48px}.sidebar .nav-icon-fi{font-size:18px}.sidebar .sidebar-footer{padding:12px}.sidebar .logout-btn{padding:14px 16px;font-size:15px;border-radius:12px;min-height:48px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
