.sidebar{width:260px;background-color:var(--bg-surface);border-right:1px solid var(--border-color);display:flex;flex-direction:column;height:100vh;box-shadow:2px 0 8px #00000005;z-index:10}.sidebar-brand{height:80px;display:flex;align-items:center;padding:0 24px;border-bottom:1px solid var(--border-color)}.brand-logo{width:40px;height:40px;background:linear-gradient(135deg,var(--primary-light),var(--primary-color));border-radius:var(--radius-md);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;letter-spacing:1px;box-shadow:var(--shadow-sm)}.brand-name{margin-left:12px;font-size:1.25rem;font-weight:700;color:var(--primary-color);letter-spacing:-.5px}.sidebar-scroll{flex:1;overflow-y:auto;padding:24px 16px}.nav-list{list-style:none}.nav-item{margin-bottom:8px}.nav-link{display:flex;align-items:center;padding:12px 16px;border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;transition:all var(--transition-speed) ease;background:transparent;width:100%}.nav-link:hover{background-color:var(--bg-main);color:var(--primary-color)}.nav-link.active{background-color:var(--secondary-color);color:var(--primary-color);box-shadow:inset 3px 0 0 var(--primary-color)}.nav-link.active .nav-icon{color:var(--primary-color)}.nav-icon{display:flex;align-items:center;margin-right:14px;color:#a0aec0;transition:color var(--transition-speed)}.nav-link:hover .nav-icon{color:var(--primary-color)}.sidebar-footer{padding:16px;border-top:1px solid var(--border-color)}.footer-btn{text-align:left;font-size:1rem}.footer-btn.logout:hover{color:#e53e3e;background-color:#fff5f5}.footer-btn.logout:hover .nav-icon{color:#e53e3e}.top-header{height:80px;background-color:var(--bg-surface);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 32px;box-shadow:0 1px 4px #00000005}.header-search{flex:1;max-width:400px}.search-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:var(--text-secondary)}.search-input{width:100%;padding:10px 16px 10px 40px;border:1px solid var(--border-color);border-radius:var(--radius-full);background-color:var(--bg-main);font-size:.9rem;transition:all var(--transition-speed)}.search-input:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 3px #2b7a4b1a;background-color:var(--bg-surface)}.header-actions{display:flex;align-items:center;gap:24px}.icon-btn{background:transparent;color:var(--text-secondary);position:relative;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-speed)}.icon-btn:hover{background-color:var(--bg-main);color:var(--primary-color)}.badge{position:absolute;top:2px;right:4px;background-color:#e53e3e;color:#fff;font-size:.65rem;font-weight:700;height:16px;min-width:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg-surface)}.user-profile{display:flex;align-items:center;gap:12px;cursor:pointer}.user-info{display:flex;flex-direction:column;align-items:flex-end}.user-name{font-weight:600;font-size:.9rem;color:var(--text-primary)}.user-role{font-size:.75rem;color:var(--text-secondary)}.user-avatar{width:40px;height:40px;background-color:var(--secondary-color);color:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--primary-light)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:#0a1a10}.login-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden}.bg-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.4;animation:float 20s ease-in-out infinite}.bg-orb-1{width:600px;height:600px;background:radial-gradient(circle,#1a5632,transparent 70%);top:-200px;left:-100px;animation-delay:0s}.bg-orb-2{width:500px;height:500px;background:radial-gradient(circle,#2b7a4b,transparent 70%);bottom:-150px;right:-100px;animation-delay:-7s}.bg-orb-3{width:400px;height:400px;background:radial-gradient(circle,#38a169,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s;opacity:.2}@keyframes float{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-40px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(40px,30px) scale(1.02)}}.bg-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px}.login-container{position:relative;z-index:1;display:flex;width:960px;max-width:95vw;min-height:600px;border-radius:24px;overflow:hidden;box-shadow:0 0 0 1px #ffffff0f,0 25px 50px -12px #00000080,0 0 100px #1a563226;animation:cardEnter .7s cubic-bezier(.16,1,.3,1)}@keyframes cardEnter{0%{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-branding{flex:1;background:linear-gradient(160deg,#143d24,#0f2e1b,#0a1f12);padding:48px 40px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.login-branding:before{content:"";position:absolute;top:0;right:0;width:200px;height:100%;background:linear-gradient(90deg,transparent,rgba(56,161,105,.04));pointer-events:none}.branding-content{position:relative;z-index:1}.brand-icon-wrapper{position:relative;width:64px;height:64px;margin-bottom:28px}.brand-icon{width:64px;height:64px;background:linear-gradient(135deg,#2b7a4b,#1a5632);border-radius:18px;display:flex;align-items:center;justify-content:center;color:#a7f3d0;position:relative;z-index:1;box-shadow:0 8px 24px #1a563266}.brand-icon-glow{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;background:radial-gradient(circle,rgba(56,161,105,.3),transparent 70%);border-radius:22px;animation:pulse-glow 3s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.brand-title{font-size:2.2rem;font-weight:800;color:#fff;letter-spacing:-1px;margin-bottom:6px;line-height:1.1}.brand-tagline{font-size:1.05rem;color:#6ee7b7;font-weight:500;letter-spacing:.5px}.brand-divider{width:48px;height:3px;background:linear-gradient(90deg,#38a169,transparent);border-radius:2px;margin:24px 0}.brand-description{font-size:.95rem;color:#ffffff8c;line-height:1.7;max-width:300px}.brand-features{display:flex;flex-wrap:wrap;gap:10px;margin-top:32px}.feature-pill{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:100px;color:#ffffffa6;font-size:.8rem;font-weight:500;transition:all .3s ease}.feature-pill:hover{background:#38a1691a;border-color:#38a16940;color:#a7f3d0}.feature-dot{width:6px;height:6px;border-radius:50%;background:#38a169;flex-shrink:0}.branding-footer{color:#ffffff40;font-size:.75rem;position:relative;z-index:1}.login-form-section{flex:1;background:#fff;display:flex;align-items:center;justify-content:center;padding:48px 40px}.login-card{width:100%;max-width:380px}.mobile-brand{display:none;align-items:center;gap:10px;margin-bottom:24px;font-size:1.1rem;font-weight:700;color:#1a5632}.mobile-brand-icon{width:36px;height:36px;background:linear-gradient(135deg,#2b7a4b,#1a5632);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.login-card-header{margin-bottom:36px}.login-title{font-size:1.75rem;font-weight:700;color:#1a202c;letter-spacing:-.5px;margin-bottom:8px}.login-subtitle{font-size:.95rem;color:#718096;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:20px}.input-group{position:relative}.input-label{display:block;font-size:.85rem;font-weight:600;color:#4a5568;margin-bottom:8px;transition:color .3s ease}.input-group.focused .input-label{color:#1a5632}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:14px;color:#a0aec0;transition:color .3s ease;pointer-events:none;z-index:1}.input-group.focused .input-icon{color:#1a5632}.input-wrapper input{width:100%;padding:14px 14px 14px 44px;border:2px solid #e2e8f0;border-radius:12px;font-size:.95rem;font-family:Inter,sans-serif;color:#1a202c;background:#f7fafc;transition:all .3s ease;outline:none}.input-wrapper input::placeholder{color:#cbd5e0}.input-wrapper input:focus{border-color:#2b7a4b;background:#fff;box-shadow:0 0 0 4px #2b7a4b14}.input-wrapper input:disabled{opacity:.6;cursor:not-allowed}.password-toggle{position:absolute;right:14px;background:none;border:none;color:#a0aec0;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s ease;z-index:1}.password-toggle:hover{color:#4a5568}.login-btn{width:100%;padding:16px 24px;background:linear-gradient(135deg,#1a5632,#2b7a4b);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);margin-top:8px;position:relative;overflow:hidden}.login-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.1));opacity:0;transition:opacity .3s ease}.login-btn:hover:not(:disabled):before{opacity:1}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #1a563259}.login-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 4px 12px #1a563240}.login-btn:disabled{cursor:not-allowed;opacity:.85}.btn-content,.btn-loader{display:flex;align-items:center;justify-content:center;gap:10px}.spinner{width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-card-footer{margin-top:28px;padding-top:20px;border-top:1px solid #edf2f7}.footer-note{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.8rem;color:#a0aec0}@media (max-width: 768px){.login-page{background:#fff}.login-container{flex-direction:column;width:100%;max-width:100%;min-height:100vh;border-radius:0;box-shadow:none}.login-branding{display:none}.mobile-brand{display:flex}.login-form-section{padding:32px 24px;min-height:100vh}}@media (min-width: 769px) and (max-width: 1024px){.login-container{width:800px}.login-branding,.login-form-section{padding:40px 32px}}.dashboard{display:flex;flex-direction:column;gap:24px;animation:fadeIn .4s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{display:flex;justify-content:space-between;align-items:center}.page-title{font-size:1.75rem;color:var(--text-primary);margin-bottom:4px}.page-subtitle{color:var(--text-secondary);font-size:.95rem}.primary-btn{background-color:var(--primary-color);color:#fff;padding:10px 20px;border-radius:var(--radius-md);font-weight:600;transition:all var(--transition-speed);box-shadow:0 4px 6px #1a563233}.primary-btn:hover{background-color:var(--primary-light);transform:translateY(-1px);box-shadow:0 6px 8px #1a563240}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}.stat-card{background:var(--bg-surface);padding:24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:transform var(--transition-speed),box-shadow var(--transition-speed)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.stat-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.stat-title{font-size:.9rem;color:var(--text-secondary);font-weight:500;margin-bottom:8px}.stat-value{font-size:1.8rem;font-weight:700;color:var(--text-primary)}.stat-icon-wrapper{padding:12px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background-color:var(--bg-main)}.icon-green{color:var(--accent-color);background-color:#38a1691a}.icon-blue{color:#3182ce;background-color:#3182ce1a}.icon-orange{color:#dd6b20;background-color:#dd6b201a}.icon-purple{color:#805ad5;background-color:#805ad51a}.stat-trend{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600}.stat-trend.positive{color:var(--accent-color)}.stat-trend.negative{color:#e53e3e}.trend-text{color:var(--text-secondary);font-weight:400}.dashboard-content{display:grid;grid-template-columns:2fr 1fr;gap:24px}@media (max-width: 1024px){.dashboard-content{grid-template-columns:1fr}}.chart-container,.recent-activity{background:var(--bg-surface);padding:24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.section-title{font-size:1.1rem;color:var(--text-primary);margin-bottom:24px}.chart-wrapper{height:300px;width:100%}.activity-list{list-style:none;display:flex;flex-direction:column;gap:20px}.activity-item{display:flex;gap:16px;position:relative}.activity-item:not(:last-child):before{content:"";position:absolute;left:5px;top:20px;bottom:-20px;width:2px;background-color:var(--border-color)}.activity-bullet{width:12px;height:12px;border-radius:50%;background-color:var(--primary-color);margin-top:4px;z-index:1;border:2px solid white;box-shadow:0 0 0 2px var(--primary-light)}.activity-text{font-size:.95rem;color:var(--text-primary);line-height:1.4}.activity-time{font-size:.8rem;color:var(--text-secondary);display:block;margin-top:4px}.notices-page{display:flex;flex-direction:column;gap:20px;animation:fadeIn .35s ease}.np-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.np-title{display:flex;align-items:center;gap:10px;font-size:1.6rem;font-weight:700;color:var(--text-primary)}.np-title svg{color:var(--primary-color)}.np-subtitle{color:var(--text-secondary);font-size:.9rem;margin-top:2px;padding-left:36px}.np-new-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;font-size:.9rem;font-weight:600;color:#fff;background:var(--primary-color);border-radius:var(--radius-sm);box-shadow:0 2px 8px #1a563233;transition:background .2s,box-shadow .2s,transform .15s}.np-new-btn:hover{background:var(--primary-light);transform:translateY(-1px);box-shadow:0 4px 14px #1a563247}.np-filters{display:flex;flex-direction:column;gap:10px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:14px 18px}.np-filters__row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.np-filters__row+.np-filters__row{padding-top:10px;border-top:1px solid var(--border-color)}.np-search{flex:1;min-width:200px;display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-main);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:border-color .2s}.np-search:focus-within{border-color:var(--primary-light);box-shadow:0 0 0 2px #2b7a4b14}.np-search svg{color:var(--text-secondary);flex-shrink:0}.np-search input{flex:1;border:none;background:none;font-family:inherit;font-size:.88rem;color:var(--text-primary);outline:none}.np-dropdown{position:relative}.np-dropdown__trigger{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-main);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:inherit;font-size:.88rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:border-color .2s,box-shadow .2s;white-space:nowrap}.np-dropdown__trigger svg:first-child{color:var(--text-secondary)}.np-dropdown__trigger:hover,.np-dropdown__trigger--open{border-color:var(--primary-light);box-shadow:0 0 0 2px #2b7a4b14}.np-dropdown__chevron{transition:transform .2s;color:var(--text-secondary)}.np-dropdown__chevron--open{transform:rotate(180deg)}.np-dropdown__menu{position:absolute;top:calc(100% + 6px);left:0;min-width:200px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:0 8px 24px #0000001a;z-index:100;padding:6px;animation:dropdownIn .15s ease-out}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.np-dropdown__item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;border:none;background:none;font-family:inherit;font-size:.86rem;color:var(--text-primary);border-radius:6px;cursor:pointer;transition:background .15s;text-align:left}.np-dropdown__item:hover{background:var(--bg-main)}.np-dropdown__item--active{background:var(--secondary-color);color:var(--primary-color);font-weight:600}.np-dropdown__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.np-date-filter{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.np-date-filter svg{color:var(--text-secondary);flex-shrink:0}.np-date-filter label{font-size:.78rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.np-date-filter input[type=date]{padding:6px 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:inherit;font-size:.84rem;color:var(--text-primary);background:var(--bg-main);outline:none;transition:border-color .2s}.np-date-filter input[type=date]:focus{border-color:var(--primary-light)}.np-date-sep{color:var(--text-secondary);font-size:.85rem}.np-date-clear{display:inline-flex;align-items:center;gap:3px;padding:4px 10px;border-radius:var(--radius-sm);background:#fef2f2;color:#dc2626;font-size:.76rem;font-weight:600;transition:background .2s;margin-left:auto}.np-date-clear:hover{background:#fecaca}.np-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color)}.np-tab{display:inline-flex;align-items:center;gap:7px;padding:12px 22px;font-size:.9rem;font-weight:600;color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .2s,border-color .2s}.np-tab:hover{color:var(--text-primary)}.np-tab--active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.np-tab--active.np-tab--disabled{color:#64748b;border-bottom-color:#94a3b8}.np-tab__badge{font-size:.72rem;font-weight:700;padding:1px 8px;border-radius:10px;background:var(--primary-color);color:#fff;line-height:1.5}.np-tab__badge--muted{background:#94a3b8}.np-list{display:flex;flex-direction:column;gap:10px}.np-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:240px;background:var(--bg-surface);border:1px dashed var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary)}.np-state__icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--secondary-color);border-radius:50%;color:var(--primary-light)}.np-state h3{color:var(--text-primary);font-size:1.05rem}.np-state p{font-size:.86rem;text-align:center;max-width:280px;line-height:1.5}.nc{display:flex;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;transition:box-shadow .2s,border-color .2s}.nc:hover{box-shadow:0 2px 12px #0000000d;border-color:#cbd5e1}.nc__bar{width:4px;flex-shrink:0}.nc__inner{flex:1;padding:16px 18px;display:flex;flex-direction:column;gap:8px;min-width:0}.nc__row-top{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.nc__badges{display:flex;align-items:center;gap:6px}.nc__cat{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full);font-size:.74rem;font-weight:600}.nc__imp{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;background:#fef2f2;color:#dc2626;text-transform:uppercase;letter-spacing:.3px}.nc__time{display:flex;align-items:center;gap:4px;font-size:.78rem;color:var(--text-secondary);white-space:nowrap}.nc__title{font-size:.98rem;font-weight:600;color:var(--text-primary);line-height:1.4}.nc__body{font-size:.86rem;color:#64748b;line-height:1.55;white-space:pre-wrap;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.nc__row-bottom{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:4px;padding-top:10px;border-top:1px solid #f1f5f9}.nc__tags{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.nc__tag{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:var(--radius-full);font-size:.73rem;font-weight:500;color:#475569;background:#f8fafc;border:1px solid #e2e8f0}.nc__actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.nc__action{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:var(--radius-sm);font-size:.76rem;font-weight:600;border:1px solid var(--border-color);background:transparent;transition:all .18s;cursor:pointer}.nc__action--disable{color:#94a3b8}.nc__action--disable:hover{color:#d97706;border-color:#fcd34d;background:#fffbeb}.nc__action--restore{color:var(--primary-color);border-color:#bbf7d0;background:#f0fdf4}.nc__action--restore:hover{background:#dcfce7;border-color:#86efac}.nc__action--delete{color:#dc2626;border-color:#fecaca;background:#fef2f2}.nc__action--delete:hover{background:#fee2e2;border-color:#fca5a5}.nc__action:disabled{opacity:.5;cursor:not-allowed}.nc--urgent{border-color:#fecaca;background:linear-gradient(to right,#fff,#fefce8)}.nc--urgent .nc__bar{width:5px}.nc--off{opacity:.55;background:#fafafa}.nc--off .nc__title{color:#94a3b8}.nc--off .nc__body{color:#cbd5e1}.nc--off .nc__tag{color:#94a3b8;border-color:#e2e8f0;background:#f1f5f9}.nc--off:hover{opacity:.75}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:modalFadeIn .15s ease-out;padding:24px}.confirm-box{background:var(--bg-surface);border-radius:var(--radius-md);width:100%;max-width:380px;padding:28px;text-align:center;box-shadow:0 20px 40px #0000002e;animation:modalUp .2s ease-out}.confirm-icon-wrap{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.confirm-icon--red{background:#fef2f2;color:#dc2626}.confirm-icon--amber{background:#fffbeb;color:#d97706}.confirm-icon--green{background:#f0fdf4;color:#16a34a}.confirm-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.confirm-msg{font-size:.88rem;color:var(--text-secondary);line-height:1.5;margin-bottom:24px}.confirm-actions{display:flex;gap:10px;justify-content:center}.confirm-cancel{padding:9px 22px;border-radius:var(--radius-sm);font-size:.86rem;font-weight:600;background:var(--bg-main);color:var(--text-secondary);border:1px solid var(--border-color);transition:all .2s}.confirm-cancel:hover{background:var(--bg-surface);color:var(--text-primary)}.confirm-ok{padding:9px 22px;border-radius:var(--radius-sm);font-size:.86rem;font-weight:600;color:#fff;border:none;transition:all .2s}.confirm-ok--red{background:#dc2626}.confirm-ok--red:hover{background:#b91c1c}.confirm-ok--amber{background:#d97706}.confirm-ok--amber:hover{background:#b45309}.confirm-ok--green{background:#16a34a}.confirm-ok--green:hover{background:#15803d}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:modalFadeIn .2s ease-out;padding:24px}.modal-content{background:var(--bg-surface);border-radius:var(--radius-lg);width:100%;max-width:580px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003;animation:modalUp .25s ease-out}@keyframes modalUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:22px 26px;border-bottom:1px solid var(--border-color)}.modal-title-group{display:flex;align-items:center;gap:14px}.modal-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--primary-color);color:#fff;border-radius:var(--radius-sm)}.modal-title{font-size:1.15rem;color:var(--text-primary)}.modal-subtitle{font-size:.82rem;color:var(--text-secondary);margin-top:1px}.modal-close{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:none;color:var(--text-secondary);transition:background .2s}.modal-close:hover{background:var(--bg-main);color:var(--text-primary)}.notice-form{padding:26px;display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:6px;position:relative}.form-group label{font-size:.86rem;font-weight:600;color:var(--text-primary)}.form-group input,.form-group textarea,.form-group .select-wrapper select{padding:10px 14px;background:var(--bg-main);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.92rem;font-family:inherit;color:var(--text-primary);transition:border-color .2s,box-shadow .2s;resize:vertical}.form-group input:focus,.form-group textarea:focus,.form-group .select-wrapper select:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 3px #2b7a4b1a;background:var(--bg-surface)}.char-count{position:absolute;right:12px;bottom:10px;font-size:.72rem;color:var(--text-secondary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.select-wrapper{position:relative}.select-wrapper select{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.select-wrapper .select-arrow{position:absolute;right:14px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-secondary)}.toggle-btn{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-main);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.88rem;color:var(--text-secondary);font-family:inherit;transition:all .2s;width:100%}.toggle-btn:hover{border-color:var(--primary-light)}.toggle-btn.active{background:#fff5f5;border-color:#e53e3e;color:#e53e3e}.modal-actions{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--border-color);padding-top:18px}.cancel-btn{padding:10px 22px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;background:var(--bg-main);color:var(--text-secondary);border:1px solid var(--border-color);transition:all .2s}.cancel-btn:hover{background:var(--bg-surface);color:var(--text-primary)}.submit-btn{display:flex;align-items:center;gap:7px;padding:10px 24px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;background:var(--primary-color);color:#fff;box-shadow:0 2px 8px #1a563233;transition:all .2s}.submit-btn:hover:not(:disabled){background:var(--primary-light);transform:translateY(-1px);box-shadow:0 4px 14px #1a56324d}.submit-btn:disabled{opacity:.65;cursor:not-allowed}.mini-spinner{width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:loadSpin .6s linear infinite}.mini-spinner.white{border-color:#ffffff4d;border-top-color:#fff}@media (max-width: 768px){.np-filters__row{flex-direction:column;align-items:stretch}.np-search{min-width:0}.np-dropdown{width:100%}.np-dropdown__trigger{width:100%;justify-content:space-between}.np-dropdown__menu,.np-date-filter{width:100%}.np-date-filter input[type=date]{flex:1;min-width:0}.np-tabs{overflow-x:auto}.np-tab{white-space:nowrap;padding:10px 16px;font-size:.84rem}.nc__row-bottom{flex-direction:column;align-items:flex-start;gap:8px}.nc__actions{align-self:flex-end}.form-row{grid-template-columns:1fr}.modal-content{max-height:95vh}.np-subtitle{padding-left:0}.np-header{flex-direction:column;align-items:flex-start}.confirm-box{max-width:320px;padding:22px}.branch-chips-wrap{gap:6px}.branch-chip{font-size:.74rem;padding:5px 10px}}.branch-chips-wrap{display:flex;flex-wrap:wrap;gap:8px;padding:10px 14px;background:var(--bg-main);border:1px solid var(--border-color);border-radius:var(--radius-sm);min-height:44px;align-items:center;transition:border-color .2s}.branch-chips-wrap:focus-within{border-color:var(--primary-light);box-shadow:0 0 0 2px #2b7a4b14}.branch-chip{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--radius-full);font-size:.8rem;font-weight:600;border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:all .18s ease;-webkit-user-select:none;user-select:none}.branch-chip:hover{border-color:var(--primary-light);color:var(--primary-color);background:#f0fdf4}.branch-chip--active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 2px 6px #1a56322e}.branch-chip--active:hover{background:var(--primary-light);border-color:var(--primary-light);color:#fff}.branch-loading{font-size:.82rem;color:var(--text-secondary);font-style:italic}.branch-hint{font-size:.76rem;font-weight:600;color:var(--primary-color);padding-left:2px}.nc__tag--branch{background:#eff6ff;color:#2563eb;border-color:#bfdbfe}.nc__tag--year{background:#fdf4ff;color:#9333ea;border-color:#e9d5ff}.academics-page{display:flex;flex-direction:column;gap:20px;animation:fadeIn .35s ease}.ac-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.ac-title{display:flex;align-items:center;gap:10px;font-size:1.6rem;font-weight:700;color:var(--text-primary)}.ac-title svg{color:var(--primary-color)}.ac-subtitle{color:var(--text-secondary);font-size:.9rem;margin-top:2px;padding-left:36px}.ac-tabs{display:flex;gap:4px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:6px;overflow-x:auto}.ac-tab{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;font-size:.82rem;font-weight:600;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;white-space:nowrap}.ac-tab:hover{color:var(--primary-color);background:var(--secondary-color)}.ac-tab--active{color:#fff;background:var(--primary-color);box-shadow:0 2px 8px #1a563233}.ac-tab--active:hover{background:var(--primary-light);color:#fff}.ac-panel{animation:fadeIn .25s ease}.ac-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;font-size:.88rem;font-weight:600;color:#fff;background:var(--primary-color);border-radius:var(--radius-sm);box-shadow:0 2px 8px #1a563233;transition:all .2s;border:none;cursor:pointer}.ac-btn:hover{background:var(--primary-light);transform:translateY(-1px);box-shadow:0 4px 14px #1a563247}.ac-btn--outline{background:transparent;color:var(--primary-color);border:1px solid var(--border-color);box-shadow:none}.ac-btn--outline:hover{background:var(--secondary-color);box-shadow:none;transform:none}.ac-btn--danger{background:#dc2626;box-shadow:0 2px 8px #dc262633}.ac-btn--danger:hover{background:#b91c1c}.ac-btn--sm{padding:6px 14px;font-size:.78rem}.ac-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.ac-table-wrap{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.ac-table{width:100%;border-collapse:collapse}.ac-table th{padding:12px 16px;font-size:.76rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;background:var(--bg-main);border-bottom:1px solid var(--border-color);text-align:left;white-space:nowrap}.ac-table td{padding:14px 16px;font-size:.88rem;color:var(--text-primary);border-bottom:1px solid #f1f5f9;vertical-align:middle}.ac-table tr:last-child td{border-bottom:none}.ac-table tr:hover td{background:#fafffe}.ac-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:.73rem;font-weight:600}.ac-badge--active{background:#d1fae5;color:#059669}.ac-badge--inactive{background:#fee2e2;color:#dc2626}.ac-badge--pending{background:#fef3c7;color:#d97706}.ac-badge--approved{background:#d1fae5;color:#059669}.ac-badge--rejected{background:#fee2e2;color:#dc2626}.ac-badge--present{background:#d1fae5;color:#059669}.ac-badge--absent{background:#fee2e2;color:#dc2626}.ac-badge--leave{background:#fef3c7;color:#d97706}.ac-badge--halfday{background:#e0e7ff;color:#4f46e5}.ac-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}.ac-search{flex:1;min-width:200px;display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-main);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:border-color .2s}.ac-search:focus-within{border-color:var(--primary-light);box-shadow:0 0 0 2px #2b7a4b14}.ac-search svg{color:var(--text-secondary);flex-shrink:0}.ac-search input{flex:1;border:none;background:none;font-family:inherit;font-size:.88rem;color:var(--text-primary);outline:none}.ac-select-wrap{position:relative}.ac-select-wrap select{padding:8px 34px 8px 14px;background:var(--bg-main);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:inherit;font-size:.86rem;color:var(--text-primary);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;outline:none;transition:border-color .2s}.ac-select-wrap select:focus{border-color:var(--primary-light)}.ac-select-wrap .sel-arrow{position:absolute;right:10px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-secondary)}.ac-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:modalFadeIn .2s ease-out;padding:24px}.ac-modal{background:var(--bg-surface);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003;animation:modalUp .25s ease-out}.ac-modal--lg{max-width:720px}.ac-modal-head{display:flex;justify-content:space-between;align-items:center;padding:22px 26px;border-bottom:1px solid var(--border-color)}.ac-modal-head-left{display:flex;align-items:center;gap:14px}.ac-modal-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--primary-color);color:#fff;border-radius:var(--radius-sm)}.ac-modal-title{font-size:1.15rem;color:var(--text-primary);font-weight:700}.ac-modal-sub{font-size:.82rem;color:var(--text-secondary);margin-top:1px}.ac-modal-close{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:none;color:var(--text-secondary);transition:background .2s;border:none;cursor:pointer}.ac-modal-close:hover{background:var(--bg-main);color:var(--text-primary)}.ac-modal-body{padding:26px;display:flex;flex-direction:column;gap:18px}.ac-form-group{display:flex;flex-direction:column;gap:6px}.ac-form-group label{font-size:.86rem;font-weight:600;color:var(--text-primary)}.ac-form-group input,.ac-form-group textarea,.ac-form-group select{padding:10px 14px;background:var(--bg-main);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.92rem;font-family:inherit;color:var(--text-primary);transition:border-color .2s,box-shadow .2s;outline:none}.ac-form-group input:focus,.ac-form-group textarea:focus,.ac-form-group select:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #2b7a4b1a;background:var(--bg-surface)}.ac-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.ac-form-actions{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--border-color);padding-top:18px}.ac-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:16px}.ac-stat{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:18px 20px;display:flex;align-items:center;gap:14px;transition:transform .2s,box-shadow .2s}.ac-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.ac-stat__icon{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ac-stat__icon--green{background:#d1fae5;color:#059669}.ac-stat__icon--red{background:#fee2e2;color:#dc2626}.ac-stat__icon--amber{background:#fef3c7;color:#d97706}.ac-stat__icon--blue{background:#dbeafe;color:#2563eb}.ac-stat__icon--purple{background:#ede9fe;color:#7c3aed}.ac-stat__val{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.ac-stat__label{font-size:.78rem;color:var(--text-secondary);margin-top:2px}.ac-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:200px;background:var(--bg-surface);border:1px dashed var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary)}.ac-empty svg{color:var(--primary-light)}.ac-empty h3{color:var(--text-primary);font-size:1.05rem}.ac-empty p{font-size:.86rem}.ac-inner-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color);margin-bottom:16px}.ac-inner-tab{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;font-size:.88rem;font-weight:600;color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all .2s}.ac-inner-tab:hover{color:var(--text-primary)}.ac-inner-tab--active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.ac-inner-tab__ct{font-size:.72rem;font-weight:700;padding:1px 8px;border-radius:10px;background:var(--primary-color);color:#fff;line-height:1.5;margin-left:2px}.ac-chip{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--radius-full);font-size:.8rem;font-weight:600;border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:all .18s;-webkit-user-select:none;user-select:none}.ac-chip:hover{border-color:var(--primary-light);color:var(--primary-color);background:#f0fdf4}.ac-chip--active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 2px 6px #1a56322e}.ac-chip--active:hover{background:var(--primary-light);border-color:var(--primary-light);color:#fff}.tt-grid{display:grid;grid-template-columns:100px repeat(8,1fr);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-surface)}.tt-cell{padding:10px 8px;font-size:.78rem;border-right:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:60px;transition:background .15s}.tt-cell:last-child{border-right:none}.tt-cell--head{background:var(--bg-main);font-weight:700;color:var(--text-secondary);font-size:.72rem;text-transform:uppercase;letter-spacing:.3px;min-height:40px}.tt-cell--day{background:var(--bg-main);font-weight:700;color:var(--primary-color);font-size:.8rem}.tt-cell--slot{cursor:pointer}.tt-cell--slot:hover{background:#f0fdf4}.tt-cell--filled{background:#fafffe}.tt-cell__subj{font-weight:600;color:var(--primary-color);font-size:.76rem}.tt-cell__fac{color:var(--text-secondary);font-size:.68rem;margin-top:2px}.leave-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:18px 20px;display:flex;flex-direction:column;gap:10px;transition:box-shadow .2s}.leave-card:hover{box-shadow:var(--shadow-md)}.leave-card__top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.leave-card__info h4{font-size:.95rem;font-weight:600;color:var(--text-primary)}.leave-card__info p{font-size:.82rem;color:var(--text-secondary);margin-top:2px}.leave-card__dates{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-secondary);margin-top:4px}.leave-card__dates svg{color:var(--primary-light)}.leave-card__reason{font-size:.86rem;color:#475569;background:var(--bg-main);padding:10px 14px;border-radius:var(--radius-sm);border-left:3px solid var(--primary-light)}.leave-card__actions{display:flex;gap:8px;justify-content:flex-end}.ac-stepper{display:flex;align-items:center;gap:0;margin-bottom:24px}.ac-step{display:flex;align-items:center;gap:8px}.ac-step__circle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:700;border:2px solid var(--border-color);color:var(--text-secondary);background:var(--bg-surface);transition:all .3s}.ac-step--done .ac-step__circle{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.ac-step--active .ac-step__circle{border-color:var(--primary-color);color:var(--primary-color);box-shadow:0 0 0 4px #2b7a4b1f}.ac-step__label{font-size:.82rem;font-weight:600;color:var(--text-secondary)}.ac-step--done .ac-step__label,.ac-step--active .ac-step__label{color:var(--primary-color)}.ac-step__line{flex:1;height:2px;background:var(--border-color);margin:0 8px;min-width:30px}.ac-step__line--done{background:var(--primary-color)}.sem-card{background:linear-gradient(135deg,var(--primary-color),var(--primary-light));color:#fff;border-radius:var(--radius-md);padding:24px 28px;display:flex;align-items:center;gap:20px}.sem-card__num{font-size:2.5rem;font-weight:800;opacity:.9}.sem-card__info h3{font-size:1.1rem;font-weight:700}.sem-card__info p{font-size:.86rem;opacity:.8;margin-top:4px}.ac-report-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:20px}.ac-report-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px;cursor:pointer;transition:all .2s}.ac-report-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.ac-report-card--active{border-color:var(--primary-color);box-shadow:0 0 0 2px #2b7a4b1f}.ac-report-card__icon{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.ac-report-card h4{font-size:.95rem;font-weight:600;color:var(--text-primary)}.ac-report-card p{font-size:.82rem;color:var(--text-secondary);margin-top:4px}.ac-chart-wrap{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:24px}.ac-chart-title{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin-bottom:16px}.att-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.att-cal__head{font-size:.7rem;font-weight:700;color:var(--text-secondary);text-align:center;padding:6px;text-transform:uppercase}.att-cal__day{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;cursor:default}.att-cal__day--p{background:#d1fae5;color:#059669}.att-cal__day--a{background:#fee2e2;color:#dc2626}.att-cal__day--l{background:#fef3c7;color:#d97706}.att-cal__day--e{background:#f1f5f9;color:#94a3b8}.ac-actions{display:flex;align-items:center;gap:6px}.ac-act{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:none;cursor:pointer;color:var(--text-secondary);transition:all .18s}.ac-act:hover{border-color:var(--primary-light);color:var(--primary-color);background:#f0fdf4}.ac-act--danger:hover{border-color:#fca5a5;color:#dc2626;background:#fef2f2}.sem-mode-toggle{display:flex;gap:4px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:5px;margin-bottom:20px;width:fit-content}.sem-mode-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;font-size:.86rem;font-weight:600;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .22s}.sem-mode-btn:hover{color:var(--text-primary);background:var(--bg-main)}.sem-mode-btn--active.sem-mode-btn--promote{color:#fff;background:var(--primary-color);box-shadow:0 2px 10px #1a563238}.sem-mode-btn--active.sem-mode-btn--rollback{color:#fff;background:#d97706;box-shadow:0 2px 10px #d9770638}.sem-section{margin-bottom:20px;animation:fadeIn .25s ease}.sem-select{padding:10px 14px;background:var(--bg-main);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:inherit;font-size:.92rem;max-width:340px;width:100%;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.sem-select:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #2b7a4b1a;outline:none}.sem-card--rollback{background:linear-gradient(135deg,#b45309,#d97706)}.ac-btn--rollback{background:#d97706;box-shadow:0 2px 8px #d9770633}.ac-btn--rollback:hover{background:#b45309;box-shadow:0 4px 14px #d9770647}.sem-assign-panel{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.sem-assign-panel--rollback{border-color:#fbbf24}.sem-assign-header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 24px;border-bottom:1px solid var(--border-color);gap:12px}.sem-assign-header h4{font-size:.95rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px;margin-bottom:2px}.sem-assign-header p{font-size:.82rem;color:var(--text-secondary)}.sem-assign-count{font-size:.78rem;font-weight:700;padding:4px 12px;border-radius:var(--radius-full);background:var(--primary-color);color:#fff;white-space:nowrap}.sem-assign-table-wrap{overflow-x:auto}.sem-assign-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border-color)}.sem-check{width:22px;height:22px;border-radius:5px;border:2px solid var(--border-color);background:var(--bg-surface);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s;color:transparent}.sem-check--on{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.sem-check:hover{border-color:var(--primary-light)}.sem-row--deselected td{opacity:.4}.sem-code{background:var(--bg-main);padding:2px 8px;border-radius:4px;font-size:.82rem;font-family:Roboto Mono,Fira Code,monospace}.sem-fac-select{padding:7px 10px;background:var(--bg-main);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:inherit;font-size:.82rem;min-width:180px;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;transition:border-color .2s}.sem-fac-select:focus{border-color:var(--primary-light);outline:none}.sem-fac-select:disabled{opacity:.4;cursor:not-allowed}.sem-loading{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-secondary);margin-top:8px}.sem-loading-lg{display:flex;align-items:center;justify-content:center;gap:10px;padding:60px 20px;color:var(--text-secondary);font-size:.9rem}.spin{animation:loadSpin .7s linear infinite}.sem-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:50px 20px;text-align:center}.sem-empty svg{color:var(--text-secondary)}.sem-empty h4{font-size:1rem;font-weight:600;color:var(--text-primary)}.sem-empty p{font-size:.86rem;color:var(--text-secondary);max-width:360px}.ac-modal-icon--warn{background:#d97706}.sem-confirm-warning{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#fef3c7;border:1px solid #fbbf24;border-radius:var(--radius-sm)}.sem-confirm-warning svg{color:#d97706;flex-shrink:0;margin-top:2px}.sem-confirm-warning p{font-size:.88rem;color:#78350f}.sem-confirm-details{display:flex;flex-direction:column;gap:0;background:var(--bg-main);border-radius:var(--radius-sm);overflow:hidden}.sem-confirm-row{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border-color);font-size:.86rem}.sem-confirm-row:last-child{border-bottom:none}.sem-confirm-row span{color:var(--text-secondary)}.sem-confirm-row strong{color:var(--text-primary)}.sem-success{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-md);padding:40px 24px;text-align:center;animation:fadeIn .35s ease}.sem-success--rollback{background:#fffbeb;border-color:#fde68a}.sem-success__icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.sem-success:not(.sem-success--rollback) .sem-success__icon{background:#d1fae5}.sem-success--rollback .sem-success__icon{background:#fef3c7}.sem-success h3{font-size:1.15rem;font-weight:700;margin-bottom:8px}.sem-success:not(.sem-success--rollback) h3{color:#059669}.sem-success--rollback h3{color:#d97706}.sem-success p{font-size:.88rem;color:#475569;margin-bottom:4px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.ac-tabs{flex-wrap:nowrap}.ac-toolbar{flex-direction:column;align-items:stretch}.ac-form-row{grid-template-columns:1fr}.tt-grid{grid-template-columns:80px repeat(8,minmax(60px,1fr));overflow-x:auto}.ac-stepper{flex-wrap:wrap}.ac-stats{grid-template-columns:1fr 1fr}.ac-header{flex-direction:column;align-items:flex-start}.sem-mode-toggle{width:100%}.sem-mode-btn{flex:1;justify-content:center;font-size:.8rem;padding:8px 12px}.sem-assign-header{flex-direction:column}.sem-fac-select{min-width:140px}.sem-confirm-row{font-size:.8rem}}:root{--primary-color: #1a5632;--primary-light: #2b7a4b;--secondary-color: #f1f8f4;--accent-color: #38a169;--bg-main: #f4f7f6;--bg-surface: #ffffff;--text-primary: #1a202c;--text-secondary: #718096;--text-inverse: #ffffff;--border-color: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px;--transition-speed: .3s}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,sans-serif;background-color:var(--bg-main);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:inherit;border:none;outline:none}.app-container{display:flex;height:100vh;overflow:hidden}.main-content-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg-main)}.page-content{flex:1;overflow-y:auto;padding:2rem}.page-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;background:var(--bg-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);color:var(--text-secondary)}.page-placeholder h2{font-size:2rem;color:var(--primary-light);margin-bottom:1rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-main)}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:var(--primary-color);border-radius:50%;animation:loadSpin .8s linear infinite}@keyframes loadSpin{to{transform:rotate(360deg)}}
