 :root{--primary:#FF8FAB;--primary-dark:#FF6B9C;--secondary:#4ECDC4;--accent:#FFD93D;--success:#6BCB77;--danger:#FF6B6B;--info:#38BDF8;--dark:#2D3436;--muted:#636E72;--bg:#F8FAFC;--surface:#FFFFFF;--radius-pill:9999px;--radius-fun:32px;--radius-xl:16px;--radius-lg:12px;--radius-md:8px;--shadow-pop:0 8px 0px -2px rgba(0,0,0,0.1);--shadow-sm:0 1px 2px rgba(0,0,0,0.06);--shadow-md:0 4px 12px rgba(0,0,0,0.08);--shadow-lg:0 8px 24px rgba(0,0,0,0.12);--shadow-xl:0 16px 40px rgba(0,0,0,0.16);--shadow-2xl:0 24px 64px rgba(0,0,0,0.2);--primary-accessible:#C2185B;--secondary-accessible:#0F766E;--success-accessible:#166534;--danger-accessible:#B91C1C;--info-accessible:#0369A1;}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}html{height:100%;}body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;background-color:#F1F5F9;color:var(--dark);overflow-y:auto;min-height:100vh;-webkit-font-smoothing:antialiased;line-height:1.6;}h1,h2,h3,h4,.font-heading{letter-spacing:0.02em;line-height:1.3;}button{cursor:pointer;border:none;background:none;font-family:inherit;}input,select,textarea{font-family:inherit;}img{display:block;max-width:100%;}[x-cloak]{display:none !important;}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);}.bg-pattern{background:radial-gradient(circle at 15% 15%,rgba(255,143,171,0.05) 0%,transparent 40%),radial-gradient(circle at 85% 85%,rgba(78,205,196,0.05) 0%,transparent 40%);position:fixed;inset:0;z-index:-1;pointer-events:none;}.scroller::-webkit-scrollbar{width:8px;}.scroller::-webkit-scrollbar-thumb{background-color:#e5e7eb;border-radius:99px;}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;}.login-card{background:#fff;padding:2.5rem;border-radius:var(--radius-fun);box-shadow:var(--shadow-pop);border:4px solid #fff;max-width:420px;width:100%;text-align:center;position:relative;}.login-emoji{font-size:3.75rem;margin-bottom:1.5rem;display:block;}.login-title{font-size:1.5rem;color:var(--dark);margin-bottom:0.25rem;line-height:1.3;font-weight:700;}.login-subtitle{color:var(--muted);font-size:0.875rem;margin-bottom:2rem;line-height:1.4;}@media (min-width:768px){.login-title{font-size:1.75rem;}}.login-form{display:flex;flex-direction:column;gap:1rem;}.login-input{width:100%;background:var(--bg);border:2px solid transparent;border-radius:var(--radius-pill);padding:0.75rem;font-weight:700;outline:none;text-align:center;font-size:1rem;transition:border-color 0.2s;min-height:2.75rem;line-height:1.4;}.login-input:focus{border-color:var(--secondary);}.login-btn{width:100%;background:var(--primary-accessible);color:#fff;padding:1rem;border-radius:var(--radius-pill);font-weight:700;font-size:1.125rem;box-shadow:0 4px 0 #9A1145;margin-top:1rem;transition:all 0.2s;}.login-btn:hover{filter:brightness(1.05);}.login-btn:disabled{opacity:0.5;cursor:not-allowed;}.app-wrapper{height:100vh;display:flex;flex-direction:column;max-width:1200px;margin:0 auto;padding:0.625rem;gap:0.625rem;}@media (min-width:768px){.app-wrapper{flex-direction:row;}}.sidebar{width:100%;flex-shrink:0;background:var(--surface);border-radius:20px;box-shadow:var(--shadow-pop);border:3px solid #fff;padding:1.25rem;display:flex;flex-direction:column;z-index:20;}@media (min-width:768px){.sidebar{width:220px;height:calc(100vh - 1.25rem);position:sticky;top:0;}}.sidebar-brand{display:flex;align-items:center;justify-content:space-between;padding:0 0.5rem;margin-bottom:0;}@media (min-width:768px){.sidebar-brand{margin-bottom:1.25rem;}}.sidebar-brand-inner{display:flex;align-items:center;gap:1rem;}.sidebar-logo-icon{width:2.5rem;height:2.5rem;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;box-shadow:var(--shadow-md);border:2px solid #fff;transform:rotate(-6deg);flex-shrink:0;}.sidebar-school-name{font-size:0.9rem;color:var(--primary-accessible);display:block;line-height:1.4;}.sidebar-label{font-size:0.8rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;line-height:1.4;}.sidebar-toggle{font-size:1.5rem;padding:0.5rem;color:var(--muted);line-height:1.4;}@media (min-width:768px){.sidebar-toggle{display:none;}}.sidebar-nav-wrap{display:none;flex-direction:column;flex:1;}.sidebar-nav-wrap.open{display:flex;margin-top:1rem;border-top:1px solid #f3f4f6;padding-top:1rem;}@media (min-width:768px){.sidebar-nav-wrap{display:flex !important;}}.sidebar-nav{display:flex;flex-direction:column;gap:0.5rem;flex:1;}.nav-btn{width:100%;text-align:left;padding:0.75rem 1rem;border-radius:var(--radius-pill);font-weight:700;display:flex;align-items:center;gap:0.625rem;color:var(--muted);transition:background 0.2s,transform 0.2s,box-shadow 0.2s;font-size:0.875rem;line-height:1.4;min-height:2.5rem;}.nav-btn:hover{background:#f9fafb;}.nav-btn.active{color:#fff;box-shadow:var(--shadow-lg);transform:translateX(0.5rem);}.nav-btn.active-dashboard{background:var(--primary-accessible);}.nav-btn.active-biaya{background:var(--accent);color:var(--dark);}.nav-btn.active-siswa{background:var(--secondary-accessible);}.nav-btn.active-hitung{background:var(--danger-accessible);}.nav-btn.active-tagihan{background:var(--success-accessible);}.nav-btn.active-laporan{background:var(--dark);}.nav-btn.active-riwayat{background:var(--info-accessible);}.logout-btn{margin-top:1rem;width:100%;border:2px solid #fecaca;color:var(--danger-accessible);padding:0.75rem 1rem;border-radius:var(--radius-pill);font-size:0.875rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:0.5rem;transition:background 0.2s;min-height:2.5rem;line-height:1.4;}.logout-btn:hover{background:#fef2f2;}@media (min-width:768px){.logout-btn{margin-top:auto;font-size:0.875rem;}}.main-content{flex:1;background:rgba(255,255,255,0.85);border-radius:20px;box-shadow:var(--shadow-sm);border:1px solid rgba(255,255,255,0.5);padding:1.25rem;position:relative;overflow-y:auto;}@media (min-width:768px){.main-content{padding:1.5rem;height:calc(100vh - 1.25rem);}}.main-header{margin-bottom:1.25rem;display:flex;justify-content:space-between;align-items:flex-end;}.main-date{font-size:0.75rem;font-weight:700;color:var(--muted);margin-bottom:0.2rem;}.main-title{font-size:1.25rem;color:var(--dark);line-height:1.3;font-weight:700;}@media (min-width:768px){.main-title{font-size:1.5rem;}}.main-title .text-primary{color:var(--primary-accessible);}.main-title .text-secondary{color:var(--secondary-accessible);}.main-title .text-accent{color:#92400e;}.main-title .text-success{color:var(--success-accessible);}.main-title .text-info{color:var(--info-accessible);}.stats-grid{display:grid;grid-template-columns:1fr;gap:0.75rem;margin-bottom:1.25rem;}@media (min-width:768px){.stats-grid{grid-template-columns:repeat(3,1fr);gap:1rem;}}.stat-card{padding:1.125rem;border-radius:18px;border:2px solid #fff;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;justify-content:space-between;height:6.5rem;}@media (max-width:640px){.stat-card{padding:0.875rem;height:auto;}}.stat-card--pink{background:#FFF0F5;}.stat-card--teal{background:#E0F7FA;}.stat-card--yellow{background:#FFF9C4;}.stat-card-top{display:flex;justify-content:space-between;align-items:flex-start;}.stat-card-label{font-size:0.75rem;font-weight:700;text-transform:uppercase;}.stat-card--pink .stat-card-label{color:var(--primary-accessible);}.stat-card--teal .stat-card-label{color:var(--secondary-accessible);}.stat-card--yellow .stat-card-label{color:#92400e;}.stat-card-icon{font-size:1.25rem;}.stat-card-value{font-size:1.75rem;color:var(--dark);}.stat-card--yellow .stat-card-value{font-size:1.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.charts-grid{display:grid;grid-template-columns:1fr;gap:0.75rem;margin-bottom:1.25rem;}@media (min-width:768px){.charts-grid{gap:1rem;}}@media (min-width:1024px){.charts-grid{grid-template-columns:repeat(2,1fr);}}.chart-card{background:#fff;padding:1.125rem;border-radius:18px;border:1px solid #f3f4f6;box-shadow:var(--shadow-sm);}@media (max-width:640px){.chart-card{padding:0.875rem;}}.chart-card-title{font-size:1rem;color:var(--dark);margin-bottom:0.75rem;line-height:1.4;}.chart-wrapper{position:relative;height:12rem;width:100%;}.mini-stats-grid{display:grid;grid-template-columns:1fr;gap:0.75rem;margin-bottom:1rem;}@media (min-width:768px){.mini-stats-grid{grid-template-columns:repeat(3,1fr);}}.mini-stat-card{background:#fff;padding:0.75rem 1rem;border-radius:14px;border:1px solid #f3f4f6;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;}.mini-stat-label{font-size:0.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;}.mini-stat-value{font-size:1.25rem;color:var(--dark);margin-top:0.2rem;}.mini-stat-value--danger{color:var(--danger-accessible);}.mini-stat-icon{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;}.mini-stat-icon--blue{background:#eff6ff;color:#1D4ED8;}.mini-stat-icon--yellow{background:#fefce8;color:#92400e;}.mini-stat-icon--red{background:#fef2f2;color:var(--danger-accessible);}.filter-bar{background:#fff;padding:0.875rem;border-radius:16px;box-shadow:var(--shadow-sm);border:1px solid #f3f4f6;margin-bottom:1rem;}.filter-bar-inner{display:flex;flex-direction:column;gap:1rem;align-items:stretch;}@media (min-width:768px){.filter-bar-inner{flex-direction:row;align-items:center;}}.search-wrap{position:relative;width:100%;}@media (min-width:768px){.search-wrap{flex:1;}}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none;}.search-input{width:100%;background:var(--bg);border:none;border-radius:var(--radius-pill);padding:0.75rem 1rem 0.75rem 2.5rem;font-weight:700;font-size:0.875rem;outline:none;transition:box-shadow 0.2s;min-height:2.5rem;line-height:1.4;}.search-input:focus{box-shadow:0 0 0 2px rgba(78,205,196,0.3);}.search-input::placeholder{color:#9ca3af;}.filter-selects{display:flex;gap:0.75rem;width:100%;}@media (min-width:768px){.filter-selects{width:auto;}}.filter-select-wrap{position:relative;flex:1;}@media (min-width:768px){.filter-select-wrap{flex:none;}}.filter-select{width:100%;appearance:none;background:var(--bg);border:none;border-radius:var(--radius-pill);padding:0.75rem 2rem 0.75rem 1rem;font-weight:700;font-size:0.875rem;outline:none;cursor:pointer;transition:background 0.2s;min-height:2.75rem;line-height:1.4;}@media (min-width:768px){.filter-select{width:10rem;}}.filter-select:hover{background:#f3f4f6;}.filter-select-arrow{position:absolute;right:0.75rem;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none;font-size:0.75rem;}.btn-add{width:100%;background:var(--secondary-accessible);color:#fff;padding:0.75rem 1.5rem;border-radius:var(--radius-pill);font-weight:700;box-shadow:var(--shadow-md);white-space:nowrap;transition:filter 0.2s,transform 0.1s;font-size:0.875rem;border:none;cursor:pointer;min-height:2.75rem;line-height:1.4;}@media (min-width:640px){.btn-add{width:auto;min-width:150px;}}.btn-add:hover{filter:brightness(1.1);}.btn-add:active{transform:scale(0.95);}.btn-add--accent{background:var(--accent);color:var(--dark);}.btn-add--dark{background:var(--dark);color:#fff;}.list-grid{display:grid;grid-template-columns:1fr;gap:0.75rem;}.student-item{padding:1rem;border-radius:16px;border:2px solid #f3f4f6;display:grid;grid-template-columns:1fr 1fr;gap:1rem;transition:border-color 0.2s,box-shadow 0.2s;cursor:pointer;}.student-item:nth-child(odd){background:rgba(59,130,246,0.05);}.student-item:nth-child(even){background:rgba(236,72,153,0.05);}@media (min-width:480px){.student-item{grid-template-columns:auto 1fr 1fr;gap:1.25rem;padding:1rem 1.25rem;}}@media (min-width:640px){.student-item{display:grid;grid-template-columns:280px 1fr 1fr;align-items:start;gap:1.5rem;padding:1rem 1.25rem;}}div[x-show*="hitung"] .student-item{grid-template-columns:1fr;cursor:pointer;gap:1rem;padding:1rem;}@media (min-width:480px){div[x-show*="hitung"] .student-item{grid-template-columns:1fr auto auto;gap:1.25rem;padding:1rem 1.25rem;}}@media (min-width:640px){div[x-show*="hitung"] .student-item{grid-template-columns:1fr auto auto;gap:1.5rem;padding:1rem 1.25rem;}}.student-item:hover{box-shadow:var(--shadow-md);border-color:var(--secondary-accessible);}.student-item--debt{border-color:#fee2e2;}.student-item--debt:hover{border-color:#fecaca;box-shadow:var(--shadow-md);}.student-item--ok:hover{border-color:rgba(78,205,196,0.3);}.student-item-left{display:flex;align-items:center;gap:1rem;width:100%;grid-column:1 / -1;}@media (min-width:480px){.student-item-left{grid-column:auto;width:auto;}}@media (min-width:640px){.student-item-left{width:auto;}}div[x-show*="hitung"] .student-item-left{grid-column:1;}.student-item-center{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start;gap:0.25rem;width:100%;}@media (min-width:480px){.student-item-center{align-items:center;width:auto;}}.student-item-right{display:flex;flex-direction:column;gap:0.25rem;align-items:flex-start;width:100%;}@media (min-width:480px){.student-item-right{align-items:center;width:auto;}}@media (min-width:480px){.student-item-right{}}.student-avatar{width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;}.student-avatar--debt{background:#fef2f2;}.student-avatar--active{background:rgba(78,205,196,0.1);}.student-avatar--inactive{background:#f3f4f6;}.student-avatar img{width:100%;height:100%;object-fit:cover;}.student-info{text-align:left;}@media (min-width:480px){.student-info{text-align:center;}}@media (min-width:640px){.student-info{text-align:left;}}.student-name{font-size:1rem;color:var(--dark);line-height:1.5;}.student-meta{display:flex;align-items:center;justify-content:flex-start;gap:0.5rem;font-size:0.75rem;font-weight:700;color:var(--muted);margin-top:0.25rem;}@media (min-width:480px){.student-meta{justify-content:center;}}@media (min-width:640px){.student-meta{justify-content:flex-start;}}.student-class-tag{background:#f9fafb;padding:0.125rem 0.5rem;border-radius:4px;color:#6b7280;}.student-sep{color:#d1d5db;}.estimate-label{font-size:0.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;text-align:right;}.estimate-value{font-size:1.125rem;font-weight:700;color:var(--dark);text-align:right;}.lunas-status{font-size:0.875rem;font-weight:700;color:var(--success-accessible);text-align:right;white-space:nowrap;}.lunas-col{font-size:0.875rem;font-weight:700;color:var(--success-accessible);text-align:left;white-space:nowrap;display:flex;align-items:center;justify-content:flex-start;}@media (min-width:480px){.lunas-col{text-align:center;justify-content:center;}}.biaya-col{display:flex;flex-direction:row;gap:1rem;align-items:center;justify-content:space-between;}@media (min-width:480px){.biaya-col{flex-direction:column;gap:0;align-items:flex-end;justify-content:center;}}.student-detail-group{display:flex;flex-direction:column;gap:0.25rem;}.detail-label{font-size:0.65rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;text-align:left;}@media (min-width:480px){.detail-label{font-size:0.75rem;text-align:center;}}.detail-value{font-size:0.8rem;color:var(--dark);font-weight:600;text-align:left;}@media (min-width:480px){.detail-value{font-size:0.875rem;text-align:center;}}.student-parent{font-size:0.75rem;color:#9ca3af;margin-top:0.125rem;display:flex;align-items:center;justify-content:flex-start;gap:0.25rem;}@media (min-width:480px){.student-parent{justify-content:center;}}@media (min-width:640px){.student-parent{justify-content:flex-start;}}.student-parent-label{opacity:0.7;}.student-parent-name{font-weight:700;color:#6b7280;}.student-item-right{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;width:100%;}@media (min-width:640px){.student-item-right{width:auto;justify-content:flex-end;}}.debt-info{text-align:right;display:flex;flex-direction:column;align-items:flex-end;}.debt-label{font-size:0.75rem;font-weight:700;color:var(--danger-accessible);text-transform:uppercase;letter-spacing:0.05em;}.debt-amount{font-weight:700;color:var(--danger-accessible);font-size:1rem;}.badge-lunas{padding:0.25rem 0.75rem;border-radius:9999px;background:#ecfdf5;color:#065F46;font-size:0.75rem;font-weight:700;border:1px solid #d1fae5;}.divider-v{width:1px;height:2rem;background:#f3f4f6;display:none;}@media (min-width:640px){.divider-v{display:block;}}.action-btns{display:flex;align-items:center;gap:0.25rem;}.action-btn{width:2.5rem;height:2.5rem;border-radius:50%;color:#9ca3af;display:flex;align-items:center;justify-content:center;transition:background 0.2s,color 0.2s;font-size:1rem;line-height:1;}.action-btn:hover{background:#f3f4f6;color:var(--dark);}.action-btn--setting:hover{background:#eef2ff;color:#6366f1;}.action-btn--delete:hover{background:#fef2f2;color:#ef4444;}.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--muted);font-weight:700;line-height:1.6;}.filter-toolbar{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;margin-bottom:1rem;background:#fff;padding:1.25rem;border-radius:16px;box-shadow:var(--shadow-sm);border:1px solid #f3f4f6;}@media (min-width:640px){.filter-toolbar{flex-direction:row;align-items:center;justify-content:space-between;}}.filter-toolbar-label{font-size:0.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;white-space:nowrap;}.filter-toolbar-left{display:flex;align-items:center;gap:0.625rem;width:100%;flex-wrap:wrap;justify-content:center;}@media (min-width:640px){.filter-toolbar-left{width:auto;flex-wrap:nowrap;gap:0.875rem;}}.filter-select-inline{background:var(--bg);border:none;border-radius:var(--radius-pill);padding:0.5rem 1rem;font-weight:700;font-size:0.875rem;outline:none;cursor:pointer;}.filter-select-inline:hover{background:#f3f4f6;}.filter-btn{background:var(--bg);color:var(--dark);padding:0.625rem 1.25rem;border-radius:var(--radius-pill);font-weight:700;font-size:0.875rem;border:2px solid #e5e7eb;cursor:pointer;transition:all 0.2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:150px;min-height:2.75rem;line-height:1.4;}.filter-btn:hover{background:#f3f4f6;border-color:var(--secondary);box-shadow:0 2px 8px rgba(78,205,196,0.15);}.filter-btn:active{transform:scale(0.98);}.filter-btn-compact{background:var(--bg);color:var(--dark);padding:0.5rem 0.875rem;border-radius:var(--radius-pill);font-weight:700;font-size:0.875rem;border:2px solid #e5e7eb;cursor:pointer;transition:all 0.2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-height:2.75rem;line-height:1.4;}.filter-btn-compact:hover{background:#f3f4f6;border-color:var(--secondary);}.filter-btn-compact:active{transform:scale(0.98);}.cost-item{background:#fff;padding:1.25rem;border-radius:16px;border:2px solid #f3f4f6;display:flex;flex-direction:column;align-items:center;gap:1rem;transition:border-color 0.2s;cursor:pointer;}@media (min-width:640px){.cost-item{flex-direction:row;align-items:center;justify-content:flex-start;gap:1.5rem;padding:1rem 1.25rem;}}.cost-item:hover{border-color:rgba(255,217,61,0.5);}.cost-item--inactive{opacity:0.6;}.cost-item .student-item-left{flex:1;display:flex;align-items:center;justify-content:center;}@media (min-width:640px){.cost-item .student-item-left{justify-content:flex-start;}}.cost-item .student-item-right{display:flex;align-items:center;justify-content:center;}@media (min-width:640px){.cost-item .student-item-right{min-width:150px;justify-content:flex-end;}}.cost-icon{width:3rem;height:3rem;background:rgba(255,217,61,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;}.cost-status-dot{width:0.5rem;height:0.5rem;border-radius:50%;display:inline-block;}.cost-status-dot--active{background:var(--success);}.cost-status-dot--inactive{background:#d1d5db;}.cost-amount{font-size:1rem;font-weight:700;color:var(--dark);}.action-btn--cost-edit:hover{background:var(--accent);color:var(--dark);}.tagihan-control{background:#fff;padding:0.875rem;border-radius:16px;box-shadow:var(--shadow-sm);border:1px solid #f3f4f6;margin-bottom:1rem;}.tagihan-search{position:relative;width:100%;margin-bottom:0.75rem;}.tagihan-search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:1rem;}.tagihan-search-input{width:100%;background:var(--bg);border:none;border-radius:var(--radius-pill);padding:0.75rem 1rem 0.75rem 2.5rem;font-weight:700;font-size:0.875rem;color:var(--dark);outline:none;transition:box-shadow 0.2s;min-height:2.5rem;line-height:1.4;}.tagihan-search-input:focus{box-shadow:0 0 0 2px rgba(255,143,171,0.2);}.tagihan-search-input::placeholder{color:#9ca3af;}.tagihan-row2{display:flex;flex-direction:column;gap:0.75rem;align-items:stretch;}@media (min-width:640px){.tagihan-row2{flex-direction:row;align-items:center;}}.tagihan-filter-wrap{position:relative;flex:1;}.tagihan-filter-select{width:100%;height:100%;appearance:none;background:var(--bg);border:none;border-radius:var(--radius-pill);padding:0.75rem 2rem 0.75rem 1rem;font-weight:700;font-size:0.875rem;color:var(--dark);outline:none;cursor:pointer;transition:background 0.2s;min-height:2.75rem;line-height:1.4;}.tagihan-filter-select:hover{background:#f3f4f6;}.tagihan-filter-arrow{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none;font-size:0.75rem;display:none;}@media (min-width:640px){.tagihan-filter-arrow{display:block;}}.tagihan-row2 > div{display:flex;gap:0.75rem;flex-direction:column;width:100%;}@media (min-width:640px){.tagihan-row2 > div{flex-direction:row;width:auto;flex:1;}}.tagihan-filter-btn{flex:1;background:var(--bg);color:var(--dark);padding:0.75rem 1.5rem;border-radius:var(--radius-pill);font-weight:700;font-size:0.875rem;border:2px solid #e5e7eb;cursor:pointer;transition:all 0.2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:2.75rem;display:flex;align-items:center;justify-content:center;line-height:1.4;}.tagihan-filter-btn:hover{background:#f3f4f6;border-color:var(--secondary);}.tagihan-filter-btn:active{transform:scale(0.95);}.btn-print{flex:1;}.btn-generate{flex:1;background:var(--dark);color:#fff;padding:0.75rem 1.5rem;border-radius:var(--radius-pill);font-weight:700;box-shadow:var(--shadow-md);font-size:0.875rem;white-space:nowrap;transition:filter 0.2s,transform 0.1s;display:flex;align-items:center;justify-content:center;gap:0.5rem;min-height:2.75rem;line-height:1.4;border:none;cursor:pointer;}.btn-generate:hover{filter:brightness(1.1);}.btn-generate:active{transform:scale(0.95);}.tagihan-grid{display:grid;grid-template-columns:1fr;gap:0.75rem;margin-bottom:2rem;}@media (min-width:640px){.tagihan-grid{grid-template-columns:repeat(2,1fr);gap:1rem;}}@media (min-width:1024px){.tagihan-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem;}}.tagihan-card{background:#fff;padding:2.25rem 1.25rem;border-radius:16px;border:2px solid #f3f4f6;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;text-align:center;justify-content:space-between;height:100%;gap:0.75rem;transition:border-color 0.2s,box-shadow 0.2s;}.tagihan-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}.tagihan-card > div:first-child{flex:1;display:flex;flex-direction:column;justify-content:center;}.tagihan-class{font-size:0.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:0.25rem;}.tagihan-name{font-size:1rem;color:var(--dark);line-height:1.3;margin-bottom:0.25rem;font-weight:700;}.tagihan-parent{font-size:0.75rem;color:#9ca3af;font-weight:600;}.tagihan-debt-amount{font-size:1.25rem;color:var(--danger-accessible);font-weight:700;margin:0.25rem 0 0.5rem 0;line-height:1.3;}.btn-bayar{width:70%;background:var(--success-accessible);color:#fff;padding:0.75rem 1.5rem;border-radius:var(--radius-pill);font-weight:700;box-shadow:var(--shadow-md);font-size:0.875rem;transition:filter 0.2s,transform 0.1s;margin-top:0.5rem;display:flex;align-items:center;justify-content:center;min-height:2.75rem;line-height:1.4;border:none;cursor:pointer;}.btn-bayar:hover{filter:brightness(1.1);}.btn-bayar:active{transform:scale(0.95);}.tagihan-empty{grid-column:1 / -1;text-align:center;padding:2.5rem 1rem;color:var(--muted);font-weight:700;line-height:1.6;}.tagihan-empty-emoji{font-size:2.5rem;margin-bottom:0.5rem;display:block;}.riwayat-control{background:#fff;padding:0.875rem;border-radius:16px;box-shadow:var(--shadow-sm);border:1px solid #f3f4f6;margin-bottom:1rem;}.riwayat-search{position:relative;width:100%;margin-bottom:0.75rem;}.riwayat-search-input{width:100%;background:var(--bg);border:none;border-radius:var(--radius-pill);padding:0.75rem 1rem 0.75rem 2.5rem;font-weight:700;font-size:0.875rem;color:var(--dark);outline:none;transition:box-shadow 0.2s;min-height:2.5rem;line-height:1.4;}.riwayat-search-input:focus{box-shadow:0 0 0 2px rgba(255,143,171,0.2);}.riwayat-search-input::placeholder{color:#9ca3af;}.riwayat-search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:1rem;}.riwayat-row2{display:flex;gap:0.75rem;align-items:center;}.riwayat-select{background:var(--bg);border:none;border-radius:var(--radius-pill);padding:0.5rem 1rem;font-weight:700;font-size:0.875rem;outline:none;width:100%;}@media (min-width:640px){.riwayat-select{width:auto;}}.riwayat-filter-btn{flex:1;background:var(--bg);color:var(--dark);padding:0.75rem 1.5rem;border-radius:var(--radius-pill);font-weight:700;font-size:0.875rem;border:2px solid #e5e7eb;cursor:pointer;transition:all 0.2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:2.75rem;display:flex;align-items:center;justify-content:center;line-height:1.4;}.riwayat-filter-btn:hover{background:#f3f4f6;border-color:var(--secondary);}.riwayat-filter-btn:active{transform:scale(0.95);}.btn-download-pdf{flex:1;background:var(--dark);color:#fff;padding:0.75rem 1.5rem;border-radius:var(--radius-pill);font-weight:700;font-size:0.875rem;border:none;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:0.5rem;white-space:nowrap;min-height:2.75rem;line-height:1.4;}.btn-download-pdf:hover{background:var(--secondary);box-shadow:0 2px 8px rgba(0,0,0,0.15);}.btn-download-pdf:active{transform:scale(0.95);}.riwayat-list{display:flex;flex-direction:column;gap:1rem;}.riwayat-item{background:#fff;padding:0.875rem 1rem;border-radius:14px;border-left:6px solid var(--info);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:0.75rem;}@media (min-width:640px){.riwayat-item{flex-direction:row;}}.riwayat-student-info{width:100%;display:flex;flex-direction:column;gap:0.25rem;align-items:flex-start;}@media (min-width:640px){.riwayat-student-info{width:auto;}}.riwayat-student-name-line{display:flex;align-items:center;justify-content:flex-start;gap:0;}.riwayat-kelas{font-size:0.75rem;font-weight:700;color:var(--muted);text-align:left;}.riwayat-name{font-size:1rem;color:var(--dark);}.riwayat-parent{font-size:0.75rem;color:#9ca3af;}.riwayat-right{display:flex;align-items:center;gap:1.5rem;}.riwayat-total-label{font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;color:var(--muted);}.riwayat-total-value{font-size:1.25rem;color:var(--dark);line-height:1.3;}.btn-detail{background:#fff;border:2px solid rgba(99,110,114,0.2);color:var(--muted);padding:0.5rem 1.5rem;border-radius:var(--radius-pill);font-weight:700;transition:background 0.2s;}.btn-detail:hover{background:#f9fafb;}.riwayat-empty{text-align:center;padding:3rem 1rem;}.riwayat-empty-emoji{font-size:2.5rem;margin-bottom:0.5rem;}.laporan-card{background:#fff;padding:1.25rem;border-radius:16px;border:1px solid #f3f4f6;}.laporan-inner{display:flex;flex-direction:column;gap:1.25rem;align-items:flex-start;}@media (min-width:768px){.laporan-inner{flex-direction:row;}}.laporan-main{flex:1;}.laporan-title{font-size:1.25rem;color:var(--dark);margin-bottom:0.375rem;}.laporan-subtitle{color:var(--muted);font-size:0.875rem;margin-bottom:1rem;}.laporan-fields{display:flex;flex-direction:column;gap:1rem;max-width:28rem;}.field-label{display:block;font-size:0.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;margin-left:0.5rem;margin-bottom:0.25rem;}.field-input{width:100%;background:var(--bg);border:none;border-radius:var(--radius-xl);padding:0.75rem 1rem;font-weight:700;color:var(--dark);outline:none;}.field-input:focus{box-shadow:0 0 0 2px rgba(255,143,171,0.3);}.field-select{width:100%;background:var(--bg);border:none;border-radius:var(--radius-xl);padding:0.75rem 1rem;font-weight:700;color:var(--dark);outline:none;cursor:pointer;}.field-select-btn{width:100%;background:var(--bg);border:2px solid #e5e7eb;border-radius:var(--radius-xl);padding:0.75rem 1rem;font-weight:700;color:var(--dark);outline:none;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;gap:0.5rem;font-size:0.875rem;}.field-select-btn:hover{background:#f3f4f6;border-color:var(--accent);}.field-select-btn:active{transform:scale(0.98);}.field-select:focus{box-shadow:0 0 0 2px rgba(255,143,171,0.3);}.laporan-info{background:#fefce8;padding:1rem;border-radius:12px;border:1px solid #fef08a;font-size:0.875rem;color:#92400e;}.laporan-actions{display:flex;gap:0.75rem;}.btn-print{flex:1;background:var(--secondary-accessible);color:#fff;padding:0.75rem;border-radius:var(--radius-pill);font-weight:700;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;gap:0.5rem;transition:filter 0.2s;}.btn-print:hover{filter:brightness(1.1);}.btn-excel{flex:1;background:var(--success-accessible);color:#fff;padding:0.75rem;border-radius:var(--radius-pill);font-weight:700;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;gap:0.5rem;transition:filter 0.2s;}.btn-excel:hover{filter:brightness(1.1);}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem;}.modal-box{background:#fff;border-radius:var(--radius-fun);width:100%;box-shadow:var(--shadow-2xl);position:relative;max-height:95vh;overflow-y:auto;overflow-x:hidden;}.modal-close{position:absolute;top:1.5rem;right:1.5rem;color:#9ca3af;z-index:10;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;transition:color 0.2s;}.modal-close:hover{color:#4b5563;}.modal-close svg{width:1.5rem;height:1.5rem;}.modal-header{padding:1rem 1.25rem 0.5rem;text-align:center;}.modal-title{display:none;1.25rem;color:var(--dark);line-height:1.3;}.modal-subtitle{display:none;font-size:0.875rem;color:var(--muted);margin-top:0.2rem;line-height:1.4;}.modal-body{padding:1rem 1.25rem 0.875rem;}.modal-body--full{padding:1.25rem;}.form-section{margin-bottom:1rem;}.form-section-label{font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;border-bottom:1px solid #f3f4f6;padding-bottom:0.25rem;margin-bottom:0.5rem;}.form-section-label--primary{color:var(--primary-accessible);}.form-section-label--secondary{color:var(--secondary-accessible);}.form-grid{display:grid;grid-template-columns:1fr;gap:1rem;}@media (min-width:640px){.form-grid{grid-template-columns:repeat(2,1fr);}}.form-field{display:flex;flex-direction:column;}.form-label{display:none;font-size:0.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;margin-left:0.25rem;margin-bottom:0.375rem;}.form-input-base{width:100%;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:0.75rem 1rem;font-weight:700;color:var(--dark);font-size:1rem;outline:none;transition:all 0.2s;}.form-input-base::placeholder{color:#9ca3af;}.form-input-base:focus{background:#fff;border-color:var(--secondary);box-shadow:0 0 0 4px rgba(78,205,196,0.1);}.form-input-base:-webkit-autofill,.form-input-base:-webkit-autofill:hover,.form-input-base:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px #f8fafc inset !important;-webkit-text-fill-color:var(--dark) !important;}.form-input-base--accent:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(255,217,61,0.2);}.form-input-icon-wrap{position:relative;}.form-input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none;z-index:1;}.form-input-with-icon{padding-left:2.5rem !important;}.form-input-arrow{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none;}.form-input-select{appearance:none;cursor:pointer;}.gender-toggle{display:flex;background:#f8fafc;padding:0.25rem;border-radius:12px;border:1px solid #e5e7eb;height:3rem;}.gender-btn{flex:1;border-radius:8px;font-size:0.875rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:0.25rem;transition:all 0.2s;color:#9ca3af;}.gender-btn:hover{color:#4b5563;}.gender-btn--active-secondary{background:#fff;color:var(--secondary-accessible);box-shadow:0 1px 3px rgba(0,0,0,0.1);}.gender-btn--active-primary{background:#fff;color:var(--primary-accessible);box-shadow:0 1px 3px rgba(0,0,0,0.1);}.gender-btn img{width:1.5rem;height:1.5rem;object-fit:contain;}.modal-actions{padding:0.875rem 1.25rem 1rem;margin-top:0.5rem;border-top:1px solid #f3f4f6;}.modal-actions-row{display:flex;width:100%;gap:0.75rem;}.btn-cancel{flex:1;padding:0.625rem 1.25rem;font-weight:700;color:#6b7280;background:#f3f4f6;border-radius:12px;transition:background 0.2s;font-size:0.875rem;}.btn-cancel:hover{background:#e5e7eb;}.btn-save-secondary{flex:1;background:linear-gradient(to right,var(--secondary-accessible),#0D9488);color:#fff;padding:0.625rem 1.5rem;border-radius:12px;font-weight:700;box-shadow:var(--shadow-lg);transition:all 0.2s;}.btn-save-secondary:hover{box-shadow:var(--shadow-xl);transform:translateY(-1px);}.btn-save-secondary:disabled{opacity:0.5;cursor:not-allowed;transform:none;}.btn-delete{width:100%;background:var(--danger-accessible);color:#fff;padding:0.625rem 1.5rem;border-radius:12px;font-weight:700;box-shadow:var(--shadow-lg);transition:all 0.2s;}.btn-delete:hover{box-shadow:var(--shadow-xl);transform:translateY(-1px);}.btn-delete:disabled{opacity:0.5;cursor:not-allowed;transform:none;}.student-item-action{grid-column:1 / -1;margin-top:1rem;}div[x-show*="hitung"] .student-item-action{grid-column:1 / -1;margin-top:1rem;}@media (min-width:480px){div[x-show*="hitung"] .student-item-action{grid-column:2;margin-top:0;}}.btn-atur-biaya{width:100%;background:linear-gradient(to right,var(--secondary-accessible),#0D9488);color:#fff;padding:0.625rem 1.5rem;border-radius:12px;font-weight:700;box-shadow:var(--shadow-lg);transition:all 0.2s;}@media (min-width:480px){.btn-atur-biaya{width:auto;padding:0.625rem 1.5rem;}}.btn-atur-biaya:hover{box-shadow:var(--shadow-xl);transform:translateY(-1px);}.btn-atur-biaya:disabled{opacity:0.5;cursor:not-allowed;transform:none;}.modal-actions-delete{margin-top:0.75rem;padding-top:0.75rem;border-top:1px solid #f3f4f6;}.btn-save-accent{flex:1;background:var(--accent);color:var(--dark);padding:0.625rem 1.5rem;border-radius:12px;font-weight:700;box-shadow:0 4px 12px rgba(255,217,61,0.3);transition:all 0.2s;}.btn-save-accent:hover{box-shadow:var(--shadow-xl);transform:translateY(-1px);}.btn-save-accent:disabled{opacity:0.5;cursor:not-allowed;transform:none;}.btn-delete-danger{width:100%;padding:0.625rem 1.5rem;background:#ef4444;color:#fff;font-weight:700;border-radius:12px;box-shadow:0 4px 12px rgba(239,68,68,0.3);transition:all 0.2s;}.btn-delete-danger:hover{box-shadow:var(--shadow-xl);transform:translateY(-1px);}.btn-delete-danger:disabled{opacity:0.5;cursor:not-allowed;transform:none;}.atur-biaya-box{background:#fff;padding:1.5rem;border-radius:var(--radius-fun);width:100%;max-width:32rem;box-shadow:var(--shadow-2xl);position:relative;max-height:90vh;display:flex;flex-direction:column;}.atur-biaya-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;border-bottom:1px solid #f3f4f6;padding-bottom:1rem;}.atur-biaya-student-name{font-size:1.125rem;color:var(--dark);}.atur-biaya-student-meta{font-size:0.75rem;color:var(--muted);font-weight:700;}.atur-biaya-total-label{font-size:0.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;font-weight:700;}.atur-biaya-total-value{font-weight:700;color:var(--primary-accessible);font-size:1.25rem;line-height:1.3;margin-top:0.25rem;}.atur-biaya-scroll{flex:1;overflow-y:auto;padding-right:0.5rem;}.section-mini-label{font-size:0.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;}.master-biaya-section{margin-bottom:1rem;}.master-biaya-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0.5rem;}.master-biaya-note{font-size:0.75rem;color:#6b7280;font-style:italic;}.cost-list{display:flex;flex-direction:column;gap:0.5rem;}.cost-list-item{display:flex;align-items:center;justify-content:space-between;gap:0.75rem;padding:0.625rem 0.875rem;background:#fff;border:1px solid #e5e7eb;border-radius:10px;transition:opacity 0.2s;}.cost-list-item--inactive{opacity:0.45;}.cost-list-name{font-weight:600;color:var(--dark);font-size:0.875rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.cost-list-controls{display:flex;align-items:center;gap:0.625rem;flex-shrink:0;}.cost-amount-badge{font-size:0.8rem;font-weight:700;color:var(--dark);background:#f3f4f6;border-radius:6px;padding:0.2rem 0.5rem;white-space:nowrap;}.toggle-switch{position:relative;display:inline-flex;height:1.25rem;width:2.25rem;align-items:center;border-radius:9999px;transition:background 0.2s;outline:none;flex-shrink:0;}.toggle-switch--on{background:var(--success);}.toggle-switch--off{background:#d1d5db;}.toggle-knob{display:inline-block;height:0.875rem;width:0.875rem;transform:translateX(4px);border-radius:50%;background:#fff;transition:transform 0.2s ease-in-out;box-shadow:0 1px 2px rgba(0,0,0,0.15);}.toggle-knob--on{transform:translateX(1rem);}.empty-cost-msg{padding:1rem;text-align:center;font-size:0.75rem;color:var(--muted);font-style:italic;}.atur-biaya-extra{background:#f9fafb;border-radius:12px;padding:0.75rem;border:1px solid #f3f4f6;margin-bottom:0.5rem;}.manual-bills-section{margin-bottom:0.75rem;}.manual-bills-list{display:flex;flex-direction:column;gap:0.25rem;}.manual-bill-item{display:flex;align-items:center;justify-content:space-between;padding:0.5rem;background:#fff;border-radius:8px;border:1px solid #fef08a;font-size:0.75rem;box-shadow:var(--shadow-sm);}.manual-bill-name{font-weight:700;color:var(--dark);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.manual-bill-amount{color:#92400e;margin:0 0.5rem;}.manual-bill-delete{color:var(--danger-accessible);font-weight:700;padding:0 0.25rem;}.manual-bill-delete:hover{color:#991B1B;}.discount-chips{display:flex;flex-wrap:wrap;gap:0.5rem;}.discount-chip{background:#fef2f2;color:var(--danger-accessible);padding:0.25rem 0.25rem 0.25rem 0.5rem;border-radius:6px;font-size:0.625rem;font-weight:700;border:1px solid #fee2e2;display:flex;align-items:center;gap:0.25rem;box-shadow:var(--shadow-sm);}.discount-chip-del{padding:0.125rem;border-radius:4px;color:var(--danger-accessible);}.discount-chip-del:hover{background:#fee2e2;}.no-discount{font-size:0.75rem;color:var(--muted);font-style:italic;}.atur-input-section{display:flex;flex-direction:column;gap:1rem;margin-top:0.75rem;padding-top:0.75rem;border-top:1px solid #e5e7eb;}.mini-input-label{font-size:0.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;margin-bottom:0.25rem;}.mini-input{display:flex;flex-direction:column;gap:0.5rem;}.mini-text-input{width:100%;font-size:0.875rem;padding:0.5rem;border-radius:8px;border:1px solid #e5e7eb;background:#f8fafc;color:var(--dark);outline:none;transition:border-color 0.2s;}.mini-text-input::placeholder{color:#9ca3af;}.mini-text-input:focus{border-color:#fca5a5;}.mini-text-input--yellow:focus{border-color:#fde047;}.mini-text-input:-webkit-autofill,.mini-text-input:-webkit-autofill:hover,.mini-text-input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px #f8fafc inset !important;-webkit-text-fill-color:var(--dark) !important;}.mini-input-row{display:flex;gap:0.5rem;}.mini-input-amount-wrap{position:relative;flex:1;}.mini-input-prefix{position:absolute;left:0.75rem;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:0.75rem;font-weight:700;}.mini-input-amount{width:100%;font-size:0.875rem;padding:0.5rem 0.5rem 0.5rem 2rem;border-radius:8px;border:1px solid #e5e7eb;background:#f8fafc;color:var(--dark);outline:none;text-align:right;transition:border-color 0.2s;}.mini-input-amount::placeholder{color:#9ca3af;}.mini-input-amount:focus{border-color:#fca5a5;}.mini-input-amount--yellow:focus{border-color:#fde047;}.mini-input-amount:-webkit-autofill,.mini-input-amount:-webkit-autofill:hover,.mini-input-amount:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px #f8fafc inset !important;-webkit-text-fill-color:var(--dark) !important;}.mini-add-btn{font-size:0.875rem;font-weight:700;padding:0.5rem 1rem;border-radius:8px;transition:background 0.2s;}.mini-add-btn--red{background:#fee2e2;color:var(--danger-accessible);}.mini-add-btn--red:hover{background:#fecaca;}.mini-add-btn--yellow{background:#fef9c3;color:#92400e;}.mini-add-btn--yellow:hover{background:#fef08a;}.atur-biaya-footer{margin-top:1rem;padding-top:0.5rem;border-top:1px solid #f3f4f6;text-align:center;}.btn-close-panel{width:100%;padding:0.75rem;font-weight:700;color:#4b5563;background:#f3f4f6;border-radius:12px;transition:background 0.2s;}.btn-close-panel:hover{background:#e5e7eb;}.modal-overlay--delete{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(4px);}.modal-delete-box{background:#fff;border-radius:40px;width:100%;max-width:24rem;box-shadow:var(--shadow-2xl);position:relative;overflow:hidden;text-align:center;padding:2rem;}.modal-delete-bg{position:absolute;top:0;left:0;width:100%;height:8rem;background:linear-gradient(to bottom,#fef2f2,#fff);z-index:0;border-radius:40px 40px 0 0;}.modal-delete-icon{width:5rem;height:5rem;background:#fff;border-radius:50%;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;font-size:3rem;box-shadow:var(--shadow-lg);border:4px solid #fef2f2;position:relative;z-index:1;animation:bounce-slow 1.5s infinite;}.modal-delete-title{font-size:1.5rem;color:var(--dark);margin-bottom:0.75rem;position:relative;z-index:1;}.modal-delete-message{color:var(--muted);font-size:0.875rem;padding:0 1rem;margin-bottom:2rem;line-height:1.6;position:relative;z-index:1;}.modal-delete-actions{display:flex;flex-direction:column;gap:0.75rem;}.btn-delete-confirm{width:100%;background:var(--danger-accessible);color:#fff;padding:0.875rem;border-radius:16px;font-weight:700;box-shadow:0 4px 12px rgba(185,28,28,0.3);transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:0.5rem;}.btn-delete-confirm:hover{box-shadow:0 6px 16px rgba(185,28,28,0.4);transform:scale(1.02);}.btn-delete-confirm:active{transform:scale(0.98);}.btn-delete-confirm:disabled{opacity:0.5;cursor:not-allowed;transform:none;}.btn-delete-cancel{width:100%;background:transparent;color:#9ca3af;padding:0.75rem;border-radius:16px;font-weight:700;transition:all 0.2s;}.btn-delete-cancel:hover{color:#4b5563;background:#f9fafb;}.modal-tagihan-box{background:#fff;padding:2rem;border-radius:var(--radius-fun);width:100%;max-width:28rem;box-shadow:var(--shadow-2xl);max-height:90vh;overflow-y:auto;}.modal-tagihan-title{font-size:1.5rem;color:var(--dark);text-align:center;margin-bottom:0.5rem;line-height:1.3;}.modal-tagihan-sub{text-align:center;color:var(--muted);font-size:0.875rem;margin-bottom:1.5rem;line-height:1.4;}.tagihan-fields{display:flex;flex-direction:column;gap:1rem;}.tagihan-field-input{width:100%;background:var(--bg);border:none;border-radius:var(--radius-xl);padding:0.75rem;font-weight:700;color:var(--dark);outline:none;}.tagihan-field-input::placeholder{color:#9ca3af;}.tagihan-field-input:focus{box-shadow:0 0 0 2px var(--accent);}.tagihan-field-input:-webkit-autofill,.tagihan-field-input:-webkit-autofill:hover,.tagihan-field-input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px #f8fafc inset !important;-webkit-text-fill-color:var(--dark) !important;}.tagihan-info{background:#fefce8;padding:0.75rem;border-radius:12px;border:1px solid #fef08a;font-size:0.75rem;color:#92400e;font-weight:700;}.tagihan-modal-actions{display:flex;gap:0.75rem;margin-top:2rem;}.btn-tagihan-cancel{flex:1;padding:0.75rem;font-weight:700;color:#4b5563;background:#f3f4f6;border-radius:var(--radius-pill);transition:background 0.2s;}.btn-tagihan-cancel:hover{background:#e5e7eb;}.btn-tagihan-process{flex:1;background:var(--accent);color:var(--dark);padding:0.75rem;border-radius:var(--radius-pill);font-weight:700;box-shadow:var(--shadow-md);}.btn-tagihan-process:disabled{opacity:0.5;cursor:not-allowed;}.modal-bayar-box{background:#fff;padding:1.5rem;border-radius:var(--radius-fun);width:100%;max-width:32rem;box-shadow:var(--shadow-2xl);position:relative;display:flex;flex-direction:column;max-height:90vh;overflow-y:auto;}.modal-bayar-title{display:none;font-size:1.25rem;color:var(--dark);text-align:center;margin-bottom:1rem;line-height:1.3;}.bayar-student-info{display:flex;align-items:center;justify-content:center;background:#f9fafb;border-radius:12px;padding:0.75rem;margin-bottom:1rem;border:1px solid #f3f4f6;font-size:0.875rem;}.bayar-student-left{display:flex;align-items:center;gap:0.5rem;justify-content:center;}.bayar-student-icon{width:2rem;height:2rem;border-radius:50%;background:#fff;border:1px solid #e5e7eb;display:flex;align-items:center;justify-content:center;font-size:0.875rem;box-shadow:var(--shadow-sm);}.bayar-student-name{font-weight:700;color:var(--dark);}.bayar-student-sep{color:var(--muted);font-size:0.875rem;margin:0 0.375rem;}.bayar-student-class{color:var(--muted);font-size:0.75rem;}.bayar-student-parent-name{font-weight:700;color:var(--dark);}.bayar-student-parent{font-size:0.75rem;color:var(--muted);background:#fff;padding:0.25rem 0.75rem;border-radius:9999px;border:1px solid #f3f4f6;}.bayar-student-parent-name{font-weight:700;color:var(--dark);}.bayar-items{flex:1;overflow-y:auto;border:1px solid #f3f4f6;border-radius:12px;margin-bottom:1rem;background:#fff;padding:1.25rem;}.bayar-item{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:0.75rem;font-size:0.875rem;}.bayar-item:last-child{margin-bottom:0;}.bayar-item-title-discount{color:#6b7280;font-style:italic;}.bayar-item-title-main{font-weight:700;color:var(--dark);}.bayar-cicilan-badge{font-size:0.75rem;background:#fef9c3;color:#92400e;padding:0 0.25rem;border-radius:4px;margin-left:0.25rem;}.bayar-item-note{font-size:0.75rem;color:var(--muted);font-style:italic;margin-left:0.25rem;}.bayar-item-right{display:flex;align-items:center;gap:0.75rem;}.bayar-amount-discount{color:#6b7280;font-style:italic;white-space:nowrap;}.bayar-amount-main{font-weight:700;color:var(--dark);white-space:nowrap;}.btn-bayar-delete{color:var(--danger-accessible);padding:0.25rem;border-radius:4px;transition:all 0.15s;}.btn-bayar-delete:hover{color:#991B1B;background:#fef2f2;}.bayar-divider{border-top:2px dashed #d1d5db;margin:1rem 0;}.bayar-total{display:flex;justify-content:space-between;align-items:center;}.bayar-total-label{font-weight:700;color:var(--dark);font-size:1.125rem;line-height:1.3;}.bayar-total-amount{font-size:1.875rem;color:var(--dark);line-height:1.3;}.bayar-form{background:#fff;border-top:1px solid #f3f4f6;padding-top:1rem;}.bayar-input-wrap{position:relative;}.bayar-input-prefix{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-weight:700;color:var(--muted);}.bayar-amount-input{width:100%;background:var(--bg);border:2px solid rgba(107,203,119,0.3);border-radius:var(--radius-xl);padding:0.75rem 1rem 0.75rem 2.5rem;font-weight:700;font-size:1.125rem;color:var(--dark);outline:none;}.bayar-amount-input::placeholder{color:#9ca3af;}.bayar-amount-input:focus{box-shadow:0 0 0 2px var(--success);}.bayar-amount-input:-webkit-autofill,.bayar-amount-input:-webkit-autofill:hover,.bayar-amount-input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px #f8fafc inset !important;-webkit-text-fill-color:var(--dark) !important;}.bayar-small-input{width:100%;background:var(--bg);border:none;border-radius:var(--radius-xl);padding:0.75rem 1rem;font-size:0.875rem;color:var(--dark);outline:none;}.bayar-small-input::placeholder{color:#9ca3af;}.bayar-small-input:focus{box-shadow:0 0 0 2px rgba(255,143,171,0.3);}.bayar-small-input:-webkit-autofill,.bayar-small-input:-webkit-autofill:hover,.bayar-small-input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px #f8fafc inset !important;-webkit-text-fill-color:var(--dark) !important;}.bayar-upload-area{display:flex;align-items:center;justify-content:center;gap:0.5rem;width:100%;height:auto;padding:0.625rem 1rem;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;background:#f9fafb;transition:all 0.2s;position:relative;color:var(--dark);}.bayar-upload-area:hover{background:#f3f4f6;border-color:var(--secondary);}.bayar-upload-emoji{font-size:1rem;margin:0;flex-shrink:0;line-height:1;}.bayar-upload-text-main{font-size:0.875rem;font-weight:700;color:var(--dark);margin:0;}.bayar-upload-text-sub{font-size:0.7rem;color:#9ca3af;display:none;}.bayar-file-name{font-size:0.875rem;font-weight:700;color:var(--dark);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:15rem;}.bayar-actions{display:flex;gap:0.75rem;margin-top:1.5rem;}.btn-bayar-close{flex:1;padding:0.75rem;font-weight:700;color:#4b5563;background:#f3f4f6;border-radius:var(--radius-pill);transition:background 0.2s;}.btn-bayar-close:hover{background:#e5e7eb;}.btn-bayar-proses{flex:1;background:var(--success-accessible);color:#fff;padding:0.75rem;border-radius:var(--radius-pill);font-weight:700;box-shadow:var(--shadow-md);}.btn-bayar-proses:disabled{opacity:0.5;cursor:not-allowed;}@media (max-width:640px){.modal-bayar-box{padding:1rem 0.875rem;max-height:100vh;}.bayar-student-info{padding:0.5rem;margin-bottom:0.75rem;font-size:0.75rem;}.bayar-student-name{font-size:0.8rem;}.bayar-student-sep{font-size:0.75rem;margin:0 0.25rem;}.bayar-student-parent-name{font-size:0.8rem;}.bayar-items{padding:0.75rem;margin-bottom:0.75rem;max-height:20rem;}.bayar-item{margin-bottom:0.5rem;font-size:0.8rem;}.bayar-divider{margin:0.75rem 0;}.bayar-total-label{font-size:1rem;}.bayar-total-amount{font-size:1.5rem;}.bayar-form{padding-top:0.75rem;}.field-label{font-size:0.7rem;margin-bottom:0.375rem;}.bayar-small-input{padding:0.5rem 0.75rem;font-size:0.8rem;}.bayar-actions{gap:0.5rem;margin-top:1rem;}.btn-bayar-close,.btn-bayar-proses{padding:0.625rem;font-size:0.875rem;}}.modal-riwayat-box{background:#fff;padding:1.5rem;border-radius:var(--radius-fun);width:100%;max-width:42rem;box-shadow:var(--shadow-2xl);position:relative;display:flex;flex-direction:column;max-height:90vh;overflow-y:auto;}.modal-riwayat-title{text-align:center;font-size:1.25rem;color:var(--dark);margin-bottom:1rem;}.riwayat-student-card{display:flex;align-items:center;justify-content:center;background:#f9fafb;border-radius:12px;padding:0.75rem;margin-bottom:1rem;border:1px solid #f3f4f6;font-size:0.875rem;}.modal-riwayat-box .riwayat-student-info{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:0;justify-content:center;}.riwayat-student-icon{display:none;}.riwayat-student-icon img{display:none;}.riwayat-table-wrap{flex:1;overflow-y:auto;border:1px solid #f3f4f6;border-radius:12px;margin-bottom:1rem;background:rgba(249,250,251,0.5);}.riwayat-table{width:100%;font-size:0.875rem;text-align:left;border-collapse:collapse;line-height:1.5;}.riwayat-table-head{position:sticky;top:0;background:#fff;box-shadow:var(--shadow-sm);}.riwayat-table-head th{padding:0.75rem 0.75rem 0.75rem 1.5rem;font-size:0.75rem;color:var(--muted);text-transform:uppercase;border-bottom:1px solid #e5e7eb;font-weight:700;letter-spacing:0.03em;line-height:1.4;}.riwayat-table-head th:last-child{text-align:right;padding-right:0.75rem;padding-left:0;}.riwayat-date-row td{padding:0.75rem 0.75rem 0.75rem 1.5rem;font-size:0.75rem;font-weight:700;color:var(--dark);text-transform:uppercase;letter-spacing:0.05em;background:#f3f4f6;}.riwayat-date-row td:last-child{text-align:right;background:#f3f4f6;}.riwayat-tx-row{background:#fff;}.riwayat-tx-row + .riwayat-tx-row{border-top:1px solid #f9fafb;}.riwayat-tx-main{padding:0.75rem 0.75rem 0.75rem 2rem;}.riwayat-tx-title{font-weight:700;color:var(--dark);font-size:0.875rem;line-height:1.4;}.riwayat-tx-note{font-size:0.75rem;color:var(--muted);font-style:italic;margin-top:0.25rem;}.riwayat-proof-link{display:inline-flex;align-items:center;gap:0.375rem;padding:0.375rem 0.75rem;background:#eff6ff;color:#1D4ED8;border-radius:8px;font-size:0.75rem;font-weight:700;border:1px solid #bfdbfe;text-decoration:none;margin-top:0.5rem;transition:background 0.2s;}.riwayat-proof-link:hover{background:#dbeafe;}.riwayat-proof-link svg{width:0.75rem;height:0.75rem;}.riwayat-tx-amount-cell{padding:0.75rem;text-align:right;vertical-align:top;}.riwayat-tx-amount{font-weight:700;color:var(--success-accessible);font-size:0.875rem;line-height:1.4;}.btn-void{font-size:0.75rem;color:var(--danger-accessible);display:flex;align-items:center;justify-content:flex-end;gap:0.25rem;margin-top:0.25rem;width:100%;}.btn-void:hover{color:#991B1B;text-decoration:underline;}.riwayat-footer{background:#fff;border-top:1px solid #f3f4f6;padding-top:1rem;display:flex;justify-content:space-between;align-items:center;}.riwayat-total-paid-label{font-size:0.875rem;font-weight:700;color:var(--muted);margin-right:0.5rem;}.riwayat-total-paid-value{font-size:1.25rem;color:var(--dark);line-height:1.3;}.btn-riwayat-close{background:#f3f4f6;color:#4b5563;padding:0.5rem 1.5rem;border-radius:var(--radius-pill);font-weight:700;transition:background 0.2s;}.btn-riwayat-close:hover{background:#e5e7eb;}.notification-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:100;pointer-events:none;padding:1rem;}.notification-box{background:rgba(45,52,54,0.9);backdrop-filter:blur(12px);color:#fff;padding:1.5rem 2rem;border-radius:var(--radius-fun);box-shadow:0 20px 50px rgba(0,0,0,0.3);font-weight:700;display:flex;flex-direction:column;align-items:center;gap:0.75rem;text-align:center;min-width:18rem;max-width:24rem;border:2px solid rgba(255,255,255,0.2);pointer-events:auto;}.notification-icon{font-size:3rem;animation:bounce 1s infinite;}.notification-text{font-size:1.125rem;line-height:1.6;}.custom-alert-box{background:#fff;border-radius:16px;padding:2rem;max-width:28rem;box-shadow:0 20px 60px rgba(0,0,0,0.3);animation:slideUp 0.3s ease-out;}.custom-alert-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;}.custom-alert-icon{font-size:2.5rem;flex-shrink:0;}.custom-alert-title{font-size:1.25rem;font-weight:700;color:var(--dark);}.custom-alert-message{font-size:0.95rem;color:#6b7280;line-height:1.6;margin:0 0 1.5rem 0;}.custom-alert-btn{width:100%;padding:0.75rem 1.5rem;border:none;border-radius:10px;font-weight:700;font-size:0.95rem;cursor:pointer;transition:all 0.2s;}.custom-alert-error .custom-alert-btn{background:#ff6b6b;color:#fff;}.custom-alert-error .custom-alert-btn:hover{background:#ff5252;}.custom-alert-warning .custom-alert-btn{background:#ffc93c;color:var(--dark);}.custom-alert-warning .custom-alert-btn:hover{background:#ffb617;}.custom-alert-info .custom-alert-btn{background:#38bdf8;color:#fff;}.custom-alert-info .custom-alert-btn:hover{background:#0ea5e9;}.custom-alert-success .custom-alert-btn{background:#6bcb77;color:#fff;}.custom-alert-success .custom-alert-btn:hover{background:#51a363;}@keyframes slideUp{from{transform:translateY(20px);opacity:0;}to{transform:translateY(0);opacity:1;}}@media (max-width:640px){.custom-alert-box{padding:1.5rem;max-width:calc(100% - 2rem);}.custom-alert-icon{font-size:2rem;}.custom-alert-title{font-size:1.125rem;}}.celebration-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.8);z-index:60;display:flex;align-items:center;justify-content:center;padding:1rem;}.celebration-box{background:#fff;padding:2.5rem;border-radius:40px;text-align:center;max-width:28rem;width:100%;position:relative;overflow:hidden;box-shadow:var(--shadow-2xl);animation:bounce-slow 1.5s infinite;}.celebration-bg{position:absolute;inset:0;opacity:0.1;background:radial-gradient(circle at 15% 15%,rgba(255,143,171,0.2) 0%,transparent 40%),radial-gradient(circle at 85% 85%,rgba(78,205,196,0.2) 0%,transparent 40%);}.celebration-content{position:relative;z-index:10;}.celebration-emoji{font-size:3.75rem;margin-bottom:1rem;display:block;animation:pulse 2s infinite;}.celebration-title{font-size:1.875rem;color:var(--success-accessible);margin-bottom:0.5rem;line-height:1.3;}.celebration-subtitle{font-size:1.25rem;font-weight:700;color:var(--dark);margin-bottom:1.5rem;line-height:1.3;}.celebration-text{color:var(--muted);font-size:0.875rem;margin-bottom:2rem;line-height:1.6;}.btn-celebration-close{background:var(--success-accessible);color:#fff;padding:0.75rem 2rem;border-radius:var(--radius-pill);font-weight:700;box-shadow:var(--shadow-lg);transition:transform 0.2s;}.btn-celebration-close:hover{transform:scale(1.05);}@keyframes bounce-slow{0%,100%{transform:translateY(0);}50%{transform:translateY(-4px);}}@keyframes bounce{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.7;}}#print-area{display:none;}@media print{@page{size:A5 portrait;margin:0;}body{margin:0;padding:0;background-color:white;color:black;-webkit-print-color-adjust:exact;}body *{visibility:hidden;}#print-area,#print-area *{visibility:visible;}#print-area{display:block !important;position:absolute;top:0;left:0;width:100%;}.no-print{display:none !important;}.invoice-page{width:148mm;min-height:210mm;box-sizing:border-box;padding:10mm;page-break-after:always;display:flex;flex-direction:column;position:relative;font-size:10pt;}}.print-header{display:flex;align-items:center;gap:1rem;margin-bottom:0.5rem;border-bottom:2px double black;padding-bottom:0.5rem;}.print-logo{width:4rem;height:4rem;flex-shrink:0;}.print-logo img{width:100%;height:100%;object-fit:contain;}.print-school-name{flex:1;text-align:center;color:black;}.print-org{font-size:0.875rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:0.125rem;}.print-school{font-size:1.125rem;font-weight:800;text-transform:uppercase;margin-bottom:0.125rem;}.print-address{font-size:0.75rem;font-style:italic;}.print-divider{border-top:1px solid black;margin-bottom:1rem;margin-top:-0.25rem;}.print-title-section{text-align:center;margin-bottom:1rem;}.print-title-text{font-weight:700;font-size:1.125rem;color:black;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:4px;text-transform:uppercase;}.print-period{color:black;margin-top:0.25rem;font-weight:500;font-size:0.75rem;}.print-student-info{margin-bottom:0.75rem;color:black;padding:0 0.5rem;}.print-student-table{width:100%;font-size:0.875rem;font-weight:500;border-collapse:collapse;}.print-student-table td{padding:0.125rem 0;}.print-bills-table-wrap{border:1px solid black;margin-bottom:1rem;flex:1;background:white;}.print-bills-table{width:100%;color:black;border-collapse:collapse;}.print-table-head{background:#e5e7eb;border-bottom:1px solid black;}.print-table-head th{padding:0.375rem;font-weight:700;text-transform:uppercase;font-size:0.75rem;}.print-th-no{width:2rem;border-right:1px solid black;text-align:center;}.print-th-keterangan{border-right:1px solid black;text-align:left;}.print-th-jumlah{width:25%;text-align:right;}.print-tbody{font-size:0.75rem;}.print-tbody tr{border-top:1px solid black;}.print-tbody tr.italic-row{font-style:italic;color:#374151;}.print-td-no{padding:0.375rem;text-align:center;font-weight:700;border-right:1px solid black;vertical-align:top;}.print-td-keterangan{padding:0.375rem;border-right:1px solid black;vertical-align:top;}.print-td-note{font-size:0.75rem;font-style:italic;margin-top:0.125rem;color:#374151;}.print-td-amount{padding:0.375rem;text-align:right;font-weight:700;vertical-align:top;}.print-total-section{margin-bottom:0.5rem;}.print-total-box{border:1px solid black;padding:0.5rem;display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:1.125rem;color:black;margin-bottom:1.5rem;background:#f9fafb;}.print-total-label{font-size:0.875rem;}.print-total-amount{font-size:1.25rem;text-decoration:underline double;}.print-signature{display:flex;justify-content:flex-end;color:black;font-size:0.75rem;padding-right:1rem;}.print-sig-center{text-align:center;}.print-sig-line{font-weight:700;border-bottom:1px solid black;display:inline-block;min-width:7.5rem;}.space-y-4 > * + *{margin-top:1rem;}.space-y-6 > * + *{margin-top:1.5rem;}.text-primary{color:var(--primary-accessible);}.text-secondary{color:var(--secondary-accessible);}.text-accent{color:#92400e;}.text-success{color:var(--success-accessible);}.text-danger{color:var(--danger-accessible);}.text-info{color:var(--info-accessible);}.text-dark{color:var(--dark);}.text-muted{color:var(--muted);}.class-selector-wrapper{display:flex;flex-direction:column;gap:0.5rem;max-height:none;overflow-y:visible;padding:0.875rem;border-radius:12px;background:#f8fafc;border:2px solid #e5e7eb;min-height:auto;}.class-selector-card{display:flex;align-items:center;gap:0.5rem;padding:0.625rem 0.875rem;background:#fff;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all 0.2s;user-select:none;font-size:0.95rem;}.class-selector-card:hover{border-color:var(--accent);background:#fffbf0;}.class-selector-card--selected{border-color:var(--accent);background:#fffbf0;box-shadow:0 0 0 3px rgba(255,217,61,0.2);}.class-selector-card--indented{margin-left:1.25rem;font-size:0.9rem;border-style:dashed;border-color:#d1d5db;}.class-selector-radio{display:flex;align-items:center;justify-content:center;flex-shrink:0;}.class-selector-radio-ui{width:1.125rem;height:1.125rem;border:2px solid #d1d5db;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all 0.2s;flex-shrink:0;}.class-selector-radio-ui--checked{border-color:var(--accent);background:var(--accent);box-shadow:inset 0 0 0 2px #fff;}.class-selector-radio-ui--checked::after{content:'✓';color:#92400e;font-weight:700;font-size:0.75rem;}.class-selector-label{font-weight:700;color:var(--dark);cursor:pointer;flex:1;}.class-selector-accordion{display:flex;flex-direction:column;border:1px solid #d1d5db;border-radius:8px;overflow:hidden;background:#fff;margin-bottom:0;}.class-selector-accordion--open .class-selector-accordion-header{background:#fffbf0;border-bottom-color:var(--accent);}.class-selector-accordion--open .class-selector-accordion-icon{transform:rotate(180deg);}.class-selector-accordion-header{display:flex;align-items:center;justify-content:space-between;padding:0.625rem 0.875rem;background:#fafbfc;border-bottom:2px solid #e5e7eb;cursor:pointer;font-weight:700;color:var(--dark);transition:all 0.2s;font-family:inherit;font-size:1rem;width:100%;border:none;}.class-selector-accordion-header:hover{background:#f3f4f6;}.class-selector-accordion-header--has-selected{background:linear-gradient(135deg,#fffbf0 0%,#fffef5 100%);border-bottom-color:var(--accent);box-shadow:inset 0 0 0 1px rgba(255,217,61,0.3);}.class-selector-accordion-header--has-selected:hover{background:linear-gradient(135deg,#fffbf0 0%,#fffef5 100%);box-shadow:inset 0 0 0 1px rgba(255,217,61,0.5);}.class-selector-accordion-header--has-selected .class-selector-accordion-title{color:var(--dark);font-weight:800;}.class-selector-accordion-header--has-selected .class-selector-accordion-title::before{background:var(--accent);box-shadow:0 0 0 2px rgba(255,217,61,0.3);}.class-selector-accordion-header--has-selected .class-selector-accordion-icon{color:var(--primary-accessible);font-weight:700;}.class-selector-accordion-title{display:flex;align-items:center;gap:0.5rem;font-size:1rem;font-weight:700;color:var(--dark);}.class-selector-accordion-title::before{content:'';display:inline-block;width:0.5rem;height:0.5rem;border-radius:50%;background:var(--accent);}.class-selector-accordion-icon{width:1.25rem;height:1.25rem;color:#9ca3af;transition:transform 0.2s;flex-shrink:0;}.class-selector-accordion-content{display:none;flex-direction:column;gap:0.35rem;padding:0.5rem;background:#fff;border:2px solid #e5e7eb;border-top:1px solid #f3f4f6;border-radius:0 0 10px 10px;}.class-selector-accordion--open .class-selector-accordion-content{display:flex;}.font-mono{font-family:inherit;}