body{background:#f9fafb}:root{--green:#22c55e;--green-dark:#16a34a;--green-light:#dcfce7;--green-mid:#86efac;--red:#ef4444;--red-light:#fee2e2;--blue:#3b82f6;--blue-light:#dbeafe;--yellow:#f59e0b;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-500:#6b7280;--gray-700:#374151;--gray-900:#111827;--white:#fff;--radius:12px;--radius-sm:8px;--shadow:0 2px 8px #00000014;--shadow-md:0 4px 16px #0000001f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--gray-50);color:var(--gray-900);min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:15px}.app{background:var(--white);max-width:700px;min-height:100vh;margin:0 auto}.app-header{color:#fff;z-index:100;background:linear-gradient(135deg,#16a34a 0%,#22c55e 100%);padding:16px;position:sticky;top:0;box-shadow:0 2px 12px #16a34a4d}.header-content{justify-content:space-between;align-items:center;gap:12px;display:flex}.header-brand{align-items:center;gap:10px;display:flex}.brand-icon{color:#fff;flex-shrink:0}.header-brand h1{font-size:1.1rem;font-weight:700;line-height:1.2}.header-brand p{opacity:.85;font-size:.75rem}.header-actions{align-items:center;gap:8px;display:flex}.app-nav{background:var(--white);border-bottom:2px solid var(--gray-100);z-index:99;display:flex;position:sticky;top:72px}.nav-tab{cursor:pointer;color:var(--gray-500);background:0 0;border:none;border-bottom:3px solid #0000;flex:1;justify-content:center;align-items:center;gap:6px;padding:12px 8px;font-size:.85rem;font-weight:500;transition:all .2s;display:flex}.nav-tab.active{color:var(--green-dark);border-bottom-color:var(--green-dark);background:var(--green-light)}.nav-tab:hover:not(.active){background:var(--gray-50);color:var(--gray-700)}.app-main{padding:16px 16px 80px}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;padding:9px 16px;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--green-dark);color:#fff}.btn-primary:hover{background:#15803d;transform:translateY(-1px)}.btn-secondary{background:var(--gray-100);color:var(--gray-700)}.btn-secondary:hover{background:var(--gray-200)}.btn-outline{color:#fff;background:#ffffff26;border:1px solid #fff6}.btn-outline:hover{background:#ffffff40}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-icon{color:#fff;cursor:pointer;border-radius:var(--radius-sm);background:#ffffff26;border:none;justify-content:center;align-items:center;padding:8px;transition:background .2s;display:flex}.btn-icon:hover{background:#ffffff4d}.btn-icon-sm{background:var(--gray-100);color:var(--gray-500);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;padding:5px;transition:all .2s;display:flex}.btn-icon-sm:hover{background:var(--gray-200);color:var(--gray-700)}.btn-icon-sm.danger:hover{background:var(--red-light);color:var(--red)}.fab{background:var(--green-dark);color:#fff;cursor:pointer;z-index:200;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:all .2s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 16px #16a34a66}.fab:hover{background:#15803d;transform:scale(1.1)}.export-wrapper{position:relative}.export-menu{border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:300;background:#fff;min-width:180px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.export-menu button{cursor:pointer;width:100%;color:var(--gray-700);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:12px 16px;font-size:.9rem;transition:background .15s;display:flex}.export-menu button:hover{background:var(--gray-50)}.dashboard{margin-bottom:20px}.stats-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;display:grid}.stat-card{border-radius:var(--radius);background:var(--white);box-shadow:var(--shadow);border-left:4px solid #0000;align-items:center;gap:12px;padding:16px;display:flex}.stat-card.green{border-left-color:var(--green-dark);background:var(--green-light)}.stat-card.blue{border-left-color:var(--blue);background:var(--blue-light)}.stat-card.green-light{border-left-color:var(--green);background:#f0fdf4}.stat-card.red-light{border-left-color:var(--red);background:var(--red-light)}.stat-icon{opacity:.7}.stat-label{color:var(--gray-500);font-size:.75rem;font-weight:500}.stat-value{color:var(--gray-900);font-size:1.6rem;font-weight:800}.monthly-section{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;padding:16px}.section-header{color:var(--gray-700);align-items:center;gap:8px;margin-bottom:12px;font-weight:700;display:flex}.monthly-grid{grid-template-columns:repeat(6,1fr);gap:6px;display:grid}.month-stat{border-radius:var(--radius-sm);border:2px solid var(--gray-200);background:var(--gray-50);cursor:pointer;flex-direction:column;align-items:center;padding:8px 4px;font-size:.7rem;transition:all .2s;display:flex}.month-stat.has-data{border-color:var(--green-mid);background:var(--green-light)}.month-stat.active{border-color:var(--green-dark)!important;background:var(--green-dark)!important;color:#fff!important}.month-name{font-size:.7rem;font-weight:700}.month-amount{color:var(--green-dark);font-size:.65rem;font-weight:600}.month-stat.active .month-amount{color:#fff}.month-count{color:var(--gray-500);font-size:.6rem}.month-stat.active .month-count{color:#fffc}.filter-info{color:var(--gray-600);align-items:center;gap:8px;margin-top:10px;font-size:.85rem;display:flex}.clear-filter{background:var(--red-light);color:var(--red);cursor:pointer;border:none;border-radius:6px;padding:3px 8px;font-size:.75rem;font-weight:600}.section-header-row{justify-content:space-between;align-items:center;margin:20px 0 12px;display:flex}.section-header-row h3{color:var(--gray-700);align-items:center;gap:8px;font-size:1rem;font-weight:700;display:flex}.child-card{border-radius:var(--radius);box-shadow:var(--shadow);border-left:4px solid var(--gray-300);background:#fff;margin-bottom:12px;transition:box-shadow .2s;overflow:hidden}.child-card.up-to-date{border-left-color:var(--green)}.child-card.behind{border-left-color:var(--red)}.child-card:hover{box-shadow:var(--shadow-md)}.child-card-header{cursor:pointer;justify-content:space-between;align-items:center;gap:8px;padding:14px 16px;display:flex}.child-info{align-items:center;gap:10px;display:flex}.child-avatar{background:linear-gradient(135deg, var(--green-dark), var(--green));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;font-weight:700;display:flex}.child-info h3{color:var(--gray-900);font-size:.95rem;font-weight:700}.guardian{color:var(--gray-500);margin-top:1px;font-size:.75rem}.child-stats{align-items:center;gap:8px;display:flex}.status-badge{border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:.7rem;font-weight:600;display:inline-flex}.status-badge.paid{background:var(--green-light);color:var(--green-dark)}.status-badge.pending{background:var(--red-light);color:var(--red)}.total-amount{color:var(--green-dark);font-size:.95rem;font-weight:700}.month-grid{grid-template-columns:repeat(6,1fr);gap:4px;padding:0 16px 14px;display:grid}.month-chip{cursor:pointer;text-align:center;border:1px solid;border-radius:6px;flex-direction:column;align-items:center;padding:6px 2px;font-size:.65rem;font-weight:600;transition:all .15s;display:flex;position:relative}.month-chip.paid{background:var(--green-light);border-color:var(--green-mid);color:var(--green-dark)}.month-chip.pending{background:var(--red-light);color:var(--red);border-color:#fca5a5}.month-chip:hover{transform:scale(1.05)}.check{font-size:.6rem;line-height:1}.payments-list{border-top:1px solid var(--gray-100);padding:14px 16px}.payments-list-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.payments-list-header h4{color:var(--gray-700);font-size:.9rem;font-weight:700}.payment-row{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:flex-start;gap:8px;padding:10px 0;display:flex}.payment-row:last-of-type{border-bottom:none}.payment-row>div:first-child{flex-direction:column;gap:2px;display:flex}.payment-row strong{color:var(--gray-900);font-size:.9rem}.payment-type-tag{color:var(--gray-500);font-size:.72rem}.payment-date{color:var(--gray-400);font-size:.7rem}.payment-notes{color:var(--gray-500);font-size:.72rem;font-style:italic}.payment-actions{align-items:center;gap:6px;display:flex}.amount{color:var(--green-dark);font-size:.95rem;font-weight:700}.pending-months{margin-top:12px}.pending-months h5{color:var(--gray-500);margin-bottom:6px;font-size:.8rem}.pending-tags{flex-wrap:wrap;gap:4px;display:flex}.pending-tag{background:var(--red-light);color:var(--red);border-radius:20px;padding:3px 8px;font-size:.7rem;font-weight:600}.filters-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;display:flex}.filters-bar select{border:1px solid var(--gray-200);border-radius:var(--radius-sm);min-width:120px;color:var(--gray-700);background:#fff;flex:1;padding:8px 10px;font-size:.85rem}.history-list{flex-direction:column;gap:8px;display:flex}.history-item{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;justify-content:space-between;align-items:flex-start;gap:8px;padding:12px 14px;display:flex}.history-left{align-items:flex-start;gap:10px;display:flex}.history-avatar{background:linear-gradient(135deg, var(--green-dark), var(--green));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;font-weight:700;display:flex}.history-child{color:var(--gray-900);font-size:.9rem;font-weight:700}.history-meta{color:var(--gray-500);margin-top:2px;font-size:.75rem}.history-date{color:var(--gray-400);margin-top:2px;font-size:.7rem}.history-notes{color:var(--gray-500);margin-top:2px;font-size:.72rem;font-style:italic}.history-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.history-amount{color:var(--green-dark);font-size:1rem;font-weight:800}.modal-overlay{z-index:500;background:#0006;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}@media (width>=480px){.modal-overlay{align-items:center;padding:20px}}.modal{border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:480px;box-shadow:var(--shadow-md);background:#fff;max-height:90vh;animation:.25s slideUp;overflow-y:auto}@media (width>=480px){.modal{border-radius:var(--radius);animation:.2s fadeIn}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.modal-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h2{color:var(--gray-900);align-items:center;gap:8px;font-size:1rem;font-weight:700;display:flex}.modal-header .btn-icon{background:var(--gray-100);color:var(--gray-600)}.modal-header .btn-icon:hover{background:var(--gray-200)}.modal-child-info{background:var(--green-light);flex-wrap:wrap;align-items:center;gap:12px;padding:10px 20px;display:flex}.child-badge{color:var(--green-dark);font-size:.9rem;font-weight:700}.guardian-info{color:var(--gray-600);font-size:.8rem}.modal-body{flex-direction:column;gap:14px;padding:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--gray-600);align-items:center;gap:4px;font-size:.8rem;font-weight:600;display:flex}.form-group input,.form-group select{border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);color:var(--gray-900);background:#fff;width:100%;padding:10px 12px;font-size:.95rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:var(--green-dark);outline:none}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.payment-type-group{gap:8px;display:flex}.payment-type-btn{border:2px solid var(--gray-200);border-radius:var(--radius-sm);background:var(--gray-50);cursor:pointer;color:var(--gray-600);flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;font-size:.85rem;font-weight:600;transition:all .15s;display:flex}.payment-type-btn.active{border-color:var(--green-dark);background:var(--green-light);color:var(--green-dark)}.modal-actions{gap:10px;margin-top:4px;display:flex}.modal-actions .btn{flex:1;justify-content:center}.error-text{color:var(--red);font-size:.8rem;font-weight:500}.success-message{text-align:center;padding:40px 20px}.success-icon{margin-bottom:12px;font-size:3rem}.success-message p{color:var(--green-dark);font-size:1.1rem;font-weight:700}.empty-state{text-align:center;color:var(--gray-500);flex-direction:column;align-items:center;gap:14px;padding:40px 20px;display:flex}.empty-state p{font-size:1rem}.empty-text{color:var(--gray-400);padding:10px 0;font-size:.85rem}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}.login-screen{background:linear-gradient(160deg,#dcfce7 0%,#f0fdf4 40%,#bbf7d0 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:380px;padding:40px 32px;box-shadow:0 8px 32px #16a34a26}.login-logo{margin-bottom:28px}.login-icon-wrap{color:#fff;background:linear-gradient(135deg,#16a34a,#22c55e);border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 14px;display:flex;box-shadow:0 4px 16px #16a34a59}.login-logo h1{color:var(--gray-900);font-size:1.4rem;font-weight:800}.login-logo p{color:var(--gray-500);margin-top:4px;font-size:.85rem}.login-form{text-align:left;flex-direction:column;gap:16px;display:flex}.login-btn{border-radius:var(--radius);justify-content:center;width:100%;padding:12px;font-size:1rem}.login-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-hint{color:var(--gray-500);margin-top:20px;font-size:.78rem;line-height:1.6}.login-hint code{background:var(--green-light);color:var(--green-dark);border-radius:4px;padding:1px 6px;font-size:.82rem;font-weight:700}.password-input-wrap{position:relative}.password-input-wrap input{padding-right:40px}.toggle-password{cursor:pointer;color:var(--gray-400);background:0 0;border:none;align-items:center;padding:2px;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.toggle-password:hover{color:var(--gray-600)}.settings-divider{background:var(--gray-100);height:1px;margin:0 20px}.settings-section-title{color:var(--gray-700);align-items:center;gap:8px;margin-bottom:-4px;font-size:.95rem;font-weight:700;display:flex}.success-text{color:var(--green-dark);font-size:.8rem;font-weight:600}.public-view{background:var(--white);max-width:700px;min-height:100vh;margin:0 auto}.public-group{margin-bottom:16px}.public-group-title{border-radius:var(--radius-sm);align-items:center;gap:8px;margin-bottom:8px;padding:8px 12px;font-size:.9rem;font-weight:700;display:flex}.paid-title{background:var(--green-light);color:var(--green-dark)}.pending-title{background:var(--red-light);color:var(--red)}.public-child-list{flex-direction:column;gap:8px;display:flex}.public-child-row{background:var(--gray-50);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:8px;padding:12px 14px;display:flex}.public-child-left{align-items:center;gap:10px;display:flex}.public-child-name{color:var(--gray-900);font-size:.9rem;font-weight:700}.paid-avatar{background:linear-gradient(135deg, var(--green-dark), var(--green))!important}.pending-avatar{background:linear-gradient(135deg,#dc2626,#ef4444)!important}.public-child-right{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.month-mini-grid{flex-wrap:wrap;justify-content:flex-end;gap:2px;max-width:160px;display:flex}.month-mini{border-radius:3px;justify-content:center;align-items:center;width:16px;height:16px;font-size:.55rem;font-weight:700;display:flex}.month-mini.paid{background:var(--green-light);color:var(--green-dark)}.month-mini.pending{background:var(--red-light);color:#dc2626}.public-total{color:var(--green-dark);font-size:.9rem;font-weight:800}.public-footer{text-align:center;color:var(--gray-400);margin-top:32px;padding:16px;font-size:.82rem}.public-footer a{color:var(--green-dark);font-weight:600;text-decoration:none}.public-footer a:hover{text-decoration:underline}a.btn{text-decoration:none}
