:root{--blue: #4f6ef7;--purple: #8b5cf6;--cyan: #06b6d4;--amber: #f59e0b;--gold: #f59e0b;--green: #10b981;--red: #ef4444;--orange: #f97316;--pink: #ec4899;--app-bg: #f8fafc;--app-content-bg: #ffffff;--app-card: #ffffff;--app-surface: #f1f5f9;--app-surface-hi: #e2e8f0;--app-text-main: #0f172a;--app-text-dim: #64748b;--app-border: rgba(0, 0, 0, .08);--app-border-hi: rgba(0, 0, 0, .15);--app-shadow: 0 4px 12px rgba(0, 0, 0, .05);--app-glow: transparent;--app-sidebar: #ffffff;--app-topbar: rgba(255, 255, 255, .8);--status-success: #10b981;--status-success-bg: rgba(16, 185, 129, .1);--status-danger: #ef4444;--status-danger-bg: rgba(239, 68, 68, .1);--status-warning: #f59e0b;--status-warning-bg: rgba(245, 158, 11, .1);--status-info: #4f6ef7;--status-info-bg: rgba(79, 110, 247, .1);--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(0, 0, 0, .08);--bg: var(--app-bg);--card: var(--app-card);--white: var(--app-text-main);--text-main: var(--app-text-main);--dim: var(--app-text-dim);--b: var(--app-border);--bh: var(--app-border-hi);--border: var(--app-border);--border-hi: var(--app-border-hi)}.dark{--app-bg: #04040f;--app-content-bg: #04040f;--app-card: rgba(12, 12, 36, .98);--app-surface: #0d0d24;--app-surface-hi: #151533;--app-text-main: #e8eeff;--app-text-dim: #8892b0;--app-border: rgba(100, 120, 255, .13);--app-border-hi: rgba(100, 120, 255, .3);--app-shadow: 0 24px 80px rgba(0, 0, 0, .6);--app-glow: 0 0 20px rgba(79, 110, 247, .3);--app-sidebar: rgba(7, 7, 32, .97);--app-topbar: rgba(4, 4, 15, .85);--status-success: #10b981;--status-success-bg: rgba(16, 185, 129, .12);--status-danger: #ef4444;--status-danger-bg: rgba(239, 68, 68, .15);--status-warning: #f59e0b;--status-warning-bg: rgba(245, 158, 11, .12);--status-info: #4f6ef7;--status-info-bg: rgba(79, 110, 247, .15);--glass-bg: rgba(4, 4, 15, .85);--glass-border: rgba(100, 120, 255, .13);--bg: var(--app-bg);--card: var(--app-card);--white: var(--app-text-main);--text-main: var(--app-text-main);--dim: var(--app-text-dim);--b: var(--app-border);--bh: var(--app-border-hi);--border: var(--app-border);--border-hi: var(--app-border-hi)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Outfit,sans-serif;background:var(--bg);color:var(--white);min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:radial-gradient(1px 1px at 8% 14%,rgba(255,255,255,.5) 0%,transparent 100%),radial-gradient(1px 1px at 24% 38%,rgba(255,255,255,.3) 0%,transparent 100%),radial-gradient(1px 1px at 47% 8%,rgba(255,255,255,.4) 0%,transparent 100%),radial-gradient(1px 1px at 66% 55%,rgba(255,255,255,.25) 0%,transparent 100%),radial-gradient(1px 1px at 81% 21%,rgba(255,255,255,.4) 0%,transparent 100%),radial-gradient(2px 2px at 37% 82%,rgba(150,170,255,.35) 0%,transparent 100%),radial-gradient(200px 200px at 18% 22%,rgba(79,110,247,.05) 0%,transparent 70%),radial-gradient(240px 240px at 78% 58%,rgba(139,92,246,.04) 0%,transparent 70%)}.demo{position:relative;z-index:1;display:flex;justify-content:center;padding:24px 16px 80px}.panel{width:800px;background:var(--card);border:1px solid var(--bh);border-radius:18px;overflow:hidden;box-shadow:0 24px 80px #0009}.panel-head{padding:18px 22px 0;border-bottom:1px solid var(--b)}.sh-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}.av{width:44px;height:44px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--blue),var(--purple));display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;border:2px solid rgba(79,110,247,.4);box-shadow:0 0 16px #4f6ef74d}.s-name{font-size:17px;font-weight:800}.s-meta{font-size:11px;color:var(--dim);margin-top:3px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.s-family{font-size:11px;margin-top:4px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.sep{width:3px;height:3px;border-radius:50%;background:#6478ff4d;flex-shrink:0}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:5px;font-size:10.5px;font-weight:700}.badge-green{background:#10b9811a;color:var(--green);border:1px solid rgba(16,185,129,.22)}.badge-purple{background:#8b5cf61a;color:var(--purple);border:1px solid rgba(139,92,246,.22)}.badge-blue{background:#4f6ef71a;color:var(--blue);border:1px solid rgba(79,110,247,.2)}.badge-amber{background:#f59e0b1a;color:var(--amber);border:1px solid rgba(245,158,11,.22)}.badge-child1{background:#06b6d414;color:var(--cyan);border:1px solid rgba(6,182,212,.22)}.badge-child2{background:#ec489914;color:var(--pink);border:1px solid rgba(236,72,153,.22)}.tabs{display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{height:0}.tab{padding:9px 14px;font-size:12px;font-weight:500;color:var(--dim);cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:all .15s;margin-bottom:-1px}.tab:hover{color:var(--white)}.tab.active{color:var(--blue);border-bottom-color:var(--blue);font-weight:600}.panel-body{padding:18px 22px;max-height:88vh;overflow-y:auto}.panel-body::-webkit-scrollbar{width:4px}.panel-body::-webkit-scrollbar-thumb{background:#4f6ef733;border-radius:2px}.bal-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}.bc{padding:11px 14px;background:#ffffff06;border:1px solid var(--b);border-radius:11px}.bc-label{font-size:9.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--dim);margin-bottom:4px}.bc-val{font-family:Space Mono,monospace;font-size:16px;font-weight:700}.bc-sub{font-size:10px;color:var(--dim);margin-top:2px}.legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.li{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--dim)}.ld{width:8px;height:8px;border-radius:3px;flex-shrink:0}.prog{border:1px solid var(--b);border-radius:14px;margin-bottom:10px;overflow:hidden;transition:border-color .2s}.prog:hover{border-color:var(--bh)}.prog-head{display:flex;align-items:center;gap:11px;padding:12px 16px;cursor:pointer;transition:background .15s}.prog-head:hover{background:#ffffff05}.prog-bar{width:4px;border-radius:2px;align-self:stretch;min-height:32px;flex-shrink:0}.prog-info{flex:1;min-width:0}.prog-name{font-size:13px;font-weight:700}.prog-sub{font-size:10.5px;color:var(--dim);margin-top:2px}.prog-bal{text-align:right;flex-shrink:0}.prog-bal-val{font-family:Space Mono,monospace;font-size:14px;font-weight:700}.prog-bal-sub{font-size:10px;color:var(--dim);margin-top:1px}.prog-arrow{font-size:11px;color:var(--dim);transition:transform .2s;flex-shrink:0;margin-left:4px}.prog.open .prog-arrow{transform:rotate(90deg)}.prog-body{display:none;border-top:1px solid var(--b)}.prog.open .prog-body{display:block}.prog-inner{padding:12px 16px}.year-row{display:flex;align-items:center;gap:5px;margin-bottom:10px;flex-wrap:wrap}.yr-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);margin-right:2px}.yr-btn{padding:3px 10px;border-radius:6px;font-size:12px;font-weight:600;font-family:Space Mono,monospace;cursor:pointer;border:1px solid var(--b);background:transparent;color:var(--dim);transition:all .15s}.yr-btn.active{background:#4f6ef726;border-color:#4f6ef766;color:var(--blue)}.view-toggle{display:flex;gap:4px;margin-left:auto}.vt-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:7px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--b);background:transparent;color:var(--dim);transition:all .15s;font-family:Outfit,sans-serif}.vt-btn.active{background:#4f6ef71f;border-color:#4f6ef74d;color:var(--blue)}.month-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:5px;margin-bottom:10px}.mcell{aspect-ratio:1;border-radius:9px;border:1px solid var(--b);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;cursor:pointer;transition:all .18s;position:relative;background:#ffffff05;overflow:hidden}.mcell:hover{border-color:var(--bh);transform:translateY(-2px);box-shadow:0 4px 14px #0000004d;z-index:2}.mcell.sel{box-shadow:0 0 0 2px #4f6ef780}.mc-name{font-size:9.5px;font-weight:700;color:var(--dim);letter-spacing:.02em}.mc-icon{font-size:13px;line-height:1}.mc-amt{font-family:Space Mono,monospace;font-size:8px;font-weight:700;line-height:1}.mc-pay{font-size:8px;line-height:1;font-weight:700}.mc-sub{font-size:7px;color:#ffffff4d;line-height:1}.cbadge{position:absolute;top:-3px;right:-3px;width:13px;height:13px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:7px;font-weight:800;border:1.5px solid var(--bg);z-index:3}.ms-paid{border-color:#10b98147;background:#10b98112}.ms-paid .mc-name,.ms-paid .mc-amt{color:var(--green)}.ms-pending{border-color:#4f6ef738;background:#4f6ef70f}.ms-pending .mc-name,.ms-pending .mc-amt{color:var(--blue)}.ms-overdue{border-color:#ef44444d;background:#ef444412;animation:cpulse 2s ease-in-out infinite}.ms-overdue .mc-name,.ms-overdue .mc-amt{color:var(--red)}.ms-pause{border-color:#f59e0b40;background:#f59e0b0f}.ms-pause .mc-name{color:var(--amber)}.ms-summer{border-color:#fbbf2433;background:#fbbf240d}.ms-summer .mc-name{color:var(--gold)}.ms-partial{border-color:#06b6d44d;background:linear-gradient(135deg,#10b9811a 50%,#f59e0b1a 50%)}.ms-partial .mc-name,.ms-partial .mc-amt{color:var(--cyan)}.ms-extra-paid{border-color:#ec48994d;background:#ec489914;border-style:dashed}.ms-extra-paid .mc-name{color:var(--pink)}.ms-extra-pending{border-color:#4f6ef74d;background:#4f6ef70f;border-style:dashed}.ms-extra-pending .mc-name{color:var(--blue)}.ms-future{opacity:.28}.mcell-add{border-style:dashed;border-color:#ec489938;background:#ec489908;cursor:pointer}.mcell-add:hover{background:#ec48991a;border-color:#ec489980}@keyframes cpulse{0%,to{box-shadow:0 0 #ef444433}50%{box-shadow:0 0 8px #ef444466}}.month-detail{background:#4f6ef70d;border:1px solid rgba(79,110,247,.2);border-radius:11px;padding:12px;margin-bottom:10px;animation:fadeIn .18s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.md-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px;flex-wrap:wrap;gap:6px}.md-title{font-size:14px;font-weight:700}.md-rows{display:flex;flex-direction:column;gap:5px;margin-bottom:9px}.md-row{display:flex;align-items:center;gap:8px;padding:6px 9px;background:#ffffff06;border-radius:7px;font-size:12px}.md-lbl{color:var(--dim);flex:1}.md-val{font-family:Space Mono,monospace;font-size:12px;font-weight:700}.md-acts{display:flex;gap:6px;flex-wrap:wrap}.exp-table{width:100%;border-collapse:collapse;font-size:12px}.exp-table th{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);padding:6px 8px;text-align:left;border-bottom:1px solid var(--b);white-space:nowrap}.exp-table td{padding:6px 8px;border-bottom:1px solid rgba(100,120,255,.06);vertical-align:middle}.exp-table tr:hover td{background:#4f6ef708}.exp-table tr.row-extra-paid td,.exp-table tr.row-extra-pending td{background:#ec489908}.st{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:5px;font-size:10px;font-weight:700;white-space:nowrap}.st-paid{background:#10b9811a;color:var(--green);border:1px solid rgba(16,185,129,.22)}.st-pending{background:#4f6ef71a;color:var(--blue);border:1px solid rgba(79,110,247,.2)}.st-overdue{background:#ef44441a;color:var(--red);border:1px solid rgba(239,68,68,.22)}.st-pause{background:#f59e0b1a;color:var(--amber);border:1px solid rgba(245,158,11,.22)}.st-summer{background:#fbbf2414;color:var(--gold);border:1px solid rgba(251,191,36,.2)}.st-partial{background:#06b6d41a;color:var(--cyan);border:1px solid rgba(6,182,212,.22)}.st-extra-paid{background:#ec48991a;color:var(--pink);border:1px solid rgba(236,72,153,.22)}.st-extra-pending{background:#4f6ef71a;color:var(--blue);border:1px dashed rgba(79,110,247,.3)}.st-future{background:#ffffff0a;color:var(--dim);border:1px solid var(--b)}.dc{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:600}.dc-family{background:#10b9811a;color:var(--green)}.dc-referral{background:#8b5cf61a;color:var(--purple)}.dc-loyalty{background:#4f6ef71a;color:var(--blue)}.dc-complaint{background:#ef444414;color:var(--red)}.dc-promo{background:#f59e0b1a;color:var(--amber)}.kb{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:5px;font-size:10px;font-weight:700;white-space:nowrap}.kb-ok{background:#10b9811a;color:var(--green);border:1px solid rgba(16,185,129,.2)}.kb-pending{background:#f59e0b1a;color:var(--amber);border:1px solid rgba(245,158,11,.2);animation:pamber 2s ease-in-out infinite}.kb-manual{background:#8b5cf61a;color:var(--purple);border:1px solid rgba(139,92,246,.2)}.kb-error{background:#ef444414;color:var(--red);border:1px solid rgba(239,68,68,.2)}.kb-conflict{background:#f9731614;color:var(--orange);border:1px solid rgba(249,115,22,.2)}.kb-replaced{background:#6464641a;color:var(--dim);border:1px solid rgba(100,100,100,.2);text-decoration:line-through}@keyframes pamber{0%,to{box-shadow:0 0 3px #f59e0b4d}50%{box-shadow:0 0 8px #f59e0b80}}.action-section{border-top:1px solid var(--b);padding:10px 16px;background:#ffffff03}.action-label{font-size:9.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--dim);margin-bottom:7px}.action-row{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:5px}.action-hint{font-size:10.5px;color:var(--dim);margin-top:5px;padding-top:5px;border-top:1px solid var(--b)}.action-divider{width:1px;height:26px;background:var(--b);flex-shrink:0;align-self:center}.tx-section{border-top:1px solid var(--b)}.tx-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;cursor:pointer;transition:background .15s}.tx-toggle:hover{background:#ffffff05}.tx-toggle-left{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600}.tx-cnt{font-size:11px;color:var(--dim)}.tx-arrow{font-size:11px;color:var(--dim);transition:transform .2s}.tx-section.open .tx-arrow{transform:rotate(90deg)}.tx-body{display:none;padding:0 16px 12px}.tx-section.open .tx-body{display:block}.tx-info-bar{display:flex;align-items:flex-start;gap:9px;padding:8px 12px;background:#4f6ef70f;border:1px solid rgba(79,110,247,.15);border-radius:8px;margin-bottom:8px;font-size:11px}.tx-row{display:flex;align-items:center;gap:7px;padding:8px 10px;background:#ffffff06;border:1px solid var(--b);border-radius:9px;margin-bottom:4px;transition:all .15s}.tx-row:hover{border-color:var(--bh)}.tx-date{font-family:Space Mono,monospace;font-size:10px;color:var(--dim);white-space:nowrap;width:58px;flex-shrink:0}.tx-desc{flex:1;min-width:0}.tx-title{font-size:12px;font-weight:600}.tx-sub{font-size:10px;color:var(--dim);margin-top:1px}.tx-amt{font-family:Space Mono,monospace;font-size:13px;font-weight:700;white-space:nowrap;flex-shrink:0}.tx-btns{display:flex;gap:3px;flex-shrink:0}.tx-btn{width:26px;height:26px;border-radius:6px;background:#ffffff0a;border:1px solid var(--b);display:flex;align-items:center;justify-content:center;font-size:11px;cursor:pointer;transition:all .15s}.tx-btn:hover{background:#4f6ef726;border-color:#4f6ef74d}.tx-conflict-wrap{background:#f973160a;border:1px solid rgba(249,115,22,.3);border-radius:10px;margin-bottom:4px;overflow:hidden}.tx-conflict-bar{background:#f973161a;padding:6px 12px;font-size:11px;font-weight:700;color:var(--orange);display:flex;align-items:center;gap:6px}.ksef-algo{border:1px solid var(--b);border-radius:10px;padding:10px 12px;margin-bottom:8px;font-size:11px}.ksef-algo-title{font-weight:700;color:var(--dim);font-size:10px;letter-spacing:.07em;text-transform:uppercase;margin-bottom:7px}.ksef-case{display:flex;align-items:flex-start;gap:8px;margin-bottom:5px;padding:5px 8px;border-radius:7px}.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 11px;border-radius:8px;font-size:12px;font-weight:500;font-family:Outfit,sans-serif;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--blue),var(--purple));color:#fff;box-shadow:0 0 12px #4f6ef74d}.btn-primary:hover{box-shadow:0 0 20px #4f6ef780;transform:translateY(-1px)}.btn-ghost{background:var(--app-surface);color:var(--app-text-dim);border:1px solid var(--app-border);transition:all .2s}.btn-ghost:hover{background:var(--status-info-bg);color:var(--app-text-main);border-color:var(--app-border-hi)}.btn-amber{background:var(--status-warning-bg);color:var(--status-warning);border:1px solid rgba(245,158,11,.28)}.btn-amber:hover{background:#f59e0b33}.btn-cyan{background:#06b6d41a;color:var(--cyan);border:1px solid rgba(6,182,212,.28)}.btn-red{background:var(--status-danger-bg);color:var(--status-danger);border:1px solid rgba(239,68,68,.28)}.btn-green{background:var(--status-success-bg);color:var(--status-success);border:1px solid rgba(16,185,129,.28)}.btn-pink{background:#ec48991a;color:var(--pink);border:1px solid rgba(236,72,153,.28)}.btn-pink:hover{background:#ec48992e}.btn-archive{background:#6478ff0f;color:var(--dim);border:1px solid rgba(100,120,255,.15)}.btn-unlock{background:#06b6d414;color:var(--cyan);border:1px solid rgba(6,182,212,.22)}.btn-sm{padding:4px 9px;font-size:11px}.popup-bd{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}.popup-bd.active{opacity:1;pointer-events:all}.popup{background:var(--app-card);border:1px solid var(--bh);border-radius:16px;width:500px;padding:22px;box-shadow:0 24px 60px #000000b3;transform:scale(.95) translateY(10px);transition:transform .2s;max-height:92vh;overflow-y:auto}.popup-bd.active .popup{transform:scale(1) translateY(0)}.popup-title{font-size:15px;font-weight:800;margin-bottom:4px}.popup-sub{font-size:11.5px;color:var(--dim);margin-bottom:14px;line-height:1.5}.popup-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);margin-bottom:5px;display:block}.popup-input{width:100%;background:#ffffff0a;border:1px solid var(--b);border-radius:8px;padding:8px 12px;color:var(--white);font-family:Outfit,sans-serif;font-size:13px;outline:none;transition:border-color .2s;margin-bottom:12px}.popup-input:focus{border-color:var(--blue)}.popup-2col{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.popup-actions{display:flex;gap:8px;margin-top:4px}.popup-actions .btn{flex:1;justify-content:center;padding:10px}.calc-preview{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:12px}.cp{background:#ffffff08;border:1px solid var(--b);border-radius:9px;padding:10px;text-align:center}.cp-label{font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);margin-bottom:5px}.cp-val{font-family:Space Mono,monospace;font-size:15px;font-weight:700}.info-box{border-radius:8px;padding:9px 12px;font-size:11.5px;margin-bottom:12px;display:flex;align-items:flex-start;gap:8px;line-height:1.5}.info-blue{background:#4f6ef712;border:1px solid rgba(79,110,247,.2);color:var(--dim)}.info-amber{background:#f59e0b12;border:1px solid rgba(245,158,11,.22);color:var(--amber)}.info-green{background:#10b98112;border:1px solid rgba(16,185,129,.22);color:var(--green)}.info-red{background:#ef444412;border:1px solid rgba(239,68,68,.2);color:var(--red)}.reason-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:12px}.reason-opt{display:flex;align-items:flex-start;gap:8px;padding:9px 11px;background:#ffffff08;border:1px solid var(--b);border-radius:9px;cursor:pointer;font-size:12px;transition:all .15s}.reason-opt:hover{border-color:var(--bh)}.reason-opt.active{border-color:#4f6ef780;background:#4f6ef71a}.month-selector{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin-bottom:12px}.ms-btn{padding:5px 3px;border-radius:7px;font-size:11px;font-weight:600;text-align:center;cursor:pointer;border:1px solid var(--b);background:transparent;color:var(--dim);transition:all .15s;font-family:Outfit,sans-serif}.ms-btn:hover:not(.disabled){border-color:var(--bh);color:var(--white)}.ms-btn.active{background:#4f6ef726;border-color:#4f6ef766;color:var(--blue)}.ms-btn.disabled{opacity:.3;cursor:not-allowed}.pause-calc{background:#ffffff05;border:1px solid var(--b);border-radius:10px;padding:11px;margin-bottom:12px}.pause-calc-title{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--dim);margin-bottom:9px}.pause-month-row{display:flex;align-items:center;gap:8px;margin-bottom:5px;font-size:12px}.pmr-name{width:75px;font-weight:600;flex-shrink:0}.pmr-bar{flex:1;height:5px;border-radius:3px;background:#ffffff0f;overflow:hidden}.pmr-fill{height:100%;border-radius:3px}.pmr-amt{font-family:Space Mono,monospace;font-size:11px;font-weight:700;width:60px;text-align:right;flex-shrink:0}.pmr-note{font-size:10px;color:var(--dim);flex:1}.split-row{background:#ffffff06;border:1px solid var(--b);border-radius:10px;padding:10px 12px;transition:border-color .15s}.split-row:nth-child(1){border-color:#4f6ef74d;background:#4f6ef70a}.split-row:nth-child(2){border-color:#06b6d44d;background:#06b6d40a}.split-row:nth-child(3){border-color:#8b5cf64d;background:#8b5cf60a}.split-row:nth-child(4){border-color:#f59e0b4d;background:#f59e0b0a}.split-row:nth-child(5){border-color:#10b9814d;background:#10b9810a}.approval-block{background:#f59e0b0f;border:1px solid rgba(245,158,11,.22);border-radius:9px;padding:10px 12px;margin-bottom:12px}.approval-title{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--amber);margin-bottom:7px;display:flex;align-items:center;gap:5px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:#4f6ef733;border-radius:2px}a{color:inherit;text-decoration:none}button:disabled{opacity:.35;cursor:not-allowed}.leg-title{font-size:12px;color:#ffffffbf;margin-right:6px;align-self:center}.leg-items{display:flex;flex-wrap:wrap;gap:8px}.leg-item{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;font-size:12px;color:#ffffffe6}.leg-dot{width:9px;height:9px;border-radius:50%}.dot-paid{background:#10b981f2}.dot-pending{background:#22d3eef2}.dot-overdue{background:#ef4444f2}.dot-pause{background:#f59e0bf2}.dot-summer{background:#6366f1f2}.dot-extra{background:#a78bfaf2}.month-table-wrap{margin-top:10px;border:1px solid rgba(255,255,255,.1);border-radius:14px;overflow:hidden;background:#0000001a}.month-table{width:100%;border-collapse:collapse;font-size:12px}.month-table th{text-align:left;padding:10px 12px;color:#ffffffb3;background:#0000002e;border-bottom:1px solid rgba(255,255,255,.1)}.month-table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08)}.month-table tr:hover{background:#ffffff0a;cursor:pointer}.month-table tr.selrow{outline:2px solid rgba(59,130,246,.35);outline-offset:-2px;background:#3b82f614}.month-table .mt-month{font-weight:700;letter-spacing:.02em}.extras-sec{margin-top:10px;border:1px solid var(--b);border-radius:12px;overflow:hidden;background:#ffffff05}.extras-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;cursor:pointer;transition:background .15s}.extras-toggle:hover{background:#ffffff08}.extras-title{font-size:12px;font-weight:700}.extras-right{display:flex;align-items:center;gap:8px;color:var(--dim);font-size:11px}.extras-arr{transition:transform .2s}.extras-sec.open .extras-arr{transform:rotate(90deg)}.extras-body{display:none;padding:10px 12px 12px}.extras-sec.open .extras-body{display:block}.extras-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--b);border-radius:10px;background:#ffffff05;margin-bottom:6px}.extras-btns{display:flex;gap:6px;flex-shrink:0}.tx-item{margin-bottom:4px}.tx-detail{margin-top:6px;margin-bottom:10px;padding:8px 10px;border:1px dashed rgba(255,255,255,.16);border-radius:10px;background:#ffffff04}.tx-detail-row{display:flex;gap:6px;flex-wrap:wrap}.ksef-wrap{margin-top:10px;padding-top:10px;border-top:1px solid var(--b)}.ksef-title{font-size:11px;font-weight:700;color:var(--dim);margin-bottom:6px}.ksef-row{display:flex;align-items:center;gap:8px;padding:7px 9px;border:1px solid var(--b);border-radius:9px;background:#ffffff05;margin-bottom:4px}.ksef-fv{font-family:Space Mono,monospace;font-size:10px;color:var(--white);width:120px;flex-shrink:0}.ksef-desc{flex:1;font-size:11px;color:var(--dim);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ksef-st{font-size:10px;font-weight:700;padding:2px 6px;border-radius:999px;border:1px solid var(--b);color:var(--dim)}.ksef-ok{color:var(--green);border-color:#10b98140;background:#10b9810f}.ksef-pending{color:var(--amber);border-color:#f59e0b40;background:#f59e0b0f}.sec-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);display:flex;align-items:center;gap:8px;margin-bottom:10px;margin-top:4px}.sec-title:after{content:"";flex:1;height:1px;background:var(--border)}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.info-field{background:#ffffff06;border:1px solid var(--border);border-radius:10px;padding:10px 13px;transition:border-color .15s}.info-field:hover{border-color:var(--border-hi)}.if-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);margin-bottom:4px}.if-val{font-size:13px;font-weight:500}.if-val-mono{font-family:Space Mono,monospace;font-size:12.5px}.prog-block{border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:12px;transition:border-color .2s}.prog-block-toggle{display:flex;align-items:center;gap:11px;padding:12px 16px;cursor:pointer;background:#ffffff05;transition:background .15s;-webkit-user-select:none;user-select:none}.prog-block-toggle:hover{background:#ffffff0a}.prog-icon{width:34px;height:34px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:900}.prog-icon-sm{background:linear-gradient(135deg,var(--blue),var(--purple));box-shadow:0 0 10px #4f6ef74d}.prog-icon-ind{background:linear-gradient(135deg,#06b6d4,#8b5cf6);box-shadow:0 0 10px #06b6d440}.prog-title-wrap{flex:1}.prog-title{font-size:13px;font-weight:700}.prog-subtitle{font-size:11px;color:var(--dim);margin-top:2px}.prog-chevron{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;border:1px solid var(--border);background:#ffffff0a;font-size:11px;font-weight:600;color:var(--dim);transition:all .2s;white-space:nowrap;flex-shrink:0}.prog-body{display:none;border-top:1px solid var(--border)}.prog-body.open{display:block}.cg-card{padding:14px 16px 12px;background:#ffffff05}.cg-head{display:flex;align-items:flex-start;gap:10px;margin-bottom:11px}.cg-badge{width:38px;height:38px;border-radius:9px;flex-shrink:0;background:linear-gradient(135deg,var(--blue),var(--purple));display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:900;box-shadow:0 0 10px #4f6ef747}.cg-badge-ind{background:linear-gradient(135deg,#06b6d4,#8b5cf6)}.cg-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cg-name{font-size:13px;font-weight:800}.cg-meta{font-size:11px;color:var(--dim);margin-top:5px;display:flex;flex-wrap:wrap;gap:8px 10px}.cg-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}.cg-stat{padding:8px 10px;border-radius:12px;border:1px solid rgba(100,120,255,.1);background:#ffffff05}.cg-stat-val{font-family:Space Mono,monospace;font-size:14px;font-weight:800}.cg-stat-label{margin-top:3px;font-size:10px;color:var(--dim);letter-spacing:.03em}@media(max-width:720px){.cg-stats{grid-template-columns:repeat(2,1fr)}}.att-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}.att-stat{padding:10px 12px;border-radius:12px;border:1px solid rgba(100,120,255,.1);background:#ffffff05}.att-stat-val{font-family:Space Mono,monospace;font-size:16px;font-weight:900}.att-stat-label{margin-top:4px;font-size:10.5px;color:var(--dim)}.att-bar{height:10px;border-radius:999px;background:#ffffff0a;border:1px solid rgba(100,120,255,.1);overflow:hidden}.att-bar-fill{height:100%;border-radius:999px}.att-table{width:100%;border-collapse:separate;border-spacing:0 8px}.att-table th{font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.08em;font-weight:800;text-align:left;padding:0 10px 6px}.att-table td{padding:10px;border:1px solid rgba(100,120,255,.1);background:#ffffff05;font-size:12px;vertical-align:middle}.att-table tbody tr td:first-child{border-radius:12px 0 0 12px}.att-table tbody tr td:last-child{border-radius:0 12px 12px 0}.att-mark{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:9px;font-size:12px;font-weight:900;border:1px solid rgba(100,120,255,.15);background:#ffffff08;cursor:pointer;-webkit-user-select:none;user-select:none}.mark-present{background:#10b9811f;border-color:#10b98140;color:var(--green)}.mark-absent{background:#ef44441a;border-color:#ef444438;color:var(--red)}.mark-late{background:#f59e0b1a;border-color:#f59e0b40;color:var(--amber)}.mark-makeup{background:#06b6d41a;border-color:#06b6d440;color:var(--cyan)}.mark-empty{background:#ffffff08;border-color:#6478ff1f;color:var(--dim)}select{background-color:#ffffff0a;color:#8892b0;color-scheme:dark}select:focus{background-color:#ffffff0a;color:#8892b0}select option,select optgroup{background-color:#1e2140;color:#8892b0;margin:0;border:0;border-radius:0;box-shadow:none}select option:checked,select option:hover{background-color:#252a4d;color:#e8eeff}.dropdown-filter-btn[data-v-bdf021cc]{padding:6px 12px;border-radius:8px;font-size:12.5px;font-weight:500;cursor:pointer;border:1px solid rgba(100,120,255,.15);background:#ffffff0a;color:#8892b0;transition:all .15s}@supports (-moz-appearance: none){select.dropdown-filter-btn{-moz-appearance:none;-webkit-appearance:none;appearance:none;background-color:#ffffff0a;color:#8892b0}select.dropdown-filter-btn option{background-color:#1c1f3a;color:#8892b0}}.sidebar{position:fixed;left:0;top:0;bottom:0;width:240px;background:#070720f7;border-right:1px solid var(--border);z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.sidebar-logo{padding:20px 16px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.logo-badge{display:flex;align-items:center;gap:10px}.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--blue),var(--purple));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 0 20px #4f6ef766;flex-shrink:0}.logo-text{font-size:15px;font-weight:800;color:var(--white);letter-spacing:.01em}.logo-sub{font-size:9.5px;color:var(--dim);font-family:Space Mono,monospace;letter-spacing:.12em;text-transform:uppercase;margin-top:1px}.school-pill-link{display:block;margin-top:10px;text-decoration:none;transition:all .24s cubic-bezier(.4,0,.2,1)}.school-pill{display:flex;align-items:center;gap:9px;padding:8px 12px;background:#4f6ef70d;border:1px solid rgba(79,110,247,.15);border-radius:10px;transition:all .2s;cursor:pointer}.school-pill-link:hover .school-pill{background:#4f6ef71f;border-color:#4f6ef759;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.school-pill-link.active .school-pill{background:linear-gradient(135deg,#4f6ef726,#8b5cf61f);border-color:#4f6ef780;box-shadow:0 0 15px #4f6ef733}.school-pill-link.active .school-name{color:var(--blue)}.school-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);animation:pulse-green 2s ease-in-out infinite;flex-shrink:0}@keyframes pulse-green{0%,to{box-shadow:0 0 5px var(--green)}50%{box-shadow:0 0 11px var(--green)}}.school-name{font-size:11.5px;font-weight:600}.school-city{font-size:10px;color:var(--dim)}.sidebar-nav{padding:10px;flex:1;overflow-y:auto}.nav-section{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:9px;cursor:pointer;margin-top:3px;margin-bottom:1px;transition:all .18s;position:relative;-webkit-user-select:none;user-select:none}.nav-section:hover{background:#4f6ef712}.nav-section.open{background:#4f6ef71a}.nav-section-icon{font-size:14px;width:18px;text-align:center;flex-shrink:0}.nav-section-label{font-size:12.5px;font-weight:700;color:var(--white);flex:1}.nav-section-arrow{font-size:10px;color:var(--dim);transition:transform .2s;flex-shrink:0}.nav-section.open .nav-section-arrow{transform:rotate(90deg)}.nav-section-badge{font-size:9.5px;font-weight:700;font-family:Space Mono,monospace;padding:1px 5px;border-radius:8px;min-width:16px;text-align:center}.nb-red{background:var(--red);color:#fff;box-shadow:0 0 7px #ef444480;animation:pulse-badge 2s ease-in-out infinite}.nb-amber{background:var(--amber);color:#fff}.nb-cyan{background:var(--cyan);color:#fff;box-shadow:0 0 7px #06b6d466;animation:pulse-cyan-badge 2s ease-in-out infinite}.nb-blue{background:var(--blue);color:#fff}.nb-green{background:var(--green);color:#fff}@keyframes pulse-badge{0%,to{box-shadow:0 0 7px #ef444466}50%{box-shadow:0 0 14px #ef4444b3}}@keyframes pulse-cyan-badge{0%,to{box-shadow:0 0 6px #06b6d459}50%{box-shadow:0 0 13px #06b6d4a6}}.nav-children{overflow:hidden;transition:max-height .28s cubic-bezier(.4,0,.2,1);padding-left:12px}.nav-children.open{max-height:500px}.nav-item{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:7px;cursor:pointer;transition:all .15s;color:var(--dim);font-size:12.5px;font-weight:400;text-decoration:none;margin-bottom:1px;position:relative}.nav-item:hover{background:#4f6ef717;color:var(--white)}.nav-item.active{background:linear-gradient(90deg,#4f6ef733,#8b5cf61a);color:var(--white);border:1px solid rgba(79,110,247,.28)}.nav-item.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;background:linear-gradient(180deg,var(--blue),var(--purple));border-radius:2px}.nav-icon{font-size:13px;width:16px;text-align:center;flex-shrink:0}.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9.5px;font-weight:700;font-family:Space Mono,monospace;padding:1px 5px;border-radius:8px;box-shadow:0 0 7px #ef444466;animation:pulse-badge 2s ease-in-out infinite}.nav-badge.cyan{background:var(--cyan);box-shadow:0 0 7px #06b6d466;animation:pulse-cyan-badge 2s ease-in-out infinite}.nav-badge.amber{background:var(--amber)}.nav-badge.blue{background:var(--blue)}.nav-badge.green{background:var(--green)}.nav-standalone{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:9px;cursor:pointer;transition:all .15s;color:var(--dim);font-size:12.5px;font-weight:500;margin-bottom:2px;position:relative}.nav-standalone:hover{background:#4f6ef717;color:var(--white)}.nav-standalone.active{background:linear-gradient(90deg,#4f6ef733,#8b5cf61a);color:var(--white);border:1px solid rgba(79,110,247,.28)}.sidebar-bottom{padding:14px 10px;border-top:1px solid var(--border);flex-shrink:0}.user-card{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:8px;cursor:pointer;transition:background .15s}.user-card:hover{background:#ffffff0a}.user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#ef4444);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:10px;color:var(--dim)}.main{margin-left:240px;min-height:100vh;position:relative;z-index:1}.topbar{position:sticky;top:0;background:var(--app-topbar);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--app-border);padding:0 28px;height:58px;display:flex;align-items:center;justify-content:space-between;z-index:50;transition:all .3s ease}.topbar-title{font-size:18px;font-weight:600;color:var(--app-text-main);display:flex;align-items:center;gap:10px}.topbar-title span{color:var(--dim);font-weight:400;font-size:14px}.topbar-actions{display:flex;align-items:center;gap:10px}.search-box{display:flex;align-items:center;gap:10px;background:var(--app-surface);border:1px solid var(--app-border);padding:7px 14px;border-radius:10px;transition:all .2s ease}.search-box:focus-within{border-color:var(--blue);background:var(--app-card);box-shadow:0 0 12px #4f6ef726}.search-box input{background:transparent;border:none;outline:none;color:var(--app-text-main);font-family:Outfit,sans-serif;font-size:13px;width:200px}.search-box input::placeholder{color:var(--dim)}.theme-toggle-btn{display:inline-flex;align-items:center;gap:7px;padding:6px 14px;border-radius:20px;cursor:pointer;font-size:12.5px;font-weight:600;font-family:Outfit,sans-serif;border:1px solid var(--app-border);background:var(--app-surface);color:var(--app-text-dim);transition:all .25s;-webkit-user-select:none;user-select:none;white-space:nowrap}.theme-toggle-btn:hover{background:var(--status-info-bg);color:var(--app-text-main);border-color:var(--app-border-hi)}.content{padding:24px 28px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;position:relative;overflow:hidden;transition:all .3s;cursor:default}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;border-radius:14px 14px 0 0}.stat-card.blue:before{background:linear-gradient(90deg,var(--blue),var(--purple))}.stat-card.green:before{background:linear-gradient(90deg,var(--green),var(--cyan))}.stat-card.amber:before{background:linear-gradient(90deg,var(--amber),#f97316)}.stat-card.cyan:before{background:linear-gradient(90deg,var(--cyan),var(--blue))}.stat-card.red:before{background:linear-gradient(90deg,var(--red),#f87171)}.stat-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-bottom:10px}.stat-value{font-size:26px;font-weight:700;font-family:Space Mono,monospace;color:var(--white);line-height:1;margin-bottom:6px}.stat-sub{font-size:11.5px;color:var(--dim)}.stat-sub .up{color:var(--green)}.stat-sub .warn{color:var(--amber)}.stat-icon{position:absolute;top:16px;right:16px;font-size:22px;opacity:.4}.table-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:16px;flex-wrap:wrap}.toolbar-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.section-title{font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px}.section-count{font-size:11px;font-family:Space Mono,monospace;background:#4f6ef726;color:var(--blue);border:1px solid rgba(79,110,247,.3);padding:2px 8px;border-radius:8px}.table-container{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:1200px}thead tr{background:#ffffff08;border-bottom:1px solid var(--border)}th{padding:11px 14px;text-align:left;font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--dim)}tbody tr{border-bottom:1px solid rgba(100,120,255,.07);transition:all .15s}tbody tr:hover{background:#4f6ef70f}td{padding:12px 14px;font-size:13.5px;vertical-align:middle;white-space:nowrap}.name-cell a.student-name{font-weight:600;font-size:13.5px;color:var(--blue);text-decoration:none}.student-meta{font-size:11px;color:var(--dim);margin-top:1px;font-family:Space Mono,monospace}.date-mono{font-family:Space Mono,monospace;font-size:12.5px;color:var(--white)}.timer-cell{display:flex;flex-direction:column;align-items:flex-start;gap:1px}.timer-days{font-family:Space Mono,monospace;font-size:15px;font-weight:700}.timer-label{font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.06em}.sp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#04040f8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;opacity:0;pointer-events:none;transition:opacity .3s}.sp-overlay.active{opacity:1;pointer-events:all}:root:not(.dark) .sp-overlay{background:#a0aadc80}.student-panel{position:fixed;top:0;right:0;bottom:0;width:860px;max-width:100vw;background:var(--app-sidebar);border-left:1px solid var(--border-hi);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);z-index:400;display:flex;flex-direction:column;transform:translate(100%);transition:transform .38s cubic-bezier(.4,0,.2,1)}.student-panel.open{transform:translate(0)}.sp-body{flex:1;overflow-y:auto;padding:20px 24px}.sp-body::-webkit-scrollbar{width:4px}.sp-body::-webkit-scrollbar-thumb{background:#4f6ef74d;border-radius:2px}.panel-head{padding:22px 24px 0;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--app-surface)}.sh-row{margin-bottom:12px}@media(max-width:1024px){.sidebar{transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:20px 0 50px #0000004d}.sidebar.open{transform:translate(0)}.main{margin-left:0!important}.topbar{padding:0 16px}.content{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr)}.student-panel{width:100vw}}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.topbar-title span{display:none}.search-box input{width:120px}.table-toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right{justify-content:space-between}}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:95;opacity:0;pointer-events:none;transition:opacity .3s ease}.mobile-overlay.active{opacity:1;pointer-events:all}
