@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;color:#1e293b;min-height:100vh}#root{min-height:100vh}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.card{transition:all .2s ease}.card:hover{transform:translateY(-2px);box-shadow:0 12px 24px -10px #0000001a}button{font-family:Inter,sans-serif;cursor:pointer;transition:all .2s ease}input,select,textarea{font-family:Inter,sans-serif}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.landing-footer{background:#fff;border-top:1px solid #e2e8f0;padding:40px 20px;margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;text-align:center}.footer-top{display:flex;flex-direction:column;align-items:center;gap:20px;margin-bottom:24px}@media(min-width:640px){.footer-top{flex-direction:row;justify-content:space-between}}.logo-container-small{display:flex;align-items:center;gap:8px}.moose-emoji-small{font-size:24px}.brand-name-small{font-size:18px;font-weight:700;color:#1e293b}.footer-links{display:flex;gap:24px}.footer-link{color:#64748b;text-decoration:none;font-size:14px;transition:color .2s}.footer-link:hover{color:#2563eb}.copyright{color:#94a3b8;font-size:14px;margin-bottom:8px}.us-notice{color:#64748b;font-size:13px;font-weight:500;background:#f8fafc;display:inline-block;padding:6px 12px;border-radius:99px;border:1px solid #e2e8f0}.landing-page{min-height:100vh;background:linear-gradient(to bottom,#f8fafc,#fff)}.hero-section{min-height:auto;display:flex;align-items:center;justify-content:center;padding:60px 20px;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden}.hero-section:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg width="60" height="60" xmlns="http://www.w3.org/2000/svg"><circle cx="30" cy="30" r="2" fill="rgba(255,255,255,0.1)"/></svg>');opacity:.3}.hero-content{max-width:800px;text-align:center;position:relative;z-index:1}.logo-container{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px}.moose-emoji{font-size:56px;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.brand-name{font-size:48px;font-weight:800;color:#fff;margin:0;text-shadow:0 4px 20px rgba(0,0,0,.2)}.tagline{font-size:22px;font-weight:600;color:#fff;margin:0 0 12px;text-shadow:0 2px 10px rgba(0,0,0,.2)}.subtitle{font-size:16px;color:#fffffff2;line-height:1.5;max-width:550px;margin:0 auto 28px}.cta-buttons{display:flex;gap:12px;justify-content:center;margin-bottom:20px;flex-wrap:wrap}.btn-primary{padding:14px 32px;background:#fff;color:#667eea;border:none;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 6px 18px #0000001f}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px #0003}.btn-secondary{padding:14px 32px;background:transparent;color:#fff;border:2px solid white;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s}.btn-secondary:hover{background:#fff;color:#667eea;transform:translateY(-2px)}.tenant-notice{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:#fff;color:#667eea;border:none;border-radius:12px;font-size:14px;font-style:italic;box-shadow:0 4px 12px #0000001a;margin:0}.features-section{max-width:1200px;margin:0 auto;padding:50px 32px;text-align:center}.features-section h2{font-size:28px;font-weight:700;color:#1e293b;margin-bottom:32px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.feature-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 3px 12px #0000000f;transition:all .3s;text-align:center}.feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px #0000001f}.feature-icon{width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.feature-icon svg{width:28px;height:28px}.feature-card h3{font-size:18px;font-weight:700;color:#1e293b;margin-bottom:8px}.feature-card p{font-size:14px;color:#64748b;line-height:1.5}.property-types-section{background:linear-gradient(135deg,#f0f4ff,#e0e7ff);padding:40px 32px;text-align:center}.property-types-section h2{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:24px}.property-types{display:flex;justify-content:center;gap:32px;flex-wrap:wrap}.property-type{display:flex;flex-direction:column;align-items:center;gap:8px}.property-emoji{font-size:40px;filter:drop-shadow(0 3px 6px rgba(0,0,0,.1))}.property-type span:last-child{font-size:14px;font-weight:600;color:#475569}.cta-section{max-width:800px;margin:0 auto;padding:50px 32px;text-align:center}.cta-section h2{font-size:28px;font-weight:700;color:#1e293b;margin-bottom:12px}.cta-section p{font-size:16px;color:#64748b;margin-bottom:24px}.btn-primary-large{padding:16px 40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 6px 20px #667eea4d}.btn-primary-large:hover{transform:translateY(-2px);box-shadow:0 12px 32px #667eea66}.landing-footer{background:#1e293b;padding:32px;text-align:center}.footer-content{max-width:800px;margin:0 auto}.logo-container-small{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px}.moose-emoji-small{font-size:32px}.brand-name-small{font-size:24px;font-weight:700;color:#fff}.landing-footer p{color:#94a3b8;font-size:14px}@media(max-width:768px){.brand-name{font-size:48px}.moose-emoji{font-size:56px}.tagline{font-size:22px}.subtitle{font-size:16px}.features-section h2,.cta-section h2{font-size:28px}.cta-buttons{flex-direction:column;align-items:stretch}.btn-primary,.btn-secondary{width:100%}}.pricing-section{padding:80px 20px;background:#f8fafc;text-align:center}.pricing-section h2{font-size:32px;color:#1e293b;margin-bottom:12px}.pricing-subtitle{color:#64748b;margin-bottom:60px;font-size:18px}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px;max-width:1200px;margin:0 auto}.pricing-card{background:#fff;border-radius:16px;padding:32px;border:1px solid #e2e8f0;display:flex;flex-direction:column;position:relative;transition:transform .2s,box-shadow .2s}.pricing-card:hover{transform:translateY(-5px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.pricing-card.popular{border:2px solid #2563eb;transform:scale(1.05);box-shadow:0 25px 50px -12px #2563eb40}.pricing-card.popular:hover{transform:scale(1.05) translateY(-5px)}.popular-tag{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:#2563eb;color:#fff;padding:4px 12px;border-radius:99px;font-size:12px;font-weight:600;text-transform:uppercase}.pricing-header{margin-bottom:32px}.pricing-header h3{font-size:20px;color:#1e293b;margin-bottom:16px}.price{font-size:48px;font-weight:800;color:#0f172a;display:flex;align-items:baseline;justify-content:center;gap:4px}.price span{font-size:16px;color:#64748b;font-weight:500}.pricing-features{list-style:none;padding:0;margin:0 0 32px;text-align:left;flex:1}.pricing-features li{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:#475569;font-size:15px}.check-icon{color:#16a34a;flex-shrink:0}.btn-outline{width:100%;padding:12px;border:1px solid #cbd5e1;background:#fff;color:#475569;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s}.btn-outline:hover{border-color:#94a3b8;background:#f8fafc;color:#1e293b}.btn-primary-filled{width:100%;padding:12px;background:#2563eb;color:#fff;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:background .2s}.btn-primary-filled:hover{background:#1d4ed8}@media(max-width:768px){.pricing-card.popular{transform:none}.pricing-card.popular:hover{transform:translateY(-5px)}}.login-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:40px 20px;position:relative}.login-container:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg width="60" height="60" xmlns="http://www.w3.org/2000/svg"><circle cx="30" cy="30" r="2" fill="rgba(255,255,255,0.1)"/></svg>');opacity:.3}.back-to-home-login{position:absolute;top:24px;left:24px;display:flex;align-items:center;gap:8px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10}.back-to-home-login:hover{background:#ffffff4d;transform:translate(-4px)}.login-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:440px;padding:48px;animation:slideUp .4s ease;position:relative;z-index:1}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:40px}.logo-container{display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px}.moose-emoji-login{font-size:64px;animation:bounce 2s ease-in-out infinite}.login-header h1{font-size:32px;font-weight:800;color:#667eea;margin-bottom:8px}.login-header p{font-size:15px;color:#64748b}.register-link{text-align:center;margin-top:24px;font-size:14px;color:#64748b}.link-button-login{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;text-decoration:underline;padding:0}.link-button-login:hover{color:#764ba2}.login-form{display:flex;flex-direction:column;gap:24px}.form-group label{font-size:14px;font-weight:600;color:#334155}.form-group input{padding:14px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;transition:all .2s;background:#f8fafc}.form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.form-group input::placeholder{color:#94a3b8}.error-message{padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px}.login-button{padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #667eea66;margin-top:8px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;padding:16px;background:#f0f4ff;border:1px solid #bfdbfe;border-radius:10px;text-align:center}.login-footer p{font-size:13px;color:#1e40af;margin:0;line-height:1.5}.registration-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:40px 20px;position:relative}.registration-page:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg width="60" height="60" xmlns="http://www.w3.org/2000/svg"><circle cx="30" cy="30" r="2" fill="rgba(255,255,255,0.1)"/></svg>');opacity:.3}.registration-page .registration-container{max-width:500px;width:100%;position:relative;z-index:1}.registration-page .back-to-home{display:flex;align-items:center;gap:8px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;margin-bottom:24px;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.registration-page .back-to-home:hover{background:#ffffff4d;transform:translate(-4px)}.registration-page .registration-card{background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d}.registration-page .registration-header{text-align:center;margin-bottom:32px}.registration-page .logo-section{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px}.registration-page .logo-section .moose-emoji{font-size:48px}.registration-page .logo-section h1{font-size:32px;font-weight:800;color:#667eea;margin:0}.registration-page .registration-header h2{font-size:24px;font-weight:700;color:#1e293b;margin:0 0 8px}.registration-page .registration-header p{font-size:15px;color:#64748b;margin:0}.registration-page .registration-form{display:flex;flex-direction:column;gap:20px}.registration-page .form-group{display:flex;flex-direction:column;gap:8px}.registration-page .form-group label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#475569}.registration-page .form-group input{padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;transition:all .2s;outline:none}.registration-page .form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.registration-page .form-group input.error{border-color:#ef4444}.registration-page .error-message{font-size:13px;color:#ef4444;margin-top:-4px}.registration-page .register-button{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s;margin-top:8px}.registration-page .register-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.registration-page .register-button:disabled{opacity:.6;cursor:not-allowed}.registration-page .login-link{text-align:center;margin-top:24px;font-size:14px;color:#64748b}.registration-page .link-button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;text-decoration:underline;padding:0}.registration-page .link-button:hover{color:#764ba2}.registration-page .tenant-notice{margin-top:24px;padding:16px;background:#f0f4ff;border:1px solid #bfdbfe;border-radius:10px;text-align:center}.registration-page .tenant-notice p{margin:0;font-size:13px;color:#1e40af;line-height:1.5}.registration-page .tenant-notice strong{display:block;margin-bottom:4px}@media(max-width:640px){.registration-page .registration-card{padding:32px 24px}.registration-page .logo-section .moose-emoji{font-size:40px}.registration-page .logo-section h1{font-size:28px}.registration-page .registration-header h2{font-size:20px}}.accept-invitation-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:40px 20px;position:relative}.accept-invitation-page:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg width="60" height="60" xmlns="http://www.w3.org/2000/svg"><circle cx="30" cy="30" r="2" fill="rgba(255,255,255,0.1)"/></svg>');opacity:.3}.accept-invitation-container{max-width:550px;width:100%;position:relative;z-index:1}.accept-invitation-card{background:#fff;border-radius:20px;padding:48px 40px;box-shadow:0 20px 60px #0000004d}.invitation-header{text-align:center;margin-bottom:32px}.moose-emoji{font-size:56px;display:block;margin-bottom:12px}.invitation-header h1{font-size:32px;font-weight:800;color:#667eea;margin-bottom:8px}.invitation-header h2{font-size:18px;font-weight:600;color:#475569}.invitation-info{background:linear-gradient(135deg,#f0f4ff,#e0e7ff);border-radius:12px;padding:24px;text-align:center;margin-bottom:32px}.invitation-info h3{font-size:20px;font-weight:700;color:#1e293b;margin-bottom:8px}.invitation-info p{font-size:15px;color:#475569;line-height:1.6}.invitation-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#475569}.form-group input{padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;transition:all .2s;outline:none}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f8fafc;cursor:not-allowed;color:#94a3b8}.form-group small{font-size:13px;color:#64748b;margin-top:-4px}.error-message{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px}.accept-button{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s;margin-top:8px}.accept-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.accept-button:disabled{opacity:.6;cursor:not-allowed}.invitation-footer{margin-top:24px;padding:16px;background:#f8fafc;border-radius:10px;text-align:center}.invitation-footer p{font-size:13px;color:#64748b;line-height:1.6;margin:0}.error-state{text-align:center;padding:40px 24px}.error-state h2{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:8px}.error-state p{font-size:15px;color:#64748b}@media(max-width:640px){.accept-invitation-card{padding:32px 24px}.invitation-header h1{font-size:28px}.moose-emoji{font-size:48px}}.property-card{background:#fff;border-radius:12px;padding:24px;cursor:pointer;border:1px solid #e2e8f0;transition:all .2s ease}.property-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.property-header{display:flex;align-items:start;gap:16px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #f1f5f9}.property-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.property-info{flex:1;min-width:0}.property-info h3{font-size:18px;font-weight:600;color:#1e293b;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.property-info p{font-size:13px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.property-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.property-stat{display:flex;align-items:center;gap:12px}.stat-icon-small{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center}.stat-icon-small.income{background:#d1fae5;color:#059669}.stat-icon-small.expense{background:#fee2e2;color:#dc2626}.stat-label-small{font-size:12px;color:#64748b;margin-bottom:2px}.stat-value-small{font-size:16px;font-weight:600;color:#1e293b}.property-footer{padding-top:16px;border-top:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.net-income{display:flex;align-items:center;gap:8px;font-size:14px}.net-income span:first-child{color:#64748b;font-weight:500}.net-value{font-weight:700}.net-value.positive{color:#059669}.net-value.negative{color:#dc2626}.expense-count{display:flex;align-items:center;gap:6px;font-size:13px;color:#64748b}.property-header-new{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #f1f5f9}.property-info-new{flex:1;min-width:0}.property-info-new h3{font-size:18px;font-weight:600;color:#1e293b;margin:0;white-space:normal;overflow:visible}.property-info-new p{font-size:14px;color:#64748b;margin:0;white-space:normal;overflow:visible}.property-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.property-stat-card{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border-radius:8px;border-left:3px solid #10b981;transition:all .2s ease}.property-stat-card:hover{background:#f1f5f9;transform:translate(2px)}.stat-value-large{font-size:18px;font-weight:700;color:#1e293b;margin:0}.property-footer-new{padding-top:16px;margin-top:12px;border-top:2px solid #f1f5f9}.net-income-new{display:flex;justify-content:space-between;align-items:center}.net-value-large{font-size:20px;font-weight:700}.net-value-large.positive{color:#059669}.net-value-large.negative{color:#dc2626}.property-title-row{display:flex;align-items:center;gap:8px}.property-title-row h3{font-size:18px;margin-bottom:4px}.status-badge.vacant{font-size:11px;font-weight:600;padding:3px 8px;border-radius:4px;background:#fef3c7;color:#92400e;border:1px solid #fde68a}.property-address{font-size:14px;color:#64748b}.border-db-blue{border-left:3px solid #3b82f6}.border-purple{border-left:3px solid #8b5cf6}.bg-purple{background:#f3e8ff;color:#7c3aed}.border-blue{border-left:3px solid #0ea5e9}.bg-blue{background:#e0f2fe;color:#0284c7}.net-label{font-size:14px;color:#64748b}.modal-overlay{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:24px;width:95%;max-width:1200px;height:90vh;max-height:900px;overflow-y:scroll;scrollbar-width:none;-ms-overflow-style:none;box-shadow:0 50px 100px -20px #00000040;animation:slideUp .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column}.modal-content::-webkit-scrollbar{display:none}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:32px 40px;border-bottom:1px solid #f1f5f9;background:#fff;position:sticky;top:0;z-index:20}.modal-header h2{font-size:20px;font-weight:700;color:#0f172a;letter-spacing:-.025em}.close-button{background:#f8fafc;border:1px solid #e2e8f0;color:#64748b;padding:8px;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#f1f5f9;color:#0f172a;border-color:#cbd5e1}.modal-form{padding:40px;flex:1}.form-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #f1f5f9}.form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.section-title{font-size:16px;font-weight:600;color:#0f172a;margin-bottom:16px;display:flex;align-items:center;gap:10px}.section-title svg{color:#3b82f6}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:14px;font-weight:500;color:#475569;margin-bottom:8px}.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;color:#0f172a;background:#fff;transition:all .2s;font-family:inherit}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:#94a3b8}.switch-group{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f8fafc;border-radius:12px;border:1px solid #f1f5f9;cursor:pointer;margin-bottom:12px;transition:all .2s}.switch-group:hover{border-color:#e2e8f0;background:#f1f5f9}.switch-label{display:flex;flex-direction:column;gap:2px}.switch-title{font-size:14px;font-weight:500;color:#0f172a}.switch-description{font-size:12px;color:#64748b}.switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.3s;border-radius:24px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:2px;bottom:2px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0000001a}input:checked+.slider{background-color:#3b82f6}input:checked+.slider:before{transform:translate(20px)}.chips-container{display:flex;gap:8px;flex-wrap:wrap}.choice-chip{cursor:pointer;padding:8px 16px;border-radius:20px;border:1px solid #e2e8f0;background:#fff;font-size:13px;font-weight:500;color:#475569;transition:all .2s;display:flex;align-items:center;gap:6px}.choice-chip:hover{background:#f8fafc;border-color:#cbd5e1}.choice-chip.active{background:#eff6ff;border-color:#3b82f6;color:#2563eb}.modal-actions{display:flex;gap:16px;padding:32px 40px;border-top:1px solid #f1f5f9;background:#fff;position:static;margin-top:auto}.button-primary{flex:1;padding:14px 28px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;font-size:16px;font-weight:600;color:#fff;box-shadow:0 4px 12px #667eea4d;transition:all .2s}.button-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.button-secondary{flex:1;padding:14px 28px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;font-size:16px;font-weight:600;color:#475569;transition:all .2s}.button-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.list-item-card{background:#f8fafc;padding:16px;border-radius:12px;border:1px solid #e2e8f0;margin-bottom:12px;position:relative}.remove-btn{position:absolute;top:12px;right:12px;background:none;border:none;color:#94a3b8;cursor:pointer;padding:4px;border-radius:4px}.remove-btn:hover{background:#fee2e2;color:#ef4444}.form-grid{display:grid;gap:16px}.layout-2{grid-template-columns:1fr 1fr}.layout-3{grid-template-columns:1fr 1fr 1fr}.form-group label{display:block;font-size:13px;font-weight:600;color:#475569;margin-bottom:6px}.form-input{width:100%;padding:10px;border:1px solid #cbd5e1;border-radius:8px;font-size:14px}.form-input.disabled{background:#f1f5f9;cursor:not-allowed}.section-title{font-size:20px;font-weight:700;margin-bottom:24px;color:#0f172a}.add-btn-small{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;border:1px solid #cbd5e1;border-radius:6px;font-size:13px;font-weight:600;color:#475569;cursor:pointer}.notify-btn{padding:10px 20px;border-radius:8px;border:1px solid #fbbf24;background:#fffbeb;color:#d97706;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px}.notify-btn:hover{background:#fef3c7}.save-btn{padding:10px 20px;border-radius:8px;border:none;background:#0f172a;color:#fff;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px}.save-btn:hover{background:#1e293b}.empty-placeholder{padding:40px;text-align:center;color:#94a3b8;border:2px dashed #e2e8f0;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:16px}.primary-btn-small{padding:8px 16px;background:#0f172a;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}.expense-ledger{padding:24px;max-width:1200px;margin:0 auto;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.ledger-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.ledger-title h1{font-size:24px;font-weight:700;color:#1e293b;margin:0}.back-button{display:flex;align-items:center;gap:8px;background:none;border:none;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;padding:8px 0;transition:color .2s}.back-button:hover{color:#334155}.header-actions{display:flex;gap:12px}.action-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;border:none;transition:all .2s}.action-btn.primary{background:#10b981;color:#fff}.action-btn.primary:hover{background:#059669}.action-btn.secondary{background:#fff;color:#334155;border:1px solid #e2e8f0}.action-btn.secondary:hover{background:#f8fafc;border-color:#cbd5e1}.ledger-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.summary-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;display:flex;flex-direction:column}.ledger-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.ledger-table{width:100%;border-collapse:collapse;font-size:14px}.ledger-table th{text-align:left;padding:12px 16px;background:#f8fafc;color:#475569;font-weight:600;font-size:12px;text-transform:uppercase;border-bottom:1px solid #e2e8f0}.ledger-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;color:#334155;vertical-align:middle}.ledger-table tr:last-child td{border-bottom:none}.ledger-table tr:hover{background:#f8fafc}.text-right{text-align:right}.text-center{text-align:center}.font-bold{font-weight:700}.font-medium{font-weight:500}.date-col{white-space:nowrap;color:#64748b;font-feature-settings:"tnum"}.desc-col{max-width:300px}.desc-text{font-weight:500;color:#0f172a;margin-bottom:2px}.invoice-link{display:inline-flex;align-items:center;gap:4px;color:#3b82f6;font-size:12px;text-decoration:none}.invoice-link:hover{text-decoration:underline}.badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:capitalize}.badge.rent{background:#fee2e2;color:#991b1b}.badge.payment{background:#dcfce7;color:#166534}.badge.utilities{background:#e0f2fe;color:#075985}.badge.maintenance{background:#fff7ed;color:#9a3412}.badge.other{background:#f1f5f9;color:#475569}.status-pill{display:inline-block;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:700;text-transform:uppercase}.status-pill.pending{background:#fef3c7;color:#92400e}.status-pill.rejected{background:#fee2e2;color:#991b1b}.bg-green-50{background:#f0fdf4!important}.bg-green-50:hover{background:#dcfce7!important}.text-gray-300{color:#cbd5e1}.line-through{text-decoration:line-through}.actions-cell{white-space:nowrap;width:1%}.icon-btn{background:none;border:none;padding:6px;border-radius:4px;cursor:pointer;color:#64748b;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:#f1f5f9;color:#1e293b}.icon-btn.approve:hover{background:#dcfce7;color:#166534}.icon-btn.reject:hover,.icon-btn.delete:hover{background:#fee2e2;color:#991b1b}.icon-btn:disabled{opacity:.3;cursor:not-allowed}.empty-state,.loading-state{padding:48px;text-align:center;color:#64748b;display:flex;flex-direction:column;align-items:center;gap:16px}.spinner{width:24px;height:24px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:768px){.ledger-header{flex-direction:column;align-items:flex-start;gap:16px}.header-actions{width:100%}.action-btn{flex:1;justify-content:center}.ledger-table th:nth-child(3),.ledger-table td:nth-child(3){display:none}}.tenant-management{min-height:100vh;background:#f8fafc}.tenant-header{background:#fff;padding:24px 32px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;gap:24px}.tenant-title h1{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:4px}.tenant-title p{font-size:14px;color:#64748b}.add-tenant-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.add-tenant-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.tenant-content{max-width:1200px;margin:0 auto;padding:32px}.tenants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.tenant-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #00000014;display:flex;justify-content:space-between;align-items:center;transition:transform .2s,box-shadow .2s}.tenant-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.tenant-info{display:flex;gap:16px;align-items:center;flex:1}.tenant-avatar{width:48px;height:48px;padding:8px;background:#f1f5f9;color:#667eea;border-radius:50%}.tenant-avatar-img{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid #e2e8f0}.tenant-info h3{font-size:16px;font-weight:600;color:#1e293b;margin-bottom:4px}.tenant-email{font-size:13px;color:#64748b;display:flex;align-items:center;gap:6px}.remove-tenant-button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#fee2e2;color:#dc2626;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.remove-tenant-button:hover{background:#fecaca}.empty-state{text-align:center;padding:80px 32px}.empty-state h3{font-size:20px;font-weight:700;color:#1e293b;margin-bottom:8px}.empty-state p{color:#64748b;margin-bottom:24px}.assign-existing-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.assign-existing-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #f59e0b66}.unassigned-tenants-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.unassigned-tenant-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;transition:background .2s}.unassigned-tenant-item:hover{background:#f1f5f9}.tenant-avatar-img-small{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid #e2e8f0}.unassigned-tenant-item h4{font-size:14px;font-weight:600;color:#1e293b;margin-bottom:2px}.bulk-actions-toolbar{position:fixed;bottom:32px;left:50%;transform:translate(-50%);background:#1e293b;padding:12px 24px;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;align-items:center;gap:24px;z-index:1000;min-width:400px;justify-content:space-between}.animate-slide-up{animation:slideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{transform:translate(-50%,20px);opacity:0}to{transform:translate(-50%);opacity:1}}.btn-toolbar{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;font-weight:600;font-size:13px;cursor:pointer;border:none;transition:all .2s}.btn-toolbar-secondary{background:#334155;color:#fff}.btn-toolbar-secondary:hover{background:#475569}.btn-toolbar-primary{background:#22c55e;color:#fff}.btn-toolbar-primary:hover{background:#16a34a}.divider-vertical{width:1px;height:24px;background:#475569}.badge{padding:4px 8px;border-radius:4px;font-size:11px;font-weight:700;line-height:1}.badge-pending{background:#fef3c7;color:#92400e}.badge-ready{background:#ecfdf5;color:#059669;display:flex;align-items:center;gap:4px}.badge-incomplete{background:#f1f5f9;color:#64748b}.tenant-details-wrapper{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.4,0,.2,1);border-top:1px solid transparent}.tenant-details-wrapper.expanded{max-height:2000px;border-top-color:#e2e8f0;margin-top:16px;padding-top:16px}.tenant-details-content{opacity:0;transform:translateY(10px);transition:opacity .4s ease .1s,transform .4s ease .1s}.tenant-details-wrapper.expanded .tenant-details-content{opacity:1;transform:translateY(0)}.detail-section{padding-bottom:16px;margin-bottom:16px;border-bottom:1px dashed #e2e8f0}.detail-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.detail-header{font-size:12px;font-weight:700;color:#94a3b8;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item label{font-size:11px;font-weight:600;color:#64748b}.detail-item div{font-size:14px;color:#334155;font-weight:500}.occupants-list{background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;overflow:hidden}.occupant-row{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px dashed #e2e8f0;transition:background .2s}.occupant-row:last-child{border-bottom:none}.occupant-row:hover{background:#fff}.relation-tag{background:#e0f2fe;color:#0369a1;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;margin-left:6px}.card-expanded{transform:scale(1.02);box-shadow:0 12px 24px -6px #00000026;border-color:#3b82f6!important;z-index:10;position:relative}.card-expanded:hover{transform:scale(1.02)}.tenant-detail-modal{max-width:600px;width:90%;max-height:90vh;overflow-y:auto;padding:0;border-radius:16px;animation:modalPop .3s cubic-bezier(.34,1.56,.64,1)}.tenant-detail-modal .modal-header{padding:24px 24px 16px;background:#fff;position:sticky;top:0;z-index:10}.tenant-detail-modal .modal-body{padding:0 24px 24px}@keyframes modalPop{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.tenant-details-wrapper{display:none}.rent-management{min-height:100vh;background:#f8fafc;font-family:Inter,system-ui,-apple-system,sans-serif}.rent-header{background:#fff;padding:24px 32px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;gap:24px;box-shadow:0 1px 2px #0000000d}.rent-title h1{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:4px;letter-spacing:-.5px}.rent-title p{font-size:14px;color:#64748b}.settings-button{padding:10px 16px;background:#fff;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;box-shadow:0 1px 2px #0000000d}.settings-button:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.rent-content{max-width:1200px;margin:0 auto;padding:40px 32px}.rent-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.summary-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;display:flex;flex-direction:column;box-shadow:none}.summary-card:hover{transform:none;box-shadow:none}.balance-card{border:1px solid #cbd5e1;box-shadow:0 4px 6px -1px #0000000d}.card-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#64748b;font-weight:600;margin-bottom:4px}.card-value{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:2px}.card-sub{font-size:12px;color:#94a3b8}.text-green{color:#059669}.text-red{color:#dc2626}.rent-actions{display:flex;justify-content:flex-start;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}.generate-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fff;color:#334155;border:1px solid #e2e8f0;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;box-shadow:none}.generate-button:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b;transform:none;box-shadow:none}.rent-charges-section{background:#fff;border-radius:12px;padding:0;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0;overflow:hidden}.rent-charges-section h3{display:none}.rent-table-container{overflow-x:auto;border-radius:0;border:none}.rent-table{width:100%;border-collapse:collapse;font-size:14px;min-width:800px}.rent-table th{text-align:left;padding:12px 16px;background:#f8fafc;color:#475569;font-weight:600;font-size:12px;text-transform:uppercase;border-bottom:1px solid #e2e8f0;letter-spacing:normal}.rent-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;color:#334155;vertical-align:middle}.rent-table tr:last-child td{border-bottom:none}.rent-table tr:hover td{background:#f8fafc}.rent-table td.amount{font-weight:700;font-size:14px;font-family:inherit;color:#1e293b}.rent-table .status-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:700;text-transform:uppercase}.status-badge.paid{background:#dcfce7;color:#166534}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.overdue{background:#fee2e2;color:#991b1b}.rent-table .actions{display:flex;gap:10px}.action-button{width:36px;height:36px;border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.paid-button{background:#dcfce7;color:#16a34a}.paid-button:hover{background:#16a34a;color:#fff}.edit-button{background:#f1f5f9;color:#64748b}.edit-button:hover{background:#e2e8f0;color:#334155}.delete-button{background:#fef2f2;color:#ef4444}.delete-button:hover{background:#ef4444;color:#fff}.empty-state{text-align:center;padding:80px 40px;background:#f9fafb;border-radius:12px;border:2px dashed #e2e8f0}.empty-state .empty-icon{color:#cbd5e1;margin-bottom:16px;width:64px;height:64px}.empty-state h4{font-size:20px;font-weight:700;color:#1e293b;margin-bottom:8px}.empty-state p{color:#64748b;max-width:400px;margin:0 auto}.dashboard{min-height:100vh;background:#f8fafc;font-family:Inter,system-ui,-apple-system,sans-serif}.dashboard-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:24px 0;position:sticky;top:0;z-index:100;box-shadow:0 1px 2px #0000000d}.header-content{max-width:1400px;margin:0 auto;padding:0 32px;display:flex;justify-items:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:16px;flex:1}.header-icon{color:#667eea}.header-left h1{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:4px}.header-left p{font-size:14px;color:#64748b}.admin-link-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;transition:all .2s}.admin-link-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.settings-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#667eea;font-size:14px;font-weight:500;transition:all .2s}.settings-button:hover{background:#f0f4ff;border-color:#667eea}.logout-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;color:#475569;font-size:14px;font-weight:500}.logout-button:hover{background:#e2e8f0;border-color:#cbd5e1}.dashboard-content{max-width:1400px;margin:0 auto;padding:32px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:40px}.stat-card{background:#fff;border-radius:16px;padding:24px;display:flex;align-items:center;gap:20px;box-shadow:0 1px 3px #00000014;transition:all .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001a}.stat-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-card.income .stat-icon{background:#d1fae5;color:#059669}.stat-card.expense .stat-icon{background:#fee2e2;color:#dc2626}.stat-card.net.positive .stat-icon{background:#dbeafe;color:#2563eb}.stat-card.net.negative .stat-icon{background:#fed7aa;color:#ea580c}.stat-info{flex:1}.stat-label{font-size:14px;color:#64748b;margin-bottom:4px;font-weight:500}.stat-value{font-size:28px;font-weight:700;color:#1e293b}.properties-section{background:#fff;border-radius:16px;padding:32px;box-shadow:0 1px 3px #00000014}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.section-header h2{font-size:20px;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:12px}.invite-button{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;box-shadow:0 4px 12px #10b9814d;cursor:pointer;transition:all .2s}.invite-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.add-button{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;box-shadow:0 4px 12px #667eea4d;cursor:pointer;transition:all .2s}.add-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.properties-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px}.empty-state{text-align:center;padding:80px 20px}.empty-icon{color:#cbd5e1;margin-bottom:24px}.empty-state h3{font-size:20px;color:#1e293b;margin-bottom:8px}.empty-state p{font-size:15px;color:#64748b;margin-bottom:32px}.add-button-large{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;box-shadow:0 4px 12px #667eea4d}.add-button-large:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{font-size:16px;color:#64748b}.property-view-wrapper{position:relative}.property-actions-bar{position:fixed;bottom:32px;right:32px;display:flex;gap:12px;background:#fff;padding:16px;border-radius:16px;box-shadow:0 8px 24px #0000001f;z-index:1000}.action-bar-button{display:flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.action-bar-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.property-edit-view{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px}.tenant-dashboard{min-height:100vh;background:#f8fafc;font-family:Inter,system-ui,-apple-system,sans-serif}.tenant-content{max-width:1000px;margin:0 auto;padding:40px 24px}.property-info{background:#fff;padding:10px;border-radius:16px;display:flex;flex-wrap:wrap;align-items:center;gap:24px;margin-bottom:40px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #f1f5f9}.property-info h2{font-size:28px;font-weight:800;color:#0f172a;margin-bottom:8px;min-width:200px;letter-spacing:-.5px}.property-address{font-size:16px;color:#64748b;display:flex;align-items:center;gap:8px}.property-dates{margin-left:auto;text-align:right;background:#f8fafc;padding:12px 20px;border-radius:12px;border:1px solid #e2e8f0}.property-dates p{font-size:13px;color:#64748b;margin:4px 0;font-weight:500}.property-dates strong{color:#334155}.tenant-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:32px}.action-card-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);color:#475569;font-weight:600;font-size:14px;box-shadow:0 1px 2px #0000000d}.action-card-btn:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border-color:#cbd5e1}.action-card-btn.purple:hover{color:#7c3aed;background:#f5f3ff;border-color:#ddd6fe}.action-card-btn.green:hover{color:#059669;background:#ecfdf5;border-color:#a7f3d0}.action-card-btn.orange:hover{color:#ea580c;background:#fff7ed;border-color:#fed7aa}.section-title{font-size:20px;font-weight:700;color:#1e293b}.expense-item{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px;background:#fff;border-radius:12px;border:1px solid #e2e8f0;margin-bottom:12px;transition:all .2s}.expense-item:hover{border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000000d}.expense-details{flex:1;min-width:200px}.expense-category{font-weight:600;color:#334155;font-size:15px;margin-bottom:4px;text-transform:capitalize}.expense-subcategory{font-size:13px;color:#64748b;margin-left:8px;font-weight:400;background:#f1f5f9;padding:2px 8px;border-radius:4px}.expense-description{font-size:14px;color:#64748b;margin-top:4px}.expense-meta{text-align:right;min-width:120px}.expense-date{font-size:13px;color:#94a3b8;margin-bottom:4px;font-weight:500}.expense-amount{font-size:18px;font-weight:700;color:#0f172a;font-family:JetBrains Mono,monospace}.status-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;margin-top:4px}.status-badge.pending{background:#fffbeb;color:#b45309}.status-badge.approved{background:#f0fdf4;color:#15803d}.status-badge.rejected{background:#fef2f2;color:#b91c1c}.empty-state{text-align:center;padding:60px;color:#64748b;background:#fff;border-radius:12px;border:2px dashed #e2e8f0}.empty-property{max-width:480px;margin:100px auto;text-align:center;padding:60px;background:#fff;border-radius:20px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.empty-property .empty-icon{color:#cbd5e1;margin-bottom:24px;width:64px;height:64px}.empty-property h3{font-size:24px;font-weight:800;color:#0f172a;margin-bottom:12px;letter-spacing:-.5px}.empty-property p{color:#64748b;font-size:16px;line-height:1.5}.audit-viewer{display:flex;flex-direction:column;height:100%;background:#1e1e1e;color:#e0e0e0;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:13px}.audit-modal-content{width:90vw!important;max-width:1400px!important;height:85vh!important;max-height:900px!important;display:flex;flex-direction:column;padding:0!important}.audit-header-embedded,.modal-header{flex-shrink:0}.audit-modal-header-row{display:flex;align-items:center;gap:12px}.audit-modal-header-row h2{font-size:20px;font-weight:600;color:#1e293b;margin:0}.audit-controls,.audit-controls-modal{padding:12px 24px;display:flex;gap:12px;background:#252526;border-bottom:1px solid #404040;align-items:center;flex-shrink:0}.control-btn{display:flex;align-items:center;gap:8px;background:#3c3c3c;border:1px solid #555;color:#e0e0e0;padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.control-btn:hover{background:#4c4c4c;border-color:#666;color:#fff}.logs-container{flex:1;overflow:auto;padding:0;background:#1e1e1e}.audit-table-simple{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.audit-table-simple th{background:#252526;color:#aaa;font-weight:600;text-align:left;padding:12px 16px;border-bottom:2px solid #404040;position:sticky;top:0;z-index:10;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.audit-table-simple td{padding:10px 16px;border-bottom:1px solid #333;color:#ccc;vertical-align:top}.audit-table-simple tr:hover{background:#2a2d3e}.audit-table-simple tr:last-child td{border-bottom:none}.audit-table-simple td:nth-child(1){color:#888;width:160px;white-space:nowrap}.audit-table-simple td:nth-child(2){color:#67e8f9;width:200px;font-weight:500}.audit-table-simple td:nth-child(3){font-weight:700;width:120px}.audit-table-simple td:nth-child(4){color:#ce9178;width:150px}.audit-table-simple td:nth-child(5){color:#e0f2fe;white-space:pre-wrap;font-family:JetBrains Mono,monospace;max-width:500px;line-height:1.5;font-size:13px}.audit-details-cell{position:relative;max-width:none!important}.status-create{color:#4ade80}.status-update{color:#facc15}.status-delete{color:#f87171}.status-soft_delete{color:#fb923c}.filters-panel{background:#2d2d2d;border-bottom:1px solid #404040;padding:16px 24px}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.filter-group label{display:block;margin-bottom:6px;color:#aaa;font-size:12px;font-weight:500}.filter-input,select{width:100%;padding:8px 12px;background:#1e1e1e;border:1px solid #404040;color:#e0e0e0;border-radius:4px;font-size:13px}.filter-actions{display:flex;justify-content:flex-end;gap:10px}.button-primary{background:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:600}.button-primary:hover{background:#2563eb}.text-button-danger{padding:4px 8px;border-radius:4px;background:#f871711a;transition:all .2s}.text-button-danger:hover{background:#f8717133;text-decoration:none}.admin-dashboard{min-height:100vh;background:#f8fafc;display:flex}.admin-sidebar{width:280px;background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;z-index:50;padding:24px}.sidebar-header{padding-bottom:32px;margin-bottom:24px;border-bottom:1px solid #e2e8f0}.sidebar-header h2{font-size:20px;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:12px}.sidebar-nav{display:flex;flex-direction:column;gap:8px}.sidebar-nav button{width:100%;padding:12px 16px;border:none;background:transparent;color:#64748b;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:12px;text-align:left}.sidebar-nav button:hover{background:#f1f5f9;color:#1e293b}.sidebar-nav button.active{background:#f3e8ff;color:#7c3aed}.admin-content{flex:1;margin-left:280px;padding:40px;max-width:100%}.page-header{margin-bottom:32px}.page-header h1{font-size:28px;font-weight:700;color:#1e293b}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px}.stat-card{background:#fff;padding:24px;border-radius:12px;border:1px solid #e2e8f0;display:flex;align-items:center;gap:20px;transition:all .3s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 12px 24px #0000000a}.stat-icon{width:56px;height:56px;border-radius:12px;background:#f8fafc;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#64748b}.stat-info h3{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:4px}.stat-info p{font-size:14px;color:#64748b;font-weight:500}.content-section{background:#fff;border-radius:16px;border:1px solid #e2e8f0;padding:32px;min-height:400px}.overview-section h2{font-size:20px;font-weight:700;color:#1e293b;margin-bottom:24px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.info-card{background:#f8fafc;padding:24px;border-radius:12px;border:1px solid #e2e8f0}.info-card h3{font-size:16px;font-weight:700;color:#1e293b;margin-bottom:16px;display:flex;align-items:center;gap:8px}.info-card ul{list-style:none;padding:0;margin:0}.info-card li{padding:12px 0;color:#475569;font-size:14px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;gap:8px}.info-card li:last-child{border-bottom:none}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.section-actions{display:flex;gap:12px;align-items:center}.search-box{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:10px 16px;min-width:250px;transition:all .2s}.search-box:focus-within{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.search-box input{border:none;background:transparent;outline:none;font-size:14px;color:#1e293b;width:100%}.add-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#1e293b;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.add-button:hover{background:#334155;transform:translateY(-1px)}.data-table{width:100%;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden}.data-table table{width:100%;border-collapse:collapse}.data-table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.data-table th{text-align:left;padding:16px 24px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.data-table td{padding:16px 24px;font-size:14px;color:#334155;border-bottom:1px solid #f1f5f9}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#f8fafc}.action-buttons{display:flex;gap:6px}.action-btn{width:32px;height:32px;padding:0;border:1px solid #e2e8f0;background:#fff;border-radius:6px;color:#64748b;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.action-btn:hover{background:#f1f5f9;color:#1e293b;border-color:#cbd5e1}.action-btn.delete:hover{background:#fef2f2;color:#ef4444;border-color:#fecaca}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:#fff;border-radius:16px;padding:32px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}@media(max-width:lg){.info-grid{grid-template-columns:1fr}}@media(max-width:768px){.admin-sidebar{width:100%;height:auto;position:relative;border-right:none;border-bottom:1px solid #e2e8f0}.admin-content{margin-left:0;padding:24px}.sidebar-nav{flex-direction:row;overflow-x:auto;padding-bottom:4px}.sidebar-nav button{white-space:nowrap;width:auto}}.tenant-registration-container{max-width:800px;margin:40px auto;background:#fff;border-radius:20px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;border:1px solid #f1f5f9;padding:2.5rem;font-family:Inter,sans-serif}.tenant-registration-container .registration-header{text-align:center;margin-bottom:3rem}.tenant-registration-container .registration-header h1{font-size:1.875rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}.tenant-registration-container .registration-header p{color:#64748b;font-size:.95rem}.tenant-registration-container .stepper{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:3rem}.tenant-registration-container .step{width:32px;height:32px;border-radius:50%;background:#f1f5f9;color:#94a3b8;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;position:relative;z-index:1}.tenant-registration-container .step:after{content:"";position:absolute;right:-1rem;width:1rem;height:2px;background:#f1f5f9;top:50%;transform:translateY(-50%);z-index:-1}.tenant-registration-container .step:last-child:after{display:none}.tenant-registration-container .step.active{background:#ecfdf5;color:#059669}.tenant-registration-container .step.current{background:#0f172a;color:#fff;box-shadow:0 0 0 4px #e2e8f0}.tenant-registration-container .form-section h3{font-size:1.25rem;color:#1e293b;margin-bottom:.25rem}.tenant-registration-container .section-desc{color:#64748b;font-size:.875rem;margin-bottom:1.5rem}.tenant-registration-container .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.tenant-registration-container .grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}.tenant-registration-container input,.tenant-registration-container select{width:100%;padding:.75rem 1rem;border:1px solid #cbd5e1;border-radius:8px;margin-top:.375rem;font-size:.95rem;outline:none;transition:all .2s}.tenant-registration-container input:focus,.tenant-registration-container select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.tenant-registration-container label{display:block;font-size:.875rem;font-weight:500;color:#334155;margin-bottom:.25rem}.tenant-registration-container .item-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1rem;margin-bottom:1rem}.tenant-registration-container .item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.85rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.tenant-registration-container .icon-btn-danger{background:#fee2e2;color:#ef4444;border:none;width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.tenant-registration-container .icon-btn-danger:hover{background:#fecaca}.tenant-registration-container .btn-secondary-dashed{width:100%;border:2px dashed #cbd5e1;background:#fff;padding:1rem;border-radius:12px;color:#64748b;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.tenant-registration-container .btn-secondary-dashed:hover{border-color:#94a3b8;color:#475569;background:#f8fafc}.tenant-registration-container .form-actions{display:flex;justify-content:space-between;margin-top:3rem;padding-top:2rem;border-top:1px solid #f1f5f9}.tenant-registration-container .btn-back{background:#fff;border:1px solid #cbd5e1;color:#64748b;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;display:flex;align-items:center;gap:.5rem;cursor:pointer}.tenant-registration-container .btn-next,.tenant-registration-container .btn-submit{background:#0f172a;color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-weight:600;display:flex;align-items:center;gap:.5rem;cursor:pointer;box-shadow:0 4px 6px -1px #0000001a;transition:all .2s}.tenant-registration-container .btn-submit{background:#059669}.tenant-registration-container .btn-next:hover{background:#1e293b;transform:translateY(-1px)}.tenant-registration-container .btn-submit:hover{background:#047857}.tenant-registration-container .review-card{background:#f8fafc;padding:1rem;border-radius:8px;margin-bottom:1rem}.tenant-registration-container .review-card h4{color:#64748b;font-size:.75rem;text-transform:uppercase;font-weight:700;margin-bottom:.5rem}.tenant-registration-container .review-card p,.tenant-registration-container .review-card li{font-size:.9rem;color:#334155}.tenant-registration-container .checkbox-agreement{display:flex;gap:.75rem;margin-top:1.5rem;align-items:flex-start}.tenant-registration-container .checkbox-agreement input{margin-top:.25rem;width:auto}.tenant-registration-container .animate-fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.tenant-signup{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:32px}.signup-container{background:#fff;border-radius:20px;padding:48px;max-width:500px;width:100%;box-shadow:0 20px 60px #0000004d}.signup-header{text-align:center;margin-bottom:32px}.signup-icon{color:#667eea;margin-bottom:16px}.signup-header h1{font-size:28px;font-weight:700;color:#1e293b;margin-bottom:8px}.signup-header p{font-size:15px;color:#64748b}.error-message{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:14px}.signup-form{display:flex;flex-direction:column;gap:20px}.avatar-upload{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px;background:#f8fafc;border-radius:12px;margin-bottom:8px}.avatar-preview{width:120px;height:120px;border-radius:50%;background:#e2e8f0;display:flex;align-items:center;justify-content:center;overflow:hidden;border:4px solid white;box-shadow:0 4px 12px #0000001a}.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-preview svg{color:#94a3b8}.avatar-upload-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#667eea;color:#fff;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s}.avatar-upload-button:hover{background:#5568d3;transform:translateY(-2px)}.form-field label{display:flex;align-items:center;gap:8px;font-weight:600;color:#334155;margin-bottom:8px;font-size:14px}.form-field input{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:15px;transition:all .2s}.form-field input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-field input:disabled{background:#f1f5f9;cursor:not-allowed}.signup-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px}.signup-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.signup-button:disabled{opacity:.6;cursor:not-allowed}.signup-footer{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid #e2e8f0}.signup-footer p{color:#64748b;font-size:14px}.signup-footer a{color:#667eea;font-weight:600;text-decoration:none}.signup-footer a:hover{text-decoration:underline}
