.notification-bell{position:relative}.bell-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#ffffff1a;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);position:relative}.bell-button:hover{background:#fff3}.bell-icon{font-size:1.25rem}.notification-bell .bell-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;background:#e53935;color:#fff;font-size:.7rem;font-weight:600;border-radius:9px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:400px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);overflow:hidden;z-index:1001;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--color-gray-200);background:var(--color-gray-50)}.dropdown-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-text)}.mark-all-read{background:none;border:none;color:var(--color-primary);font-size:.875rem;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.mark-all-read:hover{background:#0996601a}.notification-list{max-height:340px;overflow-y:auto}.notification-loading,.notification-empty{padding:var(--spacing-xl);text-align:center;color:var(--color-text-light)}.notification-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);border-bottom:1px solid var(--color-gray-100);cursor:pointer;transition:background var(--transition-fast);position:relative}.notification-item:hover{background:var(--color-gray-50)}.notification-item.unread{background:#0996600d}.notification-item.unread:hover{background:#0996601a}.notification-icon{font-size:1.25rem;flex-shrink:0;margin-top:2px}.notification-content{flex:1;min-width:0}.notification-title{font-weight:500;font-size:.875rem;color:var(--color-text);margin-bottom:2px;line-height:1.4}.notification-message{font-size:.8rem;color:var(--color-text-light);margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-time{font-size:.75rem;color:var(--color-gray-400)}.unread-dot{width:8px;height:8px;background:var(--color-primary);border-radius:50%;flex-shrink:0;margin-top:6px}@media (max-width: 480px){.notification-dropdown{position:fixed;top:58px;left:8px;right:8px;width:auto}}.language-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid rgba(255,255,255,.3);border-radius:6px;cursor:pointer;font-size:14px;color:#fff;transition:all .2s ease;white-space:nowrap}.language-btn:hover{background:#ffffff26;border-color:#fff9}.language-btn:active{background:#ffffff40}.lang-icon{font-size:14px;font-weight:600;color:#fff}.lang-label{font-size:13px}@media (max-width: 768px){.lang-label{display:none}.language-btn{padding:6px 10px}}.layout{min-height:100vh;display:flex;flex-direction:column}.header{position:fixed;top:0;left:0;right:0;height:60px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-md);z-index:1000;box-shadow:var(--shadow-md)}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.header-right{display:flex;align-items:center;gap:var(--spacing-sm);min-width:0;justify-content:flex-end;flex-shrink:1;overflow:visible}.header-right .global-search{max-width:160px;flex-shrink:1;min-width:0}@media (max-width: 1400px){.header-right .language-switcher .lang-label,.header-right .language-switcher .dropdown-arrow{display:none}}.header-right .language-switcher,.header-right .notification-bell,.header-right .user-info,.header-right .btn-outline{flex-shrink:0;white-space:nowrap}.menu-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#ffffff1a;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.menu-toggle:hover{background:#fff3}.menu-icon{display:block;width:20px;height:2px;background:#fff;position:relative}.menu-icon:before,.menu-icon:after{content:"";position:absolute;left:0;width:100%;height:2px;background:#fff}.menu-icon:before{top:-6px}.menu-icon:after{top:6px}.logo{display:flex;align-items:center;gap:var(--spacing-sm)}.logo-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#fff;color:var(--color-primary);font-weight:700;border-radius:var(--radius-md);font-size:.875rem}.logo-img{width:32px;height:32px;object-fit:contain}.logo-text{font-size:1.125rem;font-weight:700}.user-info{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2}.user-name{font-weight:500;font-size:.875rem}.user-role{font-size:.75rem;opacity:.8}.header .btn-outline{border-color:#fff;color:#fff}.header .btn-outline:hover{background:#fff;color:var(--color-primary)}.sidebar{position:fixed;top:60px;left:0;bottom:0;width:240px;background:#fff;box-shadow:var(--shadow-lg);transform:translate(-100%);transition:transform var(--transition-normal);z-index:900;overflow-y:auto}.sidebar.open{transform:translate(0)}.sidebar-overlay{position:fixed;top:60px;left:0;right:0;bottom:0;background:#00000080;z-index:800}.sidebar-nav{padding:var(--spacing-md) 0}.nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);color:var(--color-text);text-decoration:none;transition:all var(--transition-fast);border-left:3px solid transparent}.nav-item:hover{background:var(--color-gray-100);color:var(--color-primary)}.nav-item.active{background:#0996601a;color:var(--color-primary);border-left-color:var(--color-primary)}.nav-icon{font-size:1.25rem;display:inline-block;width:1.5rem;text-align:center}.nav-text{font-weight:500}.main-content{flex:1;margin-top:60px;padding:var(--spacing-md);min-height:calc(100vh - 60px)}@media (min-width: 768px){.menu-toggle{display:none}.sidebar{transform:translate(0)}.sidebar-overlay{display:none}.main-content{margin-left:240px;padding:var(--spacing-lg)}}@media (max-width: 767px){.header{height:50px;padding:0 var(--spacing-sm);overflow:visible}.header-left{flex-shrink:0}.logo-text{display:none}.logo-img{width:28px;height:28px}.user-info{display:none}.header-right{gap:4px;flex-shrink:1;overflow:visible}.header-right .global-search-input-wrapper{max-width:120px}.language-switcher .lang-label,.language-switcher .dropdown-arrow{display:none}.header-right .btn{font-size:.7rem;padding:4px 8px;white-space:nowrap}.sidebar{top:50px}.main-content{margin-top:50px;min-height:calc(100vh - 50px)}.sidebar-overlay{top:50px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);padding:var(--spacing-md)}.login-container{width:100%;max-width:400px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.login-header{text-align:center;padding:var(--spacing-xl);background:var(--color-gray-100)}.login-logo{display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-md)}.login-logo-icon{color:#fff;font-size:2rem;font-weight:700}.login-logo-img{width:80px;height:80px;object-fit:contain}.login-title{font-size:1.5rem;color:var(--color-text);margin-bottom:var(--spacing-xs)}.login-subtitle{color:var(--color-text-light);font-size:.875rem}.login-form{padding:var(--spacing-xl)}.login-error{background:#dc35451a;color:var(--color-danger);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:.875rem;text-align:center}.login-locked{background:#ff98001a!important;color:#e65100!important;border:1px solid rgba(255,152,0,.3)}.login-countdown{font-size:1.5rem;font-weight:700;font-variant-numeric:tabular-nums;margin-top:var(--spacing-sm);color:#d84315}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .form-input{padding-right:44px}.password-toggle-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:none;padding:6px;cursor:pointer;color:var(--color-text-light);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:color .2s ease,background .2s ease}.password-toggle-btn:hover{color:var(--color-primary);background:var(--color-gray-100)}.password-toggle-btn:focus{outline:none;color:var(--color-primary)}.login-footer{text-align:center;padding:var(--spacing-lg) var(--spacing-md);background:#fff;border-top:1px solid var(--color-gray-200)}.login-footer-logo{height:36px;max-width:180px;object-fit:contain}.microsoft-login-section{padding:0 var(--spacing-xl) var(--spacing-lg)}.login-divider{display:flex;align-items:center;text-align:center;margin-bottom:var(--spacing-md)}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid var(--color-gray-300)}.login-divider span{padding:0 var(--spacing-md);color:var(--color-text-light);font-size:.875rem}.microsoft-login-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 20px;background-color:#fff;border:1px solid #8c8c8c;border-radius:var(--radius-md);font-size:15px;color:#5e5e5e;cursor:pointer;transition:background-color .2s,border-color .2s}.microsoft-login-btn:hover{background-color:#f3f3f3;border-color:#666}.microsoft-login-btn:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #09966033}@media (max-width: 767px){.login-container{margin:var(--spacing-md)}.login-header,.login-form{padding:var(--spacing-lg)}.microsoft-login-section{padding:0 var(--spacing-lg) var(--spacing-md)}}:root{--color-primary: #099660;--color-primary-dark: #077a4d;--color-secondary: #004974;--color-secondary-dark: #003654;--color-success: #28a745;--color-warning: #ffc107;--color-danger: #dc3545;--color-info: #17a2b8;--color-gray-100: #f8f9fa;--color-gray-200: #e9ecef;--color-gray-300: #dee2e6;--color-gray-400: #ced4da;--color-gray-500: #adb5bd;--color-gray-600: #6c757d;--color-gray-700: #495057;--color-gray-800: #343a40;--color-gray-900: #212529;--color-text: #333333;--color-text-light: #666666;--color-text-muted: #999999;--color-bg: #ffffff;--color-bg-light: #f5f5f5;--color-bg-dark: #e8e8e8;--font-family: "Noto Sans TC", "Calibri", -apple-system, BlinkMacSystemFont, sans-serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-normal: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:1rem;line-height:1.6;color:var(--color-text);background-color:var(--color-bg-light);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}img{max-width:100%;height:auto}button{font-family:inherit;cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);font-size:1rem;font-weight:500;line-height:1.5;border:none;border-radius:var(--radius-md);transition:all var(--transition-fast);gap:var(--spacing-xs)}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-dark)}.btn-secondary{background-color:var(--color-secondary);color:#fff}.btn-secondary:hover{background-color:var(--color-secondary-dark)}.btn-outline{background-color:transparent;border:2px solid var(--color-primary);color:var(--color-primary)}.btn-outline:hover{background-color:var(--color-primary);color:#fff}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:1.125rem}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:.875rem}.btn:disabled{opacity:.6;cursor:not-allowed}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--color-text)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:1rem;font-family:inherit;border:1px solid var(--color-gray-300);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0996601a}.form-input::placeholder{color:var(--color-text-muted)}.filter-bar{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) 0;flex-wrap:wrap;align-items:center}.filter-bar .form-input{flex:0 0 auto}.card{background:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.card-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-gray-200)}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-gray-200);background:var(--color-gray-100)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--spacing-md)}.loading-spinner{width:48px;height:48px;border:4px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:.75rem;font-weight:500;border-radius:var(--radius-full)}.badge-primary{background-color:#0996601a;color:var(--color-primary)}.badge-secondary{background-color:#0049741a;color:var(--color-secondary)}.badge-success{background-color:#28a7451a;color:var(--color-success)}.badge-warning{background-color:#ffc10733;color:#856404}.badge-danger{background-color:#dc35451a;color:var(--color-danger)}.badge-required{background-color:#dc3545;color:#fff;font-weight:600}.badge-optional{background-color:#6c757d;color:#fff;font-weight:500}.progress{width:100%;height:8px;background-color:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background-color:var(--color-primary);transition:width var(--transition-normal)}@media (max-width: 767px){html{font-size:14px}.btn{padding:var(--spacing-sm) var(--spacing-md)}.card-body{padding:var(--spacing-md)}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.bg-primary{background-color:var(--color-primary)}.bg-secondary{background-color:var(--color-secondary)}.bg-light{background-color:var(--color-bg-light)}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.p-1{padding:var(--spacing-sm)}.p-2{padding:var(--spacing-md)}.p-3{padding:var(--spacing-lg)}.d-flex{display:flex}.flex-column{flex-direction:column}.align-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--spacing-sm)}.gap-2{gap:var(--spacing-md)}.gap-3{gap:var(--spacing-lg)}.w-100{width:100%}.h-100{height:100%}
