@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}[data-theme=dark]{background:#0f172a;filter:invert(.92) hue-rotate(180deg)}[data-theme=dark] .avatar,[data-theme=dark] .logo-mark,[data-theme=dark] .status-badge,[data-theme=dark] .tuition-chip,[data-theme=dark] img{filter:invert(1) hue-rotate(180deg)}[data-theme=dark] select.theme-select{background:#1e293b!important;border-color:#334155!important;color:#fff!important;filter:invert(1) hue-rotate(180deg)}[data-theme=kindergarten] .dashboard-layout{background-color:#fefce8!important}[data-theme=kindergarten] .sidebar{background-color:ivory!important;border-right:3px dashed #fde047!important}[data-theme=kindergarten] .nav-btn.active{background-color:#fdf2f8!important;border-radius:16px!important;color:#db2777!important}[data-theme=kindergarten] .nav-btn.active:before{background-color:#db2777!important;border-radius:6px!important;width:6px!important}[data-theme=kindergarten] .content-header h2{color:#d946ef!important;font-family:Comic Sans MS,Chalkboard SE,Marker Felt,sans-serif!important;font-weight:900!important;letter-spacing:1px}[data-theme=kindergarten] .user-profile{background:#e0f2fe!important;border:2px dashed #7dd3fc!important;border-radius:50px!important}[data-theme=kindergarten] .logo-mark{background:linear-gradient(135deg,#fbbf24,#f43f5e)!important;border-radius:16px!important}[data-theme=kindergarten] .avatar{background:linear-gradient(135deg,#fb7185,#c084fc)!important}[data-theme=kindergarten] .user-name{color:#9d174d!important}[data-theme=kindergarten] .user-role{color:#be185d!important}[data-theme=kindergarten] .btn-primary,[data-theme=kindergarten] .im-btn-submit,[data-theme=kindergarten] .sp-btn-checkout{background:linear-gradient(135deg,#f472b6,#db2777)!important;border-radius:12px!important}[data-theme=kindergarten] .placeholder-card{border:2px dashed #fbcfe8!important;border-radius:24px!important;box-shadow:0 4px 15px #ec48991a!important}[data-theme=kindergarten] .theme-select{background:#fdf2f8!important;border:2px dashed #fbcfe8!important;color:#db2777!important}*{box-sizing:border-box;font-family:Inter,sans-serif;margin:0;padding:0}body{background-color:#0f172a;color:#f8fafc;min-height:100vh;overflow:hidden}.app-container{align-items:center;display:flex;justify-content:center;min-height:100vh;position:relative;z-index:1}.blob{animation:float 10s infinite alternate;filter:blur(80px);opacity:.6;position:absolute;z-index:-1}.blob-1{background:linear-gradient(90deg,#4f46e5,#ec4899);height:400px;left:-100px;top:-100px;width:400px}.blob-1,.blob-2{border-radius:50%}.blob-2{animation-delay:2s;background:linear-gradient(90deg,#06b6d4,#3b82f6);bottom:-50px;height:300px;right:-50px;width:300px}.blob-3{animation-delay:4s;background:linear-gradient(90deg,#10b981,#0ea5e9);border-radius:50%;bottom:20%;height:250px;left:20%;opacity:.4;width:250px}@keyframes float{0%{transform:translate(0) scale(1)}50%{transform:translate(30px,50px) scale(1.1)}to{transform:translate(-30px,20px) scale(.9)}}.login-box{animation:slideUp .6s cubic-bezier(.16,1,.3,1) forwards;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:#1e293bb3;border:1px solid #ffffff1a;border-radius:24px;box-shadow:0 25px 50px -12px #00000080;max-width:420px;padding:3rem;width:100%}.login-header{margin-bottom:2.5rem;text-align:center}.logo-container{display:flex;justify-content:center;margin-bottom:1.5rem}.logo-icon{background:linear-gradient(135deg,#6366f1,#a855f7);border-radius:16px;box-shadow:0 10px 15px -3px #6366f166;height:56px;overflow:hidden;position:relative;width:56px}.logo-icon:after{animation:shine 3s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transform:skewX(-20deg);width:50%}@keyframes shine{0%{left:-100%}20%{left:200%}to{left:200%}}.login-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#fff,#cbd5e1);-webkit-background-clip:text;background-clip:text;font-size:1.8rem;font-weight:700;margin-bottom:.5rem}.login-header p{color:#94a3b8;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.input-group{position:relative}.input-group,.input-icon{align-items:center;display:flex}.input-icon{color:#94a3b8;justify-content:center;left:1rem;position:absolute;transition:color .3s ease}.input-group input{background:#0f172a99;border:1px solid #ffffff1a;border-radius:12px;color:#fff;font-size:1rem;outline:none;padding:1rem 1rem 1rem 3rem;transition:all .3s ease;width:100%}.input-group input::placeholder{color:#64748b}.input-group input:focus{background:#0f172acc;border-color:#6366f1;box-shadow:0 0 0 4px #6366f11a}.input-group input:focus+.input-icon,.input-group input:not(:placeholder-shown)~.input-icon{color:#6366f1}.submit-btn{align-items:center;background:linear-gradient(90deg,#4f46e5,#6366f1);border:none;border-radius:12px;box-shadow:0 4px 14px 0 #6366f163;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:1rem;padding:1rem;transition:all .3s ease;width:100%}.submit-btn:hover:not(:disabled){background:linear-gradient(90deg,#4338ca,#4f46e5);box-shadow:0 6px 20px #6366f180;transform:translateY(-2px)}.submit-btn:active:not(:disabled){transform:translateY(1px)}.submit-btn:disabled{cursor:not-allowed;opacity:.7}.message-alert{align-items:flex-start;line-height:1.4;margin-bottom:1.5rem}.message-alert.error{color:#fca5a5}.message-alert.error svg{color:#ef4444;flex-shrink:0}.message-alert.success{color:#86efac}.message-alert.success svg{color:#22c55e;flex-shrink:0}@media (max-width:768px){.login-box{margin:1rem;padding:2rem;width:auto}.action-buttons,.actions-group,.attendance-toolbar,.btn-group,.class-toolbar,.fee-btn-group,.filter-group,.header-actions,.student-actions,.toolbar,.top-actions{flex-wrap:wrap!important}.table-container{max-width:100vw;overflow-x:auto}.attendance-table{border-collapse:collapse;width:100%}@media (max-width:650px){.attendance-table thead{display:none}.attendance-table,.attendance-table tbody,.attendance-table td,.attendance-table tr{display:block;width:100%}.attendance-table tr{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;margin-bottom:1.25rem;padding:1.25rem}.attendance-table td{border:none!important;padding:.75rem 0!important;position:relative}.attendance-table td:first-child{border-bottom:1px solid #f1f5f9!important;margin-bottom:.75rem;padding-bottom:1rem!important;padding-top:0!important}.attendance-table td:not(:first-child):before{color:#64748b;content:attr(data-label);display:block;font-size:.75rem;font-weight:700;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.attendance-options-group{background:#f8fafc;border-radius:10px;display:flex;flex-direction:column;gap:.75rem;padding:.75rem}.att-radio-label{align-items:center;cursor:pointer;display:flex;font-size:1rem;font-weight:700;gap:.75rem;padding:.25rem 0}.att-radio-label input[type=radio]{height:1.2rem;width:1.2rem}}@media (min-width:651px){.attendance-options-group{display:flex;flex-direction:column;gap:.4rem}.att-radio-label{align-items:center;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.4rem}}}.attendance-portal-list{display:flex;flex-direction:column;gap:1rem;padding-bottom:2rem}.attendance-portal-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 10px #0000000d;display:flex;flex-direction:row;flex-wrap:wrap;gap:1rem 1.5rem;padding:1rem 1.25rem;transition:transform .2s ease}.attendance-portal-card:hover{transform:translateY(-2px)}.attendance-portal-card>div{flex:1 1 200px;min-width:200px}@media (max-width:650px){.attendance-portal-card{flex-direction:column;gap:1rem;padding:1.25rem}.attendance-portal-card>div{flex:0 0 auto!important;margin:0!important;min-width:0!important;width:100%!important}}.portal-att-label{color:#94a3b8;display:block;font-size:.75rem;font-weight:800;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.parent-dashboard-container{padding:0!important;text-align:left}.parent-header{background:#f8fafc!important;border:1px solid #e2e8f0!important;border-radius:12px!important;flex-wrap:wrap!important;gap:1rem!important;justify-content:space-between!important;margin-bottom:1.5rem!important;padding:1rem!important}.parent-header,.parent-header-left{align-items:center!important;display:flex!important}.parent-header-left{gap:.75rem!important}.parent-nav-tabs{-webkit-overflow-scrolling:touch!important;border-bottom:2px solid #e2e8f0!important;display:flex!important;gap:1rem!important;margin-bottom:2rem!important;overflow-x:auto!important;padding:0 .5rem!important;white-space:nowrap!important}.parent-nav-tab{border-bottom:3px solid #0000!important;color:#64748b!important;cursor:pointer!important;flex-shrink:0!important;font-size:.95rem!important;font-weight:700!important;margin-bottom:-2px!important;padding:.75rem .25rem!important}.parent-nav-tab.active-blue{border-bottom-color:#3b82f6!important;color:#3b82f6!important}.parent-nav-tab.active-green{border-bottom-color:#10b981!important;color:#10b981!important}.parent-card-grid{grid-gap:1.5rem!important;align-items:stretch!important;display:grid!important;gap:1.5rem!important;grid-template-columns:minmax(0,2fr) minmax(0,1.2fr)!important}@media (max-width:768px){.parent-header{align-items:stretch!important;text-align:center!important}.parent-header,.parent-header-left{flex-direction:column!important}.parent-header h2{font-size:1.1rem!important}.parent-card-grid{gap:1rem!important;grid-template-columns:1fr!important}.nav-tabs{overflow-x:auto}}.dashboard-layout{background-color:#f1f5f9;color:#334155;display:flex;font-family:Inter,sans-serif;height:100vh;overflow:hidden;width:100vw}.sidebar{background-color:#fff;border-right:1px solid #e2e8f0;box-shadow:4px 0 24px #00000005;display:flex;flex-direction:column;transition:all .3s cubic-bezier(.4,0,.2,1);width:280px;z-index:50}.sidebar.collapsed{width:80px}.sidebar-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;height:72px;justify-content:space-between;padding:0 1.5rem}.sidebar.collapsed .sidebar-header{justify-content:center;padding:0}.sidebar-logo{gap:.75rem}.logo-mark,.sidebar-logo{align-items:center;display:flex}.logo-mark{background:linear-gradient(135deg,#6366f1,#a855f7);border-radius:12px;box-shadow:0 4px 12px #6366f14d;color:#fff;height:40px;justify-content:center;width:40px}.logo-icon-svg{stroke-width:2.5px}.logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#1e293b,#475569);-webkit-background-clip:text;font-size:1.25rem;font-weight:800;letter-spacing:.5px}.close-btn,.collapse-btn,.mobile-menu-btn{align-items:center;background:none;border:none;border-radius:8px;color:#94a3b8;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s ease}.collapse-btn:hover{background-color:#f1f5f9;color:#334155}.sidebar-nav{flex:1 1;overflow-y:auto;padding:1.5rem 1rem}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.nav-title{color:#94a3b8;font-size:.75rem;font-weight:700;letter-spacing:1px;margin-bottom:1rem;padding-left:.75rem;text-transform:uppercase}.sidebar.collapsed .nav-title{padding-left:0;text-align:center}.sidebar-nav ul{display:flex;flex-direction:column;gap:.25rem;list-style:none;margin:0;padding:0}.nav-btn{align-items:center;background:#0000;border:none;border-radius:10px;color:#64748b;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:.75rem;padding:.75rem 1rem;position:relative;text-align:left;transition:all .2s ease;width:100%}.sidebar.collapsed .nav-btn{justify-content:center;padding:.75rem 0}.nav-btn:hover{background-color:#f8fafc;color:#0f172a}.nav-btn.active{background-color:#eef2ff;color:#4f46e5;font-weight:600}.nav-btn.active:before{background-color:#4f46e5;border-radius:0 4px 4px 0;content:"";height:60%;left:0;position:absolute;top:50%;transform:translateY(-50%);width:4px}.nav-icon{flex-shrink:0}.subtabs-sidebar{border-left:1px solid #e2e8f0;display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem;margin-left:1.5rem;margin-top:.25rem;padding-left:2rem}.sidebar-subtab-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:flex;font-size:.85rem;gap:.75rem;padding:.65rem 1rem;position:relative;text-align:left;transition:all .2s ease}.sidebar-subtab-btn:hover{background:#f8fafc;color:#1e293b}.sidebar-subtab-btn.active{background:#eef2ff;color:#4f46e5;font-weight:600}.subtab-dot{background-color:#cbd5e1;border-radius:50%;height:6px;transition:all .2s ease;width:6px}.sidebar-subtab-btn.active .subtab-dot{background-color:#4f46e5;box-shadow:0 0 0 2px #4f46e533}.sidebar-footer{border-top:1px solid #f1f5f9;padding:1.5rem 1rem}.logout-btn{align-items:center;background:#ef44441a;border:none;border-radius:10px;color:#ef4444;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.75rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.sidebar.collapsed .logout-btn{justify-content:center;padding:.75rem 0}.logout-btn:hover{background:#ef444433}.main-content{flex:1 1;overflow:hidden;position:relative}.content-inner,.main-content{display:flex;flex-direction:column}.content-inner{height:100%;overflow-y:auto;padding:2rem}.content-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.content-header h2{color:#1e293b;font-size:1.5rem;font-weight:700}.user-profile{background:#fff;border:1px solid #e2e8f0;border-radius:50px;box-shadow:0 2px 10px #00000005;gap:1rem;padding:.5rem 1rem .5rem .5rem}.avatar,.user-profile{align-items:center;display:flex}.avatar{background:linear-gradient(135deg,#10b981,#3b82f6);border-radius:50%;color:#fff;font-size:1rem;font-weight:600;height:36px;justify-content:center;width:36px}.user-info{display:flex;flex-direction:column}.user-name{color:#1e293b;font-size:.85rem;font-weight:600}.user-role{color:#94a3b8;font-size:.7rem}.card-container{flex:1 1}.placeholder-card{background:#fff;border:1px solid #f1f5f9;border-radius:20px;box-shadow:0 4px 20px #00000008;min-height:400px;padding:2.5rem}.placeholder-card h3{border-bottom:2px solid #f1f5f9;color:#334155;display:inline-block;margin-bottom:1rem;padding-bottom:1rem}.placeholder-card p{color:#64748b;line-height:1.6}.animate-fade-in{animation:contentFadeIn .4s ease-out forwards}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.hidden-desktop{display:none}@media (max-width:1024px){.hidden-mobile{display:none}.hidden-desktop{display:block}.sidebar{height:100vh;left:-280px;position:fixed;top:0}.sidebar.mobile-open{left:0}.mobile-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a66;inset:0;position:fixed;z-index:40}.mobile-top-bar{align-items:center;background:#fff;box-shadow:0 2px 10px #0000000d;display:flex;height:64px;justify-content:space-between;left:0;padding:0 1rem;position:fixed;right:0;top:0;z-index:1000}.mobile-menu-btn{background:#f8fafc;border:1px solid #e2e8f0;color:#475569;position:static}.mobile-top-title{color:#0f172a;font-size:1.15rem;font-weight:800;left:50%;position:absolute;transform:translateX(-50%);white-space:nowrap}.user-profile.compact{background:#0000;border:none;box-shadow:none;padding:0}.user-profile.compact .avatar{box-shadow:0 4px 10px #10b98133;height:38px;width:38px}.content-inner{height:calc(100vh - 64px);margin-top:64px;padding:1.5rem 1rem}.content-header.hidden-mobile{display:none}}@media (max-width:480px){.content-inner{padding:1.5rem 1rem}.placeholder-card{padding:1.5rem}}.class-manager{display:flex;flex-direction:column;height:100%}.class-toolbar{display:flex;justify-content:space-between;margin-bottom:1.5rem}.class-layout{display:flex;flex:1 1;gap:1.5rem;height:calc(100vh - 250px);min-height:0}.class-list-pane{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;display:flex;flex:0 0 320px;flex-direction:column;max-height:1000px;overflow:hidden}.pane-title{background:#f8fafc;border-bottom:1px solid #f1f5f9;color:#1e293b;font-size:1rem;font-weight:600;margin:0;padding:1.25rem}.class-list{display:flex;flex:1 1;flex-direction:column;gap:.5rem;overflow-y:auto;padding:.75rem}.class-item{align-items:center;border:1px solid #0000;border-radius:12px;cursor:pointer;display:flex;gap:1rem;padding:1rem;transition:all .2s ease}.class-item:hover{background:#f8fafc;border-color:#e2e8f0}.class-item.is-today{background:#ef444408;border-left:3px solid #ef4444}.class-item.active{background:#eef2ff;border-color:#c7d2fe}.class-item.active .class-icon{background:#4f46e5;color:#fff}.class-item.active .class-info h4{color:#4f46e5}.class-icon{align-items:center;background:#f1f5f9;border-radius:10px;color:#64748b;display:flex;height:44px;justify-content:center;transition:all .2s;width:44px}.class-info h4{color:#334155;font-size:.95rem;font-weight:600;margin:0 0 .25rem}.class-info-details{display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem}.class-info-details span{color:#64748b;font-size:.8rem;line-height:1.2}.empty-message{color:#94a3b8;font-size:.9rem;padding:2rem;text-align:center}.class-details-pane{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;flex:1 1;max-height:1000px;overflow:hidden;overflow-y:auto}.class-details-pane,.no-selection{display:flex;flex-direction:column}.no-selection{gap:1rem}.class-header-card{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:2rem}.class-title-row{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.class-title-row h2{color:#1e293b;font-size:1.8rem;margin:0 0 .25rem}.class-id{background:#e2e8f0;border-radius:999px;color:#64748b;font-size:.9rem;font-weight:500;padding:.25rem .75rem}.class-actions{display:flex;gap:.5rem}.text-layout{grid-gap:.75rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:grid;gap:.75rem;grid-template-columns:repeat(3,1fr);padding:1rem}.info-chip{align-items:flex-start;background:#f8fafc;border:1px solid #f1f5f9;border-radius:8px;display:flex;gap:.75rem;padding:.5rem}.info-chip svg{color:#64748b;flex-shrink:0;margin-top:2px}.chip-content{display:flex;flex-direction:column;gap:2px}.chip-content label{color:#94a3b8;font-size:.7rem;font-weight:700;margin:0;text-transform:uppercase}.chip-content span{color:#334155;font-size:.85rem;font-weight:600;line-height:1.4}.info-chip.full-span{grid-column:span 3}.class-students-section{display:flex;flex:1 1;flex-direction:column;padding:2rem}.section-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.section-head h3{color:#334155;font-size:1.25rem;margin:0}.student-actions{display:flex;gap:.75rem}.inline-table{border:1px solid #e2e8f0;border-radius:12px;flex:1 1;max-height:600px;min-height:400px;overflow:hidden}.td-input{background:#fff;border:1px solid #cbd5e1;border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:.85rem;padding:6px;transition:border-color .2s;width:100%}.td-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.form-grid{grid-gap:.6rem;gap:.6rem}.form-group input,.form-group select,.form-group textarea{border-radius:6px;height:32px;padding:.3rem .6rem}.form-group textarea{height:auto;line-height:1.5;min-height:150px}@media (max-width:768px){.class-layout{flex-direction:column;height:auto}.class-list-pane{flex:initial;max-height:40vh;width:100%}.class-details-pane{height:auto;max-height:none}}.inline-table{overflow-x:auto;overflow-y:auto}.data-table{min-width:600px}@media (max-width:768px){.text-layout{grid-template-columns:1fr}.class-header-card{padding:1rem}.class-title-row{flex-direction:column;gap:.5rem}.class-title-row h2{font-size:1.2rem}.class-id{font-size:.75rem;padding:2px 8px}.class-actions{display:flex;gap:.5rem;width:100%}.class-actions button{flex:1 1;font-size:.8rem;padding:6px}.text-layout{gap:.5rem;grid-template-columns:1fr;padding:.75rem}.info-chip{padding:.4rem .6rem}.info-chip.full-span{grid-column:span 1}.chip-content label{font-size:.65rem}.chip-content span{font-size:.8rem}.inline-table{display:none}.student-card-list{display:flex;flex-direction:column;gap:10px;max-height:45vh;overflow-y:auto}}.student-card{box-shadow:0 2px 4px #0000000a;gap:6px;padding:10px 12px}.student-name{font-size:.95rem;font-weight:600}.student-id{font-size:.7rem}.student-info{color:#64748b;font-size:.8rem}.student-dates,.student-info{justify-content:space-between}.student-dates{color:#94a3b8;display:flex;font-size:.75rem}.status-badge{padding:2px 8px}.tm-btn-icon{background:none;padding:6px;transition:background .2s}.print-a5-receipt{font-family:Inter,Segoe UI,Roboto,sans-serif}.print-a5-receipt *{color:#000!important}.p-header{align-items:flex-start!important;display:flex!important;justify-content:space-between!important}.p-luong-table{margin-top:10px}.p-luong-table td,.p-luong-table th{border:1.5px solid #000;font-weight:700;padding:8px}.print-a5-receipt b,.print-a5-receipt strong{font-weight:900!important}.calendar-modal{display:flex;flex-direction:column;margin:auto;max-height:92vh!important;max-width:820px!important;width:95vw}.calendar-modal .modal-header h3{font-size:1rem;max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-modal .modal-body{display:flex;flex:1 1;flex-direction:column;overflow-y:hidden!important;padding:.6rem 1rem .5rem!important}.modal-overlay.align-top{align-items:center!important;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80!important;display:flex!important;inset:0!important;justify-content:center!important;padding:1rem!important;position:fixed!important;z-index:9999!important}.calendar-toolbar{align-items:center;display:flex;justify-content:space-between;margin-bottom:.4rem}.calendar-month{color:#1e293b;font-size:1rem;font-weight:700;margin:0;text-transform:uppercase}.calendar-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex:1 1;overflow:hidden;position:relative}.calendar-grid-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;display:grid;grid-template-columns:repeat(7,1fr)}.day-name{color:#64748b;font-size:.78rem;font-weight:600;padding:.35rem .25rem;text-align:center}.calendar-grid{display:grid;grid-auto-rows:minmax(0,1fr);grid-template-columns:repeat(7,1fr);transition:opacity .2s}.calendar-cell{border-bottom:1px solid #f1f5f9;border-right:1px solid #f1f5f9;display:flex;flex-direction:column;height:68px;overflow:hidden;padding:.25rem .3rem}.calendar-cell:nth-child(7n){border-right:none}.calendar-cell.blank{background:#f8fafc}.cell-date{color:#94a3b8;font-size:.75rem;font-weight:600;line-height:1;margin-bottom:.15rem}.calendar-cell.present{background-color:#f0fdf4;border-color:#dcfce7}.calendar-cell.present .cell-content strong,.calendar-cell.present .cell-date{color:#16a34a}.calendar-cell.excused{background-color:#fffbeb;border-color:#fef3c7}.calendar-cell.excused .cell-content strong,.calendar-cell.excused .cell-date{color:#d97706}.calendar-cell.unexcused{background-color:#fef2f2;border-color:#fee2e2}.calendar-cell.unexcused .cell-content strong,.calendar-cell.unexcused .cell-date{color:#dc2626}.cell-content{display:flex;flex:1 1;flex-direction:column;gap:.1rem;overflow:hidden}.cell-content strong{font-size:.68rem;font-weight:700;line-height:1.2}.cell-notes{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;color:#64748b;display:-webkit-box;font-size:.62rem;line-height:1.25;margin:0;overflow:hidden}.calendar-overlay{align-items:center;background:#fff9;bottom:0;color:#4f46e5;font-weight:600;left:0;position:absolute;right:0;top:0}.calendar-legend,.calendar-overlay{display:flex;justify-content:center}.calendar-legend{flex-wrap:wrap;gap:1rem;margin-top:.4rem}.legend-item{align-items:center;color:#334155;display:flex;font-size:.78rem;font-weight:500;gap:.35rem}.legend-color{border:1px solid #0000001a;border-radius:3px;flex-shrink:0;height:13px;width:13px}.legend-color.present{background:#f0fdf4}.legend-color.excused{background:#fffbeb}.legend-color.unexcused{background:#fef2f2}.attendance-manager{display:flex;flex-direction:column;height:100%}.attendance-layout{display:flex;flex:1 1;gap:1.5rem;height:calc(100vh - 120px);min-height:0}.attendance-card-list,.mobile-header-actions{display:none}@media (max-width:991px){.attendance-manager{height:auto;min-height:calc(100vh - 110px);overflow:visible}.attendance-layout{flex-direction:column;gap:0;height:100%}.attendance-list-pane{border:none;border-radius:0;flex:1 1;height:100%;max-height:none;width:100%}.mobile-active{display:flex!important}.mobile-show-details .attendance-list-pane{display:none}.attendance-details-pane{background:#fff;display:none;overflow-y:visible;width:100%}.mobile-show-details .attendance-details-pane{display:block;height:auto}.mobile-header-actions{background:#fff;border-bottom:1px solid #f1f5f9;display:block;padding:1rem}.btn-back{align-items:center;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:12px;color:#475569;cursor:pointer;display:flex;font-size:.95rem;font-weight:800;gap:.6rem;padding:.75rem 1.25rem;transition:.2s}.btn-back:hover{background:#e2e8f0}.attendance-toolbar{border-bottom:1px dashed #e2e8f0;gap:1.25rem;padding:1.25rem}.attendance-toolbar,.filter-group{align-items:stretch;flex-direction:column}.filter-group{gap:.75rem}.custom-date-range{gap:.5rem;justify-content:stretch}.custom-date-range input{flex:1 1}.actions-group{width:100%}.actions-group .btn{justify-content:center;padding:.85rem;width:100%}.table-scroll-wrapper{display:none!important}.attendance-card-list{display:flex!important;padding:1rem 1rem 4rem}}.attendance-info-section{background:#fff}.im-section{padding:1.5rem 2rem}@media (max-width:768px){.im-grid-3{gap:.75rem;grid-template-columns:1fr}.im-section{padding:1rem}.attendance-card-list{height:auto!important;max-height:none!important;overflow:visible!important;padding-bottom:2rem!important}}.text-bold{font-weight:800!important}.attendance-list-pane{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;display:flex;flex:0 0 320px;flex-direction:column;max-height:1000px;overflow:hidden}@media (max-width:768px){.attendance-list-pane{flex:initial;max-height:60vh;width:100%}}.view-toggles{display:flex;gap:.5rem;padding:1rem 1rem .5rem}.toggle-btn{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:flex;flex:1 1;font-size:.85rem;font-weight:600;gap:.5rem;justify-content:center;padding:.5rem .6rem;transition:all .2s}.toggle-btn:hover{background:#f1f5f9}.toggle-btn.active{background:#4f46e5;border-color:#4f46e5;box-shadow:0 4px 10px #4f46e533;color:#fff}.search-box-sm{padding:.5rem 1rem;position:relative}.search-box-sm input{background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;font-size:.9rem;outline:none;padding:.6rem .75rem .6rem 2.25rem;width:100%}.search-box-sm input:focus{background:#fff;border-color:#6366f1}.search-box-sm .search-icon{color:#94a3b8;left:1.5rem;position:absolute;top:50%;transform:translateY(-50%)}.item-list{display:flex;flex:1 1;flex-direction:column;gap:.25rem;overflow-y:auto;padding:.5rem 1rem}.list-item{align-items:center;border:1px solid #0000;border-radius:10px;cursor:pointer;display:flex;gap:.75rem;padding:.5rem .75rem;transition:all .2s}.list-item:hover{background:#f8fafc;border-color:#e2e8f0}.list-item.active{background:#eef2ff;border-color:#c7d2fe}.list-item.active .item-icon{background:#4f46e5;color:#fff}.item-icon{background:#f1f5f9;border-radius:8px;color:#64748b;display:flex;flex-shrink:0;height:32px;width:32px}.item-info{display:flex;flex-direction:column;overflow:hidden}.item-info h4{color:#1e293b;font-size:.9rem;font-weight:600;margin:0 0 .15rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-info span{color:#94a3b8;font-size:.75rem}.empty-message-sm{color:#94a3b8;font-size:.85rem;padding:2rem;text-align:center}.attendance-details-pane{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;display:flex;flex:1 1;flex-direction:column;max-height:1000px;overflow:hidden}@media (max-width:768px){.attendance-details-pane{height:auto!important;overflow-y:visible!important}.attendance-table-container{overflow:visible!important;padding:1rem .5rem}}.attendance-toolbar{align-items:center;background:#f8fafc;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.filter-group{gap:1rem}.date-select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#334155;cursor:pointer;font-size:.9rem;outline:none;padding:.5rem 1rem}.custom-date-range{align-items:center;display:flex;gap:.5rem}.custom-date-range input{border:1px solid #cbd5e1;border-radius:6px;color:#334155;font-size:.85rem;outline:none;padding:.4rem .5rem}.attendance-table-container{flex:1 1;overflow:auto;padding:1.5rem}.text-center{text-align:center}.text-success{color:#16a34a}.text-warning{color:#d97706}.font-bold{font-weight:700}@media (max-width:768px){.table-scroll-wrapper{display:none}.attendance-toolbar{gap:.75rem;padding:1rem}.attendance-toolbar,.filter-group{align-items:stretch;flex-direction:column}.custom-date-range{justify-content:space-between}.custom-date-range input{flex:1 1}.attendance-table-container{padding:.75rem}}.attendance-card-list{display:none}@media (max-width:768px){.attendance-card-list{display:flex;flex-direction:column;gap:1rem}}.attendance-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 4px #00000005;display:flex;flex-direction:column;gap:.75rem;padding:1rem}.attendance-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem}.attendance-card-stats-compact{display:flex;gap:10px;margin:10px 0}.badge-stat{align-items:center;border-radius:8px;display:inline-flex;font-size:.75rem;font-weight:800;justify-content:center;padding:5px 10px}.bg-success-light{background-color:#f0fdf4;border:1px solid #dcfce7}.bg-warning-light{background-color:#fffbeb;border:1px solid #fef3c7}.bg-danger-light{background-color:#fef2f2;border:1px solid #fee2e2}.attendance-card .student-name{color:#1e293b;font-size:1rem;font-weight:600}.attendance-card .student-id{color:#64748b;font-size:.75rem}.sessions-scroll{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.5rem}.session-dot-item{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:.25rem}.session-date{color:#94a3b8;font-size:.65rem}.session-status{font-size:.85rem}.no-selection{align-items:center;background:#f8fafc;color:#94a3b8;display:flex!important;flex:1 1;flex-direction:row!important;gap:12px;height:100%;justify-content:center;padding:3rem}.no-selection p{font-size:.95rem;font-weight:500;margin:0}.leave-manager,.leave-manager-layout{display:flex;flex-direction:column}.leave-manager-layout{gap:1.5rem;padding-bottom:2rem}.leave-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px -1px #0000000d;overflow:hidden}.leave-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;justify-content:space-between;padding:1.25rem 1.5rem}.leave-header,.leave-title{align-items:center;display:flex}.leave-title{gap:.75rem}.leave-title h3{color:#1e293b;font-size:1.15rem;font-weight:700;margin:0}.leave-badge{border-radius:999px;font-size:.8rem;font-weight:700;padding:.35rem .85rem;text-transform:uppercase}.leave-badge.danger{background:#fef2f2;color:#ef4444}.leave-badge.warning{background:#fffbeb;color:#d97706}.leave-body{overflow-x:auto;padding:.5rem 1.5rem 1.5rem}.status-badge.danger{background:#fee2e2;color:#ef4444}.status-badge.warning{background:#fffbeb}.consecutive-badge{background-color:#ef4444;border-radius:6px;color:#fff;display:inline-block;font-size:.85rem;font-weight:600;padding:.25rem .65rem}.leave-card-list{display:none}@media (max-width:768px){.leave-card-list{display:flex;flex-direction:column;gap:1rem;padding-top:1rem}.leave-header{padding:1rem}.leave-title h3{font-size:1rem}.leave-body{padding:0 1rem 1rem}}.leave-item-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:.75rem;padding:1rem}.card-row{align-items:center;color:#475569;display:flex;font-size:.9rem;justify-content:space-between}.card-row.note{background:#fff;border-left:3px solid #cbd5e1;border-radius:8px;padding:.5rem}.text-primary{font-weight:600}.student-manager{display:flex;flex-direction:column;height:100%}.subtabs{border-bottom:2px solid #e2e8f0;display:flex;gap:1.5rem;margin-bottom:1.5rem;padding:0 .5rem}.subtab-btn{background:none;border:none;color:#64748b;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem .5rem;position:relative;transition:color .2s}.subtab-btn:hover{color:#1e293b}.subtab-btn.active{color:#4f46e5;font-weight:600}.subtab-btn.active:after{background-color:#4f46e5;border-radius:2px 2px 0 0;bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0}.subtab-content{background:#fff;border:1px solid #f1f5f9;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;display:flex;flex:1 1;flex-direction:column;padding:1.5rem}.students-tab-content{display:flex;flex-direction:column;gap:1.5rem;height:100%}@media (max-width:768px){.students-tab-content{gap:.75rem}.subtab-content{border-radius:0;padding:.75rem!important}}.stats-container{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}@media (max-width:768px){.stats-container{gap:.75rem;grid-template-columns:repeat(2,1fr)}.stat-card{gap:.75rem;padding:.75rem}.stat-icon{height:36px;width:36px}.stat-value{font-size:1.1rem}.stat-label{font-size:.75rem}}.stat-card{background:#f8fafc;transition:transform .2s,box-shadow .2s}.stat-icon{height:48px;width:48px}.stat-card.active .stat-icon{background:#dcfce7;color:#16a34a}.stat-card.inactive .stat-icon{background:#fee2e2;color:#ef4444}.stat-label{font-weight:500}.stat-value{color:#1e293b;font-weight:700}.toolbar-mobile{align-items:center;display:flex;gap:1rem;justify-content:space-between;width:100%}.search-stack{display:flex;flex:1 1;gap:1rem}.search-item{align-items:center;display:flex;position:relative;width:250px}.mobile-select,.search-item input{background:#fff;border:1px solid #cbd5e1;border-radius:10px;font-size:.95rem;height:44px;outline:none;padding:.65rem 1rem .65rem 3rem;transition:all .2s;width:100%}.item-icon{align-items:center;color:#94a3b8;display:flex!important;height:18px!important;justify-content:center;left:1rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);width:18px!important}.action-grid-v2{display:flex;flex-wrap:wrap;gap:.5rem}.grid-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;color:#475569;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.6rem 1rem;transition:all .2s}.grid-btn:hover{background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.grid-btn small{font-size:.9rem;font-weight:inherit}.grid-btn.danger{background:#fffafb;border-color:#fee2e2;color:#ef4444}.grid-btn.warning{background:#fffdf5;border-color:#fef3c7;color:#d97706}.grid-btn.success{background:#fafffc;border-color:#dcfce7;color:#16a34a}.grid-btn.transfer{background:#fafbff;border-color:#ede9fe;color:#7c3aed}.grid-btn.primary{background:#f5f8ff;border-color:#dbeafe;color:#2563eb}.grid-btn.info{background:#f0f9ff;border-color:#e0f2fe;color:#0284c7}.grid-btn.danger:hover{background:#fee2e2}.grid-btn.warning:hover{background:#fef3c7}.grid-btn.success:hover{background:#dcfce7}.grid-btn.transfer:hover{background:#ede9fe}.grid-btn.primary:hover{background:#dbeafe}.grid-btn.info:hover{background:#e0f2fe}@media (max-width:1024px){.toolbar-mobile{align-items:stretch;flex-direction:column}.search-stack{flex-direction:column;gap:.5rem}.search-item{width:100%}.action-grid-v2{grid-gap:.4rem;display:grid;gap:.4rem;grid-template-columns:repeat(4,1fr)}.grid-btn{flex-direction:column;gap:.2rem;height:54px;justify-content:center;padding:.25rem}.grid-btn small{font-size:.65rem}}.search-box{position:relative;width:300px}.search-box input{border:1px solid #cbd5e1;border-radius:8px;outline:none;padding:.6rem 1rem .6rem 2.5rem;transition:border-color .2s,box-shadow .2s;width:100%}.search-box input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.search-icon{color:#94a3b8;left:.75rem;position:absolute;top:50%;transform:translateY(-50%)}.action-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.btn{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:500;gap:.4rem;padding:.5rem 1rem;transition:all .2s}.btn-primary{background-color:#4f46e5;color:#fff}.btn-primary:hover{background-color:#4338ca}.btn-outline{background-color:#fff;border-color:#cbd5e1;color:#334155}.btn-outline:hover{background-color:#f1f5f9}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover{background-color:#dc2626}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover{background-color:#059669}.btn-warning{background-color:#f59e0b;color:#fff}.btn-warning:hover{background-color:#d97706}.table-container{border:1px solid #e2e8f0;border-radius:12px;flex:1 1;overflow:auto}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table td,.data-table th{border-bottom:1px solid #e2e8f0;padding:1rem;white-space:nowrap}.data-table th{background-color:#f8fafc;color:#475569;font-size:.85rem;font-weight:600;position:sticky;top:0;z-index:10}.data-table tbody tr{cursor:pointer;transition:background-color .15s}.data-table tbody tr:hover{background-color:#f1f5f9}.data-table tbody tr.selected-row{background-color:#eef2ff;border-left:3px solid #4f46e5}.data-table tbody tr.row-inactive{background-color:#f8fafc;opacity:.65}.data-table tbody tr.row-inactive .font-medium,.data-table tbody tr.row-inactive .text-primary,.data-table tbody tr.row-inactive td{color:#94a3b8}.font-medium{color:#1e293b;font-weight:500}.font-semibold{font-weight:600}.text-primary{color:#4f46e5}.truncate-cell{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge{font-size:.75rem;font-weight:500;padding:.25rem .75rem}.status-badge.active{background:#dcfce7;color:#16a34a}.status-badge.warning{background:#fef3c7;color:#d97706}.status-badge.inactive{background:#fee2e2;color:#ef4444}.status-badge.default{background:#f1f5f9;color:#64748b}.empty-state-content,.loading-state{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.placeholder-content{align-items:center;color:#64748b;display:flex;font-size:1.1rem;height:200px;justify-content:center}.modal-overlay{z-index:100}.form-modal{max-width:1000px}.sm-modal{max-width:450px}.modal-header{padding:.75rem 1.25rem}.modal-header h3{align-items:center;color:#1e293b;display:flex;font-size:1.25rem;gap:.5rem}.delete-header h3{color:#ef4444}.close-btn{background:none;border:none;border-radius:8px;color:#94a3b8;cursor:pointer;padding:.5rem;transition:all .2s}.close-btn:hover{background:#f1f5f9;color:#334155}.mobile-action-bar{align-items:center;background:#fff;border-top:1px solid #e2e8f0;bottom:0;box-shadow:0 -4px 20px #00000026;display:none;gap:8px;justify-content:space-around;left:0;padding:.75rem 1rem;position:fixed;right:0;z-index:1000}.mobile-action-bar .action-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:.7rem;font-weight:600;gap:4px;padding:8px}.mobile-action-bar .action-btn.warning{color:#d97706}.mobile-action-bar .action-btn.primary-purple{color:#8b5cf6}.mobile-action-bar .action-btn.danger{color:#ef4444}.mobile-action-bar .action-btn.secondary{color:#64748b}.modal-body{padding:1rem 1.25rem}.form-grid{grid-gap:.75rem;gap:.75rem;grid-template-columns:repeat(4,1fr)}.form-group{gap:.15rem}.form-group input,.form-group select{border:1px solid #cbd5e1;border-radius:6px;font-size:.95rem;height:42px;line-height:normal;padding:.5rem .75rem}.form-group input,.form-group select,.form-group textarea{background:#f8fafc;outline:none;transition:all .2s;width:100%}.form-group textarea{border:1px solid #cbd5e1;border-radius:4px;font-size:.85rem;height:auto!important;min-height:0!important;min-height:auto!important;padding:.4rem .6rem}.form-group input:disabled{background:#e2e8f0;color:#64748b;cursor:not-allowed}.form-actions{margin-top:.5rem}.message-alert{align-items:center;animation:fadeIn .3s ease;border-radius:12px;display:flex;font-size:.9rem;gap:.75rem;padding:1rem}.message-alert.error{background:#ef44441a;border:1px solid #ef444433;color:#ef4444}.message-alert.success{background:#22c55e1a;border:1px solid #22c55e33}.student-card-list{display:none}@media (max-width:768px){.student-card-list{display:flex;flex-direction:column;gap:.75rem;padding:.5rem 0}}.student-card{background:#fff;border:1px solid #e2e8f0;border-left:5px solid #0000;border-radius:12px;box-shadow:0 4px 6px #00000005;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;padding:1rem;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1)}.student-card.status-dang-hoc{border-left-color:#10b981}.student-card.status-bao-luu{border-left-color:#f59e0b}.student-card.status-da-nghi{border-left-color:#ef4444;opacity:.7}.student-card:hover{border-color:#cbd5e1;box-shadow:0 10px 15px -3px #0000000d;transform:translateY(-2px)}.student-card.selected{background:#f5f7ff;border-color:#4f46e5}.student-card-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding-bottom:.4rem}.student-id{color:#94a3b8;font-family:monospace}.simple-info-grid{display:flex;flex-direction:column;gap:.4rem}.info-pair{align-items:center;display:flex;justify-content:space-between}.info-pair .label{color:#94a3b8;font-size:.65rem;font-weight:700;text-transform:uppercase}.info-pair .value{color:#334155;font-size:.85rem;font-weight:600}.info-pair .value.highlight{color:#4f46e5}@media (max-width:768px){.mobile-action-bar{display:flex!important}}.animate-slide-up{animation:slideUp .3s cubic-bezier(.16,1,.3,1) forwards}.debt-manager{display:flex;flex-direction:column;gap:1.5rem}.debt-stats-row{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(3,1fr);margin-bottom:.5rem}.debt-stat-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;display:flex;gap:1.25rem;padding:1.25rem;transition:transform .2s}.debt-stat-card:hover{box-shadow:0 10px 15px -3px #00000014;transform:translateY(-2px)}.debt-stat-card.danger{border-left:5px solid #ef4444}.debt-stat-card.overdue{border-left:5px solid #be123c}.stat-icon-box{align-items:center;border-radius:14px;display:flex;height:54px;justify-content:center;width:54px}.stat-icon-box.warning{background:#fffbeb;color:#d97706}.stat-icon-box.danger{background:#fef2f2;color:#ef4444}.stat-info label{color:#64748b;font-size:.75rem;font-weight:700;letter-spacing:.025em;text-transform:uppercase}.stat-info .value{align-items:baseline;color:#1e293b;display:flex;font-size:1.5rem;font-weight:800;gap:4px}.stat-info .value span{color:#94a3b8;font-size:.9rem;font-weight:600}@media (max-width:768px){.debt-stats-row{gap:.75rem;grid-template-columns:1fr}}.debt-layout{display:flex;flex-direction:column;gap:1.5rem;padding-bottom:2rem}.debt-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px -1px #0000000d;max-height:500px;overflow:auto}@media (max-width:768px){.debt-card{max-height:none}}.debt-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;justify-content:space-between;padding:1.25rem 1.5rem}.debt-header,.debt-title{align-items:center;display:flex}.debt-title{gap:.75rem}.debt-title h3{color:#1e293b;font-size:1.15rem;font-weight:700;margin:0}.debt-badge{border-radius:999px;font-size:.8rem;font-weight:700;padding:.35rem .85rem;text-transform:uppercase}.debt-badge.danger{background:#fef2f2;color:#ef4444}.debt-badge.warning{background:#fffbeb;color:#d97706}.debt-body{overflow-x:auto;padding:.5rem 1.5rem 1.5rem}.status-badge{border-radius:999px;font-size:.7rem;font-weight:600;padding:.25rem .6rem;text-transform:uppercase}.status-badge.success{background:#dcfce7;color:#16a34a}.status-badge.primary{background:#e0e7ff;color:#4338ca}.text-lg{font-size:1.05rem}.text-slate-500{color:#64748b}.text-danger{color:#ef4444}.debt-card-list{display:none}@media (max-width:768px){.debt-card-list{display:flex;flex-direction:column;gap:1rem;padding-top:1rem}}.debt-item-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:.75rem;padding:1rem}.debt-item-card.overdue{border-left:4px solid #ef4444}.card-header{align-items:flex-start}.student-info{display:flex;flex-direction:column}.student-name{color:#1e293b;font-size:1rem;font-weight:700}.student-id{color:#64748b;font-size:.75rem}.card-body{display:flex;flex-direction:column;gap:.5rem}.info-line{align-items:center;color:#475569;display:flex;font-size:.9rem;justify-content:space-between}.amount-row{border-top:1px dashed #e2e8f0;margin-top:.5rem;padding-top:.5rem}.debt-amount{color:#ef4444;font-size:1.1rem;font-weight:800}.btn-pay{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:6px 16px}.deadline-row{background:#fef2f2;border-radius:8px;padding:.5rem}.deadline-label{color:#ef4444;font-weight:600}.deadline-date{color:#b91c1c;font-size:1rem;font-weight:800}.employee-manager{display:flex;flex-direction:column;gap:1.5rem}.emp-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:.5rem}.margin-bottom-0{margin-bottom:0!important}.mx-width-800{max-width:800px}.mx-width-1000{max-width:1000px}.mx-width-480{max-width:480px}.shadow-sm{box-shadow:0 1px 3px #0000000d}.border-radius-lg{border-radius:12px}.table-scroll-wrapper{overflow-x:auto}@media (max-width:768px){.table-scroll-wrapper{display:none}}.employee-card-list{display:none}@media (max-width:768px){.employee-card-list{display:flex;flex-direction:column;gap:1rem;padding:1rem}}.employee-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:.75rem;padding:1.25rem;transition:all .2s ease}.employee-card:hover{border-color:#cbd5e1}.employee-card.selected{background:#f0f7ff;border-color:#3b82f6;box-shadow:0 4px 6px -1px #3b82f61a}.employee-card.inactive{background:#f8fafc;opacity:.6}.employee-card-header{align-items:flex-start;display:flex;justify-content:space-between}.employee-info{display:flex;flex-direction:column}.employee-name{color:#1e293b;font-size:1.05rem;font-weight:700}.employee-id{color:#64748b;font-size:.8rem;font-weight:500}.employee-card-body{display:flex;flex-direction:column;gap:.5rem}.info-row{align-items:center;color:#475569;display:flex;font-size:.9rem;justify-content:space-between}.info-row.note{border-top:1px dashed #e2e8f0;font-size:.85rem;font-style:italic;margin-top:.5rem;padding-top:.5rem}@media (max-width:768px){.emp-toolbar{align-items:stretch;flex-direction:column}.search-box,.search-box input{width:100%!important}.action-buttons{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr 1fr}.action-buttons .btn{justify-content:center;margin:0;width:100%}.action-buttons .btn-danger{grid-column:span 2}}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:10000}.modal-content{animation:slideUp .3s cubic-bezier(.16,1,.3,1);background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;color:#1e293b;display:flex;flex-direction:column;max-height:90vh;width:100%}.modal-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:1rem 1.5rem}.modal-body{overflow-y:auto;padding:1.5rem}.form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr)}.form-group.full-width{grid-column:span 3}@media (max-width:991px){.form-grid{grid-template-columns:repeat(2,1fr)}.form-group.full-width{grid-column:span 2}.form-group:empty{display:none}}@media (max-width:640px){.modal-content{max-height:95vh}.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}}.form-group{gap:.35rem}.form-group label{color:#64748b;font-size:.75rem;text-transform:uppercase}.form-group input,.form-group select,.form-group textarea{background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;font-size:.9rem;outline:none;padding:.5rem .75rem;transition:all .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-actions{display:flex;gap:1rem;grid-column:1/-1;justify-content:center;margin-top:2rem}.overview-dashboard{display:flex;flex-direction:column;gap:1rem}.section-title{color:#1e293b;font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.margin-0{margin:0!important}.margin-bottom-1{margin-bottom:1rem!important}.text-success{color:#059669}.text-danger{color:#dc2626}.text-slate-800{color:#1e293b}.flex-center{align-items:center;display:flex;gap:.5rem}.top-cards-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.o-card{align-items:center;background:#fff;border:1px solid #f1f5f9;border-radius:14px;box-shadow:0 4px 12px #00000008;display:flex;gap:1.25rem;padding:1.25rem;transition:transform .2s,box-shadow .2s}.o-card:hover{box-shadow:0 8px 24px #0000000f;transform:translateY(-2px)}.o-icon{align-items:center;border-radius:12px;color:#fff;display:flex;height:54px;justify-content:center;width:54px}.o-data{display:flex;flex-direction:column}.o-data span{color:#64748b;font-size:.85rem;font-weight:600;text-transform:uppercase}.o-data h3{color:#1e293b;font-size:1.5rem;font-weight:800;margin:0}.o-card.blue .o-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.o-card.green .o-icon{background:linear-gradient(135deg,#10b981,#059669)}.o-card.purple .o-icon{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}.o-card.teal .o-icon{background:linear-gradient(135deg,#14b8a6,#0d9488)}.o-card.success .o-icon{background:linear-gradient(135deg,#22c55e,#16a34a)}.o-card.danger .o-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.financial-divider{background:#e2e8f0;height:1px;margin:1.5rem 0;width:100%}.financial-header{flex-wrap:wrap;justify-content:space-between}.financial-header,.sh-title-group{align-items:center;display:flex;gap:1rem}.sh-massive-title{font-size:1.6rem;font-weight:800}.sh-standard-title{font-size:1.35rem;font-weight:700}.finance-filters{gap:1rem}.filter-group,.finance-filters{align-items:center;display:flex}.filter-group{background:#fff;border:1px solid #cbd5e1;border-radius:8px;gap:.5rem;padding:.4rem .8rem}.filter-group select{background:#0000;border:none;color:#475569;cursor:pointer;font-size:.95rem;font-weight:600;outline:none}.custom-dates{align-items:center;background:#fff;border:1px solid #cbd5e1;border-radius:8px;display:flex;gap:.75rem;padding:.35rem .75rem}.custom-dates-sm{padding:.25rem .5rem}.custom-dates input{border:none;color:#333;font-size:.95rem;font-weight:600;outline:none;padding:.4rem}.custom-dates-sm input{font-size:.85rem;padding:.2rem}.date-sep{color:#94a3b8;font-size:.85rem;font-weight:600}.finance-cards-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:1rem}.f-card{align-items:flex-start;background:#fff;border:1px solid #f1f5f9;border-radius:16px;box-shadow:0 10px 25px #00000008;display:flex;gap:1.5rem;overflow:hidden;padding:1.75rem;position:relative}.f-card:before{bottom:0;content:"";left:0;position:absolute;top:0;width:6px}.f-card.success:before{background:#22c55e}.f-card.danger:before{background:#ef4444}.f-card.warning:before{background:#f59e0b}.f-icon{border-radius:14px;padding:1rem}.f-card.success .f-icon{background:#f0fdf4;color:#16a34a}.f-card.danger .f-icon{background:#fef2f2;color:#dc2626}.f-card.warning .f-icon{background:#fffbeb;color:#d97706}.f-data{align-items:flex-start;display:flex;flex-direction:column;gap:.25rem}.f-data span{color:#64748b;font-size:.85rem;font-weight:800;text-transform:uppercase}.f-data h2{font-size:1.8rem;font-weight:900;margin:0}.f-card.success .f-data h2{color:#16a34a}.f-card.danger .f-data h2{color:#dc2626}.f-card.warning .f-data h2{color:#d97706}.f-data p{color:#94a3b8;font-size:.85rem;margin:.25rem 0 0}.wallets-grid{grid-gap:2.5rem;gap:2.5rem;grid-template-columns:1fr 1fr;margin-top:1.25rem}.wallet-col{background:#fff;border:1px solid #f1f5f9;border-radius:14px;box-shadow:0 4px 6px #00000005;padding:1.5rem}.wallet-header{border-bottom:1px solid #f1f5f9;font-size:1.1rem;font-weight:800;margin-bottom:1.25rem;padding-bottom:.75rem}.wallet-cards{display:flex;flex-direction:column;gap:.75rem}.w-card{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;display:flex;justify-content:space-between;padding:1rem 1.25rem;transition:all .2s}.w-card:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 4px 12px #0000000a}.w-label{color:#475569;font-size:.95rem;font-weight:600}.w-amount{font-size:1.2rem;font-weight:800}.thu-col .w-amount{color:#059669}.chi-col .w-amount{color:#dc2626}.card-loading{min-height:150px}.card-loading,.card-loading-sm{background:#fff;border:1px dashed #e2e8f0;border-radius:12px}.card-loading-sm{min-height:80px}@media (max-width:768px){.financial-header{gap:1.25rem;margin-bottom:1.5rem}.financial-header,.sh-title-group{align-items:flex-start;flex-direction:column}.sh-title-group{gap:.75rem;width:100%}.sh-massive-title{font-size:1.3rem;line-height:1.3}.sh-standard-title{font-size:1.15rem}.finance-filters{flex-direction:column;gap:.75rem;width:100%}.custom-dates,.filter-group{box-sizing:border-box;justify-content:space-between;width:100%}.custom-dates{gap:.5rem}.custom-dates input{box-sizing:border-box;flex:1 1;min-width:0;width:100%}.wallets-grid{gap:1rem;grid-template-columns:1fr}.finance-cards-grid{gap:.75rem;grid-template-columns:1fr 1fr}.f-card{gap:.75rem;padding:1rem}.f-data h2{font-size:1.15rem;line-height:1.3;white-space:normal;word-break:break-all}.f-icon{flex-shrink:0;padding:.5rem}.f-icon svg{height:24px;width:24px}.top-cards-grid{gap:.75rem;grid-template-columns:1fr 1fr}.o-card{gap:.75rem;padding:.75rem}.o-icon{height:36px;width:36px}.o-icon svg{height:20px;width:20px}.o-data h3{font-size:1.1rem}.o-data span{font-size:.65rem}.finance-cards-grid .f-card:nth-child(3){grid-column:span 2}}.invoice-manager{display:flex;gap:1.5rem;height:calc(100vh - 110px);overflow:hidden}.im-left-pane{background:#fff;border:1px solid #f1f5f9;border-radius:12px;box-shadow:0 4px 6px #00000005;display:flex;flex-direction:column;width:25%}.im-search{align-items:center;background:#f8fafc;border-bottom:1px solid #f1f5f9;border-radius:12px 12px 0 0;display:flex;gap:.75rem;padding:1.25rem}.im-search input{background:#0000;border:none;font-size:1.05rem;font-weight:500;outline:none;width:100%}.im-student-list{flex:1 1;gap:.5rem;overflow-y:auto;padding:.75rem}.im-student-card,.im-student-list{display:flex;flex-direction:column}.im-student-card{border:1px solid #0000;border-radius:10px;cursor:pointer;gap:.6rem;padding:1rem 1.25rem;transition:background .2s,border .2s}.im-student-card:hover{background:#f8fafc;border-color:#e2e8f0}.im-student-card.active{background:#eff6ff;border-color:#bfdbfe}.im-sc-top{align-items:flex-start;display:flex;justify-content:space-between}.im-card-name{color:#3b82f6!important;font-size:1.05rem;font-weight:800}.im-card-name small{color:#94a3b8;font-weight:600}.im-sc-bot{align-items:center;display:flex;justify-content:space-between}.im-card-sub{color:#64748b;font-size:.85rem;font-weight:500}.im-badge{background:#f1f5f9;border-radius:99px;color:#475569;font-size:.75rem;font-weight:700;padding:.2rem .6rem}.im-s-empty{color:#94a3b8;padding:2rem 1rem;text-align:center}.im-right-pane{background:#fff;border:1px solid #f1f5f9;border-radius:12px;box-shadow:0 4px 6px #00000005;flex:1 1;overflow-x:hidden;overflow-y:auto}.im-empty,.im-right-pane{display:flex;flex-direction:column}.im-empty{align-items:center;color:#94a3b8;gap:1rem;height:100%;justify-content:center;padding:3rem;text-align:center}.im-empty h3{color:#475569;font-size:1.5rem;margin:0}.message-alert{animation:slideDown .3s ease-out;border-radius:8px;font-weight:700;margin:1.5rem 2.5rem 0;padding:1rem 1.5rem;text-align:center}.message-alert.success{background:#dcfce7;border:1px solid #bbf7d0;color:#16a34a}.message-alert.error{background:#fee2e2;border:1px solid #fecaca;color:#dc2626}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.invoice-details{padding:1.5rem}.im-section{background:#fdfeff;margin-bottom:1.5rem}.im-section-title{font-size:1.15rem;margin-bottom:1rem;padding-bottom:.5rem}.im-grid-3{grid-gap:1rem;gap:1rem}.im-grid-4{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr)}.im-grid-2{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.margin-top-1{margin-top:1rem}.im-field{display:flex;flex-direction:column;gap:.25rem}.im-field-hz{align-items:center;display:flex;flex-direction:row;gap:.5rem;width:100%}.im-field-hz label{color:#64748b;font-size:.8rem;font-weight:800;min-width:100px;text-transform:uppercase}.im-field-hz .val-text{padding:0}.im-field-hz input,.im-field-hz select{flex:1 1;max-width:160px}.highlight-field select{max-width:none!important}.val-text{padding:.2rem 0}.val-text.badge-style{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;display:inline-block;font-size:.95rem;padding:.3rem .75rem;width:max-content}.text-bold{font-weight:800}.im-field input,.im-field select,.im-field-hz input,.im-field-hz select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#1e293b;font-size:.95rem;font-weight:600;outline:none;padding:.7rem .85rem}.im-finance-row{grid-gap:1.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:grid;gap:1.5rem;margin-bottom:.75rem;padding:1.25rem 1.5rem}.im-finance-row.grid-3{grid-template-columns:.8fr 1.4fr .8fr}.im-finance-row.grid-4{grid-template-columns:.7fr 1.5fr .7fr .8fr}.im-finance-row.grid-2{grid-template-columns:repeat(2,1fr)}.im-finance-row.highlight-row{background:#eff6ff;border-color:#bfdbfe}.im-fi-item{align-items:flex-start}.im-fi-item,.im-fi-item-col{display:flex;flex-direction:column;gap:.5rem}.im-fi-item-col label{color:#64748b;font-size:.75rem;font-weight:700;text-transform:uppercase}.im-fi-item-col .im-input-text,.im-fi-item-col .im-select{width:100%}.fi-val-display{font-size:1.15rem;font-weight:800;padding:.4rem 0}.fi-input-wrapper{align-items:center;display:flex;position:relative;width:100%}.fi-input-wrapper.with-chips{align-items:flex-start;flex-direction:column}.fi-input-wrapper.with-chips input{padding-right:2.25rem}.tuition-packages-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;width:100%}.fi-input-wrapper .unit{color:#94a3b8;font-weight:700;position:absolute;right:.85rem;top:50%;transform:translateY(-50%)}.fi-input-wrapper.with-chips .unit{top:18px}.fi-input-wrapper input{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;font-size:1rem;font-weight:800;outline:none;padding:.6rem 2.25rem .6rem .85rem;text-align:right;width:100%}.fi-input-wrapper.giant input{border-color:#93c5fd;color:#1d4ed8;font-size:1.25rem}.im-input-text,.im-select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#1e293b;font-size:.95rem;font-weight:600;outline:none;padding:.6rem .85rem}.highlight-deduction{background:#fff1f2;border:1px solid #fecdd3;border-radius:6px;color:#be123c!important;display:inline-block;margin-top:4px;padding:4px 8px}.im-finance-row.grid-4{align-items:flex-start;grid-template-columns:repeat(4,1fr)}.im-finance-row.grid-3{align-items:flex-start;grid-template-columns:repeat(3,1fr)}.im-actions{display:flex;justify-content:center;margin-top:1rem;width:100%}.im-btn-submit{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:1.25rem;font-weight:800;gap:.75rem;padding:1rem 2.5rem;transition:transform .2s,box-shadow .2s}.im-btn-submit:hover{box-shadow:0 8px 20px #10b9814d;transform:translateY(-2px)}.tuition-packages{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.tuition-chip{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;box-shadow:0 2px 4px #00000005;color:#16a34a;cursor:pointer;font-size:.85rem;font-weight:700;padding:.35rem .75rem;transition:all .2s;white-space:nowrap}.tuition-chip:hover{background:#dcfce7;border-color:#86efac;transform:translateY(-1px)}.im-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.im-success-modal,.im-warning-modal{background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;color:#1e293b;max-width:440px;padding:2.5rem;position:relative;text-align:center;width:90%}.im-close-btn{align-items:center;background:#0000;border:none;border-radius:99px;color:#94a3b8;cursor:pointer;display:flex;justify-content:center;padding:.5rem;position:absolute;right:1rem;top:1rem;transition:.2s}.im-close-btn:hover{background:#f1f5f9;color:#ef4444}.im-warning-icon{background:#fee2e2;box-shadow:0 0 0 8px #fef2f2;color:#ef4444}.im-success-icon,.im-warning-icon{align-items:center;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.im-success-icon{background:#e2feee;box-shadow:0 0 0 8px #edfff0;color:green}.im-success-modal h3,.im-warning-modal h3{color:#0f172a;font-size:1.35rem;font-weight:800;margin:0 0 .75rem}.im-success-modal p,.im-warning-modal p{color:#475569;font-size:1rem;line-height:1.6;margin-bottom:2rem}.im-warning-actions{display:flex;justify-content:center}.im-btn-warn-ok{background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;padding:.85rem 2rem;transition:.2s;width:100%}.im-btn-warn-ok:hover{background:#dc2626;box-shadow:0 4px 12px #dc262640}.im-btn-success-ok{background:#4dff4a;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;padding:.85rem 2rem;transition:.2s;width:100%}.im-btn-success-ok:hover{background:#179301;box-shadow:0 4px 12px #dc262640}.print-a5-receipt{display:none}@media print{body>:not(.print-a5-receipt){display:none!important}body,html{background:#fff!important;margin:0!important;padding:0!important}@page{size:A5 landscape;margin:0}.print-a5-receipt{background:#fff;box-sizing:border-box;color:#000;display:block!important;font-family:Times New Roman,Times,serif;height:148mm;padding:12mm 15mm;position:static!important;visibility:visible!important;width:210mm}.print-a5-receipt *{color:#000!important;visibility:visible!important}.p-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:20px}.p-header-left h3{font-size:16pt;font-weight:700;margin:0 0 5px}.p-header-left p{font-size:12pt;margin:2px 0}.p-title-area{margin-bottom:5px;text-align:center}.p-title-area h2{font-size:20pt;font-weight:700;margin:0 0 5px;text-transform:uppercase}.p-title-area p{font-size:11pt;font-style:italic;margin:0}.p-content{margin-bottom:25px;padding:0 10px}.p-row{align-items:baseline;display:flex;font-size:12pt;margin-bottom:8px}.p-label{display:inline-block;min-width:140px}.p-value{border-bottom:1px dotted #999;flex:1 1;padding-bottom:2px}.p-signatures{display:grid;grid-template-columns:repeat(4,1fr);margin-bottom:30px;text-align:center}.sig-box h4{font-size:12pt;font-weight:700;margin:0 0 5px}.sig-box p{font-size:11pt;font-style:italic;margin:0}.sig-name{font-size:12pt;font-weight:700;margin-top:50px}.p-footer-note{font-size:12pt;padding-left:10px}}@media (max-width:991px){.invoice-manager{flex-direction:column;gap:0;height:calc(100vh - 80px);overflow:auto}.im-left-pane{border:none;border-radius:0;box-shadow:none;height:100%;min-height:calc(100vh - 120px);width:100%}.mobile-show-details .im-left-pane{display:none}.im-right-pane{border:none;border-radius:0;box-shadow:none;display:none;flex:1 1;height:100%;overflow-y:auto;width:100%}.mobile-show-details .im-right-pane{display:flex}.invoice-details{padding:.75rem}.mobile-header-actions{display:block;margin-bottom:.75rem}.btn-back{align-items:center;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:12px;color:#475569;cursor:pointer;display:flex;font-size:.95rem;font-weight:800;gap:.6rem;padding:.75rem 1.25rem;transition:.2s}.btn-back:hover{background:#e2e8f0}.im-section{margin-bottom:.75rem}.im-section-title{font-size:1rem;margin-bottom:.5rem;padding-bottom:.35rem}.im-finance-row.grid-2,.im-finance-row.grid-3,.im-finance-row.grid-4,.im-grid-2,.im-grid-3,.im-grid-4{display:flex!important;flex-direction:column!important;gap:0!important;padding:.6rem .75rem!important}.im-fi-item{align-items:center!important;border-bottom:1px solid #f1f5f9;flex-direction:row!important;justify-content:space-between!important;padding:.6rem 0!important}.im-fi-item:last-child{border-bottom:none}.im-fi-item label{color:#64748b;flex-shrink:0;font-size:.75rem!important;font-weight:700;line-height:1.2;max-width:110px;min-width:80px;text-transform:uppercase;white-space:normal}.im-fi-item .fi-val-display{flex:1 1;font-size:1.05rem!important;padding:0!important;text-align:right!important}.im-fi-item .fi-input-wrapper{flex:1 1}.im-fi-item .fi-input-wrapper.with-chips{align-items:stretch!important;flex-direction:column!important;position:static!important}.im-fi-item .tuition-packages-chips{background:#0000!important;border:none!important;box-shadow:none!important;display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;padding:0!important;position:static!important;width:100%!important}.fi-input-wrapper.with-chips{flex-direction:column!important;position:static!important}.fi-input-wrapper.with-chips input{padding-right:2.25rem!important}.im-actions{justify-content:stretch}.im-btn-submit{font-size:1.2rem;justify-content:center;padding:1.1rem;width:100%}.im-finance-box{flex-direction:column}.fi-r-divider{height:1px;width:100%}.fi-right-col{border-radius:0 0 16px 16px;border-top:1px solid #e2e8f0}.im-fi-input-row{align-items:flex-start;flex-direction:column;gap:.75rem}.fi-input-wrapper,.fi-input-wrapper input,.fi-input-wrapper.giant,.fi-input-wrapper.giant input{max-width:100%!important;width:100%!important}.fi-val-display{text-align:right;width:100%}.total-highlight .sum-val{font-size:2rem}}.study-summary-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000d;margin-bottom:1.5rem;padding:1rem}.study-summary-label{color:#64748b;font-size:.85rem;font-weight:700;letter-spacing:.5px;margin-bottom:.75rem;text-transform:uppercase}.study-summary-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(4,1fr)}.ss-badge{align-items:center;border-radius:10px;display:flex;flex-direction:column;justify-content:center;padding:.75rem .5rem;transition:transform .2s}.ss-badge:hover{transform:translateY(-2px)}.ss-num{font-size:1.5rem;font-weight:900;line-height:1;margin-bottom:4px}.ss-txt{font-size:.7rem;font-weight:800;opacity:.9;text-transform:uppercase}.ss-present{background:#f0fdf4;border:1px solid #dcfce7;color:#16a34a}.ss-excused{background:#fffbeb;border:1px solid #fef3c7;color:#d97706}.ss-absent{background:#fff1f2;border:1px solid #ffe4e6;color:#e11d48}.ss-total{background:#eff6ff;border:1px solid #dbeafe;color:#2563eb}@media (max-width:768px){.study-summary-grid{grid-template-columns:repeat(2,1fr)}.ss-num{font-size:1.25rem}.im-fi-item-col .im-input-text,.im-fi-item-col .im-select,.im-input-text,.im-select{box-sizing:border-box!important;width:100%!important}.im-fi-item-col{border-bottom:1px solid #f1f5f9;padding:.5rem 0}.im-fi-item-col:last-child{border-bottom:none}}.product-manager{display:flex;flex-direction:column;gap:1rem;height:calc(100vh - 100px)}.pm-toolbar{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 6px #00000005;display:flex;justify-content:space-between;padding:.75rem 1rem}.pm-toolbar .search-box{align-items:center;background:#f1f5f9;border:1px solid #0000;border-radius:8px;display:flex;gap:.5rem;padding:.45rem .75rem;transition:.2s;width:260px}.pm-toolbar .search-box:focus-within{background:#fff;border-color:#93c5fd;box-shadow:0 0 0 4px #3b82f61a}.pm-toolbar .search-box input{background:#0000;border:none;font-size:.95rem;outline:none;width:100%}.pm-toolbar .action-buttons{display:flex;gap:.5rem}.pm-toolbar .btn{font-size:.85rem;padding:.4rem .75rem}.pm-table-wrapper{background:#fff;border-radius:12px;box-shadow:0 4px 6px #00000005;flex:1 1;overflow-y:auto;padding:1rem}.action-flex{display:flex;gap:.5rem}.btn-icon{align-items:center;background:#f1f5f9;border:none;border-radius:8px;color:#475569;cursor:pointer;display:flex;padding:.5rem;transition:.2s}.btn-icon:hover{background:#e2e8f0;color:#0f172a}.btn-blue{background:#eff6ff;color:#2563eb}.btn-blue:hover{background:#dbeafe;color:#1d4ed8}.stock-badge{border-radius:99px;font-size:.85rem;font-weight:800;padding:.35rem .75rem}.in-stock{background:#dcfce7;border:1px solid #bbf7d0;color:#16a34a}.out-stock{background:#fee2e2;border:1px solid #fecaca;color:#dc2626}.mb-4{margin-bottom:1rem}.mb-0{margin-bottom:0!important}.form-alert.info{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1e40af;display:flex;font-size:.95rem;gap:.75rem;grid-column:1/-1;line-height:1.5;padding:1rem}.w-full{width:100%}.flex-col{display:flex;flex-direction:column}.gap-2{gap:.5rem}.p-4{padding:1rem}.rounded-lg{border-radius:.5rem}.rounded{border-radius:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.product-card-list{display:none;flex-direction:column;gap:1rem;padding-bottom:2rem}@media (max-width:991px){.product-manager{height:auto}.pm-toolbar{align-items:stretch;flex-direction:column;gap:1rem;padding:1rem}.pm-toolbar .search-box{width:100%}.pm-toolbar .action-buttons{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(2,1fr)}.pm-toolbar .action-buttons button{font-size:.8rem;justify-content:center;padding:.6rem}.pm-toolbar .action-buttons button:last-child{grid-column:span 2}.pm-table-wrapper{display:none}.product-card-list{display:flex}}.product-card{background:#fff;border:1px solid #f1f5f9;border-radius:12px;box-shadow:0 4px 6px #00000005;overflow:hidden}.card-main{display:flex;flex-direction:column;gap:.75rem;padding:1rem}.card-header{align-items:center;display:flex;justify-content:space-between}.mahang-code{background:#f1f5f9;border-radius:4px;color:#94a3b8;font-size:.75rem;font-weight:700;padding:2px 8px}.tenhang-val{color:#1e293b;font-size:1.1rem;font-weight:800}.price-info-row{border-top:1px dashed #f1f5f9;display:flex;gap:1.5rem;padding-top:.5rem}.price-item{display:flex;flex-direction:column;gap:2px}.price-item label{color:#94a3b8;font-size:.65rem;font-weight:700;text-transform:uppercase}.price-item span{color:#334155;font-size:.95rem;font-weight:800}.card-actions-row{border-top:1px solid #f1f5f9;display:grid;grid-template-columns:repeat(3,1fr)}.card-btn{align-items:center;background:#fdfdfd;border:none;color:#64748b;cursor:pointer;display:flex;font-size:.85rem;font-weight:700;gap:.4rem;justify-content:center;padding:.75rem;transition:.2s}.card-btn:not(:last-child){border-right:1px solid #f1f5f9}.card-btn:hover{background:#f1f5f9}.card-btn.btn-blue{background:#eff6ff;color:#2563eb}.sales-pos{display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;gap:1rem;height:800px;overflow:hidden}.sp-col-1,.sp-col-2{flex-direction:column;max-width:320px;min-width:260px;width:25%}.sp-col-1,.sp-col-2,.sp-col-3{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 6px #00000005;display:flex;overflow:hidden}.sp-col-3{flex:1 1;flex-direction:column;height:100%;min-height:0;min-width:0}.sp-col-header{background:#fff;border-bottom:2px solid #f1f5f9;color:#64748b;font-size:1.15rem;font-weight:500;padding:1rem 1.25rem;text-transform:uppercase}.sp-search{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;gap:.5rem;padding:1rem;position:sticky;top:0;z-index:5}.sp-search input{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#1e293b;font-size:.95rem;outline:none;padding:.5rem .75rem;transition:.2s;width:100%}.sp-search input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.sp-items-container{flex:1 1;gap:0;overflow-y:auto;padding:.5rem}.sp-item-card,.sp-items-container{display:flex;flex-direction:column}.sp-item-card{background:#fff;border-bottom:1px solid #f1f5f9;cursor:pointer;gap:.25rem;padding:.85rem 1rem;transition:.2s;-webkit-user-select:none;user-select:none}.sp-item-card:hover{background:#f8fafc}.sp-item-card.active{background:#eff6ff;border-left:3px solid #3b82f6}.sp-ic-title{color:#2b93fb;font-size:1rem;font-weight:700;line-height:1.3}.sp-ic-sub{color:#64748b;font-size:.85rem;font-weight:500}.sp-bill-info{align-items:flex-start;border-bottom:1px dashed #e2e8f0;display:flex;justify-content:space-between;padding:.75rem 1.25rem}.sp-student-info{display:flex;flex-direction:column;gap:.25rem}.sp-info-row{align-items:center;display:flex;gap:1.5rem}.sp-info-row .lbl{color:#64748b;font-size:.9rem;min-width:60px}.sp-info-row .val{color:#0f172a;font-size:.95rem;font-weight:600}.sp-cart{background:#fff;flex:1 1 auto;min-height:0;overflow-y:auto;padding:0 1rem}.sp-cart-table{border-collapse:collapse;table-layout:fixed;width:100%}.sp-cart-table th{background:#2b93fb;border:none;color:#fff!important;font-size:.85rem;font-weight:600;padding:.85rem .5rem;position:sticky;text-align:left;top:0;z-index:10}.sp-cart-table th:first-child{width:14%}.sp-cart-table th:nth-child(2){width:25%}.sp-cart-table th:nth-child(3){width:12%}.sp-cart-table th:nth-child(4){text-align:center;width:15%}.sp-cart-table th:nth-child(5),.sp-cart-table th:nth-child(6){text-align:right;width:15%}.sp-cart-table th:nth-child(7){width:4%}.sp-cart-table td{word-wrap:break-word;border-bottom:1px solid #e2e8f0;font-size:.9rem;padding:.85rem .5rem;vertical-align:middle}.sp-qty-ctrl{gap:.5rem}.sp-qty-ctrl,.sp-qty-ctrl button{align-items:center;display:flex;justify-content:center}.sp-qty-ctrl button{background:#f1f5f9;border:none;border-radius:4px;color:#64748b;cursor:pointer;padding:.35rem;transition:.2s}.sp-qty-ctrl button:hover{background:#e2e8f0;color:#0f172a}.sp-qty-ctrl span{color:#0f172a;font-size:1rem;font-weight:700;text-align:center;width:24px}.sp-btn-del{align-items:center;background:#0000;border:none;border-radius:6px;color:#ef4444;cursor:pointer;display:flex;justify-content:center;padding:.4rem;transition:.2s}.sp-btn-del:hover{background:#fee2e2}.sp-checkout{background:#fafafa;border-top:1px solid #e2e8f0;display:flex;flex-direction:column;gap:.4rem;padding:.75rem 1.25rem}.sp-divider{background:#e2e8f0;height:1px;margin:.2rem 0;width:100%}.sp-co-row{align-items:center;display:flex;justify-content:space-between}.sp-co-row.base span:first-child{color:#64748b;font-size:.85rem;font-weight:700}.sp-co-row.base span:last-child{color:#334155;font-size:1.05rem;font-weight:800}.sp-co-row.input-line{margin:0}.sp-co-grand{color:#0f172a;font-size:1.25rem;font-weight:900;margin:.2rem 0}.sp-co-highlight{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;margin-bottom:.2rem;padding:.5rem 1rem}.sp-co-highlight span:first-child{color:#1e3a8a;font-size:1rem;font-weight:800}.sp-val-debt{background:#fff;border:1px solid #e2e8f0;border-radius:4px;font-size:.9rem;font-weight:700;padding:.2rem .5rem}.text-success{color:#059669!important}.sp-co-config{display:flex;gap:1rem;margin-top:.25rem}.cfg-item{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.cfg-item.flex-2{flex:2 1}.cfg-item label{color:#64748b;font-size:.75rem;font-weight:700;text-transform:uppercase}.cfg-item input,.cfg-item select{border:1px solid #cbd5e1;border-radius:6px;font-size:.9rem;font-weight:600;outline:none;padding:.5rem .75rem;transition:.2s}.cfg-item input:focus,.cfg-item select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.sp-input-wrap{position:relative}.sp-input-wrap input{border:1px solid #cbd5e1;border-radius:6px;font-size:.95rem;font-weight:700;outline:none;padding:.4rem .6rem;text-align:right;transition:.2s;width:120px}.sp-input-wrap input:focus{border-color:#3b82f6}.sp-input-wrap.lg input{border-color:#93c5fd;color:#1d4ed8;font-size:1.2rem;padding:.4rem .75rem;width:160px}.sp-input-wrap.lg input:focus{box-shadow:0 0 0 3px #3b82f633}.sp-btn-checkout{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;box-shadow:0 4px 10px #10b98126;color:#fff;cursor:pointer;display:flex;font-size:1.15rem;font-weight:800;gap:.75rem;justify-content:center;letter-spacing:.5px;margin-top:.5rem;padding:.85rem;text-transform:uppercase;transition:.3s}.sp-btn-checkout:hover{box-shadow:0 6px 15px #10b98140;transform:translateY(-2px)}.sp-btn-checkout:disabled{box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.sp-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.sp-success-modal{background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;max-width:440px;padding:2.5rem;position:relative;text-align:center;width:90%}.sp-close-btn{align-items:center;background:#0000;border:none;border-radius:99px;color:#94a3b8;cursor:pointer;display:flex;justify-content:center;padding:.5rem;position:absolute;right:1rem;top:1rem;transition:.2s}.sp-close-btn:hover{background:#f1f5f9;color:#ef4444}.sp-success-icon{align-items:center;background:#e2feee;border-radius:50%;box-shadow:0 0 0 8px #edfff0;color:green;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.sp-success-modal h3{color:#0f172a;font-size:1.35rem;font-weight:800;margin:0 0 .75rem}.sp-success-modal p{color:#475569;font-size:1rem;line-height:1.6;margin-bottom:2rem}.sp-modal-actions{display:flex;justify-content:center}.sp-btn-success-ok{background:#4dff4a;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;padding:.85rem 2rem;transition:.2s;width:100%}.sp-btn-success-ok:hover{background:#179301;box-shadow:0 4px 12px #dc262640}.animate-slide-up{animation:slideUp .35s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.sp-mobile-next-btn,.sp-mobile-tabs{display:none}@media (max-width:991px){.sales-pos{flex-direction:column;gap:0;height:calc(100vh - 80px);padding-top:50px;position:relative}.sp-mobile-tabs{background:#fff;border-bottom:1px solid #e2e8f0;display:flex;height:50px;left:0;position:fixed;right:0;top:60px;z-index:1000}.sp-mobile-tabs button{background:#0000;border:none;border-bottom:3px solid #0000;color:#94a3b8;flex:1 1;font-size:.85rem;font-weight:700}.sp-mobile-tabs button.active{background:#f8fafc;border-bottom-color:#3b82f6!important;color:#3b82f6!important}.sp-col-1,.sp-col-2,.sp-col-3{border:none;border-radius:0;box-shadow:none;height:100%;max-width:none!important;width:100%!important}.mobile-hide{display:none!important}.mobile-active{display:flex!important}.sp-mobile-next-btn{bottom:1rem;left:1rem;position:fixed;right:1rem;z-index:10}.sp-cart-table td:first-child,.sp-cart-table td:nth-child(3),.sp-cart-table th:first-child,.sp-cart-table th:nth-child(3){display:none!important}.sp-cart{border-bottom:2px solid #f1f5f9;flex:none;height:auto!important;max-height:250px;padding:0 .5rem}.sp-cart-table td{padding:.6rem .35rem}.sp-checkout{background:#fff;flex:1 1;overflow-y:auto;padding:.75rem 1rem}.sp-co-grand{font-size:1.2rem}.sp-input-wrap.lg input{font-size:1.1rem;padding:.35rem .5rem;width:130px}.sp-btn-checkout{font-size:1rem;padding:.65rem}.sp-co-row.base span:first-child{font-size:.8rem}.sp-co-highlight{padding:.4rem .75rem}.sp-co-highlight span:first-child{font-size:.9rem}.sp-co-config{flex-direction:column;gap:.5rem}}.sp-product-card{align-items:center;background:#fff;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:1rem 1.25rem;transition:all .2s}.sp-product-card.in-cart{background:#f0f9ff}.sp-product-card:hover{background:#f8fafc}.sp-prod-info{flex:1 1}.sp-prod-actions{align-items:center;display:flex;gap:.85rem;margin-left:1rem}.sp-btn-minus,.sp-btn-plus{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #00000005;color:#64748b;cursor:pointer;display:flex;height:34px;justify-content:center;transition:.2s;width:34px}.sp-btn-plus:hover{background:#3b82f6;border-color:#3b82f6;color:#fff}.sp-btn-minus:hover{background:#ef4444;border-color:#ef4444;color:#fff}.sp-q-badge{color:#0f172a;font-size:1.1rem;font-weight:800;min-width:20px;text-align:center}.task-manager{display:flex;flex:1 1;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;gap:1.5rem;min-height:0}.stats-container{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:0}@media (max-width:768px){.stats-container{gap:.75rem;grid-template-columns:repeat(2,1fr)}.stat-card{gap:.75rem;padding:.75rem}.stat-icon{height:36px;width:36px}.stat-value{font-size:1.1rem}.stat-label{font-size:.7rem}}.stat-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px #00000005;display:flex;gap:1rem;padding:1.25rem;transition:.2s}.stat-card:hover{box-shadow:0 4px 12px #0000000d;transform:translateY(-2px)}.stat-card.active-filter{border:2px solid #3b82f6;box-shadow:0 4px 15px #3b82f626}.stat-icon{align-items:center;border-radius:12px;display:flex;height:44px;justify-content:center;width:44px}.stat-card.total .stat-icon{background:#e0e7ff;color:#4f46e5}.stat-card.warning .stat-icon{background:#fef3c7;color:#d97706}.stat-card.active .stat-icon{background:#dbeafe;color:#2563eb}.stat-card.success .stat-icon{background:#dcfce7;color:#16a34a}.stat-info{display:flex;flex-direction:column}.stat-label{color:#64748b;font-size:.85rem;font-weight:600;text-transform:uppercase}.stat-value{color:#0f172a;font-size:1.5rem;font-weight:800}.tm-toolbar{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px #00000005;padding:1.25rem 1.75rem}.tm-actions-top,.tm-toolbar{align-items:center;display:flex}.tm-actions-top{gap:1rem;justify-content:space-between;width:100%}@media (max-width:768px){.tm-toolbar{padding:1rem}.tm-actions-top{align-items:stretch;flex-direction:column}.tm-search{margin:0!important;width:100%!important}.tm-btn-add,.tm-filters{justify-content:center;width:100%}}.tm-search{border:1px solid #cbd5e1;border-radius:8px;gap:.5rem;min-width:200px;padding:.6rem 1rem;transition:.2s;width:280px}.tm-search:focus-within{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.tm-search input{color:#1e293b}.tm-filters{align-items:center;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;display:flex;gap:.5rem;padding:.55rem .75rem}.tm-filters select{background:#0000;border:none;color:#334155;cursor:pointer;font-size:.9rem;font-weight:600;outline:none;padding-right:.5rem}.tm-btn-add{align-items:center;background:#2b93fb;border:none;border-radius:8px;box-shadow:0 4px 10px #2b93fb33;color:#fff;cursor:pointer;display:flex;font-weight:700;gap:.5rem;padding:.75rem 1.25rem;transition:.2s;white-space:nowrap}.tm-btn-add:hover{background:#1d4ed8;transform:translateY(-1px)}.tm-grid-container{flex:1 1;overflow-y:auto;padding-bottom:2rem;padding-right:.5rem}.tm-grid{grid-gap:1.5rem;align-content:start;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.tm-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px #00000005;display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem;position:relative;transition:.2s}@media (max-width:768px){.tm-grid{gap:1rem;grid-template-columns:1fr}.tm-card{padding:1rem}}.tm-card:hover{border-color:#cbd5e1;box-shadow:0 10px 25px #0000000f;transform:translateY(-3px)}.tm-card-header{align-items:flex-start;display:flex;justify-content:space-between}.tm-card-time{align-items:center;color:#94a3b8;display:flex;font-size:.8rem;font-weight:600;gap:.3rem}.tm-badge{border:1px solid #0000;border-radius:99px;font-size:.8rem;font-weight:700;padding:.35rem .8rem}.tm-badge.pointer{cursor:pointer;transition:.2s}.tm-badge.pointer:hover{filter:brightness(.95);transform:scale(1.02)}.bg-pending{background:#fef9c3;border-color:#fde047;color:#a16207}.bg-progress{background:#dbeafe;border-color:#bfdbfe;color:#1d4ed8}.bg-done{background:#dcfce7;border-color:#bbf7d0;color:#16a34a}.bg-important{background:#fee2e2;border-color:#fecaca;color:#dc2626}.bg-default{background:#f1f5f9;border-color:#e2e8f0;color:#475569}.tm-card-content{word-wrap:break-word;color:#0f172a;flex:1 1;font-size:1.05rem;line-height:1.65;padding:.25rem 0;white-space:pre-wrap}.tm-card-footer{border-top:1px dashed #e2e8f0;justify-content:space-between;padding-top:1.25rem}.tm-card-footer,.tm-user{align-items:center;display:flex}.tm-user{color:#334155;font-size:.95rem;font-weight:700;gap:.75rem}.tm-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#60a5fa);border-radius:50%;box-shadow:0 2px 6px #3b82f64d;color:#fff;display:flex;font-size:.9rem;font-weight:800;height:34px;justify-content:center;width:34px}.tm-actions{gap:.4rem}.tm-btn-icon{border-radius:6px;color:#94a3b8;padding:.4rem}.tm-btn-icon:hover{color:#0f172a}.tm-btn-del:hover{background:#fee2e2;color:#ef4444}.tm-modal-overlay{background:#0f172a80;bottom:0;left:0;right:0;top:0;z-index:9999}.tm-modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;display:flex;flex-direction:column;max-width:400px;width:90%}.tm-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1rem 1.25rem}.tm-modal-header h3{color:#0f172a;font-size:1.1rem;font-weight:800;margin:0}.tm-close{background:#0000;border:none;border-radius:50%;color:#64748b;cursor:pointer;padding:.35rem;transition:.2s}.tm-close:hover{background:#fee2e2;color:#ef4444}.tm-modal-body{gap:1rem;padding:1rem 1.25rem}.tm-form-group,.tm-modal-body{display:flex;flex-direction:column}.tm-form-group{gap:.5rem}.tm-form-group label{color:#475569;font-size:.9rem;font-weight:700;text-transform:uppercase}.tm-form-group select,.tm-form-group textarea{border:1px solid #cbd5e1;border-radius:8px;color:#1e293b;font-family:inherit;font-size:1rem;line-height:1.5;outline:none;padding:.75rem 1rem;transition:.2s}.tm-form-group select:focus,.tm-form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.tm-form-actions{display:flex;justify-content:flex-end;margin-top:.5rem}.tm-btn-submit{background:#2b93fb;border:none;border-radius:8px;box-shadow:0 4px 12px #2b93fb40;color:#fff;cursor:pointer;font-size:1.05rem;font-weight:800;padding:.85rem 2rem;transition:.3s;width:100%}.tm-btn-submit:hover{background:#1d4ed8;transform:translateY(-2px)}.finance-manager{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px #00000005;overflow:hidden;padding:.5rem}.finance-manager,.fm-stats-layout{display:flex;flex-direction:column;gap:.75rem}.fm-stats-layout{padding:.5rem .5rem 0}.fm-stats-toprow{align-items:stretch;display:flex;gap:1rem;justify-content:space-between}.fm-dau-ky-info,.fm-top-left{align-items:center;display:flex;gap:1rem}.fm-dau-ky-info{font-size:.95rem}.fm-btn-add-dauky{align-items:center;background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.4rem;padding:.5rem 1rem;transition:.2s}.fm-btn-add-dauky:hover{background:#2563eb;transform:translateY(-1px)}.fm-top-right{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.fm-wallet-card{background:#3b82f6;border-radius:8px;box-shadow:0 4px 6px #3b82f626;color:#fff;gap:.25rem;min-width:170px;padding:.6rem 1rem}.fm-wc-row span{opacity:.9}.fm-wc-row strong{font-size:1rem;font-weight:700}.fm-date-filter select{background:#fff;border:1px solid #cbd5e1;border-radius:6px;cursor:pointer;font-size:.95rem;min-width:180px;outline:none;padding:.5rem 1rem}.fm-stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.fm-stat-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px #00000005;cursor:pointer;display:flex;gap:1rem;padding:1.25rem;transition:.2s}.fm-stat-card:hover{box-shadow:0 4px 12px #0000000d;transform:translateY(-2px)}.fm-stat-icon{align-items:center;border-radius:12px;display:flex;height:48px;justify-content:center;width:48px}.fm-stat-info{display:flex;flex:1 1;flex-direction:column}.fm-stat-label{color:#64748b;font-size:.85rem;font-weight:600;text-transform:uppercase}.fm-stat-value{color:#0f172a;font-size:1.4rem;font-weight:800}.ico-chi{background:#fee2e2;color:#ef4444}.ico-luong{background:#f3e8ff;color:#a855f7}.ico-nhap{background:#fce7f3;color:#ec4899}.ico-hocphi{background:#dcfce7;color:#16a34a}.ico-banhang{background:#ccfbf1;color:#14b8a6}.ico-thukhac{background:#dbeafe;color:#3b82f6}.ico-tm{background:#e0e7ff;color:#6366f1}.ico-mb{background:#ffedd5;color:#f97316}.ico-bidv{background:#e0f2fe;color:#0ea5e9}.fm-wallet-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px #00000005;display:flex;flex-direction:column;gap:.5rem;min-width:220px;padding:1rem 1.25rem}.fm-wc-row{align-items:center;display:flex;font-size:.85rem;justify-content:space-between}.fm-wc-row span{color:#64748b;font-weight:600;text-transform:uppercase}.fm-wc-row strong{color:#1e293b;font-size:1.1rem;font-weight:800}.fm-toolbar{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;display:flex;justify-content:space-between;padding:1rem 1.5rem}.fm-tb-left,.fm-tb-right{align-items:center;display:flex;gap:1rem}.fm-search{align-items:center;background:#fff;border:1px solid #cbd5e1;border-radius:8px;display:flex;gap:.5rem;padding:.75rem 1rem;transition:.3s;width:380px}.fm-search:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.fm-search input{background:#0000;border:none;font-size:.95rem;font-weight:500;outline:none;width:100%}.fm-btn-export{align-items:center;background:#10b981;border:none;border-radius:8px;box-shadow:0 4px 10px #10b98133;color:orange;cursor:pointer;display:flex;font-weight:700;gap:.5rem;padding:.75rem 1.25rem;transition:.2s}.fm-btn-export:hover{background:#059669;transform:translateY(-1px)}.fm-content-block{border:1px solid #e2e8f0;border-radius:10px;flex:1 1;overflow-x:auto;overflow-y:auto}.fm-table{border-collapse:collapse;min-width:1200px;text-align:left;width:100%}.fm-table th{background:#f1f5f9;border-bottom:2px solid #e2e8f0;color:#475569;font-size:.85rem;font-weight:700;padding:1rem;position:sticky;text-transform:uppercase;top:0;white-space:nowrap;z-index:10}.fm-table td{border-bottom:1px solid #f1f5f9;color:#1e293b;font-size:.95rem;padding:1rem;vertical-align:middle}.fm-table tbody tr{transition:.2s}.fm-table tbody tr:hover{background:#f8fafc}.fm-code{letter-spacing:.5px}.fm-desc{color:#64748b;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fm-badge{border-radius:99px;display:inline-block;font-size:.8rem;font-weight:700;padding:.35rem .8rem}.bg-success{background:#dcfce7;color:#16a34a}.bg-warning{background:#fef9c3;color:#a16207}.bg-pending{background:#f1f5f9;color:#64748b}.text-success{color:#16a34a!important}.text-danger{color:#dc2626!important}.text-primary{color:#3b82f6!important}.text-warning{color:#d97706!important}.fm-actions-td{min-width:160px;text-align:right;white-space:nowrap}.fm-actions-td button{align-items:center;background:#0000;border:none;border-radius:6px;color:#ef4444;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:.2s}.fm-actions-td button:hover{background:#fee2e2}.fm-actions-td button.btn-blue{color:#3b82f6!important}.fm-actions-td button.btn-blue:hover{background:#eff6ff}.fm-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.fm-modal{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;width:100%}.animate-slide-up{animation:fmSlideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes fmSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.print-a5-receipt{background:#fff;box-sizing:border-box;color:#000;font-family:Times New Roman,Times,serif;left:-9999px;min-height:148mm;padding:12mm 15mm;position:absolute;top:-9999px;width:210mm;z-index:-1000}@media print{body>:not(.print-a5-receipt){display:none!important}body,html{background:#fff!important;margin:0!important;padding:0!important}@page{size:A5 landscape;margin:0}.print-a5-receipt{display:block!important;left:auto;position:static!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;top:auto;z-index:auto}.print-a5-receipt,.print-a5-receipt *{visibility:visible!important}}.p-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:20px}.p-header-left h3{font-size:16pt;font-weight:700;margin:0 0 5px}.p-header-left p{font-size:12pt;margin:2px 0}.p-logo-placeholder{align-items:center;border:2px solid #e2e8f0;border-radius:50%;color:#3b82f6!important;display:flex;font-size:14pt;font-weight:700;height:80px;justify-content:center;width:80px}.p-title-area{margin-bottom:5px;text-align:center}.p-title-area h2{font-size:20pt;font-weight:700;margin:0 0 5px;text-transform:uppercase}.p-title-area p{font-size:11pt;font-style:italic;margin:0}.p-code-area{font-size:11pt;margin-bottom:10px;padding-right:20px;text-align:right}.p-content{margin-bottom:25px;padding:0 10px}.p-row{align-items:baseline;display:flex;font-size:12pt;margin-bottom:8px}.p-label{display:inline-block;min-width:140px}.p-value{border-bottom:1px dotted #999;flex:1 1;padding-bottom:2px}.p-signatures{display:grid;grid-template-columns:repeat(4,1fr);margin-bottom:30px;text-align:center}.sig-box h4{font-size:12pt;font-weight:700;margin:0 0 5px}.sig-box p{font-size:11pt;font-style:italic;margin:0}.sig-name{font-size:12pt;font-weight:700;margin-top:50px}.p-footer-note{font-size:12pt;padding-left:10px}.p-luong-table{border-collapse:collapse;font-size:11pt;margin-top:5px;width:100%}.p-luong-table td,.p-luong-table th{border:1px solid #999;padding:6px 8px;text-align:left}.p-luong-table th{font-weight:700}.print-a5-receipt .text-center{text-align:center!important}.print-a5-receipt .text-right{text-align:right!important}@media (max-width:768px){.fm-stats-layout{padding:.5rem}.fm-stats-toprow{flex-direction:column;gap:.75rem}.fm-top-right{grid-gap:.5rem!important;display:grid!important;gap:.5rem!important;grid-template-columns:repeat(2,1fr);width:100%}.fm-wallet-card{min-width:0!important;padding:.75rem!important}.fm-wc-row strong{font-size:.95rem!important}.fm-stats-grid{gap:.5rem!important;grid-template-columns:repeat(2,1fr)!important}.fm-stat-card{border-radius:10px!important;gap:.6rem!important;padding:.75rem!important}.fm-stat-icon{flex-shrink:0;height:40px!important;width:40px!important}.fm-stat-label{font-size:.7rem!important}.fm-stat-value{font-size:1rem!important}.fm-toolbar{flex-direction:column;gap:.75rem;padding:.75rem!important}.fm-tb-left,.fm-tb-right{flex-direction:column;gap:.5rem;width:100%}.fm-tb-right{grid-gap:.5rem!important;display:grid!important;gap:.5rem!important;grid-template-columns:1fr 1fr}.fm-tb-right button{font-size:.8rem!important;justify-content:center;padding:.6rem!important;width:100%}.fm-search{padding:.6rem!important;width:100%!important}.fm-date-filter select,.fm-hinhthuc-filter select{font-size:.85rem;width:100%}.fm-content-block{border:none!important;min-height:auto!important}.fm-card-list{display:flex!important;flex-direction:column;gap:.75rem;padding:.5rem 0}.fm-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 4px #00000005;padding:1rem}.fm-card-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.5rem}.fm-card-code{color:#3b82f6;font-size:.9rem;font-weight:700}.fm-card-body{display:flex;flex-direction:column;gap:.5rem}.fm-card-row{color:#475569;display:flex;font-size:.85rem;justify-content:space-between}.fm-card-row strong{color:#64748b;font-weight:600}.fm-card-desc{max-width:60%;overflow:hidden;text-align:right;text-overflow:ellipsis;white-space:nowrap}.price-row{border-top:1px dashed #e2e8f0;margin-top:.4rem;padding-top:.4rem}.fm-card-price{font-size:1rem;font-weight:800}.fm-card-actions{display:flex;gap:.5rem;justify-content:center;margin-top:1rem}.fm-card-actions button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:.4rem;justify-content:center;padding:.5rem .8rem;transition:all .2s}.btn-blue-sm{background:#eff6ff;color:#3b82f6}.btn-danger-sm{background:#fef2f2;color:#ef4444}.btn-success-sm{background:#f0fdf4;color:#16a34a}.btn-blue-sm:active,.btn-danger-sm:active,.btn-success-sm:active{opacity:.7;transform:scale(.95)}.table-scroll-wrapper{display:none!important}.fm-filter-controls{gap:.5rem!important}.fm-date-range-display{font-size:.8rem!important;text-align:center;width:100%}.fm-custom-date-row{justify-content:space-between;width:100%!important}.fm-custom-date-row input{flex:1 1;min-width:0}.fm-custom-date-row label{display:none}.fm-custom-date-row button{margin-top:.5rem;width:100%}}.fm-card-list{display:none}.timesheet-manager{background:#f8fafc;display:flex;flex-direction:column;height:100%}.tm-layout{display:flex;gap:1.5rem;height:calc(100vh - 100px);min-height:0;padding:1.5rem}.tm-left-pane{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;display:flex;flex:0 0 300px;flex-direction:column;overflow:hidden}.tm-search{align-items:center;background:#f8fafc;border-bottom:1px solid #f1f5f9;display:flex;gap:.75rem;padding:1.25rem}.tm-search input{background:#0000;border:none;font-size:.95rem;font-weight:500;outline:none;width:100%}.tm-employee-list{flex:1 1;overflow-y:auto;padding:.75rem}.tm-employee-card{border:1px solid #0000;border-radius:12px;cursor:pointer;margin-bottom:.5rem;padding:1rem;transition:.2s}.tm-employee-card:hover{background:#f1f5f9}.tm-employee-card.active{background:#eff6ff;border-color:#bfdbfe;box-shadow:0 2px 4px #3b82f60d}.tm-card-name{color:#1e293b;font-weight:700;margin-bottom:.25rem}.tm-card-sub{color:#64748b;font-size:.8rem}.tm-right-pane{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;overflow:hidden}.tm-empty-state,.tm-right-pane{display:flex;flex:1 1;flex-direction:column}.tm-empty-state{align-items:center;color:#64748b;justify-content:center;padding:3rem;text-align:center}.tm-content{display:flex;flex:1 1;flex-direction:column;overflow-y:auto}.tm-header{align-items:flex-start;background:#f8fafc;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:1.5rem 2rem}.tm-title{color:#0f172a;font-size:1.25rem;font-weight:800;margin:0}.tm-global-month{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:4px 12px}.tm-actions{display:flex;gap:.75rem}.im-section{border-bottom:1px dashed #e2e8f0}.im-section-title{align-items:center;border-bottom:2px solid #e2e8f0;color:#0f172a;display:flex;font-size:1.1rem;font-weight:800;gap:.6rem;letter-spacing:.5px;margin-bottom:1.25rem;padding-bottom:.6rem;text-transform:uppercase}.im-grid-3{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr)}.im-field label{color:#64748b;display:block;font-size:.75rem;font-weight:700;margin-bottom:.25rem;text-transform:uppercase}.val-text{color:#334155;font-size:1.05rem;font-weight:600}.tm-table-wrapper{padding:1.5rem 2rem}.tm-table{border-collapse:collapse;width:100%}.tm-table th{border-bottom:2px solid #f1f5f9;color:#64748b;font-size:.75rem;font-weight:700;padding:12px 16px;text-align:left;text-transform:uppercase}.tm-table td{border-bottom:1px solid #f1f5f9;padding:16px;vertical-align:middle}.tm-salary-input{background:#f8fafc;outline:none;transition:.2s}.tm-salary-input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.tm-badge-success{background:#dcfce7;color:#16a34a}.tm-badge-success,.tm-badge-warning{border-radius:99px;font-size:.75rem;font-weight:700;padding:.35rem .75rem}.tm-badge-warning{background:#fef9c3;color:#a16207;display:inline-block}.tm-mobile-cards{display:none}.tm-btn-primary{background:#3b82f6;border:none;border-radius:10px;color:#fff}.tm-btn-outline,.tm-btn-primary{align-items:center;cursor:pointer;display:flex;font-weight:700;gap:.5rem;padding:.6rem 1.25rem;transition:.2s}.tm-btn-outline{background:#fff;border:1px solid #cbd5e1;border-radius:10px;color:#64748b}.tm-btn-icon{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:.2s}.tm-btn-icon:hover{background:#f1f5f9}.tm-summary-section{background:#f8fafc;border-top:2px dashed #e2e8f0;display:flex;gap:2rem;padding:2rem}.tm-extras-dynamic{display:flex;flex-wrap:wrap;gap:1.5rem}.tm-input-group{display:flex;flex-direction:column}.tm-input-wrapper{align-items:center;background:#fff;border:1px solid #cbd5e1;border-radius:8px;display:flex;padding:0 10px}.tm-input-wrapper input{border:none;color:#1e293b;font-weight:700;outline:none;padding:10px 0;width:120px}.tm-total{display:flex;flex:0 0 300px;flex-direction:column;justify-content:flex-end;text-align:right}.tm-total span{color:#64748b;font-size:.85rem;font-weight:600}.tm-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.tm-calendar-modal{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;color:#1e293b;max-width:600px;overflow:hidden;width:100%}.tm-close-btn{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;font-weight:700;padding:.5rem 1rem;transition:.2s}.tm-close-btn:hover{background:#e2e8f0;color:#1e293b}.tm-cal-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:.6rem 1rem}.tm-cal-controls{gap:1rem;padding:.25rem 1rem}.tm-cal-controls,.tm-cal-controls button{align-items:center;display:flex;justify-content:center}.tm-cal-controls button{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;cursor:pointer;padding:6px;transition:.2s}.tm-cal-controls button:hover{background:#f8fafc;border-color:#cbd5e1}.tm-current-month{color:#1e293b!important}.tm-cal-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);padding:.25rem .75rem}.tm-cal-day-header{color:#64748b;font-size:.65rem;font-weight:800;padding:2px;text-align:center;text-transform:uppercase}.tm-cal-cell{aspect-ratio:1.5;border:1px solid #f1f5f9;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-start;min-height:48px;padding:2px 4px;transition:.2s}.tm-cal-cell:hover{background:#f8fafc;border-color:#cbd5e1}.tm-cal-cell.active-teach{background:#dcfce7;border-color:#86efac}.tm-cal-cell.active-sub{background:#dbeafe;border-color:#93c5fd}.tm-cal-cell.other-sub{background:#fef9c3;border-color:#fde047}.tm-current-month{color:#1e293b;font-size:1.25rem;font-weight:800;margin:0}.tm-day-num{color:#334155;font-size:.75rem;font-weight:700}.tm-status-text{color:#475569;display:none;font-size:.55rem;font-weight:700;line-height:1}.tm-cal-footer{align-items:center;background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;padding:.5rem 1rem}@media (max-width:991px){.tm-layout{flex-direction:column;height:auto;padding:0}.tm-left-pane{border-radius:0;flex:none;height:40vh;width:100%}.tm-right-pane{border-radius:0;display:none;width:100%}.mobile-show-details .tm-left-pane{display:none}.mobile-show-details .tm-right-pane{display:flex}.tm-table-wrapper{display:none!important}.tm-mobile-cards{display:flex!important;flex-direction:column;gap:1rem;padding:1rem}.tm-header{align-items:stretch;flex-direction:column;gap:1.25rem;padding:1rem 1.5rem}.tm-title{font-size:1.1rem}.tm-actions{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.tm-btn-outline,.tm-btn-primary{font-size:.85rem;justify-content:center;padding:.8rem .5rem;white-space:nowrap}.tm-class-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:1rem}.tm-class-card-header{align-items:flex-start;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.5rem}.tm-class-name{color:#1e293b;font-size:1.05rem;font-weight:800}.tm-class-id{color:#64748b;font-size:.85rem;margin-top:2px}.tm-class-card-body{display:flex;flex-direction:column;gap:.75rem;padding:.5rem 0}.tm-stat{align-items:center;display:flex;font-size:.95rem;justify-content:space-between}.tm-stat label{color:#64748b;font-weight:700}.tm-stat input{background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;color:#3b82f6;font-weight:800;outline:none;padding:8px 12px;text-align:right;width:140px}.tm-btn-calendar-mobile{align-items:center;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;color:#2563eb;cursor:pointer;display:flex;font-weight:800;gap:8px;justify-content:center;margin-top:.5rem;padding:12px;transition:.2s;width:100%}.tm-btn-calendar-mobile:active{transform:scale(.97)}.tm-modal-overlay{padding:.5rem}.tm-calendar-modal{border-radius:12px;display:flex;flex-direction:column;max-height:98vh}.tm-cal-header{padding:1rem}.tm-cal-header h3{font-size:1rem}.tm-cal-controls{gap:1rem;padding:.5rem}.tm-cal-grid{gap:4px;padding:.5rem}.tm-cal-day-header{font-size:.65rem;padding:4px}.tm-cal-cell{border-radius:8px;gap:2px;padding:4px}.tm-day-num{font-size:.75rem}.tm-status-text{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;font-size:.55rem;overflow:hidden}.tm-cal-controls h2{font-size:1rem!important}.tm-cal-controls .tm-btn-icon svg{height:16px;width:16px}.tm-cal-header>div>div{font-size:.75rem!important}.tm-cal-header h3{font-size:.85rem!important}.tm-cal-header .tm-btn-outline{border-radius:8px;font-size:.8rem;padding:.4rem .8rem}.tm-cal-footer{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.tm-cal-footer .tm-btn-primary{justify-content:center;order:-1;width:100%}}.tm-extra-label-input{background:#0000;border:1px solid #0000!important;border-radius:4px;font-family:inherit;padding:2px 4px;transition:.2s;width:100%}.tm-extra-label-input:hover{background:#f1f5f9!important;border-color:#e2e8f0!important}.tm-extra-label-input:focus{background:#fff!important;border:1px solid #3b82f6!important;box-shadow:0 0 0 2px #3b82f61a}.tm-note-section textarea{border:1px solid #cbd5e1;transition:.2s}.tm-note-section textarea:focus{border-color:#3b82f6!important;box-shadow:0 0 0 3px #3b82f61a}.config-manager{animation:fadeIn .4s ease-out;background:#f8fafc;display:flex;flex-direction:column;gap:1.5rem;min-height:100%;padding:1rem}.config-header{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px #00000005;justify-content:space-between;padding:1.5rem 2rem}.config-header,.h-left{align-items:center;display:flex}.h-left{gap:1.25rem}.h-left h2{color:#0f172a;font-size:1.5rem;font-weight:800;margin:0}.h-left p{color:#64748b;font-size:.9rem;margin:.25rem 0 0}.btn-save{align-items:center;background:#3b82f6;border:none;border-radius:12px;box-shadow:0 4px 12px #3b82f640;color:#fff;cursor:pointer;display:flex;font-weight:700;gap:.75rem;padding:.75rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-save:hover:not(:disabled){background:#2563eb;box-shadow:0 6px 16px #3b82f659;transform:translateY(-2px)}.btn-save:disabled{cursor:not-allowed;opacity:.6}.config-alert{align-items:center;border-radius:12px;display:flex;font-size:.95rem;font-weight:600;gap:.75rem;padding:1rem 1.5rem}.config-alert.success{background:#dcfce7;border:1px solid #bbf7d0;color:#16a34a}.config-alert.error{background:#fee2e2;border:1px solid #fecaca;color:#ef4444}.config-body{display:flex;flex-direction:column;gap:1.5rem;padding-bottom:2rem}.config-section{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px #00000005;padding:1.5rem}.section-title{align-items:center;border-bottom:1px solid #f1f5f9;color:#334155;display:flex;gap:.75rem;margin-bottom:1.5rem;padding-bottom:.75rem}.section-title h3{font-size:1.1rem;font-weight:700;letter-spacing:.5px;margin:0;text-transform:uppercase}.brand-grid{align-items:center;display:flex;gap:2rem}.logo-upload{display:flex;flex-direction:column;gap:.75rem}.logo-preview-box{align-items:center;background:#f1f5f9;border:2px dashed #cbd5e1;border-radius:16px;display:flex;height:120px;justify-content:center;overflow:hidden;position:relative;width:120px}.logo-preview-box img{height:100%;object-fit:contain;width:100%}.upload-overlay{align-items:center;background:#0006;color:#fff;cursor:pointer;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:.3s}.logo-preview-box:hover .upload-overlay{opacity:1}.upload-overlay input{cursor:pointer;inset:0;opacity:0;position:absolute}.form-fields{grid-gap:1.25rem;display:grid;flex:1 1;gap:1.25rem;grid-template-columns:1fr}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#475569;font-size:.85rem;font-weight:700}.form-group input{border:1px solid #cbd5e1;border-radius:10px;font-size:.95rem;padding:.75rem 1rem;transition:.2s}.form-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.categories-row{background:#0000;border:none;box-shadow:none;display:flex;flex-wrap:wrap;gap:1.5rem;padding:0}.cat-col{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.5rem}.cat-col textarea{border:1px solid #cbd5e1;border-radius:12px;font-size:.95rem;line-height:1.6;padding:1rem;resize:vertical;width:100%}.company-grid,.wallets-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.wallet-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.w-header{background:#334155;color:#fff;font-size:.85rem;font-weight:700;padding:.6rem 1rem;text-align:center}.w-body{display:flex;flex-direction:column;gap:.6rem;padding:1rem}.w-body input{background:#fff;border:1px solid #cbd5e1;border-radius:8px;font-size:.85rem;padding:.5rem .75rem}.roles-table-container{overflow-x:auto}.roles-table{border-collapse:collapse;text-align:center;width:100%}.roles-table th{background:#f1f5f9;border-bottom:2px solid #e2e8f0;color:#475569;font-size:.85rem;font-weight:800;padding:1rem}.roles-table td{border-bottom:1px solid #f1f5f9;color:#334155;font-size:.9rem;padding:1rem}.roles-table tr:hover{background:#f8fafc}.roles-table input[type=checkbox]{cursor:pointer;height:1.25rem;width:1.25rem}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.brand-grid{align-items:center;flex-direction:column}.categories-row{grid-template-columns:1fr}}.statistics-container{background:#f8fafc;box-sizing:border-box;min-height:100vh;padding:2rem}.stat-header{align-items:center;display:flex!important;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;margin-bottom:2rem}.stat-header-left h2{color:#0f172a;font-size:1.75rem;font-weight:800;margin:0}.stat-header-left p{color:#64748b;margin:4px 0 0}.stat-header-right{align-items:flex-end;display:flex;flex-direction:column;gap:12px}.filter-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px -1px #0000000d;display:flex;gap:12px;padding:10px 16px}.charts-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(450px,1fr))}.chart-item{background:#fff;border:1px solid #e2e8f0;border-radius:20px;box-shadow:0 4px 6px -1px #00000003;min-height:350px;padding:1.5rem}.chart-title{align-items:center;display:flex;gap:10px;margin-bottom:1.5rem}.chart-title h3{color:#1e293b;font-size:1.1rem;font-weight:700;margin:0}.chart-canvas-container{height:300px;overflow:hidden;position:relative;width:100%}@media (max-width:991px){.charts-grid{gap:1.25rem;grid-template-columns:1fr 1fr}}@media (max-width:767px){.statistics-container{padding:1rem}.stat-header{align-items:flex-start;flex-direction:column;gap:1.25rem;margin-bottom:1.5rem}.stat-header-right{align-items:stretch;width:100%}.filter-card{justify-content:space-between;padding:12px;width:100%}.charts-grid{gap:1rem;grid-template-columns:1fr;margin:0;width:100%}.chart-item{min-height:300px;padding:1rem}.chart-canvas-container{height:220px;overflow:hidden;width:100%}.stat-header-left h2{font-size:1.4rem}.custom-date-row{flex-direction:column;gap:8px;width:100%}.custom-date-row input{width:100%!important}}
/*# sourceMappingURL=main.b5a980de.css.map*/