*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#f9fafb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh;background-color:#f9fafb}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:inherit;line-height:inherit}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.login-container{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:20px;box-sizing:border-box}.login-background{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#1a1d29,#2d3748 30%,#4a5568 70%,#1a1d29);z-index:1}.login-background:before{content:"";position:fixed;top:0;left:0;width:100vw;height:100vh;background:radial-gradient(circle at 20% 80%,rgba(99,102,241,.15) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(139,92,246,.15) 0%,transparent 50%),radial-gradient(circle at 40% 40%,rgba(59,130,246,.1) 0%,transparent 50%),radial-gradient(circle at 60% 60%,rgba(16,185,129,.08) 0%,transparent 50%)}.floating-shapes{position:fixed;top:0;left:0;width:100vw;height:100vh;overflow:hidden}.shape{position:absolute;border-radius:50%;background:#6366f114;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:float 6s ease-in-out infinite;border:1px solid rgba(255,255,255,.05)}.shape-1{width:80px;height:80px;top:10%;left:10%;animation-delay:0s}.shape-2{width:120px;height:120px;top:70%;right:10%;animation-delay:2s}.shape-3{width:60px;height:60px;top:20%;right:20%;animation-delay:4s}.shape-4{width:100px;height:100px;bottom:20%;left:20%;animation-delay:1s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(180deg)}}.login-content{position:relative;z-index:2;width:100%;max-width:450px}.login-card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:24px;box-shadow:0 32px 64px #00000026,0 16px 32px #0000001a,inset 0 1px #fff6;padding:48px;width:100%;animation:slideUp .8s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:40px}.logo-container{display:flex;flex-direction:column;align-items:center;gap:16px;margin-bottom:16px}.logo-icon{width:64px;height:64px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 24px #4f46e54d;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.login-header h1{color:#1f2937;margin:0;font-size:32px;font-weight:700;background:linear-gradient(135deg,#4f46e5,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{color:#6b7280;font-size:16px;margin:0;font-weight:400}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:12px}.form-group label{font-weight:600;color:#374151;font-size:15px;margin-left:4px}.input-container{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:20px;color:#9ca3af;z-index:1;transition:color .3s ease}.form-group input{width:100%;padding:16px 24px 16px 80px!important;border:2px solid #e5e7eb;border-radius:16px;font-size:16px;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;box-sizing:border-box}.login-form .form-group input{padding-left:80px!important}.login-card .login-form .form-group .input-container input{padding-left:80px!important;padding-right:60px!important}.login-container .login-content .login-card .login-form .form-group .input-container input[type=text],.login-container .login-content .login-card .login-form .form-group .input-container input[type=password]{padding-left:80px!important;padding-right:60px!important;text-indent:0!important;margin-left:0!important}.form-group input:focus{outline:none;border-color:#4f46e5;background:#fffffff2;box-shadow:0 0 0 4px #4f46e51a;transform:translateY(-2px)}.form-group input:focus+.input-icon,.input-container:focus-within .input-icon{color:#4f46e5}.password-toggle{position:absolute;right:24px;background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;border-radius:8px;transition:all .2s ease;z-index:1}.password-toggle:hover{color:#4f46e5;background:#4f46e51a}.error-message{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;color:#dc2626;padding:16px;border-radius:16px;font-size:14px;display:flex;align-items:center;gap:12px;animation:shake .5s ease-in-out}.error-icon{font-size:18px}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.login-button{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;padding:18px 24px;border-radius:16px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:12px;position:relative;overflow:hidden;box-shadow:0 8px 24px #4f46e54d}.login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.login-button:hover:not(:disabled):before{left:100%}.login-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 32px #4f46e566}.login-button:active:not(:disabled){transform:translateY(-1px)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.button-text{font-weight:600}.button-icon{transition:transform .3s ease}.login-button:hover:not(:disabled) .button-icon{transform:translate(4px)}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-footer{margin-top:32px;padding-top:24px;border-top:1px solid rgba(229,231,235,.3);text-align:center}.login-footer p{margin:0;color:#9ca3af;font-size:13px;font-weight:400}@media (max-width: 768px){.login-container{padding:16px}.login-card{padding:32px 24px}.login-header h1{font-size:28px}.logo-icon{width:56px;height:56px}.form-group input{padding:14px 20px 14px 68px}.input-icon{left:20px}.password-toggle{right:22px}.login-button{padding:16px 20px}}@media (max-width: 480px){.login-card{padding:24px 20px}.login-header h1{font-size:24px}}@media (prefers-color-scheme: dark){.login-card{background:#111827f2;border:1px solid rgba(75,85,99,.3)}.login-header h1{color:#f9fafb}.login-header p{color:#d1d5db}.form-group label{color:#f3f4f6}.form-group input{background:#1f2937cc;border-color:#4b5563;color:#f9fafb}.form-group input:focus{background:#1f2937f2}.login-footer p{color:#6b7280}}.sidebar{width:280px;height:100vh;background:#1a1d29;color:#fff;display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:1000}.sidebar-header{padding:24px 20px;border-bottom:1px solid #2d3142}.sidebar-logo{display:flex;align-items:center;gap:12px;font-size:18px;font-weight:600;margin-bottom:12px}.sidebar-user{font-size:14px;color:#9ca3af}.sidebar-nav{flex:1;padding:20px 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 20px;color:#9ca3af;text-decoration:none;transition:all .2s ease;border-left:3px solid transparent}.nav-item:hover{background:#2d3142;color:#fff}.nav-item.active{background:#2d3142;color:#fff;border-left-color:#667eea}.nav-section{margin-top:32px}.nav-section-title{padding:0 20px 12px;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.parking-group{margin-bottom:4px}.parking-toggle{width:100%;display:flex;align-items:center;gap:8px;padding:12px 20px;background:none;border:none;color:#9ca3af;text-align:left;cursor:pointer;transition:all .2s ease}.parking-toggle:hover{background:#2d3142;color:#fff}.parking-toggle span{flex:1;font-size:14px}.parking-status{display:flex;align-items:center;gap:2px;font-size:12px;font-weight:500}.parking-status .occupied{color:#ef4444}.parking-status .separator{color:#6b7280}.parking-status .total{color:#10b981}.parking-submenu{background:#0f1419;border-left:2px solid #2d3142;margin-left:20px}.submenu-item{display:flex;align-items:center;gap:12px;padding:10px 20px;color:#6b7280;text-decoration:none;font-size:14px;transition:all .2s ease;border-left:3px solid transparent}.submenu-item:hover{background:#1f2937;color:#9ca3af}.submenu-item.active{background:#1f2937;color:#fff;border-left-color:#667eea}.sidebar-footer{padding:20px;border-top:1px solid #2d3142;display:flex;flex-direction:column;gap:12px}.refresh-button{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:1px solid #059669;border-radius:8px;color:#10b981;cursor:pointer;transition:all .2s ease;font-size:14px}.refresh-button:hover{background:#059669;color:#fff;border-color:#047857}.refresh-button:active{transform:scale(.98)}.logout-button{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:#374151;border:none;border-radius:8px;color:#9ca3af;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:#4b5563;color:#fff}.layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:280px;background:#f9fafb;min-height:100vh}@media (max-width: 768px){.main-content{margin-left:0}}.heatmap-container{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e5e7eb;margin-bottom:24px}.heatmap-title{font-size:18px;font-weight:600;color:#1f2937;margin-bottom:20px;text-align:center}.heatmap-grid{display:flex;flex-direction:column;gap:2px;margin-bottom:20px;overflow-x:auto;min-width:600px}.heatmap-header{display:flex;gap:2px;margin-bottom:4px}.heatmap-row{display:flex;gap:2px;align-items:center}.zone-label,.day-label,.parking-label{width:80px;font-size:12px;font-weight:600;color:#374151;text-align:right;padding-right:8px;display:flex;align-items:center;justify-content:flex-end;height:24px}.parking-label{width:120px;font-size:11px}.hour-label{width:20px;height:20px;font-size:10px;color:#6b7280;text-align:center;display:flex;align-items:center;justify-content:center;writing-mode:vertical-rl;text-orientation:mixed}.heatmap-cell{width:20px;height:24px;border-radius:2px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;position:relative;border:1px solid rgba(255,255,255,.3)}.heatmap-cell:hover{transform:scale(1.2);box-shadow:0 4px 8px #0003;z-index:10;border:1px solid #374151}.heatmap-cell.future-hour{background-color:#f5f5f5!important;color:#999!important;border:1px dashed #ddd!important;cursor:default}.heatmap-cell.future-hour:hover{transform:none;box-shadow:none;border:1px dashed #ddd!important}.cell-value{font-size:8px;font-weight:600;color:#1f2937;text-shadow:0 0 2px rgba(255,255,255,.8);opacity:0;transition:opacity .2s ease}.heatmap-cell:hover .cell-value{opacity:1}.heatmap-legend{display:flex;align-items:center;gap:16px;justify-content:center;padding-top:16px;border-top:1px solid #e5e7eb}.legend-label{font-size:14px;font-weight:500;color:#374151}.legend-gradient{display:flex;flex-direction:column;gap:4px}.legend-scale{display:flex;gap:1px;border-radius:4px;overflow:hidden;border:1px solid #d1d5db}.legend-step{width:20px;height:16px;cursor:pointer}.legend-labels{display:flex;justify-content:space-between;font-size:12px;color:#6b7280;padding:0 2px}@media (max-width: 768px){.heatmap-container{padding:16px;overflow-x:auto}.heatmap-grid{min-width:500px}.zone-label,.day-label{width:60px;font-size:10px}.hour-label{width:16px;height:16px;font-size:8px}.heatmap-cell{width:16px;height:20px}.cell-value{font-size:7px}.heatmap-legend{flex-direction:column;gap:8px}}.heatmap-cell:before{content:attr(title);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#1f2937;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:20;margin-bottom:4px}.heatmap-cell:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#1f2937;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:20}.heatmap-cell:hover:before,.heatmap-cell:hover:after{opacity:1}.heatmap-cell{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.dashboard{padding:32px;max-width:1200px;margin:0 auto}.dashboard-header{margin-bottom:32px}.dashboard-header h1{font-size:32px;font-weight:700;color:#1f2937;margin-bottom:8px}.dashboard-header p{color:#6b7280;font-size:16px}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:40px}.stat-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;text-align:center;border:1px solid #e5e7eb}.stat-number{font-size:36px;font-weight:700;color:#1f2937;margin-bottom:8px}.parking-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:32px}.parking-card{background:#fff;border-radius:16px;box-shadow:0 10px 25px -5px #0000001a;overflow:hidden;border:1px solid #e5e7eb;transition:transform .2s ease,box-shadow .2s ease}.parking-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -10px #00000026}.parking-card-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px}.parking-card-header h3{font-size:20px;font-weight:600;color:#1f2937;margin:0}.occupancy-badge{padding:6px 12px;border-radius:20px;color:#fff;font-size:14px;font-weight:600}.parking-chart{padding:0 24px}.parking-info{padding:16px 24px 24px;background:#f9fafb}.info-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #e5e7eb}.info-row:last-child{border-bottom:none}.info-label{font-size:14px;color:#6b7280}.info-value{font-size:14px;font-weight:600;color:#1f2937}.info-value.occupied{color:#ef4444}.info-value.free{color:#10b981}@media (max-width: 768px){.dashboard{padding:20px}.dashboard-stats{grid-template-columns:repeat(2,1fr);gap:16px}.parking-grid{grid-template-columns:1fr;gap:20px}.stat-card{padding:16px}.stat-number{font-size:28px}}.zone-line-chart{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px;margin-bottom:24px}.chart-header{margin-bottom:24px}.chart-header h3{margin:0 0 8px;color:#1f2937;font-size:20px;font-weight:600}.chart-header p{margin:0;color:#6b7280;font-size:14px}.chart-container{margin-bottom:24px}.zone-chart-tooltip{background:#fffffff2;border:1px solid #e5e7eb;border-radius:8px;padding:12px;box-shadow:0 4px 12px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tooltip-label{margin:0 0 8px;font-weight:600;color:#1f2937;font-size:14px}.zone-chart-tooltip p{margin:4px 0;font-size:13px;font-weight:500}.chart-legend-info{display:flex;flex-direction:column;gap:12px;padding-top:20px;border-top:1px solid #e5e7eb}.legend-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#f9fafb;border-radius:8px;transition:background-color .2s ease}.legend-item:hover{background:#f3f4f6}.legend-line-container{width:24px;height:16px;display:flex;align-items:center;flex-shrink:0}.legend-line{width:100%;height:0;border-top:3px solid;border-radius:1px}.legend-line.solid{border-style:solid}.legend-line.dashed{border-style:dashed;border-top-width:2px}.legend-color{width:16px;height:16px;border-radius:3px;flex-shrink:0}.legend-color.global{border:2px solid rgba(139,92,246,.3)}.legend-color.zone{border:1px solid rgba(0,0,0,.1)}.legend-item span{font-size:14px;color:#374151;line-height:1.4}.zone-chart-error{display:flex;align-items:center;justify-content:center;height:200px;color:#6b7280;font-size:16px;background:#f9fafb;border-radius:8px;border:1px dashed #d1d5db}@media (max-width: 768px){.zone-line-chart{padding:16px;margin-bottom:16px}.chart-header h3{font-size:18px}.chart-container{margin-bottom:16px}.chart-legend-info{gap:8px}.legend-item{padding:6px 8px}.legend-item span{font-size:13px}}@media (max-width: 480px){.zone-line-chart{padding:12px}.chart-header h3{font-size:16px}.chart-header p{font-size:13px}.legend-item{flex-direction:column;align-items:flex-start;gap:8px}.legend-color{width:12px;height:12px}}.parking-dashboard{padding:32px;max-width:1400px;margin:0 auto}.parking-dashboard-header{margin-bottom:32px}.parking-dashboard-header h1{font-size:32px;font-weight:700;color:#1f2937;margin-bottom:8px}.parking-dashboard-header p{color:#6b7280;font-size:16px}.parking-overview{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-bottom:48px}.overview-card{background:#fff;border-radius:16px;box-shadow:0 10px 25px -5px #0000001a;padding:24px;border:1px solid #e5e7eb}.overview-card h3{font-size:20px;font-weight:600;color:#1f2937;margin-bottom:20px}.main-stats-info{display:flex;justify-content:space-around;margin-top:20px}.stat-item{text-align:center}.stat-value{display:block;font-size:24px;font-weight:700;color:#1f2937;margin-bottom:4px}.stat-value.occupied{color:#ef4444}.stat-value.free{color:#10b981}.heatmap-section{margin-bottom:48px}.zones-section h2{font-size:24px;font-weight:600;color:#1f2937;margin-bottom:24px}.zones-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.zone-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:20px;border:1px solid #e5e7eb;transition:transform .2s ease}.zone-card:hover{transform:translateY(-2px)}.zone-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.zone-header h4{font-size:18px;font-weight:600;color:#1f2937;margin:0}.zone-badge{padding:4px 8px;border-radius:12px;color:#fff;font-size:12px;font-weight:600}.zone-info{display:flex;justify-content:space-around;margin-top:16px}.zone-stat{text-align:center}.zone-stat-value{display:block;font-size:18px;font-weight:600;color:#1f2937;margin-bottom:4px}.zone-stat-value.occupied{color:#ef4444}.zone-stat-value.free{color:#10b981}.zone-stat-label{font-size:12px;color:#6b7280;font-weight:500}@media (max-width: 1024px){.parking-overview{grid-template-columns:1fr;gap:24px}}@media (max-width: 768px){.parking-dashboard{padding:20px}.zones-grid{grid-template-columns:1fr;gap:16px}.main-stats-info{flex-direction:column;gap:16px}}.parking-history{padding:32px;max-width:1400px;margin:0 auto}.history-header{margin-bottom:32px}.history-header h1{font-size:32px;font-weight:700;color:#1f2937;margin-bottom:8px}.history-header p{color:#6b7280;font-size:16px}.history-controls{display:flex;gap:32px;margin-bottom:32px;padding:24px;background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e5e7eb}.control-group{display:flex;flex-direction:column;gap:8px}.control-group label{font-size:14px;font-weight:600;color:#374151}.control-select{padding:8px 12px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s ease}.control-select:focus{outline:none;border-color:#667eea}.granularity-slider{display:flex;background:#f3f4f6;border-radius:8px;padding:4px}.granularity-slider button{padding:8px 16px;border:none;background:transparent;border-radius:6px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease}.granularity-slider button.active{background:#fff;color:#667eea;box-shadow:0 2px 4px #0000001a}.granularity-slider button:hover:not(.active){color:#374151}.history-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:40px}.stat-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e5e7eb;display:flex;align-items:center;gap:16px}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#667eea;color:#fff}.stat-icon.max{background:#10b981}.stat-icon.min{background:#f59e0b}.stat-icon.trend-up{background:#10b981}.stat-icon.trend-down{background:#ef4444}.stat-icon.trend-stable{background:#6b7280}.stat-content{flex:1}.stat-value{font-size:24px;font-weight:700;color:#1f2937;margin-bottom:4px}.stat-label{font-size:14px;color:#6b7280;font-weight:500}.heatmap-section{margin-bottom:40px}.zone-line-section{margin-bottom:32px}.charts-section{display:grid;grid-template-columns:1fr;gap:32px}.chart-card{background:#fff;border-radius:16px;box-shadow:0 10px 25px -5px #0000001a;padding:24px;border:1px solid #e5e7eb}.chart-card h3{font-size:20px;font-weight:600;color:#1f2937;margin-bottom:20px}.chart-container{width:100%;height:400px}.error{padding:32px;text-align:center;font-size:18px;color:#ef4444}@media (max-width: 1024px){.history-controls{flex-direction:column;gap:20px}.history-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.parking-history{padding:20px}.history-stats{grid-template-columns:1fr;gap:16px}.stat-card{padding:16px}.chart-container{height:300px}}.user-form-modal{padding:0}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;border-bottom:1px solid #e5e7eb;margin-bottom:24px}.modal-close{background:none;border:none;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#374151}.user-form{padding:0 24px 24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#374151;font-size:14px}.form-group input,.form-group select{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6}.form-group input.error,.form-group select.error{border-color:#dc2626}.form-group input:disabled,.form-group select:disabled{background:#f9fafb;color:#6b7280;cursor:not-allowed}.error-text{display:block;color:#dc2626;font-size:12px;margin-top:4px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}@media (max-width: 480px){.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%;justify-content:center}}.user-management{padding:24px;max-width:1200px;margin:0 auto}.user-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.user-management-header h1{margin:0;color:#1f2937;font-size:28px;font-weight:600}.loading{text-align:center;padding:48px;color:#6b7280;font-size:16px}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:24px;display:flex;justify-content:space-between;align-items:center}.error-close{background:none;border:none;color:#dc2626;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.users-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.users-table{width:100%;border-collapse:collapse}.users-table th{background:#f9fafb;padding:16px;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.users-table td{padding:16px;border-bottom:1px solid #f3f4f6;vertical-align:middle}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover{background:#f9fafb}.username-cell strong{color:#1f2937;font-weight:600}.role-cell{display:flex;align-items:center;gap:8px}.role-icon{flex-shrink:0}.role-icon.admin{color:#dc2626}.role-icon.user{color:#059669}.actions-cell{display:flex;gap:8px}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-sm{padding:6px 12px;font-size:12px}.empty-state{text-align:center;padding:48px;color:#6b7280}.empty-state svg{margin-bottom:16px;opacity:.5}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal h3{margin:0 0 16px;color:#1f2937;font-size:20px;font-weight:600}.modal p{margin:0 0 24px;color:#6b7280;line-height:1.6}.modal-actions{display:flex;gap:12px;justify-content:flex-end;padding:24px;border-top:1px solid #e5e7eb;margin:24px -24px -24px}@media (max-width: 768px){.user-management{padding:16px}.user-management-header{flex-direction:column;gap:16px;align-items:stretch}.users-table-container{overflow-x:auto}.users-table{min-width:600px}.modal{margin:16px;width:calc(100% - 32px)}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
