*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}:root{--accent:#2563eb;--accent-h:#1d4ed8;--accent-light:#2563eb1f;--green:#059669;--amber:#d97706;--red:#dc2626;--purple:#7c3aed;--cyan:#0891b2;--pink:#db2777;--radius:12px;--radius-lg:18px;--radius-sm:8px;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 10px 40px #00000026;--font-body:"Plus Jakarta Sans",sans-serif;--font-head:"Sora",sans-serif;--sb-width:260px}.theme-light{--bg:#f0f4fa;--bg2:#e4ecf7;--surface:#fff;--surface2:#f8fafd;--border:#dde5f0;--text:#0d1b2e;--text2:#4a6080;--text3:#8aa0be;--sb-bg:#0d1b2e;--sb-text:#ffffffa6;--sb-active:#ffffff1f;--sb-active-text:#fff}.theme-dark{--bg:#080d14;--bg2:#0c1320;--surface:#101828;--surface2:#141e2e;--border:#1e2d42;--text:#e8f0fb;--text2:#7b92b0;--text3:#4a6080;--sb-bg:#060c16;--sb-text:#ffffff8c;--sb-active:#2563eb33;--sb-active-text:#93bbfd}body{font-family:var(--font-body);background:var(--bg);color:var(--text);transition:background .3s,color .3s}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-track{background:0 0;border-radius:8px}::-webkit-scrollbar-thumb{background:var(--text3);border:2px solid var(--bg);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--text2)}::-webkit-scrollbar-corner{background:0 0}*{scrollbar-width:thin;scrollbar-color:var(--text3) transparent}.app-wrap{min-height:100vh;display:flex;position:relative}.main-content{margin-left:var(--sb-width);flex-direction:column;flex:1;min-width:0;transition:margin-left .3s;display:flex}.main-content.expanded{margin-left:0}.sidebar{width:var(--sb-width);z-index:200;background:#1c44b2;flex-direction:column;height:100vh;transition:transform .3s;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar.collapsed{transform:translateX(calc(-1 * var(--sb-width)))}.sidebar-overlay{-webkit-backdrop-filter:blur(3px);z-index:195;background:#0000008c;animation:.2s fade-in;display:none;position:fixed;inset:0}.nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;gap:8px;height:60px;padding:0 24px 0 30px;display:flex;position:sticky;top:0}.topbar-title{white-space:nowrap;text-overflow:ellipsis;max-width:200px;overflow:hidden}.topbar-user-info{flex-direction:column;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.card-inner{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius)}.btn{border-radius:var(--radius-sm);cursor:pointer;font-size:13.5px;font-weight:600;font-family:var(--font-body);white-space:nowrap;border:none;align-items:center;gap:7px;padding:9px 18px;transition:all .18s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-h);transform:translateY(-1px);box-shadow:0 4px 14px #2563eb59}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-success{background:var(--green);color:#fff}.btn-success:hover{background:#047857}.btn-sm{padding:6px 12px;font-size:12.5px}.btn-ghost{color:var(--accent);border:1px solid var(--accent);background:0 0}.btn-ghost:hover{background:var(--accent-light)}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--text2);text-transform:uppercase;letter-spacing:.07em;font-size:11.5px;font-weight:700}.form-input{border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface2);color:var(--text);font-size:13.5px;font-family:var(--font-body);width:100%;padding:10px 14px;transition:border-color .2s,box-shadow .2s}.form-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #2563eb1f}.form-input option{background:var(--surface)}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;min-width:400px}.data-table th{text-transform:uppercase;letter-spacing:.07em;color:var(--text3);border-bottom:1.5px solid var(--border);text-align:left;white-space:nowrap;background:var(--surface2);padding:11px 16px;font-size:11px;font-weight:700}.data-table td{border-bottom:1px solid var(--border);color:var(--text2);vertical-align:middle;padding:12px 16px;font-size:13.5px}.data-table tbody tr:hover td{background:var(--surface2)}.data-table tbody tr:last-child td{border-bottom:none}.badge{border-radius:20px;align-items:center;padding:3px 10px;font-size:11.5px;font-weight:700;display:inline-flex}.chip{border-radius:6px;align-items:center;gap:4px;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:16px;animation:.2s fade-in;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-height:90vh;padding:28px;animation:.22s scale-in;overflow-y:auto}.modal-sm{max-width:440px}.modal-md{max-width:600px}.modal-lg{max-width:800px}.page-anim{animation:.28s slide-up}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes slide-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.stat-card{border-radius:var(--radius-lg);cursor:pointer;padding:22px;transition:transform .22s,box-shadow .22s;position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}.stat-card:after{content:"";pointer-events:none;background:#ffffff0f;border-radius:50%;width:100px;height:100px;position:absolute;bottom:-24px;right:-24px}.notif-dot{background:var(--red);border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s infinite pulse-dot}.search-box{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:8px 14px;transition:border-color .2s;display:flex}.search-box:focus-within{border-color:var(--accent)}.search-box input{color:var(--text);font-size:13.5px;font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1;min-width:0}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:18px;display:flex}.section-title{font-family:var(--font-head);color:var(--text);font-size:15px;font-weight:700}.page-title{font-family:var(--font-head);color:var(--text);letter-spacing:-.02em;font-size:23px;font-weight:800}.page-sub{color:var(--text2);margin-top:3px;font-size:13px}.grid-2{grid-template-columns:repeat(2,1fr);gap:18px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.col2{display:grid}.pos-layout{grid-template-columns:1fr 360px;align-items:start;gap:18px;display:grid}.custom-item-grid{grid-template-columns:1fr 1fr 80px 1fr auto;align-items:end;gap:10px;display:grid}.settings-layout{flex-wrap:wrap;align-items:flex-start;gap:20px;display:flex}.settings-nav{flex-shrink:0;width:200px;padding:8px}.settings-nav .nav-item{color:var(--text2)}.settings-nav .nav-item.active{color:var(--accent);background:var(--accent-light);box-shadow:inset 4px 0 0 var(--accent);border:1px solid #2563eb33;font-weight:700}.settings-content{flex:1;min-width:0;padding:28px}.msg-grid{grid-template-columns:3fr 2fr;align-items:start;gap:20px;display:grid}.msg-grid>:first-child{order:1}.msg-grid>:last-child{order:2}.sales-rev-stats{flex-wrap:wrap;align-items:center;gap:20px;padding:10px 18px;display:flex}.sales-rev-divider{background:var(--border);flex-shrink:0;width:1px;height:32px}.progress-bar-wrap{background:var(--border);border-radius:3px;height:5px;overflow:hidden}.progress-bar-fill{border-radius:3px;height:100%;transition:width .6s}.avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.avatar-lg{width:56px;height:56px;font-size:20px}.att-radio{appearance:none;border:2px solid var(--border);cursor:pointer;border-radius:50%;flex-shrink:0;width:18px;height:18px;transition:all .15s}.att-radio:checked{border-color:#0000}.att-radio.p:checked{background:var(--green)}.att-radio.a:checked{background:var(--red)}.att-radio.l:checked{background:var(--amber)}.att-radio.e:checked{background:var(--cyan)}.tab-bar{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);flex-wrap:wrap;gap:3px;width:fit-content;padding:4px;display:flex}.tab-btn{font-family:var(--font-body);cursor:pointer;color:var(--text2);background:0 0;border:none;border-radius:7px;padding:7px 18px;font-size:13px;font-weight:600;transition:all .17s}.tab-btn.active{background:var(--accent);color:#fff}.notif-panel{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);width:360px;box-shadow:var(--shadow-lg);z-index:300;animation:.18s scale-in;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.notif-item{border-bottom:1px solid var(--border);cursor:pointer;gap:12px;padding:13px 16px;transition:background .15s;display:flex}.notif-item:hover{background:var(--surface2)}.notif-item:last-child{border-bottom:none}.notif-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;display:flex}.receipt-preview{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:580px;margin:0 auto;padding:28px}.report-card{color:#0d1b2e;border-radius:var(--radius-lg);background:#fff;border:2px solid #dde5f0;max-width:720px;margin:0 auto;padding:32px}.rc-header{border-bottom:2px solid #dde5f0;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;display:flex}.rc-logo{background:linear-gradient(135deg,#1e3a8a,#2563eb);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:60px;height:60px;font-size:26px;display:flex}.step-num{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:flex}.toggle-switch{cursor:pointer;border:none;border-radius:12px;flex-shrink:0;width:44px;height:24px;transition:background .2s;position:relative}.toggle-knob{background:#fff;border-radius:50%;width:18px;height:18px;transition:left .2s;position:absolute;top:3px}.grade-A1{color:#059669;font-weight:800}.grade-B2,.grade-B3{color:#2563eb;font-weight:700}.grade-C4,.grade-C5,.grade-C6{color:#d97706;font-weight:700}.grade-D7{color:#ea580c;font-weight:700}.grade-E8,.grade-F9{color:#dc2626;font-weight:700}.msg-compose{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);min-height:100px;color:var(--text);font-size:13.5px;font-family:var(--font-body);resize:vertical;outline:none;width:100%;padding:12px 14px}.msg-compose:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a}.inline-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.divider{background:var(--border);height:1px;margin:14px 0}.sidebar-group-label{text-transform:uppercase;letter-spacing:.12em;color:#ffffff73;padding:18px 24px 8px;font-size:10.5px;font-weight:700}.nav-item{cursor:pointer;color:#ffffffd9;white-space:nowrap;border:1px solid #0000;border-radius:10px;align-items:center;margin:2px 14px;padding:10px 18px 10px 24px;font-size:14.5px;font-weight:500;transition:all .2s;display:flex;position:relative;overflow:hidden}.nav-item:hover{color:#fff;background:#ffffff0f}.nav-item.active{-webkit-backdrop-filter:blur(10px);color:#fff;background:#ffffff1f;border:1px solid #ffffff40;font-weight:700;box-shadow:inset 4px 0 #fff,0 8px 20px #0000001a}.print-only{display:none!important}@media print{.no-print,.sidebar,.topbar,footer{display:none!important}body,.app-wrap,.main-content,#root{color:#000!important;background:#fff!important;width:100%!important;height:auto!important;margin:0!important;padding:0!important;display:block!important}.main-content{margin-left:0!important}main{padding:0!important;overflow:visible!important}.report-card{box-shadow:none!important;border:none!important;max-width:100%!important;margin:0!important;padding:0!important}.page-anim{animation:none!important;transform:none!important}.print-only{display:block!important}.attendance-print-area{width:100%;padding:10px 0;display:block!important}.attendance-print-area .att-print-header{text-align:center;border-bottom:2px solid #000;margin-bottom:16px;padding-bottom:12px}.attendance-print-area .att-print-header h2{margin:0 0 4px;font-size:18pt;font-weight:800}.attendance-print-area .att-print-header p{color:#444;margin:2px 0;font-size:10pt}.attendance-print-area .att-print-header .att-meta{justify-content:space-between;margin-top:10px;font-size:10pt;font-weight:600;display:flex}.attendance-print-area table{border-collapse:collapse;width:100%;font-size:9.5pt}.attendance-print-area th{text-align:center;-webkit-print-color-adjust:exact;print-color-adjust:exact;border:1px solid #374151;padding:7px 8px;font-weight:700;color:#fff!important;background:#1e293b!important}.attendance-print-area td{text-align:center;vertical-align:middle;border:1px solid #d1d5db;padding:6px 8px}.attendance-print-area tr:nth-child(2n) td{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#f8fafc!important}.attendance-print-area .att-status-present{color:#15803d;font-weight:700}.attendance-print-area .att-status-absent{color:#dc2626;font-weight:700}.attendance-print-area .att-status-late{color:#b45309;font-weight:700}.attendance-print-area .att-status-excused{color:#0369a1;font-weight:700}.attendance-print-area .att-print-footer{justify-content:space-between;margin-top:24px;font-size:9pt;display:flex}.attendance-print-area .att-sig-box{text-align:center;color:#555;border-top:1px solid #000;width:180px;padding-top:4px;font-size:8pt}.receipt-print-sheet{border:1px solid #d1d5db;max-width:420px;margin:20px auto;padding:24px;font-family:Arial,sans-serif}.receipt-print-sheet .rp-header{text-align:center;border-bottom:2px dashed #000;margin-bottom:16px;padding-bottom:14px}.receipt-print-sheet .rp-header h2{text-transform:uppercase;margin:0 0 3px;font-size:15pt;font-weight:800}.receipt-print-sheet .rp-header p{color:#555;margin:1px 0;font-size:9pt}.receipt-print-sheet .rp-header .rp-title{color:#1d4ed8;letter-spacing:.04em;margin-top:6px;font-size:11pt;font-weight:700}.receipt-print-sheet .rp-row{border-bottom:1px solid #e5e7eb;justify-content:space-between;padding:7px 0;font-size:10pt;display:flex}.receipt-print-sheet .rp-row .rp-label{color:#555;font-weight:600}.receipt-print-sheet .rp-row .rp-val{color:#111;font-weight:700}.receipt-print-sheet .rp-row.total .rp-val{color:#15803d;font-size:12pt}.receipt-print-sheet .rp-footer{text-align:center;color:#888;border-top:1px solid #e5e7eb;margin-top:24px;padding-top:10px;font-size:8pt}.receipt-print-sheet .rp-sig-row{justify-content:space-between;margin-top:28px;display:flex}.receipt-print-sheet .rp-sig-box{text-align:center;color:#555;border-top:1px solid #000;width:140px;padding-top:4px;font-size:8pt}.print-attendance .receipt-print-sheet,.print-receipt .attendance-print-area{display:none!important}}@media (width<=1100px){.pos-layout{grid-template-columns:1fr 300px}.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.notif-panel{width:300px}.pos-layout{grid-template-columns:1fr}.custom-item-grid{grid-template-columns:1fr 1fr}.page-title{font-size:20px}}@media (width<=768px){.main-content,.main-content.expanded{margin-left:0!important}.sidebar-overlay{display:block}.sidebar{z-index:200;box-shadow:4px 0 24px #0006}main{padding:16px 14px!important}.topbar{height:56px;padding:0 12px 0 14px}.topbar-title{max-width:130px;font-size:15px}.topbar-user-info{display:none}.notif-panel{width:auto;position:fixed;top:64px;left:12px;right:12px}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.col2{grid-template-columns:1fr!important}.pos-layout{grid-template-columns:1fr;gap:14px}.custom-item-grid{grid-template-columns:1fr 1fr;gap:8px}.modal-backdrop{align-items:flex-end;padding:0}.modal-box{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:92vh;padding:20px 16px}.modal-sm,.modal-md,.modal-lg{max-width:100%}.section-header{flex-direction:column;align-items:flex-start}.tab-bar{flex-wrap:nowrap;width:100%;overflow-x:auto}.tab-btn{white-space:nowrap;padding:7px 14px;font-size:12px}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.stat-card{padding:16px}.search-box{width:100%;min-width:0!important}.page-title{font-size:18px}.page-sub{font-size:12px}.inline-actions{flex-wrap:wrap;gap:6px}.report-card{padding:16px}.rc-header{flex-wrap:wrap;gap:10px}.receipt-preview{padding:16px}.att-radio{width:22px;height:22px}.settings-nav{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-direction:row;flex-shrink:0;gap:0;width:100%;padding:4px;display:flex;overflow-x:auto}.settings-nav::-webkit-scrollbar{display:none}.settings-nav .nav-item{white-space:nowrap;flex-shrink:0;margin:2px;padding:7px 11px;font-size:12px;overflow:visible}.settings-nav .nav-item.active{box-shadow:inset 0 -3px 0 0 var(--accent);border-radius:6px 6px 0 0}.settings-content{padding:18px 14px}.sales-rev-stats{gap:12px;padding:12px 14px}.sales-rev-divider{width:100%;height:1px}}@media (width<=480px){main{padding:12px 10px!important}.topbar{padding:0 10px 0 12px}.topbar-title{max-width:100px;font-size:14px}.grid-4{grid-template-columns:repeat(2,1fr);gap:10px}.grid-2{grid-template-columns:1fr}.col2{grid-template-columns:1fr!important}.custom-item-grid{grid-template-columns:1fr}.modal-box{padding:16px 12px}.card{border-radius:var(--radius)}.btn{padding:8px 14px;font-size:12.5px}.btn-sm{padding:5px 10px;font-size:11.5px}.tab-btn{padding:6px 10px;font-size:11px}.data-table th,.data-table td{padding:9px 10px;font-size:12px}.notif-panel{left:6px;right:6px}.page-title{font-size:16px}.section-title{font-size:13px}.settings-content{padding:14px 12px}.settings-nav .nav-item{padding:6px 9px;font-size:11px}.sales-rev-stats{text-align:center;flex-direction:column;align-items:stretch;gap:8px}}.kpi-grid{grid-template-columns:repeat(5,1fr);gap:14px;display:grid}@media (width<=1100px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.kpi-grid{grid-template-columns:1fr}}@media (width<=900px){.msg-grid{grid-template-columns:1fr 1fr;gap:16px}}@media (width<=768px){.msg-grid{grid-template-columns:1fr;gap:14px}.msg-grid .grid-2{grid-template-columns:1fr 1fr!important}}@media (width<=480px){.msg-grid{gap:12px}}@media (width<=1100px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.kpi-grid{grid-template-columns:1fr}}@keyframes sk-shimmer{0%{background-position:-400% 0}to{background-position:400% 0}}.sk{background:linear-gradient(90deg, var(--surface2) 25%, var(--border) 50%, var(--surface2) 75%);background-size:400% 100%;border-radius:6px;flex-shrink:0;animation:1.6s ease-in-out infinite sk-shimmer}
