@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Manrope:wght@300;400;500;600;700;800&display=swap";.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition-base)}.sidebar-overlay{display:none}.sidebar-header{padding:.9rem 1rem;border-bottom:1px solid var(--border-color)}.sidebar-logo{display:flex;align-items:center;gap:.75rem}.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--primary-500),var(--accent-500));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff;box-shadow:0 4px 12px #3b82f64d;flex-shrink:0}.logo-text h1{font-size:1.05rem;font-weight:800;color:var(--text-primary);line-height:1.2}.logo-text span{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:500}.sidebar-nav{flex:1;overflow-y:auto;padding:.75rem;scrollbar-width:none;-ms-overflow-style:none}.sidebar-nav::-webkit-scrollbar{display:none}.nav-section-title{display:block;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:0 .75rem;margin-bottom:.3rem;margin-top:.15rem}.nav-section{margin-bottom:.4rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}.nav-section:last-child{border-bottom:none;margin-bottom:0}.nav-item{display:flex;align-items:center;gap:.7rem;padding:.55rem .75rem;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:500;position:relative;transition:all var(--transition-fast);margin-bottom:.15rem;text-decoration:none}.nav-item:hover{background:#3b82f614;color:var(--text-primary)}.nav-item-active{background:#3b82f61f;color:var(--primary-400)}.nav-item-active .nav-icon{color:var(--primary-400)}.nav-indicator{position:absolute;right:-12px;width:3px;height:60%;background:linear-gradient(180deg,var(--primary-400),var(--accent-500));border-radius:var(--radius-full)}.nav-icon{font-size:1.15rem;flex-shrink:0}.sidebar-footer{padding:.75rem;border-top:1px solid var(--border-color);display:flex;align-items:center;gap:.5rem}.user-card{flex:1;display:flex;align-items:center;gap:.65rem;min-width:0}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-500),var(--accent-500));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0}.user-info{display:flex;flex-direction:column;min-width:0}.user-name{font-size:.8rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.65rem;color:var(--text-muted);text-transform:capitalize}.btn-logout{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:transparent;transition:all var(--transition-fast);font-size:1.2rem;flex-shrink:0}.btn-logout:hover{background:#ef44441a;color:var(--danger-400)}.mode-toggle{display:flex;margin:.4rem .75rem;background:var(--bg-card, #1e293b);border-radius:999px;padding:3px;border:1px solid var(--border-color);gap:2px}.mode-toggle button{flex:1;border:none;background:transparent;color:var(--text-secondary, #94a3b8);font-size:.72rem;font-weight:500;padding:.35rem .5rem;border-radius:999px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.mode-toggle button.active{background:var(--primary, #6366f1);color:#fff;box-shadow:0 1px 4px #6366f173}.mode-toggle button:not(.active):hover{color:var(--text-primary, #f1f5f9)}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99}}.condo-selector{padding:.5rem .75rem;border-bottom:1px solid var(--border-color)}.condo-selector-active{display:flex;align-items:center;justify-content:space-between;padding:.5rem .65rem;border-radius:var(--radius-md);background:var(--bg-secondary);transition:background var(--transition-base)}.condo-selector-active:hover{background:var(--bg-tertiary, var(--bg-secondary))}.condo-selector-active[style]{cursor:pointer}.condo-selector-info{display:flex;flex-direction:column;gap:.05rem;min-width:0}.condo-selector-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600}.condo-selector-name{font-size:.82rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.condo-selector-arrow{font-size:.85rem;color:var(--text-muted);transition:transform .2s ease;flex-shrink:0}.condo-selector-arrow.open{transform:rotate(180deg)}.condo-selector-list{margin-top:.35rem;display:flex;flex-direction:column;gap:.15rem}.condo-selector-option{display:flex;align-items:center;gap:.5rem;width:100%;padding:.45rem .65rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:background var(--transition-base),color var(--transition-base);text-align:left}.condo-selector-option:hover{background:var(--primary-50);color:var(--primary-500)}.navbar{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:var(--navbar-height);background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:50}.navbar-left{display:flex;align-items:center;gap:1rem}.menu-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-secondary);background:transparent;font-size:1.4rem;transition:all var(--transition-fast)}.menu-toggle:hover{background:#94a3b81a;color:var(--text-primary)}.page-title{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.navbar-right{display:flex;align-items:center;gap:.5rem}.navbar-btn{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-secondary);background:transparent;font-size:1.3rem;transition:all var(--transition-fast)}.navbar-btn:hover{background:#94a3b81a;color:var(--text-primary)}.notification-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 5px;background:var(--danger-500);color:#fff;border-radius:999px;border:2px solid var(--bg-card);font-size:.65rem;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center}@media(max-width:768px){.navbar{padding:0 1rem}.menu-toggle{display:flex}.page-title{font-size:1.05rem}}.layout{display:flex;min-height:100vh}.layout-main{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.layout-content{flex:1;padding:1.5rem;animation:fadeIn var(--transition-base) ease-out}@media(max-width:768px){.layout-main{margin-left:0}.layout-content{padding:1rem}}.landing{min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#fffc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(0,0,0,.06)}.landing-nav-inner{max-width:1200px;margin:0 auto;padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between}.landing-logo{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.landing-logo svg{font-size:1.5rem;color:var(--primary-500)}.landing-nav-links{display:flex;align-items:center;gap:1.5rem}.landing-nav-links a{color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:color .2s}.landing-nav-links a:hover{color:var(--text-primary)}.landing-btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff!important;border-radius:10px;font-weight:600;font-size:.9rem;transition:all .25s;border:none;cursor:pointer}.landing-btn-primary:hover{background:linear-gradient(135deg,var(--primary-600),var(--primary-700));color:#fff!important;transform:translateY(-1px);box-shadow:0 6px 20px #6366f14d}.landing-btn-glow{box-shadow:0 4px 14px #6366f140}.landing-btn-outline{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:transparent;color:var(--text-secondary)!important;border:1px solid var(--border-color);border-radius:10px;font-weight:500;font-size:.9rem;transition:all .25s;cursor:pointer}.landing-btn-outline:hover{border-color:var(--primary-400);color:var(--primary-500)!important;background:var(--primary-50)}.landing-btn-lg{padding:.85rem 1.75rem;font-size:1rem}.landing-hero{padding:10rem 2rem 6rem;text-align:center;position:relative;overflow:hidden}.landing-hero-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}.hero-glow{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}.hero-glow-1{width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.15) 0%,transparent 70%);top:-200px;left:50%;transform:translate(-70%);animation:float 8s ease-in-out infinite}.hero-glow-2{width:500px;height:500px;background:radial-gradient(circle,rgba(20,184,166,.12) 0%,transparent 70%);top:-100px;right:-100px;animation:float 10s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translateY(0) translate(-70%)}50%{transform:translateY(20px) translate(-70%)}}.landing-hero-content{max-width:720px;margin:0 auto;position:relative}.landing-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem 1rem;background:var(--primary-50);border:1px solid var(--primary-200);border-radius:50px;font-size:.8rem;font-weight:500;color:var(--primary-700);margin-bottom:1.5rem}.landing-badge svg{font-size:.95rem}.landing-hero h1{font-size:3.25rem;font-weight:800;line-height:1.15;margin-bottom:1.5rem;letter-spacing:-.03em}.gradient-text{background:linear-gradient(135deg,var(--primary-500),#14b8a6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-hero p{font-size:1.15rem;color:var(--text-secondary);line-height:1.7;margin-bottom:2rem}.landing-hero-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:1.25rem}.landing-hero-note{font-size:.85rem!important;color:var(--text-muted)!important}.landing-container{max-width:1200px;margin:0 auto;padding:0 2rem}.landing-features,.landing-roles,.landing-pricing,.landing-cta{padding:5rem 0}.landing-features h2,.landing-roles h2,.landing-pricing h2,.landing-cta h2{text-align:center;font-size:2.25rem;font-weight:700;margin-bottom:.75rem;letter-spacing:-.02em}.landing-subtitle{text-align:center;color:var(--text-secondary);font-size:1.05rem;margin-bottom:3rem;max-width:600px;margin-left:auto;margin-right:auto}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.feature-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:2rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.feature-card:hover{border-color:var(--primary-300);transform:translateY(-4px);box-shadow:0 12px 32px #6366f114,0 2px 8px #0000000a}.feature-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-50),rgba(20,184,166,.08));border-radius:12px;margin-bottom:1rem;font-size:1.4rem;color:var(--primary-600)}.feature-card h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.feature-card p{font-size:.9rem;color:var(--text-secondary);line-height:1.6}.landing-roles{background:var(--bg-secondary)}.roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.role-card{text-align:center;padding:2.5rem 2rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;transition:all .3s}.role-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000000a}.role-emoji{font-size:2.5rem;margin-bottom:1rem}.role-card h3{font-size:1.2rem;font-weight:600;margin-bottom:.75rem}.role-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.pricing-calculator{display:grid;grid-template-columns:1.3fr 1fr;gap:2rem;align-items:start}.calculator-main{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;padding:2.5rem;position:relative;overflow:hidden}.calculator-main:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-500),#14b8a6)}.calculator-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1.75rem}.calc-icon{font-size:1.5rem;color:var(--primary-500)}.calculator-header h3{font-size:1.3rem;font-weight:700}.quick-select{display:flex;gap:.5rem;margin-bottom:1.75rem;flex-wrap:wrap}.quick-btn{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.quick-btn:hover{border-color:var(--primary-400);color:var(--primary-600);background:var(--primary-50)}.quick-btn.active{border-color:var(--primary-500);background:var(--primary-500);color:#fff}.calculator-slider-section{margin-bottom:1.75rem}.slider-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.9rem;color:var(--text-secondary)}.units-input-wrap{display:flex;align-items:center;gap:.4rem}.units-input{width:70px;padding:.4rem .5rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;font-weight:700;color:var(--text-primary);text-align:center;background:var(--bg-secondary);transition:border-color .2s}.units-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #6366f11a}.units-label{font-size:.8rem;color:var(--text-muted)}.calculator-slider{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:4px;background:linear-gradient(to right,var(--primary-500) 0%,var(--primary-500) var(--progress),var(--gray-200) var(--progress),var(--gray-200) 100%);outline:none;cursor:pointer}.calculator-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid var(--primary-500);cursor:pointer;box-shadow:0 2px 8px #6366f14d;transition:transform .15s,box-shadow .15s}.calculator-slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 4px 12px #6366f166}.calculator-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid var(--primary-500);cursor:pointer;box-shadow:0 2px 8px #6366f14d}.slider-marks{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:var(--text-muted)}.pricing-toggle{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.75rem;font-size:.95rem}.pricing-toggle span{color:var(--text-muted);transition:color .2s}.pricing-toggle span.active{color:var(--text-primary);font-weight:600}.toggle-switch{width:48px;height:26px;background:var(--gray-300);border-radius:50px;position:relative;cursor:pointer;transition:background .25s;border:none;padding:0}.toggle-switch.active{background:var(--primary-500)}.toggle-knob{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:transform .25s;box-shadow:0 1px 4px #00000026}.toggle-switch.active .toggle-knob{transform:translate(22px)}.save-badge{background:#ecfdf5;color:#059669;padding:.2rem .6rem;border-radius:50px;font-size:.75rem;font-weight:600}.calculator-result{background:linear-gradient(135deg,var(--primary-50),rgba(20,184,166,.05));border:1px solid var(--primary-200);border-radius:16px;padding:1.75rem;text-align:center;margin-bottom:1.5rem}.result-price{display:flex;align-items:baseline;justify-content:center;gap:4px;margin-bottom:.5rem}.result-currency{font-size:1.5rem;font-weight:700;color:var(--primary-600)}.result-amount{font-size:3.5rem;font-weight:800;line-height:1;color:var(--text-primary);animation:pop-in .3s cubic-bezier(.34,1.56,.64,1)}@keyframes pop-in{0%{transform:scale(.8);opacity:.5}to{transform:scale(1);opacity:1}}.result-period{font-size:1rem;color:var(--text-muted);font-weight:500}.result-annual{margin-bottom:.75rem}.result-annual p{font-size:.9rem;color:var(--text-secondary);margin:0}.result-savings{color:#059669!important;font-weight:600;margin-top:.25rem!important}.result-breakdown{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.85rem;color:var(--text-muted);padding-top:.75rem;border-top:1px solid var(--primary-200)}.calculator-cta{width:100%;justify-content:center;padding:1rem;font-size:1.05rem;border-radius:12px}.calculator-note{text-align:center;font-size:.8rem;color:var(--text-muted);margin-top:.75rem}.calculator-features{position:sticky;top:80px}.features-included-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;padding:2rem}.features-included-card h4{display:flex;align-items:center;gap:.5rem;font-size:1.15rem;font-weight:700;margin-bottom:.5rem}.check-all{color:#059669;font-size:1.25rem}.features-included-desc{font-size:.85rem;color:var(--text-secondary);margin-bottom:1.25rem;line-height:1.5}.features-checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.65rem}.features-checklist li{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--text-secondary)}.features-checklist li svg{color:#059669;flex-shrink:0;font-size:1rem}.landing-cta{text-align:center;background:var(--bg-secondary);position:relative;overflow:hidden}.cta-glow{position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(99,102,241,.08) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.landing-cta p{color:var(--text-secondary);font-size:1.1rem;margin-bottom:2rem}.landing-footer{padding:2rem 0;border-top:1px solid var(--border-color);text-align:center}.landing-footer .landing-container{display:flex;flex-direction:column;align-items:center;gap:.75rem}.landing-footer p{color:var(--text-muted);font-size:.85rem}@media(max-width:1024px){.pricing-calculator{grid-template-columns:1fr}.calculator-features{position:static}}@media(max-width:768px){.landing-hero h1{font-size:2.2rem}.features-grid,.roles-grid{grid-template-columns:1fr}.landing-hero-actions{flex-direction:column;align-items:center}.landing-nav-links a:not(.landing-btn-primary):not(.landing-btn-outline){display:none}.calculator-main{padding:1.5rem}.quick-select{display:grid;grid-template-columns:1fr 1fr}.result-amount{font-size:2.75rem}.slider-label{flex-direction:column;gap:.5rem;align-items:flex-start}}@media(max-width:480px){.landing-hero h1{font-size:1.75rem}.landing-hero{padding:8rem 1rem 4rem}.landing-features,.landing-roles,.landing-pricing,.landing-cta{padding:3rem 0}}.social-login-btn{display:flex;align-items:center;justify-content:center;gap:.625rem;width:100%;padding:.625rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s,box-shadow .15s,opacity .15s;border:1.5px solid #dadce0;background:#fff;color:#3c4043;line-height:1.4}.social-login-btn:hover:not(:disabled){background:#f8f9fa;box-shadow:0 1px 4px #0000001f}.social-login-btn:disabled{opacity:.55;cursor:not-allowed}.social-login-btn__icon{width:20px;height:20px;flex-shrink:0}.social-login-btn--apple{background:#000;border-color:#000;color:#fff}.social-login-btn--apple:hover:not(:disabled){background:#1a1a1a;box-shadow:0 1px 4px #0000004d}.social-divider{display:flex;align-items:center;gap:.75rem;margin:1rem 0;color:#9ca3af;font-size:.82rem}.social-divider:before,.social-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;position:relative;overflow:hidden}.login-bg{position:absolute;inset:0;overflow:hidden}.bg-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.15}.blob-1{width:400px;height:400px;background:var(--primary-500);top:-100px;right:-100px;animation:float 8s ease-in-out infinite}.blob-2{width:350px;height:350px;background:var(--accent-500);bottom:-80px;left:-80px;animation:float 10s ease-in-out infinite reverse}.blob-3{width:250px;height:250px;background:var(--success-500);top:50%;left:50%;animation:float 12s ease-in-out infinite 2s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}.login-container{position:relative;z-index:1;width:100%;max-width:420px}.login-card{border-radius:var(--radius-xl);overflow:hidden}.login-header{text-align:center;padding:2rem 2rem 0}.login-logo{width:64px;height:64px;margin:0 auto 1rem;background:linear-gradient(135deg,var(--primary-500),var(--accent-500));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:#fff;box-shadow:0 8px 24px #3b82f64d}.login-header h1{font-size:1.8rem;font-weight:800;color:var(--text-primary);margin-bottom:.3rem}.login-header p{color:var(--text-muted);font-size:.9rem}.login-form{padding:1.5rem 2rem;display:flex;flex-direction:column;gap:1rem}.password-wrapper{position:relative}.password-wrapper .input-field{padding-right:2.5rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;color:var(--text-muted);font-size:1.2rem;display:flex;padding:0}.password-toggle:hover{color:var(--text-secondary)}.login-error{background:var(--danger-50);border:1px solid rgba(239,68,68,.3);color:var(--danger-600);padding:.6rem .9rem;border-radius:var(--radius-md);font-size:.85rem;text-align:center}.login-btn{width:100%;margin-top:.5rem}.btn-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;padding:0 2rem 1.25rem}.login-footer p{color:var(--text-muted);font-size:.85rem}.link-btn{background:none;color:var(--primary-400);font-weight:600;margin-left:.3rem;font-size:.85rem}.link-btn:hover{color:var(--primary-600);text-decoration:underline}.demo-credentials{text-align:center;padding:.75rem 2rem 1.5rem}.demo-credentials span{font-size:.72rem;color:var(--text-muted);background:var(--gray-50);padding:.35rem .7rem;border-radius:var(--radius-full)}.invitacion-banner{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,var(--primary-50),var(--accent-50));border:1px solid rgba(59,130,246,.2);color:var(--text-primary);padding:.75rem 1rem;margin:0 2rem;border-radius:var(--radius-md);font-size:.85rem;line-height:1.4}.invitacion-banner strong{color:var(--primary-600)}.codigo-toggle{display:flex;align-items:center;margin-bottom:.25rem}.codigo-toggle label{display:flex;align-items:center;gap:.25rem;cursor:pointer;font-size:.85rem;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.codigo-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-500);cursor:pointer}.registro-hint{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.unit-fields-title{font-size:.85rem;color:var(--text-secondary);margin:0 0 .5rem}.unit-fields-row{display:flex;gap:.75rem}.unit-fields-col{flex:1;min-width:0}.unit-fields-row .input-field{height:46px}.condo-register-section{background:var(--bg-secondary, rgba(255,255,255,.05));border:1px solid var(--border-color, rgba(255,255,255,.1));border-radius:var(--radius-lg, 12px);padding:1rem;margin-top:.25rem}.condo-register-section .input-group{margin-bottom:.75rem}.condo-register-section .input-group:last-child{margin-bottom:0}.register-wizard{padding:0 2rem .5rem}.step-indicator{display:flex;align-items:flex-start;justify-content:center;gap:0;padding:1.25rem 0 .5rem;position:relative}.step-item{display:flex;flex-direction:column;align-items:center;gap:.35rem;position:relative;flex:1}.step-circle{width:32px;height:32px;border-radius:50%;border:2px solid var(--border);background:var(--bg-secondary);color:var(--text-muted);font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .25s ease;position:relative;z-index:1}.step-item.active .step-circle{border-color:var(--primary-500);background:var(--primary-500);color:#fff;box-shadow:0 0 0 4px #3b82f626}.step-item.done .step-circle{border-color:var(--success-500);background:var(--success-500);color:#fff;font-size:1rem}.step-label{font-size:.7rem;font-weight:500;color:var(--text-muted);text-align:center;white-space:nowrap}.step-item.active .step-label{color:var(--primary-500);font-weight:600}.step-item.done .step-label{color:var(--success-500)}.step-connector{position:absolute;top:15px;left:calc(50% + 16px);right:calc(-50% + 16px);height:2px;background:var(--border);transition:background .25s ease;z-index:0}.step-item.done .step-connector{background:var(--success-500)}.wizard-content{display:flex;flex-direction:column;gap:0;padding-bottom:.5rem}.wizard-step{display:flex;flex-direction:column;gap:.875rem;padding:1rem 0 .25rem}.step-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.3}.step-subtitle{font-size:.82rem;color:var(--text-muted);margin:-.5rem 0 0;line-height:1.4}.tipo-cards{display:flex;gap:.75rem;flex-direction:column}.tipo-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.1rem;border-radius:var(--radius-lg);border:2px solid var(--border);background:var(--bg-secondary);cursor:pointer;text-align:left;transition:all .2s ease;width:100%}.tipo-card:hover{border-color:var(--primary-400);background:#3b82f60d}.tipo-card.selected{border-color:var(--primary-500);background:#3b82f614;box-shadow:0 0 0 3px #3b82f61a}.tipo-card-icon{width:42px;height:42px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--primary-500),var(--accent-500));display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#fff;flex-shrink:0}.tipo-card.selected .tipo-card-icon{box-shadow:0 4px 12px #3b82f659}.tipo-card-text{display:flex;flex-direction:column;gap:.15rem}.tipo-card-text strong{font-size:.9rem;font-weight:700;color:var(--text-primary)}.tipo-card-text span{font-size:.78rem;color:var(--text-muted)}.codigo-input-group{margin-top:.25rem}.invitacion-inline{margin:.5rem 0 0!important;font-size:.8rem}.input-valid{border-color:var(--success-500)!important;box-shadow:0 0 0 3px #22c55e26!important}.wizard-error{margin-top:.25rem}.wizard-actions{display:flex;gap:.75rem;margin-top:1rem;padding-top:.25rem}.wizard-back{display:flex;align-items:center;gap:.3rem;padding:0 1rem;color:var(--text-secondary);font-size:.875rem;border:1px solid var(--border);border-radius:var(--radius-md);background:transparent;height:44px;white-space:nowrap}.wizard-back:hover{border-color:var(--text-secondary);color:var(--text-primary)}.wizard-next{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;height:44px;font-size:.9rem}@media(max-width:480px){.login-form{padding:1.25rem}.login-header{padding:1.5rem 1.25rem 0}.login-footer{padding:0 1.25rem 1rem}.demo-credentials{padding:.5rem 1.25rem 1.25rem}.unit-fields-row{flex-direction:column}.register-wizard{padding:0 1.25rem .5rem}.tipo-cards{gap:.5rem}.tipo-card{padding:.75rem .9rem}.step-label{font-size:.62rem}}.dashboard{display:flex;flex-direction:column;gap:1.5rem}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem;color:var(--text-muted)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}.dashboard-filter{max-width:300px}.dashboard-filter .input-field{font-size:.85rem}.admin-dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.admin-header-main{display:flex;flex-direction:column;gap:.75rem}.admin-header-title{font-size:1.8rem;font-weight:700;margin:0;color:var(--text-primary)}.admin-header-subtitle{color:var(--text-muted);font-size:.9rem;margin:0}.admin-health-row{display:flex;align-items:stretch;flex-wrap:wrap;gap:.75rem}.admin-health-pill{display:flex;flex-direction:column;gap:.2rem;padding:.75rem 1rem;min-width:150px;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-card);box-shadow:var(--shadow-sm)}.admin-health-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:700}.admin-health-value{font-size:1.35rem;line-height:1;color:var(--text-primary)}.admin-health-value.is-positive{color:var(--success-400)}.admin-health-value.is-negative{color:var(--danger-400)}.admin-header-actions{display:flex;align-items:flex-start;gap:1rem}.admin-dashboard-filter{min-width:250px}.admin-filter-label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:.35rem}.admin-dashboard-filter .input-field{margin:0}.stats-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.stat-card{position:relative;display:flex;align-items:center;gap:1rem;padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-card);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--transition-base)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card:after{content:"";position:absolute;top:0;left:0;width:100%;height:3px}.stat-blue:after{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.stat-purple:after{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.stat-teal:after{background:linear-gradient(90deg,#14b8a6,#5eead4)}.stat-green:after{background:linear-gradient(90deg,#22c55e,#4ade80)}.stat-red:after{background:linear-gradient(90deg,#ef4444,#f87171)}.stat-yellow:after{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.stat-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.stat-blue .stat-icon{background:#3b82f61f;color:#60a5fa}.stat-purple .stat-icon{background:#8b5cf61f;color:#a78bfa}.stat-teal .stat-icon{background:#14b8a61f;color:#5eead4}.stat-green .stat-icon{background:#22c55e1f;color:#4ade80}.stat-red .stat-icon{background:#ef44441f;color:#f87171}.stat-yellow .stat-icon{background:#f59e0b1f;color:#fbbf24}.stat-content{display:flex;flex-direction:column;min-width:0}.stat-value{font-size:1.5rem;font-weight:800;color:var(--text-primary);line-height:1.2}.stat-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.stat-sub{font-size:.7rem;color:var(--text-muted);display:flex;align-items:center;gap:.25rem;margin-top:.15rem}.stat-danger-sub{color:var(--danger-400)}.dashboard-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:1.5rem}.card-header{padding:1.25rem;border-bottom:1px solid var(--border-color);display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.card-header h3{font-size:1rem;font-weight:700}.card-subtitle{font-size:.75rem;color:var(--text-muted)}.chart-wrapper{padding:1rem}.chart-kpis{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.chart-kpi{font-size:.75rem;font-weight:700;padding:.28rem .55rem;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-secondary)}.chart-kpi.is-income{color:var(--success-500)}.chart-kpi.is-expense{color:var(--danger-500)}.activity-list{padding:.5rem 0}.activity-total{font-size:.72rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.03em}.activity-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;transition:background var(--transition-fast)}.activity-item:hover{background:var(--gray-50)}.activity-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-success{background:var(--success-500)}.dot-warning{background:var(--warning-500)}.activity-info{flex:1;display:flex;flex-direction:column;min-width:0}.activity-title{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-meta{font-size:.75rem;color:var(--text-muted)}.empty-text{text-align:center;padding:2rem;color:var(--text-muted);font-size:.9rem}@media(max-width:768px){.admin-dashboard-header{flex-direction:column;align-items:stretch}.admin-header-actions{width:100%}.admin-dashboard-filter{width:100%;min-width:0}.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.stat-value{font-size:1.2rem}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.admin-health-row{display:grid;grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem;animation:fadeIn .15s ease-out}.modal-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-height:90vh;overflow-y:auto;animation:scaleIn .2s ease-out}.modal-sm{max-width:400px}.modal-md{max-width:520px}.modal-lg{max-width:700px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-muted);background:transparent;font-size:1.3rem;transition:all var(--transition-fast)}.modal-close:hover{background:var(--gray-100);color:var(--text-primary)}.modal-body{padding:1.5rem}.form-grid{display:grid;gap:1rem}.form-grid-2{grid-template-columns:1fr 1fr}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border-color)}@media(max-width:480px){.form-grid-2{grid-template-columns:1fr}}.confirm-overlay{position:fixed;inset:0;z-index:1100;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:1rem;animation:confirmFadeIn .2s ease}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:2rem;width:100%;max-width:400px;text-align:center;box-shadow:0 20px 60px #00000080}.animate-scale-in{animation:scaleIn .25s cubic-bezier(.175,.885,.32,1.275)}@keyframes scaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.confirm-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;font-size:1.75rem}.confirm-icon-danger{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.confirm-icon-warning{background:#f59e0b1f;color:#f59e0b;border:1px solid rgba(245,158,11,.2)}.confirm-title{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.confirm-message{font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin-bottom:1.75rem}.confirm-actions{display:flex;gap:.75rem;justify-content:center}.confirm-actions .btn{flex:1;padding:.65rem 1.25rem;font-weight:600;font-size:.9rem}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 15px #ef444459}.btn-danger:active{transform:translateY(0)}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-warning:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-1px);box-shadow:0 4px 15px #f59e0b59}@media(max-width:480px){.confirm-dialog{padding:1.5rem}.confirm-actions{flex-direction:column-reverse}}.page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.page-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.page-filters{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1.25rem}.page-filters .input-field{max-width:250px;font-size:.85rem}.page-filters select.input-field{max-width:200px}.page-filters .pagos-filter-select{min-width:220px;max-width:280px;height:46px}.condo-grid{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.condo-card{padding:1.5rem;cursor:pointer}.condo-card:hover{border-color:var(--primary-500);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.condo-card-selected{border-color:var(--primary-500);box-shadow:var(--shadow-glow)}.condo-card-expanded{grid-column:1 / -1}.condo-name{font-size:1.3rem;font-weight:800;margin-bottom:.25rem;color:var(--text-primary)}.condo-location{font-size:.8rem;color:var(--text-muted);margin-bottom:1rem}.condo-stats{display:flex;gap:1.25rem;flex-wrap:wrap}.condo-stat{display:flex;flex-direction:column}.condo-stat-value{font-size:1.1rem;font-weight:700;color:var(--primary-400)}.condo-stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase}.condo-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.data-table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-card);box-shadow:var(--shadow-sm)}.data-table{width:100%;border-collapse:collapse}.data-table-compact{table-layout:fixed}.data-table th{padding:.6rem .5rem;text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--text-secondary);background:var(--gray-50);border-bottom:1px solid var(--border-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.data-table td{padding:.5rem;font-size:.8rem;border-bottom:1px solid var(--border-color);white-space:normal;word-break:break-word;overflow:hidden;text-overflow:ellipsis}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--gray-50)}.td-actions{display:flex;gap:.2rem;flex-wrap:nowrap}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:.75rem;opacity:.3}.empty-state h3{font-size:1.1rem;color:var(--text-secondary);margin-bottom:.3rem}.empty-state p{font-size:.85rem}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start}.page-filters .input-field,.page-filters select.input-field{max-width:100%;flex:1}.page-filters .pagos-filter-select{min-width:0}.condo-grid{grid-template-columns:1fr}.data-table th{padding:.4rem .35rem;font-size:.65rem}.data-table td{padding:.4rem .35rem;font-size:.75rem}}.rp-page{padding:1.5rem;max-width:1100px}.rp-loading{padding:2rem;text-align:center;color:var(--text-secondary)}.rp-header{margin-bottom:1.5rem}.rp-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.rp-subtitle{color:var(--text-secondary);font-size:.9rem}.rp-tabs{display:flex;gap:.25rem;border-bottom:2px solid var(--border-color);margin-bottom:1.5rem}.rp-tab{padding:.6rem 1.2rem;border:none;background:none;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.rp-tab.active{color:var(--primary-600);border-bottom-color:var(--primary-600)}.rp-tab:hover:not(.active){color:var(--text-primary)}.rp-content{animation:fadeIn .2s ease}.rp-actions{margin-bottom:1.25rem;display:flex;justify-content:flex-end}.rp-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary);background:var(--bg-card);border-radius:var(--radius-lg);border:1px dashed var(--border-color)}.rp-empty p{margin:.25rem 0}.rp-roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.rp-rol-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:var(--shadow-sm)}.rp-rol-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.rp-rol-header h3{font-size:1rem;font-weight:600;margin:0;color:var(--text-primary)}.rp-badge{background:var(--primary-50);color:var(--primary-700);padding:.2rem .5rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:500;white-space:nowrap}.rp-rol-desc{font-size:.85rem;color:var(--text-secondary);margin:0}.rp-permisos-list{display:flex;flex-wrap:wrap;gap:.35rem}.rp-permiso-chip{background:var(--bg-secondary);color:var(--text-secondary);padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.75rem}.rp-rol-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:auto;padding-top:.5rem;border-top:1px solid var(--border-color)}.rp-staff-table{overflow-x:auto;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.rp-staff-table table{width:100%;border-collapse:collapse;font-size:.9rem}.rp-staff-table th{text-align:left;padding:.6rem .75rem;background:var(--bg-secondary);color:var(--text-secondary);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.rp-staff-table td{padding:.6rem .75rem;border-bottom:1px solid var(--border-color);vertical-align:middle}.rp-roles-chips{display:flex;flex-wrap:wrap;gap:.35rem}.rp-rol-chip{background:var(--primary-50);color:var(--primary-700);padding:.2rem .4rem .2rem .6rem;border-radius:var(--radius-full);font-size:.78rem;font-weight:500;display:flex;align-items:center;gap:.2rem}.rp-chip-remove{background:none;border:none;color:var(--primary-600);cursor:pointer;font-size:1rem;line-height:1;padding:0;opacity:.7}.rp-chip-remove:hover{opacity:1}.btn-primary{background:var(--primary-600);color:#fff;border:none;border-radius:var(--radius-md);padding:.5rem 1rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-primary:hover{opacity:.9}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.5rem 1rem;font-size:.875rem;font-weight:500;cursor:pointer}.btn-secondary:hover{background:var(--border-color)}.btn-outline-sm{background:none;border:1px solid var(--primary-500);color:var(--primary-600);border-radius:var(--radius-sm);padding:.3rem .6rem;font-size:.78rem;cursor:pointer;white-space:nowrap}.btn-outline-sm:hover{background:var(--primary-50)}.btn-outline-xs{background:none;border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-sm);padding:.2rem .5rem;font-size:.75rem;cursor:pointer;margin-right:.25rem;margin-bottom:.25rem;white-space:nowrap}.btn-outline-xs:hover{border-color:var(--primary-500);color:var(--primary-600)}.btn-danger-sm{background:none;border:1px solid var(--danger-500);color:var(--danger-500);border-radius:var(--radius-sm);padding:.3rem .6rem;font-size:.78rem;cursor:pointer}.btn-danger-sm:hover{background:var(--danger-50)}.rp-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.rp-modal{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003}.rp-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.rp-modal-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.rp-modal-close{background:none;border:none;font-size:1.4rem;color:var(--text-secondary);cursor:pointer;line-height:1;padding:.25rem;border-radius:var(--radius-sm)}.rp-modal-close:hover{color:var(--text-primary);background:var(--bg-secondary)}.rp-modal-body{padding:1.25rem 1.5rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1rem}.rp-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color);flex-shrink:0}.rp-section-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 .5rem}.rp-plantillas-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.rp-plantilla-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.7rem .85rem;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:.15rem;transition:border-color .15s,background .15s}.rp-plantilla-btn:hover{border-color:var(--primary-400);background:var(--primary-50)}.rp-plantilla-btn strong{font-size:.85rem;color:var(--text-primary);font-weight:600}.rp-plantilla-btn span{font-size:.75rem;color:var(--text-secondary)}.rp-form-group{display:flex;flex-direction:column;gap:.35rem}.rp-form-group label{font-size:.85rem;font-weight:600;color:var(--text-primary)}.rp-form-group input{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.5rem .75rem;font-size:.9rem;background:var(--bg-input);color:var(--text-primary);transition:border-color .15s;width:100%}.rp-form-group input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #14b8a61a}.rp-permisos-section{display:flex;flex-direction:column;gap:.75rem}.rp-grupo{background:var(--bg-secondary);border-radius:var(--radius-md);padding:.75rem}.rp-grupo-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--primary-600);margin:0 0 .5rem}.rp-checkboxes{display:flex;flex-direction:column;gap:.35rem}.rp-checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-primary);cursor:pointer;padding:.1rem 0}.rp-checkbox-label input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary-600);cursor:pointer;flex-shrink:0}.rp-error{color:var(--danger-500);font-size:.85rem;margin:0;padding:.5rem .75rem;background:var(--danger-50);border-radius:var(--radius-sm);border-left:3px solid var(--danger-500)}.rp-usuarios-list{display:flex;flex-direction:column;gap:.5rem}.rp-usuario-item{display:flex;align-items:center;justify-content:space-between;padding:.7rem .9rem;background:var(--bg-secondary);border-radius:var(--radius-md);gap:.75rem;border:1px solid var(--border-color)}.rp-usuario-info{display:flex;flex-direction:column}.rp-usuario-info strong{font-size:.9rem;color:var(--text-primary)}.rp-usuario-info span{font-size:.8rem;color:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.rp-plantillas-grid,.rp-roles-grid{grid-template-columns:1fr}}:root{--primary-50: #f0fdfa;--primary-100: #ccfbf1;--primary-200: #99f6e4;--primary-300: #5eead4;--primary-400: #2dd4bf;--primary-500: #14b8a6;--primary-600: #0d9488;--primary-700: #0f766e;--primary-800: #115e59;--primary-900: #134e4a;--accent-400: #60a5fa;--accent-500: #3b82f6;--accent-600: #2563eb;--success-50: #f0fdf4;--success-400: #4ade80;--success-500: #22c55e;--success-600: #16a34a;--success-700: #15803d;--warning-50: #fffbeb;--warning-400: #fbbf24;--warning-500: #f59e0b;--warning-600: #d97706;--warning-700: #b45309;--danger-50: #fef2f2;--danger-400: #f87171;--danger-500: #ef4444;--danger-600: #dc2626;--danger-700: #b91c1c;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--gray-950: #020617;--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-card: #ffffff;--bg-card-hover: #f8fafc;--bg-input: #ffffff;--bg-sidebar: #ffffff;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--text-inverse: #ffffff;--border-color: #e2e8f0;--border-light: #f1f5f9;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .05), 0 4px 6px -4px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .05), 0 8px 10px -6px rgba(0, 0, 0, .05);--shadow-glow: 0 0 15px rgba(20, 184, 166, .15);--sidebar-width: 260px;--sidebar-collapsed: 72px;--navbar-height: 64px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--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);--font-sans: "Inter", "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:var(--primary-400);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-300)}button{cursor:pointer;font-family:inherit;border:none;outline:none}input,select,textarea{font-family:inherit;font-size:inherit}img{max-width:100%;height:auto}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--gray-600);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.container{width:100%;max-width:1400px;margin:0 auto;padding:0 1.5rem}.glass{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.glass-strong{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-md)}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full)}.badge-success{background:var(--success-50);color:var(--success-700);border:1px solid rgba(22,163,74,.2)}.badge-warning{background:var(--warning-50);color:var(--warning-700);border:1px solid rgba(217,119,6,.2)}.badge-danger{background:var(--danger-50);color:var(--danger-700);border:1px solid rgba(220,38,38,.2)}.badge-info{background:var(--primary-50);color:var(--primary-700);border:1px solid rgba(13,148,136,.2)}.badge-neutral{background:var(--gray-50);color:var(--gray-700);border:1px solid var(--border-color)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.875rem;font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:var(--primary-600);color:#fff;box-shadow:0 2px 4px #0d948826}.btn-primary:hover{background:var(--primary-700);box-shadow:0 4px 6px #0d948833;transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--primary-500)}.btn-danger{background:linear-gradient(135deg,var(--danger-500),var(--danger-600));color:#fff;box-shadow:0 4px 12px #dc26264d}.btn-danger:hover{background:linear-gradient(135deg,var(--danger-400),var(--danger-500));transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--gray-100);color:var(--text-primary)}.btn-sm{padding:.4rem .8rem;font-size:.8rem}.btn-lg{padding:.8rem 1.6rem;font-size:1rem}.btn-icon{padding:.5rem;width:36px;height:36px}.input-group{display:flex;flex-direction:column;gap:.4rem}.input-group label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.input-field{width:100%;padding:.65rem .9rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;transition:all var(--transition-fast)}.input-field:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #14b8a626;background:#fff}.input-field::placeholder{color:var(--text-muted)}.custom-checkbox{display:inline-flex;align-items:center;cursor:pointer;font-size:.85rem;position:relative;-webkit-user-select:none;user-select:none;gap:.5rem}.custom-checkbox input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.custom-checkbox .checkmark{height:18px;width:18px;background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;transition:all .2s ease;display:flex;justify-content:center;align-items:center;flex-shrink:0}.custom-checkbox:hover input~.checkmark{border-color:var(--primary-400)}.custom-checkbox input:checked~.checkmark{background-color:var(--primary-500);border-color:var(--primary-500)}.custom-checkbox .checkmark:after{content:"";display:none;width:4px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg);margin-bottom:2px}.custom-checkbox input:checked~.checkmark:after{display:block}.custom-toggle{display:inline-flex;align-items:center;cursor:pointer;gap:.5rem;font-size:.85rem;-webkit-user-select:none;user-select:none}.custom-toggle input{opacity:0;width:0;height:0;position:absolute}.custom-toggle .slider{position:relative;display:inline-block;width:36px;height:20px;background-color:var(--gray-300);border-radius:20px;transition:.3s;flex-shrink:0}.custom-toggle .slider:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:#fff;border-radius:50%;transition:.3s;box-shadow:0 2px 4px #0003}.custom-toggle input:checked+.slider{background-color:var(--primary-500)}.custom-toggle input:focus+.slider{box-shadow:0 0 1px var(--primary-500)}.custom-toggle input:checked+.slider:before{transform:translate(16px)}select.input-field{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.25rem;padding-right:2.5rem}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.card:hover{border-color:var(--primary-300);box-shadow:var(--shadow-md)}.grid-auto{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-slide-in{animation:slideInLeft var(--transition-base) ease-out}@media(max-width:768px){html{font-size:14px}.container{padding:0 1rem}.grid-auto{grid-template-columns:1fr}}
