:root{--color-primary:#ffd54f;--color-primary-dark:#ffc107;--color-secondary:#ff9800;--color-secondary-dark:#f57c00;--color-accent:#ff5722;--color-accent-dark:#e64a19;--color-bg-main:#f4f7f9;--color-bg-card:#fffffffa;--color-bg-sidebar:#ffffffd9;--color-text-main:#333;--color-text-muted:#666;--color-text-light:#999;--color-border:#eee;--color-border-focus:#ffc107;--font-main:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--shadow-sm:0 2px 8px #0000000a, 0 10px 30px #959da533;--shadow-md:0 4px 12px #0000000f, 0 16px 40px #959da540;--shadow-lg:0 8px 24px #00000014, 0 24px 50px #959da54d;--glass-bg:#ffffffd9;--glass-border:#0000000d;--radius-sm:10px;--radius-md:16px;--radius-lg:24px;--radius-full:9999px;--transition-fast:.25s cubic-bezier(.4, 0, .2, 1);--transition-normal:.4s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-main);background-color:var(--color-bg-main);color:var(--color-text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}a{color:var(--color-secondary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-secondary-dark)}button{cursor:pointer;border:none;outline:none;font-family:inherit}.form-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-bg-card);transition:all var(--transition-fast);color:var(--color-text-main);padding:10px 12px;font-family:inherit;font-size:.95rem}ul,ol{list-style:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#e0e0e0}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border)}.salary-mode-badge{color:var(--color-secondary-dark);border-radius:var(--radius-full);vertical-align:middle;background:#ffd54f26;border:1px solid #ffc10759;align-items:center;gap:4px;padding:3px 10px;font-size:.78rem;font-weight:500;display:inline-flex}.app-container{background-color:var(--color-bg-main);width:100vw;height:100vh;display:flex;overflow:hidden}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}@keyframes ambientGlow{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.content-area{background:linear-gradient(-45deg,#f4f7f9,#fff,#fff9ec,#f4f7f9) 0 0/400% 400%;flex:1;padding:32px;animation:20s infinite ambientGlow;overflow-y:auto}.card{background-color:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);-webkit-backdrop-filter:blur(20px);border:1px solid #fff9;padding:32px;position:relative;overflow:hidden}.card:before{content:"";background:linear-gradient(90deg, var(--color-primary), var(--color-secondary));opacity:0;height:4px;transition:opacity var(--transition-normal);position:absolute;top:0;left:0;right:0}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px)}.card:hover:before{opacity:1}.card-title{color:var(--color-text-main);margin-bottom:12px;font-size:1.1rem;font-weight:600}.btn{border-radius:var(--radius-sm);transition:all var(--transition-fast);justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:.95rem;font-weight:500;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));color:#fff;text-shadow:0 1px 2px #0000001a;border:none;box-shadow:0 4px 15px #ff98004d}.btn-primary:hover{background:linear-gradient(135deg, var(--color-secondary), var(--color-accent));transform:translateY(-3px)scale(1.03);box-shadow:0 8px 25px #ff572266}.btn-secondary{background:linear-gradient(135deg, var(--color-secondary), var(--color-secondary-dark));color:var(--color-secondary-text,#fff);border:1px solid #ffffff4d;box-shadow:0 4px 12px #0000000d}.btn-secondary:hover{background:linear-gradient(135deg, var(--color-secondary-dark), var(--color-secondary));transform:translateY(-2px)scale(1.02);box-shadow:0 6px 16px #0000001a}.btn-outline{border:1px solid var(--color-border);color:var(--color-text-main);background-color:#0000}.btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary-dark)}.tab-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.tab-btn:hover{color:var(--color-text-main);background-color:#0000000d}.tab-btn.active{background-color:var(--color-primary);color:var(--color-primary-text,#1a1a1a);box-shadow:0 4px 12px #0000001a}@media (width<=768px){.content-area{background:var(--color-bg-main);padding:12px 10px 80px}.card{border-radius:16px;padding:16px;box-shadow:0 4px 15px #00000008}.table-toolbar,.page-header{background:0 0;border-bottom:none;flex-direction:column;gap:16px;padding:10px 4px;align-items:stretch!important}.table-toolbar>*,.page-header>*{width:100%}.search-box{background:#fff;border-radius:12px;padding:12px 16px;box-shadow:0 2px 8px #0000000a;width:100%!important}.table-toolbar .d-flex{flex-direction:column;gap:12px;width:100%}.table-toolbar .action-buttons,.table-toolbar .d-flex>div{flex-direction:column;gap:12px;width:100%;display:flex}.table-toolbar .btn{border-radius:12px;justify-content:center;width:100%;padding:12px}.table-responsive{-webkit-overflow-scrolling:touch;background:#fff;border:1px solid #0000000d;border-radius:12px;width:calc(100% + 8px);margin:10px -4px;overflow-x:auto;box-shadow:inset -10px 0 10px -10px #0000001a}.data-table{min-width:600px}.data-table th{color:#64748b;background:#f8fafc;font-size:.8rem;padding:12px 16px!important}.data-table td{white-space:nowrap;color:#334155;border-bottom:1px solid #f1f5f9;font-size:.85rem;padding:16px!important}.action-buttons{flex-wrap:nowrap}.icon-action{background:#f8fafc;padding:10px}.dashboard-content,.stats-grid{gap:16px;grid-template-columns:1fr!important}.stat-card{border-radius:16px}.modal-overlay{align-items:flex-end;padding:0}.modal-content{width:100%;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;border-radius:24px 24px 0 0!important;max-width:100%!important;max-height:90vh!important;margin:0!important;padding:24px 20px!important}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.form-grid,.form-grid-3{flex-direction:column!important;gap:16px!important;display:flex!important}.form-group{margin-bottom:4px}.form-input,.form-group input,.form-group select,.form-group textarea{background:#f8fafc!important;border:1px solid #e2e8f0!important;border-radius:12px!important;padding:14px 16px!important;font-size:.95rem!important}.header{height:60px;padding:0 16px}.header-right{gap:12px!important}.user-profile{padding:4px}.modal-actions{flex-direction:column;gap:10px;margin-top:24px}.modal-actions button{width:100%;font-size:1rem;border-radius:12px!important;padding:14px!important}.modal-actions .btn-secondary{order:2}.modal-actions .btn-primary{order:1}}.sidebar{width:240px;height:100vh;transition:width var(--transition-normal);z-index:10;background:linear-gradient(160deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);color:var(--color-primary-text,#fff);box-shadow:var(--shadow-lg);border-right:none;flex-direction:column;display:flex}.sidebar.closed{width:80px}.sidebar-header{border-bottom:1px solid #0000001a;align-items:center;height:60px;padding:0 16px;display:flex;overflow:hidden}.logo-icon{justify-content:center;align-items:center;min-width:28px;margin-right:10px;font-size:24px;display:flex}.logo-text{letter-spacing:.5px;color:var(--color-primary-text,#fff);white-space:nowrap;text-overflow:ellipsis;font-size:1.1rem;font-weight:700;overflow:hidden}.sidebar-nav{flex:1;padding:16px 0 16px 12px;overflow-y:auto}.nav-list{flex-direction:column;gap:4px;display:flex}.nav-item{border-radius:var(--radius-md) 0 0 var(--radius-md);color:var(--color-primary-text,#fff);opacity:.85;transition:all var(--transition-fast);white-space:nowrap;align-items:center;padding:10px 14px;font-size:.95rem;font-weight:500;display:flex;overflow:hidden}.sidebar.closed .nav-item{justify-content:center;padding:12px 0}.sidebar.closed .nav-icon{margin-right:0}.nav-icon{align-items:center;margin-right:12px;display:flex}.nav-item:hover{color:var(--color-primary-text,#fff);opacity:1;background-color:#fff3}.nav-item.active{background-color:var(--color-bg-main);color:var(--color-primary);opacity:1;box-shadow:none;border:none}.sidebar-footer{border-top:1px solid #0000001a;padding:12px}.nav-group-container{flex-direction:column;display:flex}.nav-group-header{-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;display:flex}.nav-group-header:hover{background-color:#ffffff26}.nav-chevron{opacity:.7;align-items:center;display:flex}.nav-group-content{background-color:#0000000d;border-radius:12px;max-height:0;margin:4px 12px;transition:max-height .4s ease-in-out;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #00000005}.nav-group-content.open{max-height:600px;transition:max-height .4s ease-in-out}.sub-nav-list{padding:8px 0;position:relative}.sub-item{opacity:.85;border-radius:8px;align-items:center;margin:2px 6px;padding:10px 14px;font-size:.88rem;transition:all .2s;display:flex;position:relative}.sub-item .nav-icon{margin:0 12px 0 0;transform:scale(.85)}.sub-item:hover{opacity:1;background-color:#fff6;transform:translate(4px)}.sub-item.active{color:var(--color-primary-text,#fff);opacity:1;background-color:#fff9;font-weight:600;box-shadow:0 2px 4px #0000000d}.sub-item.active:after{content:"";background-color:var(--color-primary-text,#fff);border-radius:4px;width:4px;height:60%;position:absolute;top:50%;left:-2px;transform:translateY(-50%)}@media (width<=768px){.sidebar{width:280px;height:100vh;position:fixed;top:0;left:0;transform:translate(0);box-shadow:10px 0 30px #0000004d}.sidebar.closed{width:280px;box-shadow:none;transform:translate(-100%)}.sidebar-header{height:70px}}.header{z-index:5;background-color:var(--color-bg-sidebar);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid #fff6;justify-content:space-between;align-items:center;height:70px;padding:0 24px;display:flex}.header-left,.header-right{align-items:center;gap:16px;display:flex}.menu-btn{color:var(--color-text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;padding:8px;display:flex}.menu-btn:hover{background-color:var(--color-border);color:var(--color-text-main)}.search-bar{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-full);width:300px;transition:all var(--transition-fast);align-items:center;padding:8px 16px;display:flex}.search-bar:focus-within{border-color:var(--color-border-focus);box-shadow:0 0 0 2px #ffc10733}.search-icon{color:var(--color-text-muted);margin-right:8px}.search-bar input{width:100%;color:var(--color-text-main);background:0 0;border:none;outline:none;font-family:inherit}.icon-btn{color:var(--color-text-muted);border-radius:var(--radius-full);transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;padding:10px;display:flex;position:relative}.icon-btn:hover{background-color:var(--color-border);color:var(--color-text-main)}.notification-btn .badge{background-color:var(--color-accent);color:#fff;border:2px solid var(--color-bg-card);border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;font-weight:700;display:flex;position:absolute;top:4px;right:4px}.user-profile{cursor:pointer;border-radius:var(--radius-sm);transition:background-color var(--transition-fast);align-items:center;gap:12px;padding:4px 8px;display:flex}.user-profile:hover{background-color:var(--color-border)}.avatar{background-color:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:var(--color-text-main);font-size:.9rem;font-weight:600}.user-role{color:var(--color-text-muted);font-size:.75rem}@media (width<=768px){.header{padding:0 12px}.user-info,.header-right .btn-text-hide{display:none}}.app-footer{border-top:1px solid var(--color-border);background-color:#0000;margin-top:auto;padding:10px 20px}.footer-content{color:var(--color-text-light);justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.system-details{gap:15px;display:flex}.version{background-color:var(--color-bg-card);border-radius:var(--radius-full);border:1px solid var(--color-border);color:var(--color-text-muted);padding:4px 10px;font-weight:500}@media (width<=600px){.footer-content{text-align:center;flex-direction:column;gap:10px}}.page-title{color:var(--color-text-main);margin-bottom:4px;font-size:1.75rem;font-weight:700}.page-subtitle{color:var(--color-text-muted);font-size:.95rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:24px;display:grid}.stat-card{position:relative;overflow:hidden}.stat-content{justify-content:space-between;align-items:flex-start;display:flex}.stat-info{flex-direction:column;display:flex}.stat-title{margin-bottom:8px;font-size:.95rem;font-weight:500}.stat-value{margin-bottom:4px;font-size:2rem;font-weight:700}.stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:52px;height:52px;display:flex}.bg-primary{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));border:none}.bg-secondary{background:linear-gradient(135deg, var(--color-secondary), var(--color-secondary-dark));border:none}.bg-accent{background:linear-gradient(135deg, var(--color-accent), var(--color-accent-dark));border:none}.bg-success{background:linear-gradient(135deg,#4caf50,#2e7d32);border:none}.stat-card[class*=bg-] .stat-title{color:#ffffffe6}.stat-card[class*=bg-] .stat-value{color:#fff}.stat-card[class*=bg-] .stat-trend{color:#fffc}.stat-card.bg-primary .stat-title{color:var(--color-primary-text,#fff);opacity:.9}.stat-card.bg-primary .stat-value{color:var(--color-primary-text,#fff)}.stat-card[class*=bg-] .stat-icon{color:#fff;background-color:#ffffff40}.stat-card.bg-primary .stat-icon{color:var(--color-primary-text,#fff);background-color:#0000001a}.dashboard-content{grid-template-columns:1fr 1fr;gap:24px;display:grid}.placeholder-chart{justify-content:space-around;align-items:flex-end;gap:10px;height:250px;padding-top:20px;display:flex}.bar{background-color:var(--color-primary);border-radius:var(--radius-sm) var(--radius-sm) 0 0;width:40px;transition:height 1s ease-out}.bar:hover{background-color:var(--color-secondary)}.schedule-list{flex-direction:column;gap:16px;display:flex}.schedule-item{border-bottom:1px solid var(--color-border);align-items:flex-start;gap:16px;padding-bottom:16px;display:flex}.schedule-item:last-child{border-bottom:none;padding-bottom:0}.time{color:var(--color-primary-dark);font-size:1.1rem;font-weight:700}.details{flex-direction:column;display:flex}.subject{color:var(--color-text-main);margin-bottom:4px;font-weight:600}.tutor{color:var(--color-text-muted);font-size:.85rem}@media (width<=1024px){.stats-grid{grid-template-columns:repeat(4,1fr);gap:12px}.stat-card{padding:16px}.stat-value{margin-bottom:2px;font-size:1.4rem}.stat-title{margin-bottom:4px;font-size:.75rem;line-height:1.2}.stat-icon{width:36px;height:36px;margin-left:8px}.stat-icon svg{width:18px;height:18px}.dashboard-content{grid-template-columns:1fr}}@media (width<=640px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-value{font-size:1.5rem}.stat-title{font-size:.85rem}}.d-flex{display:flex}.justify-between{justify-content:space-between}.align-center{align-items:center}.table-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden;background:#fffc!important;border:none!important;border-radius:12px!important;padding:20px!important;box-shadow:0 4px 6px #0000000d!important}.table-card:before{display:none!important}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.6s cubic-bezier(.16,1,.3,1) forwards slideUpFade}.table-toolbar{border-bottom:1px solid var(--color-border);background-color:#0000;justify-content:space-between;align-items:center;padding:24px;display:flex}.search-box{background-color:var(--color-bg-main);border-radius:var(--radius-full);border:1px solid #0000;align-items:center;width:320px;padding:12px 20px;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex}.search-box:focus-within{border-color:var(--color-border-focus);background-color:#fff;transform:translateY(-1px);box-shadow:0 4px 20px #0000000d}.search-box input{background:0 0;border:none;outline:none;width:100%;margin-left:10px;font-family:inherit;font-size:.95rem}.filter-select{border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-bg-card);cursor:pointer;outline:none;padding:8px 12px;font-family:inherit}.table-responsive{width:100%;overflow-x:auto}.data-table{border-collapse:separate;border-spacing:0;text-align:left;width:100%}.data-table th,.data-table td{border-bottom:1px solid #eee;padding:12px}.data-table thead tr{background-color:#0000}.data-table th{color:#555;text-transform:none;letter-spacing:normal;background-color:#00000005;border-bottom:1px solid #eee;padding:12px;font-weight:600}.data-table tbody tr{opacity:0;transition:all .3s cubic-bezier(.16,1,.3,1);animation:.5s forwards slideUpFade}.data-table tbody tr:first-child{animation-delay:50ms}.data-table tbody tr:nth-child(2){animation-delay:.1s}.data-table tbody tr:nth-child(3){animation-delay:.15s}.data-table tbody tr:nth-child(4){animation-delay:.2s}.data-table tbody tr:nth-child(5){animation-delay:.25s}.data-table tbody tr:nth-child(n+6){animation-delay:.3s}.data-table tbody tr:hover{background-color:var(--color-bg-card);z-index:2;position:relative;transform:scale(1.005)translateY(-2px);box-shadow:0 4px 15px #0000000d}.font-medium{color:var(--color-text-main);font-weight:500}.text-right{text-align:right!important}.text-center{text-align:center!important}.badge-program{background-color:var(--color-bg-main);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);padding:4px 8px;font-size:.8rem}.status-badge{border-radius:var(--radius-full);padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-block}.status-badge.aktif{color:#2e7d32;background-color:#4caf501a}.status-badge.nonaktif{color:#757575;background-color:#9e9e9e1a}.action-buttons{justify-content:flex-end;gap:8px;display:flex}.icon-action{color:var(--color-text-muted);border-radius:var(--radius-sm);background:#00000005;border:1px solid #00000008;justify-content:center;align-items:center;padding:8px;transition:all .2s cubic-bezier(.16,1,.3,1);display:flex}.icon-action:hover{border-color:#0000;transform:translateY(-3px)scale(1.1);box-shadow:0 5px 15px #0000001a}.icon-action.edit:hover{background-color:var(--color-primary);color:#fff}.icon-action.delete:hover{background-color:var(--color-accent);color:#fff}.icon-action.id-card:hover{color:#fff;background-color:#2196f3}.icon-action.more:hover{color:#fff;background-color:#111}.empty-state{color:var(--color-text-muted);font-style:italic;padding:40px!important}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;padding:24px;overflow-y:auto;box-shadow:0 10px 25px #0000001a}.modal-content.modal-landscape{max-width:800px}.modal-content.modal-large{max-width:960px}.form-grid{grid-template-columns:200px 1fr;gap:30px;display:grid}.form-grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=900px){.form-grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.form-grid-3{grid-template-columns:1fr}}@media (width<=768px){.form-grid{grid-template-columns:1fr}}.form-body{flex-direction:column;gap:16px;display:flex}.modal-header{border-bottom:1px solid var(--color-border);margin-bottom:20px;padding-bottom:16px}.modal-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:4px;display:flex}.form-group label{color:var(--color-text-main);font-size:.8rem;font-weight:600}.form-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-bg-main);transition:all var(--transition-fast);padding:8px 10px;font-family:inherit;font-size:.85rem}.form-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #ffc10733}.justify-end{justify-content:flex-end}.form-group input,.form-group select,.form-group textarea{box-sizing:border-box;background-color:var(--color-bg-main);width:100%;transition:all var(--transition-fast);border:1px solid #ddd;border-radius:6px;padding:8px 10px;font-family:inherit;font-size:.85rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #ffc10733}.modal-content h3{margin-top:0;margin-bottom:16px;font-size:1.15rem}.modal-actions{justify-content:flex-end;gap:12px;margin-top:16px;display:flex}.btn-primary{background-color:var(--color-primary);color:var(--color-primary-text);cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-weight:500;transition:all .2s;display:flex}.btn-primary:hover{filter:brightness(1.1)}.btn-secondary{color:#334155;cursor:pointer;background:#f1f5f9;border:none;border-radius:6px;padding:8px 16px}.finance-tabs{border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:12px;margin-bottom:24px;padding-bottom:12px;display:flex}.print-receipt.invoice-document .invoice-header{padding:20px 30px}.print-receipt.invoice-document .header-left,.print-receipt.invoice-document .header-right{flex-direction:column;justify-content:center;display:flex}.print-receipt.invoice-document .header-left{align-items:flex-start}.print-receipt.invoice-document .header-left h1{letter-spacing:1px;margin:0 0 4px;font-size:1.5rem;line-height:1.2}.print-receipt.invoice-document .header-left p{opacity:.9;margin:0;font-size:.9rem}.print-receipt.invoice-document .header-right{text-align:right;align-items:flex-end}.print-receipt.invoice-document .company-logo-text{margin-bottom:2px;font-size:1.5rem}.print-receipt.invoice-document .company-tagline{margin:0;font-size:.8rem}.print-receipt.invoice-document .invoice-body{padding:30px 40px}.badge-lunas{color:#2e7d32;letter-spacing:1px;background-color:#e8f5e9;border:2px solid #4caf50;border-radius:6px;padding:8px 24px;font-size:1.1rem;font-weight:700;display:inline-block;box-shadow:0 4px 6px #0000000d}.print-receipt.invoice-document .info-name{font-size:1.15rem}.print-receipt.invoice-document .info-value{font-size:.95rem;font-weight:600}.print-receipt.invoice-document th{color:#555;border-bottom:2px solid #ddd;padding:10px 8px;font-weight:700}.print-receipt.invoice-document td{padding:14px 8px}.print-receipt.invoice-document .invoice-summary{width:300px;margin-left:auto}.print-receipt.invoice-document .total-row{background:#f5f7f9;border:1px solid #eaeaea;border-radius:8px;padding:14px 20px}.print-receipt.invoice-document .total-val{font-size:1.3rem}@media screen{.print-only-modal{opacity:0!important;pointer-events:none!important;position:absolute!important;left:-9999px!important}}@media print{.students-page>:not(.modal-overlay){display:none!important}html,body,#root,.app-container,.main-content,.content-area,.students-page{background:#fff!important;height:auto!important;min-height:auto!important;margin:0!important;padding:0!important;display:block!important;position:static!important;overflow:visible!important}aside,header,footer{display:none!important}.modal-overlay{opacity:1!important;visibility:visible!important;background:0 0!important;width:100%!important;height:auto!important;margin:0!important;padding:0!important;display:block!important;position:relative!important;left:0!important}.print-receipt{width:100%!important;max-width:100%!important;box-shadow:none!important;border:none!important;margin:0!important;padding:0!important;display:block!important;position:relative!important;overflow:visible!important}.no-print{display:none!important}}.invoice-page{max-width:900px;margin:0 auto;padding:20px}.invoice-actions{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.action-left{align-items:center;gap:16px;display:flex}.action-title{color:var(--color-text-main);margin-bottom:4px;font-size:1.5rem}.action-subtitle{color:var(--color-text-muted);font-size:.9rem}.btn-back{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-main);transition:all var(--transition-fast);background:#fff;align-items:center;gap:8px;padding:8px 16px;font-weight:500;display:flex}.btn-back:hover{background:var(--color-bg-main)}.btn-print{background:var(--color-primary);color:var(--color-primary-text,#fff);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);align-items:center;gap:8px;padding:10px 20px;font-weight:600;display:flex}.btn-print:hover{background:var(--color-primary-dark);box-shadow:var(--shadow-md);transform:translateY(-2px)}.invoice-document{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);background:#fff;overflow:hidden}.invoice-header{background:linear-gradient(135deg, var(--color-secondary) 0%, var(--color-accent) 100%);color:#fff;justify-content:space-between;align-items:center;padding:40px;display:flex}.header-left,.header-right{flex-direction:column;justify-content:center;display:flex}.header-left{align-items:flex-start}.header-right{align-items:flex-end}.header-left h1{letter-spacing:2px;margin-bottom:8px;font-size:2.5rem}.invoice-number{opacity:.9;font-size:1.1rem}.company-logo-text{text-align:right;letter-spacing:1px;font-size:2rem;font-style:italic;font-weight:900}.company-tagline{opacity:.9;text-align:right;margin-top:4px;font-size:.9rem}.invoice-body{padding:40px}.info-section{grid-template-columns:1fr 1fr;gap:30px;margin-bottom:40px;display:grid}.info-box{flex-direction:column;gap:4px;display:flex}.info-box.align-right{text-align:right;align-items:flex-end}.info-label{text-transform:uppercase;color:var(--color-text-light);letter-spacing:1px;margin-bottom:4px;font-size:.75rem}.info-name{color:var(--color-text-main);margin-bottom:4px;font-size:1.25rem;font-weight:700}.info-detail,.info-value{color:var(--color-text-muted);font-size:.95rem}.highlight-red{color:var(--color-accent);font-weight:600}.info-group{margin-bottom:16px}.payment-notice{border-radius:var(--radius-md);background-color:#ff980014;border:1px solid #ff980033;align-items:flex-start;gap:16px;margin-bottom:40px;padding:16px 20px;display:flex}.notice-icon{color:var(--color-secondary-dark);background:#ff980026;border-radius:50%;padding:8px;display:flex}.notice-content h4{color:var(--color-secondary-dark);margin-bottom:4px;font-size:1rem}.notice-content p{color:var(--color-text-main);font-size:.9rem;line-height:1.5}.invoice-items{margin-bottom:40px}.invoice-items table{border-collapse:collapse;width:100%}.invoice-items th{text-align:left;border-bottom:2px solid var(--color-border);color:var(--color-text-light);text-transform:uppercase;letter-spacing:1px;padding:12px 8px;font-size:.8rem}.invoice-items th.col-period,.invoice-items th.col-amount{text-align:right}.invoice-items td{border-bottom:1px solid var(--color-border);vertical-align:top;padding:16px 8px}.invoice-items td.col-period,.invoice-items td.col-amount{text-align:right}.item-name{color:var(--color-text-main);margin-bottom:4px;font-weight:600}.item-note{color:var(--color-text-muted);font-size:.85rem}.col-amount{color:var(--color-text-main);font-weight:600}.invoice-summary-container{justify-content:flex-end;margin-bottom:40px;display:flex}.invoice-summary{width:100%;max-width:350px}.summary-row{border-bottom:1px solid var(--color-border);color:var(--color-text-muted);justify-content:space-between;padding:12px 0;display:flex}.summary-row.text-green{color:#4caf50}.summary-val{font-weight:600}.total-row{background:var(--color-bg-main);border-radius:var(--radius-sm);border-bottom:none;align-items:center;margin-top:12px;padding:16px}.total-row span{color:var(--color-text-main);font-size:1.1rem;font-weight:700}.total-row .total-val{color:var(--color-secondary-dark);font-size:1.4rem}.invoice-footer-notes{border-top:1px solid var(--color-border);padding-top:30px}.invoice-footer-notes h4{color:var(--color-text-main);margin-bottom:12px;font-size:.9rem}.invoice-footer-notes ul{padding-left:20px;list-style:outside}.invoice-footer-notes li{color:var(--color-text-muted);margin-bottom:6px;font-size:.85rem}@page{size:A4 portrait;margin:1cm}@media print{body{background:#fff;margin:0;padding:0}.no-print{display:none!important}.invoice-page{max-width:100%;padding:0}.invoice-document{box-shadow:none;border:none;border-radius:0}.invoice-body{padding:20px 30px!important}.invoice-header{-webkit-print-color-adjust:exact;print-color-adjust:exact;padding:20px 30px!important}.info-section{gap:15px!important;margin-bottom:20px!important}.payment-notice{-webkit-print-color-adjust:exact;print-color-adjust:exact;margin-bottom:20px!important;padding:10px 15px!important}.invoice-items{margin-bottom:20px!important}.invoice-items td,.invoice-items th{padding:8px!important}.invoice-summary-container{margin-bottom:10px!important}.total-row{-webkit-print-color-adjust:exact;print-color-adjust:exact;padding:10px!important}.invoice-footer-notes{margin-top:15px!important;padding-top:15px!important}}.attendance-page{animation:.3s fadeIn}.filter-panel{gap:15px;margin-bottom:25px;padding:15px 20px}.mb-0{margin-bottom:0!important}#qr-reader__scan_region,#kiosk-qr-reader__scan_region,#kiosk-tutor-qr-reader__scan_region,#kiosk-employee-qr-reader__scan_region{border-radius:8px;background-color:#000!important;justify-content:center!important;align-items:center!important;display:flex!important;position:relative!important;overflow:hidden!important}#qr-reader video,#kiosk-qr-reader video,#kiosk-tutor-qr-reader video,#kiosk-employee-qr-reader video{object-fit:cover!important;width:100%!important;height:auto!important;display:block!important;transform:translate(0,0)!important}#qr-reader__scan_region>svg,#kiosk-qr-reader__scan_region>svg,#kiosk-tutor-qr-reader__scan_region>svg,#kiosk-employee-qr-reader__scan_region>svg{display:none!important}#qr-reader__scan_region:after{content:"";pointer-events:none;z-index:10;border:none;border-radius:12px;width:250px;height:250px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 4000px #00000080}#kiosk-qr-reader__scan_region:after{content:"";pointer-events:none;z-index:10;border:none;border-radius:12px;width:300px;height:300px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 4000px #00000080}.tabs{border-bottom:1px solid var(--color-border);gap:12px;margin-bottom:24px;padding-bottom:12px;display:flex}.badge-hours{border-radius:var(--radius-full);background-color:var(--color-bg-main);color:var(--color-text-main);border:1px solid var(--color-border);padding:4px 10px;font-size:.85rem;font-weight:600;display:inline-block}.badge-hours.primary{color:var(--color-primary-dark);background-color:#ffc1071a;border-color:#ffc1074d}.payroll-summary-header{border-bottom:1px solid var(--color-border);padding:20px}.payroll-summary-header h3{color:var(--color-text-main);margin-bottom:5px}.payroll-summary-header p{color:var(--color-text-muted);font-size:.9rem}.table-footer{background-color:var(--color-bg-main)}.table-footer td{padding:15px 20px}.print-only{display:none}@media print{@page{size:A4 portrait;margin:15mm}body{margin:0;padding:0;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background:#fff!important}.sidebar,.header,header,.footer,footer,.page-header,.filter-panel,.attendance-content,.modal-overlay{display:none!important}#root,.app-container,.main-content,.content-area,.attendance-page{opacity:1!important;visibility:visible!important;background:#fff!important;width:100%!important;height:auto!important;margin:0!important;padding:0!important;display:block!important;position:static!important;overflow:visible!important;transform:none!important}.print-only{background:#fff;width:100%;margin:0;padding:0;opacity:1!important;visibility:visible!important;display:block!important;position:static!important;transform:none!important}.print-only *{visibility:visible!important;opacity:1!important}.payslip-paper{width:100%;max-width:100%;box-shadow:none;break-after:page;page-break-after:always;background:#fff;border:none;border-radius:0;margin:0;padding:0;font-family:Inter,system-ui,-apple-system,sans-serif;position:relative;overflow:visible;color:#0f172a!important}.payslip-paper:last-child{break-after:auto;page-break-after:auto}.payslip-copy-badge{color:#475569;text-transform:uppercase;letter-spacing:1px;z-index:2;background:#e2e8f0;border-radius:4px;padding:4px 12px;font-size:11px;font-weight:700;position:absolute;top:15px;right:20px}.payslip-watermark{opacity:.03;z-index:0;pointer-events:none;font-size:300px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.payslip-watermark img{object-fit:contain;filter:grayscale();width:400px;height:400px}.payslip-header{z-index:1;justify-content:space-between;align-items:flex-start;padding:10px 10px 20px;display:flex;position:relative}.payslip-logo{align-items:center;gap:15px;display:flex}.logo-icon-print{font-size:45px;line-height:1}.logo-img-print{object-fit:contain;width:50px;height:50px}.payslip-company-info h2{color:#1e293b;letter-spacing:-.5px;margin:0;font-size:22px;font-weight:800}.payslip-company-info p{color:#64748b;text-transform:uppercase;letter-spacing:1px;margin:2px 0 0;font-size:12px;font-weight:600}.payslip-title{text-align:right}.payslip-title h1{color:var(--color-primary-dark,#d97706);letter-spacing:-.5px;margin:0;font-size:26px;font-weight:900}.payslip-badge{background:var(--color-primary,#f59e0b);color:#fff;letter-spacing:1.5px;border-radius:20px;margin-top:5px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.payslip-title p{color:#475569;margin:8px 0 0;font-size:13px;font-weight:600}.payslip-divider{background:linear-gradient(90deg, var(--color-primary,#f59e0b), var(--color-secondary,#fbbf24));z-index:1;border-radius:3px;height:6px;margin:10px 10px 30px;position:relative}.payslip-body{z-index:1;padding:0 10px 20px;position:relative}.payslip-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:25px;padding:20px 25px}.payslip-section-title{color:#64748b;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;margin-left:5px;font-size:12px;font-weight:700}.details-section{background:#fff;border:2px dashed #e2e8f0}.payslip-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:10px 0;font-size:15px;display:flex}.payslip-row:last-child{border-bottom:none}.payslip-label{color:#64748b;font-weight:500}.payslip-value{color:#0f172a}.ref-code{color:#475569;letter-spacing:1px;background:#f1f5f9;border-radius:6px;padding:3px 8px;font-family:Space Mono,monospace;font-size:13px}.total-row{border-top:2px solid #e2e8f0;margin-top:15px;padding-top:15px}.total-row .payslip-label{color:#0f172a;font-size:16px;font-weight:800}.total-amount{color:#059669!important;font-size:24px!important;font-weight:900!important}.payslip-qr-section{flex-direction:column;align-items:center;margin-top:30px;display:flex}.qr-box{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:5px;box-shadow:0 4px 6px #00000005}.qr-box img{width:70px;height:70px;display:block}.qr-text{color:#94a3b8;text-align:center;margin:8px 0 0;font-size:10px;line-height:1.4}.payslip-footer{text-align:center;z-index:1;padding:0 10px 40px;position:relative}.footer-note{color:#64748b;margin-bottom:30px;font-size:13px;font-style:italic}.signature-area{justify-content:space-between;padding:0 30px;display:flex}.signature-box{text-align:center;width:150px}.sig-title{color:#64748b;margin:0;font-size:13px}.sig-space{height:70px}.sig-name{color:#0f172a;border-top:1px solid #cbd5e1;margin:0;padding-top:8px;font-size:14px}.payslip-bottom-bar{display:none}}.salary-rates-page{flex-direction:column;gap:24px;display:flex}.content-grid{grid-template-columns:2fr 1fr;align-items:start;gap:24px;display:grid}.rates-cards-container{flex-direction:column;gap:16px;display:flex}.rate-card{border-left:4px solid var(--color-primary);border-radius:16px;padding:24px}.rate-card:first-child{border-left-color:var(--color-primary)}.rate-card:nth-child(2){border-left-color:var(--color-secondary)}.rate-card:nth-child(3){border-left-color:var(--color-accent)}.rate-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.rate-header h3{color:#1f2937;margin:0;font-size:18px;font-weight:600}.badge{text-transform:uppercase;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.badge-primary{background-color:rgba(var(--color-primary-rgb,255, 213, 79), .2);color:var(--color-primary-text,#b45309)}.badge-secondary{background-color:rgba(var(--color-secondary-rgb,255, 152, 0), .2);color:var(--color-secondary-text,#c2410c)}.badge-accent{background-color:rgba(var(--color-accent-rgb,255, 87, 34), .2);color:var(--color-accent-text,#9f1239)}.rate-display{align-items:baseline;gap:8px;display:flex}.rate-amount{color:#111827;font-size:32px;font-weight:700}.rate-period{color:#6b7280;font-size:16px;font-weight:500}.info-panel{background:linear-gradient(145deg,#ffffffe6,#fff6);border-radius:16px;padding:24px}.info-panel h3{color:#1f2937;margin-top:0;margin-bottom:16px;font-size:18px}.info-panel p{color:#4b5563;margin-bottom:16px;line-height:1.6}.info-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.info-list li{color:#4b5563;padding-left:16px;line-height:1.5;position:relative}.info-list li:before{content:"•";color:var(--color-primary);font-weight:700;position:absolute;left:0}.alert-success{color:#065f46;background-color:#ecfdf5;border:1px solid #a7f3d0;border-radius:12px;align-items:center;gap:12px;padding:16px;font-weight:500;display:flex}.action-group{gap:12px;display:flex}.form-group{margin-bottom:0}.form-help{color:#6b7280;margin-top:8px;font-size:13px;display:block}@media (width<=992px){.content-grid{grid-template-columns:1fr}}.settings-page{max-width:800px;margin:0 auto;padding:20px 0}.page-header{margin-bottom:30px}.page-header h2{color:var(--color-primary-dark);margin-bottom:8px;font-size:1.8rem}.page-header p{color:var(--color-text-muted)}.settings-form{border-radius:var(--radius-lg);flex-direction:column;gap:30px;padding:30px;display:flex}.form-section{border-bottom:1px solid var(--color-border);padding-bottom:25px}.form-section:last-of-type{border-bottom:none;padding-bottom:0}.form-section h3{color:var(--color-text-main);align-items:center;gap:10px;margin-bottom:15px;font-size:1.2rem;display:flex}.help-text{color:var(--color-text-muted);margin-bottom:15px;font-size:.9rem}.text-success{color:#4caf50;margin-top:5px}.logo-type-selector{gap:10px;margin-bottom:20px;display:flex}.type-btn{border-radius:var(--radius-sm);background:var(--color-bg-main);border:1px solid var(--color-border);color:var(--color-text-muted);transition:all var(--transition-fast);align-items:center;gap:8px;padding:8px 16px;font-weight:500;display:flex}.type-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.logo-input-container{align-items:flex-start;gap:30px;display:flex}.logo-input-container .form-group{flex:1}.logo-preview-box{background:var(--color-bg-main);border-radius:var(--radius-md);border:1px dashed var(--color-border-focus);flex-direction:column;justify-content:center;align-items:center;min-width:150px;padding:15px;display:flex}.preview-label{color:var(--color-text-light);margin-bottom:10px;font-size:.8rem}.preview-icon{font-size:3rem;line-height:1}.preview-image{object-fit:contain;max-width:100px;max-height:100px}.preview-placeholder{color:var(--color-text-light);font-size:.9rem;font-style:italic}.color-pickers{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;display:grid}.color-group{margin-bottom:0}.color-input-wrapper{background:var(--color-bg-main);border-radius:var(--radius-sm);border:1px solid var(--color-border);align-items:center;gap:15px;padding:8px;display:flex}.color-picker{appearance:none;border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;width:40px;height:40px;padding:0}.color-picker::-webkit-color-swatch-wrapper{padding:0}.color-picker::-webkit-color-swatch{border:none;border-radius:4px}.color-hex{color:var(--color-text-main);font-family:monospace;font-size:1.1rem}.form-actions{justify-content:flex-end;align-items:center;gap:20px;margin-top:10px;display:flex}.success-msg{color:#4caf50;font-weight:500;animation:.3s fadeIn}.btn-save{padding:10px 24px;font-size:1rem}.file-upload-wrapper{margin-top:10px;margin-bottom:15px}.file-input-hidden{display:none}.file-upload-label{border:2px dashed var(--color-border-focus);border-radius:var(--radius-md);background:var(--color-bg-main);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;justify-content:center;align-items:center;padding:30px 20px;display:flex}.file-upload-label:hover{border-color:var(--color-primary);background:#ffc1070d;transform:translateY(-2px)}.upload-icon{color:var(--color-primary);margin-bottom:10px}.upload-text{color:var(--color-text-main);margin-bottom:5px;font-weight:500}.upload-hint{color:var(--color-text-light);font-size:.85rem}.salary-mode-selector{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:10px;display:grid}.salary-mode-card{border-radius:var(--radius-md);border:2px solid var(--color-border);background:var(--color-bg-main);cursor:pointer;text-align:center;flex-direction:column;align-items:center;gap:8px;padding:22px 16px;transition:all .25s;display:flex;position:relative}.salary-mode-card:hover{border-color:var(--color-primary);transform:translateY(-3px);box-shadow:0 6px 20px #00000014}.salary-mode-card.active{border-color:var(--color-primary);background:#ffc10714;box-shadow:0 0 0 3px #ffd54f4d}.salary-mode-icon{font-size:2.2rem;line-height:1}.salary-mode-label{color:var(--color-text-main);font-size:1rem;font-weight:700}.salary-mode-desc{color:var(--color-text-muted);font-size:.8rem;line-height:1.4}.salary-mode-check{background:var(--color-primary);color:#fff;border-radius:20px;padding:3px 8px;font-size:.7rem;font-weight:700;animation:.2s fadeIn;position:absolute;top:10px;right:10px}@media (width<=768px){.logo-input-container{flex-direction:column}.logo-preview-box{width:100%}.salary-mode-selector{grid-template-columns:1fr}}.employee-attendance-page,.employee-schedule-page{padding:24px}.schedule-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (width<=768px){.schedule-grid{grid-template-columns:1fr}}.card-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border-radius:12px;padding:20px;box-shadow:0 4px 6px #0000000d}.card-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.card-header h3{color:var(--color-primary-text);margin:0;font-size:18px}.task-list,.schedule-list{flex-direction:column;gap:12px;display:flex}.task-item,.schedule-item{background:#fff;border:1px solid #eee;border-radius:8px;justify-content:space-between;align-items:flex-start;padding:12px;display:flex}.task-item.completed{opacity:.6}.task-item.completed .task-title{text-decoration:line-through}.task-info,.schedule-info{flex-direction:column;gap:4px;display:flex}.task-title{color:#333;font-weight:600}.task-meta,.schedule-meta{color:#666;align-items:center;gap:8px;font-size:13px;display:flex}.employee-badge{background:var(--color-secondary);color:var(--color-secondary-text);border-radius:4px;padding:2px 6px;font-size:11px}.task-actions{gap:4px;display:flex}.btn-check{cursor:pointer;color:#10b981;background:0 0;border:none;padding:4px}.btn-delete{cursor:pointer;color:#ef4444;background:0 0;border:none;padding:4px}.ReloadPrompt-container{width:0;height:0;margin:0;padding:0}.ReloadPrompt-toast{z-index:99999;text-align:left;background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;max-width:350px;margin:16px;padding:18px;animation:.3s ease-out slideUp;position:fixed;bottom:16px;right:16px;box-shadow:0 10px 25px -5px #0003}@keyframes slideUp{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.ReloadPrompt-message{color:#334155;margin-bottom:16px;font-size:.95rem;font-weight:500;line-height:1.4}.ReloadPrompt-buttons{gap:10px;display:flex}.ReloadPrompt-toast-button{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s}.ReloadPrompt-toast-button:hover{background:#f1f5f9}.ReloadPrompt-toast-button.bg-orange{color:#fff;background:#f97316;border:none}.ReloadPrompt-toast-button.bg-orange:hover{background:#ea580c}
