.layout{display:flex;flex-direction:column;min-height:100vh}.navbar{background-color:#2c3e50;color:#fff;padding:1rem 0;box-shadow:0 2px 4px #0000001a}.navbar-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.navbar-brand{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none}.navbar-menu{display:flex;gap:1.5rem;align-items:center}.navbar-link{color:#fff;text-decoration:none;transition:opacity .2s}.navbar-link:hover{opacity:.8}.navbar-admin{background-color:#9b59b6;padding:.35rem .75rem;border-radius:4px;font-weight:500}.navbar-admin:hover{opacity:1;background-color:#8e44ad}.navbar-profile-link{display:flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;transition:opacity .2s}.navbar-profile-link:hover{opacity:.8}.navbar-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.3)}.navbar-avatar-placeholder{width:32px;height:32px;border-radius:50%;background-color:#3498db;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;border:2px solid rgba(255,255,255,.3)}.navbar-display-name{font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-dropdown{position:relative}.navbar-avatar-btn{display:flex;align-items:center;gap:.25rem;background:none;border:none;cursor:pointer;padding:.25rem;border-radius:8px;transition:background-color .2s}.navbar-avatar-btn:hover{background-color:#ffffff1a}.navbar-dropdown-arrow{width:16px;height:16px;color:#fff;transition:transform .2s}.navbar-avatar-btn[aria-expanded=true] .navbar-dropdown-arrow{transform:rotate(180deg)}.navbar-dropdown-menu{position:absolute;top:calc(100% + .5rem);right:0;min-width:220px;background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;z-index:1000;overflow:hidden;animation:dropdownFadeIn .15s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.navbar-dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1rem;background:none;border:none;text-align:left;font-size:.9375rem;color:#2c3e50;text-decoration:none;cursor:pointer;transition:background-color .2s}.navbar-dropdown-item:hover{background-color:#f8f9fa}.navbar-dropdown-item svg{width:18px;height:18px;flex-shrink:0}.navbar-dropdown-logout{border-top:1px solid #e9ecef;color:#e74c3c}.navbar-dropdown-logout:hover{background-color:#fef2f2}.navbar-button{background-color:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s}.navbar-button:hover{background-color:#c0392b}.main-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem}.footer{background-color:#34495e;color:#fff;padding:2rem 0;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;padding:0 2rem;text-align:center}@media(max-width:768px){.navbar-container{padding:0 1rem;flex-direction:column;gap:1rem}.navbar-brand{font-size:1.25rem}.navbar-menu{flex-wrap:wrap;justify-content:center;gap:1rem}.navbar-link{font-size:.9375rem}.navbar-button{font-size:.9375rem;padding:.5rem .875rem}.navbar-display-name{max-width:100px}.navbar-dropdown-menu{min-width:200px}.main-content{padding:1.5rem 1rem}.footer-container{padding:0 1rem;font-size:.9375rem}}@media(max-width:480px){.navbar{padding:.875rem 0}.navbar-container{padding:0 .75rem}.navbar-brand{font-size:1.125rem}.navbar-menu{gap:.75rem;font-size:.875rem}.navbar-link{font-size:.875rem}.navbar-button{font-size:.875rem;padding:.5rem .75rem}.navbar-avatar,.navbar-avatar-placeholder{width:28px;height:28px;font-size:.75rem}.navbar-display-name{max-width:80px;font-size:.875rem}.navbar-dropdown-menu{min-width:180px;right:-.5rem}.navbar-dropdown-item{padding:.75rem .875rem;font-size:.875rem}.navbar-dropdown-arrow{width:14px;height:14px}.main-content{padding:1rem .75rem}.footer{padding:1.5rem 0}.footer-container{padding:0 .75rem;font-size:.875rem}}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:16px;border-radius:8px;background:#fff;box-shadow:0 4px 12px #00000026;cursor:pointer;animation:slideIn .3s ease-out;transition:transform .2s,opacity .2s}.toast:hover{transform:translate(-4px)}.toast-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-weight:700;font-size:16px;flex-shrink:0}.toast-success{border-left:4px solid #10b981}.toast-success .toast-icon{background:#d1fae5;color:#10b981}.toast-error{border-left:4px solid #ef4444}.toast-error .toast-icon{background:#fee2e2;color:#ef4444}.toast-info{border-left:4px solid #3b82f6}.toast-info .toast-icon{background:#dbeafe;color:#3b82f6}.toast-message{flex:1;font-size:14px;color:#374151;line-height:1.5}.toast-close{background:none;border:none;font-size:24px;color:#9ca3af;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s}.toast-close:hover{color:#374151}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.toast-container{top:10px;right:10px;left:10px;max-width:none}.toast{padding:12px}.toast-message{font-size:13px}}.error-fallback{display:flex;align-items:center;justify-content:center;min-height:400px;padding:2rem}.error-fallback-content{text-align:center;max-width:500px}.error-fallback-icon{width:64px;height:64px;margin:0 auto 1.5rem;color:#dc3545}.error-fallback-icon svg{width:100%;height:100%}.error-fallback-title{font-size:1.5rem;font-weight:600;color:#1a1a2e;margin:0 0 .75rem}.error-fallback-message{color:#666;margin:0 0 1.5rem;line-height:1.5}.error-fallback-details{text-align:left;margin-bottom:1.5rem;padding:1rem;background-color:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.error-fallback-details summary{cursor:pointer;font-weight:500;color:#495057;padding:.25rem 0}.error-fallback-details pre{margin:.75rem 0 0;padding:.75rem;background-color:#fff;border-radius:4px;font-size:.75rem;overflow-x:auto;white-space:pre-wrap;word-break:break-word;color:#dc3545}.error-fallback-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.error-fallback-button{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s ease;border:none}.error-fallback-button.primary{background-color:#4f46e5;color:#fff}.error-fallback-button.primary:hover{background-color:#4338ca}.error-fallback-button.secondary{background-color:#f3f4f6;color:#374151;border:1px solid #d1d5db}.error-fallback-button.secondary:hover{background-color:#e5e7eb}.error-fallback.full-page{min-height:100vh;background-color:#f8f9fa}.error-fallback.inline{min-height:200px;padding:1rem}.error-fallback.inline .error-fallback-icon{width:48px;height:48px;margin-bottom:1rem}.error-fallback.inline .error-fallback-title{font-size:1.25rem}.error-fallback.inline .error-fallback-message{font-size:.875rem}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem}.loading-spinner-container--fullpage{min-height:400px;width:100%}.loading-spinner{border-radius:50%;border-style:solid;border-color:#e0e0e0;border-top-color:#3498db;animation:spin .8s linear infinite}.loading-spinner--small{width:20px;height:20px;border-width:2px}.loading-spinner--medium{width:40px;height:40px;border-width:3px}.loading-spinner--large{width:60px;height:60px;border-width:4px}.loading-spinner-text{color:#7f8c8d;font-size:1rem;margin:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.button-spinner{display:inline-flex;align-items:center;gap:.5rem}.button-spinner .loading-spinner{border-color:#ffffff4d;border-top-color:#fff}*{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}
