body.dark{--primary-bg: #181a20;--secondary-bg: #21242c;--header-bg: #21242c;--text-color: #e2e4eb;--text-secondary: #a0a4b8;--border-color: #2d313a;--hover-bg: #2d313a;--active-bg: #2a3a5a;--logo-filter: invert(100%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(100%) contrast(100%);--shadow-color: rgba(0, 0, 0, .4);--card-bg: #1e2128;--input-bg: #2d313a;--button-primary: #4a6bff;--button-hover: #3a5aef}body.dark{background:var(--primary-bg)!important;color:var(--text-color)!important}body.dark .portal-header{background:var(--header-bg)!important;border-bottom:1px solid var(--border-color)}body.dark .logo-container img{filter:var(--logo-filter)}body.dark .sidebar{background:var(--secondary-bg)!important;border-right:1px solid var(--border-color)}body.dark button{background:var(--button-primary);color:#fff}body.dark button:hover{background:var(--button-hover)}body.dark input,body.dark textarea,body.dark select{background:var(--input-bg);color:var(--text-color);border:1px solid var(--border-color)}body.dark{--heading-color: #ffffff;--link-color: #6c9eff;--link-hover: #8ab1ff;--input-border-focus: #4a6bff;--input-placeholder: #7a7f8c;--card-shadow: 0 4px 12px rgba(0, 0, 0, .3);--table-header-bg: #2d313a;--table-row-odd: #21242c;--table-row-even: #252931}body.dark .btn-primary{background:var(--button-primary);border-color:var(--button-primary)}body.dark .btn-outline{background:transparent;border:1px solid var(--button-primary);color:var(--button-primary)}body.dark .card{background:var(--card-bg);box-shadow:var(--card-shadow);border:1px solid var(--border-color)}body.dark .table{color:var(--text-color)}body.dark .table thead th{background:var(--table-header-bg)}body.dark .table tbody tr:nth-child(odd){background:var(--table-row-odd)}body.dark .table tbody tr:nth-child(2n){background:var(--table-row-even)}body.dark .dropdown-menu{background:var(--secondary-bg);border:1px solid var(--border-color)}body.dark .nav-tabs .nav-link.active{border-bottom-color:var(--button-primary)}body.light{--primary-bg: #f6f7fa;--secondary-bg: #ffffff;--header-bg: #ececf3;--text-color: #181a20;--text-secondary: #5a5e6a;--border-color: #d8dae3;--hover-bg: #e8eaf3;--active-bg: #e6f0ff;--logo-filter: none;--shadow-color: rgba(0, 0, 0, .1);--card-bg: #ffffff;--input-bg: #ffffff;--button-primary: #4a6bff;--button-hover: #3a5aef}body.light{background:var(--primary-bg)!important;color:var(--text-color)!important}body.light .portal-header{background:var(--header-bg)!important;border-bottom:1px solid var(--border-color)}body.light .logo-container img{filter:var(--logo-filter)}body.light .sidebar{background:var(--secondary-bg)!important;border-right:1px solid var(--border-color)}body.light button{background:var(--button-primary);color:#fff}body.light button:hover{background:var(--button-hover)}body.light input,body.light textarea,body.light select{background:var(--input-bg);color:var(--text-color);border:1px solid var(--border-color)}body.light{--heading-color: #12141a;--link-color: #2c5aff;--link-hover: #1a4eff;--input-border-focus: #2c5aff;--input-placeholder: #a0a4b8;--card-shadow: 0 2px 8px rgba(0, 0, 0, .1);--table-header-bg: #f0f2f7;--table-row-odd: #ffffff;--table-row-even: #f8f9fc}body.light .btn-primary{background:var(--button-primary);border-color:var(--button-primary)}body.light .btn-outline{background:transparent;border:1px solid var(--button-primary);color:var(--button-primary)}body.light .card{background:var(--card-bg);box-shadow:var(--card-shadow);border:1px solid var(--border-color)}body.light .table{color:var(--text-color)}body.light .table thead th{background:var(--table-header-bg)}body.light .table tbody tr:nth-child(odd){background:var(--table-row-odd)}body.light .table tbody tr:nth-child(2n){background:var(--table-row-even)}body.light .dropdown-menu{background:var(--secondary-bg);border:1px solid var(--border-color)}body.light .nav-tabs .nav-link.active{border-bottom-color:var(--button-primary)}.top-right-menu{position:relative;display:inline-block}.user-menu-button{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;padding:8px 12px;color:var(--text-color);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.user-menu-button:hover{background:var(--hover-bg);transform:translateY(-1px)}.user-menu-button:active{transform:translateY(0)}.menu-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:var(--dropdown-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 25px var(--shadow-color);min-width:280px;z-index:1000;overflow:hidden;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.menu-header{padding:16px;border-bottom:1px solid var(--border-color);background:var(--secondary-bg)}.user-info{display:flex;align-items:center;gap:12px}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-color);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px}.user-details{display:flex;flex-direction:column}.user-name{font-weight:600;color:var(--text-color);font-size:14px}.user-email{color:var(--text-secondary);font-size:12px;margin-top:2px}.menu-section{padding:16px;border-bottom:1px solid var(--border-color)}.menu-section:last-of-type{border-bottom:none}.section-title{margin:0 0 12px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.menu-item{display:flex;align-items:center;width:100%;padding:12px;background:transparent;border:none;border-radius:8px;color:var(--text-color);cursor:pointer;transition:all .2s ease;text-align:left;gap:12px}.menu-item:hover{background:var(--hover-bg)}.menu-item:active{transform:scale(.98)}.item-icon{font-size:18px;color:var(--accent-color);flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px}.item-content{display:flex;flex-direction:column;flex:1;gap:2px}.item-label{font-weight:500;font-size:14px}.item-description{font-size:12px;color:var(--text-secondary)}.external-indicator{font-size:14px;color:var(--text-secondary);flex-shrink:0}.menu-footer{padding:16px;background:var(--secondary-bg);border-top:1px solid var(--border-color)}.logout-button{display:flex;align-items:center;gap:8px;width:100%;padding:12px;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--error-color);cursor:pointer;transition:all .2s ease;font-weight:500}.logout-button:hover{background:var(--error-color);color:#fff}@media (max-width: 768px){.menu-dropdown{position:fixed;inset:auto 16px 16px;margin-top:0;max-height:80vh;overflow-y:auto}.user-menu-button{width:36px;height:36px;padding:6px}}@media (max-width: 480px){.menu-dropdown{right:8px;left:8px;bottom:8px;min-width:auto}}[data-theme=dark] .menu-dropdown{border:1px solid var(--border-color)}[data-theme=dark] .menu-item:hover{background:var(--hover-bg)}.menu-item{animation:fadeIn .3s ease-out}.menu-item:nth-child(1){animation-delay:.05s}.menu-item:nth-child(2){animation-delay:.1s}.menu-item:nth-child(3){animation-delay:.15s}.menu-item:nth-child(4){animation-delay:.2s}.menu-item:nth-child(5){animation-delay:.25s}@keyframes fadeIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.layout{display:flex;min-height:100vh;background-color:var(--primary-bg);position:relative}.sidebar{width:280px;background-color:var(--secondary-bg);border-right:1px solid var(--border-color);display:flex;flex-direction:column;transition:transform .3s ease;z-index:1000;position:fixed;height:100vh;overflow-y:auto}.sidebar-header{padding:20px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background-color:var(--secondary-bg);z-index:10}.sidebar-header h2{margin:0;font-size:18px;color:var(--text-color);font-weight:600}.sidebar-close{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px}.sidebar-close:hover{background-color:var(--hover-bg)}.sidebar-nav{flex:1;padding:20px 0;overflow-y:auto}.nav-item{display:flex;align-items:center;padding:12px 20px;color:var(--text-secondary);text-decoration:none;transition:all .2s ease;margin:4px 0;border:none;background:none;width:100%;text-align:left;cursor:pointer}.nav-item:hover{background-color:var(--hover-bg);color:var(--text-color)}.nav-item.active{background-color:var(--accent-color);color:#fff;border-right:3px solid var(--accent-color)}.nav-icon{margin-right:12px;font-size:18px;flex-shrink:0}.nav-label{font-weight:500;flex:1}.sidebar-footer{padding:20px;border-top:1px solid var(--border-color);position:sticky;bottom:0;background-color:var(--secondary-bg)}.user-info{display:flex;align-items:center;margin-bottom:20px}.user-icon{font-size:24px;margin-right:12px;color:var(--text-secondary);flex-shrink:0}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{font-weight:600;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-actions{display:flex;flex-direction:column;gap:10px}.theme-toggle{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border:1px solid var(--border-color);border-radius:6px;background:var(--primary-bg);color:var(--text-color);cursor:pointer;font-size:14px;transition:all .2s ease}.theme-toggle:hover{background-color:var(--hover-bg)}.logout-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border:1px solid var(--error-color);border-radius:6px;background:transparent;color:var(--error-color);cursor:pointer;transition:all .2s ease;font-size:14px}.logout-btn:hover{background:var(--error-color);color:#fff}.main-content{flex:1;display:flex;flex-direction:column;margin-left:280px;min-width:0}.header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background-color:var(--header-bg);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;gap:16px;flex-wrap:wrap}.header-left{display:flex;align-items:center;gap:16px;flex:1;min-width:0}.menu-toggle{display:none;background:none;border:none;color:var(--text-color);cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s ease}.menu-toggle:hover{background-color:var(--hover-bg)}.page-title{margin:0;font-size:20px;font-weight:600;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-search{flex:1;max-width:400px;margin:0 20px}.search-form{display:flex;align-items:center;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.search-input{flex:1;border:none;padding:10px 16px;background:transparent;color:var(--text-color);font-size:14px;outline:none}.search-input::placeholder{color:var(--text-secondary)}.search-submit{background:none;border:none;padding:10px 16px;color:var(--text-secondary);cursor:pointer;transition:color .2s ease}.search-submit:hover{color:var(--accent-color)}.header-right{display:flex;align-items:center;gap:16px;flex-shrink:0}.header-btn{position:relative;background:none;border:none;color:var(--text-color);cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center}.header-btn:hover{background-color:var(--hover-bg)}.notification-badge{position:absolute;top:-2px;right:-2px;background-color:var(--error-color);color:#fff;border-radius:50%;width:16px;height:16px;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:600}.user-menu{display:flex;align-items:center;gap:12px}.user-greeting{font-size:14px;color:var(--text-secondary);white-space:nowrap}.user-avatar{width:40px;height:40px;border-radius:50%;background-color:var(--accent-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.quick-actions-desktop{display:flex;gap:8px;border-right:1px solid var(--border-color);padding-right:16px;margin-right:8px}.quick-actions-mobile{display:none;background:var(--secondary-bg);border-bottom:1px solid var(--border-color);padding:12px 16px;gap:12px;justify-content:space-around}.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-color);text-decoration:none;font-size:12px;transition:all .2s ease;min-width:60px}.quick-action-btn:hover{background:var(--hover-bg);transform:translateY(-1px)}.content{flex:1;padding:24px;overflow-y:auto;min-width:0}.layout-footer{background:var(--secondary-bg);border-top:1px solid var(--border-color);padding:20px 24px;margin-top:auto}.footer-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.footer-content p{margin:0;color:var(--text-secondary);font-size:14px}.footer-content nav{display:flex;gap:20px}.footer-content nav a{color:var(--text-secondary);text-decoration:none;font-size:14px;transition:color .2s ease}.footer-content nav a:hover{color:var(--accent-color)}.sidebar-overlay{position:fixed;inset:0;background-color:#00000080;z-index:999;display:none}@media (max-width: 1200px){.header-search{max-width:300px}}@media (max-width: 1024px){.sidebar{transform:translate(-100%);position:fixed}.sidebar.open{transform:translate(0)}.sidebar-close,.menu-toggle{display:block}.main-content{margin-left:0}.sidebar-overlay{display:block}.user-greeting{display:none}.header-search{display:none;position:absolute;top:100%;left:0;right:0;margin:0;max-width:none;background:var(--header-bg);padding:16px;border-bottom:1px solid var(--border-color);z-index:99}.header-search.search-open{display:block}.search-form{max-width:100%}.mobile-search-toggle{display:flex!important}}@media (max-width: 768px){.header{padding:12px 16px;gap:12px}.content{padding:16px}.sidebar{width:100%;max-width:320px}.quick-actions-desktop{display:none}.quick-actions-mobile{display:flex}.footer-content{flex-direction:column;gap:12px;text-align:center}.footer-content nav{justify-content:center;flex-wrap:wrap;gap:12px}}@media (max-width: 480px){.header-right{gap:8px}.header-btn{padding:6px}.user-avatar{width:32px;height:32px;font-size:14px}.quick-actions-mobile{padding:8px 12px}.quick-action-btn{padding:6px 8px;font-size:11px;min-width:50px}.layout-footer{padding:16px}}@media (prefers-reduced-motion: reduce){.sidebar,.nav-item,.header-btn{transition:none}}.nav-item:focus,.header-btn:focus,.theme-toggle:focus,.logout-btn:focus,.search-input:focus,.search-submit:focus,.quick-action-btn:focus{outline:2px solid var(--accent-color);outline-offset:2px}@media (prefers-contrast: high){.nav-item.active{outline:2px solid white}.header-btn:hover{outline:2px solid var(--text-color)}}@media print{.sidebar,.header,.quick-actions-mobile,.layout-footer{display:none!important}.main-content{margin-left:0}.content{padding:0}}.loading-spinner-fullscreen{position:fixed;inset:0;background:var(--overlay-bg, rgba(255, 255, 255, .9));display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dark-theme .loading-spinner-fullscreen{background:var(--overlay-bg, rgba(0, 0, 0, .8))}.spinner-container{text-align:center}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.inline-spinner{display:inline-flex;align-items:center;justify-content:center}.button-spinner{display:inline-flex;align-items:center;justify-content:center;margin-right:8px}.spinner{border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}.spinner-small{width:16px;height:16px;border-width:2px}.spinner-medium{width:32px;height:32px;border-width:3px}.spinner-large{width:48px;height:48px;border-width:4px}.spinner-xlarge{width:64px;height:64px;border-width:4px}.spinner-primary{border:2px solid var(--spinner-track, #f3f3f3);border-top:2px solid var(--accent-color, #3498db)}.spinner-secondary{border:2px solid var(--spinner-track, #f3f3f3);border-top:2px solid var(--secondary-color, #6c757d)}.spinner-light{border:2px solid rgba(255,255,255,.3);border-top:2px solid rgba(255,255,255,.8)}.spinner-dark{border:2px solid rgba(0,0,0,.1);border-top:2px solid rgba(0,0,0,.6)}.loading-text{margin:16px 0 0;color:var(--text-secondary, #666666);font-size:14px;font-weight:500}.dark-theme .loading-text{color:var(--text-secondary, #b0b0b0)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-pulse{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.wave-spinner{display:flex;align-items:center;justify-content:center;gap:4px}.wave-dot{width:8px;height:8px;border-radius:50%;background-color:var(--accent-color, #3498db);animation:wave 1.4s ease-in-out infinite}.wave-dot:nth-child(1){animation-delay:-.32s}.wave-dot:nth-child(2){animation-delay:-.16s}.wave-dot:nth-child(3){animation-delay:0s}@keyframes wave{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}.dark-theme .spinner-primary{border-color:var(--spinner-track, #3a3a3a);border-top-color:var(--accent-color, #3498db)}.dark-theme .spinner-secondary{border-color:var(--spinner-track, #3a3a3a);border-top-color:var(--secondary-color, #6c757d)}*{box-sizing:border-box;margin:0;padding:0}:root{--primary-bg: #ffffff;--secondary-bg: #f5f5f5;--header-bg: #ffffff;--footer-bg: #f5f5f5;--text-color: #333333;--text-secondary: #666666;--border-color: #e0e0e0;--hover-bg: #eaeaea;--theme-switcher-bg: #eaeaea;--dropdown-bg: #ffffff;--shadow-color: rgba(0, 0, 0, .1);--accent-color: #1890ff;--error-color: #ff4d4f;--success-color: #52c41a;--warning-color: #faad14}[data-theme=dark]{--primary-bg: #1a1a1a;--secondary-bg: #2d2d2d;--header-bg: #121212;--footer-bg: #121212;--text-color: #f5f5f5;--text-secondary: #b0b0b0;--border-color: #3a3a3a;--hover-bg: #3a3a3a;--theme-switcher-bg: #3a3a3a;--dropdown-bg: #2d2d2d;--shadow-color: rgba(0, 0, 0, .3)}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:var(--primary-bg);color:var(--text-color);transition:background-color .3s ease,color .3s ease}.app{min-height:100vh;display:flex;flex-direction:column}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px;text-decoration:none}.btn-primary{background-color:var(--accent-color);color:#fff}.btn-primary:hover{background-color:#40a9ff;transform:translateY(-1px)}.btn-secondary{background-color:var(--secondary-bg);color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover{background-color:var(--hover-bg)}.btn-danger{background-color:var(--error-color);color:#fff}.btn-danger:hover{background-color:#ff7875}.btn-success{background-color:var(--success-color);color:#fff}.btn-success:hover{background-color:#73d13d}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-color)}.form-input,.form-select,.form-textarea{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--secondary-bg);color:var(--text-color);font-size:14px;transition:border-color .2s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #1890ff33}.form-textarea{min-height:100px;resize:vertical}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-color);animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.btn{padding:8px 16px;font-size:13px}.form-input,.form-select,.form-textarea{padding:10px}}.text-center{text-align:center}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.mt-5{margin-top:3rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.mb-5{margin-bottom:3rem}.hidden{display:none}.visible{display:block}
