:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#dbeafe;--danger:#dc2626;--danger-light:#fee2e2;--success:#059669;--success-light:#d1fae5;--warning:#d97706;--warning-light:#fef3c7;--bg:#f1f5f9;--bg-card:#fff;--bg-header:#1e293b;--text:#334155;--text-secondary:#64748b;--text-light:#94a3b8;--text-white:#fff;--border:#e2e8f0;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--radius:12px;--radius-sm:8px;--nav-height:64px;--header-height:56px}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;line-height:1.5;overflow-x:hidden}#root{background:var(--bg);width:100%;max-width:480px;min-height:100dvh;margin:0 auto;position:relative}.app-shell{min-height:100dvh;padding-bottom:var(--nav-height);flex-direction:column;display:flex}.app-header{z-index:100;height:var(--header-height);background:var(--bg-header);color:var(--text-white);align-items:center;padding:0 16px;display:flex;position:sticky;top:0}.header-left{flex-shrink:0;width:40px}.header-back{width:36px;height:36px;color:var(--text-white);cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .2s;display:flex}.header-back:active{background:#fff3}.header-title{text-align:center;letter-spacing:-.3px;white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:17px;font-weight:600;overflow:hidden}.header-right{flex-shrink:0;justify-content:flex-end;width:40px;display:flex}.user-menu-wrapper{position:relative}.user-avatar{background:var(--primary);color:#fff;cursor:pointer;border:2px solid #ffffff4d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;transition:opacity .2s;display:flex}.user-avatar:active{opacity:.8}.user-dropdown{background:var(--bg-card);border-radius:var(--radius-sm);min-width:190px;box-shadow:var(--shadow-lg);z-index:200;padding:12px 0 8px;position:absolute;top:calc(100% + 8px);right:0}.user-dropdown-name{color:var(--text);padding:0 14px 2px;font-size:14px;font-weight:600}.user-dropdown-email{color:var(--text-secondary);padding:0 14px 8px;font-size:12px}.user-dropdown-divider{border:none;border-top:1px solid var(--border);margin:0}.user-dropdown-logout{width:100%;color:var(--danger);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:10px 14px;font-size:14px;display:flex}.user-dropdown-logout:active{background:var(--danger-light)}.page{flex-direction:column;flex:1;display:flex}.page-content{flex:1;padding:16px 16px 80px}.bottom-nav{width:100%;max-width:480px;height:var(--nav-height);background:var(--bg-card);border-top:1px solid var(--border);z-index:200;padding-bottom:env(safe-area-inset-bottom,0);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{color:var(--text-light);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;font-size:10px;font-weight:500;transition:color .2s;display:flex}.nav-item.active{color:var(--primary)}.nav-item span{line-height:1}.more-menu-overlay{z-index:250;background:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.more-menu{background:var(--bg-card);width:100%;max-width:480px;padding:8px 0 calc(var(--nav-height) + 16px);border-radius:20px 20px 0 0;animation:.25s ease-out slideUp}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.more-menu-item{width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;align-items:center;gap:16px;padding:16px 24px;font-size:15px;transition:background .2s;display:flex}.more-menu-item:active{background:var(--bg)}.more-menu-item.active{color:var(--primary);font-weight:600}.search-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:10px;margin-bottom:12px;padding:10px 14px;display:flex}.search-bar svg{color:var(--text-light);flex-shrink:0}.search-bar input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:15px}.search-bar input::placeholder{color:var(--text-light)}.filter-chips{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;padding-bottom:12px;display:flex;overflow-x:auto}.filter-chips::-webkit-scrollbar{display:none}.chip{border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;text-transform:capitalize;border-radius:20px;flex-shrink:0;padding:6px 14px;font-size:13px;font-weight:500;transition:all .2s}.chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.card-list{flex-direction:column;gap:10px;display:flex}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;transition:box-shadow .2s,transform .15s;overflow:hidden}.card:active{transform:scale(.98)}.card-body{align-items:center;gap:12px;padding:14px 16px;display:flex}.card-info{flex:1;min-width:0}.card-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;line-height:1.3;overflow:hidden}.card-subtitle{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:13px;overflow:hidden}.card-detail{color:var(--text-light);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.card-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.card-chevron{color:var(--text-light)}.btn-icon-delete{background:var(--danger-light);width:28px;height:28px;color:var(--danger);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;transition:background .2s;display:flex}.btn-icon-delete:active{background:#fca5a5}.badge{color:#fff;text-transform:capitalize;border-radius:12px;margin-top:6px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.empty-state{color:var(--text-light);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-state p{font-size:15px}.fab{bottom:calc(var(--nav-height) + 16px);background:var(--primary);color:#fff;width:56px;height:56px;box-shadow:var(--shadow-lg);cursor:pointer;z-index:50;border:none;border-radius:16px;justify-content:center;align-items:center;transition:background .2s,transform .15s;display:flex;position:fixed;right:calc(50% - 224px)}.fab:active{background:var(--primary-dark);transform:scale(.92)}@media (width<=480px){.fab{right:16px}}.form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;flex:1;gap:6px;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:var(--bg-card);padding:12px 14px;font-family:inherit;font-size:15px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.form-group textarea{resize:vertical;min-height:80px}.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:40px}.form-row{gap:12px;display:flex}.form-hint{color:var(--text-light);margin-top:-2px;font-size:12px}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;padding:12px 24px;font-family:inherit;font-size:15px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:active{background:var(--primary-dark)}.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:active{background:#b91c1c}.btn-block{width:100%;margin-top:8px}.dialog-overlay{z-index:300;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.dialog{background:var(--bg-card);border-radius:var(--radius);width:100%;max-width:360px;box-shadow:var(--shadow-lg);padding:24px;animation:.2s ease-out dialogIn}.dialog-form{max-width:400px}.dialog-form .form{margin-top:16px}@keyframes dialogIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.dialog-title{color:var(--text);margin-bottom:8px;font-size:17px;font-weight:700}.dialog-message{color:var(--text-secondary);margin-bottom:20px;font-size:14px;line-height:1.5}.dialog-actions{justify-content:flex-end;gap:10px;display:flex}.stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;display:grid}.stat-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);border-left:4px solid var(--primary);flex-direction:column;gap:4px;padding:16px;display:flex}.stat-value{color:var(--text);font-size:28px;font-weight:700;line-height:1}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:500}.dashboard-section{margin-bottom:24px}.section-title{color:var(--text);border-bottom:2px solid var(--primary-light);margin-bottom:12px;padding-bottom:8px;font-size:16px;font-weight:700}.summary-cards{grid-template-columns:1fr 1fr;gap:10px;display:grid}.summary-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.summary-card.alquiler{color:#fff;background:#3b4fd8;border-left:none;flex-direction:column-reverse}.summary-card.servicio{color:#fff;background:#dc2626;border-left:none;flex-direction:column-reverse}.summary-card.total{color:#fff;background:#059669;border-left:none;grid-column:1/-1}.summary-label{color:inherit;opacity:.85;text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:500}.summary-value{color:inherit;font-size:20px;font-weight:700}.chart-container{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;padding:16px 8px;overflow-x:auto}.table-container{border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto}.data-table{border-collapse:collapse;background:var(--bg-card);width:100%;font-size:13px}.data-table th{background:var(--bg-header);color:var(--text-white);text-align:left;text-transform:uppercase;letter-spacing:.5px;padding:10px 12px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 12px}.data-table .num{text-align:right;font-variant-numeric:tabular-nums}.data-table .total{color:var(--success);font-weight:700}.data-table .table-footer{background:var(--bg)}.data-table .table-footer td{border-bottom:none}.empty-dashboard{text-align:center;color:var(--text-light);padding:40px 20px;font-size:14px}.btn-precios{color:var(--primary);background:var(--primary-light);cursor:pointer;border:none;border-radius:6px;margin-top:8px;padding:4px 12px;font-size:12px;font-weight:600;transition:background .2s;display:inline-block}.btn-precios:active{background:#bfdbfe}.mes-list{flex-direction:column;gap:10px;padding:12px 16px;display:flex}.mes-group{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.mes-header{cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;justify-content:space-between;align-items:center;gap:8px;padding:14px 16px;display:flex}.mes-header-left{flex-direction:column;align-items:flex-start;gap:2px;display:flex}.mes-label{font-size:15px;font-weight:600}.mes-total{color:var(--primary);font-size:13px;font-weight:700}.mes-body{border-top:1px solid var(--border);padding:8px 0}.mes-pago-row{justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.mes-pago-info{flex-direction:column;gap:2px;display:flex}.mes-pago-nombre{color:var(--text);font-size:14px}.mes-pago-estado{border-radius:4px;width:fit-content;padding:1px 6px;font-size:11px;font-weight:600}.mes-pago-estado.pagado{background:var(--success-light);color:var(--success)}.mes-pago-estado.pendiente{background:var(--warning-light);color:var(--warning)}.mes-pago-importe{color:var(--text);font-size:15px;font-weight:600}.mes-subtotal{border-top:1px solid var(--border);color:var(--text);justify-content:space-between;margin-top:4px;padding:10px 16px 4px;font-size:14px;font-weight:700;display:flex}.year-group-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:4px;padding:12px 4px 4px;font-size:.75rem;font-weight:700}.year-selector{justify-content:center;align-items:center;gap:20px;padding:12px 0 16px;display:flex}.year-btn{background:var(--bg-card);border:1px solid var(--border);width:36px;height:36px;color:var(--primary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:20px;line-height:1;display:flex}.year-btn:disabled{opacity:.3;cursor:default}.year-label{color:var(--text);font-size:22px;font-weight:700}.month-accordion{flex-direction:column;gap:8px;padding-bottom:16px;display:flex}.month-item{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.month-header{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:14px 16px;display:flex}.month-name{color:var(--text);flex:1;font-size:16px;font-weight:600}.month-total{color:var(--primary);margin-right:4px;font-size:16px;font-weight:700}.month-detail{border-top:1px solid var(--border);flex-direction:column;gap:12px;padding:12px;display:flex}.detail-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 4px;font-size:13px;font-weight:600}.propiedad-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:8px;padding:12px;display:flex}.prop-card-header{justify-content:space-between;align-items:center;display:flex}.prop-tipo{color:#0891b2;letter-spacing:.06em;font-size:12px;font-weight:700}.prop-total-val{color:var(--text);font-size:18px;font-weight:700}.prop-direccion{color:var(--text);font-size:14px}.prop-bar{border-radius:20px;height:32px;font-size:12px;font-weight:600;display:flex;overflow:hidden}.prop-bar-alq{color:#fff;white-space:nowrap;text-overflow:ellipsis;background:#3b4fd8;justify-content:center;align-items:center;min-width:0;padding:0 8px;display:flex;overflow:hidden}.prop-bar-srv{color:#fff;white-space:nowrap;text-overflow:ellipsis;background:#0891b2;justify-content:center;align-items:center;min-width:0;padding:0 8px;display:flex;overflow:hidden}.prop-bar-labels{color:var(--text-secondary);justify-content:space-between;font-size:12px;display:flex}.prop-dir-row{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.prop-pdf-icon-btn{border:1.5px solid var(--primary);width:30px;height:30px;color:var(--primary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.prop-pdf-icon-btn:hover{background:var(--primary);color:#fff}.btn-liq{cursor:pointer;white-space:nowrap;border:none;border-radius:20px;align-items:center;gap:5px;margin-top:8px;padding:6px 12px;font-size:12px;font-weight:600;transition:opacity .15s;display:inline-flex}.btn-liq:hover:not(:disabled){opacity:.85}.btn-liq:disabled{cursor:default}.btn-liq-generar{color:#3730a3;background:#e0e7ff}.btn-liq-borrador{color:#92400e;background:#fef3c7}.btn-liq-pendiente{color:#991b1b;background:#fee2e2}.btn-liq-pagar{color:#fff;background:#3b4fd8}.btn-liq-pagado{color:#059669;background:#f0fdf4}.btn-liq-pdf{color:#1d4ed8;background:#eff6ff;margin-left:4px}.btn-liq-group{flex-wrap:wrap;gap:4px;margin-top:8px;display:inline-flex}.pagar-nro{color:var(--text-secondary);margin-bottom:12px;font-size:12px}.pagar-dialog{width:100%;max-width:360px}.pagar-titulo{color:var(--text);margin-bottom:4px;font-size:18px;font-weight:700}.pagar-propiedad{color:var(--text-secondary);margin-bottom:2px;font-size:14px}.pagar-mes{color:var(--primary);text-transform:capitalize;margin-bottom:16px;font-size:13px;font-weight:600}.pagar-detalle{background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:20px;overflow:hidden}.pagar-fila{color:var(--text);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 14px;font-size:14px;display:flex}.pagar-fila:last-child{border-bottom:none}.pagar-fila.pagar-total{background:var(--bg-card);font-size:15px;font-weight:700}.pagar-monto{font-weight:600}.file-input{width:100%;color:var(--text);padding:8px 0;font-size:14px}.comprobante-preview{object-fit:contain;border-radius:var(--radius-sm);border:1px solid var(--border);width:100%;max-height:200px;margin-top:10px}.pagar-exito{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:16px 0 8px;display:flex}.pagar-exito-icon{color:#fff;background:#059669;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;display:flex}.pagar-exito h3{color:var(--text);margin:0;font-size:18px;font-weight:700}.pagar-exito p{color:var(--text-secondary);margin:0;font-size:14px}.pagar-page-header{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:16px}.pagar-page-dir{color:var(--text);margin:0 0 4px;font-size:16px;font-weight:700}.pagar-page-periodo{color:var(--primary);text-transform:capitalize;margin:0 0 4px;font-size:14px;font-weight:600}.pagar-page-nro{color:var(--text-muted);margin:0;font-size:12px}.pagar-detalle-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}.pagar-seccion-titulo{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border);padding:8px 14px 4px;font-size:11px;font-weight:700}.pagar-fila-srv{color:var(--text-secondary);padding-left:20px;font-size:13px}.pagar-subtotal{background:var(--bg);font-size:13px;font-style:italic}.pagar-form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:0;padding:16px;display:flex}.pagar-submit-btn{width:100%;margin-top:8px}.pagar-exito-page{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:40px 24px;display:flex}.pagar-exito-page .pagar-exito-icon{color:#059669}.pagar-exito-page h2{color:var(--text);margin:0;font-size:22px;font-weight:700}.pagar-exito-nro{color:var(--text-secondary);margin:0;font-size:14px}.pagar-exito-sub{color:var(--text-muted);margin:0 0 8px;font-size:13px}.pagar-pdf-btn{width:100%;max-width:280px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.login-page{background:linear-gradient(135deg, var(--bg-header) 0%, #334155 100%);justify-content:center;align-items:center;min-height:100dvh;padding:24px 16px;display:flex}.login-card{background:var(--bg-card);border-radius:var(--radius);width:100%;max-width:400px;box-shadow:var(--shadow-lg);padding:32px 24px}.login-header{text-align:center;margin-bottom:28px}.login-title{color:var(--text);margin-bottom:4px;font-size:24px;font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:14px}.login-error{background:var(--danger-light);color:var(--danger);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;font-weight:500}@media (prefers-reduced-motion:no-preference){.card{transition:box-shadow .2s,transform .15s}}
