.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-container{background:#fff;padding:40px;border-radius:20px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:420px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:30px}.logo{font-size:60px;margin-bottom:15px}.login-header h1{color:#333;font-size:28px;margin-bottom:8px;font-weight:600}.login-header p{color:#666;font-size:14px}.login-form,.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500;font-size:14px}.form-group input{width:100%;padding:14px 16px;border:2px solid #e8e8e8;border-radius:10px;font-size:16px;transition:all .3s ease;background-color:#fafafa}.form-group input:focus{outline:none;border-color:#667eea;background-color:#fff;box-shadow:0 0 0 4px #667eea1a}.form-group input:disabled{opacity:.6;cursor:not-allowed}.error-message{color:#e74c3c;text-align:center;margin-bottom:15px;font-size:14px;padding:10px;background-color:#fdf2f2;border-radius:8px;border-left:4px solid #e74c3c}.login-btn{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;padding-top:20px;border-top:1px solid #eee}.login-footer p{color:#999;font-size:12px}@media (max-width: 480px){.login-page{padding:15px;background:linear-gradient(135deg,#667eea,#764ba2)}.login-container{padding:30px 25px;border-radius:16px}.logo{font-size:50px}.login-header h1{font-size:24px}.form-group input{padding:12px 14px;font-size:16px}.login-btn{padding:14px}}.home-page{min-height:100vh;background-color:#f5f7fa}.home-header{background:#fff;padding:0 30px;height:64px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #00000014;position:sticky;top:0;z-index:100}.brand{font-size:20px;font-weight:600;color:#667eea}.header-right{display:flex;align-items:center;gap:20px}.user-info{display:flex;align-items:center;gap:6px}.user-name{font-weight:500;color:#333}.user-id{color:#999;font-size:14px}.logout-btn{padding:8px 16px;background:transparent;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:14px;transition:all .3s}.logout-btn:hover{background:#f5f5f5;border-color:#667eea;color:#667eea}.home-main{max-width:1400px;margin:0 auto;padding:30px}.welcome-section{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:30px 40px;color:#fff;display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;box-shadow:0 10px 40px #667eea4d}.welcome-content h1{font-size:28px;font-weight:600;margin-bottom:8px}.welcome-subtitle{opacity:.9;font-size:16px}.time-display{text-align:right}.time{font-size:36px;font-weight:300;font-family:Courier New,monospace}.date{opacity:.9;font-size:14px;margin-top:4px}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.dashboard-card{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000000f;overflow:hidden;transition:transform .3s,box-shadow .3s}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.card-header{padding:20px 24px;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;gap:12px}.card-icon{font-size:24px}.card-header h3{font-size:18px;font-weight:600;color:#333}.card-content{padding:20px 24px;min-height:150px}.announcement-list,.task-list,.notification-list{list-style:none}.announcement-item,.task-item,.notification-item{padding:10px 0;border-bottom:1px solid #f5f5f5;display:flex;align-items:flex-start;gap:10px}.announcement-item:last-child,.task-item:last-child,.notification-item:last-child{border-bottom:none}.bullet{color:#667eea;font-weight:700}.task-item{align-items:center}.task-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#667eea}.task-item label{cursor:pointer;flex:1}.task-item input:checked+label{text-decoration:line-through;color:#999}.notification-dot{width:8px;height:8px;background:#ff6b6b;border-radius:50%;margin-top:6px;flex-shrink:0}.profile-info{display:flex;flex-direction:column;gap:14px}.info-row{display:flex;justify-content:space-between;align-items:center}.info-label{color:#666;font-size:14px}.info-value{color:#333;font-weight:500}.empty-text{color:#999;text-align:center;padding:40px 0;font-size:14px}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:18px;color:#666}@media (max-width: 1024px){.dashboard-grid{grid-template-columns:1fr}.welcome-section{flex-direction:column;text-align:center;gap:20px}.time-display{text-align:center}}@media (max-width: 768px){.home-header{padding:0 20px}.home-main{padding:20px}.welcome-section{padding:24px}.welcome-content h1{font-size:22px}.time{font-size:28px}.user-id{display:none}.dashboard-card{border-radius:10px}.card-header,.card-content{padding:16px 20px}}.app-loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:18px;color:#667eea;background:linear-gradient(135deg,#f5f7fa,#e4e8ec)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
