:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#333}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem;color:#034833}.loading-spinner{width:36px;height:36px;border:3px solid #e5e7eb;border-top-color:#034833;border-radius:50%;animation:spin .7s linear infinite}.loading-screen p{font-size:.95rem;color:#666}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#1a1a2e}.login-card{background:#fff;padding:2.5rem;border-radius:12px;width:100%;max-width:400px;box-shadow:0 4px 24px #00000026}.login-card h1{font-size:1.5rem;margin-bottom:.25rem;color:#1a1a2e}.login-subtitle{color:#888;margin-bottom:1.5rem;font-size:.9rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.4rem;font-size:.85rem;font-weight:500;color:#555}.form-group input{width:100%;padding:.65rem .75rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#4a6cf7}.error-message{color:#e74c3c;font-size:.85rem;margin-bottom:.75rem}.login-button{width:100%;padding:.7rem;background:#4a6cf7;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s;margin-top:.5rem}.login-button:hover{background:#3b5de7}.login-button:disabled{background:#a0b0f0;cursor:not-allowed}.admin-layout{display:flex;min-height:100vh}.sidebar{width:256px;background:#034833;color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:10}.sidebar-header{padding:1.25rem;border-bottom:1px solid rgba(255,255,255,.12)}.sidebar-header h2{font-size:1rem;font-weight:600;letter-spacing:-.01em;line-height:1.35}.sidebar-nav{padding:.5rem 0;flex:1;overflow-y:auto}.nav-link{display:flex;align-items:center;gap:.65rem;padding:.6rem 1.25rem;color:#ffffffb3;text-decoration:none;font-size:.875rem;border-radius:6px;margin:1px .5rem;transition:background .15s,color .15s}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link-active{background:#ffffff26;color:#fff;font-weight:500}.nav-icon{display:flex;align-items:center;line-height:1}.sidebar-user{padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:.6rem}.sidebar-user-email{font-size:.8rem;color:#ffffffa6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout-button{display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;font-size:.82rem;color:#fffc;cursor:pointer;transition:background .15s,color .15s;width:100%;justify-content:center}.sidebar-logout-button:hover{background:#ffffff26;color:#fff}.main-area{flex:1;margin-left:256px;display:flex;flex-direction:column}.top-header{display:flex;align-items:center;justify-content:flex-end;gap:1rem;padding:.75rem 1.5rem;background:#fff;border-bottom:1px solid #e5e5e5;position:sticky;top:0;z-index:5}.user-email{font-size:.85rem;color:#666}.logout-button{padding:.4rem 1rem;background:transparent;border:1px solid #ddd;border-radius:6px;font-size:.85rem;color:#666;cursor:pointer;transition:background .15s,color .15s}.logout-button:hover{background:#f5f5f5;color:#333}.main-content{flex:1;padding:2rem}.page-placeholder{display:flex;align-items:center;justify-content:center;min-height:60vh}.page-placeholder h1{font-size:1.75rem;color:#888;font-weight:500}
