:root{--primary:#2563eb;--primary-rgb:37, 99, 235;--primary-hover:#1d4ed8;--primary-active:#1e40af;--primary-light:#eff6ff;--secondary:#64748b;--secondary-rgb:100, 116, 139;--secondary-hover:#475569;--bg-main:#f8fafc;--bg-card:#fff;--bg-sidebar:#1e293b;--bg-navbar:#fff;--text-main:#0f172a;--text-muted:#64748b;--text-inverse:#fff;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--base-font-size:16px;--sidebar-width:260px;--sidebar-collapsed-width:80px;--navbar-height:70px;--radius:12px;--radius-sm:8px;--radius-lg:16px;--border:#e2e8f0;--border-light:#f1f5f9;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-lg:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}.tabs-container{background:var(--primary);box-shadow:var(--shadow-sm);border-radius:14px;gap:6px;width:fit-content;padding:6px;display:flex}.tab-btn{color:#fffc;cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;padding:10px 20px;font-size:.875rem;font-weight:700;display:flex}.tab-btn:hover{color:#fff;background:#ffffff1a}.tab-btn.active{background:var(--secondary);color:#fff;box-shadow:var(--shadow)}.tab-btn svg{opacity:.8}.tab-btn.active svg{opacity:1}.ribbon-tab-item{color:#ffffffb3;cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:8px 8px 0 0;align-items:center;gap:8px;padding:12px 24px;font-size:.9rem;font-weight:700;display:flex}.ribbon-tab-item:hover{color:#fff;background:#ffffff1a}.ribbon-tab-item.active{background:var(--secondary);color:#fff;box-shadow:0 -2px 10px #0000001a}[data-theme=dark]{--bg-main:#0f172a;--bg-card:#1e293b;--bg-sidebar:#0f172a;--bg-navbar:#1e293b;--text-main:#f8fafc;--text-muted:#94a3b8;--border:#334155;--border-light:#1e293b;--primary-light:#232f491a;--shadow:0 10px 15px -3px #0000004d}*{box-sizing:border-box;margin:0;padding:0}html{font-size:var(--base-font-size);scroll-behavior:smooth}body{background-color:var(--bg-main);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;overflow-x:hidden}.compact-btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:6px;padding:6px 12px;font-size:.875rem;transition:all .2s;display:inline-flex}.btn-primary{background-color:var(--secondary);color:#fff}.btn-primary:hover{background-color:var(--secondary-hover)}.card{background-color:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:0;overflow:hidden}.card-header{background-color:var(--secondary);color:#fff;padding:12px 20px;font-size:1rem;font-weight:700}.card-body{padding:20px}::selection{background-color:var(--secondary);color:#fff}.active-selection{background-color:var(--secondary)!important;color:#fff!important}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.goog-te-gadget-simple{background-color:var(--bg-card)!important;border:1px solid var(--border)!important;border-radius:var(--radius)!important;cursor:pointer!important;align-items:center!important;gap:8px!important;width:100%!important;padding:8px 12px!important;font-family:inherit!important;transition:all .2s!important;display:flex!important}.goog-te-gadget-simple:hover{border-color:var(--primary)!important;box-shadow:0 2px 8px #0000000d!important}.goog-te-gadget-simple img{display:none!important}.goog-te-menu-value span{color:var(--text-main)!important;font-size:.8125rem!important;font-weight:500!important}.goog-te-menu-value span:nth-child(3),.goog-te-menu-value span:nth-child(5){display:none!important}.goog-te-gadget-icon{background-image:none!important;display:none!important}iframe.goog-te-banner-frame{display:none!important}body{top:0!important}#google_translate_element{width:100%}.skiptranslate{width:100%;display:flex!important}.goog-te-menu-frame{border:none!important;border-radius:12px!important;max-width:100%!important;box-shadow:0 10px 40px #0003!important}.goog-te-menu2{background-color:var(--bg-card)!important;border:none!important;max-width:100%!important;padding:10px!important;overflow:auto!important}.goog-logo-link,.goog-te-gadget span{display:none!important}.goog-te-gadget{color:#0000!important;font-size:0!important}.goog-te-gadget .goog-te-combo{border-radius:var(--radius)!important;border:1px solid var(--border)!important;background:var(--bg-card)!important;color:var(--text-main)!important;outline:none!important;width:100%!important;margin:0!important;padding:8px!important}.goog-te-balloon-frame,.goog-te-balloon-frame-main,.goog-te-balloon-frame-content,.goog-tooltip,.goog-tooltip:hover{display:none!important}.goog-text-highlight{box-shadow:none!important;background-color:#0000!important;border:none!important}#goog-gt-tt,.goog-te-balloon-frame,.VIpgJm-ZVi9od-ORHb-nS1RWf{display:none!important}.tab-navigation{background:var(--bg-card);border-bottom:1px solid var(--border);z-index:80;flex-direction:column;padding:0;display:flex}.tab-list{background:var(--bg-main);gap:2px;padding:8px 16px 0;display:flex;overflow-x:auto}.tab-item{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;min-width:120px;max-width:200px;color:var(--text-muted);border-bottom:none;border-radius:8px 8px 0 0;align-items:center;gap:8px;padding:8px 16px;font-size:.8125rem;font-weight:500;transition:all .2s;display:flex;position:relative}.tab-item:hover{background:var(--bg-hover);color:var(--text-main)}.tab-item.active{background:var(--bg-card);color:var(--primary);font-weight:600;box-shadow:0 -2px 10px #00000005}.tab-item.active:after{content:"";background:var(--bg-card);z-index:2;height:2px;position:absolute;bottom:-1px;left:0;right:0}.tab-icon{opacity:.7}.tab-item.active .tab-icon{color:var(--primary);opacity:1}.tab-name{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.tab-close{width:18px;height:18px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;margin-right:-4px;transition:all .2s;display:flex}.tab-close:hover{color:#ef4444;background:#ef44441a}.tab-breadcrumb{color:var(--primary);background:var(--bg-card);border-top:1px solid var(--border);align-items:center;gap:8px;padding:6px 20px;font-size:.75rem;font-weight:600;display:flex}.tab-list::-webkit-scrollbar{height:4px}.tab-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}.toast-container{z-index:11000;pointer-events:none;flex-direction:column;gap:12px;display:flex;position:fixed;top:24px;right:24px}.toast{pointer-events:auto;background:var(--bg-card);-webkit-backdrop-filter:blur(12px);min-width:320px;max-width:450px;box-shadow:var(--shadow);border:1px solid var(--border);border-radius:16px;align-items:center;gap:14px;padding:16px 20px;animation:.4s cubic-bezier(.23,1,.32,1) toastIn;display:flex;position:relative;overflow:hidden}@keyframes toastIn{0%{opacity:0;transform:translate(100%)scale(.9)}to{opacity:1;transform:translate(0)scale(1)}}.toast:before{content:"";border-radius:6px 0 0 6px;width:6px;position:absolute;top:0;bottom:0;left:0}.toast-success:before{background:#10b981}.toast-warning:before{background:#f59e0b}.toast-error:before{background:#ef4444}.toast-info:before{background:#3b82f6}.toast-icon{flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.toast-message{color:var(--text-main);flex:1;font-size:14px;font-weight:600}.toast-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;transition:all .2s;display:flex}.toast-close:hover{background:var(--border);color:var(--text-main);transform:rotate(90deg)}@media (width<=640px){.toast-container{align-items:center;top:16px;left:16px;right:16px}.toast{min-width:100%;max-width:100%}}.login-outer{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;font-family:Inter,system-ui,-apple-system,sans-serif;transition:background 1s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.login-outer.morning{background:linear-gradient(135deg,#ffedd5 0%,#fed7aa 40%,#fdba74 100%)}.login-outer.afternoon{background:linear-gradient(135deg,#e0f2fe 0%,#bae6fd 40%,#7dd3fc 100%)}.login-outer.night{background:linear-gradient(135deg,#090d16 0%,#0f172a 50%,#1e1b4b 100%)}.login-header-nav{text-align:center;z-index:10;flex-direction:column;gap:4px;margin-bottom:24px;display:flex}.login-title-bold{letter-spacing:-.5px;font-size:24px;font-weight:850}.login-subtitle-dim{font-size:14px;font-weight:500}.login-outer.morning .login-title-bold{color:#431407}.login-outer.morning .login-subtitle-dim{color:#78350f}.login-outer.afternoon .login-title-bold{color:#0f172a}.login-outer.afternoon .login-subtitle-dim{color:#1e3a8a}.login-outer.night .login-title-bold{color:#f8fafc}.login-outer.night .login-subtitle-dim{color:#94a3b8}.login-card{z-index:10;border-radius:28px;width:100%;max-width:1050px;min-height:680px;transition:all .5s;display:flex;position:relative;overflow:hidden;box-shadow:0 25px 50px -12px #00000038}.login-card.morning,.login-card.afternoon{-webkit-backdrop-filter:blur(25px);color:#0f172a;background:#ffffffbf;border:1px solid #ffffff73}.login-card.night{-webkit-backdrop-filter:blur(25px);color:#f8fafc;background:#0f172aa6;border:1px solid #ffffff1a}.login-card-left{background-position:50%;background-size:cover;flex:1.2;transition:background-image .8s ease-in-out;position:relative}.login-left-overlay{color:#fff;background:linear-gradient(#0000 0%,#0f172a59 40%,#0f172ae6 100%);flex-direction:column;justify-content:space-between;padding:44px;display:flex;position:absolute;inset:0}.features-badge{-webkit-backdrop-filter:blur(10px);letter-spacing:.5px;background-color:#ffffff1f;border:1px solid #ffffff40;border-radius:20px;align-items:center;width:fit-content;padding:6px 14px;font-size:11px;font-weight:700;display:inline-flex}.school-info-badge{text-align:left;max-width:90%}.school-name-text{letter-spacing:-.5px;text-shadow:0 2px 8px #00000080;margin:0;font-size:34px;font-weight:850;line-height:1.2}.school-quote-text{color:#ffffffe6;text-shadow:0 1px 4px #0006;margin:10px 0 0;font-size:15px;font-style:italic;font-weight:500;line-height:1.5}.login-card-right{flex-direction:column;flex:1;justify-content:center;padding:44px;display:flex;position:relative;overflow-y:auto}.card-top-header{text-align:center;flex-direction:column;align-items:center;margin-bottom:24px;display:flex}.crest-logo-wrapper{margin-bottom:10px}.brand-title{letter-spacing:2px;margin:0 0 8px;font-size:13px;font-weight:800}.login-card.morning .brand-title{color:#7c2d12}.login-card.afternoon .brand-title{color:#1e40af}.login-card.night .brand-title{color:#e2e8f0}.time-greeting{letter-spacing:-1px;margin:0 0 6px;font-size:30px;font-weight:800}.login-card.morning .time-greeting{color:#ea580c}.login-card.afternoon .time-greeting{color:#2563eb}.login-card.night .time-greeting{color:#a78bfa}.time-subtitle{margin:0;font-size:13.5px}.login-card.morning .time-subtitle{color:#7c2d12}.login-card.afternoon .time-subtitle{color:#1e3a8a}.login-card.night .time-subtitle{color:#94a3b8}.theme-quick-switches{background:#0000000d;border-radius:20px;gap:4px;padding:4px;display:flex;position:absolute;top:16px;right:16px}.login-card.night .theme-quick-switches{background:#ffffff14}.switch-btn{cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;transition:all .2s;display:flex}.switch-btn:hover{opacity:1}.switch-btn.active{opacity:1;background:#fff;box-shadow:0 2px 4px #0000001a}.login-card.night .switch-btn.active{background:#fff3}.login-method-section{flex-direction:column;gap:6px;margin-bottom:20px;display:flex}.section-label{letter-spacing:.5px;opacity:.8;text-align:left;font-size:11px;font-weight:700}.login-card.morning .section-label,.login-card.afternoon .section-label{color:#475569}.login-card.night .section-label{color:#94a3b8}.login-methods{gap:8px;display:flex}.login-method-btn{cursor:pointer;color:inherit;background:#ffffff80;border:1.5px solid #00000014;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:700;transition:all .25s;display:flex}.login-card.night .login-method-btn{background:#ffffff08;border-color:#ffffff14}.login-method-btn.is-active{border-color:#0000;color:#fff!important}.login-card.morning .login-method-btn.is-active{background:linear-gradient(135deg,#f97316 0%,#ea580c 100%);box-shadow:0 4px 10px #f9731640}.login-card.afternoon .login-method-btn.is-active{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);box-shadow:0 4px 10px #3b82f640}.login-card.night .login-method-btn.is-active{background:linear-gradient(135deg,#8b5cf6 0%,#7c3aed 100%);box-shadow:0 4px 10px #8b5cf640}.login-field{text-align:left;margin-bottom:16px}.login-label{letter-spacing:.5px;opacity:.8;margin-bottom:6px;font-size:11px;font-weight:700;display:block}.login-input-wrap{position:relative}.login-input{box-sizing:border-box;border-radius:12px;outline:none;width:100%;padding:12px 42px;font-size:14px;transition:all .2s}.login-card.morning .login-input,.login-card.afternoon .login-input{color:#0f172a;background:#fff9;border:1.5px solid #00000014}.login-card.morning .login-input:focus,.login-card.afternoon .login-input:focus{background:#fff;box-shadow:0 0 0 3px #2563eb26}.login-card.morning .login-input:focus{border-color:#ea580c;box-shadow:0 0 0 3px #ea580c26}.login-card.afternoon .login-input:focus{border-color:#2563eb}.login-card.night .login-input{color:#f8fafc;background:#0f172a80;border:1.5px solid #ffffff1a}.login-card.night .login-input:focus{background:#0f172acc;border-color:#a78bfa;box-shadow:0 0 0 3px #a78bfa33}.login-input-icon-left{opacity:.6;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.login-right-icon{opacity:.6;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.toggle-password-btn{color:inherit;opacity:.6;transition:opacity .2s}.toggle-password-btn:hover{opacity:1}.login-options-row{justify-content:space-between;align-items:center;margin-bottom:20px;font-size:13px;display:flex}.remember-me-checkbox{cursor:pointer;align-items:center;gap:8px;font-weight:500;display:flex}.checkbox-input{cursor:pointer;border-radius:4px;width:16px;height:16px}.login-card.morning .checkbox-input{accent-color:#ea580c}.login-card.afternoon .checkbox-input{accent-color:#2563eb}.login-card.night .checkbox-input{accent-color:#a78bfa}.forgot-password-link{font-weight:600;text-decoration:none;transition:opacity .2s}.login-card.morning .forgot-password-link{color:#ea580c}.login-card.afternoon .forgot-password-link{color:#2563eb}.login-card.night .forgot-password-link{color:#a78bfa}.forgot-password-link:hover{opacity:.85}.login-submit{color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:15px;font-weight:700;transition:all .25s;display:flex}.login-submit:hover{transform:translateY(-1px)}.login-submit.morning{background:linear-gradient(90deg,#f97316 0%,#ea580c 100%);box-shadow:0 8px 20px -4px #ea580c59}.login-submit.afternoon{background:linear-gradient(90deg,#3b82f6 0%,#2563eb 100%);box-shadow:0 8px 20px -4px #2563eb59}.login-submit.night{background:linear-gradient(90deg,#8b5cf6 0%,#7c3aed 100%);box-shadow:0 8px 20px -4px #7c3aed59}.login-face-btn{cursor:pointer;background:#00000005;border:1.5px solid #00000014;border-radius:16px;outline:none;justify-content:center;align-items:center;width:100%;transition:all .2s;display:flex}.login-card.night .login-face-btn{background:#ffffff05;border-color:#ffffff1a}.login-face-subtext{font-size:11px}.login-small-hint{opacity:.7;justify-content:center;align-items:center;gap:6px;margin-top:14px;font-size:11px;display:flex}.sso-divider-row{opacity:.5;align-items:center;gap:12px;margin:18px 0 14px;display:flex}.divider-line{background-color:currentColor;flex:1;height:1px}.divider-text{text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.sso-buttons-group{gap:12px;display:flex}.sso-btn{cursor:pointer;background:#fff9;border:1.5px solid #00000014;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:10px;padding:10px 14px;font-size:13px;font-weight:700;transition:all .2s;display:flex}.login-card.night .sso-btn{color:#f8fafc;background:#ffffff08;border-color:#ffffff14}.sso-btn:hover{background:#fff;box-shadow:0 4px 10px #0000000d}.login-card.night .sso-btn:hover{background:#ffffff14}.card-footer-text{text-align:center;opacity:.5;margin-top:20px;font-size:11px}.face-scan-overlay{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.face-scan-frame{border:3px solid #ffffff4d;border-radius:50%;width:180px;height:180px;transition:all .3s;position:relative;box-shadow:0 0 0 1000px #00000080}.face-scan-frame.is-active{border-color:#6366f1;animation:2s infinite pulse-frame;box-shadow:0 0 0 1000px #6366f140}@keyframes pulse-frame{0%{border-color:#6366f180;transform:scale(1)}50%{border-color:#6366f1;transform:scale(1.05)}to{border-color:#6366f180;transform:scale(1)}}.face-scan-frame:after{content:"";background:#10b981;width:100%;height:2px;animation:2s linear infinite scan-line;position:absolute;top:0;left:0;box-shadow:0 0 15px #10b981}@keyframes scan-line{0%{top:0}50%{top:100%}to{top:0}}.animate-pulse{animation:1.5s cubic-bezier(.4,0,.6,1) infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-error{color:#ef4444;text-align:center;background:#ef444414;border:1px solid #ef444433;border-radius:12px;margin-top:10px;padding:12px;font-size:13px;font-weight:500}@media (width<=900px){.login-card-left{display:none}.login-card{max-width:480px;min-height:auto}.login-card-right{padding:30px 24px}}@media (width<=520px){.login-outer{padding:20px 12px}.login-card{border-radius:20px}.time-greeting{font-size:26px}.login-methods{flex-direction:column;gap:6px}.sso-buttons-group{flex-direction:column;gap:8px}.login-submit{padding:12px}}.modal-overlay{z-index:10000;background:#0006;justify-content:center;align-items:center;padding:20px;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-container{border-radius:var(--radius);background:#fff;flex-direction:column;width:100%;max-width:500px;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleUp;display:flex;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}@keyframes scaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{color:#1e293b;margin:0;font-size:18px;font-weight:800}.modal-close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:4px;transition:all .2s}.modal-close-btn:hover{color:#1e293b;background:#f1f5f9}.modal-content{max-height:70vh;padding:24px;overflow-y:auto}.modal-footer{background:#f8fafc;border-top:1px solid #f1f5f9;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.attendance-entry-wrapper{height:calc(100vh - var(--navbar-height) - 40px);grid-template:"header header header""sidebar main stats"1fr/280px 1fr 340px;gap:20px;margin:20px;display:grid;overflow:hidden}.attendance-top-bar{background:linear-gradient(135deg, var(--primary), var(--primary-hover));color:#fff;box-shadow:0 10px 25px -5px rgba(var(--primary-rgb), .2);border-radius:16px;grid-area:header;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.date-display{align-items:center;gap:16px;display:flex}.date-icon{background:#fff3;border-radius:12px;padding:10px}.date-text h2{margin:0;font-size:1.125rem;font-weight:700}.top-actions{align-items:center;gap:12px;display:flex}.search-students{position:relative}.search-students input{color:#fff;background:#ffffff26;border:1px solid #fff3;border-radius:10px;outline:none;width:240px;padding:8px 16px 8px 40px;transition:all .2s}.search-students input::placeholder{color:#fff9}.search-students .icon{opacity:.7;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.classes-sidebar{box-shadow:var(--shadow-sm);background:#fff;border-radius:16px;flex-direction:column;grid-area:sidebar;gap:16px;padding:20px;display:flex;overflow-y:auto}.classes-sidebar h3{color:#1e293b;align-items:center;gap:10px;font-size:1rem;font-weight:700;display:flex}.class-category-item{border:1px solid #f1f5f9;border-radius:12px;margin-bottom:8px;overflow:hidden}.class-category-header{cursor:pointer;background:#f8fafc;justify-content:space-between;align-items:center;padding:12px 16px;transition:all .2s;display:flex}.class-category-header:hover{background:#f1f5f9}.class-category-header.active{color:#4f46e5;background:#4f46e50d}.sub-classes{background:#fff;padding:4px}.sub-class-btn{text-align:left;cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:8px;justify-content:space-between;align-items:center;width:100%;padding:10px 16px;font-size:.875rem;font-weight:500;display:flex}.sub-class-btn:hover{background:#f8fafc}.sub-class-btn.active{color:#fff;background:#4f46e5}.attendance-main-view{box-shadow:var(--shadow-sm);background:#fff;border-radius:16px;flex-direction:column;grid-area:main;display:flex;overflow:hidden}.main-view-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.main-view-header h2{color:#1e293b;font-size:1.25rem;font-weight:800}.table-container{flex:1;overflow-y:auto}.attendance-table{border-collapse:collapse;width:100%}.attendance-table th{text-align:left;color:#64748b;text-transform:uppercase;z-index:10;background:#f8fafc;border-bottom:1px solid #f1f5f9;padding:12px 20px;font-size:.75rem;font-weight:700;position:sticky;top:0}.attendance-table td{border-bottom:1px solid #f1f5f9;padding:16px 20px}.student-name-cell{align-items:center;gap:12px;display:flex}.student-avatar{object-fit:cover;border-radius:50%;width:40px;height:40px}.student-info h4{margin:0;font-size:.9375rem;font-weight:700}.student-info p{color:#64748b;margin:0;font-size:.75rem}.attendance-actions{gap:8px;display:flex}.att-btn{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;min-width:44px;height:36px;padding:4px;font-size:.75rem;font-weight:700;transition:all .2s;display:flex}.att-btn span{opacity:.8;font-size:.625rem;font-weight:500}.att-btn:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a}.stats-sidebar{flex-direction:column;grid-area:stats;gap:20px;display:flex;overflow-y:auto}.stat-panel{box-shadow:var(--shadow-sm);background:#fff;border-radius:16px;padding:20px}.stat-panel h3{color:#1e293b;margin-bottom:20px;font-size:1rem;font-weight:700}.summary-content{align-items:center;gap:20px;display:flex}.donut-chart-container{width:140px;height:140px;position:relative}.donut-label{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.donut-label h2{margin:0;font-size:1.5rem;font-weight:800}.donut-label p{color:#64748b;margin:0;font-size:.75rem}.summary-stats{flex:1;grid-template-columns:1fr;gap:12px;display:grid}.summary-item{background:#f8fafc;border-radius:12px;justify-content:space-between;align-items:center;padding:12px;display:flex}.summary-info{align-items:center;gap:10px;display:flex}.summary-info .dot{border-radius:50%;width:10px;height:10px}.summary-info span{color:#64748b;font-size:.8125rem;font-weight:600}.summary-value{font-size:1rem;font-weight:700}.gender-breakdown{grid-template-columns:1fr 1fr;gap:16px;display:grid}.gender-card{border:1px solid #f1f5f9;border-radius:16px;padding:16px}.gender-card.boys{background:#eff6ff}.gender-card.girls{background:#fdf2f8}.gender-header{align-items:center;gap:8px;margin-bottom:12px;font-size:.75rem;font-weight:600;display:flex}.gender-val{margin-bottom:4px;font-size:1.25rem;font-weight:800}.gender-progress{background:#0000000d;border-radius:3px;height:6px;overflow:hidden}.gender-bar{height:100%}@media (width<=1400px){.attendance-entry-wrapper{grid-template-columns:240px 1fr 300px}}@media (width<=1200px){.attendance-entry-wrapper{grid-template-columns:200px 1fr;grid-template-areas:"header header""sidebar main""stats stats";height:auto;overflow-y:auto}.stats-sidebar{grid-template-columns:1fr 1fr;display:grid}}@media (width<=768px){.attendance-entry-wrapper{grid-template-columns:1fr;grid-template-areas:"header""sidebar""main""stats"}.stats-sidebar{grid-template-columns:1fr}.attendance-top-bar{flex-direction:column;align-items:stretch;gap:16px}.top-actions{flex-direction:column}.search-students input{width:100%}}.report-page-wrapper{min-height:calc(100vh - var(--navbar-height));background-color:var(--bg-main);flex-direction:column;gap:24px;width:100%;max-width:1600px;margin:0 auto;padding:24px;display:flex}.report-top-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.header-info h1{color:var(--text-main);margin:0;font-size:1.5rem;font-weight:700}.header-info p{color:var(--text-muted);margin:4px 0 0;font-size:.875rem}.btn-primary,.btn-secondary,.btn-generate{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 18px;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-secondary{border:1px solid var(--border);color:var(--text-main);background:#fff}.btn-secondary:hover{background:var(--bg-main)}.btn-generate{background:var(--secondary);color:#fff;justify-content:center;width:100%;margin-top:10px;padding:12px}.report-stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;display:grid}.stat-card-premium{box-shadow:var(--shadow-sm);border:1px solid var(--border-light);background:#fff;border-radius:16px;align-items:center;gap:16px;padding:20px;display:flex}.stat-icon-wrap{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-label{color:var(--text-muted);margin:0;font-size:.8125rem;font-weight:600}.stat-value{color:var(--text-main);margin:2px 0;font-size:1.5rem;font-weight:700}.stat-sub{color:var(--text-muted);margin:0;font-size:.75rem}.report-main-layout{grid-template-columns:320px 1fr;align-items:start;gap:24px;display:grid}.report-sidebar{flex-direction:column;gap:20px;display:flex;position:sticky;top:24px}.sidebar-section{box-shadow:var(--shadow-sm);border:1px solid var(--border-light);background:#fff;border-radius:16px;padding:20px}.sidebar-section.border-top{border-top:1px solid var(--border)}.sidebar-section h4{color:var(--text-main);text-transform:uppercase;letter-spacing:.02em;margin:0 0 16px;font-size:.9375rem;font-weight:700}.report-type-btns{flex-direction:column;gap:6px;display:flex}.type-btn{color:var(--text-main);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;padding:10px 14px;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.type-btn:hover{background:var(--bg-main)}.type-btn.active{background:var(--primary-light);color:var(--primary)}.filter-inputs{flex-direction:column;gap:16px;display:flex}.input-group{flex-direction:column;gap:6px;display:flex}.input-group label{color:var(--text-muted);font-size:.75rem;font-weight:600}.input-group input,.input-group select{border:1px solid var(--border);background:#fff;border-radius:10px;outline:none;padding:10px 12px;font-size:.875rem}.relative-input{position:relative}.input-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.relative-input input{padding-left:36px}.grid-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.class-display{background:var(--bg-main);color:var(--text-main);border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:.875rem;font-weight:600}.search-wrapper{margin-bottom:12px;position:relative}.search-wrapper input{border:1px solid var(--border);background:var(--bg-main);border-radius:8px;width:100%;padding:8px 10px 8px 32px;font-size:.8125rem}.class-tree{max-height:300px;overflow-y:auto}.node-header{cursor:pointer;border-radius:6px;justify-content:space-between;align-items:center;padding:8px 10px;transition:background .2s;display:flex}.node-header:hover{background:var(--bg-main)}.node-title{align-items:center;gap:8px;font-size:.8125rem;font-weight:600;display:flex}.node-count{background:var(--border-light);color:var(--text-muted);border-radius:10px;padding:2px 6px;font-size:.6875rem}.node-children{border-left:1px solid var(--border);flex-direction:column;gap:2px;margin-top:4px;margin-left:14px;padding-left:10px;display:flex}.child-btn{text-align:left;cursor:pointer;width:100%;color:var(--text-muted);background:0 0;border:none;border-radius:4px;padding:6px 10px;font-size:.75rem}.child-btn:hover{background:var(--bg-main)}.child-btn.active{background:var(--primary-light);color:var(--primary);font-weight:700}.report-main-content{min-width:0}.report-data-card{box-shadow:var(--shadow-sm);border:1px solid var(--border-light);background:#fff;border-radius:16px;flex-direction:column;min-height:600px;display:flex;overflow:hidden}.card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.card-header h3{margin:0;font-size:1.125rem;font-weight:700}.record-count{color:var(--text-muted);font-size:.75rem}.table-viewport{flex:1;overflow:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{background:var(--bg-main);text-align:left;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);z-index:10;padding:14px 20px;font-size:.75rem;font-weight:700;position:sticky;top:0}.data-table td{border-bottom:1px solid var(--border-light);color:var(--text-main);padding:14px 20px;font-size:.875rem}.loading-state{height:400px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.empty-state-view{text-align:center;height:400px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex}.empty-icon{opacity:.1;margin-bottom:20px}.badge.present{color:#059669;background:#ecfdf5}.badge.absent{color:#dc2626;background:#fef2f2}.badge.warning{color:#d97706;background:#fffbeb}@media (width<=1200px){.report-main-layout{grid-template-columns:1fr}.report-sidebar{position:static}}@media (width<=768px){.report-page-wrapper{padding:16px}.report-top-header{flex-direction:column;align-items:stretch}.header-actions{flex-direction:column}.report-stats-grid{grid-template-columns:1fr 1fr}}@media (width<=480px){.report-stats-grid{grid-template-columns:1fr}}.animate-spin{animation:1s linear infinite spin}.offcanvas{z-index:2000;visibility:hidden;width:100%;height:100%;transition:right .3s ease-in-out;display:flex;position:fixed;top:0;right:-100%}.offcanvas.open{visibility:visible;right:0}.offcanvas-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;width:100%;height:100%;position:absolute;top:0;left:0}.offcanvas-content{background:#fff;flex-direction:column;width:90%;max-width:1100px;height:100%;margin-left:auto;display:flex;position:relative;box-shadow:-10px 0 30px #0000001a}.offcanvas-body{flex:1;padding:30px;overflow-y:auto}.close-btn{background:var(--bg-main);cursor:pointer;width:36px;height:36px;color:var(--text-muted);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:24px;display:flex}.close-btn:hover{color:#fff;background:#ef4444}.calendar-report-view{flex-direction:column;gap:30px;display:flex}.calendar-report-header{justify-content:space-between;align-items:center;display:flex}.student-profile-mini{align-items:center;gap:16px;display:flex}.profile-icon{background:var(--primary-light);width:56px;height:56px;color:var(--primary);border-radius:14px;justify-content:center;align-items:center;display:flex}.profile-details h3{margin:0;font-size:1.25rem}.profile-details span{color:var(--text-muted);font-size:.875rem}.calendar-table{border-collapse:collapse;width:100%;font-size:.8125rem}.calendar-table th,.calendar-table td{border:1px solid var(--border);text-align:center;min-width:32px;padding:10px 4px}.calendar-table th{background:var(--bg-main);color:var(--text-muted);font-weight:700}.calendar-table .month-name{background:var(--bg-main);font-weight:700}.calendar-table .count-cell{font-weight:700}.calendar-table .count-cell.present{color:#10b981}.calendar-table .count-cell.absent{color:#ef4444}.calendar-legend{background:var(--bg-main);border-radius:12px;flex-wrap:wrap;gap:24px;padding:20px;font-size:.875rem;display:flex}.legend-item .code{border:1px solid var(--border);background:#fff;border-radius:4px;padding:2px 6px;font-weight:800}:root{--erp-primary:#4f46e5;--erp-primary-rgb:79, 70, 229;--erp-primary-hover:#4338ca;--erp-secondary:#0f172a;--erp-accent:#10b981;--erp-bg:#f8fafc;--erp-card-bg:#fff;--erp-text-main:#0f172a;--erp-text-muted:#64748b;--erp-border:#e2e8f0;--erp-border-focus:#c7d2fe;--erp-shadow-soft:0 4px 20px #00000008, 0 2px 8px #00000005;--erp-shadow-premium:0 20px 40px #4f46e50f, 0 10px 20px #00000008;--erp-radius:12px;--erp-radius-lg:16px;--erp-radius-sm:8px}.td-app-container{background-color:var(--erp-bg);width:100%;height:100vh;color:var(--erp-text-main);flex-direction:column;font-family:Inter,-apple-system,sans-serif;display:flex;overflow:hidden}.td-hidden-file-input{display:none}.glass-panel{-webkit-backdrop-filter:blur(12px);box-shadow:var(--erp-shadow-soft);background:#ffffffd9;border:1px solid #ffffff80}.glass-card{-webkit-backdrop-filter:blur(8px);border-radius:var(--erp-radius);background:#ffffffb3;border:1px solid #fff6;transition:all .25s}.glass-card:hover{background:#fffffff2;transform:translateY(-2px);box-shadow:0 12px 24px #4f46e514}.td-erp-header{background:var(--erp-card-bg);border-bottom:1px solid var(--erp-border);justify-content:space-between;align-items:center;padding:12px 24px;display:flex;box-shadow:0 1px 3px #00000003}.td-header-left{align-items:center;gap:14px;display:flex}.td-logo-shield{background:linear-gradient(135deg, var(--erp-primary), #6366f1);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 4px 10px #4f46e540}.td-header-titles{flex-direction:column;display:flex}.td-header-titles h1{letter-spacing:-.02em;color:var(--erp-text-main);align-items:center;gap:8px;margin:0;font-size:1.15rem;font-weight:800;display:flex}.td-header-titles span{color:var(--erp-text-muted);font-size:.75rem;font-weight:500}.td-header-middle{align-items:center;gap:16px;display:flex}.td-template-name-wrapper{border-radius:var(--erp-radius-sm);background:#f1f5f9;border:1px solid #0000;align-items:center;gap:8px;padding:6px 12px;transition:all .2s;display:flex}.td-template-name-wrapper:focus-within{border-color:var(--erp-primary);background:#fff;box-shadow:0 0 0 3px #4f46e526}.td-template-name-wrapper input{color:var(--erp-text-main);background:0 0;border:none;outline:none;width:140px;font-size:.85rem;font-weight:600}.td-template-name-wrapper svg{color:var(--erp-text-muted);cursor:pointer}.td-header-dropdown-group{flex-direction:column;gap:2px;display:flex}.td-header-dropdown-group label{color:var(--erp-text-muted);text-transform:uppercase;font-size:.65rem;font-weight:700}.td-header-dropdown-group select{border-radius:var(--erp-radius-sm);border:1px solid var(--erp-border);color:var(--erp-text-main);cursor:pointer;background-color:#fff;outline:none;min-width:120px;padding:6px 12px;font-size:.8rem;font-weight:600;transition:all .2s}.td-header-dropdown-group select:focus{border-color:var(--erp-primary);box-shadow:0 0 0 3px #4f46e526}.td-header-right{align-items:center;gap:8px;display:flex}.td-icon-btn{border-radius:var(--erp-radius-sm);border:1px solid var(--erp-border);width:34px;height:34px;color:var(--erp-text-main);cursor:pointer;background:#fff;justify-content:center;align-items:center;transition:all .2s;display:flex}.td-icon-btn:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.td-icon-btn:disabled{opacity:.4;cursor:not-allowed}.td-preview-btn{border-radius:var(--erp-radius-sm);border:1px solid var(--erp-border);height:34px;color:var(--erp-text-main);cursor:pointer;background:#fff;align-items:center;gap:6px;padding:0 14px;font-size:.8rem;font-weight:600;transition:all .2s;display:flex}.td-preview-btn:hover{background:#f1f5f9}.td-save-btn-group{border-radius:var(--erp-radius-sm);align-items:center;display:flex;overflow:hidden;box-shadow:0 4px 12px #4f46e533}.td-main-save-btn{background:var(--erp-primary);color:#fff;cursor:pointer;border:none;align-items:center;gap:8px;height:34px;padding:0 16px;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.td-main-save-btn:hover{background:var(--erp-primary-hover)}.td-split-arrow-btn{background:var(--erp-primary);color:#fff;cursor:pointer;border:none;border-left:1px solid #fff3;justify-content:center;align-items:center;width:28px;height:34px;transition:all .2s;display:flex}.td-split-arrow-btn:hover{background:var(--erp-primary-hover)}.td-ribbon-bar{background:var(--erp-card-bg);border-bottom:1px solid var(--erp-border);flex-direction:column;display:flex;box-shadow:0 2px 8px #00000005}.td-ribbon-tabs-row{background:#fafafa;border-bottom:1px solid #f1f5f9;align-items:center;padding:0 20px;display:flex}.td-ribbon-tab{color:var(--erp-text-muted);cursor:pointer;border-bottom:2px solid #0000;padding:10px 18px;font-size:.825rem;font-weight:700;transition:all .2s;position:relative;top:1px}.td-ribbon-tab:hover{color:var(--erp-text-main)}.td-ribbon-tab.active{color:var(--erp-primary);border-bottom-color:var(--erp-primary)}.td-ribbon-tools-content{background:#fff;align-items:stretch;gap:16px;height:86px;padding:6px 16px;display:flex;overflow-x:auto}.td-ribbon-group{border-right:1px solid #f1f5f9;flex-direction:column;justify-content:space-between;align-items:center;padding-right:16px;display:flex;position:relative}.td-ribbon-group:last-child{border-right:none;padding-right:0}.td-ribbon-group-items{flex:1;align-items:center;gap:8px;display:flex}.td-ribbon-group-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-size:.625rem;font-weight:800}.td-ribbon-btn{border-radius:var(--erp-radius-sm);cursor:pointer;width:62px;height:58px;color:var(--erp-text-main);background:0 0;border:1px solid #0000;flex-direction:column;justify-content:center;align-items:center;padding:4px;transition:all .15s;display:flex}.td-ribbon-btn:hover{background:#f1f5f9;border-color:#e2e8f0}.td-ribbon-btn:active{background:#e2e8f0}.td-ribbon-btn.active{color:var(--erp-primary);background:#4f46e514;border-color:#4f46e533}.td-ribbon-btn svg{color:#334155;margin-bottom:3px;transition:color .15s}.td-ribbon-btn:hover svg,.td-ribbon-btn.active svg{color:var(--erp-primary)}.td-ribbon-btn span{text-align:center;word-break:break-word;font-size:.625rem;font-weight:600;line-height:1.1}.td-ribbon-checkbox-group{flex-direction:column;justify-content:center;gap:4px;padding:0 4px;display:flex}.td-ribbon-checkbox-label{color:var(--erp-text-main);cursor:pointer;align-items:center;gap:6px;font-size:.725rem;font-weight:600;display:flex}.td-ribbon-checkbox-label input{cursor:pointer;accent-color:var(--erp-primary);width:13px;height:13px}.td-ribbon-help-card{border:1px dashed var(--erp-border);border-radius:var(--erp-radius-sm);background:#f8fafc;align-items:center;gap:10px;max-width:180px;padding:8px 14px;display:flex}.td-ribbon-help-text{flex-direction:column;display:flex}.td-ribbon-help-text h4{color:var(--erp-text-main);margin:0;font-size:.725rem;font-weight:700}.td-ribbon-help-text span{color:var(--erp-text-muted);font-size:.625rem}.td-ribbon-help-play-btn{background:var(--erp-primary);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:flex;box-shadow:0 2px 6px #4f46e533}.td-ribbon-status{color:#10b981;border-radius:var(--erp-radius-sm);background:#ecfdf5;align-items:center;gap:6px;padding:6px 12px;font-size:.7rem;font-weight:700;display:flex}.td-app-body{flex:1;display:flex;position:relative;overflow:hidden}.td-sidebar{background:var(--erp-card-bg);border-right:1px solid var(--erp-border);flex-direction:column;width:280px;display:flex;overflow-y:auto}.td-sidebar-section{border-bottom:1px solid #f1f5f9;padding:16px}.td-sidebar-section:last-child{border-bottom:none}.td-sidebar-section-title{color:var(--erp-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;font-size:.725rem;font-weight:800}.td-pages-list{flex-direction:column;gap:12px;display:flex}.td-page-card-item{cursor:pointer;align-items:center;gap:12px;display:flex}.td-page-card-thumbnail-wrapper{border-radius:var(--erp-radius-sm);border:1px solid var(--erp-border);width:100px;height:64px;box-shadow:var(--erp-shadow-soft);background:#f8fafc;transition:all .2s;position:relative;overflow:hidden}.td-page-card-item:hover .td-page-card-thumbnail-wrapper{border-color:var(--erp-primary-focus);transform:scale(1.02)}.td-page-card-item.active .td-page-card-thumbnail-wrapper{border-color:var(--erp-primary);box-shadow:0 0 0 3px #4f46e526}.td-page-card-number-tag{color:#fff;z-index:5;background:#0f172acc;border-radius:3px;justify-content:center;align-items:center;width:14px;height:14px;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:4px;left:4px}.td-page-card-thumbnail-preview{transform-origin:0 0;pointer-events:none;width:100%;height:100%;transform:scale(.23)}.td-page-card-info{flex-direction:column;display:flex}.td-page-card-title{color:var(--erp-text-main);font-size:.775rem;font-weight:700}.td-page-card-item.active .td-page-card-title{color:var(--erp-primary)}.td-page-card-dims{color:var(--erp-text-muted);font-size:.65rem}.td-add-page-btn{border:1.5px dashed var(--erp-border);border-radius:var(--erp-radius-sm);width:100%;color:var(--erp-primary);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:.775rem;font-weight:700;transition:all .2s;display:flex}.td-add-page-btn:hover{border-color:var(--erp-primary);background:#4f46e508}.td-search-box{border:1px solid var(--erp-border);border-radius:var(--erp-radius-sm);background:#f1f5f9;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;display:flex}.td-search-box input{color:var(--erp-text-main);background:0 0;border:none;outline:none;width:100%;font-size:.8rem}.td-search-box svg{color:var(--erp-text-muted)}.td-fields-grid{flex-direction:column;gap:6px;max-height:240px;padding-right:4px;display:flex;overflow-y:auto}.td-field-pill-btn{border-radius:var(--erp-radius-sm);border:1px solid var(--erp-border);cursor:pointer;color:var(--erp-text-main);background:#fff;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.775rem;transition:all .15s;display:flex}.td-field-pill-btn:hover{border-color:var(--erp-primary-focus);background:#f8fafc;transform:translate(2px)}.td-field-pill-left{align-items:center;gap:8px;display:flex}.td-field-pill-left svg{color:var(--erp-primary)}.td-field-pill-left span{font-weight:600}.td-field-pill-tag{color:var(--erp-text-muted);font-size:.65rem;font-weight:500}.td-view-all-fields-btn{border:1px solid var(--erp-border);border-radius:var(--erp-radius-sm);width:100%;color:var(--erp-text-main);cursor:pointer;background:#f8fafc;justify-content:space-between;align-items:center;margin-top:10px;padding:10px 12px;font-size:.775rem;font-weight:700;transition:all .2s;display:flex}.td-view-all-fields-btn:hover{background:#f1f5f9}.td-center-workspace{background:#e2e8f0;flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.td-canvas-floating-toolbar{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe6;border:1px solid #fff6;border-radius:30px;align-items:center;gap:2px;padding:4px 8px;display:flex;position:absolute;top:16px;left:50%;transform:translate(-50%);box-shadow:0 10px 25px #0f172a14}.td-toolbar-tool-btn{width:32px;height:32px;color:var(--erp-text-main);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.td-toolbar-tool-btn:hover{background:#e2e8f0}.td-toolbar-tool-btn.active{background:var(--erp-primary);color:#fff}.td-toolbar-divider{background:var(--erp-border);width:1px;height:18px;margin:0 6px}.td-ruler-layout-container{flex:1;justify-content:center;align-items:center;margin-top:50px;margin-bottom:164px;padding:40px;display:flex;position:relative;overflow:auto}.td-ruler-corner{border-right:1px solid var(--erp-border);border-bottom:1px solid var(--erp-border);z-index:80;background:#f1f5f9;width:25px;height:25px;position:absolute;top:0;left:0}.td-ruler-horizontal{border-bottom:1px solid var(--erp-border);z-index:80;background:#f8fafc;height:25px;position:absolute;top:0;left:25px;right:0;overflow:hidden}.td-horizontal-ticks-wrapper{height:100%;position:relative}.td-ruler-tick-h{background-color:#94a3b8;width:1px;position:absolute;bottom:0}.td-ruler-tick-h.major{height:12px}.td-ruler-tick-h.medium{height:8px}.td-ruler-tick-h.minor{height:4px}.td-ruler-label-h{color:var(--erp-text-muted);font-size:.55rem;font-weight:700;position:absolute;top:2px;transform:translate(-50%)}.td-ruler-vertical{border-right:1px solid var(--erp-border);z-index:80;background:#f8fafc;width:25px;position:absolute;top:25px;bottom:0;left:0;overflow:hidden}.td-vertical-ticks-wrapper{width:100%;height:100%;position:relative}.td-ruler-tick-v{background-color:#94a3b8;height:1px;position:absolute;right:0}.td-ruler-tick-v.major{width:12px}.td-ruler-tick-v.medium{width:8px}.td-ruler-tick-v.minor{width:4px}.td-ruler-label-v{color:var(--erp-text-muted);font-size:.55rem;font-weight:700;position:absolute;left:2px;transform:translateY(-50%)}.td-card-viewport-wrapper{perspective:1200px;z-index:50;position:relative}.td-card-canvas-container{width:428px;height:270px;transform-style:preserve-3d;-webkit-user-select:none;user-select:none;background:#fff;border-radius:12px;transition:transform .6s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 15px 40px #0f172a1f}.td-card-canvas-container.flipped{transform:rotateY(180deg)}.td-card-face{backface-visibility:hidden;border-radius:12px;width:100%;height:100%;position:absolute;top:0;left:0;overflow:hidden}.td-card-face-front{z-index:2}.td-card-face-back{z-index:1;transform:rotateY(180deg)}.td-canvas-grid-lines{pointer-events:none;z-index:4;background-image:linear-gradient(90deg,#0000000d 1px,#0000 1px),linear-gradient(#0000000d 1px,#0000 1px);background-size:10px 10px;width:100%;height:100%;position:absolute;top:0;left:0}.td-canvas-margin-guide{pointer-events:none;z-index:4;border:1px dashed #4f46e540;border-radius:6px;position:absolute;inset:15px}.td-canvas-element{cursor:pointer;z-index:10;transform-origin:0 0;align-items:center;display:flex;position:absolute}.td-canvas-element:after{content:"";pointer-events:none;border:1px dashed #0000;border-radius:4px;transition:all .1s;position:absolute;inset:-4px}.td-canvas-element:hover:after{border-color:#4f46e559}.td-canvas-element.selected:after{border-color:var(--erp-primary);border-style:solid;box-shadow:0 0 0 1px #fff,0 4px 12px #4f46e51a}.td-resize-handle{background:var(--erp-primary);cursor:nwse-resize;z-index:50;border:1px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;bottom:-8px;right:-8px;box-shadow:0 2px 4px #00000026}.td-element-text-content{white-space:pre-wrap;width:100%;font-family:inherit;line-height:1.2}.td-element-logo-img{object-fit:contain;width:100%;height:100%}.td-saved-template-strip{border-top:1px solid var(--erp-border);z-index:88;background:#fffffff5;grid-template-columns:170px 1fr;align-items:stretch;height:100px;display:grid;position:absolute;bottom:64px;left:0;right:0}.td-saved-template-strip-header{border-right:1px solid var(--erp-border);background:#f8fafc;flex-direction:column;justify-content:space-between;padding:12px 16px;display:flex}.td-saved-template-title{color:var(--erp-text-main);font-size:.78rem;font-weight:850;display:block}.td-saved-template-count{color:var(--erp-text-muted);margin-top:3px;font-size:.66rem;font-weight:700;display:block}.td-saved-template-refresh{border:1px solid var(--erp-border);height:28px;color:var(--erp-text-main);border-radius:var(--erp-radius-sm);cursor:pointer;background:#fff;justify-content:center;align-items:center;gap:6px;font-size:.72rem;font-weight:750;display:inline-flex}.td-saved-template-refresh:hover:not(:disabled){border-color:var(--erp-primary);color:var(--erp-primary)}.td-saved-template-refresh:disabled{opacity:.55;cursor:not-allowed}.td-saved-template-cards{align-items:center;gap:10px;padding:10px 14px;display:flex;overflow:auto hidden}.td-saved-template-card{border:1px solid var(--erp-border);border-radius:var(--erp-radius-sm);text-align:left;cursor:pointer;height:78px;box-shadow:var(--erp-shadow-soft);background:#fff;flex:0 0 188px;grid-template-columns:58px 1fr;align-items:center;gap:10px;padding:8px;transition:all .18s;display:grid;position:relative}.td-saved-template-card:hover{border-color:var(--erp-primary);transform:translateY(-1px);box-shadow:0 8px 18px #4f46e51f}.td-saved-template-card.active{border-color:var(--erp-primary);box-shadow:0 0 0 2px #4f46e526}.td-saved-template-card.disabled{opacity:.72}.td-saved-template-thumb{background:#e2e8f0;border-radius:5px;justify-content:center;align-items:center;width:58px;height:38px;display:flex;overflow:hidden}.td-saved-template-mini-card{background:#fff;border:1px solid #cbd5e1;border-radius:4px;width:52px;height:32px;position:relative;overflow:hidden}.td-saved-template-mini-card:after{content:"";background:#1e40af;border-radius:50%;width:38px;height:38px;position:absolute;bottom:-14px;right:-10px}.td-saved-template-mini-line{z-index:1;background:#94a3b8;border-radius:2px;width:22px;height:3px;position:absolute;left:21px}.td-saved-template-mini-line.wide{background:#4f46e5;width:30px;top:6px;left:7px}.td-saved-template-mini-line:not(.wide):not(.short){top:17px}.td-saved-template-mini-line.short{width:16px;top:23px}.td-saved-template-mini-avatar{z-index:1;background:#f59e0b;border-radius:50%;width:10px;height:10px;position:absolute;top:15px;left:7px}.td-saved-template-info{flex-direction:column;gap:4px;min-width:0;display:flex}.td-saved-template-name{color:var(--erp-text-main);white-space:nowrap;text-overflow:ellipsis;font-size:.76rem;font-weight:800;overflow:hidden}.td-saved-template-meta{color:var(--erp-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.64rem;font-weight:650;overflow:hidden}.td-saved-template-badge{color:#92400e;background:#fef3c7;border:1px solid #fde68a;border-radius:999px;padding:2px 5px;font-size:.58rem;font-weight:800;position:absolute;top:6px;right:6px}.td-saved-template-empty{color:var(--erp-text-muted);padding:16px;font-size:.76rem;font-weight:700}.td-uploaded-template-image{object-fit:cover;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;display:block}.td-element-photo-wrapper{background:#f1f5f9;justify-content:center;align-items:center;width:100%;height:100%;transition:clip-path .2s;display:flex;overflow:hidden}.td-element-photo-wrapper img{object-fit:cover;width:100%;height:100%}.td-shape-circle{border-radius:50%}.td-shape-rounded{border-radius:12%}.td-shape-square{border-radius:0}.td-shape-hexagon{clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%)}.td-barcode-render{background:#fff;border-radius:2px;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:3px;display:flex}.td-barcode-lines{flex:1;justify-content:space-between;align-items:stretch;width:100%;display:flex}.td-barcode-bar{background:#000;width:2px}.td-barcode-bar.thin{width:1px}.td-barcode-bar.thick{width:3px}.td-barcode-bar.spaced{background:0 0}.td-barcode-label{color:#000;letter-spacing:2px;margin-top:2px;font-size:6px;font-weight:700}.td-workspace-bottom-bar{background:var(--erp-card-bg);border-top:1px solid var(--erp-border);z-index:90;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;position:absolute;bottom:0;left:0;right:0}.td-student-preview-picker{align-items:center;gap:12px;display:flex}.td-student-preview-picker span{color:var(--erp-text-muted);text-transform:uppercase;font-size:.775rem;font-weight:800}.td-student-picker-dropdown{border:1px solid var(--erp-border);border-radius:var(--erp-radius-sm);cursor:pointer;color:var(--erp-text-main);background:#f8fafc;align-items:center;gap:8px;min-width:220px;padding:6px 12px;font-size:.8rem;font-weight:600;display:flex;position:relative}.td-student-picker-dropdown-img{object-fit:cover;border:1px solid var(--erp-border);border-radius:50%;width:22px;height:22px}.td-student-picker-popover{border:1px solid var(--erp-border);border-radius:var(--erp-radius-sm);z-index:200;background:#fff;width:100%;margin-bottom:6px;position:absolute;bottom:100%;left:0;box-shadow:0 -4px 20px #00000014}.td-student-picker-option{cursor:pointer;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.td-student-picker-option:hover{background:#f1f5f9}.td-student-picker-option-info{flex-direction:column;display:flex}.td-student-picker-option-name{font-size:.775rem;font-weight:700}.td-student-picker-option-meta{color:var(--erp-text-muted);font-size:.65rem}.td-preview-control-btns{align-items:center;gap:8px;display:flex}.td-preview-solid-btn{border-radius:var(--erp-radius-sm);background:var(--erp-primary);color:#fff;cursor:pointer;border:none;align-items:center;gap:6px;height:34px;padding:0 16px;font-size:.8rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 3px 8px #4f46e526}.td-preview-solid-btn:hover{background:var(--erp-primary-hover)}.td-preview-outline-btn{border-radius:var(--erp-radius-sm);border:1px solid var(--erp-border);height:34px;color:var(--erp-text-main);cursor:pointer;background:#fff;align-items:center;gap:6px;padding:0 16px;font-size:.8rem;font-weight:600;transition:all .2s;display:flex}.td-preview-outline-btn:hover{background:#f1f5f9}.td-properties-panel{background:var(--erp-card-bg);border-left:1px solid var(--erp-border);flex-direction:column;width:300px;display:flex;overflow:hidden}.td-properties-panel-header{border-bottom:1px solid #f1f5f9;padding:16px}.td-properties-title-row{color:var(--erp-text-muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:8px;margin-bottom:14px;font-size:.725rem;font-weight:800;display:flex}.td-properties-title-row svg{color:var(--erp-primary)}.td-selected-element-selector{border-radius:var(--erp-radius-sm);border:1px solid var(--erp-border);background:#f8fafc;align-items:center;gap:10px;padding:8px 12px;font-size:.8rem;font-weight:600;display:flex}.td-selected-element-selector svg{color:var(--erp-text-muted)}.td-prop-tabs-row{border-bottom:1px solid var(--erp-border);background:#fafafa;display:flex}.td-prop-tab{text-align:center;color:var(--erp-text-muted);cursor:pointer;border-bottom:2px solid #0000;flex:1;padding:10px 0;font-size:.775rem;font-weight:700;transition:all .2s}.td-prop-tab:hover{color:var(--erp-text-main)}.td-prop-tab.active{color:var(--erp-primary);border-bottom-color:var(--erp-primary);background:#fff}.td-properties-content{flex-direction:column;flex:1;gap:18px;padding:16px;display:flex;overflow-y:auto}.td-field-group{flex-direction:column;gap:6px;display:flex}.td-field-group label{color:var(--erp-text-muted);text-transform:uppercase;letter-spacing:.02em;font-size:.7rem;font-weight:800}.td-field-select{border-radius:var(--erp-radius-sm);border:1px solid var(--erp-border);color:var(--erp-text-main);cursor:pointer;background-color:#fff;outline:none;padding:8px 12px;font-size:.8rem;font-weight:600}.td-field-select:focus{border-color:var(--erp-primary)}.td-shape-selector-row{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.td-shape-btn{border-radius:var(--erp-radius-sm);border:1px solid var(--erp-border);cursor:pointer;background:#fff;justify-content:center;align-items:center;height:38px;transition:all .15s;display:flex}.td-shape-btn:hover{border-color:var(--erp-primary-focus)}.td-shape-btn.active{border-color:var(--erp-primary);background:#4f46e50d;box-shadow:0 0 0 2px #4f46e526}.td-shape-icon-inner{border:1.5px solid var(--erp-text-main);width:14px;height:14px}.td-shape-btn.active .td-shape-icon-inner{border-color:var(--erp-primary)}.td-shape-icon-circle{border-radius:50%}.td-shape-icon-square{border-radius:0}.td-shape-icon-rounded{border-radius:3px}.td-shape-icon-hexagon{clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%);background:0 0;border-width:1.5px}.td-properties-grid-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.td-input-with-addons{border:1px solid var(--erp-border);border-radius:var(--erp-radius-sm);background:#fff;align-items:center;transition:border-color .2s;display:flex;overflow:hidden}.td-input-with-addons:focus-within{border-color:var(--erp-primary)}.td-input-with-addons input{border:none;outline:none;flex:1;min-width:0;padding:8px 10px;font-size:.8rem;font-weight:600}.td-input-addon{color:var(--erp-text-muted);border-left:1px solid var(--erp-border);background:#f8fafc;align-items:center;height:32px;padding:0 10px;font-size:.65rem;font-weight:700;display:flex}.td-aspect-lock-btn{border-radius:var(--erp-radius-sm);border:1px solid var(--erp-border);width:32px;height:34px;color:var(--erp-text-muted);cursor:pointer;background:#fff;justify-content:center;align-items:center;margin-top:18px;display:flex}.td-aspect-lock-btn.active{color:var(--erp-primary);border-color:var(--erp-primary);background:#4f46e50d}.td-border-customizer-row{align-items:center;gap:10px;display:flex}.td-color-picker-input-wrapper{border:1px solid var(--erp-border);border-radius:var(--erp-radius-sm);background:#fff;flex:1.2;align-items:center;height:36px;padding:4px;display:flex;position:relative}.td-color-picker-color-dot{cursor:pointer;border:1px solid #00000014;border-radius:4px;width:26px;height:26px;position:relative}.td-color-picker-color-dot input[type=color]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;top:0;left:0}.td-color-picker-text-value{color:var(--erp-text-main);margin-left:8px;font-size:.775rem;font-weight:700}.td-slider-row{align-items:center;gap:12px;display:flex}.td-slider-row input[type=range]{accent-color:var(--erp-primary);cursor:pointer;border-radius:3px;outline:none;flex:1;height:6px}.td-slider-value-badge{color:var(--erp-text-main);border-radius:var(--erp-radius-sm);text-align:center;background:#f1f5f9;min-width:42px;padding:4px 8px;font-size:.75rem;font-weight:700}.td-toggle-row{justify-content:space-between;align-items:center;display:flex}.td-switch-btn{width:38px;height:22px;display:inline-block;position:relative}.td-switch-btn input{opacity:0;width:0;height:0}.td-switch-slider{cursor:pointer;background-color:#cbd5e1;border-radius:34px;transition:all .25s;position:absolute;inset:0}.td-switch-slider:before{content:"";background-color:#fff;border-radius:50%;width:16px;height:16px;transition:all .25s;position:absolute;bottom:3px;left:3px}.td-switch-btn input:checked+.td-switch-slider{background-color:var(--erp-primary)}.td-switch-btn input:checked+.td-switch-slider:before{transform:translate(16px)}.td-delete-element-panel-btn{color:#dc2626;border-radius:var(--erp-radius-sm);cursor:pointer;background:0 0;border:1px solid #fecaca;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:12px;padding:10px;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.td-delete-element-panel-btn:hover{background:#fef2f2}.td-empty-props-panel{height:100%;color:var(--erp-text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:32px;display:flex}.td-app-footer{background:var(--erp-card-bg);border-top:1px solid var(--erp-border);z-index:100;justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.td-footer-metadata{color:var(--erp-text-muted);align-items:center;gap:16px;font-size:.7rem;font-weight:600;display:flex}.td-footer-metadata span{align-items:center;display:flex}.td-footer-actions{align-items:center;gap:8px;display:flex}.td-dialog-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#0f172a66;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.td-dialog-card{border-radius:var(--erp-radius);border:1px solid var(--erp-border);background:#fff;flex-direction:column;width:380px;display:flex;overflow:hidden;box-shadow:0 25px 50px #00000026}.td-dialog-header{border-bottom:1px solid var(--erp-border);color:var(--erp-text-main);background:#f8fafc;padding:16px 20px;font-size:.95rem;font-weight:800}.td-dialog-body{flex-direction:column;gap:12px;padding:20px;display:flex}.td-dialog-footer{border-top:1px solid var(--erp-border);background:#f8fafc;justify-content:flex-end;gap:8px;padding:12px 20px;display:flex}.td-toast-overlay{z-index:3000;flex-direction:column;gap:10px;display:flex;position:fixed;top:24px;right:24px}.td-toast-card{border-radius:var(--erp-radius-sm);border-left:4px solid var(--erp-primary);background:#fff;align-items:center;gap:12px;min-width:280px;max-width:380px;padding:12px 20px;transition:all .2s;animation:.25s cubic-bezier(.4,0,.2,1) slideInRight;display:flex;box-shadow:0 10px 30px #00000014}@keyframes slideInRight{0%{opacity:0;transform:translate(110%)}to{opacity:1;transform:translate(0)}}.td-toast-card.success{border-left-color:#10b981}.td-toast-card.error{border-left-color:#ef4444}.td-toast-card.warning{border-left-color:#f59e0b}.td-toast-card.info{border-left-color:#3b82f6}.td-toast-content{color:var(--erp-text-main);flex:1;font-size:.8rem;font-weight:600}.td-toast-close{color:var(--erp-text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.td-toast-close:hover{color:var(--erp-text-main)}.td-export-canvas,.td-export-canvas *{box-sizing:border-box}@media print{body{background:#fff!important}.td-erp-header,.td-ribbon-bar,.td-sidebar,.td-properties-panel,.td-workspace-bottom-bar,.td-app-footer,.td-canvas-floating-toolbar,.td-ruler-corner,.td-ruler-horizontal,.td-ruler-vertical,.td-toast-overlay{display:none!important}.td-app-container,.td-app-body,.td-center-workspace,.td-ruler-layout-container{background:#fff!important;width:auto!important;height:auto!important;min-height:0!important;margin:0!important;padding:0!important;display:block!important;overflow:visible!important}.td-card-viewport-wrapper{perspective:none!important;width:428px!important;margin:20mm auto!important;transform:none!important}.td-card-canvas-container{page-break-inside:avoid;box-shadow:none!important;border:1px solid #cbd5e1!important}}.setup-container{padding:24px;animation:.5s ease-out fadeIn}.setup-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.header-title h1{color:var(--text-main);margin-bottom:4px;font-size:1.5rem;font-weight:700}.header-title p{color:var(--text-muted);font-size:.875rem}.search-wrapper{min-width:300px;position:relative}.search-input{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-card);width:100%;transition:var(--transition);padding:10px 12px 10px 40px}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.add-btn{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;transition:var(--transition);border:none;align-items:center;gap:8px;padding:10px 20px;font-weight:600;display:flex}.add-btn:hover{background:var(--primary-hover);box-shadow:var(--shadow);transform:translateY(-1px)}.types-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.type-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);padding:20px;position:relative;overflow:hidden}.type-card:hover{border-color:var(--primary);box-shadow:var(--shadow-lg)}.type-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.type-info h3{margin-bottom:4px;font-size:1.125rem;font-weight:700}.type-badge{border-radius:var(--radius);width:40px;height:40px;box-shadow:var(--shadow-sm);justify-content:center;align-items:center;font-size:1.25rem;font-weight:800;display:inline-flex}.type-details{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;display:grid}.detail-item{flex-direction:column;display:flex}.detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.detail-value{color:var(--text-main);font-weight:600}.type-actions{border-top:1px solid var(--border-light);gap:8px;padding-top:16px;display:flex}.action-btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:1px solid var(--border);background:0 0;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px;font-size:.875rem;font-weight:500;display:flex}.edit-btn:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.delete-btn:hover{color:var(--danger);border-color:var(--danger);background:#fef2f2}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a99;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-lg);padding:32px;position:relative}.modal-header{margin-bottom:24px}.modal-header h2{font-size:1.5rem;font-weight:700}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.form-group.full{grid-column:span 2}.form-group input,.form-group textarea,.form-group select{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-main);transition:var(--transition);padding:10px 12px}.form-group input:focus{border-color:var(--primary);outline:none}.color-inputs{gap:12px;display:flex}.color-preview{border-radius:var(--radius-sm);border:1px solid var(--border);width:42px;height:42px}.modal-footer{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.btn-cancel{border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;background:0 0;padding:10px 20px;font-weight:600}.btn-save{border-radius:var(--radius);background:var(--primary);color:#fff;cursor:pointer;border:none;padding:10px 24px;font-weight:600}.comm-dashboard-v2{flex-direction:column;gap:24px;display:flex}.dashboard-header-row{justify-content:space-between;align-items:center;display:flex}.title-block h2{color:#0f172a;margin:0;font-size:1.125rem;font-weight:800}.title-block p{color:#64748b;margin:4px 0 0;font-size:.8125rem}.customize-btn{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:.8125rem;font-weight:700;transition:all .2s;display:flex}.customize-btn:hover{background:#f8fafc;border-color:#cbd5e1}.stats-grid-v2{grid-template-columns:repeat(5,1fr);gap:20px;display:grid}.stat-card-v2{background:#fff;border-radius:16px;flex-direction:column;gap:16px;padding:20px;transition:transform .2s;display:flex;box-shadow:0 4px 6px -1px #0000000d}.stat-card-v2:hover{transform:translateY(-4px)}.stat-header{justify-content:space-between;align-items:center;display:flex}.stat-header .label{color:#64748b;font-size:.8125rem;font-weight:700}.stat-icon-box{border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.stat-icon-box.purple{color:#7c3aed;background:#f5f3ff}.stat-icon-box.blue{color:#3b82f6;background:#eff6ff}.stat-icon-box.red{color:#ef4444;background:#fef2f2}.stat-icon-box.indigo{color:#4f46e5;background:#eef2ff}.stat-icon-box.sky{color:#0ea5e9;background:#f0f9ff}.stat-body .value{color:#0f172a;font-size:1.5rem;font-weight:800}.stat-body .change{align-items:center;gap:4px;margin-top:8px;font-size:.75rem;font-weight:700;display:flex}.change.up{color:#10b981}.change.down{color:#ef4444}.change .since{color:#94a3b8;margin-left:4px;font-weight:500}.charts-grid-v2{grid-template-columns:350px 1fr 350px;gap:20px;display:grid}.chart-card-v2{background:#fff;border-radius:16px;flex-direction:column;padding:20px;display:flex;box-shadow:0 4px 6px -1px #0000000d}.chart-header h3{color:#0f172a;margin:0;font-size:.9375rem;font-weight:800}.pie-content{flex-direction:column;gap:20px;display:flex}.pie-wrapper{height:240px;position:relative}.pie-center-label{pointer-events:none;flex-direction:column;align-items:center;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.pie-center-label .val{color:#0f172a;font-size:1.25rem;font-weight:800}.pie-center-label .lab{color:#64748b;font-size:.75rem;font-weight:600}.pie-legend{flex-direction:column;gap:12px;display:flex}.legend-item{align-items:center;gap:12px;font-size:.8125rem;display:flex}.legend-item .name{color:#475569;flex:1;font-weight:600}.legend-item .val{color:#0f172a;font-weight:700}.legend-item .per{color:#94a3b8;font-size:.75rem}.bar-list{flex-direction:column;gap:20px;display:flex}.bar-item-row{flex-direction:column;gap:8px;display:flex}.bar-item-row .label{color:#64748b;font-size:.75rem;font-weight:600}.bar-container{background:#f1f5f9;border-radius:4px;height:8px;overflow:hidden}.bar-fill{border-radius:4px;height:100%}.bar-fill.purple{background:#7c3aed}.bar-fill.blue{background:#3b82f6}.bar-fill.indigo{background:#4f46e5}.bar-fill.pink{background:#db2777}.bar-fill.slate{background:#475569}.bar-item-row .value{color:#0f172a;text-align:right;font-size:.8125rem;font-weight:700}.dashboard-table-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 6px -1px #0000000d}.table-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.table-header h3{color:#0f172a;margin:0;font-size:1rem;font-weight:800}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #f1f5f9;padding:12px 16px;font-size:.75rem;font-weight:700}td{color:#475569;border-bottom:1px solid #f1f5f9;padding:16px;font-size:.8125rem}.title-cell{color:#0f172a;font-weight:700}.type-badge{color:#475569;background:#f1f5f9;border-radius:6px;padding:4px 8px;font-size:.7rem;font-weight:700}.channel-icons{gap:6px;display:flex}.c-icon{border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.c-icon.sms{color:#7c3aed;background:#f5f3ff}.c-icon.email{color:#3b82f6;background:#eff6ff}.c-icon.whatsapp{color:#10b981;background:#f0fdf4}.c-icon.push{color:#ef4444;background:#fef2f2}.status-badge{border-radius:20px;padding:4px 10px;font-size:.7rem;font-weight:700}.status-badge.delivered{color:#15803d;background:#dcfce7}.status-badge.failed{color:#b91c1c;background:#fee2e2}.bold{color:#0f172a;font-weight:800}.date-cell{color:#64748b;font-size:.75rem}.wa-center-container{color:#1e293b;background:#f8fafc;flex-direction:column;height:100%;display:flex;position:relative}.wa-top-nav{background:#fff;border-bottom:1px solid #e2e8f0;padding:16px 32px}.breadcrumbs{color:#64748b;align-items:center;gap:8px;margin-bottom:12px;font-size:.75rem;display:flex}.breadcrumbs .active{color:#7c3aed;font-weight:600}.wa-page-header{justify-content:space-between;align-items:center;display:flex}.header-text h2{color:#0f172a;margin:0;font-size:1.25rem;font-weight:800}.header-text p{color:#64748b;margin:4px 0 0;font-size:.8125rem}.wa-btn{cursor:pointer;border:1px solid #0000;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.wa-btn.primary.purple{color:#fff;background:#7c3aed;box-shadow:0 4px 12px #7c3aed33}.wa-btn.secondary{color:#475569;background:#fff;border-color:#e2e8f0}.wa-btn.secondary:hover{background:#f8fafc;border-color:#cbd5e1}.wa-btn.text{color:#64748b;background:0 0}.wa-steps-indicator{background:#fff;border-bottom:1px solid #e2e8f0;justify-content:center;padding:24px 0;display:flex}.step-item{align-items:center;gap:12px;display:flex;position:relative}.step-circle{color:#94a3b8;z-index:2;background:#f1f5f9;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;font-weight:700;display:flex}.step-item.active .step-circle{color:#fff;background:#7c3aed;box-shadow:0 0 0 4px #7c3aed1a}.step-item.completed .step-circle{color:#fff;background:#10b981}.step-label{color:#94a3b8;font-size:.8125rem;font-weight:600}.step-item.active .step-label{color:#7c3aed}.step-line{background:#f1f5f9;width:60px;height:2px;margin:0 12px}.step-item.completed .step-line{background:#10b981}.wa-main-content{flex:1;grid-template-columns:1fr 380px;display:grid;overflow:hidden}.content-left-scrollable{padding:32px;overflow-y:auto}.wa-step-content.grid-layout{grid-template-columns:350px 1fr;gap:24px;display:grid}.template-info-card{grid-row:span 2}.wa-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px;box-shadow:0 1px 3px #0000000d}.wa-card.full-width{width:100%}.card-header{color:#0f172a;justify-content:space-between;align-items:center;margin-bottom:20px;font-size:.9375rem;font-weight:700;display:flex}.card-header span{color:#94a3b8;font-size:.75rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid #e2e8f0;border-radius:10px;outline:none;width:100%;padding:10px 14px;font-size:.875rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}.req{color:#ef4444}.char-count{text-align:right;color:#94a3b8;margin-top:4px;font-size:.7rem}.tags-container{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.tag{color:#7c3aed;background:#f5f3ff;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:.75rem;font-weight:600;display:flex}.add-tag-btn{color:#7c3aed;cursor:pointer;background:#fff;border:1px dashed #7c3aed;border-radius:6px;padding:4px 10px;font-size:.75rem;font-weight:600}.editor-toolbar{background:#f8fafc;border:1px solid #e2e8f0;border-bottom:none;border-radius:10px 10px 0 0;align-items:center;gap:4px;padding:8px;display:flex}.message-content-card textarea{resize:none;border-radius:0 0 10px 10px;height:200px}.editor-toolbar button{cursor:pointer;color:#475569;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:.8125rem}.editor-toolbar .divider{background:#e2e8f0;width:1px;height:16px;margin:0 4px}.insert-var-btn{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:4px;padding:4px 12px;font-size:.75rem;font-weight:600;display:flex}.wa-mini-table{border-collapse:collapse;width:100%;font-size:.8125rem}.wa-mini-table th{text-align:left;color:#64748b;border-bottom:1px solid #f1f5f9;padding:12px}.wa-mini-table td{border-bottom:1px solid #f1f5f9;padding:12px}.var-badge{color:#6366f1;background:#f1f5f9;border-radius:4px;padding:2px 6px;font-size:.75rem;font-weight:700}.actions{gap:8px;display:flex}.actions button{cursor:pointer;color:#64748b;background:#f8fafc;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.actions button.edit:hover{color:#7c3aed;background:#f5f3ff}.actions button.delete:hover{color:#ef4444;background:#fef2f2}.content-right-fixed{background:#fff;border-left:1px solid #e2e8f0;padding:32px;overflow-y:auto}.preview-tabs{background:#f1f5f9;border-radius:10px;margin-bottom:24px;padding:4px;display:flex}.preview-tabs button{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:8px;flex:1;padding:8px;font-size:.75rem;font-weight:700}.preview-tabs button.active{color:#0f172a;background:#fff;box-shadow:0 2px 4px #0000000d}.wa-phone-preview{background:#e5ddd5;border:12px solid #1e293b;border-radius:32px;flex-direction:column;width:100%;max-width:300px;height:500px;margin:0 auto;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 40px #0000001a}.wa-header{color:#fff;background:#075e54;align-items:center;gap:8px;padding:12px 10px;display:flex}.wa-avatar{color:#075e54;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:800;display:flex}.wa-name{align-items:center;gap:4px;font-size:.75rem;font-weight:700;display:flex}.wa-name svg{color:#128c7e;fill:#fff}.wa-status{opacity:.8;font-size:.6rem}.wa-icons{gap:12px;margin-left:auto;display:flex}.wa-chat-body{background:url(https://user-images.githubusercontent.com/15075759/28719144-86dc0f70-73b1-11e7-911d-60d70fcded21.png);flex:1;padding:12px;overflow-y:auto}.wa-date-chip{color:#64748b;background:#fff;border-radius:8px;width:fit-content;margin:0 auto 16px;padding:4px 10px;font-size:.6rem;font-weight:700}.wa-message-bubble{background:#fff;border-radius:0 12px 12px;max-width:90%;padding:10px;position:relative;box-shadow:0 1px 2px #0000001a}.wa-msg-header{margin-bottom:6px;font-size:.8rem;font-weight:800}.wa-msg-body{color:#1e293b;font-size:.75rem;line-height:1.4}.wa-msg-footer{text-align:right;color:#94a3b8;justify-content:flex-end;align-items:center;gap:4px;margin-top:4px;font-size:.6rem;display:flex}.wa-msg-footer .delivered{color:#34b7f1}.wa-footer{z-index:10;background:#fff;border-top:1px solid #e2e8f0;align-items:center;padding:20px 32px;display:flex}.option-item{justify-content:space-between;align-items:center;margin-bottom:16px;font-size:.8125rem;font-weight:600;display:flex}.toggle{cursor:pointer;background:#cbd5e1;border-radius:10px;width:36px;height:20px;padding:2px;transition:all .2s}.toggle.active{background:#7c3aed}.knob{background:#fff;border-radius:50%;width:16px;height:16px;transition:all .2s}.toggle.active .knob{transform:translate(16px)}.info-banner{color:#6d28d9;background:#f5f3ff;border:1px solid #ddd6fe;border-radius:12px;gap:12px;margin-bottom:24px;padding:16px;font-size:.8125rem;display:flex}.wa-full-table{border-collapse:collapse;width:100%}.wa-full-table th{text-align:left;color:#64748b;text-transform:uppercase;background:#f8fafc;padding:16px;font-size:.75rem;font-weight:700}.wa-full-table td{border-bottom:1px solid #f1f5f9;padding:16px;font-size:.875rem}:root{--comm-primary:#7c3aed;--comm-primary-light:#f5f3ff;--comm-bg-main:#f8fafc;--comm-bg-card:#fff;--comm-text-main:#1e293b;--comm-text-muted:#64748b;--comm-border:#e2e8f0;--comm-sidebar-width:68px;--comm-header-height:70px;--comm-ribbon-height:150px;--comm-shadow:0 4px 20px -2px #0000000d}.comm-workspace-app{background-color:var(--comm-bg-main);width:100vw;height:100vh;color:var(--comm-text-main);font-family:Inter,system-ui,-apple-system,sans-serif;display:flex;overflow:hidden}.comm-mini-sidebar{width:var(--comm-sidebar-width);border-right:1px solid var(--comm-border);z-index:100;background:#fff;flex-direction:column;align-items:center;height:100%;padding:20px 0;display:flex}.mini-sidebar-logo{margin-bottom:30px}.mini-sidebar-nav{flex-direction:column;flex:1;align-items:center;gap:12px;width:100%;display:flex}.nav-item{width:44px;height:44px;color:var(--comm-text-muted);cursor:pointer;background:0 0;border:none;border-radius:12px;justify-content:center;align-items:center;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.nav-item:hover{background:var(--comm-primary-light);color:var(--comm-primary);transform:translateY(-2px)}.nav-item.active{background:var(--comm-primary);color:#fff;box-shadow:0 4px 12px #7c3aed4d}.spacer{flex:1}.comm-main-container{flex-direction:column;flex:1;display:flex;overflow:hidden}.comm-header{height:var(--comm-header-height);border-bottom:1px solid var(--comm-border);background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex}.header-left{flex:1;align-items:center;gap:40px;display:flex}.module-info h1{color:#0f172a;margin:0;font-size:1.25rem;font-weight:800}.module-info span{color:var(--comm-text-muted);font-size:.75rem;font-weight:500}.search-bar-container{flex:1;max-width:600px;position:relative}.search-icon{color:var(--comm-text-muted);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-bar-container input{background:#f1f5f9;border:1px solid #0000;border-radius:12px;width:100%;height:44px;padding:0 100px 0 44px;font-size:.875rem;transition:all .2s}.search-bar-container input:focus{border-color:var(--comm-primary);background:#fff;outline:none;box-shadow:0 0 0 4px #7c3aed1a}.k-shortcut{border:1px solid var(--comm-border);color:var(--comm-text-muted);background:#fff;border-radius:6px;padding:4px 8px;font-size:.7rem;font-weight:700;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.header-right{align-items:center;gap:16px;display:flex}.academic-year-select{cursor:pointer;background:#f1f5f9;border-radius:10px;align-items:center;gap:8px;padding:8px 14px;font-size:.875rem;font-weight:700;display:flex}.notification-icons{gap:10px;display:flex}.icon-badge-wrapper{width:40px;height:40px;color:var(--comm-text-main);cursor:pointer;background:#f1f5f9;border-radius:10px;justify-content:center;align-items:center;display:flex;position:relative}.badge{color:#fff;background:#ef4444;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;min-width:18px;height:18px;font-size:.65rem;font-weight:800;display:flex;position:absolute;top:-4px;right:-4px}.quick-action-btn{background:var(--comm-primary);color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 18px;font-size:.875rem;font-weight:700;display:flex;box-shadow:0 4px 12px #7c3aed33}.header-actions-divider{background:var(--comm-border);width:1px;height:30px}.user-profile-small{align-items:center;gap:12px;padding-left:10px;display:flex}.user-text{text-align:right;flex-direction:column;display:flex}.user-text .name{color:#0f172a;font-size:.875rem;font-weight:700}.user-text .role{color:var(--comm-text-muted);font-size:.7rem}.user-profile-small img{object-fit:cover;width:38px;height:38px;box-shadow:var(--comm-shadow);border:2px solid #fff;border-radius:10px}.comm-ribbon-section{border-bottom:1px solid var(--comm-border);background:#fff;flex-direction:column;display:flex}.ribbon-tabs-row{border-bottom:1px solid #f1f5f9;padding:0 24px;display:flex;overflow-x:auto}.ribbon-tab-btn{color:var(--comm-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:12px 20px;font-size:.8125rem;font-weight:600;position:relative}.ribbon-tab-btn.active{color:var(--comm-primary)}.ribbon-tab-btn.active:after{content:"";background:var(--comm-primary);border-radius:3px 3px 0 0;width:60%;height:3px;position:absolute;bottom:0;left:20%}.ribbon-toolbar-row{background:#f8fafc;align-items:center;height:100px;display:flex}.ribbon-tools-container{height:100%;padding:0 24px;display:flex}.ribbon-group{flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:0 16px;display:flex}.ribbon-group-items{flex:1;align-items:center;gap:12px;display:flex}.ribbon-group-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;font-size:.625rem;font-weight:700}.ribbon-divider{background:#e2e8f0;align-self:center;width:1px;height:60%}.ribbon-tool-btn{cursor:pointer;min-width:60px;color:var(--comm-text-main);background:0 0;border:1px solid #0000;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:6px 8px;transition:all .2s;display:flex}.ribbon-tool-btn:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 2px 8px #0000000d}.ribbon-tool-btn.large{min-width:90px}.ribbon-tool-btn span{text-align:center;font-size:.6875rem;font-weight:600;line-height:1.2}.icon-box{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:2px;display:flex}.icon-box.purple{color:#7c3aed;background:#f5f3ff}.icon-box.blue{color:#3b82f6;background:#eff6ff}.icon-box.pink{color:#db2777;background:#fdf2f8}.icon-box.indigo{color:#4f46e5;background:#eef2ff}.ribbon-filter-box{border:1px solid var(--comm-border);cursor:pointer;background:#fff;border-radius:10px;align-items:center;gap:8px;padding:8px 12px;font-size:.75rem;font-weight:600;display:flex}.comm-content-workspace{flex:1;display:flex;overflow:hidden}.main-content-scrollable{background:#f1f5f9;flex:1;padding:24px;overflow-y:auto}.comm-right-panel{border-left:1px solid var(--comm-border);background:#fff;flex-direction:column;gap:32px;padding:24px;display:flex;overflow-y:auto}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-header h3{color:#0f172a;margin:0;font-size:.9375rem;font-weight:800}.view-all-link{color:var(--comm-primary);cursor:pointer;background:0 0;border:none;font-size:.75rem;font-weight:700}.activity-list,.event-list{flex-direction:column;gap:16px;display:flex}.activity-card,.event-card{background:#f8fafc;border:1px solid #0000;border-radius:12px;gap:12px;padding:12px;transition:all .2s;display:flex}.activity-card:hover,.event-card:hover{background:#fff;border-color:#cbd5e1}.activity-icon,.event-date-box{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.activity-icon.purple{color:#7c3aed;background:#f5f3ff}.activity-icon.orange{color:#f97316;background:#fff7ed}.event-date-box{color:#4f46e5;background:#eef2ff}.activity-details h4,.event-details h4{margin:0 0 4px;font-size:.8125rem;font-weight:700}.activity-details p,.event-details p{color:var(--comm-text-muted);justify-content:space-between;margin:0;font-size:.7rem;display:flex}.quick-stats-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.q-stat-card{background:#f8fafc;border-radius:12px;flex-direction:column;gap:12px;padding:16px;display:flex}.q-stat-icon{border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.q-stat-icon.green{color:#22c55e;background:#f0fdf4}.q-stat-icon.orange{color:#f97316;background:#fff7ed}.q-stat-info{flex-direction:column;display:flex}.q-stat-info .val{color:#0f172a;font-size:1.125rem;font-weight:800}.q-stat-info .lab{color:var(--comm-text-muted);text-transform:uppercase;font-size:.65rem;font-weight:600}.empty-module-state{justify-content:center;align-items:center;height:100%;display:flex}.glass-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);text-align:center;background:#fffc;border:1px solid #ffffff4d;border-radius:24px;padding:60px;box-shadow:0 10px 40px #0000000d}.glass-card h2{color:var(--comm-primary);margin-bottom:12px;font-size:2rem;font-weight:900}.homework-ribbon{background:var(--bg-card);border:1px solid var(--border);z-index:100;border-radius:12px;margin-bottom:24px;position:sticky;top:0;overflow:hidden;box-shadow:0 10px 30px #0000000a}.ribbon-tabs{background:linear-gradient(90deg,#6366f1,#4f46e5);gap:4px;padding:0 12px;display:flex}.ribbon-tab{color:#fffc;cursor:pointer;border-bottom:3px solid #0000;padding:8px 20px;font-size:.8125rem;font-weight:600;transition:all .2s}.ribbon-tab:hover{color:#fff;background:#ffffff1a}.ribbon-tab.active{color:#fff;background:#ffffff26;border-bottom-color:#fff}.ribbon-tools{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;align-items:flex-start;gap:16px;min-height:92px;padding:12px 16px;display:flex}.ribbon-section{flex-direction:column;align-items:center;gap:8px;display:flex}.section-items{align-items:center;gap:12px;display:flex}.ribbon-btn{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:6px;min-width:70px;padding:8px 12px;transition:all .2s;display:flex}.ribbon-btn:hover{background:#6366f114;border-color:#6366f133;transform:translateY(-2px)}.ribbon-btn span{color:var(--text-main);white-space:nowrap;font-size:.7rem;font-weight:600}.section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.625rem;font-weight:700}.ribbon-divider{background:var(--border);width:1px;height:60px;margin-top:4px}[data-theme=dark] .ribbon-tools{background:#1e293bcc}[data-theme=dark] .ribbon-btn span{color:#cbd5e1}@media (width<=768px){.ribbon-tools{padding-bottom:8px;overflow-x:auto}.ribbon-btn{min-width:60px}}.homework-page{flex-direction:column;gap:24px;padding:0 0 40px;display:flex}.dashboard-grid{flex-direction:column;gap:24px;display:flex}.stats-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;display:grid}.kpi-card{background:#fff;border:none;align-items:center;gap:20px;padding:24px;display:flex}.kpi-icon{border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.kpi-title{color:var(--text-muted);margin:0;font-size:.875rem;font-weight:600}.kpi-value-row{align-items:baseline;gap:12px;display:flex}.kpi-value{color:var(--text-main);margin:4px 0 0;font-size:1.75rem;font-weight:800}.kpi-trend{font-size:.75rem;font-weight:700}.charts-row{grid-template-columns:1.5fr 1fr;gap:24px;display:grid}.chart-container{background:#fff;border:none;padding:24px}.chart-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.chart-header h4{color:var(--text-main);margin:0;font-size:1.125rem;font-weight:700}.pie-legend{flex-wrap:wrap;justify-content:center;gap:16px;margin-top:20px;display:flex}.legend-item{align-items:center;gap:8px;display:flex}.legend-item .dot{border-radius:50%;width:8px;height:8px}.legend-item .label{color:var(--text-muted);font-size:.75rem;font-weight:600}.bottom-row{grid-template-columns:1.2fr 1fr;gap:24px;display:grid}.recent-list,.staff-performance{background:#fff;border:none;padding:24px}.list-content{flex-direction:column;gap:12px;display:flex}.list-item{background:var(--bg-main);border-radius:12px;align-items:center;gap:16px;padding:12px;transition:all .2s;display:flex}.list-item:hover{background:#6366f10d;transform:translate(5px)}.item-icon{width:40px;height:40px;color:var(--primary);background:#fff;border-radius:10px;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 10px #0000000d}.item-info{flex:1}.item-info h6{color:var(--text-main);margin:0;font-size:.9375rem;font-weight:700}.item-info span{color:var(--text-muted);font-size:.75rem}.item-status{border-radius:20px;padding:4px 12px;font-size:.6875rem;font-weight:700}.status-published{color:#10b981;background:#10b9811a}.form-container{grid-template-columns:1fr 1fr;gap:24px;display:grid}.form-card{background:#fff;flex-direction:column;gap:24px;padding:32px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-main);font-size:.875rem;font-weight:700}.form-control{border:1px solid var(--border);background:var(--bg-main);border-radius:10px;outline:none;width:100%;padding:12px 16px;font-size:.9375rem;transition:all .2s}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 4px #6366f11a}@media (width<=1200px){.charts-row,.bottom-row{grid-template-columns:1fr}}@media (width<=768px){.form-container{grid-template-columns:1fr}}.academic-config-page{max-width:1400px;margin:0 auto;padding:24px}.page-header{justify-content:space-between;align-items:flex-end;margin-bottom:32px;display:flex}.breadcrumb-nav{color:var(--text-muted);align-items:center;gap:8px;margin-bottom:12px;font-size:.75rem;display:flex}.breadcrumb-nav .active{color:var(--primary);font-weight:600}.header-left h1{color:var(--text-main);margin:0;font-size:1.75rem;font-weight:800}.header-left p{color:var(--text-muted);margin:4px 0 0;font-size:.875rem}.header-actions{gap:12px;display:flex}.action-btn{cursor:pointer;border:none;border-radius:12px;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.action-btn.primary{background:var(--primary);color:#fff;box-shadow:0 4px 12px #7c3aed40}.action-btn.secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text-main)}.config-stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:16px;align-items:center;gap:16px;padding:20px;display:flex}.stat-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-icon.purple{color:var(--primary);background:#7c3aed1a}.stat-icon.green{color:#10b981;background:#10b9811a}.stat-icon.blue{color:#3b82f6;background:#3b82f61a}.stat-info{flex-direction:column;display:flex}.stat-info .val{color:var(--text-main);font-size:1.25rem;font-weight:700}.stat-info .lab{color:var(--text-muted);font-size:.75rem;font-weight:600}.config-content-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-md);border-radius:20px;overflow:hidden}.card-toolbar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px;display:flex}.search-box{width:320px;position:relative}.search-box svg{color:var(--text-muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-box input{background:var(--bg-app);border:1px solid var(--border);border-radius:10px;outline:none;width:100%;padding:10px 12px 10px 40px;font-size:.875rem;transition:all .2s}.search-box input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #7c3aed1a}.toolbar-actions{gap:8px;display:flex}.icon-btn{background:var(--bg-app);border:1px solid var(--border);width:38px;height:38px;color:var(--text-main);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:all .2s;display:flex}.icon-btn:hover{background:var(--border)}.table-container{overflow-x:auto}.modern-table{border-collapse:collapse;width:100%}.modern-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;background:var(--bg-app);border-bottom:1px solid var(--border);padding:16px 20px;font-size:.75rem;font-weight:700}.modern-table td{color:var(--text-main);border-bottom:1px solid var(--border);padding:16px 20px;font-size:.875rem}.modern-table .bold{font-weight:700}.date-range{color:var(--text-main);align-items:center;gap:8px;font-size:.8125rem;display:flex}.date-range span{color:var(--text-muted)}.badge{border-radius:20px;padding:4px 10px;font-size:.75rem;font-weight:700}.badge.blue{color:#3b82f6;background:#3b82f61a}.badge.gray{color:#94a3b8;background:#94a3b81a}.status-pill{border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:700}.status-pill.active{color:#15803d;background:#dcfce7}.status-pill.inactive{color:#64748b;background:#f1f5f9}.row-actions{justify-content:flex-end;gap:8px;display:flex}.row-actions button{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.edit-btn{color:var(--primary);background:#7c3aed1a}.delete-btn{color:#ef4444;background:#ef44441a}.offcanvas-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#0000004d;position:fixed;inset:0}.modern-offcanvas{background:var(--bg-card);z-index:2001;flex-direction:column;width:420px;height:100vh;transition:right .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:-420px;box-shadow:-10px 0 30px #0000001a}.modern-offcanvas.show{right:0}.offcanvas-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:24px;display:flex}.offcanvas-header h3{margin:0;font-size:1.125rem;font-weight:800}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none}.offcanvas-form{flex-direction:column;flex:1;display:flex;overflow:hidden}.form-body{flex:1;padding:24px;overflow-y:auto}.form-group{margin-bottom:20px}.form-group label{color:var(--text-muted);margin-bottom:8px;font-size:.8125rem;font-weight:700;display:block}.form-group input,.form-group select{border:1px solid var(--border);background:var(--bg-app);width:100%;color:var(--text-main);border-radius:12px;outline:none;padding:12px 16px;font-size:.9375rem}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-switches{background:var(--bg-app);border-radius:16px;flex-direction:column;gap:16px;margin-top:24px;padding:16px;display:flex}.switch-item{justify-content:space-between;align-items:center;display:flex}.switch-item label{color:var(--text-main);font-size:.875rem;font-weight:700}.toggle-switch{cursor:pointer;background:#cbd5e1;border-radius:20px;width:44px;height:24px;padding:3px;transition:all .2s}.toggle-switch.active{background:var(--primary)}.toggle-knob{background:#fff;border-radius:50%;width:18px;height:18px;transition:all .2s}.toggle-switch.active .toggle-knob{transform:translate(20px)}.form-footer{border-top:1px solid var(--border);gap:12px;padding:24px;display:flex}.btn-cancel{background:var(--bg-app);border:1px solid var(--border);color:var(--text-main);cursor:pointer;border-radius:12px;flex:1;padding:12px;font-weight:700}.btn-save{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;flex:2;padding:12px;font-weight:700;box-shadow:0 4px 12px #7c3aed40}.academic-ribbon-bar{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:16px;align-items:center;margin-bottom:24px;padding:8px 16px;display:flex}.ribbon-tabs-selector{gap:12px;display:flex}.ribbon-tab-item{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:8px;padding:10px 18px;font-size:.875rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.ribbon-tab-item:hover{background:var(--bg-app);color:var(--text-main)}.ribbon-tab-item.active{color:var(--primary);background:#7c3aed1a;border-color:#7c3aed33;box-shadow:0 4px 12px #7c3aed0d}.delete-btn.confirming{animation:.3s ease-in-out infinite shake;color:#ef4444!important;background:#fef2f2!important;border:1px solid #ef444433!important}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}
