:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,#7c3aed,#ec4899,#f97316);position:relative;overflow:hidden}.login-bg{position:absolute;inset:0;pointer-events:none}.login-blob{position:absolute;width:420px;height:420px;border-radius:999px;background:#ffffff1f;filter:blur(70px);animation:loginFloat 18s ease-in-out infinite}.login-blob-1{top:-220px;right:-220px}.login-blob-2{bottom:-220px;left:-220px;animation-delay:9s}@keyframes loginFloat{0%,to{transform:translate(0)}50%{transform:translate(90px,90px)}}.login-card{position:relative;width:100%;max-width:460px;background:#fff;border-radius:28px;padding:3rem;box-shadow:0 24px 70px #00000059;z-index:2}.login-logo{display:flex;justify-content:center;margin-bottom:1.75rem;position:relative}.login-logo-glow{position:absolute;width:92px;height:92px;border-radius:22px;background:linear-gradient(135deg,#7c3aed,#ec4899);filter:blur(18px);opacity:.55}.login-logo-icon{width:92px;height:92px;border-radius:22px;background:linear-gradient(135deg,#7c3aed,#ec4899);display:flex;align-items:center;justify-content:center;color:#fff;position:relative}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2.5rem;font-weight:900;color:#111827;margin:0 0 .5rem}.login-header p{margin:0;color:#6b7280;font-size:1.05rem}.login-error{display:flex;gap:.75rem;align-items:flex-start;background:#fef2f2;color:#b91c1c;border-left:4px solid #ef4444;padding:1rem;border-radius:14px;margin-bottom:1.5rem;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-field{display:flex;flex-direction:column;gap:.5rem}.login-field label{font-weight:700;font-size:.9rem;color:#374151}.login-input-wrapper{position:relative}.login-input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;transition:color .2s;pointer-events:none}.login-input-wrapper input{width:100%;padding:.95rem 1rem .95rem 3rem;border:2px solid #e5e7eb;border-radius:14px;background:#f9fafb;color:#111827;font-size:1rem;transition:all .2s}.login-input-wrapper input:hover{border-color:#d1d5db}.login-input-wrapper input:focus{outline:none;border-color:#7c3aed;background:#fff;box-shadow:0 0 0 3px #7c3aed1f}.login-input-wrapper:focus-within .login-input-icon{color:#7c3aed}.login-btn{margin-top:.25rem;width:100%;border:none;border-radius:14px;padding:1rem;font-weight:900;font-size:1.1rem;cursor:pointer;color:#fff;background:linear-gradient(135deg,#7c3aed,#ec4899);box-shadow:0 10px 26px #7c3aed59;transition:transform .15s,box-shadow .15s,opacity .15s}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 16px 34px #7c3aed73}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-btn-content,.login-btn-loading{display:inline-flex;gap:.6rem;align-items:center;justify-content:center}.login-spinner{width:18px;height:18px;border-radius:999px;border:2px solid rgba(255,255,255,.8);border-top-color:transparent;animation:spin .9s linear infinite}.login-footer{margin-top:1.75rem;text-align:center;color:#6b7280}.login-footer a{color:#7c3aed;font-weight:800;text-decoration:none}.login-footer a:hover{text-decoration:underline;color:#6d28d9}@media(max-width:520px){.login-card{padding:2rem}.login-header h1{font-size:2.1rem}}.register-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);position:relative;overflow:hidden}.register-background{position:absolute;inset:0;pointer-events:none}.bubble{position:absolute;border-radius:50%;background:#ffffff1a;filter:blur(60px);animation:float 20s infinite ease-in-out}.bubble-1{width:400px;height:400px;top:-200px;right:-200px}.bubble-2{width:400px;height:400px;bottom:-200px;left:-200px;animation-delay:10s}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(100px,100px)}}.register-card{background:#fff;border-radius:24px;box-shadow:0 20px 60px #0000004d;padding:3rem;width:100%;max-width:500px;position:relative;z-index:10}.register-logo{display:flex;justify-content:center;margin-bottom:2rem;position:relative}.logo-glow{position:absolute;inset:0;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;filter:blur(20px);opacity:.5}.logo-icon{position:relative;background:linear-gradient(135deg,#667eea,#764ba2);padding:1.25rem;border-radius:20px;color:#fff;display:flex;align-items:center;justify-content:center}.register-header{text-align:center;margin-bottom:2.5rem}.register-header h1{font-size:2.5rem;font-weight:800;color:#1a202c;margin:0 0 .5rem}.register-header p{font-size:1.125rem;color:#718096;margin:0}.success-icon{display:flex;justify-content:center;margin-bottom:2rem;color:#48bb78}.register-card h2{text-align:center;font-size:2rem;font-weight:800;color:#1a202c;margin:0 0 2rem}.warning-box{background:#fffaf0;border-left:4px solid #ed8936;padding:1.5rem;border-radius:12px;margin-bottom:2rem}.warning-title{font-weight:600;color:#7c2d12;margin:0 0 .75rem;font-size:.875rem}.warning-text{color:#9c4221;margin:0;font-size:.875rem;line-height:1.6}.error-message{display:flex;align-items:center;gap:.75rem;background:#fee;border-left:4px solid #e53e3e;padding:1rem;border-radius:12px;margin-bottom:1.5rem;color:#c53030;font-size:.875rem}.register-form{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;font-size:.875rem;color:#2d3748}.input-wrapper{position:relative}.input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#a0aec0;pointer-events:none;transition:color .2s}.input-wrapper input,.form-group input{width:100%;padding:.875rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:all .2s;background:#f7fafc;color:#1a202c}.input-wrapper input{padding-left:3rem}.input-wrapper input:hover,.form-group input:hover{border-color:#cbd5e0}.input-wrapper input:focus,.form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.input-wrapper input:focus+.input-icon,.input-wrapper:focus-within .input-icon{color:#667eea}.btn-submit,.btn-primary{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-weight:700;font-size:1.125rem;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #667eea66;text-decoration:none;display:block;text-align:center}.btn-submit{margin-top:.5rem}.btn-submit:hover:not(:disabled),.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn-submit:active:not(:disabled),.btn-primary:active{transform:translateY(0)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.register-footer{text-align:center;margin-top:2rem;color:#718096}.register-footer a{color:#667eea;font-weight:600;text-decoration:none;transition:color .2s}.register-footer a:hover{color:#764ba2;text-decoration:underline}@media(max-width:640px){.register-card{padding:2rem}.register-header h1{font-size:2rem}.form-row{grid-template-columns:1fr}}.students{display:flex;flex-direction:column;gap:1.5rem}.students-loading{padding:3rem 0;display:flex;justify-content:center}.students-loading-inner{display:flex;align-items:center;gap:.75rem;color:#6b7280;font-weight:600}.students-spinner{width:18px;height:18px;border-radius:999px;border:2px solid #d1d5db;border-top-color:#7c3aed;animation:spin .9s linear infinite}.students-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.students-header h1{font-size:2rem;font-weight:900;color:#111827;margin:0}.students-header p{margin:.35rem 0 0;color:#6b7280}.students-primary-btn{border:none;cursor:pointer;color:#fff;font-weight:800;padding:.9rem 1.15rem;border-radius:14px;background:linear-gradient(135deg,#7c3aed,#ec4899);box-shadow:0 10px 22px #7c3aed40;display:inline-flex;align-items:center;gap:.6rem;transition:transform .15s,box-shadow .15s,opacity .15s}.students-primary-btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px #7c3aed52}.students-filter-tabs{display:flex;gap:.75rem;flex-wrap:wrap}.filter-tab{display:flex;align-items:center;gap:.6rem;padding:.85rem 1.25rem;border:2px solid #e5e7eb;background:#fff;border-radius:16px;cursor:pointer;font-weight:700;color:#6b7280;transition:all .2s;box-shadow:0 2px 8px #0000000a}.filter-tab:hover{border-color:#d1d5db;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.filter-tab.active{background:linear-gradient(135deg,#7c3aed,#ec4899);border-color:transparent;color:#fff;box-shadow:0 8px 20px #7c3aed4d}.tab-badge{background:#0000001a;color:inherit;padding:.25rem .65rem;border-radius:999px;font-size:.8rem;font-weight:800;min-width:26px;text-align:center}.filter-tab.active .tab-badge{background:#ffffff40}.tab-badge.success{background:#dcfce7;color:#16a34a}.filter-tab.active .tab-badge.success{background:#ffffff40;color:#fff}.tab-badge.danger{background:#fee2e2;color:#dc2626}.filter-tab.active .tab-badge.danger{background:#ffffff40;color:#fff}.students-search-card{background:#fff;border-radius:18px;padding:1rem;box-shadow:0 4px 15px #0000000f}.students-search{display:flex;align-items:center;gap:.6rem;color:#9ca3af;background:#f9fafb;border:2px solid #e5e7eb;border-radius:14px;padding:.75rem .9rem;transition:border-color .2s,box-shadow .2s}.students-search:focus-within{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f}.students-search input{width:100%;border:none;outline:none;background:transparent;color:#111827;font-size:1rem}.students-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}@media(max-width:1100px){.students-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:700px){.students-grid{grid-template-columns:1fr}}.student-card{background:#fff;border-radius:18px;padding:1.4rem;box-shadow:0 4px 14px #00000012;transition:transform .15s,box-shadow .15s,border-color .15s;border:2px solid transparent}.student-card:hover{transform:translateY(-3px);box-shadow:0 10px 26px #0000001a;border-color:#f3f4f6}.student-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.student-title h3{margin:0;font-size:1.1rem;font-weight:900;color:#111827}.student-group{display:inline-flex;align-items:center;gap:.45rem;margin-top:.6rem;color:#9ca3af}.student-group-badge{font-size:.85rem;font-weight:800;padding:.25rem .6rem;border-radius:999px}.student-pay{width:40px;height:40px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.student-pay.ok{background:#dcfce7;color:#16a34a}.student-pay.bad{background:#fee2e2;color:#dc2626;animation:pulse-warning 2s ease-in-out infinite}@keyframes pulse-warning{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.student-contact{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1rem}.student-contact-item{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.95rem}.student-contact-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-status{font-weight:800;padding:.75rem .9rem;border-radius:14px;margin-bottom:1rem;font-size:.95rem}.student-status.ok{background:#ecfdf5;color:#047857}.student-status.bad{background:#fef2f2;color:#b91c1c;border:2px solid #fecaca}.student-actions{display:flex;gap:.6rem;padding-top:1rem;border-top:1px solid #f3f4f6;flex-wrap:wrap}.student-btn{flex:1;min-width:90px;border:none;cursor:pointer;border-radius:14px;padding:.75rem .8rem;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;transition:transform .12s,filter .12s,background .12s;font-size:.875rem}.student-btn.history{background:#dbeafe;color:#1e40af}.student-btn.edit{background:#ede9fe;color:#6d28d9}.student-btn.delete{background:#fee2e2;color:#b91c1c}.student-btn:hover{transform:translateY(-1px);filter:brightness(.98)}.students-empty{text-align:center;padding:3rem 1rem;color:#6b7280;background:#fff;border-radius:18px;box-shadow:0 4px 15px #0000000f}.custom-select-wrapper{position:relative}.custom-select{width:100%;padding:.9rem 3rem .9rem 1rem;border:2px solid #e5e7eb;border-radius:14px;background:#f9fafb;color:#111827;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:20px}.custom-select:focus{outline:none;border-color:#7c3aed;background:#fff;box-shadow:0 0 0 3px #7c3aed1f}.custom-select option{padding:.75rem;background:#fff;color:#111827;font-weight:600}.students-modal-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.students-modal{width:100%;max-width:520px;background:#fff;border-radius:22px;box-shadow:0 24px 70px #00000059;max-height:90vh;overflow:auto}.students-modal.history-modal{max-width:600px}.students-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.4rem 1.4rem .75rem;gap:1rem}.students-modal-header h2{margin:0;font-size:1.5rem;font-weight:900;color:#111827;display:flex;align-items:center;gap:.75rem}.students-icon-btn{border:none;cursor:pointer;background:#f3f4f6;color:#6b7280;padding:.5rem;border-radius:10px;transition:all .2s;display:flex;align-items:center;justify-content:center}.students-icon-btn:hover{background:#e5e7eb;color:#374151}.students-form{padding:.75rem 1.4rem 1.4rem;display:flex;flex-direction:column;gap:1rem}.students-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}@media(max-width:520px){.students-form-row{grid-template-columns:1fr}}.students-field{display:flex;flex-direction:column;gap:.5rem}.students-field label{font-weight:800;font-size:.9rem;color:#374151}.students-field input,.students-field select{width:100%;padding:.9rem 1rem;border:2px solid #e5e7eb;border-radius:14px;background:#f9fafb;color:#111827;transition:border-color .2s,box-shadow .2s,background .2s}.students-field input:focus,.students-field select:focus{outline:none;border-color:#7c3aed;background:#fff;box-shadow:0 0 0 3px #7c3aed1f}.students-form-actions{display:flex;gap:.75rem;padding-top:.5rem}.students-secondary-btn{flex:1;background:#fff;border:2px solid #e5e7eb;color:#374151;font-weight:900;padding:.9rem 1rem;border-radius:14px;cursor:pointer;transition:all .2s}.students-secondary-btn:hover{background:#f9fafb;border-color:#d1d5db}.history-content{padding:.75rem 1.4rem 1.4rem}.history-empty{text-align:center;padding:3rem 1.5rem;color:#9ca3af}.history-empty svg{margin:0 auto 1rem;color:#d1d5db}.history-empty p{margin:0;font-weight:600}.history-list{display:flex;flex-direction:column;gap:.75rem}.history-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:linear-gradient(135deg,#f9fafb,#fff);border:2px solid #e5e7eb;border-radius:16px;transition:all .2s}.history-item:hover{border-color:#7c3aed;box-shadow:0 4px 12px #7c3aed1a;transform:translate(4px)}.history-date{display:flex;align-items:center;gap:.6rem;color:#6b7280}.history-month{font-weight:800;color:#111827;font-size:1.05rem}.history-amount{display:flex;align-items:center;gap:.4rem;background:linear-gradient(135deg,#dcfce7,#d1fae5);color:#16a34a;padding:.5rem 1rem;border-radius:12px;font-weight:900;font-size:1.1rem}@media(max-width:640px){.students-filter-tabs{overflow-x:auto;padding-bottom:.5rem}.filter-tab{white-space:nowrap}.student-actions{flex-direction:column}.student-btn{width:100%}}.ph-confirm-bg{position:fixed;inset:0;background:#0000008c;display:grid;place-items:center;padding:1rem;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ph-confirm{width:100%;max-width:520px;background:#fff;border-radius:22px;box-shadow:0 24px 70px #00000059;border:2px solid #f3f4f6}.ph-confirm-header{display:grid;grid-template-columns:auto 1fr auto;gap:12px;padding:1.25rem 1.25rem 1rem;align-items:start}.ph-confirm-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center}.ph-confirm-icon.danger{background:#fee2e2;color:#dc2626}.ph-confirm-icon.warning{background:#ffedd5;color:#c2410c}.ph-confirm-icon.info{background:#dbeafe;color:#2563eb}.ph-confirm-title h3{margin:0;font-size:1.15rem;font-weight:900;color:#111827}.ph-confirm-title p{margin:.25rem 0 0;color:#6b7280;font-weight:600;line-height:1.35}.ph-confirm-close{border:none;cursor:pointer;background:#f3f4f6;color:#6b7280;padding:.5rem;border-radius:10px;transition:all .2s;display:grid;place-items:center}.ph-confirm-close:hover{background:#e5e7eb;color:#374151}.ph-confirm-actions{display:flex;gap:.75rem;padding:0 1.25rem 1.25rem}.ph-btn-secondary{flex:1;background:#fff;border:2px solid #e5e7eb;color:#374151;font-weight:900;padding:.9rem 1rem;border-radius:14px;cursor:pointer;transition:all .2s}.ph-btn-danger{flex:1;border:none;cursor:pointer;color:#fff;font-weight:900;padding:.9rem 1rem;border-radius:14px;background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 10px 22px #dc262638;transition:transform .15s,box-shadow .15s}.ph-btn-danger:hover{transform:translateY(-2px);box-shadow:0 16px 30px #dc262647}.custom-select-container{position:relative;width:100%}.custom-select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.9rem 1rem;border:2px solid #e5e7eb;border-radius:16px;background:linear-gradient(135deg,#ffffffe6,#f9fafbf2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#111827;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000a}.custom-select-trigger:hover:not(:disabled){border-color:#d1d5db;box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.custom-select-container.open .custom-select-trigger{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f,0 4px 12px #7c3aed26;background:#fff}.custom-select-trigger:disabled{opacity:.5;cursor:not-allowed}.custom-select-trigger .placeholder{color:#9ca3af}.custom-select-trigger .selected{color:#111827}.chevron{color:#6b7280;transition:transform .3s cubic-bezier(.4,0,.2,1);flex-shrink:0}.chevron.rotate{transform:rotate(180deg);color:#7c3aed}.custom-select-dropdown{background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid #e5e7eb;border-radius:18px;box-shadow:0 20px 60px #00000026,0 0 0 1px #7c3aed1a;animation:dropdownSlideIn .2s cubic-bezier(.4,0,.2,1);overflow:hidden;max-height:280px;z-index:999999999!important}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.custom-select-options{max-height:inherit;overflow-y:auto;padding:.5rem}.custom-select-options::-webkit-scrollbar{width:8px}.custom-select-options::-webkit-scrollbar-track{background:transparent}.custom-select-options::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#d1d5db,#9ca3af);border-radius:999px}.custom-select-option{width:100%;display:flex;align-items:center;padding:.85rem 1rem;border:none;background:transparent;color:#374151;font-weight:600;font-size:.95rem;text-align:left;cursor:pointer;border-radius:12px;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative}.custom-select-option:before{content:"";position:absolute;inset:0;border-radius:12px;background:linear-gradient(135deg,#7c3aed0d,#ec48990d);opacity:0;transition:opacity .2s}.custom-select-option:hover:before{opacity:1}.custom-select-option:hover{color:#7c3aed;transform:translate(4px)}.custom-select-option.selected{background:linear-gradient(135deg,#7c3aed1f,#ec489914);color:#7c3aed;font-weight:800}.custom-select-option.selected:after{content:"✓";margin-left:auto;font-weight:900;color:#7c3aed}.custom-select-empty{padding:.9rem 1rem;color:#9ca3af;font-weight:800;text-align:center}.ph-page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}.ph-page-header h1{font-size:2rem;font-weight:800;color:#1a202c;margin:0}.ph-page-header p{margin:.35rem 0 0;color:#718096}.ph-card{background:#fff;border-radius:18px;box-shadow:0 4px 15px #00000014}.ph-btn-primary{display:flex;align-items:center;gap:.6rem;border:0;cursor:pointer;padding:.85rem 1.1rem;border-radius:14px;font-weight:800;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 10px 25px #667eea40;transition:all .2s}.ph-btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 35px #667eea59}.ph-btn-soft{display:flex;align-items:center;gap:.5rem;border:1px solid #e2e8f0;background:#f7fafc;color:#4a5568;padding:.65rem .9rem;border-radius:12px;cursor:pointer;font-weight:700;transition:all .2s}.ph-btn-soft:hover{background:#edf2f7}.ph-btn-info{display:flex;align-items:center;gap:.5rem;border:1px solid #dbeafe;background:#eff6ff;color:#1e40af;padding:.65rem .9rem;border-radius:12px;cursor:pointer;font-weight:800;transition:all .2s}.ph-btn-info:hover{background:#dbeafe}.ph-btn-danger{display:flex;align-items:center;gap:.5rem;border:1px solid #fed7d7;background:#fff5f5;color:#c53030;padding:.65rem .9rem;border-radius:12px;cursor:pointer;font-weight:800;transition:all .2s}.ph-btn-danger:hover{background:#ffe3e3}.ph-search{padding:.9rem 1rem;display:flex;align-items:center;gap:.7rem;border:1px solid #edf2f7}.ph-search-icon{color:#a0aec0}.ph-search input{border:0;outline:0;width:100%;font-size:1rem;background:transparent;color:#1a202c}.groups-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.group-card{background:#fff;border-radius:18px;padding:1.25rem;box-shadow:0 4px 15px #00000014;border:1px solid #edf2f7;transition:all .2s}.group-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px #0000001a}.group-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem}.group-badge{display:inline-flex;align-items:center;gap:.55rem;padding:.55rem .75rem;border-radius:999px;font-weight:800}.group-color-dot{width:14px;height:14px;border-radius:50%;box-shadow:0 0 0 4px #0000000a}.group-actions{display:flex;flex-direction:column;gap:.65rem}.ph-empty{background:#fff;border-radius:22px;padding:3rem 1.5rem;text-align:center;box-shadow:0 4px 15px #00000014;color:#718096}.ph-empty h2{margin:1rem 0 .5rem;color:#1a202c;font-weight:900}.ph-modal-bg{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ph-modal{width:100%;max-width:520px;background:#fff;border-radius:20px;box-shadow:0 25px 80px #00000040;overflow:hidden;max-height:90vh;display:flex;flex-direction:column}.ph-modal.students-modal{max-width:600px}.ph-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid #edf2f7;flex-shrink:0}.ph-modal-header h2{margin:0;font-size:1.35rem;font-weight:900;color:#1a202c;display:flex;align-items:center;gap:.75rem}.ph-icon-btn{border:0;background:#f7fafc;color:#4a5568;width:40px;height:40px;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.ph-icon-btn:hover{background:#edf2f7}.ph-form{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.ph-form-group{display:flex;flex-direction:column;gap:.45rem}.ph-form-group label{font-weight:800;font-size:.9rem;color:#2d3748}.ph-form-group input,.ph-form-group select{padding:.85rem .95rem;border-radius:14px;border:2px solid #e2e8f0;background:#f7fafc;outline:none;transition:all .2s;color:#1a202c;font-weight:600}.ph-form-group input:focus,.ph-form-group select:focus{border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1f}.ph-form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:18px;padding-right:2.75rem;cursor:pointer}.ph-form-group select option{padding:.75rem;background:#fff;color:#1a202c;font-weight:600}.ph-color-row{display:flex;align-items:center;gap:.85rem}.ph-color-row input[type=color]{width:56px;height:44px;border:2px solid #e2e8f0;background:#fff;border-radius:12px;padding:0;cursor:pointer}.ph-color-code{font-weight:800;color:#4a5568;background:#f7fafc;border:1px solid #edf2f7;padding:.45rem .65rem;border-radius:12px}.students-list-container{padding:1.25rem;overflow-y:auto;flex:1}.ph-empty-students{text-align:center;padding:3rem 1.5rem;color:#9ca3af}.ph-empty-students svg{margin:0 auto 1rem;color:#d1d5db}.ph-empty-students p{margin:0;font-weight:600}.students-list{display:flex;flex-direction:column;gap:.75rem}.student-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:linear-gradient(135deg,#f9fafb,#fff);border:2px solid #e5e7eb;border-radius:16px;transition:all .2s}.student-item:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a;transform:translate(4px)}.student-item-info h4{margin:0 0 .25rem;font-size:1.05rem;font-weight:900;color:#111827}.student-phone{display:inline-block;font-size:.875rem;color:#6b7280;font-weight:600}.ph-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1rem;color:#718096}.ph-spinner{width:44px;height:44px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@media(max-width:640px){.ph-page-header{flex-direction:column;align-items:flex-start}.group-actions{flex-direction:column}}.ss-select{position:relative;width:100%}.ss-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem;border:2px solid #e5e7eb;background:#f9fafb;border-radius:14px;padding:.9rem 1rem;cursor:pointer;transition:all .2s;color:#111827}.ss-trigger.open,.ss-trigger:focus{outline:none;border-color:#7c3aed;background:#fff;box-shadow:0 0 0 3px #7c3aed1f}.ss-trigger-left{display:flex;align-items:center;gap:.6rem;min-width:0}.ss-trigger-text{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ss-trigger-text.muted{color:#9ca3af;font-weight:700}.ss-trigger-right{display:flex;align-items:center;gap:.5rem;color:#6b7280}.ss-clear{width:26px;height:26px;border-radius:10px;border:none;background:#e5e7eb;color:#374151;cursor:pointer;font-weight:900;line-height:1;display:grid;place-items:center}.ss-clear:hover{background:#d1d5db}.ss-popover{background:#fff;border-radius:18px;border:2px solid #f3f4f6;box-shadow:0 24px 70px #0003;overflow:hidden;animation:ssIn .2s ease;z-index:999999999!important}@keyframes ssIn{0%{opacity:0;transform:translateY(-8px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}.ss-search{display:flex;align-items:center;gap:.6rem;padding:.9rem 1rem;border-bottom:2px solid #f3f4f6;color:#9ca3af}.ss-search input{border:none;outline:none;width:100%;font-weight:700;color:#111827;background:transparent}.ss-hint{padding:1rem;color:#6b7280;font-weight:700}.ss-list{max-height:260px;overflow:auto;padding:.5rem}.ss-item{width:100%;border:none;background:transparent;cursor:pointer;text-align:left;padding:.75rem .8rem;border-radius:14px;display:flex;align-items:center;justify-content:space-between;gap:.75rem;transition:background .15s}.ss-item:hover{background:#f9fafb}.ss-item-name{font-weight:900;color:#111827}.ss-item-group{font-weight:900;font-size:.85rem;padding:.25rem .6rem;border-radius:999px;white-space:nowrap}.ss-empty{padding:1rem;text-align:center;color:#9ca3af;font-weight:800}.ph-date-container{width:100%;position:relative}.ph-date-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.8rem 1rem;border:2px solid #e5e7eb;border-radius:14px;background:linear-gradient(135deg,#ffffffe6,#f9fafbf2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#111827;font-weight:700;font-size:1rem;min-height:52px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000a}.ph-date-trigger:hover:not(:disabled){border-color:#d1d5db;box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.ph-date-container.open .ph-date-trigger{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f,0 4px 12px #7c3aed26;background:#fff}.ph-date-trigger:disabled{opacity:.55;cursor:not-allowed}.ph-date-placeholder{color:#9ca3af;font-weight:700;font-size:1rem}.ph-date-value{color:#111827;font-weight:800;font-size:1rem}.ph-date-icon{width:38px;height:38px;border-radius:12px;background:#f3f4f6;color:#6b7280;display:grid;place-items:center;flex-shrink:0;transition:all .15s}.ph-date-container.open .ph-date-icon{background:#7c3aed1a;color:#7c3aed}body.datepicker-active .ph-modal *,body.datepicker-active .ph-form,body.datepicker-active .ph-form *,body.datepicker-active .ph-grid-2,body.datepicker-active .ph-grid-2 *,body.datepicker-active .ph-form-group,body.datepicker-active .ph-form-group *{overflow:visible!important}@media(max-width:520px){.ph-modal-bg.allow-scroll{overflow-y:auto!important;align-items:flex-start!important}.ph-modal-bg.allow-scroll .ph-modal{margin-top:1rem;margin-bottom:1rem}}.ph-date-popover{pointer-events:auto!important;z-index:2147483647!important;position:fixed!important;overflow:visible!important;isolation:isolate}.ph-date-card{background:#fff;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid #e5e7eb;border-radius:18px;box-shadow:0 25px 75px #0000004d,0 0 0 1px #7c3aed26;overflow:auto;animation:phDateIn .18s cubic-bezier(.4,0,.2,1);min-width:320px;opacity:1;max-height:calc(100vh - 24px);overscroll-behavior:contain;-webkit-overflow-scrolling:touch}@keyframes phDateIn{0%{opacity:0;transform:translateY(-8px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.ph-date-head{display:flex;align-items:center;justify-content:space-between;padding:.85rem .9rem;border-bottom:1px solid #f3f4f6;gap:.5rem;background:#fff;position:sticky;top:0;z-index:2}.ph-date-title{font-weight:950;color:#111827;text-transform:capitalize;letter-spacing:.2px;font-size:1.05rem}.ph-date-nav{width:38px;height:38px;border-radius:12px;border:none;background:#f3f4f6;color:#4b5563;display:grid;place-items:center;cursor:pointer;transition:all .15s;flex-shrink:0}.ph-date-nav:hover{background:#7c3aed1f;color:#7c3aed}.ph-date-week{display:grid;grid-template-columns:repeat(7,1fr);padding:.65rem .8rem .45rem;gap:.35rem;color:#6b7280;font-weight:900;font-size:.8rem;text-align:center}.ph-date-grid{display:grid;grid-template-columns:repeat(7,1fr);padding:.55rem .8rem .8rem;gap:.35rem}.ph-date-day{height:40px;border-radius:12px;border:none;background:transparent;color:#111827;font-weight:900;cursor:pointer;transition:all .15s;display:grid;place-items:center;position:relative;font-size:.95rem}.ph-date-day.outside{color:#9ca3af;font-weight:800}.ph-date-day:hover{background:#7c3aed14;color:#7c3aed;transform:translateY(-1px)}.ph-date-day.today:not(.selected):after{content:"";position:absolute;bottom:7px;width:6px;height:6px;border-radius:999px;background:#7c3aeda6}.ph-date-day.selected{background:linear-gradient(135deg,#7c3aed2e,#ec48991a);color:#7c3aed;box-shadow:0 0 0 2px #7c3aed59 inset}.ph-date-actions{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;padding:.85rem .9rem;border-top:1px solid #f3f4f6;background:#f9fafbf2;position:sticky;bottom:0;z-index:2}.ph-date-btn{height:42px;border-radius:14px;font-weight:950;border:2px solid transparent;cursor:pointer;transition:all .15s}.ph-date-btn.ghost{background:#fff;border-color:#e5e7eb;color:#374151}.ph-date-btn.ghost:hover{background:#f9fafb;border-color:#d1d5db}.ph-date-btn.danger{background:#fee2e2;color:#dc2626}.ph-date-btn.danger:hover{background:#fecaca;transform:translateY(-1px)}@media(max-width:520px){.ph-date-trigger{padding:.7rem .85rem;min-height:48px;font-size:.95rem}.ph-date-icon{width:36px;height:36px}.ph-date-card{min-width:0;width:100%;border-radius:16px;max-height:calc(100vh - 24px)}.ph-date-head{padding:.75rem}.ph-date-title{font-size:.95rem}.ph-date-nav{width:34px;height:34px}.ph-date-week{font-size:.72rem;padding:.55rem .7rem .4rem;gap:.25rem}.ph-date-grid{padding:.45rem .7rem .7rem;gap:.3rem}.ph-date-day{height:36px;font-size:.9rem}.ph-date-actions{padding:.7rem .75rem;gap:.6rem}.ph-date-btn{height:40px;font-size:.9rem}}@media(max-width:360px){.ph-date-trigger{padding:.65rem .8rem;min-height:46px;font-size:.9rem}.ph-date-icon{width:34px;height:34px}.ph-date-card{border-radius:14px}.ph-date-day{height:34px;font-size:.85rem}.ph-date-week{font-size:.7rem}.ph-date-title{font-size:.9rem}.ph-date-nav{width:32px;height:32px}}.ph-page{display:flex;flex-direction:column;gap:1.25rem}.ph-header{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap}.ph-header h1{font-size:2rem;font-weight:950;color:#111827;margin:0}.ph-header p{margin:.35rem 0 0;color:#6b7280}.ph-filters{display:flex;gap:1rem;align-items:stretch;flex-wrap:wrap}.ph-pill{display:flex;align-items:center;gap:.75rem;background:#fff;padding:.75rem 1rem;border-radius:16px;box-shadow:0 4px 15px #0000000f;color:#7c3aed}.ph-searchbar{flex:1;min-width:260px;display:flex;align-items:center;gap:.6rem;background:#fff;padding:.75rem 1rem;border-radius:16px;box-shadow:0 4px 15px #0000000f;border:2px solid transparent;transition:all .2s}.ph-searchbar:focus-within{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f}.ph-searchbar svg{color:#9ca3af}.ph-searchbar input{flex:1;border:none;outline:none;background:transparent;color:#111827;font-size:1rem}.ph-total{flex:0 0 auto;display:flex;align-items:center;gap:.6rem;background:linear-gradient(135deg,#dcfce7,#d1fae5);color:#16a34a;padding:.75rem 1.2rem;border-radius:16px;font-weight:950;box-shadow:0 4px 15px #16a34a26}.ph-total strong{color:#16a34a}.ph-list{display:flex;flex-direction:column;gap:.75rem}.ph-row{background:#fff;border-radius:18px;padding:1.15rem 1.2rem;border:1px solid #edf2f7;box-shadow:0 4px 15px #00000014;display:flex;align-items:center;justify-content:space-between;gap:1rem;transition:all .2s}.ph-row:hover{transform:translateY(-2px);box-shadow:0 10px 28px #0000001a}.ph-row-left{display:flex;align-items:center;gap:1rem;min-width:0}.ph-row-icon{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;flex-shrink:0}.ph-row-icon-green{background:linear-gradient(135deg,#dcfce7,#d1fae5);color:#16a34a}.ph-row-info{min-width:0}.ph-row-title{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;font-weight:950;color:#111827;font-size:1.05rem}.ph-badge{font-size:.82rem;font-weight:900;padding:.25rem .65rem;border-radius:999px}.ph-row-right{display:flex;align-items:center;gap:.85rem;flex-shrink:0}.ph-row-amount{font-weight:1000;font-size:1.15rem}.ph-row-amount.green{color:#16a34a}.ph-icon-delete{width:40px;height:40px;border-radius:12px;border:none;background:#f3f4f6;color:#6b7280;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;padding:0;line-height:0;appearance:none;-webkit-appearance:none;box-sizing:border-box;transition:all .15s}.ph-icon-delete:hover{background:#fee2e2;color:#dc2626;transform:translateY(-1px)}.ph-icon-delete svg{display:block}.ph-empty{text-align:center;padding:4rem 1.5rem;background:#fff;border-radius:22px;box-shadow:0 4px 15px #00000014;color:#718096}.ph-empty h2{margin:0 0 .75rem;color:#111827;font-weight:950;font-size:1.75rem}.ph-empty p{margin:0;font-size:1.05rem}.ph-modal-bg{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ph-modal{width:100%;max-width:520px;background:#fff;border-radius:22px;box-shadow:0 24px 70px #00000059;overflow:visible!important;position:relative;z-index:1000}.ph-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.4rem 1.4rem 1rem;border-bottom:2px solid #f3f4f6;background:#fff;border-radius:22px 22px 0 0}.ph-modal-header h2{margin:0;font-size:1.5rem;font-weight:950;color:#111827}.ph-icon-btn{border:none;cursor:pointer;background:#f3f4f6;color:#6b7280;padding:.5rem;border-radius:10px;display:grid;place-items:center;transition:all .15s}.ph-icon-btn:hover{background:#e5e7eb;color:#374151}.ph-form{padding:1.25rem 1.4rem 1.4rem;display:flex;flex-direction:column;gap:1rem;overflow:visible!important;background:#fff;border-radius:0 0 22px 22px}.ph-form-group{display:flex;flex-direction:column;gap:.5rem;overflow:visible!important}.ph-form-group label{font-weight:850;font-size:.9rem;color:#374151}.ph-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;overflow:visible!important}.ph-form-error{background:#fee2e2;color:#b91c1c;border:2px solid #fecaca;padding:.75rem 1rem;border-radius:14px;font-weight:900}.ph-actions{display:flex;gap:.75rem;padding-top:.25rem}.ph-btn-secondary{flex:1;background:#fff;border:2px solid #e5e7eb;color:#374151;font-weight:950;padding:.9rem 1rem;border-radius:14px;cursor:pointer;transition:all .15s}.ph-btn-secondary:hover{background:#f9fafb;border-color:#d1d5db}.ph-input-with-icon{position:relative;display:flex;align-items:center}.ph-input-with-icon svg{position:absolute;left:1rem;pointer-events:none}.ph-input-with-icon.green svg{color:#16a34a}.ph-input-with-icon input{width:100%;padding:.9rem 1rem .9rem 2.75rem;border:2px solid #e5e7eb;border-radius:14px;background:#f9fafb;color:#111827;font-weight:800;font-size:1.05rem;transition:all .15s}.ph-input-with-icon input:focus{outline:none;border-color:#16a34a;background:#fff;box-shadow:0 0 0 3px #16a34a1f}.ph-pill svg{width:36px;height:36px}.ph-pill{gap:1rem}@media(max-width:768px){.ph-header h1{font-size:1.75rem}.ph-filters{flex-direction:column;align-items:stretch}.ph-searchbar{min-width:auto}.ph-row{flex-direction:column;align-items:flex-start;gap:1rem;padding:1rem}.ph-row-right{width:100%;justify-content:space-between}.ph-grid-2{grid-template-columns:1fr}.ph-modal-bg{padding:.5rem}.ph-modal{max-width:100%}.ph-modal-header{padding:1.2rem 1.2rem .9rem}.ph-modal-header h2{font-size:1.35rem}.ph-form{padding:1rem 1.2rem 1.2rem}}@media(max-width:520px){.ph-modal-bg.allow-scroll{overflow-y:auto!important;align-items:flex-start!important}.ph-modal-bg.allow-scroll .ph-modal{margin-top:1rem;margin-bottom:1rem}.ph-header{gap:.75rem}.ph-header h1{font-size:1.5rem}.ph-header p{font-size:.9rem}.ph-pill{padding:.65rem .9rem}.ph-pill svg{width:28px;height:28px}.ph-searchbar{padding:.65rem .9rem}.ph-total{padding:.65rem 1rem}.ph-row{padding:.9rem;border-radius:16px}.ph-row-icon{width:44px;height:44px}.ph-row-title{font-size:1rem}.ph-row-amount{font-size:1.05rem}.ph-icon-delete{width:38px;height:38px}.ph-empty{padding:3rem 1rem}.ph-empty h2{font-size:1.5rem}.ph-empty p{font-size:.95rem}}@media(max-width:360px){.ph-header h1{font-size:1.35rem}.ph-modal-header h2{font-size:1.25rem}.ph-form{gap:.85rem}.ph-actions{flex-direction:column}.ph-btn-secondary,.ph-btn-primary{width:100%}}.ledger-total--neutral{background:#fff;color:#111827;border:2px solid #eef2ff}.ledger-icon--violet{background:linear-gradient(135deg,#7c3aed1f,#ec489914);color:#7c3aed}.gasto-title{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.gasto-pill{font-size:.8rem;font-weight:800;padding:.25rem .6rem;border-radius:999px;background:#ede9fe;color:#7c3aed}.gasto-date{display:flex;align-items:center;gap:.4rem;color:#718096;font-weight:800;font-size:.9rem}.ledger-amount--dark{color:#111827}.ledger-alert{margin-top:12px;padding:12px 14px;border-radius:14px;background:#fffbeb;border:1px solid #fde68a;color:#92400e;font-weight:800}.ledger-input{width:100%;padding:.9rem 1rem;border:2px solid #e5e7eb;border-radius:14px;background:#f9fafb;color:#111827;font-weight:600;transition:all .2s}.ledger-input:focus{outline:none;border-color:#7c3aed;background:#fff;box-shadow:0 0 0 3px #7c3aed1f}.gastos-page .gastos-total{background:linear-gradient(135deg,#eef2ff,#f5f3ff);color:#0c1018;box-shadow:0 4px 15px #4f46e51f}.gastos-page .gastos-total strong{color:#dc2626}.ph-row-icon-purple{background:linear-gradient(135deg,#7c3aed1f,#ec489914);color:#7c3aed}.ph-badge.purple{background:#ede9fe;color:#7c3aed}.gasto-date{margin-top:.35rem;display:flex;align-items:center;gap:.4rem;color:#6b7280;font-weight:850;font-size:.9rem}.ph-alert{margin-top:12px;padding:12px 14px;border-radius:14px;background:#fffbeb;border:1px solid #fde68a;color:#92400e;font-weight:800}.gasto-amount{color:#dc2626;font-weight:900;font-size:1.05rem}.gastos-page .ph-modal-bg,.gastos-page .ph-modal{overflow:visible!important}.gastos-page .ph-form,.gastos-page .ph-grid-2,.gastos-page .ph-form-group,.gastos-page .ph-date-container{overflow:visible!important;position:relative;z-index:1}.ph-date-popover{z-index:999999999!important;position:fixed!important}body.datepicker-active .ph-modal,.ph-modal.datepicker-open{overflow:visible!important;border-radius:0!important}body.datepicker-active .ph-modal,body.datepicker-active .ph-modal *,body.datepicker-active .ph-form{overflow:visible!important;position:static!important}.gastos-page .ph-modal{border-radius:22px!important;overflow:visible!important}.ph-date-popover{position:absolute!important;z-index:9999!important;left:50%!important;transform:translate(-50%)!important;width:auto!important;max-width:90%}body.datepicker-active .ph-modal-header{border-radius:22px 22px 0 0}body.datepicker-active .ph-form{border-radius:0 0 22px 22px}.ph-date-icon{width:48px!important;height:48px!important;font-size:1.2rem!important}.progreso{display:flex;flex-direction:column;gap:18px}.progreso-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.progreso-title{display:flex;align-items:center;gap:12px}.progreso-icon{width:46px;height:46px;border-radius:14px;background:#6366f11f;color:#5b5ef0;display:grid;place-items:center}.progreso-title h2{margin:0;font-size:22px;font-weight:800;color:#111827}.progreso-title p{margin:2px 0 0;color:#6b7280;font-size:13px}.progreso-filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.filter{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:10px 12px;box-shadow:0 8px 24px #1118270a}.filter select,.year-input{border:none;outline:none;background:transparent;font-size:14px;color:#111827}.year-input{width:92px}.progreso-error{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;padding:10px 12px;border-radius:12px;font-size:14px}.progreso-cards{display:grid;grid-template-columns:repeat(4,minmax(230px,1fr));gap:14px}.progreso-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:14px;box-shadow:0 18px 36px #1118270d}.pc-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.pc-label{margin:0;color:#6b7280;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.pc-value{margin:4px 0 0;font-size:22px;font-weight:900;color:#111827}.pc-value.pos{color:#047857}.pc-value.neg{color:#b91c1c}.pc-sub{margin:6px 0 0;color:#6b7280;font-size:12px}.pc-badge{width:40px;height:40px;border-radius:14px;display:grid;place-items:center}.pc-badge.ok{background:#10b9811f;color:#059669}.pc-badge.warn{background:#f59e0b24;color:#b45309}.pc-badge.info{background:#3b82f624;color:#2563eb}.pc-badge.danger{background:#ef44441f;color:#dc2626}.progressbar{margin-top:12px;height:10px;background:#f3f4f6;border-radius:999px;overflow:hidden}.progressbar-fill{height:100%;background:linear-gradient(90deg,#6366f1,#a78bfa);border-radius:999px}.progreso-lists{display:grid;grid-template-columns:1fr 1fr;gap:14px}.list-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:14px;box-shadow:0 18px 36px #1118270d}.list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.list-header h3{margin:0;font-size:16px;font-weight:900;color:#111827}.pill{font-size:12px;font-weight:800;padding:6px 10px;border-radius:999px;background:#eef2ff;color:#4338ca}.pill.danger{background:#fee2e2;color:#b91c1c}.list{display:flex;flex-direction:column;gap:8px;max-height:360px;overflow:auto;padding-right:4px}.row{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid #f1f5f9;background:#fbfdff;padding:10px 12px;border-radius:12px}.row-name{font-weight:700;color:#111827}.tag{font-size:12px;font-weight:800;padding:6px 10px;border-radius:999px}.tag.ok{background:#10b9811f;color:#047857}.tag.danger{background:#ef44441f;color:#b91c1c}.empty{padding:14px;border-radius:12px;border:1px dashed #e5e7eb;background:#fafafa;color:#6b7280}.empty.ok{border-color:#bbf7d0;background:#f0fdf4;color:#065f46}.progreso-loading{display:grid;place-items:center;min-height:240px}.progreso-history{margin-top:18px;background:#fff;border:2px solid #f3f4f6;border-radius:18px;padding:20px;box-shadow:0 12px 26px #0000000f}.ph-history-header h3{margin:0;display:flex;align-items:center;gap:10px;font-size:1.25rem;font-weight:900;color:#111827}.ph-history-header p{margin:8px 0 0;color:#6b7280;font-weight:600}.ph-scroll-hint{display:none;margin:12px 0 0;padding:8px 12px;background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:8px;color:#5b5ef0;font-size:.85rem;font-weight:600;text-align:center}@media(max-width:640px){.ph-scroll-hint{display:block}}.ph-chart-wrap{margin-top:18px;padding:18px;border-radius:18px;background:#fff;border:2px solid #eef2f7;box-shadow:0 10px 24px #1118270d}.ph-chart-title{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}.ph-chart-title h4{margin:0;font-size:1.1rem;font-weight:950;color:#111827}.ph-chart-title span{color:#6b7280;font-weight:700;font-size:.95rem}.ph-chart2{display:grid;grid-template-columns:120px 1fr;gap:12px;align-items:stretch}.ph-yaxis{display:flex;flex-direction:column;justify-content:space-between;padding:10px 0 34px;color:#64748b;font-weight:900;font-size:.85rem}.ph-plot{position:relative;height:220px;border-radius:18px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;overflow:hidden;padding:18px 16px 36px}.ph-gridlines{position:absolute;inset:18px 16px 36px;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}.ph-gridlines>div{height:1px;background:#94a3b859}.ph-bars{position:absolute;inset:18px 16px 36px;display:flex;gap:10px;align-items:flex-end}.ph-scroll-container{position:relative;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(99,102,241,.3) transparent}.ph-scroll-container::-webkit-scrollbar{height:6px}.ph-scroll-container::-webkit-scrollbar-track{background:transparent}.ph-scroll-container::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:3px}.ph-scroll-container::-webkit-scrollbar-thumb:hover{background:#6366f180}.ph-bar2{width:56px;flex:0 0 auto;height:100%;border:none;background:transparent;padding:0;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:10px}.ph-bar2:focus-visible{outline:3px solid rgba(99,102,241,.35);border-radius:12px}.ph-bar2-fill{width:100%;border-radius:14px 14px 8px 8px;position:relative;overflow:hidden;box-shadow:0 12px 28px #2563eb40,0 6px 12px #2563eb24,inset 0 2px 5px #ffffff59;transition:transform .22s cubic-bezier(.4,0,.2,1),filter .22s,box-shadow .22s}.ph-bar2-fill:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.42),transparent 45%);border-radius:inherit}.ph-bar2:hover .ph-bar2-fill{transform:translateY(-4px) scale(1.04);filter:saturate(1.15);box-shadow:0 16px 34px #2563eb52,0 8px 16px #2563eb2e,inset 0 2px 5px #fff6}.ph-bar2-label{font-size:.8rem;color:#475569;font-weight:950;white-space:nowrap}.ph-blue{background:linear-gradient(180deg,#60a5fa,#2563eb)}.ph-amber{background:linear-gradient(180deg,#fdba74,#f97316)}.ph-green{background:linear-gradient(180deg,#34d399,#059669);box-shadow:0 12px 28px #05966938,0 6px 12px #05966924,inset 0 2px 5px #ffffff59}.ph-red{background:linear-gradient(180deg,#fb7185,#dc2626);box-shadow:0 12px 28px #dc262638,0 6px 12px #dc262624,inset 0 2px 5px #ffffff59}.ph-plot--balance{background:linear-gradient(to bottom,#f8fafc,#f8fafcf5 45% 55%,#f8fafc)}.ph-gridlines--balance{inset:18px 16px 36px}.ph-zero-line{height:1px!important;background:linear-gradient(to right,#94a3b826,#64748b73,#94a3b826)!important}.ph-bar2-zone{position:relative;width:100%;flex:1;border-radius:14px;overflow:hidden}.ph-bar2--balance{width:56px;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:10px}.ph-bar2-fill--abs{position:absolute;left:0;right:0;border-radius:14px}.ph-bar2-fill--abs.is-pos{border-radius:14px 14px 8px 8px}.ph-bar2-fill--abs.is-neg{border-radius:8px 8px 14px 14px}.ph-bar2-fill--abs.is-pos:before{background:linear-gradient(180deg,rgba(255,255,255,.42),transparent 45%)}.ph-bar2-fill--abs.is-neg:before{background:linear-gradient(0deg,rgba(255,255,255,.38),transparent 45%)}.ph-bar2--balance:hover .ph-bar2-fill--abs.is-pos{transform:translateY(-3px) scale(1.03)}.ph-bar2--balance:hover .ph-bar2-fill--abs.is-neg{transform:translateY(3px) scale(1.03)}@media(max-width:1100px){.progreso-cards{grid-template-columns:repeat(2,minmax(230px,1fr))}.ph-chart2{grid-template-columns:100px 1fr}.ph-yaxis{font-size:.8rem}.ph-bars{gap:8px}.ph-bar2,.ph-bar2--balance{width:50px}}@media(max-width:900px){.ph-chart2{grid-template-columns:80px 1fr}.ph-yaxis{font-size:.75rem;padding:10px 0 30px}.ph-bars{gap:6px}.ph-bar2,.ph-bar2--balance{width:44px}.ph-bar2-label{font-size:.7rem}}@media(max-width:800px){.progreso-lists{grid-template-columns:1fr}.ph-plot{height:200px;padding:16px 12px 32px}.ph-gridlines,.ph-bars{inset:16px 12px 32px}.ph-chart2{grid-template-columns:75px 1fr;gap:8px}.ph-yaxis{font-size:.7rem;padding:8px 0 28px}}@media(max-width:640px){.progreso-cards{grid-template-columns:1fr}.ph-history-header h3{font-size:1.1rem}.ph-chart-title h4{font-size:1rem}.ph-chart-title span{font-size:.85rem}.ph-chart2{grid-template-columns:70px 1fr;gap:8px}.ph-yaxis{font-size:.7rem;padding:8px 0 26px}.ph-plot{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}.ph-gridlines{min-width:700px}.ph-bars{min-width:700px;gap:8px}.ph-bar2,.ph-bar2--balance{width:48px;gap:8px}.ph-bar2-label{font-size:.7rem}.ph-plot::-webkit-scrollbar{height:6px}.ph-plot::-webkit-scrollbar-track{background:#94a3b81a;border-radius:3px}.ph-plot::-webkit-scrollbar-thumb{background:#6366f166;border-radius:3px}.ph-plot::-webkit-scrollbar-thumb:hover{background:#6366f199}}@media(max-width:520px){.year-input{width:80px}.ph-chart-wrap{padding:14px}.ph-chart2{grid-template-columns:65px 1fr}.ph-yaxis{font-size:.65rem}.ph-plot{height:180px}.ph-gridlines,.ph-bars{min-width:650px}.ph-bar2,.ph-bar2--balance{width:45px}.ph-bar2-label{font-size:.65rem}}@media(max-width:420px){.progreso-history{padding:16px}.ph-chart-wrap{padding:12px}.ph-chart2{grid-template-columns:60px 1fr}.ph-yaxis{font-size:.6rem}.ph-plot{height:170px}.ph-gridlines,.ph-bars{min-width:600px}.ph-bar2,.ph-bar2--balance{width:42px}.ph-bar2-label{font-size:.6rem}}@media(max-width:360px){.ph-chart2{grid-template-columns:55px 1fr}.ph-yaxis{font-size:.55rem}.ph-plot{height:160px}.ph-gridlines,.ph-bars{min-width:550px}.ph-bar2,.ph-bar2--balance{width:40px}.ph-bar2-label{font-size:.55rem}}.dashboard{min-height:100vh;background:#f7fafc}.dashboard-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f7fafc}.spinner{width:50px;height:50px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.verification-pending{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fef5e7,#fce4ec);padding:1.5rem}.verification-card{background:#fff;border-radius:24px;padding:3rem;max-width:500px;width:100%;text-align:center;box-shadow:0 20px 60px #0000001a}.warning-icon{display:inline-flex;padding:1.5rem;background:#fef5e7;border-radius:50%;color:#f59e0b;margin-bottom:2rem}.verification-card h2{font-size:2rem;font-weight:800;color:#1a202c;margin:0 0 1rem}.verification-card>p{color:#718096;margin:0 0 2rem;font-size:1.125rem}.info-box{background:#eff6ff;border:2px solid #3b82f6;border-radius:12px;padding:1.5rem;margin-bottom:2rem;text-align:left}.info-box strong{display:block;color:#1e40af;margin-bottom:.5rem}.info-box p{color:#1e3a8a;margin:.25rem 0}.btn-logout{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-weight:700;font-size:1.125rem;cursor:pointer;transition:all .3s}.btn-logout:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 20px #0000001a}.header-content{max-width:1400px;margin:0 auto;padding:1.5rem 2rem;display:flex;align-items:center;justify-content:space-between}.header-left{display:flex;align-items:center;gap:1rem}.header-logo{background:#fff3;padding:.75rem;border-radius:12px;color:#fff;display:flex;align-items:center;justify-content:center}.header-title h1{font-size:1.75rem;font-weight:800;color:#fff;margin:0}.header-title p{font-size:.875rem;color:#ffffffe6;margin:0}.header-right{display:flex;align-items:center;gap:1.5rem}.user-info{text-align:right;background:#ffffff26;padding:.75rem 1.25rem;border-radius:12px}.user-name{font-weight:700;color:#fff;margin:0;font-size:1rem}.user-email{font-size:.875rem;color:#ffffffe6;margin:0}.btn-logout-header{background:#fff3;border:none;padding:.75rem;border-radius:12px;color:#fff;cursor:pointer;transition:all .2s}.btn-logout-header:hover{background:#ffffff4d}.dashboard-nav{background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000d}.nav-content{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;gap:.5rem;overflow-x:auto}.nav-tab{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;border:none;background:none;color:#718096;font-weight:600;font-size:.9375rem;cursor:pointer;border-radius:12px;transition:all .2s;white-space:nowrap}.nav-tab:hover{background:#f7fafc;color:#667eea}.nav-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.dashboard-main{max-width:1400px;margin:0 auto;padding:2rem}.dashboard-home{display:flex;flex-direction:column;gap:2rem}.welcome-banner{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:24px;padding:3rem;color:#fff;box-shadow:0 10px 40px #667eea4d}.welcome-banner h2{font-size:2.5rem;font-weight:800;margin:0 0 .75rem}.welcome-banner p{font-size:1.25rem;margin:0;opacity:.95}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.stat-card{background:#fff;border-radius:20px;padding:1.75rem;box-shadow:0 4px 15px #00000014;transition:all .3s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #0000001f}.stat-content{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem}.stat-label{font-size:.8125rem;font-weight:600;text-transform:uppercase;color:#718096;margin:0 0 .5rem;letter-spacing:.5px}.stat-value{font-size:2.5rem;font-weight:800;color:#1a202c;margin:0}.stat-icon{padding:1rem;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-icon.purple{background:#ede9fe;color:#667eea}.stat-icon.pink{background:#fce7f3;color:#ec4899}.stat-icon.orange{background:#fed7aa;color:#f97316}.stat-badge{display:inline-block;background:#d1fae5;color:#065f46;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600}.pending-payments{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 15px #00000014}.section-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.section-icon{background:#fee2e2;color:#dc2626;padding:.75rem;border-radius:12px;display:flex;align-items:center;justify-content:center}.section-header h2{font-size:1.75rem;font-weight:800;color:#1a202c;margin:0}.payments-list{display:flex;flex-direction:column;gap:.75rem}.payment-item{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;background:linear-gradient(to right,#fef2f2,#fff7ed);border-left:4px solid #dc2626;border-radius:12px;transition:all .2s}.payment-item:hover{box-shadow:0 4px 12px #dc26261a}.payment-name{font-weight:700;color:#1a202c;font-size:1.0625rem}.payment-badge{background:#fee2e2;color:#991b1b;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600}.coming-soon{text-align:center;padding:5rem 2rem;background:#fff;border-radius:24px;box-shadow:0 4px 15px #00000014}.coming-soon-icon{display:inline-flex;padding:2rem;background:#ede9fe;color:#667eea;border-radius:50%;margin-bottom:2rem}.coming-soon h2{font-size:2.5rem;font-weight:800;color:#1a202c;margin:0 0 1rem}.coming-soon p{font-size:1.25rem;color:#718096;margin:0}@media(max-width:768px){.header-content{padding:1rem}.user-info{display:none}.dashboard-main{padding:1rem}.welcome-banner{padding:2rem}.welcome-banner h2{font-size:1.75rem}.welcome-banner p{font-size:1rem}.stats-grid{grid-template-columns:1fr}.nav-content{padding:0 1rem}}.stat-card-clickable{border:none;text-align:left;width:100%;cursor:pointer}.stat-card-clickable:disabled{cursor:not-allowed}.stat-icon.red{background:#fee2e2;color:#dc2626}.badge-red{background:#fee2e2;color:#991b1b}.admin-auth{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,#7c3aed,#ec4899,#f97316);position:relative;overflow:hidden}.admin-auth-bg{position:absolute;inset:0;pointer-events:none}.admin-blob{position:absolute;width:420px;height:420px;border-radius:999px;background:#ffffff1f;filter:blur(70px);animation:float 18s ease-in-out infinite}.admin-blob-1{top:-220px;right:-220px}.admin-blob-2{bottom:-220px;left:-220px;animation-delay:9s}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(90px,90px)}}.admin-auth-card{position:relative;width:100%;max-width:460px;background:#fff;border-radius:28px;padding:3rem;box-shadow:0 24px 70px #00000059;z-index:2}.admin-auth-logo{display:flex;justify-content:center;margin-bottom:1.75rem;position:relative}.admin-auth-glow{position:absolute;width:86px;height:86px;border-radius:22px;background:linear-gradient(135deg,#7c3aed,#ec4899);filter:blur(18px);opacity:.55}.admin-auth-icon{width:86px;height:86px;border-radius:22px;background:linear-gradient(135deg,#7c3aed,#ec4899);display:flex;align-items:center;justify-content:center;color:#fff;position:relative}.admin-auth-header{text-align:center;margin-bottom:2rem}.admin-auth-header h1{font-size:2.2rem;font-weight:900;margin:0 0 .5rem;color:#111827}.admin-auth-header p{margin:0;color:#6b7280;font-size:1.05rem}.admin-auth-form{display:flex;flex-direction:column;gap:1rem}.admin-field{display:flex;flex-direction:column;gap:.5rem}.admin-field label{font-weight:800;font-size:.9rem;color:#374151}.admin-field input{width:100%;padding:.95rem 1rem;border:2px solid #e5e7eb;border-radius:14px;background:#f9fafb;color:#111827;transition:border-color .2s,box-shadow .2s,background .2s}.admin-field input:focus{outline:none;border-color:#7c3aed;background:#fff;box-shadow:0 0 0 3px #7c3aed1f}.admin-auth-btn{border:none;cursor:pointer;color:#fff;font-weight:900;padding:1rem;border-radius:14px;background:linear-gradient(135deg,#7c3aed,#ec4899);box-shadow:0 10px 26px #7c3aed59;transition:transform .15s,box-shadow .15s}.admin-auth-btn:hover{transform:translateY(-2px);box-shadow:0 16px 34px #7c3aed73}.admin-back{margin-top:1rem;border:none;background:transparent;cursor:pointer;color:#6b7280;display:inline-flex;gap:.45rem;align-items:center;padding:.5rem;font-weight:800}.admin-back:hover{color:#111827}.admin{min-height:100vh;background:#f9fafb}.admin-header{background:linear-gradient(135deg,#7c3aed,#ec4899 55%,#f97316);box-shadow:0 10px 30px #0000001f}.admin-header-inner{max-width:1400px;margin:0 auto;padding:1.6rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.admin-title{display:flex;gap:1rem;align-items:center}.admin-badge{background:#ffffff38;padding:.75rem;border-radius:16px;color:#fff;display:flex;align-items:center;justify-content:center}.admin-title h1{margin:0;color:#fff;font-weight:900;font-size:1.8rem}.admin-title p{margin:.15rem 0 0;color:#ffffffe6}.admin-header-actions{display:flex;gap:.75rem;flex-wrap:wrap}.admin-header-btn{border:none;cursor:pointer;color:#fff;font-weight:900;padding:.85rem 1rem;border-radius:14px;background:#ffffff38;display:inline-flex;align-items:center;gap:.5rem;transition:background .15s,transform .15s}.admin-header-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.admin-main{max-width:1400px;margin:0 auto;padding:2rem}.admin-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin-bottom:1.25rem}@media(max-width:1100px){.admin-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:600px){.admin-stats{grid-template-columns:1fr}}.admin-stat-card{background:#fff;border-radius:18px;padding:1.25rem;box-shadow:0 4px 14px #00000012;display:flex;gap:.9rem;align-items:center;border-left:5px solid transparent}.admin-stat-card span{display:block;color:#6b7280;font-weight:800;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.admin-stat-card strong{display:block;font-size:2.2rem;font-weight:950;color:#111827;line-height:1;margin-top:.25rem}.admin-stat-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center}.admin-stat-card.blue{border-left-color:#3b82f6}.admin-stat-card.blue .admin-stat-icon{background:#dbeafe;color:#2563eb}.admin-stat-card.green{border-left-color:#22c55e}.admin-stat-card.green .admin-stat-icon{background:#dcfce7;color:#16a34a}.admin-stat-card.orange{border-left-color:#f97316}.admin-stat-card.orange .admin-stat-icon{background:#ffedd5;color:#ea580c}.admin-stat-card.red{border-left-color:#ef4444}.admin-stat-card.red .admin-stat-icon{background:#fee2e2;color:#dc2626}.admin-filters{background:#fff;border-radius:18px;padding:1rem;box-shadow:0 4px 14px #00000012;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}.admin-search{flex:1;min-width:260px;display:flex;align-items:center;gap:.6rem;color:#9ca3af;background:#f9fafb;border:2px solid #e5e7eb;border-radius:14px;padding:.75rem .9rem}.admin-search:focus-within{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f}.admin-search input{width:100%;border:none;outline:none;background:transparent;color:#111827;font-size:1rem}.admin-filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.admin-filter-btn{border:none;cursor:pointer;padding:.75rem 1rem;border-radius:14px;font-weight:900;background:#f3f4f6;color:#6b7280;transition:transform .12s,background .12s,color .12s}.admin-filter-btn:hover{background:#e5e7eb;transform:translateY(-1px)}.admin-filter-btn.active{background:linear-gradient(135deg,#7c3aed,#ec4899);color:#fff;box-shadow:0 10px 22px #7c3aed40}.admin-loading{display:flex;flex-direction:column;align-items:center;padding:4rem 1rem;color:#6b7280;font-weight:800;gap:1rem}.admin-loader{width:54px;height:54px;border-radius:999px;border:4px solid #e5e7eb;border-top-color:#7c3aed;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.admin-list{display:flex;flex-direction:column;gap:1rem}.admin-card{background:#fff;border-radius:18px;padding:1.4rem;box-shadow:0 4px 14px #00000012;border:2px solid transparent;display:flex;gap:1rem;justify-content:space-between;flex-wrap:wrap;transition:all .2s}.admin-card:hover{border-color:#f3f4f6}.admin-card.disabled{opacity:.6;background:#fafafa}.admin-card-left{flex:1;min-width:260px}.admin-card-top{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.75rem}.admin-card-top h3{margin:0;font-size:1.4rem;font-weight:950;color:#111827}.admin-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .75rem;border-radius:999px;font-weight:950;font-size:.9rem}.admin-pill.ok{background:#dcfce7;color:#166534}.admin-pill.pending{background:#ffedd5;color:#9a3412}.admin-pill.disabled{background:#fee2e2;color:#991b1b}.admin-card-info{display:flex;flex-direction:column;gap:.5rem;color:#6b7280;font-weight:700}.admin-info-item{display:flex;align-items:center;gap:.6rem}.admin-card-actions{display:flex;flex-direction:column;gap:.6rem;min-width:180px}.admin-action-btn{border:none;cursor:pointer;border-radius:14px;padding:.85rem 1rem;font-weight:950;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;color:#fff;transition:transform .12s,filter .12s}.admin-action-btn:hover{transform:translateY(-1px);filter:brightness(.98)}.admin-action-btn.ok{background:#22c55e}.admin-action-btn.success{background:#10b981}.admin-action-btn.warn{background:#f97316}.admin-action-btn.disable{background:#6b7280}.admin-action-btn.danger{background:#ef4444}.admin-empty{text-align:center;padding:4rem 1rem;background:#fff;border-radius:18px;box-shadow:0 4px 14px #00000012;color:#6b7280}.admin-empty svg{color:#9ca3af;margin-bottom:.75rem}@media(max-width:768px){.admin-main{padding:1rem}.admin-header-inner{padding:1.2rem 1rem}.admin-card-actions{min-width:100%}}.admin-action-btn.password{background:linear-gradient(135deg,#7c3aed,#a855f7);box-shadow:0 4px 12px #7c3aed40}.admin-action-btn.password:hover{box-shadow:0 6px 16px #7c3aed59}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb}#root{width:100%;min-height:100vh}.container{width:100%;max-width:1400px;margin:0 auto;padding:0 1.5rem}html{scroll-behavior:smooth}::selection{background-color:#a855f7;color:#fff}.hide-scrollbar::-webkit-scrollbar{display:none}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}
