@import "https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800&family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary:#000;--primary-container:#131b2e;--on-primary:#fff;--on-primary-container:#7c839b;--primary-fixed:#dae2fd;--primary-fixed-dim:#bec6e0;--secondary:#515f74;--secondary-container:#d5e3fc;--on-secondary:#fff;--on-secondary-container:#57657a;--tertiary:#000;--tertiary-container:#00201d;--on-tertiary:#fff;--on-tertiary-container:#0c9488;--tertiary-fixed:#89f5e7;--background:#f7f9fb;--surface:#f7f9fb;--surface-dim:#d8dadc;--surface-bright:#f7f9fb;--surface-container-lowest:#fff;--surface-container-low:#f2f4f6;--surface-container:#eceef0;--surface-container-high:#e6e8ea;--surface-container-highest:#e0e3e5;--surface-variant:#e0e3e5;--on-surface:#191c1e;--on-surface-variant:#45464d;--on-background:#191c1e;--outline:#76777d;--outline-variant:#c6c6cd;--error:#ba1a1a;--error-container:#ffdad6;--on-error:#fff;--on-error-container:#93000a;--inverse-surface:#2d3133;--inverse-on-surface:#eff1f3;--inverse-primary:#bec6e0;--surface-tint:#565e74;--font-display:"Manrope", sans-serif;--font-body:"Inter", sans-serif;--display-lg:3.5rem;--display-md:2.8125rem;--display-sm:2.25rem;--headline-lg:2rem;--headline-md:1.75rem;--headline-sm:1.5rem;--title-lg:1.375rem;--title-md:1rem;--title-sm:.875rem;--body-lg:1rem;--body-md:.875rem;--body-sm:.75rem;--label-lg:.875rem;--label-md:.75rem;--label-sm:.6875rem;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--spacing-20:5rem;--spacing-24:6rem;--control-height:48px;--control-height-compact:44px;--rounded-none:0;--rounded-sm:.125rem;--rounded-md:.375rem;--rounded-lg:.5rem;--rounded-xl:.75rem;--rounded-2xl:1rem;--rounded-3xl:1.5rem;--rounded-full:9999px;--shadow-sm:0px 4px 12px #191c1e0a;--shadow-md:0px 8px 24px #191c1e0d;--shadow-lg:0px 12px 32px #191c1e0f;--shadow-xl:0px 20px 48px #191c1e14;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-body);font-size:var(--body-md);color:var(--on-surface);background-color:var(--background);min-height:100vh;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--on-surface);font-weight:700;line-height:1.2}a{color:var(--on-tertiary-container);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--secondary)}img{max-width:100%;display:block}input,button,textarea,select{font-family:inherit;font-size:inherit}:focus-visible{outline:2px solid var(--on-tertiary-container);outline-offset:2px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--outline-variant);border-radius:var(--rounded-full)}::-webkit-scrollbar-thumb:hover{background:var(--outline)}.label-sm{font-family:var(--font-body);font-size:var(--label-sm);color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.05em;font-weight:500}::selection{background-color:var(--primary-fixed-dim);color:var(--primary-container)}#root{min-height:100vh}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-layout{min-height:100vh;display:flex}.mobile-menu-button,.sidebar-close,.sidebar-backdrop{display:none}.sidebar{background-color:var(--primary-container);width:260px;padding:var(--spacing-6) 0;z-index:100;transition:transform var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{align-items:center;gap:var(--spacing-3);padding:0 var(--spacing-6);margin-bottom:var(--spacing-10);display:flex}.sidebar-logo-icon{background:var(--on-tertiary-container);border-radius:var(--rounded-lg);justify-content:center;align-items:center;width:38px;height:38px;display:flex}.sidebar-logo-icon svg{width:20px;height:20px;color:var(--on-primary)}.sidebar-logo-text{font-family:var(--font-display);font-size:var(--title-md);color:var(--on-primary);font-weight:700}.sidebar-nav{gap:var(--spacing-1);flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.sidebar-section-label{font-family:var(--font-body);font-size:var(--label-sm);color:var(--on-primary-container);text-transform:uppercase;letter-spacing:.08em;padding:var(--spacing-4) var(--spacing-6) var(--spacing-2);opacity:.5}.sidebar-item{align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-6);color:var(--on-primary-container);font-family:var(--font-body);font-size:var(--body-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;width:100%;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-item:hover{color:var(--primary-fixed-dim);background:#ffffff0a}.sidebar-item.active{color:var(--on-primary)}.sidebar-item.active:before{content:"";background:var(--on-tertiary-container);border-radius:0 var(--rounded-full) var(--rounded-full) 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-item svg{flex-shrink:0;width:20px;height:20px}.sidebar-footer{padding:var(--spacing-4) var(--spacing-6);margin-top:auto}.sidebar-user{align-items:center;gap:var(--spacing-3);display:flex}.sidebar-avatar{background:var(--secondary);border-radius:var(--rounded-full);width:36px;height:36px;font-family:var(--font-display);font-size:var(--label-md);color:var(--on-secondary);justify-content:center;align-items:center;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-family:var(--font-body);font-size:var(--body-sm);color:var(--on-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-user-role{font-size:var(--label-sm);color:var(--on-primary-container);text-transform:uppercase;letter-spacing:.05em}.sidebar-logout{color:var(--on-primary-container);cursor:pointer;padding:var(--spacing-1);transition:color var(--transition-fast);background:0 0;border:none;align-items:center;display:flex}.sidebar-logout:hover{color:var(--error-container)}.sidebar-logout svg{width:18px;height:18px}.main-content{padding:var(--spacing-8);background-color:var(--background);flex:1;min-height:100vh;margin-left:260px}.page-header{margin-bottom:var(--spacing-8)}.page-title{font-family:var(--font-display);font-size:var(--headline-md);color:var(--on-surface);margin-bottom:var(--spacing-2);font-weight:700}.page-subtitle{font-family:var(--font-body);font-size:var(--body-md);color:var(--on-surface-variant)}.stats-grid{gap:var(--spacing-6);margin-bottom:var(--spacing-8);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.stat-card{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-6);transition:all var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-card-label{font-family:var(--font-body);font-size:var(--label-sm);color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-3);font-weight:600}.stat-card-value{font-family:var(--font-display);font-size:var(--display-sm);color:var(--on-surface);letter-spacing:-.02em;font-weight:800}.stat-card-trend{align-items:center;gap:var(--spacing-1);margin-top:var(--spacing-2);font-size:var(--label-md);font-weight:600;display:inline-flex}.stat-card-trend.positive{color:var(--on-tertiary-container)}.stat-card-trend.negative{color:var(--error)}.resident-announcements{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);margin-bottom:var(--spacing-8);padding:var(--spacing-6)}.resident-announcements-head{align-items:center;gap:var(--spacing-4);margin-bottom:var(--spacing-5);justify-content:space-between;display:flex}.resident-announcements-head h2{color:var(--on-surface);font-family:var(--font-display);font-size:var(--title-lg);margin:var(--spacing-1) 0 0}.resident-announcement-empty{color:var(--on-surface-variant);padding:var(--spacing-6);text-align:center;margin:0}.resident-announcement-list{gap:var(--spacing-4);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.resident-announcement-card{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-5)}.resident-announcement-meta{color:var(--on-surface-variant);font-size:var(--body-sm);align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-3);justify-content:space-between;display:flex}.resident-announcement-card h3{color:var(--on-surface);font-family:var(--font-display);font-size:var(--title-md);margin:0 0 var(--spacing-2)}.resident-announcement-card p{color:var(--on-surface-variant);white-space:pre-wrap;margin:0;line-height:1.55}.resident-announcement-files{gap:var(--spacing-2);margin-top:var(--spacing-4);flex-wrap:wrap;display:flex}.resident-summary{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);margin-bottom:var(--spacing-8);padding:var(--spacing-6)}.resident-summary-head{align-items:center;gap:var(--spacing-4);margin-bottom:var(--spacing-5);justify-content:space-between;display:flex}.resident-summary-head h2{color:var(--on-surface);font-family:var(--font-display);font-size:var(--title-lg);margin:var(--spacing-1) 0 0}.resident-summary-grid{gap:var(--spacing-5);grid-template-columns:minmax(0,1.4fr) minmax(320px,.8fr);display:grid}.resident-houses-panel,.resident-status-panel{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-4)}.resident-houses-panel h3,.resident-last-pqr h3{color:var(--on-surface);font-family:var(--font-display);font-size:var(--title-md);margin:0 0 var(--spacing-4)}.resident-house-list,.resident-status-panel{gap:var(--spacing-3);flex-direction:column;display:flex}.resident-house-card{background:var(--surface-container-lowest);border-radius:var(--rounded-md);align-items:center;gap:var(--spacing-3);padding:var(--spacing-4);grid-template-columns:minmax(0,1fr) auto auto;display:grid}.resident-house-card strong,.resident-house-card small,.resident-house-balance span,.resident-house-balance small{display:block}.resident-house-card strong{color:var(--on-surface);font-family:var(--font-display);font-size:var(--title-lg)}.resident-house-card small,.resident-house-balance small{color:var(--on-surface-variant);font-size:var(--body-sm)}.resident-house-balance{text-align:right}.resident-house-balance span{color:var(--on-surface);font-weight:700}.resident-status-card,.resident-last-pqr{background:var(--surface-container-lowest);border-radius:var(--rounded-md);padding:var(--spacing-4)}.resident-status-card strong{color:var(--on-surface);font-family:var(--font-display);font-size:var(--headline-sm);margin:var(--spacing-2) 0;display:block}.resident-status-card small{color:var(--on-surface-variant);display:block}.content-section{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-6)}.content-section-title{font-family:var(--font-display);font-size:var(--title-lg);color:var(--on-surface);margin-bottom:var(--spacing-6);font-weight:700}.dashboard-activity-header{align-items:center;gap:var(--spacing-4);margin-bottom:var(--spacing-5);justify-content:space-between;display:flex}.dashboard-activity-header .content-section-title{margin-bottom:0}.dashboard-activity-grid{gap:var(--spacing-4);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.activity-column{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-4)}.activity-column h3{color:var(--on-surface);font-family:var(--font-display);font-size:var(--title-md);margin:0 0 var(--spacing-4)}.activity-item{background:var(--surface-container-lowest);border-radius:var(--rounded-md);gap:var(--spacing-2);padding:var(--spacing-3);flex-direction:column;display:flex}.activity-item+.activity-item{margin-top:var(--spacing-3)}.activity-item strong,.activity-item span,.activity-item small{display:block}.activity-item strong{color:var(--on-surface);font-size:var(--body-md);font-weight:700}.activity-item span{color:var(--on-surface-variant);font-size:var(--body-sm);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.45;display:-webkit-box;overflow:hidden}.activity-item small,.activity-empty,.dashboard-activity-warning{color:var(--on-surface-variant);font-size:var(--body-sm)}.activity-empty,.dashboard-activity-warning{margin:0}.dashboard-activity-warning{margin-bottom:var(--spacing-4)}@media (width<=900px){.mobile-menu-button{top:var(--spacing-4);left:var(--spacing-4);z-index:90;border-radius:var(--rounded-lg);background:var(--primary-container);width:44px;height:44px;color:var(--on-primary);box-shadow:var(--shadow-md);cursor:pointer;border:none;justify-content:center;align-items:center;display:inline-flex;position:fixed}.mobile-menu-button svg,.sidebar-close svg{width:22px;height:22px}.sidebar{z-index:120;width:min(82vw,300px);box-shadow:var(--shadow-xl);transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar.open+.main-content{pointer-events:none}.sidebar-logo{padding-right:var(--spacing-4)}.sidebar-close{border-radius:var(--rounded-md);width:36px;height:36px;color:var(--on-primary);cursor:pointer;background:#ffffff14;border:none;justify-content:center;align-items:center;margin-left:auto;display:inline-flex}.sidebar-backdrop{z-index:110;cursor:pointer;background:#00000059;border:0;display:block;position:fixed;inset:0}.main-content{padding:calc(var(--spacing-4) + 52px) var(--spacing-4) var(--spacing-4);margin-left:0}.resident-announcements-head,.resident-summary-head{flex-direction:column;align-items:stretch}.resident-summary-grid{grid-template-columns:1fr}.resident-house-card{grid-template-columns:1fr;align-items:start}.resident-house-balance{text-align:left}.dashboard-activity-header{flex-direction:column;align-items:stretch}.dashboard-activity-grid{grid-template-columns:1fr}}.login-page{background-color:var(--background);min-height:100vh;display:flex}.login-branding{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-container) 100%);padding:var(--spacing-16);flex-direction:column;flex:1;justify-content:center;display:flex;position:relative;overflow:hidden}.login-branding:before{content:"";pointer-events:none;background:#0c94880f;border-radius:50%;width:500px;height:500px;position:absolute;top:-20%;right:-15%}.login-branding:after{content:"";pointer-events:none;background:#bec6e00a;border-radius:50%;width:350px;height:350px;position:absolute;bottom:-10%;left:-10%}.branding-content{z-index:1;max-width:520px;position:relative}.branding-logo{align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-16);display:flex}.branding-logo-icon{background:var(--on-tertiary-container);border-radius:var(--rounded-xl);justify-content:center;align-items:center;width:44px;height:44px;display:flex}.branding-logo-icon svg{width:24px;height:24px;color:var(--on-primary)}.branding-logo-text{font-family:var(--font-display);font-size:var(--title-lg);color:var(--on-primary);letter-spacing:-.01em;font-weight:700}.branding-headline{font-family:var(--font-display);font-size:clamp(2rem, 3.5vw, var(--display-sm));color:var(--on-primary);margin-bottom:var(--spacing-6);letter-spacing:-.02em;font-weight:800;line-height:1.15}.branding-headline span{color:var(--on-tertiary-container)}.branding-subtitle{font-family:var(--font-body);font-size:var(--body-lg);color:var(--on-primary-container);max-width:440px;line-height:1.7}.branding-features{gap:var(--spacing-4);margin-top:var(--spacing-12);flex-direction:column;display:flex}.branding-feature{align-items:center;gap:var(--spacing-3);display:flex}.branding-feature-icon{border-radius:var(--rounded-lg);background:#0c94881f;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.branding-feature-icon svg{width:18px;height:18px;color:var(--on-tertiary-container)}.branding-feature-text{font-family:var(--font-body);font-size:var(--body-md);color:var(--primary-fixed-dim)}.branding-footer{bottom:var(--spacing-8);left:var(--spacing-16);right:var(--spacing-16);position:absolute}.branding-footer-text{font-family:var(--font-body);font-size:var(--label-sm);color:var(--on-primary-container);text-transform:uppercase;letter-spacing:.05em;opacity:.6}.login-form-panel{padding:var(--spacing-10);background-color:var(--surface-container-lowest);flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.login-form-container{width:100%;max-width:420px}.login-form-header{margin-bottom:var(--spacing-10)}.login-form-title{font-family:var(--font-display);font-size:var(--headline-md);color:var(--on-surface);margin-bottom:var(--spacing-2);font-weight:700}.login-form-description{font-family:var(--font-body);font-size:var(--body-md);color:var(--on-surface-variant)}.form-group{margin-bottom:var(--spacing-6)}.form-label{font-family:var(--font-body);font-size:var(--label-sm);color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-2);font-weight:600;display:block}.form-input-wrapper{position:relative}.form-input{width:100%;height:var(--control-height);padding:var(--spacing-3) var(--spacing-4);background-color:var(--surface-container-high);border-radius:var(--rounded-md) var(--rounded-md) 0 0;font-family:var(--font-body);font-size:var(--body-md);color:var(--on-surface);transition:all var(--transition-base);border:none;border-bottom:2px solid #76777d33;outline:none}.form-input-wrapper .form-input{padding-left:var(--spacing-10)}.form-input::placeholder{color:var(--outline)}.form-input:focus{border-bottom-color:var(--on-tertiary-container);background-color:var(--surface-container)}.form-input-icon{left:var(--spacing-3);color:var(--outline);transition:color var(--transition-fast);align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.form-input:focus~.form-input-icon,.form-input:not(:placeholder-shown)~.form-input-icon{color:var(--on-tertiary-container)}.form-input-icon svg{width:18px;height:18px}.password-toggle{right:var(--spacing-3);color:var(--outline);cursor:pointer;padding:var(--spacing-1);transition:color var(--transition-fast);background:0 0;border:none;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.password-toggle:hover{color:var(--on-surface-variant)}.password-toggle svg{width:18px;height:18px}.form-row{margin-bottom:var(--spacing-8);justify-content:space-between;align-items:center;display:flex}.form-checkbox{align-items:center;gap:var(--spacing-2);cursor:pointer;display:flex}.form-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--on-tertiary-container);cursor:pointer}.form-checkbox-label{font-size:var(--body-sm);color:var(--on-surface-variant)}.form-link{font-size:var(--body-sm);color:var(--on-tertiary-container);transition:color var(--transition-fast);font-weight:500}.form-link:hover{color:var(--secondary)}.login-button{width:100%;padding:var(--spacing-3) var(--spacing-6);background:linear-gradient(135deg, var(--primary) 0%, var(--primary-container) 100%);color:var(--on-primary);border-radius:var(--rounded-md);font-family:var(--font-display);font-size:var(--title-sm);cursor:pointer;transition:all var(--transition-base);letter-spacing:.01em;border:none;font-weight:600;position:relative;overflow:hidden}.login-button:hover:not(:disabled){box-shadow:var(--shadow-lg);transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-button-loading{align-items:center;gap:var(--spacing-2);display:inline-flex}.spinner{border:2px solid #ffffff4d;border-top-color:var(--on-primary);border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}.login-error{align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);background-color:var(--error-container);border-radius:var(--rounded-lg);margin-bottom:var(--spacing-6);animation:.3s ease-out slideDown;display:flex}.login-error svg{width:18px;height:18px;color:var(--error);flex-shrink:0}.login-error-text{font-size:var(--body-sm);color:var(--on-error-container);font-weight:500}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.login-register{text-align:center;margin-top:var(--spacing-8);font-size:var(--body-sm);color:var(--on-surface-variant)}.login-register a{color:var(--on-tertiary-container);font-weight:600}.login-footer{justify-content:center;gap:var(--spacing-6);margin-top:var(--spacing-12);display:flex}.login-footer a{font-size:var(--label-sm);color:var(--outline);text-transform:uppercase;letter-spacing:.05em;transition:color var(--transition-fast);font-weight:500}.login-footer a:hover{color:var(--on-surface-variant)}@media (width<=900px){.login-page{flex-direction:column}.login-branding{padding:var(--spacing-8) var(--spacing-6);min-height:auto}.branding-headline{font-size:var(--headline-lg)}.branding-features,.branding-footer{display:none}.login-form-panel{padding:var(--spacing-8) var(--spacing-6)}}.casas-layout{gap:var(--spacing-6);grid-template-columns:minmax(0,1fr) 380px;align-items:start;display:grid}.casas-list-panel{min-width:0}.casa-detail{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-6);min-height:420px;top:var(--spacing-8);position:sticky}.casa-avatar{border-radius:var(--rounded-lg);background:var(--primary-container);width:48px;height:48px;color:var(--on-primary);justify-content:center;align-items:center;display:flex}.casa-avatar svg{width:24px;height:24px}.detail-actions{gap:var(--spacing-2);flex-wrap:wrap;justify-content:flex-end;display:flex}.casas-topbar{justify-content:space-between;align-items:center;gap:var(--spacing-4);margin-bottom:var(--spacing-6);flex-wrap:wrap;display:flex}.casas-search{flex:1;min-width:240px;max-width:400px;position:relative}.casas-search-input{width:100%;padding:var(--spacing-3) var(--spacing-4);padding-left:var(--spacing-10);background:var(--surface-container-lowest);border-radius:var(--rounded-md) var(--rounded-md) 0 0;font-family:var(--font-body);font-size:var(--body-md);color:var(--on-surface);transition:all var(--transition-base);border:none;border-bottom:2px solid #76777d26;outline:none}.casas-search-input:focus{border-bottom-color:var(--on-tertiary-container);background:var(--surface-container)}.casas-search-input::placeholder{color:var(--outline)}.casas-search-icon{left:var(--spacing-3);color:var(--outline);display:flex;position:absolute;top:50%;transform:translateY(-50%)}.casas-search-icon svg{width:18px;height:18px}.form-select{width:100%;height:var(--control-height);padding:var(--spacing-2) 44px var(--spacing-2) var(--spacing-4);background-color:var(--surface-container-high);border-radius:var(--rounded-md) var(--rounded-md) 0 0;color:var(--on-surface);cursor:pointer;transition:all var(--transition-base);appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%2376777d' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;border:none;border-bottom:2px solid #76777d33;outline:none;line-height:1.4}.form-select:focus{border-bottom-color:var(--on-tertiary-container);background-color:var(--surface-container)}.form-select:disabled{color:var(--outline);cursor:not-allowed;opacity:.75}.casas-filters{gap:var(--spacing-2);flex-wrap:wrap;display:flex}.filter-chip{padding:var(--spacing-2) var(--spacing-4);background:var(--surface-container-low);border-radius:var(--rounded-full);font-family:var(--font-body);font-size:var(--label-md);color:var(--on-surface-variant);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;font-weight:500}.filter-chip:hover{background:var(--surface-container-high)}.filter-chip.active{background:var(--primary-container);color:var(--on-primary)}.btn-add{justify-content:center;align-items:center;gap:var(--spacing-2);min-height:var(--control-height);padding:0 var(--spacing-5);background:linear-gradient(135deg, var(--primary) 0%, var(--primary-container) 100%);color:var(--on-primary);border-radius:var(--rounded-md);font-family:var(--font-display);font-size:var(--title-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;font-weight:600;display:inline-flex}.btn-add:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn-add svg{width:18px;height:18px}.casas-table-wrap{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);overflow:auto hidden}.casas-table{border-collapse:collapse;width:100%;min-width:720px}.casas-table thead th{font-family:var(--font-body);font-size:var(--label-md);color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.06em;text-align:left;padding:var(--spacing-4);background:var(--surface-container-low);font-weight:600}.casas-table tbody tr{transition:all var(--transition-fast);cursor:pointer}.casas-table tbody tr:nth-child(odd){background:var(--surface-container-lowest)}.casas-table tbody tr:nth-child(2n){background:var(--surface-container-low)}.casas-table tbody tr:hover{background:var(--surface-container-highest)}.casas-table tbody tr:hover td:first-child{box-shadow:inset 4px 0 0 0 var(--on-tertiary-container)}.casas-table tbody td{padding:var(--spacing-4);font-family:var(--font-body);font-size:var(--body-md);color:var(--on-surface);vertical-align:middle}.pagination-bar{justify-content:space-between;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--surface-container-lowest);border-top:1px solid #76777d1f;display:flex}.pagination-info{color:var(--on-surface-variant);font-size:var(--body-sm)}.pagination-info strong{color:var(--on-surface);font-weight:700}.pagination-actions{align-items:center;gap:var(--spacing-2);flex-wrap:wrap;justify-content:flex-end;display:flex}.pagination-size{align-items:center;gap:var(--spacing-2);color:var(--on-surface-variant);font-size:var(--body-sm);display:inline-flex}.pagination-size .form-select{width:84px;min-width:84px;height:40px;font-size:var(--body-sm);padding-top:0;padding-bottom:0}.pagination-button{min-height:40px;padding:0 var(--spacing-4);border-radius:var(--rounded-md);background:var(--surface-container-lowest);color:var(--on-surface);font-family:var(--font-body);font-size:var(--body-sm);cursor:pointer;transition:all var(--transition-fast);border:1px solid #76777d2e;font-weight:600}.pagination-button:hover:not(:disabled){background:var(--surface-container-low);transform:translateY(-1px)}.pagination-button:disabled{color:var(--outline);cursor:not-allowed;opacity:.65}.pagination-page{text-align:center;min-width:56px;color:var(--on-surface-variant);font-size:var(--body-sm);font-weight:600}.actions-column,.actions-cell{text-align:right;width:96px;min-width:96px}.table-code{font-family:var(--font-display);font-weight:700;font-size:var(--title-sm);color:var(--on-surface)}.table-secondary{color:var(--on-surface-variant);font-size:var(--body-sm)}.status-badge{align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-3);border-radius:var(--rounded-full);font-size:var(--label-sm);text-transform:uppercase;letter-spacing:.04em;font-weight:600;display:inline-flex}.status-badge:before{content:"";border-radius:50%;width:6px;height:6px}.status-badge.ocupada{color:var(--on-tertiary-container);background:#0c94881a}.status-badge.ocupada:before{background:var(--on-tertiary-container)}.status-badge.desocupada{color:var(--secondary);background:#515f741a}.status-badge.desocupada:before{background:var(--secondary)}.status-badge.mora{color:var(--error);background:#ba1a1a14}.status-badge.mora:before{background:var(--error)}.table-actions{gap:var(--spacing-2);justify-content:flex-end;display:flex}.btn-icon{border-radius:var(--rounded-md);width:32px;height:32px;color:var(--on-surface-variant);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.btn-icon:hover{background:var(--surface-container-high);color:var(--on-surface)}.btn-icon.danger:hover{background:var(--error-container);color:var(--on-error-container)}.btn-icon svg{width:16px;height:16px}.empty-state{text-align:center;padding:var(--spacing-16) var(--spacing-6)}.empty-state-icon{width:64px;height:64px;margin:0 auto var(--spacing-4);background:var(--surface-container-low);border-radius:var(--rounded-full);justify-content:center;align-items:center;display:flex}.empty-state-icon svg{width:28px;height:28px;color:var(--outline)}.empty-state-title{font-family:var(--font-display);font-size:var(--title-md);color:var(--on-surface);margin-bottom:var(--spacing-2);font-weight:600}.empty-state-text{font-size:var(--body-sm);color:var(--on-surface-variant)}.casas-stats{gap:var(--spacing-6);margin-bottom:var(--spacing-6);flex-wrap:wrap;display:flex}.casas-stat{align-items:center;gap:var(--spacing-3);background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-4) var(--spacing-6);flex:1;min-width:180px;display:flex}.casas-stat-icon{border-radius:var(--rounded-lg);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.casas-stat-icon.total{background:#131b2e14}.casas-stat-icon.total svg{color:var(--primary-container)}.casas-stat-icon.ocupada{background:#0c94881a}.casas-stat-icon.ocupada svg{color:var(--on-tertiary-container)}.casas-stat-icon.desocupada{background:#515f741a}.casas-stat-icon.desocupada svg{color:var(--secondary)}.casas-stat-icon svg{width:20px;height:20px}.casas-stat-value{font-family:var(--font-display);font-size:var(--title-lg);color:var(--on-surface);font-weight:800}.casas-stat-label{font-size:var(--label-sm);color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.05em}.modal-overlay{z-index:200;padding:var(--spacing-4);background:#191c1e80;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);width:100%;max-width:560px;max-height:90vh;box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);animation:.3s ease-out slideUp;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--spacing-6);padding-bottom:var(--spacing-4);justify-content:space-between;align-items:center;display:flex}.modal-title{font-family:var(--font-display);font-size:var(--title-lg);color:var(--on-surface);font-weight:700}.modal-close{border-radius:var(--rounded-md);width:32px;height:32px;color:var(--on-surface-variant);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--surface-container-high);color:var(--on-surface)}.modal-close svg{width:18px;height:18px}.modal-body{padding:0 var(--spacing-6) var(--spacing-6)}.modal-form .form-group{margin-bottom:var(--spacing-5)}.modal-form .form-input{height:var(--control-height);padding-left:var(--spacing-4)}.modal-form .form-textarea{width:100%;padding:var(--spacing-3) var(--spacing-4);background:var(--surface-container-high);border-radius:var(--rounded-md) var(--rounded-md) 0 0;font-family:var(--font-body);font-size:var(--body-md);color:var(--on-surface);resize:vertical;min-height:80px;transition:all var(--transition-base);border:none;border-bottom:2px solid #76777d33;outline:none}.modal-form .form-textarea:focus{border-bottom-color:var(--on-tertiary-container);background:var(--surface-container)}.modal-form .form-select{width:100%;height:var(--control-height);padding:var(--spacing-2) 44px var(--spacing-2) var(--spacing-4);background:var(--surface-container-high);border-radius:var(--rounded-md) var(--rounded-md) 0 0;font-family:var(--font-body);font-size:var(--body-md);color:var(--on-surface);cursor:pointer;transition:all var(--transition-base);appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%2376777d' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border:none;border-bottom:2px solid #76777d33;outline:none}.modal-form .form-select:focus{border-bottom-color:var(--on-tertiary-container);background-color:var(--surface-container)}.modal-footer{justify-content:flex-end;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-6) var(--spacing-6);display:flex}.btn-secondary{min-height:var(--control-height);padding:0 var(--spacing-5);border-radius:var(--rounded-md);font-family:var(--font-body);font-size:var(--body-md);color:var(--on-surface-variant);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #c6c6cd66;justify-content:center;align-items:center;font-weight:500;display:inline-flex}.btn-secondary:hover{background:var(--surface-container-high);color:var(--on-surface)}.btn-primary{min-height:var(--control-height);padding:0 var(--spacing-5);background:linear-gradient(135deg, var(--primary) 0%, var(--primary-container) 100%);border-radius:var(--rounded-md);font-family:var(--font-display);font-size:var(--body-md);color:var(--on-primary);cursor:pointer;transition:all var(--transition-base);border:none;justify-content:center;align-items:center;font-weight:600;display:inline-flex}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.modal-detail{max-width:640px}.casa-resumen-modal{max-width:1120px}.detail-grid{gap:var(--spacing-4);margin-bottom:var(--spacing-6);grid-template-columns:1fr 1fr;display:grid}.detail-item{gap:var(--spacing-1);flex-direction:column;display:flex}.detail-item.full{grid-column:1/-1}.detail-label{font-size:var(--label-sm);color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.detail-value{font-family:var(--font-body);font-size:var(--body-md);color:var(--on-surface)}.detail-divider{height:1px;margin:var(--spacing-4) 0;background:#c6c6cd26}.detail-section-title{font-family:var(--font-display);font-size:var(--title-sm);color:var(--on-surface);margin-bottom:var(--spacing-4);font-weight:700}.resident-list{gap:var(--spacing-3);flex-direction:column;display:flex}.resident-card{align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:var(--surface-container-low);border-radius:var(--rounded-lg);display:flex}.resident-avatar{border-radius:var(--rounded-full);background:var(--primary-container);width:36px;height:36px;font-family:var(--font-display);font-size:var(--label-md);color:var(--on-primary);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.resident-info{flex:1;min-width:0}.resident-name{font-size:var(--body-md);color:var(--on-surface);font-weight:600}.resident-role{font-size:var(--label-sm);color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.04em}.resident-empty{text-align:center;padding:var(--spacing-6);color:var(--on-surface-variant);font-size:var(--body-sm)}.resumen-hero{justify-content:space-between;gap:var(--spacing-4);background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-5);margin-bottom:var(--spacing-5);display:flex}.resumen-hero h3{font-size:var(--title-lg);margin:var(--spacing-1) 0}.resumen-hero p{color:var(--on-surface-variant)}.resumen-badges{align-items:flex-start;gap:var(--spacing-2);flex-wrap:wrap;justify-content:flex-end;display:flex}.resumen-metrics{gap:var(--spacing-3);margin-bottom:var(--spacing-5);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.resumen-metric,.resumen-info,.resumen-section,.resumen-row{background:var(--surface-container-low);border-radius:var(--rounded-lg)}.resumen-metric{padding:var(--spacing-4)}.resumen-metric strong{font-family:var(--font-display);font-size:var(--title-lg);color:var(--on-surface);display:block}.resumen-metric.mora strong{color:var(--error)}.resumen-metric span{color:var(--on-surface-variant);font-size:var(--label-sm);text-transform:uppercase;letter-spacing:.05em}.resumen-grid{gap:var(--spacing-4);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.resumen-section{padding:var(--spacing-4)}.resumen-info{padding:var(--spacing-3);margin-bottom:var(--spacing-2)}.resumen-info strong{overflow-wrap:anywhere;display:block}.resumen-row{justify-content:space-between;gap:var(--spacing-3);padding:var(--spacing-3);margin-bottom:var(--spacing-2);display:flex}.resumen-row strong,.resumen-row span,.resumen-row small{display:block}.resumen-row span,.resumen-row small{color:var(--on-surface-variant);font-size:var(--label-sm)}.anotacion-card{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-4);margin-bottom:var(--spacing-2)}.anotacion-card p{margin:var(--spacing-2) 0}.anotacion-card small{color:inherit;opacity:.75;display:block}.toast{bottom:var(--spacing-6);right:var(--spacing-6);padding:var(--spacing-3) var(--spacing-6);border-radius:var(--rounded-lg);font-family:var(--font-body);font-size:var(--body-sm);color:var(--on-primary);z-index:300;box-shadow:var(--shadow-lg);font-weight:500;animation:.3s ease-out slideUp,.3s ease-in 2.7s forwards fadeOut;position:fixed}.toast.success{background:var(--primary-container)}.toast.error{background:var(--error)}@keyframes fadeOut{to{opacity:0;transform:translateY(8px)}}@media (width<=1180px){.casas-layout{grid-template-columns:1fr}.casa-detail{position:static}}@media (width<=768px){.casas-topbar{flex-direction:column;align-items:stretch}.casas-search{max-width:none}.casas-stats{flex-direction:column}.detail-grid{grid-template-columns:1fr}.resumen-hero{flex-direction:column}.resumen-badges{justify-content:flex-start}.resumen-metrics,.resumen-grid{grid-template-columns:1fr}.resumen-row{flex-direction:column}.casas-list-panel{overflow-x:auto}.casas-list-panel .casas-table{min-width:860px}}.personas-layout{gap:var(--spacing-6);grid-template-columns:minmax(0,1fr) 380px;align-items:start;display:grid}.personas-table-wrap{min-width:0}.selected-row td:first-child{box-shadow:inset 4px 0 0 0 var(--on-tertiary-container)}.person-detail{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-6);min-height:420px;top:var(--spacing-8);position:sticky}.person-detail-header{justify-content:space-between;gap:var(--spacing-4);align-items:flex-start;display:flex}.person-detail-header h2{font-size:var(--title-lg);margin-top:var(--spacing-3)}.person-detail-header p{color:var(--on-surface-variant);font-size:var(--body-sm)}.person-avatar{border-radius:var(--rounded-lg);background:var(--primary-container);width:48px;height:48px;color:var(--on-primary);font-family:var(--font-display);text-transform:uppercase;justify-content:center;align-items:center;font-weight:800;display:flex}.person-contact-grid{gap:var(--spacing-3);margin-top:var(--spacing-6);grid-template-columns:1fr;display:grid}.person-contact-grid div{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-3)}.person-contact-grid strong{font-size:var(--body-sm);color:var(--on-surface);overflow-wrap:anywhere;display:block}.person-section-heading{justify-content:space-between;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-4);display:flex}.btn-secondary.compact{min-height:var(--control-height-compact);padding:0 var(--spacing-3);font-size:var(--body-sm)}.relation-card{align-items:flex-start}.relation-card.inactive{opacity:.7}.relation-dates{margin-top:var(--spacing-1);color:var(--outline);font-size:var(--label-sm)}.person-empty{justify-content:center;align-items:center;gap:var(--spacing-3);min-height:340px;color:var(--on-surface-variant);text-align:center;flex-direction:column;display:flex}.toggle-grid{gap:var(--spacing-2);margin-bottom:var(--spacing-5);grid-template-columns:1fr;display:grid}.toggle-row{align-items:center;gap:var(--spacing-2);color:var(--on-surface);font-size:var(--body-sm);cursor:pointer;display:flex}.toggle-row input{width:18px;height:18px;accent-color:var(--on-tertiary-container)}@media (width<=1180px){.personas-layout{grid-template-columns:1fr}.person-detail{position:static}}@media (width<=768px){.form-row{grid-template-columns:1fr;gap:0}.personas-table-wrap{overflow-x:auto}.personas-table-wrap .casas-table{min-width:760px}}.pqr-filters{gap:var(--spacing-3);margin-bottom:var(--spacing-6);grid-template-columns:minmax(180px,1.4fr) repeat(5,minmax(130px,1fr)) auto;align-items:end;display:grid}.pqr-layout{gap:var(--spacing-6);grid-template-columns:minmax(0,1fr) 420px;align-items:start;display:grid}.pqr-table-wrap{min-width:0}.pqr-detail{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-6);min-height:520px;top:var(--spacing-8);position:sticky}.pqr-detail-header{justify-content:space-between;gap:var(--spacing-4);align-items:flex-start;display:flex}.pqr-detail-header h2{font-size:var(--title-lg);margin-top:var(--spacing-2)}.pqr-detail-header p,.pqr-description{color:var(--on-surface-variant);font-size:var(--body-sm)}.pqr-description{margin-top:var(--spacing-4);background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-4)}.pqr-meta-grid{gap:var(--spacing-3);margin-top:var(--spacing-4);grid-template-columns:1fr 1fr;display:grid}.pqr-meta-grid div,.pqr-final-response{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-3)}.pqr-meta-grid strong{font-size:var(--body-sm);color:var(--on-surface);display:block}.pqr-final-response{margin-top:var(--spacing-4)}.pqr-final-response p{font-size:var(--body-sm);color:var(--on-surface)}.pqr-actions{gap:var(--spacing-2);margin-top:var(--spacing-4);flex-wrap:wrap;display:flex}.pqr-timeline{gap:var(--spacing-3);flex-direction:column;display:flex}.timeline-item{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-4)}.timeline-item strong,.timeline-item span,.timeline-item small{display:block}.timeline-item span,.timeline-item small{color:var(--on-surface-variant);font-size:var(--label-sm)}.timeline-item p{margin:var(--spacing-2) 0;font-size:var(--body-sm)}.evidence-list{gap:var(--spacing-2);margin-top:var(--spacing-2);flex-wrap:wrap;display:flex}.evidence-list span{background:var(--surface-container-high);border-radius:var(--rounded-md);color:var(--on-surface);padding:var(--spacing-1) var(--spacing-2);font-size:var(--label-sm)}@media (width<=1280px){.pqr-filters,.pqr-layout{grid-template-columns:1fr}.pqr-detail{position:static}}@media (width<=768px){.pqr-table-wrap{overflow-x:auto}.pqr-table-wrap .casas-table{min-width:900px}.pqr-meta-grid{grid-template-columns:1fr}}.salon-toolbar{gap:var(--spacing-3);margin-bottom:var(--spacing-6);grid-template-columns:auto minmax(140px,1fr) minmax(140px,1fr) 150px 150px auto;align-items:center;display:grid}.salon-toolbar.resident-toolbar{grid-template-columns:auto 150px 150px auto}.salon-layout{gap:var(--spacing-6);grid-template-columns:minmax(0,1fr) 410px;align-items:start;display:grid}.salon-calendar{gap:var(--spacing-4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.calendar-day{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-4);min-height:160px}.calendar-day header{justify-content:space-between;gap:var(--spacing-2);margin-bottom:var(--spacing-3);display:flex}.calendar-day header span,.calendar-events p{color:var(--on-surface-variant);font-size:var(--label-sm)}.calendar-events{gap:var(--spacing-2);flex-direction:column;display:flex}.calendar-event{text-align:left;border-radius:var(--rounded-lg);padding:var(--spacing-3);background:var(--surface-container-low);cursor:pointer;transition:all var(--transition-fast);border:none}.calendar-event:hover{background:var(--surface-container-high)}.calendar-event span{color:var(--on-surface-variant);font-size:var(--label-sm);display:block}.calendar-event strong{color:var(--on-surface);font-size:var(--body-sm);display:block}.calendar-event.aprobada,.calendar-event.pagada{box-shadow:inset 4px 0 0 0 var(--on-tertiary-container)}.calendar-event.solicitada{box-shadow:inset 4px 0 0 0 var(--secondary)}.calendar-event.rechazada{box-shadow:inset 4px 0 0 0 var(--error)}.salon-detail{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-6);min-height:520px;top:var(--spacing-8);position:sticky}.salon-detail-header h2{margin-top:var(--spacing-3);font-size:var(--title-lg)}.salon-detail-header p{color:var(--on-surface-variant);font-size:var(--body-sm)}.salon-meta-grid{gap:var(--spacing-3);margin-top:var(--spacing-5);grid-template-columns:1fr 1fr;display:grid}.salon-meta-grid div,.salon-observation{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-3)}.salon-meta-grid strong{overflow-wrap:anywhere;font-size:var(--body-sm);display:block}.salon-observation{margin-top:var(--spacing-4);color:var(--on-surface-variant);font-size:var(--body-sm)}.salon-actions{gap:var(--spacing-2);margin-top:var(--spacing-4);flex-wrap:wrap;display:flex}.tarifa-readonly{min-height:var(--control-height);padding:0 var(--spacing-4);background:var(--surface-container-high);border-radius:var(--rounded-md) var(--rounded-md) 0 0;color:var(--on-surface);font-size:var(--body-md);border-bottom:2px solid #76777d33;align-items:center;font-weight:600;display:flex}.btn-primary.compact{min-height:var(--control-height-compact);padding:0 var(--spacing-3);font-size:var(--body-sm)}.payment-list{gap:var(--spacing-3);flex-direction:column;display:flex}.payment-list article{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-3)}.payment-list span,.payment-list small{color:var(--on-surface-variant);font-size:var(--label-sm);display:block}@media (width<=1280px){.salon-toolbar,.salon-layout{grid-template-columns:1fr}.salon-detail{position:static}}@media (width<=768px){.salon-calendar,.salon-meta-grid{grid-template-columns:1fr}}.users-toolbar{gap:var(--spacing-3);margin-bottom:var(--spacing-6);grid-template-columns:auto minmax(260px,1fr) auto;align-items:center;display:grid}.segmented-control{min-height:var(--control-height);background:var(--surface-container-low);border-radius:var(--rounded-md);padding:var(--spacing-1);align-items:center;display:inline-flex}.segmented-control button{color:var(--on-surface-variant);min-height:calc(var(--control-height) - 8px);border-radius:var(--rounded-sm);padding:var(--spacing-2) var(--spacing-3);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:inline-flex}.roles-grid{gap:var(--spacing-4);padding:var(--spacing-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.role-card{background:var(--surface-container-low);border-radius:var(--rounded-xl);padding:var(--spacing-5)}.role-card-header{justify-content:space-between;gap:var(--spacing-3);align-items:flex-start;display:flex}.role-card h3{font-size:var(--title-md)}.role-card p{color:var(--on-surface-variant);font-size:var(--body-sm);margin-top:var(--spacing-1)}.permission-chips{gap:var(--spacing-2);margin:var(--spacing-4) 0;flex-wrap:wrap;display:flex}.permission-chips span{background:var(--surface-container-high);border-radius:var(--rounded-md);color:var(--on-surface);font-size:var(--label-sm);padding:var(--spacing-1) var(--spacing-2)}.role-actions{gap:var(--spacing-2);justify-content:flex-end;display:flex}.permissions-grid{gap:var(--spacing-2);margin-bottom:var(--spacing-5);grid-template-columns:1fr 1fr;display:grid}@media (width<=900px){.users-toolbar,.permissions-grid{grid-template-columns:1fr}}.morosidad-layout{gap:var(--spacing-6);grid-template-columns:minmax(0,1fr) 360px;align-items:start;display:grid}.morosidad-summary{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-6);top:var(--spacing-8);position:sticky}.morosidad-summary-value{font-family:var(--font-display);font-size:var(--display-sm);color:var(--error);margin-top:var(--spacing-2);font-weight:800}.morosidad-summary-grid{gap:var(--spacing-3);margin-top:var(--spacing-6);grid-template-columns:1fr;display:grid}.morosidad-summary-item{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-3)}.morosidad-summary-item strong{color:var(--on-surface);font-size:var(--title-sm);display:block}.morosidad-summary-item span{color:var(--on-surface-variant);font-size:var(--label-md);text-transform:uppercase;letter-spacing:.05em}.morosidad-actions{justify-content:flex-end;gap:var(--spacing-3);margin-bottom:var(--spacing-4);display:flex}.cartera-filter-select,.cartera-small-input{min-width:160px;max-width:220px}.cartera-filter-select{height:var(--control-height);padding:var(--spacing-2) 44px var(--spacing-2) var(--spacing-4);background:var(--surface-container-lowest);border-radius:var(--rounded-md) var(--rounded-md) 0 0;font-family:var(--font-body);font-size:var(--body-md);color:var(--on-surface);border:none;border-bottom:2px solid #76777d26;outline:none}.form-row{gap:var(--spacing-4);grid-template-columns:1fr 1fr;display:grid}.danger-action{color:var(--error);border-color:#ba1a1a47}.danger-action:hover{background:var(--error-container);color:var(--on-error-container)}.cartera-status-cell{align-items:flex-start;gap:var(--spacing-2);flex-direction:column;display:flex}.cartera-row-actions{gap:var(--spacing-2);flex-wrap:wrap;display:flex}@media (width<=1180px){.morosidad-layout{grid-template-columns:1fr}.morosidad-summary{position:static}}@media (width<=768px){.morosidad-actions{justify-content:stretch}.morosidad-actions .btn-add{justify-content:center;width:100%}.cartera-filter-select,.cartera-small-input{width:100%;max-width:none}.form-row{grid-template-columns:1fr;gap:0}}.vigilancia-toolbar{justify-content:space-between;gap:var(--spacing-4);margin-bottom:var(--spacing-6);flex-wrap:wrap;align-items:center;display:flex}.vigilancia-search{width:min(100%,560px);position:relative}.vigilancia-grid{gap:var(--spacing-5);grid-template-columns:repeat(auto-fill,minmax(360px,1fr));display:grid}.vigilancia-card{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-5);gap:var(--spacing-4);flex-direction:column;display:flex}.vigilancia-card-header{justify-content:space-between;gap:var(--spacing-4);align-items:flex-start;display:flex}.vigilancia-house{align-items:center;gap:var(--spacing-3);display:flex}.vigilancia-house-icon{border-radius:var(--rounded-lg);background:var(--primary-container);width:48px;height:48px;color:var(--on-primary);font-family:var(--font-display);font-size:var(--title-sm);justify-content:center;align-items:center;font-weight:800;display:flex}.vigilancia-house h2{font-size:var(--title-md);margin:0}.vigilancia-house p,.vigilancia-owner p,.vigilancia-meta span{color:var(--on-surface-variant);font-size:var(--body-sm)}.vigilancia-owner{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-4)}.vigilancia-owner h3{font-size:var(--title-sm);margin-bottom:var(--spacing-1)}.vigilancia-meta{gap:var(--spacing-3);grid-template-columns:repeat(2,1fr);display:grid}.vigilancia-meta div{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-3)}.vigilancia-meta strong{color:var(--on-surface);margin-top:var(--spacing-1);display:block}.vigilancia-block{border-left:4px solid var(--error);padding:var(--spacing-3) var(--spacing-4);background:var(--error-container);border-radius:var(--rounded-md);color:var(--on-error-container)}@media (width<=768px){.vigilancia-grid,.vigilancia-meta{grid-template-columns:1fr}}.vigilancia-detail-layout{gap:var(--spacing-6);grid-template-columns:minmax(0,1fr) 420px;align-items:start;display:grid}.vigilancia-house-list{gap:var(--spacing-4);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.vigilancia-house-card{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-5);cursor:pointer;transition:all var(--transition-fast)}.vigilancia-house-card:hover,.vigilancia-house-card.active{background:var(--surface-container-low);box-shadow:inset 4px 0 0 0 var(--on-tertiary-container)}.vigilancia-house-card h2{font-size:var(--title-md);margin:var(--spacing-2) 0}.vigilancia-owners{margin-top:var(--spacing-4);gap:var(--spacing-2);flex-direction:column;display:flex}.vigilancia-owner-line{background:var(--surface-container-low);border-radius:var(--rounded-md);padding:var(--spacing-3)}.vigilancia-detail{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-6);top:var(--spacing-8);min-height:520px;position:sticky}.anotaciones-toolbar{margin-bottom:var(--spacing-6);grid-template-columns:minmax(260px,1fr) minmax(180px,220px) 160px 160px auto auto;display:grid}.anotaciones-table{min-width:980px}.anotaciones-table tbody tr.selected-row{background:var(--surface-container-high)}.anotacion-comment-cell{text-overflow:ellipsis;white-space:nowrap;max-width:360px;overflow:hidden}.anotacion-detail-comment{background:var(--surface-container-low);border-radius:var(--rounded-lg);color:var(--on-surface);padding:var(--spacing-4);white-space:pre-wrap;margin:0;line-height:1.6}.anotacion-form{gap:var(--spacing-3);margin-bottom:var(--spacing-5);flex-direction:column;display:flex}.anotacion-list{gap:var(--spacing-3);flex-direction:column;display:flex}.anotacion-card{background:var(--surface-container-low);border-radius:var(--rounded-lg);padding:var(--spacing-4)}.anotacion-card.warning{background:var(--error-container);color:var(--on-error-container)}.anotacion-card small{margin-top:var(--spacing-2);color:inherit;opacity:.75;display:block}@media (width<=1180px){.vigilancia-detail-layout{grid-template-columns:1fr}.anotaciones-toolbar{grid-template-columns:1fr 1fr}.vigilancia-detail{position:static}}@media (width<=720px){.anotaciones-toolbar{grid-template-columns:1fr}}.anuncios-toolbar{align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-6);flex-wrap:wrap;display:flex}.segmented-control{min-height:var(--control-height);background:var(--surface-container-low);border-radius:var(--rounded-full);align-items:center;padding:4px;display:inline-flex}.segmented-control button{color:var(--on-surface-variant);min-height:calc(var(--control-height) - 8px);padding:var(--spacing-2) var(--spacing-5);border-radius:var(--rounded-full);font:inherit;cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;display:inline-flex}.segmented-control button.active{background:var(--on-surface);color:var(--surface)}.compact-select{height:var(--control-height);max-width:170px}.anuncios-toolbar .btn-secondary.compact{min-height:var(--control-height);padding:0 var(--spacing-4)}.anuncios-layout{gap:var(--spacing-6);grid-template-columns:minmax(0,1fr) 420px;align-items:start;display:grid}.anuncios-list{gap:var(--spacing-4);display:grid}.anuncio-card{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-5);cursor:pointer;transition:all var(--transition-fast)}.anuncio-card:hover,.anuncio-card.active{background:var(--surface-container-low);box-shadow:inset 4px 0 0 0 var(--on-tertiary-container)}.anuncio-card-head{justify-content:space-between;gap:var(--spacing-3);margin-bottom:var(--spacing-3);align-items:center;display:flex}.anuncio-card h2{font-size:var(--title-md);margin:0 0 var(--spacing-2)}.anuncio-card p{color:var(--on-surface-variant);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;display:-webkit-box;overflow:hidden}.anuncio-meta{color:var(--on-surface-variant);font-size:var(--body-sm);margin-top:var(--spacing-4)}.anuncio-detail{background:var(--surface-container-lowest);border-radius:var(--rounded-xl);padding:var(--spacing-6);top:var(--spacing-8);min-height:520px;position:sticky}.anuncio-detail-head h2{margin:var(--spacing-3) 0 var(--spacing-2);font-size:var(--headline-sm)}.anuncio-detail-actions{justify-content:space-between;gap:var(--spacing-3);align-items:center;display:flex}.anuncio-content{white-space:pre-wrap;color:var(--on-surface);line-height:1.65}.anuncio-validity{gap:var(--spacing-3);margin:var(--spacing-5) 0;grid-template-columns:repeat(3,1fr);display:grid}.anuncio-validity div,.adjunto-row{background:var(--surface-container-low);border-radius:var(--rounded-md);padding:var(--spacing-3)}.adjunto-row{align-items:center;gap:var(--spacing-3);justify-content:space-between;display:flex}.anuncio-validity strong,.anuncio-validity span,.adjunto-row span,.adjunto-row small{display:block}.anuncio-validity strong{font-size:var(--label-sm);text-transform:uppercase;letter-spacing:.08em;color:var(--on-surface-variant);margin-bottom:var(--spacing-1)}.adjunto-list{gap:var(--spacing-2);flex-direction:column;display:flex}.adjunto-row small{color:var(--on-surface-variant);margin-top:var(--spacing-1)}.priority-badge{border-radius:var(--rounded-full);padding:var(--spacing-1) var(--spacing-3);font-size:var(--label-sm);text-transform:uppercase;align-items:center;font-weight:700;display:inline-flex}.priority-baja{background:var(--surface-container-high);color:var(--on-surface-variant)}.priority-media{background:var(--tertiary-container);color:var(--on-tertiary-container)}.priority-alta{color:#7a4d00;background:#fff3cd}.priority-urgente{background:var(--error-container);color:var(--on-error-container)}.form-hint{color:var(--on-surface-variant);margin-top:var(--spacing-1)}.anuncio-modal{max-height:min(92vh,760px);overflow-y:auto}.anuncio-modal .form-input,.anuncio-modal .form-textarea,.anuncio-modal .form-select{background-color:var(--surface-container-high)}@media (width<=1180px){.anuncios-layout{grid-template-columns:1fr}.anuncio-detail{position:static}}@media (width<=720px){.anuncios-toolbar{align-items:stretch}.anuncios-toolbar>*{width:100%}.anuncio-validity{grid-template-columns:1fr}.compact-select{max-width:none}.anuncio-modal{border-radius:var(--rounded-lg);width:calc(100vw - 24px);max-height:calc(100vh - 24px)}.anuncio-modal .modal-header{padding:var(--spacing-5) var(--spacing-4) var(--spacing-3)}.anuncio-modal .modal-header h2{font-size:var(--title-lg)}.anuncio-modal .modal-body{padding:0 var(--spacing-4) var(--spacing-4)}.anuncio-modal .form-row{grid-template-columns:1fr;gap:0}.anuncio-modal .form-textarea{min-height:160px}}
