@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#6366f1;--primary-dark:#4f46e5;--primary-light:#eef2ff;--secondary:#8b5cf6;--accent:#06b6d4;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--sidebar-bg:#0f172a;--sidebar-width:260px;--sidebar-collapsed:72px;--surface:#fff;--surface-2:#f8fafc;--surface-3:#f1f5f9;--border:#e2e8f0;--text-1:#0f172a;--text-2:#475569;--text-3:#94a3b8;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 16px #0000001a;--shadow-lg:0 8px 32px #0000001f;--radius:12px;--radius-lg:16px;--transition:.2s ease}body{background:var(--surface-2);color:var(--text-1);min-height:100vh;font-family:Inter,sans-serif}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);z-index:100;flex-direction:column;transition:width .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar-collapsed{width:var(--sidebar-collapsed)}.sidebar-header{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:20px 16px;display:flex}.school-logo{align-items:center;gap:12px;display:flex}.logo-icon{flex-shrink:0;width:48px;height:48px}.logo-img{object-fit:contain;filter:drop-shadow(0 2px 4px #0000004d);width:100%;height:100%}.school-info{flex-direction:column;display:flex;overflow:hidden}.school-name{color:#fff;white-space:nowrap;letter-spacing:-.3px;font-size:14px;font-weight:700}.school-sub{color:#64748b;white-space:nowrap;font-size:11px}.collapse-btn{cursor:pointer;color:#94a3b8;width:28px;height:28px;transition:all var(--transition);background:#ffffff0f;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.collapse-btn:hover{color:#fff;background:#ffffff1f}.collapse-btn svg{width:14px;height:14px}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-section-label{color:#475569;letter-spacing:.8px;text-transform:uppercase;padding:10px 8px 6px;font-size:10px;font-weight:600}.nav-item{color:#94a3b8;transition:all var(--transition);cursor:pointer;border-radius:10px;align-items:center;gap:12px;margin-bottom:2px;padding:10px;text-decoration:none;display:flex;position:relative}.nav-item:hover:not(.nav-item-disabled){color:#a5b4fc;background:#6366f126}.nav-item-active{border:1px solid #6366f14d;color:#a5b4fc!important;background:linear-gradient(135deg,#6366f140,#8b5cf626)!important}.nav-item-disabled{opacity:.45;cursor:not-allowed}.nav-icon{background:#ffffff0d;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.nav-item-active .nav-icon{background:#6366f14d}.nav-icon svg{width:16px;height:16px}.nav-label{white-space:nowrap;flex:1;font-size:13px;font-weight:500}.nav-badge{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;white-space:nowrap;border-radius:20px;padding:2px 8px;font-size:10px;font-weight:600}.nav-soon{color:#475569;white-space:nowrap;background:#ffffff0d;border-radius:4px;padding:2px 6px;font-size:10px}.sidebar-footer{border-top:1px solid #ffffff0f;padding:16px}.user-card{background:#ffffff0a;border-radius:10px;align-items:center;gap:10px;padding:10px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.user-info{flex-direction:column;flex:1;min-width:0;display:flex}.user-name{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;display:block;overflow:hidden}.user-role{color:#64748b;white-space:nowrap;text-overflow:ellipsis;font-size:11px;display:block;overflow:hidden}.logout-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:6px;transition:all .2s;display:flex}.logout-btn:hover{color:#ef4444;background:#ef44441a}.logout-btn svg{width:16px;height:16px}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.app-shell.no-sidebar .main-content{width:100%;margin-left:0}.page-fade-enter-active,.page-fade-leave-active{transition:opacity .2s,transform .2s}.page-fade-enter-from{opacity:0;transform:translateY(8px)}.page-fade-leave-to{opacity:0;transform:translateY(-4px)}::-webkit-scrollbar{width:0!important;height:0!important;display:none!important}.sidebar-nav::-webkit-scrollbar{width:0!important;height:0!important;display:none!important}.main-content::-webkit-scrollbar{width:0!important;height:0!important;display:none!important}body::-webkit-scrollbar{width:0!important;height:0!important;display:none!important}html::-webkit-scrollbar{width:0!important;height:0!important;display:none!important}*{scrollbar-width:none!important;-ms-overflow-style:none!important}.page-container[data-v-dfc522c5]{max-width:1400px;margin:0 auto;padding:32px 40px;animation:.4s ease-out fade-in-dfc522c5}@keyframes fade-in-dfc522c5{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header[data-v-dfc522c5]{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.header-content h1[data-v-dfc522c5]{color:var(--text-1);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.subtitle[data-v-dfc522c5]{color:var(--text-2);font-size:15px}.bulan-badge[data-v-dfc522c5]{background:var(--primary-light);color:var(--primary);border-radius:20px;padding:6px 14px;font-size:13px;font-weight:600}.stats-grid[data-v-dfc522c5]{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px;display:grid}.stat-card[data-v-dfc522c5]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);cursor:default;justify-content:space-between;align-items:center;padding:22px 24px;transition:all .25s;display:flex}.stat-card[data-v-dfc522c5]:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.stat-left[data-v-dfc522c5]{flex-direction:column;gap:4px;display:flex}.stat-label[data-v-dfc522c5]{color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.stat-value[data-v-dfc522c5]{color:var(--text-1);letter-spacing:-.5px;font-size:26px;font-weight:800;line-height:1.1}.stat-sub[data-v-dfc522c5]{color:var(--text-3);margin-top:2px;font-size:11px}.stat-icon[data-v-dfc522c5]{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.stat-icon svg[data-v-dfc522c5]{width:26px;height:26px}.icon-blue[data-v-dfc522c5]{color:#3b82f6;background:#eff6ff}.icon-green[data-v-dfc522c5]{color:#10b981;background:#ecfdf5}.icon-purple[data-v-dfc522c5]{color:#8b5cf6;background:#f5f3ff}.icon-orange[data-v-dfc522c5]{color:#f59e0b;background:#fff7ed}.mid-grid[data-v-dfc522c5]{grid-template-columns:1fr 320px;gap:20px;margin-bottom:24px;display:grid}.chart-card[data-v-dfc522c5],.donut-card[data-v-dfc522c5],.recent-card[data-v-dfc522c5]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.card-header[data-v-dfc522c5]{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.card-header h3[data-v-dfc522c5]{color:var(--text-1);font-size:15px;font-weight:700}.card-sub[data-v-dfc522c5]{color:var(--text-3);font-size:12px;font-weight:500}.link-all[data-v-dfc522c5]{color:var(--primary);font-size:13px;font-weight:600;text-decoration:none}.link-all[data-v-dfc522c5]:hover{text-decoration:underline}.bar-chart[data-v-dfc522c5]{justify-content:space-between;align-items:flex-end;gap:8px;height:160px;display:flex}.bar-item[data-v-dfc522c5]{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:4px;height:100%;display:flex}.bar-value[data-v-dfc522c5]{color:var(--text-3);white-space:nowrap;font-size:9px;font-weight:600}.bar-wrap[data-v-dfc522c5]{background:var(--surface-3);border-radius:6px 6px 0 0;align-items:flex-end;width:100%;height:130px;display:flex;overflow:hidden}.bar-fill[data-v-dfc522c5]{background:linear-gradient(#6366f1,#8b5cf6);border-radius:6px 6px 0 0;width:100%;transition:height .6s cubic-bezier(.4,0,.2,1)}.bar-label[data-v-dfc522c5]{color:var(--text-3);font-size:11px;font-weight:500}.chart-empty[data-v-dfc522c5]{height:160px;color:var(--text-3);justify-content:center;align-items:center;font-size:14px;display:flex}.donut-wrapper[data-v-dfc522c5]{width:160px;margin:0 auto 20px;position:relative}.donut-svg[data-v-dfc522c5]{width:100%;height:auto}.donut-center[data-v-dfc522c5]{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-pct[data-v-dfc522c5]{color:var(--text-1);font-size:26px;font-weight:800;line-height:1}.donut-lbl[data-v-dfc522c5]{color:var(--text-3);font-size:11px;font-weight:600}.donut-legend[data-v-dfc522c5]{flex-direction:column;gap:10px;display:flex}.legend-item[data-v-dfc522c5]{color:var(--text-2);align-items:center;gap:8px;font-size:13px;display:flex}.legend-item strong[data-v-dfc522c5]{color:var(--text-1);margin-left:auto}.legend-dot[data-v-dfc522c5]{border-radius:50%;flex-shrink:0;width:10px;height:10px}.legend-dot.green[data-v-dfc522c5]{background:#10b981}.legend-dot.gray[data-v-dfc522c5]{background:#cbd5e1}.recent-card[data-v-dfc522c5]{margin-bottom:0}.table-wrap[data-v-dfc522c5]{overflow-x:auto}.recent-table[data-v-dfc522c5]{border-collapse:collapse;width:100%;font-size:13px}.recent-table th[data-v-dfc522c5]{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;border-bottom:2px solid var(--border);padding:10px 14px;font-size:11px;font-weight:700}.recent-table td[data-v-dfc522c5]{border-bottom:1px solid var(--border);color:var(--text-1);padding:13px 14px}.trx-row:last-child td[data-v-dfc522c5]{border-bottom:none}.trx-row:hover td[data-v-dfc522c5]{background:var(--surface-2)}.code-badge[data-v-dfc522c5]{background:var(--primary-light);color:var(--primary);border-radius:6px;padding:3px 8px;font-family:monospace;font-size:12px;font-weight:600}.student-cell[data-v-dfc522c5]{align-items:center;gap:10px;font-weight:600;display:flex}.avatar-sm[data-v-dfc522c5]{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.amount[data-v-dfc522c5]{color:var(--success);font-variant-numeric:tabular-nums}.date-cell[data-v-dfc522c5]{color:var(--text-2);white-space:nowrap}.empty-row[data-v-dfc522c5]{text-align:center;color:var(--text-3);padding:32px}@media (width<=1100px){.stats-grid[data-v-dfc522c5]{grid-template-columns:repeat(2,1fr)}.mid-grid[data-v-dfc522c5]{grid-template-columns:1fr}}@media (width<=640px){.page-container[data-v-dfc522c5]{padding:20px}.stats-grid[data-v-dfc522c5]{grid-template-columns:1fr}}.modal-backdrop[data-v-9bd69c52]{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a66;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;animation:.2s ease-out fade-in-9bd69c52;display:flex;position:fixed;top:0;left:0}.modal-content[data-v-9bd69c52]{border-radius:var(--radius-lg,12px);box-shadow:var(--shadow-lg,0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d);background:#fff;flex-direction:column;width:100%;max-height:90vh;animation:.3s ease-out slide-up-9bd69c52;display:flex}.modal-content.form-modal[data-v-9bd69c52]{max-width:800px}.modal-content.delete-modal[data-v-9bd69c52]{text-align:center;max-width:400px;padding:24px}.modal-content.delete-modal .modal-body[data-v-9bd69c52]{padding:0}@keyframes fade-in-9bd69c52{0%{opacity:0}to{opacity:1}}@keyframes slide-up-9bd69c52{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header[data-v-9bd69c52]{border-bottom:1px solid var(--border,#e2e8f0);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2[data-v-9bd69c52]{color:var(--text-1,#1e293b);margin:0;font-size:18px;font-weight:700}.btn-close[data-v-9bd69c52]{color:var(--text-3,#94a3b8);cursor:pointer;transition:color var(--transition,.2s ease);background:0 0;border:none;padding:4px}.btn-close[data-v-9bd69c52]:hover{color:var(--text-1,#1e293b)}.btn-close svg[data-v-9bd69c52]{width:20px;height:20px}.modal-body[data-v-9bd69c52]{padding:24px;overflow-y:auto}.modal-footer[data-v-9bd69c52]{border-top:1px solid var(--border,#e2e8f0);background:var(--surface-2,#f8fafc);border-radius:0 0 var(--radius-lg,12px) var(--radius-lg,12px);justify-content:flex-end;gap:12px;padding:20px 24px;display:flex}.pagination-wrapper[data-v-acf8ff2c]{justify-content:space-between;align-items:center;display:flex}.pagination-info[data-v-acf8ff2c]{color:var(--text-2,#64748b);font-size:14px}.pagination-controls[data-v-acf8ff2c]{gap:6px;display:flex}.btn-page[data-v-acf8ff2c]{border:1px solid var(--border,#e2e8f0);color:var(--text-2,#64748b);cursor:pointer;transition:all var(--transition,.2s ease);background:#fff;border-radius:6px;padding:8px 12px;font-size:13px;font-weight:500}.btn-page[data-v-acf8ff2c]:hover:not(:disabled):not(.active){background:var(--surface-2,#f8fafc)}.btn-page.active[data-v-acf8ff2c]{background:var(--primary,#6366f1);color:#fff;border-color:var(--primary,#6366f1)}.btn-page[data-v-acf8ff2c]:disabled{opacity:.5;cursor:not-allowed;background:var(--surface-2,#f8fafc)}.page-container[data-v-b2e7dc4a]{max-width:1400px;margin:0 auto;padding:32px 40px;animation:.4s ease-out fade-in-b2e7dc4a}@keyframes fade-in-b2e7dc4a{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-header[data-v-b2e7dc4a]{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.page-title[data-v-b2e7dc4a]{color:var(--text-1);letter-spacing:-.5px;margin-bottom:8px;font-size:28px;font-weight:800}.page-subtitle[data-v-b2e7dc4a]{color:var(--text-2);font-size:15px}.header-actions[data-v-b2e7dc4a]{gap:12px;display:flex}.btn[data-v-b2e7dc4a]{border-radius:var(--radius);cursor:pointer;transition:all var(--transition);border:none;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;display:inline-flex}.btn svg[data-v-b2e7dc4a]{width:18px;height:18px}.btn-primary[data-v-b2e7dc4a]{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;box-shadow:0 4px 12px #6366f140}.btn-primary[data-v-b2e7dc4a]:hover{transform:translateY(-1px);box-shadow:0 6px 16px #6366f159}.btn-secondary[data-v-b2e7dc4a]{color:var(--text-2);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff}.btn-secondary[data-v-b2e7dc4a]:hover{background:var(--surface-3);color:var(--text-1)}.btn-danger[data-v-b2e7dc4a]{background:var(--danger);color:#fff;box-shadow:0 4px 12px #ef444440}.btn-danger[data-v-b2e7dc4a]:hover{transform:translateY(-1px);box-shadow:0 6px 16px #ef444459}.filters-card[data-v-b2e7dc4a]{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;padding:16px;display:flex}.search-box[data-v-b2e7dc4a]{flex:1;max-width:400px;position:relative}.search-box svg[data-v-b2e7dc4a]{width:18px;height:18px;color:var(--text-3);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-box input[data-v-b2e7dc4a]{border:1px solid var(--border);border-radius:var(--radius);width:100%;transition:all var(--transition);background:var(--surface-2);color:var(--text-1);padding:10px 16px 10px 42px;font-size:14px}.search-box input[data-v-b2e7dc4a]:focus{border-color:var(--primary);background:#fff;outline:none;box-shadow:0 0 0 3px #6366f11a}.filter-actions[data-v-b2e7dc4a]{gap:12px;display:flex}.form-select[data-v-b2e7dc4a]{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-2);appearance:none;cursor:pointer;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748B'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;min-width:150px;padding:10px 36px 10px 16px;font-size:14px}.form-select[data-v-b2e7dc4a]:focus{border-color:var(--primary);outline:none}.table-container[data-v-b2e7dc4a]{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;margin-bottom:24px;overflow:hidden}.data-table[data-v-b2e7dc4a]{border-collapse:collapse;width:100%}.data-table th[data-v-b2e7dc4a]{background:var(--surface-2);text-align:left;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding:16px 24px;font-size:12px;font-weight:600}.data-table td[data-v-b2e7dc4a]{border-bottom:1px solid var(--border);vertical-align:top;padding:20px 24px}.table-row[data-v-b2e7dc4a]{transition:background-color var(--transition)}.table-row[data-v-b2e7dc4a]:hover{background-color:#f8fafc}.student-profile[data-v-b2e7dc4a]{align-items:flex-start;gap:16px;display:flex}.student-avatar[data-v-b2e7dc4a]{color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;font-weight:700;display:flex}.avatar-0[data-v-b2e7dc4a]{background:linear-gradient(135deg,#3b82f6,#2563eb)}.avatar-1[data-v-b2e7dc4a]{background:linear-gradient(135deg,#10b981,#059669)}.avatar-2[data-v-b2e7dc4a]{background:linear-gradient(135deg,#f59e0b,#d97706)}.avatar-3[data-v-b2e7dc4a]{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}.student-info[data-v-b2e7dc4a]{flex-direction:column;gap:4px;display:flex}.student-name[data-v-b2e7dc4a]{color:var(--text-1);font-size:15px;font-weight:600}.student-nis[data-v-b2e7dc4a]{color:var(--primary);background:var(--primary-light);border-radius:4px;align-self:flex-start;padding:2px 8px;font-size:13px;font-weight:500;display:inline-block}.student-ttl[data-v-b2e7dc4a]{color:var(--text-3);margin-top:2px;font-size:13px}.contact-info[data-v-b2e7dc4a]{flex-direction:column;gap:8px;display:flex}.info-item[data-v-b2e7dc4a]{color:var(--text-2);align-items:center;gap:8px;font-size:13px;display:flex}.info-item svg[data-v-b2e7dc4a]{width:14px;height:14px;color:var(--text-3);flex-shrink:0}.address-item[data-v-b2e7dc4a]{align-items:flex-start}.address-item svg[data-v-b2e7dc4a]{margin-top:2px}.truncate-text[data-v-b2e7dc4a]{-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;display:-webkit-box;overflow:hidden}.parents-info[data-v-b2e7dc4a]{flex-direction:column;gap:12px;display:flex}.parent-card[data-v-b2e7dc4a]{background:var(--surface-2);border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:13px;display:flex}.parent-label[data-v-b2e7dc4a]{color:var(--text-3);width:36px;font-weight:500}.parent-name[data-v-b2e7dc4a]{color:var(--text-1);flex:1;font-weight:500}.parent-phone[data-v-b2e7dc4a]{color:var(--text-2);font-family:monospace}.action-buttons[data-v-b2e7dc4a]{gap:8px;display:flex}.btn-icon[data-v-b2e7dc4a]{cursor:pointer;width:32px;height:32px;transition:all var(--transition);background:var(--surface-2);color:var(--text-2);border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.btn-edit[data-v-b2e7dc4a]:hover{background:var(--primary-light);color:var(--primary)}.btn-delete[data-v-b2e7dc4a]:hover{color:var(--danger);background:#fef2f2}.btn-icon svg[data-v-b2e7dc4a]{width:16px;height:16px}.empty-state[data-v-b2e7dc4a]{text-align:center;padding:60px 20px!important}.empty-content[data-v-b2e7dc4a]{flex-direction:column;align-items:center;gap:12px;display:flex}.empty-content svg[data-v-b2e7dc4a]{width:48px;height:48px;color:var(--text-3);margin-bottom:8px}.empty-content h3[data-v-b2e7dc4a]{color:var(--text-1);font-size:16px}.empty-content p[data-v-b2e7dc4a]{color:var(--text-2);font-size:14px}[data-v-b2e7dc4a] .form-modal{max-width:800px}[data-v-b2e7dc4a] .delete-modal{text-align:center;max-width:400px;padding:32px}[data-v-b2e7dc4a] .delete-modal .modal-body{padding:0}.form-section[data-v-b2e7dc4a]{margin-bottom:32px}.form-section[data-v-b2e7dc4a]:last-child{margin-bottom:0}.section-title[data-v-b2e7dc4a]{color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--surface-3);margin-bottom:16px;padding-bottom:8px;font-size:14px;font-weight:700}.form-grid[data-v-b2e7dc4a]{grid-template-columns:1fr 1fr;gap:20px;display:grid}.col-span-2[data-v-b2e7dc4a]{grid-column:span 2}.form-group[data-v-b2e7dc4a]{flex-direction:column;gap:8px;display:flex}.form-group label[data-v-b2e7dc4a]{color:var(--text-2);font-size:13px;font-weight:500}.form-input[data-v-b2e7dc4a]{border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);padding:10px 14px;font-family:inherit;font-size:14px}.form-input[data-v-b2e7dc4a]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.form-input[data-v-b2e7dc4a]:disabled{background:var(--surface-2);color:var(--text-3);cursor:not-allowed}textarea.form-input[data-v-b2e7dc4a]{resize:vertical}.delete-icon-wrapper[data-v-b2e7dc4a]{width:64px;height:64px;color:var(--danger);background:#fef2f2;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.delete-icon-wrapper svg[data-v-b2e7dc4a]{width:32px;height:32px}.delete-modal h2[data-v-b2e7dc4a]{color:var(--text-1);margin-bottom:12px;font-size:20px;font-weight:700}.delete-modal p[data-v-b2e7dc4a]{color:var(--text-2);margin-bottom:24px;font-size:14px;line-height:1.5}.delete-modal .modal-actions[data-v-b2e7dc4a]{justify-content:center;gap:12px;display:flex}.delete-modal .btn[data-v-b2e7dc4a]{flex:1}.page-container[data-v-f11cf3a9]{max-width:1200px;margin:0 auto;padding:32px 40px;animation:.4s ease-out fade-in-f11cf3a9}@keyframes fade-in-f11cf3a9{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-header[data-v-f11cf3a9]{margin-bottom:32px}.header-content[data-v-f11cf3a9]{align-items:flex-start;gap:20px;display:flex}.btn-back[data-v-f11cf3a9]{border:1px solid var(--border,#e2e8f0);border-radius:var(--radius,8px);color:var(--text-2,#64748b);cursor:pointer;box-shadow:var(--shadow-sm,0 1px 2px 0 #0000000d);background:#fff;align-items:center;gap:8px;margin-top:4px;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.btn-back[data-v-f11cf3a9]:hover{background:var(--surface-2,#f8fafc);color:var(--text-1,#1e293b);transform:translate(-2px)}.btn-back svg[data-v-f11cf3a9]{width:18px;height:18px}.page-title[data-v-f11cf3a9]{color:var(--text-1,#1e293b);letter-spacing:-.5px;margin-bottom:8px;font-size:28px;font-weight:800}.page-subtitle[data-v-f11cf3a9]{color:var(--text-2,#64748b);font-size:15px}.import-layout[data-v-f11cf3a9]{flex-direction:column;gap:24px;display:flex}.upload-card[data-v-f11cf3a9],.preview-section[data-v-f11cf3a9]{border-radius:var(--radius-lg,12px);box-shadow:var(--shadow-sm,0 1px 3px 0 #0000001a, 0 1px 2px 0 #0000000f);background:#fff;padding:24px}.card-header[data-v-f11cf3a9],.preview-header[data-v-f11cf3a9]{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.card-header h3[data-v-f11cf3a9],.preview-header h3[data-v-f11cf3a9]{color:var(--text-1,#1e293b);margin:0;font-size:18px;font-weight:700}.btn[data-v-f11cf3a9]{border-radius:var(--radius,8px);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn-sm[data-v-f11cf3a9]{padding:6px 12px;font-size:13px}.btn svg[data-v-f11cf3a9]{width:18px;height:18px}.btn-sm svg[data-v-f11cf3a9]{width:16px;height:16px}.btn-primary[data-v-f11cf3a9]{background:linear-gradient(135deg, var(--primary,#6366f1), var(--secondary,#4f46e5));color:#fff;box-shadow:0 4px 12px #6366f140}.btn-primary[data-v-f11cf3a9]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #6366f159}.btn-primary[data-v-f11cf3a9]:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-secondary[data-v-f11cf3a9]{color:var(--text-2,#64748b);border:1px solid var(--border,#e2e8f0);background:#fff}.btn-secondary[data-v-f11cf3a9]:hover{background:var(--surface-2,#f8fafc);color:var(--text-1,#1e293b)}.btn-success[data-v-f11cf3a9]{color:#fff;background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b98140}.btn-success[data-v-f11cf3a9]:hover{transform:translateY(-1px);box-shadow:0 6px 16px #10b98159}.drop-zone[data-v-f11cf3a9]{border:2px dashed var(--border,#cbd5e1);border-radius:var(--radius-lg,12px);text-align:center;cursor:pointer;background:var(--surface-1,#f8fafc);padding:40px 20px;transition:all .3s}.drop-zone[data-v-f11cf3a9]:hover,.drop-zone.is-dragover[data-v-f11cf3a9]{border-color:var(--primary,#6366f1);background:#6366f10d}.drop-zone.has-file[data-v-f11cf3a9]{cursor:default;background:#fff;border-style:solid;padding:24px}.hidden-input[data-v-f11cf3a9]{display:none}.drop-zone-content[data-v-f11cf3a9]{flex-direction:column;align-items:center;gap:12px;display:flex}.upload-icon[data-v-f11cf3a9]{width:64px;height:64px;color:var(--primary,#6366f1);background:#fff;border-radius:50%;justify-content:center;align-items:center;margin-bottom:8px;display:flex;box-shadow:0 4px 12px #0000000d}.upload-icon svg[data-v-f11cf3a9]{width:32px;height:32px}.drop-zone-content h4[data-v-f11cf3a9]{color:var(--text-1,#1e293b);margin:0;font-size:16px;font-weight:600}.drop-zone-content p[data-v-f11cf3a9]{color:var(--text-3,#94a3b8);margin:0;font-size:14px}.file-preview[data-v-f11cf3a9]{background:var(--surface-2,#f8fafc);border-radius:var(--radius,8px);border:1px solid var(--border,#e2e8f0);align-items:center;gap:16px;padding:16px;display:flex}.file-icon[data-v-f11cf3a9]{color:#fff;background:#10b981;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.file-info[data-v-f11cf3a9]{flex-direction:column;flex:1;align-items:flex-start;display:flex}.file-name[data-v-f11cf3a9]{color:var(--text-1,#1e293b);font-size:15px;font-weight:600}.file-size[data-v-f11cf3a9]{color:var(--text-3,#94a3b8);font-size:13px}.btn-icon[data-v-f11cf3a9]{border:1px solid var(--border,#e2e8f0);width:36px;height:36px;color:var(--text-2,#64748b);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-remove[data-v-f11cf3a9]:hover{color:var(--danger,#ef4444);background:#fef2f2;border-color:#fecaca}.btn-icon svg[data-v-f11cf3a9]{width:18px;height:18px}.upload-actions[data-v-f11cf3a9]{justify-content:flex-end;margin-top:20px;display:flex}.table-container[data-v-f11cf3a9]{border:1px solid var(--border,#e2e8f0);border-radius:var(--radius,8px);margin-bottom:24px;overflow-x:auto}.data-table[data-v-f11cf3a9]{border-collapse:collapse;width:100%}.data-table th[data-v-f11cf3a9]{background:var(--surface-2,#f8fafc);text-align:left;color:var(--text-2,#64748b);border-bottom:1px solid var(--border,#e2e8f0);padding:12px 16px;font-size:13px;font-weight:600}.data-table td[data-v-f11cf3a9]{border-bottom:1px solid var(--border,#e2e8f0);color:var(--text-1,#1e293b);padding:12px 16px;font-size:14px}.table-row[data-v-f11cf3a9]:hover{background-color:var(--surface-2,#f8fafc)}.badge[data-v-f11cf3a9]{border-radius:20px;padding:6px 12px;font-size:13px;font-weight:600}.badge.success[data-v-f11cf3a9]{color:#059669;background:#ecfdf5}.status-badge[data-v-f11cf3a9]{border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600}.status-badge.valid[data-v-f11cf3a9]{color:#059669;background:#ecfdf5}.status-badge.invalid[data-v-f11cf3a9]{color:#ef4444;background:#fef2f2}.action-footer[data-v-f11cf3a9]{border-top:1px solid var(--border,#e2e8f0);justify-content:flex-end;gap:12px;padding-top:16px;display:flex}.page-container[data-v-85d2c72c]{max-width:1300px;margin:0 auto;padding:32px 40px;animation:.4s ease-out fade-in-85d2c72c}@keyframes fade-in-85d2c72c{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-header[data-v-85d2c72c]{justify-content:space-between;align-items:flex-start;margin-bottom:28px;display:flex}.header-content h1[data-v-85d2c72c]{color:var(--text-1);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.subtitle[data-v-85d2c72c]{color:var(--text-2);font-size:15px}.stats-grid[data-v-85d2c72c]{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px;display:grid}.stat-card[data-v-85d2c72c]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);align-items:center;gap:16px;padding:20px;display:flex}.stat-icon[data-v-85d2c72c]{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.stat-icon svg[data-v-85d2c72c]{width:22px;height:22px}.stat-icon.blue[data-v-85d2c72c]{color:#3b82f6;background:#eff6ff}.stat-icon.green[data-v-85d2c72c]{color:#10b981;background:#ecfdf5}.stat-icon.purple[data-v-85d2c72c]{color:#8b5cf6;background:#f5f3ff}.stat-value[data-v-85d2c72c]{color:var(--text-1);font-size:22px;font-weight:800;line-height:1.2;display:block}.stat-label[data-v-85d2c72c]{color:var(--text-3);margin-top:2px;font-size:12px;font-weight:500;display:block}.filters-section[data-v-85d2c72c]{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.search-box[data-v-85d2c72c]{flex:1;max-width:380px;position:relative}.search-box svg[data-v-85d2c72c]{width:18px;height:18px;color:var(--text-3);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-box input[data-v-85d2c72c]{border:1px solid var(--border);width:100%;color:var(--text-1);background:var(--surface);transition:all var(--transition);border-radius:10px;padding:11px 16px 11px 42px;font-size:14px}.search-box input[data-v-85d2c72c]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.filter-group[data-v-85d2c72c]{gap:10px;display:flex}.filter-select[data-v-85d2c72c]{border:1px solid var(--border);color:var(--text-1);background:var(--surface);cursor:pointer;border-radius:10px;padding:10px 14px;font-size:14px}.filter-select[data-v-85d2c72c]:focus{border-color:var(--primary);outline:none}.table-container[data-v-85d2c72c]{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:24px;overflow:hidden}.data-table[data-v-85d2c72c]{border-collapse:collapse;width:100%}.data-table th[data-v-85d2c72c],.data-table td[data-v-85d2c72c]{text-align:left;padding:14px 20px}.data-table th[data-v-85d2c72c]{color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:#f8fafc;font-size:12px;font-weight:600}.table-row[data-v-85d2c72c]{border-bottom:1px solid var(--border);transition:background var(--transition)}.table-row[data-v-85d2c72c]:last-child{border-bottom:none}.table-row[data-v-85d2c72c]:hover{background:#f8fafc}.tagihan-info[data-v-85d2c72c]{flex-direction:column;gap:3px;display:flex}.tagihan-name[data-v-85d2c72c]{color:var(--text-1);font-size:14px;font-weight:600}.tagihan-note[data-v-85d2c72c]{color:var(--text-3);font-size:12px}.nominal-badge[data-v-85d2c72c]{color:var(--text-1);font-variant-numeric:tabular-nums;font-size:14px;font-weight:700}.periode-info[data-v-85d2c72c]{flex-direction:column;gap:4px;display:flex}.tipe-badge[data-v-85d2c72c]{border-radius:20px;width:fit-content;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.tipe-badge.bulanan[data-v-85d2c72c]{color:#2563eb;background:#eff6ff}.tipe-badge.tahunan[data-v-85d2c72c]{color:#7c3aed;background:#f5f3ff}.tipe-badge.sekali[data-v-85d2c72c]{color:#059669;background:#ecfdf5}.periode-text[data-v-85d2c72c]{color:var(--text-2);font-size:12px}.target-info[data-v-85d2c72c]{flex-wrap:wrap;gap:6px;display:flex}.target-badge[data-v-85d2c72c]{border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.target-badge.kelas[data-v-85d2c72c]{color:#92400e;background:#fef3c7}.target-badge.jurusan[data-v-85d2c72c]{color:#9d174d;background:#fce7f3}.target-badge.semua[data-v-85d2c72c]{background:var(--surface-3);color:var(--text-2)}.status-toggle[data-v-85d2c72c]{cursor:pointer;transition:all var(--transition);border:none;border-radius:20px;align-items:center;gap:8px;padding:5px 12px;font-size:12px;font-weight:600;display:inline-flex}.status-toggle.aktif[data-v-85d2c72c]{color:#065f46;background:#d1fae5}.status-toggle.nonaktif[data-v-85d2c72c]{color:#6b7280;background:#f3f4f6}.status-toggle[data-v-85d2c72c]:hover{opacity:.8;transform:scale(.97)}.toggle-dot[data-v-85d2c72c]{border-radius:50%;width:8px;height:8px}.aktif .toggle-dot[data-v-85d2c72c]{background:#10b981}.nonaktif .toggle-dot[data-v-85d2c72c]{background:#9ca3af}.action-buttons[data-v-85d2c72c]{gap:8px;display:flex}.btn-icon[data-v-85d2c72c]{cursor:pointer;width:34px;height:34px;transition:all var(--transition);color:var(--text-3);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.btn-icon svg[data-v-85d2c72c]{width:16px;height:16px}.btn-icon.edit[data-v-85d2c72c]:hover{color:var(--primary);background:var(--primary-light)}.btn-icon.delete[data-v-85d2c72c]:hover{color:var(--danger);background:#fee2e2}.btn-icon.blast[data-v-85d2c72c]:hover{color:#10b981;background:#d1fae5}.empty-state[data-v-85d2c72c]{text-align:center;padding:48px}.empty-content[data-v-85d2c72c]{color:var(--text-3);flex-direction:column;align-items:center;gap:12px;display:flex}.empty-content svg[data-v-85d2c72c]{opacity:.4;width:40px;height:40px}.btn[data-v-85d2c72c]{cursor:pointer;transition:all var(--transition);border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;display:inline-flex}.btn svg[data-v-85d2c72c]{width:18px;height:18px}.btn-primary[data-v-85d2c72c]{background:var(--primary);color:#fff;box-shadow:0 4px 12px #6366f140}.btn-primary[data-v-85d2c72c]:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-primary[data-v-85d2c72c]:disabled{background:var(--text-3);cursor:not-allowed;box-shadow:none;transform:none}.btn-outline[data-v-85d2c72c]{color:var(--text-2);border:1px solid var(--border);background:0 0}.btn-outline[data-v-85d2c72c]:hover{background:var(--surface-3);color:var(--text-1)}.btn-danger[data-v-85d2c72c]{background:var(--danger);color:#fff}.btn-danger[data-v-85d2c72c]:hover{background:#dc2626}.w-full[data-v-85d2c72c]{justify-content:center;width:100%}.form-grid[data-v-85d2c72c]{grid-template-columns:1fr 1fr;gap:18px;display:grid}.form-group[data-v-85d2c72c]{flex-direction:column;gap:7px;display:flex}.form-group.full[data-v-85d2c72c]{grid-column:1/-1}.form-group label[data-v-85d2c72c]{color:var(--text-1);font-size:13px;font-weight:600}.required[data-v-85d2c72c]{color:var(--danger)}.form-input[data-v-85d2c72c]{border:1px solid var(--border);transition:all var(--transition);border-radius:8px;padding:10px 14px;font-family:inherit;font-size:14px}.form-input[data-v-85d2c72c]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.delete-icon[data-v-85d2c72c]{width:64px;height:64px;color:var(--danger);background:#fee2e2;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.delete-icon svg[data-v-85d2c72c]{width:32px;height:32px}.delete-title[data-v-85d2c72c]{color:var(--text-1);margin-bottom:12px;font-size:20px;font-weight:700}.delete-desc[data-v-85d2c72c]{color:var(--text-2);margin-bottom:24px;font-size:14px;line-height:1.5}@media print{body>:not(#app),.page-container>:not(.modal-overlay){display:none!important}.modal-overlay{background:0 0!important;display:block!important;position:static!important}.struk-wrapper{box-shadow:none!important}.no-print{display:none!important}.struk{margin:0 auto;width:72mm!important}}.page-container[data-v-ddc64205]{max-width:1200px;margin:0 auto;padding:32px 40px;animation:.4s ease-out fade-in-ddc64205}@keyframes fade-in-ddc64205{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-header[data-v-ddc64205]{margin-bottom:28px}.page-header h1[data-v-ddc64205]{color:var(--text-1);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.subtitle[data-v-ddc64205]{color:var(--text-2);font-size:15px}.search-section[data-v-ddc64205]{margin-bottom:28px}.search-card[data-v-ddc64205]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.search-label[data-v-ddc64205]{color:var(--text-1);margin-bottom:10px;font-size:14px;font-weight:600;display:block}.search-wrapper[data-v-ddc64205]{position:relative}.search-wrapper svg[data-v-ddc64205]{width:18px;height:18px;color:var(--text-3);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-input[data-v-ddc64205]{border:1px solid var(--border);width:100%;color:var(--text-1);background:var(--surface);transition:all var(--transition);border-radius:10px;padding:13px 16px 13px 44px;font-size:15px}.search-input[data-v-ddc64205]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.dropdown[data-v-ddc64205]{border:1px solid var(--border);box-shadow:var(--shadow-md);z-index:100;background:#fff;border-radius:10px;position:absolute;top:calc(100% + 8px);left:0;right:0;overflow:hidden}.dropdown-item[data-v-ddc64205]{cursor:pointer;transition:background var(--transition);padding:12px 16px}.dropdown-item[data-v-ddc64205]:hover{background:var(--surface-2)}.dd-name[data-v-ddc64205]{color:var(--text-1);font-size:14px;font-weight:600}.dd-meta[data-v-ddc64205]{color:var(--text-3);margin-top:2px;font-size:12px}.siswa-card[data-v-ddc64205]{border-radius:var(--radius-lg);color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);align-items:center;gap:20px;margin-bottom:24px;padding:24px 28px;display:flex}.siswa-avatar[data-v-ddc64205]{background:#ffffff40;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:22px;font-weight:800;display:flex}.siswa-detail[data-v-ddc64205]{flex:1}.siswa-detail h2[data-v-ddc64205]{margin-bottom:6px;font-size:20px;font-weight:700}.siswa-meta[data-v-ddc64205]{opacity:.85;gap:12px;font-size:13px;display:flex}.siswa-meta span[data-v-ddc64205]{background:#fff3;border-radius:20px;padding:2px 10px}.mt-2[data-v-ddc64205]{margin-top:8px}.saldo-badge[data-v-ddc64205]{color:#fff;background:#10b98166;border:1px solid #10b98180;border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:13px;font-weight:500;display:inline-flex}.saldo-badge svg[data-v-ddc64205]{width:14px;height:14px}.siswa-stats[data-v-ddc64205]{gap:20px;display:flex}.stat[data-v-ddc64205]{text-align:center}.sn[data-v-ddc64205]{font-size:24px;font-weight:800;display:block}.sl[data-v-ddc64205]{opacity:.8;font-size:11px;display:block}.sn.cicilan[data-v-ddc64205]{color:#fcd34d}.sn.belum[data-v-ddc64205]{color:#fca5a5}.section-title[data-v-ddc64205]{color:var(--text-1);margin-bottom:16px;font-size:16px;font-weight:700}.loading-state[data-v-ddc64205],.empty-tagihan[data-v-ddc64205]{text-align:center;color:var(--text-3);padding:32px}.tagihan-grid[data-v-ddc64205]{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.tagihan-card[data-v-ddc64205]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition);padding:18px}.tagihan-card[data-v-ddc64205]:hover{box-shadow:var(--shadow-md)}.tagihan-card.lunas[data-v-ddc64205]{border-left:4px solid #10b981}.tagihan-card.cicilan[data-v-ddc64205]{border-left:4px solid #f59e0b}.tagihan-card.belum_bayar[data-v-ddc64205]{border-left:4px solid #ef4444}.tc-header[data-v-ddc64205]{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:12px;display:flex}.tc-name[data-v-ddc64205]{color:var(--text-1);font-size:14px;font-weight:700;display:block}.tc-periode[data-v-ddc64205]{color:var(--text-3);margin-top:3px;font-size:12px;display:block}.tc-status[data-v-ddc64205]{white-space:nowrap;border-radius:20px;flex-shrink:0;padding:3px 10px;font-size:11px;font-weight:700}.tc-status.lunas[data-v-ddc64205]{color:#065f46;background:#d1fae5}.tc-status.cicilan[data-v-ddc64205]{color:#92400e;background:#fef3c7}.tc-status.belum_bayar[data-v-ddc64205]{color:#991b1b;background:#fee2e2}.tc-nominal[data-v-ddc64205]{color:var(--text-2);justify-content:space-between;margin-bottom:8px;font-size:12px;display:flex}.tc-sisa strong[data-v-ddc64205]{color:var(--danger)}.progress-bar[data-v-ddc64205]{background:var(--surface-3);border-radius:10px;height:6px;margin-bottom:6px;overflow:hidden}.progress-fill[data-v-ddc64205]{border-radius:10px;height:100%;transition:width .5s}.progress-fill.lunas[data-v-ddc64205]{background:#10b981}.progress-fill.cicilan[data-v-ddc64205]{background:#f59e0b}.progress-fill.belum_bayar[data-v-ddc64205]{background:#ef4444}.tc-paid-info[data-v-ddc64205]{color:var(--text-3);justify-content:space-between;margin-bottom:14px;font-size:11px;display:flex}.btn-bayar[data-v-ddc64205]{background:var(--primary);color:#fff;cursor:pointer;width:100%;transition:all var(--transition);border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:9px;font-size:13px;font-weight:600;display:flex}.btn-bayar svg[data-v-ddc64205]{width:16px;height:16px}.btn-bayar[data-v-ddc64205]:hover{background:var(--primary-dark)}.placeholder-state[data-v-ddc64205]{text-align:center;color:var(--text-3);padding:80px 20px}.placeholder-state svg[data-v-ddc64205]{opacity:.25;width:64px;height:64px;margin-bottom:16px}.placeholder-state p[data-v-ddc64205]{font-size:16px}.modal-overlay[data-v-ddc64205]{z-index:200;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box[data-v-ddc64205]{border-radius:var(--radius-lg);width:100%;max-width:460px;box-shadow:var(--shadow-lg);background:#fff;flex-direction:column;max-height:90vh;display:flex}.modal-header[data-v-ddc64205]{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3[data-v-ddc64205]{color:var(--text-1);font-size:18px;font-weight:700}.modal-close[data-v-ddc64205]{cursor:pointer;color:var(--text-3);background:0 0;border:none;font-size:22px;line-height:1}.modal-body[data-v-ddc64205]{padding:20px 24px;overflow-y:auto}.info-row[data-v-ddc64205]{color:var(--text-2);justify-content:space-between;padding:6px 0;font-size:14px;display:flex}.info-row.highlight[data-v-ddc64205]{color:var(--danger);font-weight:700}.info-row strong[data-v-ddc64205]{color:var(--text-1)}hr[data-v-ddc64205]{border:none;border-top:1px solid var(--border);margin:12px 0}.form-group[data-v-ddc64205]{flex-direction:column;gap:6px;margin-top:14px;display:flex}.form-group label[data-v-ddc64205]{color:var(--text-1);font-size:13px;font-weight:600}.req[data-v-ddc64205]{color:var(--danger)}.form-input[data-v-ddc64205]{border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:14px}.form-input[data-v-ddc64205]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.quick-btns[data-v-ddc64205]{gap:8px;margin-top:6px;display:flex}.qbtn[data-v-ddc64205]{border:1px solid var(--border);background:var(--surface-3);cursor:pointer;border-radius:6px;padding:5px 12px;font-size:12px}.qbtn[data-v-ddc64205]:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.modal-footer[data-v-ddc64205]{border-top:1px solid var(--border);flex-shrink:0;gap:10px;padding:16px 24px;display:flex}.btn-outline-sm[data-v-ddc64205]{border:1px solid var(--border);color:var(--text-2);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:10px;font-size:14px;font-weight:600}.btn-proses[data-v-ddc64205]{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;flex:2;padding:10px;font-size:14px;font-weight:700}.btn-proses[data-v-ddc64205]:disabled{background:var(--text-3);cursor:not-allowed}.struk-wrapper[data-v-ddc64205]{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;padding:20px}.struk-actions[data-v-ddc64205]{justify-content:center;gap:10px;margin-bottom:16px;display:flex}.btn-print[data-v-ddc64205]{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:700}.struk[data-v-ddc64205]{color:#000;width:72mm;margin:0 auto;font-family:Courier New,monospace;font-size:11px;line-height:1.6}.struk-header[data-v-ddc64205]{text-align:center;margin-bottom:4px}.struk-logo-img[data-v-ddc64205]{object-fit:contain;width:52px;height:52px;margin:0 auto 6px;display:block}.struk-sekolah[data-v-ddc64205]{letter-spacing:1px;font-size:13px;font-weight:700}.struk-sekolah.sub[data-v-ddc64205]{font-size:11px;font-weight:400}.struk-divider[data-v-ddc64205]{letter-spacing:0;margin:4px 0}.struk-title[data-v-ddc64205]{letter-spacing:2px;margin:4px 0;font-size:12px;font-weight:700}.struk-body[data-v-ddc64205]{margin:8px 0}.struk-row[data-v-ddc64205]{justify-content:space-between;gap:4px;display:flex}.struk-row span[data-v-ddc64205]:first-child{flex-shrink:0}.struk-row span[data-v-ddc64205]:last-child{text-align:right;word-break:break-all}.struk-footer[data-v-ddc64205]{text-align:center;margin-top:8px;font-size:10px}.struk-thanks[data-v-ddc64205]{margin-top:8px;font-style:italic}.struk-thanks.small[data-v-ddc64205]{color:#666;font-size:9px}.mt-3[data-v-ddc64205]{margin-top:16px}.checkbox-group[data-v-ddc64205]{background:var(--surface-2);border:1px dashed var(--border);border-radius:8px;padding:12px 14px}.cb-label[data-v-ddc64205]{cursor:pointer;color:var(--text-1);align-items:center;gap:10px;margin:0;font-size:13px;font-weight:500;display:flex}.cb-label input[type=checkbox][data-v-ddc64205]{cursor:pointer;width:16px;height:16px}.riwayat-table-wrapper[data-v-ddc64205]{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.riwayat-table[data-v-ddc64205]{border-collapse:collapse;text-align:left;width:100%;font-size:13px}.riwayat-table th[data-v-ddc64205]{background:var(--surface-2);color:var(--text-2);border-bottom:1px solid var(--border);padding:12px 16px;font-weight:600}.riwayat-table td[data-v-ddc64205]{border-bottom:1px solid var(--border);color:var(--text-1);padding:12px 16px}.riwayat-table tr:last-child td[data-v-ddc64205]{border-bottom:none}.r-nominal[data-v-ddc64205]{font-weight:700}.r-badge[data-v-ddc64205]{border-radius:6px;padding:3px 8px;font-size:11px;font-weight:600}.r-badge.saldo[data-v-ddc64205]{color:#065f46;background:#d1fae5}.r-badge.tunai[data-v-ddc64205]{color:#1e40af;background:#dbeafe}.r-actions[data-v-ddc64205]{gap:6px;display:flex}.btn-icon[data-v-ddc64205]{background:var(--surface-3);border:1px solid var(--border);width:28px;height:28px;color:var(--text-2);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-icon svg[data-v-ddc64205]{width:14px;height:14px}.btn-icon[data-v-ddc64205]:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.btn-icon.danger[data-v-ddc64205]:hover{color:#dc2626;background:#fee2e2;border-color:#fecaca}@media print{body>:not(#app),.sidebar,.page-header,.filter-bar,.stats-grid,.chart-section,.split-section{display:none!important}.print-only{display:block!important}.page-container{padding:0!important}}.page-container[data-v-b573c3e2]{max-width:1400px;margin:0 auto;padding:32px 40px;animation:.4s fade-in-b573c3e2}@keyframes fade-in-b573c3e2{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header[data-v-b573c3e2]{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.header-content h1[data-v-b573c3e2]{color:var(--text-1);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.subtitle[data-v-b573c3e2]{color:var(--text-2);font-size:15px}.header-actions[data-v-b573c3e2]{gap:10px;display:flex}.btn[data-v-b573c3e2]{cursor:pointer;transition:all var(--transition);border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;display:inline-flex}.btn svg[data-v-b573c3e2]{width:16px;height:16px}.btn-outline[data-v-b573c3e2]{background:var(--surface);border:1px solid var(--border);color:var(--text-2)}.btn-outline[data-v-b573c3e2]:hover{background:var(--surface-3);color:var(--text-1)}.filter-bar[data-v-b573c3e2]{gap:16px;margin-bottom:24px;display:flex}.filter-group[data-v-b573c3e2]{flex-direction:column;gap:4px;display:flex}.filter-group label[data-v-b573c3e2]{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.filter-select[data-v-b573c3e2]{border:1px solid var(--border);color:var(--text-1);background:var(--surface);cursor:pointer;border-radius:8px;min-width:130px;padding:9px 14px;font-size:14px}.filter-select[data-v-b573c3e2]:focus{border-color:var(--primary);outline:none}.stats-grid[data-v-b573c3e2]{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card[data-v-b573c3e2]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);align-items:center;gap:16px;padding:20px;display:flex;position:relative;overflow:hidden}.stat-card[data-v-b573c3e2]:before{content:"";width:4px;height:100%;position:absolute;top:0;left:0}.stat-card.accent-green[data-v-b573c3e2]:before{background:#10b981}.stat-card.accent-blue[data-v-b573c3e2]:before{background:#3b82f6}.stat-card.accent-purple[data-v-b573c3e2]:before{background:#8b5cf6}.stat-icon[data-v-b573c3e2]{background:var(--surface-3);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-icon svg[data-v-b573c3e2]{width:22px;height:22px;color:var(--primary)}.stat-body[data-v-b573c3e2]{flex-direction:column;gap:4px;display:flex}.stat-label[data-v-b573c3e2]{color:var(--text-3);font-size:12px;font-weight:500}.stat-value[data-v-b573c3e2]{color:var(--text-1);letter-spacing:-.5px;font-size:20px;font-weight:800}.chart-section[data-v-b573c3e2]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:24px;padding:24px}.section-header[data-v-b573c3e2]{margin-bottom:20px}.section-header h2[data-v-b573c3e2]{color:var(--text-1);font-size:16px;font-weight:700}.chart-container[data-v-b573c3e2]{height:200px}.chart-bars[data-v-b573c3e2]{justify-content:space-between;align-items:flex-end;gap:6px;height:100%;display:flex}.chart-col[data-v-b573c3e2]{cursor:pointer;flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:4px;height:100%;display:flex}.bar-value[data-v-b573c3e2]{color:var(--text-3);white-space:nowrap;font-size:9px;font-weight:600}.bar-wrap[data-v-b573c3e2]{background:var(--surface-3);border-radius:6px 6px 0 0;align-items:flex-end;width:100%;height:160px;display:flex;overflow:hidden}.bar-fill[data-v-b573c3e2]{background:linear-gradient(#6366f1,#8b5cf6);border-radius:6px 6px 0 0;width:100%;transition:height .5s}.chart-col.active .bar-fill[data-v-b573c3e2]{background:linear-gradient(#10b981,#059669)}.chart-col:hover .bar-fill[data-v-b573c3e2]{opacity:.8}.bar-label[data-v-b573c3e2]{color:var(--text-3);font-size:11px;font-weight:500}.chart-empty[data-v-b573c3e2]{height:100%;color:var(--text-3);justify-content:center;align-items:center;display:flex}.split-section[data-v-b573c3e2]{grid-template-columns:320px 1fr;gap:20px;display:grid}.rekap-card[data-v-b573c3e2],.transaksi-card[data-v-b573c3e2]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.card-title[data-v-b573c3e2]{color:var(--text-1);align-items:center;gap:10px;margin-bottom:16px;font-size:15px;font-weight:700;display:flex}.trx-count[data-v-b573c3e2]{background:var(--primary-light);color:var(--primary);border-radius:20px;padding:2px 10px;font-size:12px;font-weight:500}.empty-text[data-v-b573c3e2]{color:var(--text-3);text-align:center;padding:24px;font-size:14px}.mini-table[data-v-b573c3e2]{border-collapse:collapse;width:100%;font-size:13px}.mini-table th[data-v-b573c3e2]{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border);padding:8px 10px;font-size:11px;font-weight:600}.mini-table td[data-v-b573c3e2]{border-bottom:1px solid var(--border);color:var(--text-1);padding:10px}.mini-table tfoot td[data-v-b573c3e2]{border-top:2px solid var(--border);border-bottom:none;padding-top:12px}.mini-table .center[data-v-b573c3e2]{text-align:center}.mini-table .right[data-v-b573c3e2]{text-align:right}.table-wrap[data-v-b573c3e2]{overflow-x:auto}.data-table[data-v-b573c3e2]{border-collapse:collapse;width:100%;font-size:13px}.data-table th[data-v-b573c3e2]{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border);padding:10px 12px;font-size:11px;font-weight:600}.data-table td[data-v-b573c3e2]{border-bottom:1px solid var(--border);color:var(--text-1);padding:12px}.table-row[data-v-b573c3e2]:hover{background:var(--surface-2)}.table-row:last-child td[data-v-b573c3e2]{border-bottom:none}.nowrap[data-v-b573c3e2]{white-space:nowrap}.code[data-v-b573c3e2]{color:var(--primary);font-family:monospace;font-size:12px}.right[data-v-b573c3e2]{text-align:right}.empty-state[data-v-b573c3e2]{text-align:center;color:var(--text-3);padding:32px}.siswa-cell[data-v-b573c3e2]{align-items:center;gap:10px;display:flex}.siswa-avatar-sm[data-v-b573c3e2]{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:flex}.siswa-nm[data-v-b573c3e2]{font-size:13px;font-weight:600}.siswa-nis[data-v-b573c3e2]{color:var(--text-3);font-size:11px}.pagination[data-v-b573c3e2]{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:16px;margin-top:12px;padding:16px 0 4px;display:flex}.page-btn[data-v-b573c3e2]{background:var(--surface-2);border:1px solid var(--border);color:var(--text-2);cursor:pointer;transition:all var(--transition);border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600}.page-btn[data-v-b573c3e2]:hover:not(:disabled){background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.page-btn[data-v-b573c3e2]:disabled{opacity:.5;cursor:not-allowed}.page-info[data-v-b573c3e2]{color:var(--text-3);font-size:13px;font-weight:500}.print-only[data-v-b573c3e2]{display:none}.print-header[data-v-b573c3e2]{align-items:center;gap:16px;margin-bottom:16px;display:flex}.print-logo[data-v-b573c3e2]{object-fit:contain;width:60px;height:60px}.print-school-name[data-v-b573c3e2]{font-size:18px;font-weight:700}.print-school-sub[data-v-b573c3e2]{color:#666;font-size:13px}.print-title[data-v-b573c3e2]{text-align:center;text-transform:uppercase;letter-spacing:1px;margin:12px 0 8px;font-size:14px;font-weight:700}.print-summary[data-v-b573c3e2]{justify-content:center;gap:24px;margin-bottom:12px;font-size:12px;display:flex}.print-table[data-v-b573c3e2]{border-collapse:collapse;width:100%;font-size:12px}.print-table th[data-v-b573c3e2],.print-table td[data-v-b573c3e2]{border:1px solid #ccc;padding:6px 8px}.print-table th[data-v-b573c3e2]{background:#f0f0f0;font-weight:600}.print-table tfoot td[data-v-b573c3e2]{background:#f5f5f5;font-weight:700}.print-table .right[data-v-b573c3e2]{text-align:right}.login-container[data-v-ab4b1f17]{background:var(--bg-color,#f4f7fe);z-index:9999;justify-content:center;align-items:center;width:100vw;min-height:100vh;display:flex;position:fixed;top:0;left:0}.login-card[data-v-ab4b1f17]{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px;box-shadow:0 10px 25px #0000000d}.login-header[data-v-ab4b1f17]{text-align:center;margin-bottom:30px}.logo[data-v-ab4b1f17]{object-fit:contain;width:80px;height:80px;margin:0 auto 16px;display:block}.login-header h2[data-v-ab4b1f17]{color:#1a202c;margin-bottom:4px;font-size:20px;font-weight:700}.login-header p[data-v-ab4b1f17]{color:#718096;font-size:14px}.form-group[data-v-ab4b1f17]{margin-bottom:20px}.form-group label[data-v-ab4b1f17]{color:#4a5568;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.form-control[data-v-ab4b1f17]{box-sizing:border-box;border:1px solid #e2e8f0;border-radius:8px;width:100%;padding:12px 16px;font-size:14px;transition:all .2s}.form-control[data-v-ab4b1f17]:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f11a}.btn-block[data-v-ab4b1f17]{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:8px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:background .2s}.btn-block[data-v-ab4b1f17]:hover:not(:disabled){background:#4f46e5}.btn-block[data-v-ab4b1f17]:disabled{opacity:.7;cursor:not-allowed}.alert-error[data-v-ab4b1f17]{color:#b91c1c;text-align:center;background:#fee2e2;border-radius:8px;margin-bottom:20px;padding:12px;font-size:13px}.forgot-link[data-v-ab4b1f17]{color:var(--primary,#6366f1);font-size:12px;font-weight:500;text-decoration:none}.forgot-link[data-v-ab4b1f17]:hover{text-decoration:underline}.page-container[data-v-602159fc]{max-width:1400px;margin:0 auto;padding:32px 40px;animation:.4s fade-in-602159fc}@keyframes fade-in-602159fc{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header[data-v-602159fc]{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.header-content h1[data-v-602159fc]{color:var(--text-1);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.subtitle[data-v-602159fc]{color:var(--text-2);font-size:15px}.btn[data-v-602159fc]{cursor:pointer;transition:all var(--transition);border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;display:inline-flex}.btn svg[data-v-602159fc]{width:16px;height:16px}.btn-primary[data-v-602159fc]{background:var(--primary);color:#fff}.btn-primary[data-v-602159fc]:hover:not(:disabled){background:var(--primary-hover)}.btn-outline[data-v-602159fc]{background:var(--surface);border:1px solid var(--border);color:var(--text-2)}.btn-outline[data-v-602159fc]:hover{background:var(--surface-3);color:var(--text-1)}.card[data-v-602159fc]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.table-wrap[data-v-602159fc]{overflow-x:auto}.data-table[data-v-602159fc]{border-collapse:collapse;width:100%;font-size:13px}.data-table th[data-v-602159fc]{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--surface-2);padding:14px 20px;font-size:12px;font-weight:600}.data-table td[data-v-602159fc]{border-bottom:1px solid var(--border);color:var(--text-1);vertical-align:middle;padding:16px 20px}.table-row[data-v-602159fc]:hover{background:var(--surface-2)}.table-row:last-child td[data-v-602159fc]{border-bottom:none}.right[data-v-602159fc]{text-align:right}.user-cell[data-v-602159fc]{align-items:center;gap:12px;display:flex}.user-avatar-sm[data-v-602159fc]{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.user-nm[data-v-602159fc]{font-size:14px;font-weight:600}.role-badges[data-v-602159fc]{flex-wrap:wrap;gap:6px;display:flex}.badge[data-v-602159fc]{border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600}.badge-primary[data-v-602159fc]{background:var(--primary-light);color:var(--primary)}.badge-secondary[data-v-602159fc]{background:var(--surface-3);color:var(--text-2)}.action-btn[data-v-602159fc]{cursor:pointer;color:var(--text-3);background:0 0;border:none;border-radius:6px;padding:6px;transition:all .2s}.action-btn[data-v-602159fc]:hover{background:var(--surface-3);color:var(--text-1)}.edit-btn[data-v-602159fc]:hover{color:#3b82f6;background:#dbeafe}.delete-btn[data-v-602159fc]:hover{color:#ef4444;background:#fee2e2}.action-btn svg[data-v-602159fc]{width:18px;height:18px}.modal-overlay[data-v-602159fc]{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0006;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.modal-content[data-v-602159fc]{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-lg);padding:32px;animation:.3s cubic-bezier(.16,1,.3,1) modal-up-602159fc}@keyframes modal-up-602159fc{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header[data-v-602159fc]{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h2[data-v-602159fc]{color:var(--text-1);font-size:20px;font-weight:700}.close-btn[data-v-602159fc]{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:4px;font-size:28px;line-height:1}.close-btn[data-v-602159fc]:hover{color:var(--text-1);background:var(--surface-3)}.form-group[data-v-602159fc]{margin-bottom:20px}.form-group label[data-v-602159fc]{color:var(--text-2);margin-bottom:8px;font-size:13px;font-weight:600;display:block}.form-control[data-v-602159fc]{border:1px solid var(--border);width:100%;color:var(--text-1);background:var(--surface);box-sizing:border-box;border-radius:8px;padding:10px 14px;font-size:14px;transition:all .2s}.form-control[data-v-602159fc]:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.role-checkboxes[data-v-602159fc]{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:10px;max-height:150px;padding:16px;display:flex;overflow-y:auto}.checkbox-label[data-v-602159fc]{color:var(--text-1);cursor:pointer;align-items:center;gap:8px;font-size:14px;display:flex}.checkbox-label input[type=checkbox][data-v-602159fc]{width:16px;height:16px;accent-color:var(--primary)}.modal-footer[data-v-602159fc]{justify-content:flex-end;gap:12px;margin-top:32px;display:flex}.phone-input-wrap[data-v-602159fc]{border:1px solid var(--border);border-radius:8px;transition:all .2s;display:flex;overflow:hidden}.phone-input-wrap[data-v-602159fc]:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.phone-prefix[data-v-602159fc]{background:var(--surface-2);color:var(--text-2);border-right:1px solid var(--border);white-space:nowrap;padding:10px 12px;font-size:14px;font-weight:600}.phone-field[data-v-602159fc]{border-radius:0;flex:1;box-shadow:none!important;border:none!important}.phone-field[data-v-602159fc]:focus{outline:none;box-shadow:none!important}.hint[data-v-602159fc]{color:var(--text-3);font-size:11px;font-weight:400}.nohp-cell[data-v-602159fc]{color:var(--text-1);align-items:center;gap:4px;font-size:13px;display:inline-flex}.nohp-empty[data-v-602159fc]{color:var(--text-3);font-size:13px}.rp-container[data-v-b9532d66]{background:var(--surface-2);height:100vh;animation:.3s fade-in-b9532d66;display:flex;overflow:hidden}@keyframes fade-in-b9532d66{0%{opacity:0}to{opacity:1}}.panel-left[data-v-b9532d66]{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:300px;display:flex;overflow:hidden}.panel-left-header[data-v-b9532d66]{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;padding:28px 20px 16px;display:flex}.panel-left-header h1[data-v-b9532d66]{color:var(--text-1);margin-bottom:2px;font-size:18px;font-weight:800}.panel-left-header p[data-v-b9532d66]{color:var(--text-3);font-size:12px}.btn-add[data-v-b9532d66]{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:background .2s;display:flex}.btn-add[data-v-b9532d66]:hover{background:var(--primary-dark)}.btn-add svg[data-v-b9532d66]{width:16px;height:16px}.role-list[data-v-b9532d66]{flex:1;padding:8px;overflow-y:auto}.role-item[data-v-b9532d66]{cursor:pointer;border:1px solid #0000;border-radius:10px;align-items:center;gap:12px;margin-bottom:2px;padding:12px;transition:all .15s;display:flex}.role-item[data-v-b9532d66]:hover{background:var(--surface-2)}.role-item.active[data-v-b9532d66]{background:var(--primary-light);border-color:#6366f133}.role-item-icon[data-v-b9532d66]{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.role-item-icon svg[data-v-b9532d66]{width:18px;height:18px}.color-red[data-v-b9532d66]{color:#dc2626;background:#fee2e2}.color-blue[data-v-b9532d66]{color:#2563eb;background:#dbeafe}.color-green[data-v-b9532d66]{color:#059669;background:#d1fae5}.color-purple[data-v-b9532d66]{color:#7c3aed;background:#ede9fe}.color-orange[data-v-b9532d66]{color:#d97706;background:#fef3c7}.color-indigo[data-v-b9532d66]{color:#6366f1;background:#eef2ff}.role-item-info[data-v-b9532d66]{flex:1;min-width:0}.role-item-name[data-v-b9532d66]{color:var(--text-1);font-size:14px;font-weight:600;display:block}.role-item-count[data-v-b9532d66]{color:var(--text-3);font-size:11px}.role-item-arrow svg[data-v-b9532d66]{width:14px;height:14px;color:var(--text-3)}.role-item.active .role-item-arrow svg[data-v-b9532d66]{color:var(--primary)}.empty-roles[data-v-b9532d66]{text-align:center;color:var(--text-3);padding:40px 20px}.empty-roles svg[data-v-b9532d66]{opacity:.4;width:40px;height:40px;margin-bottom:8px}.empty-roles p[data-v-b9532d66]{font-size:13px}.panel-right[data-v-b9532d66]{flex-direction:column;flex:1;display:flex;overflow:hidden}.empty-detail[data-v-b9532d66]{color:var(--text-3);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.empty-detail-icon[data-v-b9532d66]{background:var(--surface-3);border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:8px;display:flex}.empty-detail-icon svg[data-v-b9532d66]{opacity:.4;width:32px;height:32px}.empty-detail h3[data-v-b9532d66]{color:var(--text-2);font-size:18px;font-weight:700}.empty-detail p[data-v-b9532d66]{text-align:center;max-width:300px;font-size:14px;line-height:1.6}.detail-header[data-v-b9532d66]{border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:16px;padding:28px 32px 20px;display:flex}.detail-header-left[data-v-b9532d66]{flex:1;align-items:center;gap:16px;display:flex}.detail-icon[data-v-b9532d66]{border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.detail-icon svg[data-v-b9532d66]{width:24px;height:24px}.detail-header-left h2[data-v-b9532d66]{color:var(--text-1);margin-bottom:2px;font-size:22px;font-weight:800}.detail-header-left p[data-v-b9532d66]{color:var(--text-3);font-size:13px}.detail-actions[data-v-b9532d66]{gap:8px;display:flex}.btn-edit[data-v-b9532d66]{background:var(--surface-3);border:1px solid var(--border);color:var(--text-2);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn-edit svg[data-v-b9532d66]{width:14px;height:14px}.btn-edit[data-v-b9532d66]:hover{color:#2563eb;background:#dbeafe;border-color:#bfdbfe}.btn-delete[data-v-b9532d66]{background:var(--surface-3);border:1px solid var(--border);color:var(--text-2);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn-delete svg[data-v-b9532d66]{width:14px;height:14px}.btn-delete[data-v-b9532d66]:hover{color:#dc2626;background:#fee2e2;border-color:#fecaca}.badge-superadmin[data-v-b9532d66]{color:#b45309;background:#fef3c7;border:1px solid #fde68a;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:700;display:inline-flex}.badge-superadmin svg[data-v-b9532d66]{width:14px;height:14px}.superadmin-notice[data-v-b9532d66]{color:#9a3412;background:#fff7ed;border:1px solid #fed7aa;border-radius:10px;align-items:center;gap:10px;margin:20px 32px;padding:14px 16px;font-size:13px;display:flex}.superadmin-notice svg[data-v-b9532d66]{flex-shrink:0;width:18px;height:18px}.perm-matrix[data-v-b9532d66]{flex-direction:column;flex:1;padding:24px 32px;display:flex;overflow:hidden}.perm-matrix-header[data-v-b9532d66]{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.perm-matrix-header>span[data-v-b9532d66]{color:var(--text-1);font-size:14px;font-weight:700}.perm-search[data-v-b9532d66]{background:var(--surface-3);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:7px 12px;display:flex}.perm-search svg[data-v-b9532d66]{width:14px;height:14px;color:var(--text-3);flex-shrink:0}.perm-search input[data-v-b9532d66]{color:var(--text-1);background:0 0;border:none;outline:none;width:180px;font-size:13px}.perm-grid[data-v-b9532d66]{flex:1;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;padding-bottom:8px;display:grid;overflow-y:auto}.perm-toggle[data-v-b9532d66]{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:12px 14px;transition:all .15s;display:flex}.perm-toggle[data-v-b9532d66]:hover,.perm-toggle.checked[data-v-b9532d66]{border-color:var(--primary);background:var(--primary-light)}.perm-toggle input[data-v-b9532d66]{display:none}.toggle-track[data-v-b9532d66]{background:var(--border);border-radius:20px;flex-shrink:0;width:36px;height:20px;transition:background .2s;position:relative}.perm-toggle.checked .toggle-track[data-v-b9532d66]{background:var(--primary)}.toggle-thumb[data-v-b9532d66]{background:#fff;border-radius:50%;width:14px;height:14px;transition:left .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.perm-toggle.checked .toggle-thumb[data-v-b9532d66]{left:19px}.perm-name[data-v-b9532d66]{color:var(--text-1);flex:1;font-size:13px;font-weight:500}.perm-toggle.checked .perm-name[data-v-b9532d66]{color:var(--primary);font-weight:600}.perm-empty[data-v-b9532d66]{text-align:center;color:var(--text-3);grid-column:1/-1;padding:30px;font-size:13px}.perm-save-bar[data-v-b9532d66]{background:linear-gradient(135deg,#1e1b4b,#312e81);border-radius:12px;justify-content:space-between;align-items:center;margin-top:16px;padding:14px 20px;animation:.2s slide-up-b9532d66;display:flex}@keyframes slide-up-b9532d66{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.perm-save-bar>span[data-v-b9532d66]{color:#c7d2fe;font-size:13px;font-weight:600}.save-bar-actions[data-v-b9532d66]{gap:8px;display:flex}.btn-cancel[data-v-b9532d66]{color:#a5b4fc;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;transition:all .15s}.btn-cancel[data-v-b9532d66]:hover{background:#fff3}.btn-save[data-v-b9532d66]{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:7px 16px;font-size:13px;font-weight:700;transition:all .15s;display:inline-flex}.btn-save svg[data-v-b9532d66]{width:14px;height:14px}.btn-save[data-v-b9532d66]:hover:not(:disabled){background:var(--primary-dark)}.btn-save[data-v-b9532d66]:disabled{opacity:.6;cursor:not-allowed}.modal-overlay[data-v-b9532d66]{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box[data-v-b9532d66]{background:var(--surface);width:100%;max-width:440px;box-shadow:var(--shadow-lg);border-radius:16px;padding:28px;animation:.25s cubic-bezier(.16,1,.3,1) modal-in-b9532d66}@keyframes modal-in-b9532d66{0%{opacity:0;transform:scale(.94)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-title[data-v-b9532d66]{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-title h3[data-v-b9532d66]{color:var(--text-1);font-size:18px;font-weight:800}.modal-close[data-v-b9532d66]{background:var(--surface-3);width:30px;height:30px;color:var(--text-3);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:20px;line-height:1;display:flex}.modal-close[data-v-b9532d66]:hover{color:var(--text-1)}.field[data-v-b9532d66]{margin-bottom:20px}.field label[data-v-b9532d66]{color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:700;display:block}.field input[data-v-b9532d66]{border:1px solid var(--border);width:100%;color:var(--text-1);background:var(--surface);box-sizing:border-box;border-radius:8px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.field input[data-v-b9532d66]:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.modal-footer[data-v-b9532d66]{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;margin-top:24px;padding-top:20px;display:flex}.mp-page[data-v-69b28d76]{max-width:900px;margin:0 auto;padding:32px 40px;animation:.3s fi-69b28d76}@keyframes fi-69b28d76{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mp-header[data-v-69b28d76]{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.mp-header h1[data-v-69b28d76]{color:var(--text-1);margin-bottom:4px;font-size:24px;font-weight:800}.mp-header p[data-v-69b28d76]{color:var(--text-3);font-size:14px}.btn-add[data-v-69b28d76]{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;transition:background .2s;display:inline-flex}.btn-add[data-v-69b28d76]:hover{background:var(--primary-dark)}.btn-add svg[data-v-69b28d76]{width:16px;height:16px}.add-card[data-v-69b28d76]{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:14px;margin-bottom:20px;padding:24px}.add-card h3[data-v-69b28d76]{color:var(--text-1);margin-bottom:4px;font-size:16px;font-weight:700}.hint[data-v-69b28d76]{color:var(--text-3);margin-bottom:16px;font-size:13px}.hint code[data-v-69b28d76]{background:var(--surface-3);color:var(--primary);border-radius:4px;padding:2px 6px;font-family:monospace}.add-form[data-v-69b28d76]{align-items:center;gap:10px;display:flex}.add-form input[data-v-69b28d76]{border:1px solid var(--border);color:var(--text-1);background:var(--surface);border-radius:8px;outline:none;flex:1;padding:10px 14px;font-family:monospace;font-size:14px;transition:border-color .15s}.add-form input[data-v-69b28d76]:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.btn-save[data-v-69b28d76]{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:background .2s}.btn-save[data-v-69b28d76]:hover:not(:disabled){background:var(--primary-dark)}.btn-save[data-v-69b28d76]:disabled{opacity:.6;cursor:not-allowed}.btn-cancel[data-v-69b28d76]{background:var(--surface-3);border:1px solid var(--border);color:var(--text-2);cursor:pointer;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:600}.btn-cancel[data-v-69b28d76]:hover{background:var(--surface-2)}.err-msg[data-v-69b28d76]{color:#dc2626;background:#fee2e2;border-radius:8px;margin-top:10px;padding:8px 12px;font-size:13px}.table-card[data-v-69b28d76]{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:14px;overflow:hidden}.table-toolbar[data-v-69b28d76]{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.search-box[data-v-69b28d76]{background:var(--surface-3);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:8px 12px;display:flex}.search-box svg[data-v-69b28d76]{width:14px;height:14px;color:var(--text-3)}.search-box input[data-v-69b28d76]{color:var(--text-1);background:0 0;border:none;outline:none;width:200px;font-size:13px}.count-badge[data-v-69b28d76]{color:var(--text-3);background:var(--surface-3);border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}table[data-v-69b28d76]{border-collapse:collapse;width:100%}thead[data-v-69b28d76]{background:var(--surface-2)}th[data-v-69b28d76]{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;padding:12px 20px;font-size:11px;font-weight:700}td[data-v-69b28d76]{color:var(--text-1);border-top:1px solid var(--border);padding:14px 20px;font-size:14px}tr:hover td[data-v-69b28d76]{background:var(--surface-2)}.td-no[data-v-69b28d76]{color:var(--text-3);width:40px;font-size:13px}.perm-chip[data-v-69b28d76]{background:var(--surface-3);border:1px solid var(--border);color:var(--primary);border-radius:6px;padding:4px 10px;font-family:monospace;font-size:13px;font-weight:600}.roles-count[data-v-69b28d76]{border-radius:20px;padding:4px 10px;font-size:12px;font-weight:700}.roles-count.used[data-v-69b28d76]{color:#15803d;background:#dcfce7}.roles-count.unused[data-v-69b28d76]{background:var(--surface-3);color:var(--text-3)}.btn-del[data-v-69b28d76]{cursor:pointer;color:var(--text-3);background:0 0;border:none;border-radius:6px;padding:6px;transition:all .15s}.btn-del[data-v-69b28d76]:hover{color:#dc2626;background:#fee2e2}.btn-del svg[data-v-69b28d76]{width:16px;height:16px}.state-msg[data-v-69b28d76]{text-align:center;color:var(--text-3);padding:48px;font-size:14px}.page-container[data-v-7d58446f]{max-width:1200px;margin:0 auto;padding:32px 40px;animation:.4s ease-out fade-in-7d58446f}.page-header[data-v-7d58446f]{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.header-content h1[data-v-7d58446f]{color:var(--text-1);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.subtitle[data-v-7d58446f]{color:var(--text-2);font-size:15px}.header-actions[data-v-7d58446f]{gap:12px;display:flex}.btn[data-v-7d58446f]{cursor:pointer;transition:all var(--transition);border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;display:inline-flex}.btn svg[data-v-7d58446f]{width:18px;height:18px}.btn-primary[data-v-7d58446f]{background:var(--primary);color:#fff;box-shadow:0 4px 12px #6366f140}.btn-primary[data-v-7d58446f]:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 16px #6366f14d}.btn-primary[data-v-7d58446f]:disabled{background:var(--text-3);cursor:not-allowed;box-shadow:none;transform:none}.btn-outline[data-v-7d58446f]{color:var(--text-2);border:1px solid var(--border);background:0 0}.btn-outline[data-v-7d58446f]:hover{background:var(--surface-3);color:var(--text-1)}.btn-danger[data-v-7d58446f]{background:var(--danger);color:#fff}.btn-danger[data-v-7d58446f]:hover{background:#dc2626}.w-full[data-v-7d58446f]{justify-content:center;width:100%}.filters-section[data-v-7d58446f]{justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.search-box[data-v-7d58446f]{flex:1;max-width:400px;position:relative}.search-box svg[data-v-7d58446f]{width:18px;height:18px;color:var(--text-3);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-box input[data-v-7d58446f]{border:1px solid var(--border);width:100%;color:var(--text-1);background:var(--surface);transition:all var(--transition);border-radius:10px;padding:12px 16px 12px 42px;font-size:14px}.search-box input[data-v-7d58446f]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.table-container[data-v-7d58446f]{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:24px;overflow:hidden}.data-table[data-v-7d58446f]{border-collapse:collapse;width:100%}.data-table th[data-v-7d58446f],.data-table td[data-v-7d58446f]{text-align:left;padding:16px 24px}.data-table th[data-v-7d58446f]{color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:#f8fafc;font-size:13px;font-weight:600}.table-row[data-v-7d58446f]{border-bottom:1px solid var(--border);transition:background var(--transition)}.table-row[data-v-7d58446f]:last-child{border-bottom:none}.table-row[data-v-7d58446f]:hover{background:#f8fafc}.class-info[data-v-7d58446f]{align-items:center;gap:14px;display:flex}.class-avatar[data-v-7d58446f]{color:#fff;border-radius:10px;justify-content:center;align-items:center;width:42px;height:42px;font-size:16px;font-weight:700;display:flex}.avatar-0[data-v-7d58446f]{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.avatar-1[data-v-7d58446f]{background:linear-gradient(135deg,#10b981,#059669)}.avatar-2[data-v-7d58446f]{background:linear-gradient(135deg,#f59e0b,#d97706)}.class-name[data-v-7d58446f]{color:var(--text-1);font-size:15px;font-weight:600}.wali-kelas[data-v-7d58446f]{color:var(--text-1);font-weight:500}.student-count[data-v-7d58446f]{background:var(--surface-3);color:var(--text-2);border-radius:6px;padding:4px 10px;font-size:13px;font-weight:600;display:inline-block}.action-buttons[data-v-7d58446f]{gap:8px;display:flex}.btn-icon[data-v-7d58446f]{cursor:pointer;width:34px;height:34px;transition:all var(--transition);color:var(--text-3);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.btn-icon[data-v-7d58446f]:hover{background:var(--surface-3)}.btn-icon.edit[data-v-7d58446f]:hover{color:var(--primary);background:var(--primary-light)}.btn-icon.delete[data-v-7d58446f]:hover{color:var(--danger);background:#fee2e2}.btn-icon svg[data-v-7d58446f]{width:18px;height:18px}.empty-state[data-v-7d58446f]{text-align:center;padding:48px 24px}.empty-content[data-v-7d58446f]{color:var(--text-3);flex-direction:column;align-items:center;gap:16px;display:flex}.empty-content svg[data-v-7d58446f]{opacity:.5;width:48px;height:48px}.form-grid[data-v-7d58446f]{grid-template-columns:1fr;gap:20px;display:grid}.form-group[data-v-7d58446f]{flex-direction:column;gap:8px;display:flex}.form-group label[data-v-7d58446f]{color:var(--text-1);font-size:14px;font-weight:600}.required[data-v-7d58446f]{color:var(--danger)}.form-input[data-v-7d58446f]{border:1px solid var(--border);transition:all var(--transition);border-radius:8px;padding:10px 14px;font-family:inherit;font-size:14px}.form-input[data-v-7d58446f]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.delete-icon[data-v-7d58446f]{width:64px;height:64px;color:var(--danger);background:#fee2e2;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.delete-icon svg[data-v-7d58446f]{width:32px;height:32px}.delete-title[data-v-7d58446f]{color:var(--text-1);margin-bottom:12px;font-size:20px;font-weight:700}.delete-desc[data-v-7d58446f]{color:var(--text-2);margin-bottom:24px;font-size:14px;line-height:1.5}@keyframes fade-in-7d58446f{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-container[data-v-05b26ff9]{max-width:1200px;margin:0 auto;padding:32px 40px;animation:.4s ease-out fade-in-05b26ff9}.page-header[data-v-05b26ff9]{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.header-content h1[data-v-05b26ff9]{color:var(--text-1);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.subtitle[data-v-05b26ff9]{color:var(--text-2);font-size:15px}.header-actions[data-v-05b26ff9]{gap:12px;display:flex}.btn[data-v-05b26ff9]{cursor:pointer;transition:all var(--transition);border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;display:inline-flex}.btn svg[data-v-05b26ff9]{width:18px;height:18px}.btn-primary[data-v-05b26ff9]{background:var(--primary);color:#fff;box-shadow:0 4px 12px #6366f140}.btn-primary[data-v-05b26ff9]:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 16px #6366f14d}.btn-primary[data-v-05b26ff9]:disabled{background:var(--text-3);cursor:not-allowed;box-shadow:none;transform:none}.btn-outline[data-v-05b26ff9]{color:var(--text-2);border:1px solid var(--border);background:0 0}.btn-outline[data-v-05b26ff9]:hover{background:var(--surface-3);color:var(--text-1)}.btn-danger[data-v-05b26ff9]{background:var(--danger);color:#fff}.btn-danger[data-v-05b26ff9]:hover{background:#dc2626}.w-full[data-v-05b26ff9]{justify-content:center;width:100%}.filters-section[data-v-05b26ff9]{justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.search-box[data-v-05b26ff9]{flex:1;max-width:400px;position:relative}.search-box svg[data-v-05b26ff9]{width:18px;height:18px;color:var(--text-3);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-box input[data-v-05b26ff9]{border:1px solid var(--border);width:100%;color:var(--text-1);background:var(--surface);transition:all var(--transition);border-radius:10px;padding:12px 16px 12px 42px;font-size:14px}.search-box input[data-v-05b26ff9]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.table-container[data-v-05b26ff9]{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:24px;overflow:hidden}.data-table[data-v-05b26ff9]{border-collapse:collapse;width:100%}.data-table th[data-v-05b26ff9],.data-table td[data-v-05b26ff9]{text-align:left;padding:16px 24px}.data-table th[data-v-05b26ff9]{color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:#f8fafc;font-size:13px;font-weight:600}.table-row[data-v-05b26ff9]{border-bottom:1px solid var(--border);transition:background var(--transition)}.table-row[data-v-05b26ff9]:last-child{border-bottom:none}.table-row[data-v-05b26ff9]:hover{background:#f8fafc}.jurusan-code-badge[data-v-05b26ff9]{letter-spacing:.5px;color:#fff;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:700;display:inline-flex}.badge-0[data-v-05b26ff9]{background:linear-gradient(135deg,#3b82f6,#2563eb)}.badge-1[data-v-05b26ff9]{background:linear-gradient(135deg,#10b981,#059669)}.badge-2[data-v-05b26ff9]{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.jurusan-name[data-v-05b26ff9]{color:var(--text-1);font-size:15px;font-weight:600}.kajur-info[data-v-05b26ff9]{color:var(--text-2);align-items:center;gap:8px;font-size:14px;display:flex}.kajur-info svg[data-v-05b26ff9]{width:16px;height:16px;color:var(--text-3)}.action-buttons[data-v-05b26ff9]{gap:8px;display:flex}.btn-icon[data-v-05b26ff9]{cursor:pointer;width:34px;height:34px;transition:all var(--transition);color:var(--text-3);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.btn-icon[data-v-05b26ff9]:hover{background:var(--surface-3)}.btn-icon.edit[data-v-05b26ff9]:hover{color:var(--primary);background:var(--primary-light)}.btn-icon.delete[data-v-05b26ff9]:hover{color:var(--danger);background:#fee2e2}.btn-icon svg[data-v-05b26ff9]{width:18px;height:18px}.empty-state[data-v-05b26ff9]{text-align:center;padding:48px 24px}.empty-content[data-v-05b26ff9]{color:var(--text-3);flex-direction:column;align-items:center;gap:16px;display:flex}.empty-content svg[data-v-05b26ff9]{opacity:.5;width:48px;height:48px}.form-grid[data-v-05b26ff9]{grid-template-columns:1fr;gap:20px;display:grid}.form-group[data-v-05b26ff9]{flex-direction:column;gap:8px;display:flex}.form-group label[data-v-05b26ff9]{color:var(--text-1);font-size:14px;font-weight:600}.required[data-v-05b26ff9]{color:var(--danger)}.form-input[data-v-05b26ff9]{border:1px solid var(--border);transition:all var(--transition);border-radius:8px;padding:10px 14px;font-family:inherit;font-size:14px}.form-input[data-v-05b26ff9]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.delete-icon[data-v-05b26ff9]{width:64px;height:64px;color:var(--danger);background:#fee2e2;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.delete-icon svg[data-v-05b26ff9]{width:32px;height:32px}.delete-title[data-v-05b26ff9]{color:var(--text-1);margin-bottom:12px;font-size:20px;font-weight:700}.delete-desc[data-v-05b26ff9]{color:var(--text-2);margin-bottom:24px;font-size:14px;line-height:1.5}@keyframes fade-in-05b26ff9{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-container[data-v-24e0d62a]{max-width:1000px;margin:0 auto;padding:32px}.page-header[data-v-24e0d62a]{margin-bottom:32px}.page-title[data-v-24e0d62a]{color:var(--text-1);margin-bottom:4px;font-size:24px;font-weight:700}.page-subtitle[data-v-24e0d62a]{color:var(--text-2);font-size:14px}.settings-content[data-v-24e0d62a]{flex-direction:column;gap:24px;display:flex}.setting-card[data-v-24e0d62a]{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:hidden}.setting-card-header[data-v-24e0d62a]{border-bottom:1px solid var(--border);background:var(--surface-2);align-items:flex-start;gap:16px;padding:24px;display:flex}.setting-icon[data-v-24e0d62a]{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.setting-icon svg[data-v-24e0d62a]{width:24px;height:24px}.waha-icon[data-v-24e0d62a]{color:var(--success);background:#10b9811a}.setting-title-wrapper[data-v-24e0d62a]{flex:1}.setting-card-title[data-v-24e0d62a]{color:var(--text-1);align-items:center;gap:8px;margin-bottom:4px;font-size:16px;font-weight:600;display:flex}.setting-card-desc[data-v-24e0d62a]{color:var(--text-2);font-size:13px;line-height:1.5}.setting-form[data-v-24e0d62a]{padding:24px}.form-grid[data-v-24e0d62a]{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;display:grid}@media (width<=768px){.form-grid[data-v-24e0d62a]{grid-template-columns:1fr;gap:16px}}.form-group[data-v-24e0d62a]{margin-bottom:20px}.form-group[data-v-24e0d62a]:last-child{margin-bottom:0}.form-label[data-v-24e0d62a]{color:var(--text-1);margin-bottom:8px;font-size:13px;font-weight:600;display:block}.required[data-v-24e0d62a]{color:var(--danger);margin-left:4px}.form-control[data-v-24e0d62a]{background:var(--surface-2);border:1px solid var(--border);width:100%;height:42px;color:var(--text-1);border-radius:8px;padding:0 12px;font-family:inherit;font-size:14px;transition:all .2s}.form-control[data-v-24e0d62a]:focus{border-color:var(--primary);background:var(--surface);outline:none;box-shadow:0 0 0 3px #6366f11a}.form-help[data-v-24e0d62a]{color:var(--text-3);margin-top:6px;font-size:12px;line-height:1.4}.input-with-icon[data-v-24e0d62a]{position:relative}.input-with-icon .form-control[data-v-24e0d62a]{padding-right:40px}.icon-btn[data-v-24e0d62a]{width:34px;color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:4px;bottom:4px;right:4px}.icon-btn[data-v-24e0d62a]:hover{background:var(--surface-3);color:var(--text-1)}.icon-btn svg[data-v-24e0d62a]{width:16px;height:16px}.form-actions[data-v-24e0d62a]{border-top:1px solid var(--border);justify-content:flex-end;margin-top:24px;padding-top:24px;display:flex}.btn-save[data-v-24e0d62a]{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;height:42px;padding:0 20px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.btn-save[data-v-24e0d62a]:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.btn-save[data-v-24e0d62a]:active:not(:disabled){transform:translateY(0)}.btn-save[data-v-24e0d62a]:disabled{opacity:.7;cursor:not-allowed}.btn-save svg[data-v-24e0d62a]{width:16px;height:16px}.spinner[data-v-24e0d62a]{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin-24e0d62a}@keyframes spin-24e0d62a{to{transform:rotate(360deg)}}.toast-container[data-v-24e0d62a]{z-index:1000;pointer-events:none;opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);position:fixed;bottom:24px;right:24px;transform:translateY(20px)}.toast-show[data-v-24e0d62a]{opacity:1;transform:translateY(0)}.toast-message[data-v-24e0d62a]{background:#fff;border-radius:8px;align-items:center;gap:10px;padding:12px 20px;font-size:14px;font-weight:500;display:flex;box-shadow:0 4px 12px #00000026}.toast-message.success[data-v-24e0d62a]{border-left:4px solid var(--success)}.toast-message.success svg[data-v-24e0d62a]{color:var(--success)}.toast-message.error[data-v-24e0d62a]{border-left:4px solid var(--danger)}.toast-message.error svg[data-v-24e0d62a]{color:var(--danger)}.toast-message svg[data-v-24e0d62a]{width:18px;height:18px}.page-container[data-v-53a87539]{max-width:1100px;margin:0 auto;padding:32px 40px;animation:.4s ease-out fade-in-53a87539}@keyframes fade-in-53a87539{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-header[data-v-53a87539]{margin-bottom:16px}.page-header h1[data-v-53a87539]{color:var(--text-1);align-items:center;gap:10px;margin-bottom:6px;font-size:26px;font-weight:800;display:flex}.page-header h1 svg[data-v-53a87539]{color:#10b981;width:28px;height:28px}.subtitle[data-v-53a87539]{color:var(--text-2);font-size:15px}.waha-status[data-v-53a87539]{border:1px solid var(--border);background:var(--surface);border-radius:8px;align-items:center;gap:8px;margin-bottom:20px;padding:7px 14px;font-size:13px;font-weight:600;transition:all .3s;display:inline-flex}.waha-status.ok[data-v-53a87539]{color:#15803d;background:#f0fdf4;border-color:#86efac}.waha-status.error[data-v-53a87539]{color:#b91c1c;background:#fef2f2;border-color:#fca5a5}.waha-status.checking[data-v-53a87539]{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.ws-text[data-v-53a87539]{flex:1}.waha-dot[data-v-53a87539]{background:var(--border);border-radius:50%;flex-shrink:0;width:8px;height:8px}.waha-dot.ok[data-v-53a87539]{background:#22c55e}.waha-dot.error[data-v-53a87539]{background:#ef4444}.waha-dot.checking[data-v-53a87539]{background:#3b82f6;animation:.8s infinite pulse-53a87539}@keyframes pulse-53a87539{0%,to{opacity:1}50%{opacity:.3}}.btn-test[data-v-53a87539]{background:var(--surface-3);border:1px solid var(--border);color:var(--text-2);cursor:pointer;border-radius:5px;padding:4px 10px;font-size:11px;font-weight:600}.btn-test[data-v-53a87539]:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.btn-test[data-v-53a87539]:disabled{opacity:.5;cursor:not-allowed}.tabs[data-v-53a87539]{gap:12px;margin-bottom:24px;display:flex}.tab-btn[data-v-53a87539]{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text-2);transition:all var(--transition);flex-direction:column;flex:1;align-items:flex-start;gap:4px;padding:16px 18px;font-size:14px;font-weight:700;display:flex}.tab-btn svg[data-v-53a87539]{width:18px;height:18px;margin-bottom:2px}.tab-btn .tab-desc[data-v-53a87539]{color:var(--text-3);font-size:11px;font-weight:400}.tab-btn.active[data-v-53a87539]{border-color:var(--primary);color:var(--primary);background:#eef2ff}.tab-btn.active .tab-desc[data-v-53a87539]{color:#818cf8}.tab-btn[data-v-53a87539]:hover:not(.active){border-color:var(--primary);color:var(--text-1)}.panel[data-v-53a87539]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:24px}.panel-body[data-v-53a87539]{padding:24px}.form-group[data-v-53a87539]{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.form-group label[data-v-53a87539]{color:var(--text-1);font-size:13px;font-weight:600}.form-select[data-v-53a87539]{border:1px solid var(--border);background:var(--surface);color:var(--text-1);cursor:pointer;border-radius:8px;padding:11px 14px;font-size:14px}.form-select[data-v-53a87539]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.info-box[data-v-53a87539]{border-radius:10px;margin-top:4px;padding:16px}.loading-box[data-v-53a87539]{background:var(--surface-2);color:var(--text-2);align-items:center;gap:10px;font-size:13px;display:flex}.success-box[data-v-53a87539]{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0;align-items:center;gap:10px;font-size:13px;font-weight:600;display:flex}.success-box svg[data-v-53a87539]{width:20px;height:20px}.target-box[data-v-53a87539]{background:var(--surface-2);border:1px solid var(--border)}.target-header[data-v-53a87539]{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.target-count[data-v-53a87539]{color:var(--primary);font-size:22px;font-weight:800}.btn-blast[data-v-53a87539]{color:#fff;cursor:pointer;transition:all var(--transition);background:#10b981;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:700;display:flex}.btn-blast[data-v-53a87539]:hover:not(:disabled){background:#059669}.btn-blast[data-v-53a87539]:disabled{opacity:.6;cursor:not-allowed}.btn-blast svg[data-v-53a87539]{width:16px;height:16px}.progress-area[data-v-53a87539]{margin-bottom:14px}.progress-row[data-v-53a87539]{color:var(--text-1);justify-content:space-between;margin-bottom:6px;font-size:12px;font-weight:600;display:flex}.progress-bar[data-v-53a87539]{background:#e5e7eb;border-radius:10px;height:8px;margin-bottom:8px;overflow:hidden}.progress-fill[data-v-53a87539]{background:#10b981;border-radius:10px;height:100%;transition:width .3s}.status-sending[data-v-53a87539]{color:#d97706;font-size:12px;font-weight:500}.status-done[data-v-53a87539]{color:#059669;font-size:12px;font-weight:600}.target-list[data-v-53a87539]{flex-direction:column;gap:6px;max-height:300px;display:flex;overflow-y:auto}.target-item[data-v-53a87539]{background:var(--surface);border:1px solid var(--border);border-radius:8px;align-items:center;gap:10px;padding:8px 12px;font-size:13px;transition:all .2s;display:flex}.target-item.sent[data-v-53a87539]{background:#f0fdf4;border-color:#a7f3d0}.target-item.failed[data-v-53a87539]{background:#fef2f2;border-color:#fca5a5}.target-item.current[data-v-53a87539]{background:#eef2ff;border-color:#c7d2fe}.target-name[data-v-53a87539]{color:var(--text-1);flex:1;font-weight:600}.target-kelas[data-v-53a87539]{color:var(--text-3);background:var(--surface-3);border-radius:20px;padding:2px 8px;font-size:11px}.target-sisa[data-v-53a87539]{color:var(--danger);font-size:12px;font-weight:600}.target-state[data-v-53a87539]{text-align:center;width:20px}.search-wrapper[data-v-53a87539]{position:relative}.search-wrapper svg[data-v-53a87539]{width:18px;height:18px;color:var(--text-3);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-input[data-v-53a87539]{border:1px solid var(--border);width:100%;color:var(--text-1);background:var(--surface);border-radius:8px;padding:11px 16px 11px 44px;font-size:14px}.search-input[data-v-53a87539]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.dropdown[data-v-53a87539]{border:1px solid var(--border);box-shadow:var(--shadow-md);z-index:100;background:#fff;border-radius:10px;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden}.dropdown-item[data-v-53a87539]{cursor:pointer;transition:background var(--transition);padding:10px 16px}.dropdown-item[data-v-53a87539]:hover{background:var(--surface-2)}.dd-name[data-v-53a87539]{color:var(--text-1);font-size:13px;font-weight:600}.dd-meta[data-v-53a87539]{color:var(--text-3);font-size:11px}.siswa-card[data-v-53a87539]{color:#fff;border-radius:var(--radius);background:linear-gradient(135deg,#4f46e5,#7c3aed);align-items:center;gap:16px;margin-top:16px;padding:20px;display:flex}.siswa-avatar[data-v-53a87539]{background:#ffffff40;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;font-weight:800;display:flex}.siswa-info[data-v-53a87539]{flex:1}.siswa-info h3[data-v-53a87539]{margin-bottom:4px;font-size:16px;font-weight:700}.siswa-meta[data-v-53a87539]{opacity:.85;gap:8px;font-size:12px;display:flex}.siswa-meta span[data-v-53a87539]{background:#fff3;border-radius:20px;padding:2px 10px}.btn-send-pdf[data-v-53a87539]{color:#4f46e5;cursor:pointer;transition:all var(--transition);background:#fff;border:none;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:10px 18px;font-size:13px;font-weight:700;display:flex}.btn-send-pdf svg[data-v-53a87539]{width:16px;height:16px}.btn-send-pdf[data-v-53a87539]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #0003}.btn-send-pdf[data-v-53a87539]:disabled{opacity:.6;cursor:not-allowed}.siswa-msg[data-v-53a87539]{border-radius:8px;margin-top:12px;padding:10px 14px;font-size:13px;font-weight:500}.msg-success[data-v-53a87539]{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0}.msg-error[data-v-53a87539]{color:#991b1b;background:#fef2f2;border:1px solid #fca5a5}.placeholder[data-v-53a87539]{text-align:center;color:var(--text-3);padding:48px 20px}.placeholder svg[data-v-53a87539]{opacity:.2;width:56px;height:56px;margin-bottom:12px}.placeholder p[data-v-53a87539]{font-size:15px}.how-it-works[data-v-53a87539]{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px}.how-it-works h4[data-v-53a87539]{color:var(--text-1);margin-bottom:10px;font-size:13px;font-weight:700}.how-it-works ul[data-v-53a87539]{flex-direction:column;gap:8px;list-style:none;display:flex}.how-it-works li[data-v-53a87539]{color:var(--text-2);border-left:2px solid var(--primary);padding-left:12px;font-size:12px;line-height:1.6}.how-it-works code[data-v-53a87539]{background:var(--surface-3);border-radius:4px;padding:1px 6px;font-size:11px}.spinner[data-v-53a87539]{border:2px solid #6366f133;border-top-color:var(--primary);border-radius:50%;width:18px;height:18px;animation:1s linear infinite spin-53a87539;display:inline-block}.spinner-sm[data-v-53a87539]{border:2px solid #10b9814d;border-top-color:#10b981;border-radius:50%;width:14px;height:14px;animation:1s linear infinite spin-53a87539;display:inline-block}@keyframes spin-53a87539{to{transform:rotate(360deg)}}.bulk-toolbar[data-v-53a87539]{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.bulk-search[data-v-53a87539]{background:var(--surface-3);border:1px solid var(--border);border-radius:8px;flex:1;align-items:center;gap:8px;min-width:200px;padding:8px 12px;display:flex}.bulk-search svg[data-v-53a87539]{width:14px;height:14px;color:var(--text-3);flex-shrink:0}.bulk-search input[data-v-53a87539]{color:var(--text-1);background:0 0;border:none;outline:none;width:100%;font-size:13px}.bulk-actions[data-v-53a87539]{align-items:center;gap:8px;display:flex}.sel-count[data-v-53a87539]{color:var(--primary);background:var(--primary-light);border-radius:20px;padding:4px 12px;font-size:13px;font-weight:700}.btn-sel-all[data-v-53a87539]{background:var(--surface-3);border:1px solid var(--border);color:var(--text-2);cursor:pointer;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;transition:all .15s}.btn-sel-all[data-v-53a87539]:hover{border-color:var(--primary);color:var(--primary)}.btn-send-bulk[data-v-53a87539]{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:700;transition:background .2s;display:inline-flex}.btn-send-bulk svg[data-v-53a87539]{width:15px;height:15px}.btn-send-bulk[data-v-53a87539]:hover:not(:disabled){background:#059669}.btn-send-bulk[data-v-53a87539]:disabled{opacity:.6;cursor:not-allowed}.bulk-result[data-v-53a87539]{color:#15803d;background:#f0fdf4;border:1px solid #86efac;border-radius:10px;align-items:center;gap:10px;margin-bottom:12px;padding:12px 16px;font-size:14px;display:flex}.btn-reset[data-v-53a87539]{cursor:pointer;color:#15803d;background:#fff;border:1px solid #86efac;border-radius:6px;margin-left:auto;padding:5px 12px;font-size:12px;font-weight:600}.state-msg[data-v-53a87539]{text-align:center;color:var(--text-3);padding:48px;font-size:14px}.siswa-table-wrap[data-v-53a87539]{border:1px solid var(--border);border-radius:10px;max-height:480px;overflow:hidden auto}.siswa-tbl[data-v-53a87539]{border-collapse:collapse;width:100%;font-size:13px}.siswa-tbl thead[data-v-53a87539]{background:var(--surface-2);z-index:1;position:sticky;top:0}.siswa-tbl th[data-v-53a87539]{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border);padding:10px 14px;font-size:11px;font-weight:700}.siswa-tbl td[data-v-53a87539]{border-bottom:1px solid var(--border);vertical-align:middle;padding:11px 14px}.siswa-tbl tbody tr[data-v-53a87539]{cursor:pointer;transition:background .1s}.siswa-tbl tbody tr[data-v-53a87539]:hover{background:var(--surface-2)}.siswa-tbl tbody tr:last-child td[data-v-53a87539]{border-bottom:none}.row-selected td[data-v-53a87539]{background:#eef2ff!important}.row-sent td[data-v-53a87539]{background:#f0fdf4!important}.row-fail td[data-v-53a87539]{background:#fef2f2!important}.row-curr td[data-v-53a87539]{background:#eff6ff!important}.td-nama[data-v-53a87539]{color:var(--text-1);font-weight:600}.td-sm[data-v-53a87539]{color:var(--text-2)}.td-rp[data-v-53a87539]{text-align:right;color:var(--text-2);font-family:monospace;font-size:12px}.td-sisa[data-v-53a87539]{font-weight:700;color:#dc2626!important}.td-status[data-v-53a87539]{text-align:center}.badge-sent[data-v-53a87539]{color:#065f46;background:#d1fae5;border-radius:20px;padding:3px 8px;font-size:11px;font-weight:700}.badge-fail[data-v-53a87539]{color:#991b1b;background:#fee2e2;border-radius:20px;padding:3px 8px;font-size:11px;font-weight:700}.badge-curr[data-v-53a87539]{font-size:16px}.badge-idle[data-v-53a87539]{background:var(--surface-3);color:var(--text-3);border-radius:20px;padding:3px 8px;font-size:11px}.page-container[data-v-f942af47]{max-width:1200px;margin:0 auto;padding:32px 40px;animation:.4s ease-out fade-in-f942af47}.page-header[data-v-f942af47]{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.header-content h1[data-v-f942af47]{color:var(--text-1);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.subtitle[data-v-f942af47]{color:var(--text-2);font-size:15px}.header-actions[data-v-f942af47]{gap:12px;display:flex}.btn[data-v-f942af47]{cursor:pointer;transition:all var(--transition);border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;display:inline-flex}.btn svg[data-v-f942af47]{width:18px;height:18px}.btn-primary[data-v-f942af47]{background:var(--primary);color:#fff;box-shadow:0 4px 12px #6366f140}.btn-primary[data-v-f942af47]:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-primary[data-v-f942af47]:disabled{background:var(--text-3);cursor:not-allowed;box-shadow:none;transform:none}.btn-outline[data-v-f942af47]{color:var(--text-2);border:1px solid var(--border);background:0 0}.btn-outline[data-v-f942af47]:hover{background:var(--surface-3);color:var(--text-1)}.btn-danger[data-v-f942af47]{background:var(--danger);color:#fff}.btn-danger[data-v-f942af47]:hover{background:#dc2626}.w-full[data-v-f942af47]{justify-content:center;width:100%}.table-container[data-v-f942af47]{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:24px;overflow:hidden}.data-table[data-v-f942af47]{border-collapse:collapse;width:100%}.data-table th[data-v-f942af47],.data-table td[data-v-f942af47]{text-align:left;padding:16px 24px}.data-table th[data-v-f942af47]{color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:#f8fafc;font-size:13px;font-weight:600}.table-row[data-v-f942af47]{border-bottom:1px solid var(--border);transition:background var(--transition)}.table-row[data-v-f942af47]:last-child{border-bottom:none}.table-row[data-v-f942af47]:hover{background:#f8fafc}.action-buttons[data-v-f942af47]{gap:8px;display:flex}.btn-icon[data-v-f942af47]{cursor:pointer;width:34px;height:34px;transition:all var(--transition);color:var(--text-3);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.btn-icon[data-v-f942af47]:hover{background:var(--surface-3)}.btn-icon.edit[data-v-f942af47]:hover{color:var(--primary);background:var(--primary-light)}.btn-icon.delete[data-v-f942af47]:hover{color:var(--danger);background:#fee2e2}.btn-icon svg[data-v-f942af47]{width:18px;height:18px}.empty-state[data-v-f942af47]{text-align:center;color:var(--text-3);padding:48px 24px}.form-grid[data-v-f942af47]{grid-template-columns:1fr;gap:20px;display:grid}.form-group[data-v-f942af47]{flex-direction:column;gap:8px;display:flex}.form-group label[data-v-f942af47]{color:var(--text-1);font-size:14px;font-weight:600}.required[data-v-f942af47]{color:var(--danger)}.form-input[data-v-f942af47]{border:1px solid var(--border);transition:all var(--transition);border-radius:8px;padding:10px 14px;font-family:inherit;font-size:14px}.form-input[data-v-f942af47]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.delete-icon[data-v-f942af47]{width:64px;height:64px;color:var(--danger);background:#fee2e2;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.delete-icon svg[data-v-f942af47]{width:32px;height:32px}.delete-title[data-v-f942af47]{color:var(--text-1);text-align:center;margin-bottom:12px;font-size:20px;font-weight:700}.delete-desc[data-v-f942af47]{color:var(--text-2);text-align:center;margin-bottom:24px;font-size:14px;line-height:1.5}.fw-bold[data-v-f942af47]{color:var(--text-1);font-weight:600}@keyframes fade-in-f942af47{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-container[data-v-777eec49]{max-width:1200px;margin:0 auto;padding:32px 40px;animation:.4s ease-out fade-in-777eec49}.page-header[data-v-777eec49]{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.header-content h1[data-v-777eec49]{color:var(--text-1);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.subtitle[data-v-777eec49]{color:var(--text-2);font-size:15px}.header-actions[data-v-777eec49]{gap:12px;display:flex}.btn[data-v-777eec49]{cursor:pointer;transition:all var(--transition);border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;display:inline-flex}.btn svg[data-v-777eec49]{width:18px;height:18px}.btn-primary[data-v-777eec49]{background:var(--primary);color:#fff;box-shadow:0 4px 12px #6366f140}.btn-primary[data-v-777eec49]:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-primary[data-v-777eec49]:disabled{background:var(--text-3);cursor:not-allowed;box-shadow:none;transform:none}.btn-outline[data-v-777eec49]{color:var(--text-2);border:1px solid var(--border);background:0 0}.btn-outline[data-v-777eec49]:hover{background:var(--surface-3);color:var(--text-1)}.table-container[data-v-777eec49]{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:24px;position:relative;overflow:hidden}.search-box[data-v-777eec49]{flex:1;max-width:400px;position:relative}.search-box svg[data-v-777eec49]{width:18px;height:18px;color:var(--text-3);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-box input[data-v-777eec49]{border:1px solid var(--border);width:100%;color:var(--text-1);background:var(--surface);transition:all var(--transition);border-radius:10px;padding:12px 16px 12px 42px;font-size:14px}.search-box input[data-v-777eec49]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.search-results[data-v-777eec49]{border:1px solid var(--border);max-width:400px;box-shadow:var(--shadow-lg);z-index:10;background:#fff;border-radius:8px;max-height:250px;margin:0;padding:0;list-style:none;position:absolute;top:75px;left:20px;right:20px;overflow-y:auto}.form-results[data-v-777eec49]{max-width:100%;margin-top:4px;position:relative;top:auto;left:0}.search-results li[data-v-777eec49]{border-bottom:1px solid var(--surface-3);cursor:pointer;padding:12px 16px;transition:background .2s}.search-results li[data-v-777eec49]:last-child{border-bottom:none}.search-results li[data-v-777eec49]:hover{background:var(--surface-2)}.saldo-card[data-v-777eec49]{border:1px solid var(--border);background:var(--surface-2);border-radius:12px;flex-direction:column;min-width:150px;padding:16px 20px;display:flex}.saldo-card.total[data-v-777eec49]{background:var(--primary-light);border-color:#6366f133}.saldo-card .label[data-v-777eec49]{color:var(--text-2);margin-bottom:4px;font-size:13px;font-weight:600}.saldo-card.total .label[data-v-777eec49]{color:var(--primary-dark)}.saldo-card .value[data-v-777eec49]{color:var(--text-1);font-size:20px;font-weight:800}.saldo-card.total .value[data-v-777eec49]{color:var(--primary)}.data-table[data-v-777eec49]{border-collapse:collapse;width:100%}.data-table th[data-v-777eec49],.data-table td[data-v-777eec49]{text-align:left;border-bottom:1px solid var(--border);padding:14px 20px;font-size:14px}.data-table th[data-v-777eec49]{color:var(--text-2);text-transform:uppercase;background:#f8fafc;font-size:13px;font-weight:600}.empty-state[data-v-777eec49]{text-align:center;color:var(--text-3);padding:40px}.badge[data-v-777eec49]{border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.bg-success-light[data-v-777eec49]{background:#10b9811a}.text-success[data-v-777eec49]{color:var(--success)}.bg-danger-light[data-v-777eec49]{background:#ef44441a}.text-danger[data-v-777eec49]{color:var(--danger)}.bg-primary-light[data-v-777eec49]{background:#6366f11a}.text-primary[data-v-777eec49]{color:var(--primary)}.fw-bold[data-v-777eec49]{font-weight:600}.form-grid[data-v-777eec49]{grid-template-columns:1fr;gap:16px;display:grid}.form-group[data-v-777eec49]{flex-direction:column;gap:6px;display:flex}.form-group label[data-v-777eec49]{color:var(--text-1);font-size:13px;font-weight:600}.required[data-v-777eec49]{color:var(--danger)}.form-input[data-v-777eec49]{border:1px solid var(--border);transition:all var(--transition);border-radius:8px;padding:10px 14px;font-size:14px}.form-input[data-v-777eec49]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}@keyframes fade-in-777eec49{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-container[data-v-4e48d5e0]{max-width:1100px;margin:0 auto;padding:32px 40px;animation:.4s ease-out fade-in-4e48d5e0}@keyframes fade-in-4e48d5e0{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header[data-v-4e48d5e0]{margin-bottom:32px}.header-content h1[data-v-4e48d5e0]{color:var(--text-1);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.subtitle[data-v-4e48d5e0]{color:var(--text-2);font-size:15px}.akun-layout[data-v-4e48d5e0]{grid-template-columns:260px 1fr;align-items:start;gap:24px;display:grid}.profile-panel[data-v-4e48d5e0]{border-radius:var(--radius-lg);background:linear-gradient(135deg,#4f46e5,#7c3aed);flex-direction:column;align-items:center;gap:12px;padding:32px 24px;display:flex;box-shadow:0 8px 32px #4f46e54d}.avatar-circle[data-v-4e48d5e0]{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;background:#ffffff40;border:3px solid #fff6;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:32px;font-weight:800;display:flex}.profile-name[data-v-4e48d5e0]{color:#fff;text-align:center;font-size:17px;font-weight:700}.profile-email[data-v-4e48d5e0]{color:#ffffffb3;text-align:center;font-size:12px}.profile-roles[data-v-4e48d5e0]{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.role-badge[data-v-4e48d5e0]{color:#fff;background:#fff3;border-radius:20px;padding:4px 12px;font-size:11px;font-weight:600}.form-panel[data-v-4e48d5e0]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.tabs[data-v-4e48d5e0]{border-bottom:1px solid var(--border);display:flex}.tab-btn[data-v-4e48d5e0]{cursor:pointer;color:var(--text-2);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:8px;padding:16px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.tab-btn svg[data-v-4e48d5e0]{width:16px;height:16px}.tab-btn.active[data-v-4e48d5e0]{color:var(--primary);border-bottom-color:var(--primary);background:#6366f10a}.tab-btn[data-v-4e48d5e0]:hover:not(.active){color:var(--text-1);background:var(--surface-2)}.tab-content[data-v-4e48d5e0]{padding:28px}.form-grid[data-v-4e48d5e0]{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;display:grid}.form-group[data-v-4e48d5e0]{flex-direction:column;gap:7px;display:flex}.form-group.full[data-v-4e48d5e0]{grid-column:1/-1}.form-group label[data-v-4e48d5e0]{color:var(--text-1);font-size:13px;font-weight:600}.req[data-v-4e48d5e0]{color:var(--danger)}.form-input[data-v-4e48d5e0]{border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-family:inherit;font-size:14px;transition:all .2s}.form-input[data-v-4e48d5e0]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.field-hint[data-v-4e48d5e0]{color:var(--text-3);margin-top:4px;font-size:12px}.phone-input[data-v-4e48d5e0]{border:1px solid var(--border);border-radius:8px;transition:all .2s;display:flex;overflow:hidden}.phone-input[data-v-4e48d5e0]:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.phone-prefix[data-v-4e48d5e0]{background:var(--surface-2);color:var(--text-2);border-right:1px solid var(--border);padding:10px 12px;font-size:14px;font-weight:600}.phone-field[data-v-4e48d5e0]{border-radius:0;flex:1;box-shadow:none!important;border:none!important}.phone-field[data-v-4e48d5e0]:focus{outline:none;box-shadow:none!important}.pass-wrap[data-v-4e48d5e0]{position:relative}.eye-btn[data-v-4e48d5e0]{cursor:pointer;color:var(--text-3);background:0 0;border:none;padding:4px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.eye-btn[data-v-4e48d5e0]:hover{color:var(--text-1)}.eye-btn svg[data-v-4e48d5e0]{width:16px;height:16px}.form-footer[data-v-4e48d5e0]{border-top:1px solid var(--border);justify-content:flex-end;padding-top:20px;display:flex}.btn[data-v-4e48d5e0]{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 22px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn svg[data-v-4e48d5e0]{width:16px;height:16px}.btn-primary[data-v-4e48d5e0]{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;box-shadow:0 4px 12px #6366f140}.btn-primary[data-v-4e48d5e0]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #6366f159}.btn-primary[data-v-4e48d5e0]:disabled{opacity:.65;cursor:not-allowed;box-shadow:none;transform:none}.spinner[data-v-4e48d5e0]{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:1s linear infinite spin-4e48d5e0;display:inline-block}@keyframes spin-4e48d5e0{to{transform:rotate(360deg)}}@media (width<=768px){.page-container[data-v-4e48d5e0]{padding:20px}.akun-layout[data-v-4e48d5e0],.form-grid[data-v-4e48d5e0]{grid-template-columns:1fr}}.forgot-wrapper[data-v-ce31512e]{background:linear-gradient(135deg,#f0f4ff 0%,#faf5ff 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:32px 20px;display:flex}.brand[data-v-ce31512e]{align-items:center;gap:12px;margin-bottom:28px;display:flex}.brand-logo[data-v-ce31512e]{object-fit:contain;width:44px;height:44px}.brand-name[data-v-ce31512e]{color:var(--text-1);font-size:16px;font-weight:700}.forgot-card[data-v-ce31512e]{background:#fff;border-radius:20px;width:100%;max-width:460px;padding:36px;box-shadow:0 20px 60px #4f46e51f,0 4px 20px #0000000f}.steps[data-v-ce31512e]{align-items:center;margin-bottom:32px;display:flex}.step[data-v-ce31512e]{flex-direction:column;align-items:center;gap:6px;display:flex}.step-dot[data-v-ce31512e]{background:var(--surface-2);width:32px;height:32px;color:var(--text-3);border:2px solid var(--border);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;transition:all .3s;display:flex}.step.active .step-dot[data-v-ce31512e]{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 0 0 4px #6366f126}.step.done .step-dot[data-v-ce31512e]{color:#fff;background:#10b981;border-color:#10b981}.step span[data-v-ce31512e]{color:var(--text-3);white-space:nowrap;font-size:11px;font-weight:600}.step.active span[data-v-ce31512e],.step.done span[data-v-ce31512e]{color:var(--text-1)}.step-line[data-v-ce31512e]{background:var(--border);flex:1;height:2px;margin:0 8px 18px;transition:background .3s}.step-line.active[data-v-ce31512e]{background:var(--primary)}.step-content[data-v-ce31512e]{flex-direction:column;gap:16px;display:flex}.step-icon[data-v-ce31512e]{border-radius:16px;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 4px;display:flex}.step-icon svg[data-v-ce31512e]{width:28px;height:28px}.step-icon.blue[data-v-ce31512e]{color:#3b82f6;background:#eff6ff}.step-icon.green[data-v-ce31512e]{color:#10b981;background:#ecfdf5}.step-icon.purple[data-v-ce31512e]{color:#8b5cf6;background:#f5f3ff}.step-content h2[data-v-ce31512e]{color:var(--text-1);text-align:center;letter-spacing:-.5px;margin:0;font-size:22px;font-weight:800}.step-desc[data-v-ce31512e]{color:var(--text-2);text-align:center;font-size:14px;line-height:1.5}.form-group[data-v-ce31512e]{flex-direction:column;gap:7px;display:flex}.form-group label[data-v-ce31512e]{color:var(--text-1);font-size:13px;font-weight:600}.form-input[data-v-ce31512e]{border:1px solid var(--border);box-sizing:border-box;border-radius:10px;width:100%;padding:11px 14px;font-family:inherit;font-size:14px;transition:all .2s}.form-input[data-v-ce31512e]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.otp-inputs[data-v-ce31512e]{justify-content:center;gap:10px;display:flex}.otp-box[data-v-ce31512e]{text-align:center;border:2px solid var(--border);width:48px;height:56px;color:var(--text-1);caret-color:var(--primary);border-radius:12px;font-size:22px;font-weight:700;transition:all .2s}.otp-box[data-v-ce31512e]:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f126}.countdown[data-v-ce31512e]{text-align:center;color:var(--text-3);font-size:13px}.resend-btn[data-v-ce31512e]{color:var(--primary);cursor:pointer;text-align:center;background:0 0;border:none;padding:0;font-size:13px;font-weight:600}.resend-btn[data-v-ce31512e]:hover{text-decoration:underline}.pass-wrap[data-v-ce31512e]{position:relative}.eye-btn[data-v-ce31512e]{cursor:pointer;color:var(--text-3);background:0 0;border:none;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.eye-btn[data-v-ce31512e]:hover{color:var(--text-1)}.eye-btn svg[data-v-ce31512e]{width:16px;height:16px}.strength-bar[data-v-ce31512e]{background:var(--surface-2);border-radius:4px;height:4px;overflow:hidden}.strength-fill[data-v-ce31512e]{border-radius:4px;height:100%;transition:width .4s}.strength-fill.weak[data-v-ce31512e]{background:#ef4444}.strength-fill.medium[data-v-ce31512e]{background:#f59e0b}.strength-fill.strong[data-v-ce31512e]{background:#3b82f6}.strength-fill.very-strong[data-v-ce31512e]{background:#10b981}.strength-label[data-v-ce31512e]{color:var(--text-3);font-size:12px}.error-msg[data-v-ce31512e]{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;font-size:13px;font-weight:500}.btn[data-v-ce31512e]{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:700;transition:all .2s;display:inline-flex}.btn svg[data-v-ce31512e]{width:16px;height:16px}.btn-primary[data-v-ce31512e]{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;box-shadow:0 4px 14px #6366f14d}.btn-primary[data-v-ce31512e]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #6366f166}.btn-primary[data-v-ce31512e]:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.w-full[data-v-ce31512e]{width:100%;text-decoration:none}.spinner[data-v-ce31512e]{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:1s linear infinite spin-ce31512e}@keyframes spin-ce31512e{to{transform:rotate(360deg)}}.back-link[data-v-ce31512e]{text-align:center;color:var(--text-2);font-size:13px;text-decoration:none;display:block}.back-link[data-v-ce31512e]:hover{color:var(--primary)}.success-state[data-v-ce31512e]{text-align:center}.success-icon[data-v-ce31512e]{color:#10b981;background:#ecfdf5;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto;display:flex}.success-icon svg[data-v-ce31512e]{width:36px;height:36px}
