:root{--bg-main:#0b0f19;--bg-surface:#111827b3;--bg-surface-hover:#1f2937cc;--border-color:#ffffff14;--border-glow:#8b5cf64d;--primary:#8b5cf6;--primary-hover:#7c3aed;--secondary:#06b6d4;--secondary-hover:#0891b2;--text-main:#f8fafc;--text-muted:#94a3b8;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--shadow-sm:0 2px 8px #0003;--shadow-md:0 8px 30px #0000004d;--shadow-lg:0 12px 40px #0006;--font-sans:"Outfit", "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box;font-family:var(--font-sans);margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-main);background-image:radial-gradient(at 0 0,#8b5cf626 0,#0000 50%),radial-gradient(at 100% 100%,#06b6d41a 0,#0000 50%);background-attachment:fixed;min-height:100vh;line-height:1.5;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-main)}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.app-container{flex-direction:column;min-height:100vh;display:flex}.container{width:100%;max-width:1800px;margin:0 auto;padding:2rem 2.5rem}.login-wrapper{justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{background:var(--bg-surface);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-color);width:100%;max-width:440px;box-shadow:var(--shadow-lg);border-radius:24px;padding:3rem 2.5rem;animation:.5s cubic-bezier(.16,1,.3,1) slideUp;position:relative;overflow:hidden}.login-card:before{content:"";background:linear-gradient(90deg, var(--primary), var(--secondary));width:100%;height:4px;position:absolute;top:0;left:0}.login-header{text-align:center;margin-bottom:2.5rem}.login-logo{letter-spacing:-.05em;background:linear-gradient(135deg, #fff 30%, var(--text-muted) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:2.2rem;font-weight:800}.login-logo span{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.login-subtitle{color:var(--text-muted);font-size:.95rem}.form-group{flex-direction:column;gap:.5rem;margin-bottom:1.5rem;display:flex}.form-group label{color:var(--text-main);letter-spacing:.02em;font-size:.88rem;font-weight:500}.input-control{border:1px solid var(--border-color);color:var(--text-main);background:#ffffff0a;border-radius:12px;width:100%;padding:.8rem 1rem;font-size:1rem;transition:all .25s}.input-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--border-glow);background:#ffffff12;outline:none}.input-control::placeholder{color:#ffffff4d}.btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);color:#fff;box-shadow:0 4px 15px #8b5cf64d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.btn-primary:active{transform:translateY(0)}.btn-secondary{border:1px solid var(--border-color);color:var(--text-main);background:#ffffff0f}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626;box-shadow:0 4px 15px #ef44444d}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669;box-shadow:0 4px 15px #10b9814d}.app-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);z-index:50;background:#0f172a99;padding:1rem 0;position:sticky;top:0}.header-content{justify-content:space-between;align-items:center;display:flex}.brand{letter-spacing:-.03em;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:800;display:flex}.brand span{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.user-profile{align-items:center;gap:1rem;display:flex}.user-name{font-size:.95rem;font-weight:500}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2.5rem;display:grid}.stat-card{background:var(--bg-surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:20px;align-items:center;gap:1.25rem;padding:1.5rem;transition:all .3s;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);border-color:#ffffff26;transform:translateY(-4px)}.stat-icon{color:var(--primary);background:#8b5cf626;border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.stat-card:nth-child(2) .stat-icon{color:var(--success);background:#10b98126}.stat-card:nth-child(3) .stat-icon{color:var(--secondary);background:#06b6d426}.stat-info{flex-direction:column;display:flex}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:500}.stat-value{margin-top:.15rem;font-size:1.6rem;font-weight:700}.dashboard-grid{grid-template-columns:2fr 1fr;align-items:start;gap:2rem;display:grid}@media (width<=992px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-grid-three{grid-template-columns:1.1fr 1.8fr 1.1fr;align-items:start;gap:1.5rem;display:grid}@media (width<=1200px){.dashboard-grid-three{grid-template-columns:1fr 1fr}}@media (width<=768px){.dashboard-grid-three{grid-template-columns:1fr}}.panel{background:var(--bg-surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);box-shadow:var(--shadow-md);border-radius:24px;margin-bottom:2rem;padding:1.75rem}.panel-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.panel-title{align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;display:flex}.alerts-list{flex-direction:column;gap:1rem;display:flex}.alert-item{border:1px solid var(--border-color);background:#ffffff05;border-radius:16px;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;transition:all .2s;display:flex}.alert-item:hover{background:#ffffff0a;border-color:#ffffff1f}.alert-item.vencido{border-left:4px solid var(--danger)}.alert-item.proximo{border-left:4px solid var(--warning)}.alert-details{flex-direction:column;gap:.15rem;display:flex}.alert-name{font-size:.95rem;font-weight:600}.alert-meta{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.82rem;display:flex}.badge{text-transform:uppercase;letter-spacing:.02em;border-radius:9999px;align-items:center;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-vencido{color:var(--danger);background:#ef444426}.badge-proximo{color:var(--warning);background:#f59e0b26}.badge-activo{color:var(--success);background:#10b98126}.badge-inactivo{color:var(--text-muted);background:#94a3b826}.alert-amount{color:var(--text-main);text-align:right;font-size:1rem;font-weight:700}.alert-actions{align-items:center;gap:.5rem;display:flex}.btn-icon{border:1px solid var(--border-color);color:var(--text-main);cursor:pointer;background:#ffffff0d;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;transition:all .2s;display:flex}.btn-icon:hover{color:#fff;background:#ffffff1a;border-color:#fff3;transform:scale(1.05)}.btn-whatsapp{color:#25d366;background:#25d36626;border-color:#25d3664d}.btn-whatsapp:hover{color:#fff;background:#25d366;border-color:#25d366}.filter-bar{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.search-input-wrapper{flex:1;min-width:240px;position:relative}.select-filter{border:1px solid var(--border-color);height:46px;color:var(--text-main);cursor:pointer;background:#ffffff0a;border-radius:12px;outline:none;min-width:140px;padding:0 1rem;font-size:.9rem}.select-filter option{color:var(--text-main);background:#111827}.client-list{flex-direction:column;gap:1rem;display:flex}.client-row{border:1px solid var(--border-color);background:#ffffff05;border-radius:18px;grid-template-columns:1.5fr 1fr 1fr 1fr 120px;align-items:center;gap:1rem;padding:1.25rem;transition:all .25s;display:grid}@media (width<=768px){.client-row{grid-template-columns:1fr;gap:.75rem}.client-row>div{justify-content:space-between;align-items:center;display:flex}}.client-row:hover{background:#ffffff0a;border-color:#8b5cf640;box-shadow:0 4px 20px #00000026}.client-profile{flex-direction:column;display:flex}.client-name-title{font-size:1.05rem;font-weight:700}.client-company-title{color:var(--text-muted);font-size:.85rem}.client-service{flex-direction:column;gap:.25rem;display:flex}.client-service-tag{color:#c084fc;background:#8b5cf61a;border:1px solid #8b5cf633;border-radius:6px;align-self:flex-start;padding:.15rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.client-billing-info{flex-direction:column;display:flex}.billing-label{color:var(--text-muted);font-size:.82rem}.billing-val{font-size:.95rem;font-weight:600}.client-amount-val{color:var(--text-main);font-size:1.1rem;font-weight:700}.client-row-actions{justify-content:flex-end;gap:.5rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#030712cc;justify-content:center;align-items:center;padding:1.5rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{border:1px solid var(--border-color);width:100%;max-width:580px;max-height:90vh;box-shadow:var(--shadow-lg);background:#111827;border-radius:24px;padding:2.25rem;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;overflow-y:auto}.modal-title{border-bottom:1px solid var(--border-color);margin-bottom:1.5rem;padding-bottom:.75rem;font-size:1.5rem;font-weight:800}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.25rem;display:flex}.history-item{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}.history-item:last-child{border-bottom:none}.history-meta{flex-direction:column;display:flex}.history-date{color:var(--text-muted);font-size:.85rem}.history-period{font-size:.95rem;font-weight:600}.history-amount{color:var(--success);font-weight:700}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem}.empty-icon{opacity:.5;margin-bottom:1rem}.loading-container{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.spinner{border:3px solid #ffffff0d;border-top:3px solid var(--primary);border-radius:50%;width:40px;height:40px;margin-bottom:1rem;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tab-container{margin-top:1rem;margin-bottom:.5rem;display:flex}.tab-list{border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#11182780;border-radius:16px;gap:.25rem;padding:.35rem;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:12px;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.92rem;font-weight:600;transition:all .2s;display:flex}.tab-btn:hover{color:var(--text-main);background:#ffffff08}.tab-btn.active{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);color:#fff;box-shadow:0 4px 12px #8b5cf640}.badge-servicios{color:var(--secondary)!important;background:#06b6d426!important}.badge-publicidad{color:#f472b6!important;background:#ec489926!important}.badge-alquiler{color:var(--warning)!important;background:#f59e0b26!important}.badge-sueldos{color:var(--success)!important;background:#10b98126!important}.badge-herramientas{color:#c084fc!important;background:#8b5cf626!important}.badge-impuestos{color:var(--danger)!important;background:#ef444426!important}.badge-otros{color:var(--text-muted)!important;background:#94a3b826!important}.stat-card.stat-danger .stat-icon{color:var(--danger);background:#ef444426}.stat-card.stat-primary .stat-icon{color:var(--primary);background:#8b5cf626}.stat-card.stat-success .stat-icon{color:var(--success);background:#10b98126}.expense-list{flex-direction:column;gap:1rem;display:flex}.expense-row{border:1px solid var(--border-color);background:#ffffff05;border-radius:18px;grid-template-columns:2fr 1.2fr 1fr 1fr 100px;align-items:center;gap:1rem;padding:1.25rem;transition:all .25s;display:grid}@media (width<=768px){.expense-row{grid-template-columns:1fr;gap:.75rem}.expense-row>div{justify-content:space-between;align-items:center;display:flex}}.expense-row:hover{background:#ffffff0a;border-color:#ef444440;box-shadow:0 4px 20px #00000026}.expense-concept-info{flex-direction:column;display:flex}.expense-concept{font-size:1.05rem;font-weight:700}.expense-notes{color:var(--text-muted);margin-top:.15rem;font-size:.85rem;font-style:italic}.expense-category-wrapper{align-items:center;display:flex}.expense-amount-val{color:var(--danger);font-size:1.1rem;font-weight:700}.expense-row-actions{justify-content:flex-end;gap:.5rem;display:flex}.credential-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.credential-card{background:var(--bg-surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:20px;flex-direction:column;justify-content:space-between;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.credential-card:before{content:"";background:0 0;width:4px;height:100%;transition:background .3s;position:absolute;top:0;left:0}.credential-card:hover{box-shadow:var(--shadow-lg);background:#ffffff08;border-color:#ffffff1f;transform:translateY(-4px)}.credential-card.cat-servidor:before{background:var(--secondary)}.credential-card.cat-api-key:before{background:var(--primary)}.credential-card.cat-base-de-datos:before{background:var(--success)}.credential-card.cat-hosting:before{background:#f59e0b}.credential-card.cat-cuenta:before{background:#ec4899}.credential-card.cat-otro:before{background:#94a3b8}.credential-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.credential-title-area{flex-direction:column;gap:.3rem;max-width:70%;display:flex}.credential-title{color:var(--text-light);text-overflow:ellipsis;white-space:nowrap;font-size:1.12rem;font-weight:700;overflow:hidden}.credential-actions{gap:.35rem;display:flex}.credential-body{background:#ffffff03;border:1px solid #ffffff08;border-radius:12px;flex-direction:column;gap:.6rem;padding:.75rem;display:flex}.credential-item{flex-direction:column;gap:.15rem;font-size:.85rem;display:flex}.credential-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.credential-value-wrapper{background:#00000026;border:1px solid #ffffff05;border-radius:8px;justify-content:space-between;align-items:center;gap:.4rem;padding:.35rem .55rem;display:flex}.credential-value{text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:Courier New,Courier,monospace;font-weight:600;overflow:hidden}.btn-credential-action{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:.25rem;transition:all .2s;display:flex}.btn-credential-action:hover{color:var(--text-light);background:#ffffff14}.credential-notes{color:var(--text-muted);border-top:1px solid #ffffff0d;margin-top:.85rem;padding-top:.65rem;font-size:.82rem;line-height:1.4}.badge-servidor{color:var(--secondary)!important;background:#06b6d426!important}.badge-api-key{color:var(--primary)!important;background:#8b5cf626!important}.badge-base-de-datos{color:var(--success)!important;background:#10b98126!important}.badge-hosting{color:#f59e0b!important;background:#f59e0b26!important}.badge-cuenta{color:#ec4899!important;background:#ec489926!important}.form-grid-2{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-grid-1-5{grid-template-columns:1.5fr 1fr;gap:1rem;display:grid}@media (width<=992px){.dashboard-grid{gap:1.5rem;grid-template-columns:1fr!important}}@media (width<=768px){.container{padding:1.25rem 1rem!important}.stats-grid{gap:1rem!important;margin-bottom:1.5rem!important}.stat-card{padding:1.25rem!important}.filter-bar{flex-direction:column!important;align-items:stretch!important;gap:.75rem!important}.search-input-wrapper,.select-filter,.filter-bar input[type=month]{width:100%!important;min-width:unset!important}.header-content{text-align:center!important;flex-direction:column!important;gap:1rem!important}.tab-list{scrollbar-width:none;-webkit-overflow-scrolling:touch!important;flex-wrap:nowrap!important;gap:.5rem!important;padding-bottom:.5rem!important;display:flex!important;overflow-x:auto!important}.tab-list::-webkit-scrollbar{display:none}.tab-btn{white-space:nowrap!important;flex-shrink:0!important;padding:.65rem 1rem!important;font-size:.85rem!important}.panel-header{flex-direction:column!important;align-items:flex-start!important;gap:1rem!important;margin-bottom:1.25rem!important}.panel-header button{width:100%!important}.client-row,.expense-row{border-radius:14px!important;padding:1.25rem!important}.client-row-actions,.expense-row-actions{border-top:1px solid #ffffff0d!important;justify-content:flex-end!important;width:100%!important;margin-top:.5rem!important;padding-top:.5rem!important}}@media (width<=576px){.modal-overlay{padding:.75rem!important}.modal-content{border-radius:16px!important;max-height:95vh!important;padding:1.5rem 1.25rem!important}.modal-title{margin-bottom:1.25rem!important;font-size:1.3rem!important}.form-grid-2,.form-grid-1-5{grid-template-columns:1fr!important;gap:.75rem!important}.credential-grid{grid-template-columns:1fr!important;gap:1rem!important}.credential-card{border-radius:16px!important;padding:1.25rem!important}.modal-footer{flex-direction:column-reverse!important;gap:.75rem!important}.modal-footer button{width:100%!important;margin:0!important}.login-card{border-radius:20px!important;padding:2rem 1.5rem!important}.login-logo{font-size:1.8rem!important}}
