*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}.login-container{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:2rem}.login-card{animation:slideUp .4s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:450px;padding:3rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.login-header h1{color:#1a202c;font-size:2rem;font-weight:700;margin-bottom:.5rem}.login-header p{color:#718096;font-size:1rem}.login-form{margin-bottom:2rem}.test-credentials{background:linear-gradient(135deg,#f6f8fb,#e9ecf1);border:2px solid #e2e8f0;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.test-label{color:#2d3748;font-size:.95rem;font-weight:600;margin-bottom:.75rem}.credentials-box{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:1rem;padding:1rem}.credentials-box p{color:#4a5568;font-family:Courier New,monospace;font-size:.9rem;margin-bottom:.5rem}.credentials-box p:last-child{margin-bottom:0}.credentials-box strong{color:#2d3748;font-weight:600}.btn-fill{background:#fff;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;font-size:.9rem;font-weight:600;padding:.75rem;transition:all .3s ease;width:100%}.btn-fill:hover{background:#667eea;box-shadow:0 4px 12px #667eea4d;color:#fff;transform:translateY(-1px)}.login-footer{border-top:1px solid #e2e8f0;padding-top:1.5rem;text-align:center}.login-footer p{color:#718096;font-size:.95rem}@media (max-width:640px){.login-card{padding:2rem 1.5rem}.login-header h1{font-size:1.75rem}}.register-container{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:2rem}.register-card{animation:slideUp .4s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:550px;padding:3rem;width:100%}.register-header{margin-bottom:2rem;text-align:center}.register-header h1{color:#1a202c;font-size:2rem;font-weight:700;margin-bottom:.5rem}.register-header p{color:#718096;font-size:1rem}.error-message{align-items:center;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c53030;display:flex;gap:.5rem;margin-bottom:1.5rem;padding:1rem}.error-icon{font-size:1.2rem}.register-form{margin-bottom:2rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group,.form-row{margin-bottom:1.5rem}.form-row .form-group{margin-bottom:0}.form-group label{color:#2d3748;display:block;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.form-group input{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:.875rem 1rem;transition:all .3s ease;width:100%}.form-group input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-hint{color:#718096;display:block;font-size:.85rem;margin-top:.5rem}.btn-primary{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:1rem;transition:all .3s ease;width:100%}.btn-primary:hover:not(:disabled){box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.7}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.register-footer{border-top:1px solid #e2e8f0;padding-top:1.5rem;text-align:center}.register-footer p{color:#718096;font-size:.95rem}.link-primary{color:#667eea;font-weight:600;text-decoration:none;transition:color .3s ease}.link-primary:hover{color:#764ba2;text-decoration:underline}@media (max-width:640px){.register-card{padding:2rem 1.5rem}.register-header h1{font-size:1.75rem}.form-row{gap:0;grid-template-columns:1fr}.form-row .form-group{margin-bottom:1.5rem}}.dashboard{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.dashboard-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-bottom:1px solid #fff3;box-shadow:0 4px 6px #0000001a}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:1.5rem 2rem}.dashboard-header h1{color:#fff;font-size:1.75rem;font-weight:700;margin:0}.user-info{gap:1rem}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:50%;box-shadow:0 4px 12px #0003;color:#fff;font-size:1.25rem;font-weight:700;height:48px;justify-content:center;width:48px}.user-details{display:flex;flex-direction:column}.user-name{color:#fff;font-size:1rem;font-weight:600;margin:0}.user-email{color:#fffc;font-size:.875rem;margin:0}.btn-logout{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:.625rem 1.25rem;transition:all .3s ease}.btn-logout:hover{background:#ffffff4d;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.dashboard-main{margin:0 auto;max-width:1400px;padding:2rem}.welcome-section{margin-bottom:2rem}.welcome-card{animation:slideUp .4s ease-out;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;padding:2rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.welcome-card h2{color:#1a202c;font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.welcome-card p{color:#718096;font-size:1.1rem;margin:0}.info-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.info-card{animation:slideUp .4s ease-out;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;padding:2rem;transition:all .3s ease}.info-card:hover{box-shadow:0 12px 40px #00000026;transform:translateY(-4px)}.info-icon{font-size:2.5rem;margin-bottom:1rem}.info-card h3{color:#1a202c;font-size:1.25rem;font-weight:700;margin:0 0 1.5rem}.info-details{display:flex;flex-direction:column;gap:1rem}.info-row{align-items:center;background:#f7fafc;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem}.info-label{color:#718096;font-size:.9rem;font-weight:600}.info-value{color:#2d3748;font-weight:600}.role-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;font-size:.85rem;padding:.25rem .75rem;text-transform:uppercase}.security-item{align-items:center;background:#f7fafc;border-radius:8px;display:flex;gap:.75rem;padding:.75rem}.security-status{align-items:center;border-radius:50%;display:flex;font-size:.875rem;font-weight:700;height:24px;justify-content:center;width:24px}.security-status.success{background:#48bb78;color:#fff}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.stat-item{background:#f7fafc;border-radius:8px;padding:1rem;text-align:center}.stat-value{color:#667eea;font-size:2rem;font-weight:700;margin-bottom:.25rem}.stat-label{color:#718096;font-size:.875rem;font-weight:600}.system-info{color:#4a5568;line-height:1.6;margin-bottom:.75rem}.feature-list{list-style:none;margin:0;padding:0}.feature-list li{color:#4a5568;padding:.5rem 0 .5rem 1.5rem;position:relative}.feature-list li:before{color:#48bb78;content:"✓";font-weight:700;left:0;position:absolute}@media (max-width:768px){.header-content{gap:1rem;text-align:center}.header-content,.user-info{flex-direction:column}.info-grid,.stats-grid{grid-template-columns:1fr}}.app{min-height:100vh}.loading-container{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}