@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--bg:#f8fafc;--surface:#fff;--border:#e2e8f0;--border-light:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--accent:#6366f1;--accent-hover:#4f46e5;--accent-light:#eef2ff;--accent-glow:#6366f133;--success:#10b981;--success-light:#d1fae5;--warning:#f59e0b;--warning-light:#fef3c7;--danger:#ef4444;--danger-light:#fee2e2;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-xs:0 1px 2px #0f172a0d;--shadow-sm:0 4px 6px -1px #0f172a0d, 0 2px 4px -1px #0f172a05;--shadow-md:0 10px 20px -3px #0f172a0f, 0 4px 6px -2px #0f172a08;--shadow-lg:0 20px 25px -5px #0f172a14, 0 10px 10px -5px #0f172a08;--glass-bg:#ffffffbf;--glass-border:#fff9;--transition:.25s cubic-bezier(.4, 0, .2, 1);--font:"Outfit", system-ui, -apple-system, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font);color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.6}#root{flex-direction:column;max-width:100%;min-height:100vh;margin:0 auto;display:flex}input,select,textarea,button{font-family:var(--font);font-size:15px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 24px 24px}@media (width<=768px){.container{padding:0 16px 16px}}.card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition), background var(--transition);padding:24px}.card:hover{border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);white-space:nowrap;letter-spacing:.02em;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;text-decoration:none;display:inline-flex}.btn:active,.l-btn:active,.admin-nav__item:active,.landlord-nav-bar__btn:active,.nav-btn:active,.tenant-nav-btn:active,.nav-btn--active:active,.tenant-nav-btn--active:active,.search-mode-btn:active,.search-mode-btn--active:active,.nav-item:active,.home-nav:active,.home-nav__btn-login:active,.home-nav__btn-lang:active,.home-nav__btn-register:active,.notfound-btn--primary:active,.notfound-btn--secondary:active,.btn-search-primary:active,.btn-search-secondary:active,.cta-section__btn:active,.hero__btn-primary:active,.hero__btn-secondary:active,.auth-lang-btn:active,.auth-footer__link:active,.landlord-contact-btn:active,.l-room-card__delete-btn:active,.l-modal__close:active,.home-footer__social-btn:active,.home-footer__list-link:active,.header__btn-lang:active,.header__btn-logout:active,.header__profile:active{filter:brightness(.85)saturate(1.25);transition:transform .1s cubic-bezier(.16,1,.3,1),filter .1s;transform:scale(.94)!important}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn--primary{background:linear-gradient(135deg, var(--accent), #818cf8);color:#fff;box-shadow:0 4px 12px var(--accent-glow)}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg, var(--accent-hover), var(--accent));box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-1px)}.btn--outline{border-color:var(--border);color:var(--text-secondary);background-color:#0000}.btn--outline:hover:not(:disabled){background-color:var(--border-light);color:var(--text-primary)}.btn--full{width:100%}.form-group{margin-bottom:20px}.form-label{color:var(--text-secondary);letter-spacing:.02em;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.form-input{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-primary);transition:all var(--transition);outline:none;padding:14px 16px;font-size:15px}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-light);background:var(--surface)}.alert{border-radius:var(--radius-md);align-items:center;gap:10px;padding:14px 18px;font-size:14px;font-weight:500;animation:.3s fadeIn;display:flex}.alert--error{background:var(--danger-light);color:var(--danger);border:1px solid #fecaca}.alert--success{background:var(--success-light);color:var(--success);border:1px solid #bbf7d0}.header{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);z-index:100;transition:all var(--transition);justify-content:space-between;align-items:center;margin-top:16px;margin-bottom:32px;padding:14px 24px;animation:.4s cubic-bezier(.16,1,.3,1) slideDown;display:flex;position:sticky;top:16px}.header:hover{box-shadow:var(--shadow-md);border-color:var(--border)}.header__brand{transition:transform var(--transition);align-items:center;gap:12px;display:flex}.header__brand:hover{transform:scale(1.02)}.header__logo{filter:drop-shadow(0 2px 4px #0000000f);font-size:28px}.header__title{color:var(--text-primary);letter-spacing:-.5px;font-size:20px;font-weight:800}.header__actions{align-items:center;gap:14px;display:flex}.header__profile{background:var(--surface);border:1px solid var(--border-light);box-shadow:var(--shadow-xs);transition:all var(--transition);border-radius:999px;align-items:center;gap:12px;padding:6px 14px 6px 8px;display:flex}.header__profile:hover{border-color:var(--border);box-shadow:var(--shadow-sm)}.header__avatar{background:linear-gradient(135deg, var(--accent), #818cf8);color:#fff;width:32px;height:32px;box-shadow:0 2px 6px var(--accent-glow);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:800;display:flex}.header__user-info{text-align:left;flex-direction:column;display:flex}.header__username{color:var(--text-primary);font-size:13px;font-weight:700;line-height:1.2}.header__role{color:var(--text-secondary);opacity:.8;margin-top:1px;font-size:10px;font-weight:600}.header__btn-lang,.header__btn-logout{background:var(--surface);box-shadow:var(--shadow-xs);transition:all var(--transition);border-radius:999px;padding:8px 16px;font-size:12px}.header__btn-lang:hover,.header__btn-logout:hover{background:var(--border-light);border-color:var(--accent);color:var(--accent-hover);transform:translateY(-1px)}.app-footer{border-top:1px solid var(--border-light);background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-top:64px;padding:40px 24px 24px;animation:.8s cubic-bezier(.16,1,.3,1) both fadeInUp}.app-footer__grid{text-align:left;grid-template-columns:1.5fr 1fr;gap:32px;margin-bottom:24px;display:grid}.app-footer__col{border-radius:var(--radius-md);transition:transform var(--transition), box-shadow var(--transition), background var(--transition), border-color var(--transition);background:#ffffff73;border:1px solid #6366f126;flex-direction:column;gap:8px;padding:20px 24px;display:flex}.app-footer__col:hover{background:var(--surface);border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.app-footer__title{color:var(--text-primary);font-size:14px;font-weight:700}.app-footer__desc{color:var(--text-secondary);font-size:12.5px;line-height:1.5}.app-footer__badges{flex-wrap:wrap;gap:8px;display:flex}.app-footer__badge{color:var(--text-secondary);background:var(--bg);border:1px solid var(--border-light);box-shadow:var(--shadow-xs);border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600}.app-footer__bottom{border-top:1px solid var(--border-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding-top:16px;display:flex}.app-footer__copy{color:var(--text-muted);font-size:12px}@media (width<=768px){.header{margin-top:8px;padding:10px 16px}.app-footer__grid{grid-template-columns:1fr;gap:20px}.app-footer__bottom{text-align:center;flex-direction:column}}@media (width<=640px){.header__title,.header__profile{display:none}}.grid-cards{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;display:grid}@media (width<=640px){.grid-cards{grid-template-columns:1fr;gap:16px}}.flex-responsive{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}@media (width<=640px){.flex-responsive{flex-direction:column;align-items:flex-start}}.nav-btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);color:var(--text-muted);background:0 0;border:none;padding:8px 20px;font-size:13px;font-weight:500}.nav-btn:hover{background:var(--accent-light)!important;color:var(--accent)!important}.nav-btn--active{background:var(--accent)!important;color:#fff!important;box-shadow:0 2px 8px var(--accent-glow)!important}.tenant-nav-btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);color:var(--text-muted);background:0 0;border:none;padding:8px 18px;font-size:13px;font-weight:500}.tenant-nav-btn:hover{background:var(--accent-light)!important;color:var(--accent)!important}.tenant-nav-btn--active{background:var(--surface)!important;color:var(--text-primary)!important;box-shadow:var(--shadow-xs)!important}.dashboard-app-container{background:var(--bg);width:100%;min-height:100vh;margin:0;padding:0}.dashboard-layout{grid-template-columns:1fr;align-items:stretch;gap:20px;margin-top:16px;display:grid}@media (width>=1024px){.dashboard-layout{grid-template-columns:280px 1fr;gap:0;min-height:100vh;margin-top:0}}.dashboard-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);z-index:10;flex-direction:column;justify-content:space-between;gap:16px;padding:24px 16px;display:flex;position:sticky;top:96px}@media (width<=1023px){.dashboard-layout{grid-template-columns:1fr;gap:0;margin-top:0}.dashboard-sidebar{width:280px;height:100vh;box-shadow:var(--shadow-lg);z-index:1010;transition:transform var(--transition);border:none;border-radius:0;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.dashboard-sidebar--open{transform:translate(0)}.dashboard-content{box-shadow:none;border:none;border-radius:0;padding:20px 16px}}@media (width>=1024px){.dashboard-sidebar{border:none;border-right:1px solid var(--border);height:100vh;box-shadow:none;border-radius:0;padding:32px 20px 24px;top:0}}.dashboard-mobile-header{display:none}@media (width<=1023px){.dashboard-mobile-header{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);z-index:999;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:14px 20px;display:flex;position:sticky;top:0}}.dashboard-mobile-header__brand{align-items:center;gap:10px;display:flex}.dashboard-mobile-header__logo-icon{font-size:24px}.dashboard-mobile-header__logo-title{color:var(--text-primary);font-size:15px;font-weight:800}.dashboard-mobile-header__toggle{background:var(--accent-light);color:var(--accent);border-radius:var(--radius-md);cursor:pointer;width:40px;height:40px;transition:all var(--transition);border:none;justify-content:center;align-items:center;font-size:20px;display:flex}.dashboard-mobile-header__toggle:hover{background:var(--accent);color:#fff}.dashboard-sidebar__close-btn{border:1px solid var(--border);background:var(--bg);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);transition:all var(--transition);z-index:10;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:none;position:absolute;top:20px;right:16px}@media (width<=1023px){.dashboard-sidebar__close-btn{display:flex}}.dashboard-sidebar__close-btn:hover{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}.dashboard-sidebar-backdrop{-webkit-backdrop-filter:blur(4px);z-index:1005;background:#0f172a66;animation:.25s fadeIn;position:fixed;inset:0}.dashboard-sidebar__top{flex-direction:column;gap:24px;display:flex}.dashboard-sidebar__logo{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;padding:0 12px 16px;display:flex}.dashboard-sidebar__logo-icon{font-size:28px}.dashboard-sidebar__logo-text{text-align:left;flex-direction:column;display:flex}.dashboard-sidebar__logo-title{color:var(--text-primary);font-size:16px;font-weight:800;line-height:1.2}.dashboard-sidebar__logo-subtitle{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.dashboard-sidebar__menu{flex-direction:column;gap:6px;display:flex}.dashboard-sidebar__item{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;text-align:left;transition:all var(--transition);background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 16px;font-size:14px;font-weight:600;display:flex}.dashboard-sidebar__item:hover{background:var(--accent-light);color:var(--accent);padding-left:20px}.dashboard-sidebar__item--active{background:linear-gradient(135deg, var(--accent), #818cf8);color:#fff;box-shadow:0 4px 12px var(--accent-glow)}.dashboard-sidebar__item--active:hover{background:linear-gradient(135deg, var(--accent), #818cf8);color:#fff;padding-left:16px}.dashboard-sidebar__footer{border-top:1px solid var(--border-light);padding-top:16px}.dashboard-sidebar__logout-btn{width:100%;color:var(--danger);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition);background:0 0;border:none;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:600;display:flex}.dashboard-sidebar__logout-btn:hover{background:var(--danger-light);padding-left:20px}.dashboard-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);min-height:500px;padding:32px}@media (width>=1024px){.dashboard-content{box-shadow:none;background:0 0;border:none;border-radius:0;min-height:100vh;padding:32px 48px}}.dashboard-content__header{border-bottom:1px solid var(--border-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;padding-bottom:20px;display:flex}.dashboard-content__title{color:var(--text-primary);letter-spacing:-.5px;font-size:20px;font-weight:800}.dashboard-content__actions{align-items:center;gap:16px;display:flex}.dashboard-header-btn{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-xs);cursor:pointer;transition:all var(--transition);border-radius:999px;padding:8px 16px;font-size:12px;font-weight:600}.dashboard-header-btn:hover{background:var(--border-light);border-color:var(--accent);color:var(--accent)}.dashboard-header-profile{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-xs);border-radius:999px;align-items:center;gap:12px;padding:6px 14px 6px 8px;display:flex}.dashboard-header-avatar{background:linear-gradient(135deg, var(--accent), #818cf8);color:#fff;width:32px;height:32px;box-shadow:0 2px 6px var(--accent-glow);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:800;display:flex}.dashboard-header-userinfo{text-align:left;flex-direction:column;display:flex}.dashboard-header-username{color:var(--text-primary);font-size:13px;font-weight:700;line-height:1.2}.dashboard-header-role{color:var(--text-secondary);opacity:.8;margin-top:1px;font-size:10px;font-weight:600}.premium-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);padding:24px}.premium-card:hover{border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.premium-table-wrap{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);width:100%;overflow-x:auto}.premium-table{border-collapse:collapse;text-align:left;width:100%;font-size:13.5px}.premium-table th{background:var(--bg);color:var(--text-secondary);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.05em;padding:14px 16px;font-size:11px;font-weight:600}.premium-table td{border-bottom:1px solid var(--border-light);color:var(--text-primary);padding:16px}.premium-table tr:last-child td{border-bottom:none}.premium-table tr:hover td{background:var(--bg)}.lang-selector{display:inline-block;position:relative}.lang-selector__btn{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);cursor:pointer;box-shadow:var(--shadow-xs);transition:all var(--transition);color:var(--text-primary);align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:500;display:flex}.lang-selector__btn:hover{border-color:var(--accent);background:var(--border-light)}.lang-selector__dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:1000;flex-direction:column;min-width:150px;padding:4px 0;animation:.2s fadeIn;display:flex;position:absolute;top:calc(100% + 4px);right:0}.lang-selector__item{text-align:left;cursor:pointer;width:100%;color:var(--text-primary);transition:background var(--transition);background:0 0;border:none;align-items:center;gap:12px;padding:10px 16px;font-size:14px;display:flex}.lang-selector__item:hover{background:var(--bg);color:var(--accent)}.lang-selector__item--active{background:var(--accent-light);color:var(--accent);font-weight:600}.auth-page{background:var(--bg);min-height:100vh;display:flex;position:relative}.auth-lang-switcher{z-index:100;position:absolute;top:24px;right:24px}.auth-brand{z-index:100;cursor:pointer;align-items:center;gap:8px;transition:opacity .2s;display:flex;position:absolute;top:24px;left:24px}.auth-brand:hover{opacity:.85}.auth-brand__logo{font-size:24px}.auth-brand__title{color:#fff;letter-spacing:-.5px;font-size:18px;font-weight:700}.auth-lang-btn{cursor:pointer;transition:all var(--transition);align-items:center;gap:6px;font-weight:600;display:flex;background:var(--surface)!important;color:var(--text-primary)!important;border:1px solid var(--border)!important;box-shadow:var(--shadow-sm)!important;border-radius:20px!important;padding:8px 16px!important;font-size:13px!important}.auth-lang-btn:hover{transform:translateY(-1px);background:var(--bg)!important;border-color:var(--accent)!important}.auth-hero{color:#fff;flex-direction:column;flex:1;justify-content:space-between;padding:40px;display:flex;position:relative;overflow:hidden}.auth-hero:before{content:"";z-index:1;background:linear-gradient(to bottom right,#0f172a66,#0f172acc);position:absolute;inset:0}.auth-hero__img{object-fit:cover;z-index:0;width:100%;height:100%;position:absolute;inset:0}.auth-hero__content{z-index:2;animation:.8s cubic-bezier(.16,1,.3,1) slideRight;position:relative}.auth-hero__logo{margin-bottom:24px;font-size:32px;display:inline-block}.auth-hero__title{letter-spacing:-1px;max-width:500px;margin-bottom:16px;font-size:48px;font-weight:800;line-height:1.1}.auth-hero__subtitle{opacity:.9;max-width:400px;font-size:18px;font-weight:300;line-height:1.5}.auth-hero__footer{z-index:2;opacity:.7;font-size:14px;position:relative}.auth-content{flex:1;justify-content:center;align-items:center;padding:24px;display:flex;position:relative}.auth-card{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:48px;animation:.5s cubic-bezier(.16,1,.3,1) scaleIn}.auth-header{margin-bottom:36px}.auth-header__title{color:var(--text-primary);letter-spacing:-.5px;margin-bottom:8px;font-size:28px;font-weight:800}.auth-header__subtitle{color:var(--text-muted);font-size:15px}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:32px;font-size:15px}.auth-footer__link{color:var(--accent);cursor:pointer;transition:all var(--transition);margin-left:6px;font-weight:700}.auth-footer__link:hover{color:var(--accent-hover);text-decoration:underline}@media (width<=960px){.auth-hero{display:none}.auth-content{background:url(/assets/login-bg-DpUs_sD_.png) 50%/cover no-repeat}.auth-content:before{content:"";-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a99;position:absolute;inset:0}.auth-card{z-index:2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;padding:40px 24px;position:relative}}.home-nav{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);z-index:1000;transition:all var(--transition);justify-content:space-between;align-items:center;margin-top:16px;padding:14px 24px;display:flex;position:sticky;top:16px}.home-nav:hover{box-shadow:var(--shadow-md);border-color:var(--border)}.home-nav__brand{align-items:center;gap:10px;text-decoration:none;display:flex}.home-nav__logo{font-size:28px}.home-nav__title{color:var(--text-primary);letter-spacing:-.5px;font-size:20px;font-weight:800}.home-nav__actions{align-items:center;gap:12px;display:flex}.home-nav__btn-login{border-radius:var(--radius-md);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;padding:9px 20px;font-size:14px;font-weight:500;text-decoration:none}.home-nav__btn-login:hover{background:var(--border-light);color:var(--text-primary)}.home-nav__btn-lang{border-radius:var(--radius-md);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;align-items:center;gap:6px;padding:9px 16px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.home-nav__btn-lang:hover{background:var(--border-light);color:var(--text-primary)}.home-nav__btn-register{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent), #6366f1);color:#fff;cursor:pointer;transition:all var(--transition);box-shadow:0 4px 12px var(--accent-glow);border:none;padding:9px 20px;font-size:14px;font-weight:600;text-decoration:none}.home-nav__btn-register:hover{opacity:.9;transform:translateY(-1px)}.hero{grid-template-columns:1fr 1fr;align-items:center;gap:48px;min-height:80vh;padding:72px 0 64px;display:grid}.hero__content{animation:.5s fadeIn}.hero__badge{background:var(--accent-light);color:var(--accent);letter-spacing:.04em;border:1px solid #4f46e533;border-radius:999px;align-items:center;gap:6px;margin-bottom:24px;padding:6px 14px;font-size:12px;font-weight:600;display:inline-flex}.hero__title{color:var(--text-primary);letter-spacing:-2px;margin-bottom:20px;font-size:52px;font-weight:900;line-height:1.12}.hero__title-highlight{background:linear-gradient(135deg, var(--accent) 0%, #a855f7 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero__desc{color:var(--text-secondary);max-width:480px;margin-bottom:36px;font-size:17px;line-height:1.7}.hero__cta-group{flex-wrap:wrap;gap:14px;display:flex}.hero__btn-primary{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent), #6366f1);color:#fff;cursor:pointer;transition:all var(--transition);box-shadow:0 8px 24px var(--accent-glow);border:none;align-items:center;gap:8px;padding:14px 32px;font-size:15px;font-weight:700;text-decoration:none;display:inline-flex}.hero__btn-primary:hover{box-shadow:0 12px 32px var(--accent-glow);transform:translateY(-2px)}.hero__btn-secondary{border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--surface);color:var(--text-primary);cursor:pointer;transition:all var(--transition);align-items:center;gap:8px;padding:14px 28px;font-size:15px;font-weight:600;text-decoration:none;display:inline-flex}.hero__btn-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.hero__stats{border-top:1px solid var(--border-light);flex-wrap:wrap;gap:32px;margin-top:40px;padding-top:32px;display:flex}.hero__stat-value{color:var(--text-primary);letter-spacing:-1px;font-size:26px;font-weight:800}.hero__stat-label{color:var(--text-muted);margin-top:2px;font-size:12px;font-weight:500}.hero__image-wrap{animation:.6s .1s both fadeIn;position:relative}.hero__image{border-radius:var(--radius-xl);width:100%;box-shadow:var(--shadow-lg);object-fit:cover;max-height:440px}.hero__float-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:14px 20px;animation:.6s .3s both fadeIn;position:absolute}.hero__float-card--tl{top:-16px;left:-16px}.hero__float-card--br{bottom:-16px;right:-16px}.hero__float-value{color:var(--text-primary);font-size:20px;font-weight:800}.hero__float-label{color:var(--text-muted);margin-top:2px;font-size:11px;font-weight:500}.features{text-align:center;padding:80px 0}.features__label{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:var(--accent-light);border-radius:999px;margin-bottom:16px;padding:5px 14px;font-size:12px;font-weight:700;display:inline-block}.features__title{letter-spacing:-1.5px;color:var(--text-primary);margin-bottom:14px;font-size:38px;font-weight:900}.features__subtitle{color:var(--text-secondary);max-width:540px;margin:0 auto 56px;font-size:16px;line-height:1.7}.features__grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);text-align:left;transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);padding:32px 28px;position:relative;overflow:hidden}.feature-card:before{content:"";background:linear-gradient(90deg, var(--accent), #a855f7);opacity:0;height:3px;transition:opacity var(--transition);position:absolute;top:0;left:0;right:0}.feature-card:hover{border-color:var(--accent);box-shadow:0 8px 20px var(--accent-glow);transform:translateY(-6px)}.feature-card:hover:before{opacity:1}.feature-card__icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:20px;font-size:24px;display:flex}.feature-card__icon--purple{background:#f3f0ff}.feature-card__icon--green{background:#ecfdf5}.feature-card__icon--amber{background:#fffbeb}.feature-card__icon--blue{background:#eff6ff}.feature-card__icon--pink{background:#fdf2f8}.feature-card__icon--cyan{background:#ecfeff}.feature-card__title{color:var(--text-primary);margin-bottom:8px;font-size:16px;font-weight:700}.feature-card__desc{color:var(--text-secondary);font-size:14px;line-height:1.65}.roles{border-radius:var(--radius-xl);background:linear-gradient(135deg,#f8fafc 0%,#eef2ff 100%);margin-bottom:80px;padding:72px 0}.roles__inner{max-width:1100px;margin:0 auto;padding:0 32px}.roles__title{text-align:center;letter-spacing:-1px;color:var(--text-primary);margin-bottom:48px;font-size:36px;font-weight:900}.roles__grid{grid-template-columns:repeat(2,1fr);gap:32px;max-width:800px;margin:0 auto;display:grid}.role-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);text-align:center;transition:all var(--transition);cursor:pointer;padding:32px}.role-card:hover{border-color:var(--accent);box-shadow:0 8px 20px var(--accent-glow);transform:translateY(-6px)}.role-card__emoji{margin-bottom:16px;font-size:44px;display:block}.role-card__title{color:var(--text-primary);margin-bottom:10px;font-size:18px;font-weight:800}.role-card__desc{color:var(--text-secondary);margin-bottom:20px;font-size:13px;line-height:1.6}.role-card__perks{text-align:left;flex-direction:column;gap:6px;list-style:none;display:flex}.role-card__perk{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:flex}.role-card__perk:before{content:"✓";color:var(--success);font-size:11px;font-weight:700}.cta-section{border-radius:var(--radius-xl);text-align:center;background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 60%,#a855f7 100%);margin-bottom:80px;padding:72px 48px;position:relative;overflow:hidden}.cta-section:before{content:"";background:radial-gradient(circle,#ffffff0f 0%,#0000 60%);width:200%;height:200%;animation:20s linear infinite spin;position:absolute;top:-50%;left:-50%}.cta-section__title{color:#fff;letter-spacing:-1.5px;margin-bottom:16px;font-size:40px;font-weight:900;position:relative}.cta-section__desc{color:#fffc;margin-bottom:36px;font-size:16px;position:relative}.cta-section__btn{border-radius:var(--radius-md);color:var(--accent);cursor:pointer;transition:all var(--transition);background:#fff;border:none;align-items:center;gap:8px;padding:16px 40px;font-size:16px;font-weight:700;text-decoration:none;display:inline-flex;position:relative;box-shadow:0 8px 24px #0003}.cta-section__btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px #00000040}.home-footer{border-top:1px solid var(--border-light);background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;margin-top:64px;padding:64px 32px 32px;animation:.8s cubic-bezier(.16,1,.3,1) both fadeInUp;position:relative;overflow:hidden;box-shadow:0 -10px 30px #6366f10a}.home-footer:after{content:"";pointer-events:none;background:radial-gradient(circle,#6366f114 0%,#0000 70%);width:150px;height:150px;position:absolute;bottom:0;right:0}.home-footer__grid{text-align:left;grid-template-columns:2fr repeat(3,1fr);gap:40px;margin-bottom:48px;display:grid}.home-footer__col{border-radius:var(--radius-md);transition:transform var(--transition), box-shadow var(--transition), background var(--transition), border-color var(--transition);background:#ffffff73;border:1px solid #6366f126;flex-direction:column;gap:16px;padding:24px;display:flex}.home-footer__col:hover{background:var(--surface);border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.home-footer__brand{align-items:center;gap:10px;display:flex}.home-footer__logo{font-size:28px}.home-footer__title{color:var(--text-primary);letter-spacing:-.5px;font-size:20px;font-weight:800}.home-footer__desc{color:var(--text-secondary);max-width:320px;font-size:13.5px;line-height:1.6}.home-footer__socials{gap:10px;display:flex}.home-footer__social-btn{background:var(--bg);border:1px solid var(--border-light);width:36px;height:36px;transition:all var(--transition);box-shadow:var(--shadow-xs);border-radius:50%;justify-content:center;align-items:center;font-size:16px;text-decoration:none;display:flex}.home-footer__social-btn:hover{background:var(--accent-light);border-color:var(--accent);box-shadow:0 4px 10px var(--accent-glow);transform:translateY(-3px)scale(1.1)}.home-footer__col-title{color:var(--text-primary);border-bottom:2px solid var(--border-light);margin-bottom:8px;padding-bottom:8px;font-size:15px;font-weight:700}.home-footer__list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.home-footer__list-link{color:var(--text-secondary);transition:all var(--transition);align-items:center;font-size:13px;text-decoration:none;display:inline-flex}.home-footer__list-link:before{content:"→";opacity:0;transition:all var(--transition);color:var(--accent);margin-right:6px;transform:translate(-5px)}.home-footer__list-link:hover{color:var(--accent);transform:translate(4px)}.home-footer__list-link:hover:before{opacity:1;transform:translate(0)}.home-footer__contact-item{color:var(--text-secondary);font-size:13px;line-height:1.6}.home-footer__bottom{border-top:1px solid var(--border-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding-top:24px;display:flex}.home-footer__copy{color:var(--text-muted);font-size:13px}.home-footer__links{gap:20px;display:flex}.home-footer__link{color:var(--text-muted);transition:color var(--transition);font-size:13px;text-decoration:none}.home-footer__link:hover{color:var(--accent)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@media (width<=968px){.hero{text-align:center;grid-template-columns:1fr;min-height:auto;padding:48px 0}.hero__title{font-size:36px}.hero__desc{max-width:100%}.hero__cta-group,.hero__stats{justify-content:center}.hero__image-wrap{order:-1}.hero__float-card{display:none}.roles__grid{grid-template-columns:1fr}.features__title{font-size:28px}.cta-section{padding:48px 24px}.cta-section__title{font-size:28px}}@media (width<=640px){.hero__title{font-size:30px}.home-nav__btn-login{display:none}}.home-room-card:hover{transform:translateY(-6px);border-color:var(--accent)!important;box-shadow:0 8px 20px var(--accent-glow)!important}.notfound-page{background:var(--bg);min-height:100vh;font-family:var(--font);justify-content:center;align-items:center;padding:24px;display:flex}.notfound-card{text-align:center;max-width:480px;animation:.4s fadeIn}.notfound-code{letter-spacing:-4px;background:linear-gradient(135deg, var(--accent), #a855f7);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:-8px;font-size:120px;font-weight:900;line-height:1}.notfound-emoji{margin-bottom:20px;font-size:64px;animation:.4s .1s both fadeIn;display:block}.notfound-title{color:var(--text-primary);letter-spacing:-.5px;margin-bottom:12px;font-size:28px;font-weight:800}.notfound-desc{color:var(--text-secondary);margin-bottom:36px;font-size:15px;line-height:1.7}.notfound-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.notfound-btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);align-items:center;gap:6px;padding:12px 28px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.notfound-btn--primary{background:linear-gradient(135deg, var(--accent), #6366f1);color:#fff;box-shadow:0 4px 12px var(--accent-glow);border:none}.notfound-btn--primary:hover{box-shadow:0 8px 20px var(--accent-glow);transform:translateY(-2px)}.notfound-btn--secondary{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border)}.notfound-btn--secondary:hover{border-color:var(--accent);color:var(--accent)}.admin-nav{background:var(--border-light);border-radius:var(--radius-md);border:1px solid var(--border);gap:4px;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.admin-nav__item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);color:var(--text-muted);background:0 0;border:none;align-items:center;padding:9px 20px;font-size:13px;font-weight:500;display:flex}.admin-nav__item--active{background:var(--text-primary);color:#fff}.admin-nav__item:hover:not(.admin-nav__item--active){background:var(--border-light);color:var(--text-primary)}.admin-nav__badge{background:var(--danger);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;margin-left:6px;font-size:10px;font-weight:700;display:inline-flex}.admin-host-card{background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius-md);text-align:center;transition:all var(--transition);cursor:pointer;padding:20px}.admin-host-card:hover{border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.admin-host-card--locked{opacity:.5;cursor:not-allowed}.admin-host-card__avatar{width:44px;height:44px;margin:0 auto 10px;font-size:15px}.admin-host-card__name{color:var(--text-primary);font-size:13px;font-weight:600}.admin-host-card__locked-label{color:var(--danger);margin-top:4px;font-size:11px;font-weight:600}.admin-host-card__id{color:var(--text-muted);margin-top:3px;font-size:11px}.admin-complaint{border:1px solid var(--border);border-radius:var(--radius-md);transition:opacity var(--transition);overflow:hidden}.admin-complaint--resolved{opacity:.6}.admin-complaint__header{background:var(--bg);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.admin-complaint__sender{align-items:center;gap:10px;display:flex}.admin-complaint__title{color:var(--text-primary);font-size:13px;font-weight:600}.admin-complaint__sender-info{color:var(--text-muted);margin-top:2px;font-size:11px}.admin-complaint__body{padding:12px 16px}.admin-complaint__content{color:var(--text-secondary);background:var(--warning-light);border-radius:var(--radius-sm);border:1px solid #fde68a;border-left:3px solid var(--warning);margin-bottom:12px;padding:10px 14px;font-size:13px;font-style:italic}.admin-complaint__actions{justify-content:flex-end;gap:8px;display:flex}@media (width<=768px){.admin-nav{width:100%}.admin-nav__item{padding:8px 12px;font-size:12px}}.admin-room-card{cursor:pointer;transition:all var(--transition)!important}.admin-room-card:hover{transform:translateY(-4px);border-color:var(--accent)!important;box-shadow:0 6px 16px var(--accent-glow)!important}.landlord-nav-bar{background:var(--border-light);border-radius:var(--radius-md);border:1px solid var(--border);flex-wrap:wrap;gap:4px;padding:4px;display:flex}.landlord-nav-bar__btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);color:var(--text-muted);white-space:nowrap;background:0 0;border:none;align-items:center;padding:9px 18px;font-size:13px;font-weight:500;display:flex}.landlord-nav-bar__btn--active{background:linear-gradient(135deg, var(--accent), #818cf8);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.landlord-nav-bar__btn:hover:not(.landlord-nav-bar__btn--active){background:var(--accent-light);color:var(--accent)}.landlord-nav-bar__badge{background:var(--danger);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;margin-left:6px;font-size:10px;font-weight:700;display:inline-flex}.landlord-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.landlord-contact-btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);white-space:nowrap;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;display:flex}.landlord-contact-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.landlord-contact-btn:disabled{opacity:.5;cursor:not-allowed}.l-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition), background var(--transition);padding:24px;animation:.3s fadeIn}.l-card:hover{border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.l-section-title{color:var(--text-primary);border-bottom:1px solid var(--border-light);align-items:center;gap:8px;margin-bottom:20px;padding-bottom:12px;font-size:15px;font-weight:600;display:flex}.l-info-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:10px 0;font-size:13px;display:flex}.l-info-row:last-child{border-bottom:none}.l-info-row__label{color:var(--text-muted)}.l-info-row__value{color:var(--text-primary);font-weight:600}.l-tag{border-radius:999px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.l-tag--green{background:var(--success-light);color:var(--success)}.l-tag--red{background:var(--danger-light);color:var(--danger)}.l-tag--blue{background:var(--accent-light);color:var(--accent)}.l-tag--amber{background:var(--warning-light);color:var(--warning)}.l-btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);padding:8px 16px;font-size:13px;font-weight:500}.l-btn:hover{background:var(--border-light)}.l-btn--primary{background:linear-gradient(135deg, var(--accent), #818cf8);color:#fff;box-shadow:0 2px 8px var(--accent-glow);border:none}.l-btn--primary:hover{opacity:.9;transform:translateY(-1px)}.l-btn--success{background:var(--success);color:#fff;border:none}.l-btn--danger{background:var(--danger);color:#fff;border:none}.l-btn--full{justify-content:center;width:100%}.l-form-group{margin-bottom:0}.l-form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:11px;font-weight:600;display:block}.l-form-input{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-primary);transition:all var(--transition);box-sizing:border-box;font-size:14px;font-family:var(--font);outline:none;padding:10px 14px}.l-form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.l-stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:24px;display:grid}.l-stat-card{background:var(--surface);border-radius:var(--radius-xl);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);padding:24px;position:relative;overflow:hidden}.l-stat-card:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.l-stat-card--revenue:before{background:linear-gradient(90deg, var(--accent), #818cf8)}.l-stat-card--occupancy:before{background:linear-gradient(90deg, var(--success), #34d399)}.l-stat-card--debt:before{background:linear-gradient(90deg, var(--warning), #fbbf24)}.l-stat-card:hover{border-color:var(--accent);box-shadow:0 8px 20px var(--accent-glow);transform:translateY(-6px)}.l-stat-card__icon{margin-bottom:12px;font-size:28px;display:block}.l-stat-card__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px;font-size:11px;font-weight:600}.l-stat-card__value{color:var(--text-primary);letter-spacing:-.5px;margin-bottom:6px;font-size:26px;font-weight:800}.l-stat-card__sub{color:var(--text-secondary);font-size:13px}.l-stat-card__trend{align-items:center;gap:4px;font-size:13px;font-weight:500;display:flex}.l-stat-card__trend--up{color:var(--success)}.l-stat-card__trend--down{color:var(--danger)}.l-chart-card{background:var(--surface);border-radius:var(--radius-xl);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:24px}.l-chart-card__title{color:var(--text-primary);margin-bottom:24px;font-size:16px;font-weight:700}.l-chart-bars{border-bottom:1px solid var(--border-light);align-items:flex-end;gap:12px;height:180px;padding-bottom:12px;display:flex}.l-chart-col{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}.l-chart-col__label-top{color:var(--text-muted);font-size:10px}.l-chart-col__bar{border-radius:4px 4px 0 0;width:100%;max-width:36px;min-height:4px;transition:height .6s cubic-bezier(.16,1,.3,1)}.l-chart-col__bar--current{background:linear-gradient(to top, var(--accent), #818cf8)}.l-chart-col__bar--past{background:var(--border)}.l-chart-col__label-bot{color:var(--text-secondary);font-size:11px;font-weight:500}.l-add-room-form{flex-wrap:wrap;align-items:flex-end;gap:16px;display:flex}.l-add-room-form__field{flex:1;min-width:130px}.l-room-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.l-room-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);border-top:3px solid var(--border);padding:20px;position:relative}.l-room-card:hover{border-color:var(--accent);box-shadow:0 8px 20px var(--accent-glow);transform:translateY(-6px)}.l-room-card--empty{border-top-color:var(--success)}.l-room-card--rented{border-top-color:var(--danger)}.l-room-card--maintenance{border-top-color:var(--warning)}.l-room-card__delete-btn{border-radius:var(--radius-sm);background:var(--danger-light);width:28px;height:28px;color:var(--danger);cursor:pointer;transition:all var(--transition);border:none;justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute;top:14px;right:14px}.l-room-card__delete-btn:hover{background:var(--danger);color:#fff}.l-room-card__name{color:var(--text-primary);margin-bottom:16px;padding-right:36px;font-size:16px;font-weight:700}.l-request-item{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);flex-wrap:wrap;align-items:center;gap:14px;padding:16px 20px;display:flex}.l-request-item:hover{border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.l-request-item__avatar{background:var(--accent-light);width:44px;height:44px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.l-request-item__info{flex:1;min-width:120px}.l-request-item__name{color:var(--text-primary);font-size:14px;font-weight:600}.l-request-item__phone{color:var(--text-muted);margin-top:2px;font-size:12px}.l-request-item__room{min-width:100px}.l-request-item__room-name{color:var(--text-primary);font-size:13px;font-weight:600}.l-request-item__date{color:var(--text-muted);margin-top:2px;font-size:11px}.l-request-item__actions{flex-wrap:wrap;gap:8px;display:flex}.l-invoice-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);padding:20px}.l-invoice-card:hover{border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.l-invoice-card__header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.l-invoice-card__room{color:var(--text-primary);font-size:14px;font-weight:700}.l-invoice-card__actions{gap:8px;margin-top:16px;display:flex}.l-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a80;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.l-modal{background:var(--surface);border-radius:var(--radius-xl);border:1px solid var(--border);width:100%;max-height:90vh;box-shadow:var(--shadow-lg);animation:.25s cubic-bezier(.16,1,.3,1) scaleIn;overflow-y:auto}.l-modal--sm{max-width:440px}.l-modal--md{max-width:540px}.l-modal__header{border-bottom:1px solid var(--border-light);background:var(--surface);z-index:1;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:sticky;top:0}.l-modal__title{color:var(--text-primary);font-size:16px;font-weight:700}.l-modal__subtitle{color:var(--text-muted);margin-top:2px;font-size:12px}.l-modal__close{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);cursor:pointer;width:32px;height:32px;transition:all var(--transition);justify-content:center;align-items:center;font-size:14px;display:flex}.l-modal__close:hover{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}.l-modal__body{padding:24px}.l-modal__footer{border-top:1px solid var(--border-light);padding:16px 24px}.l-room-detail-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;display:grid}.l-room-detail-cell{background:var(--bg);border-radius:var(--radius-md);border:1px solid var(--border-light);padding:14px}.l-room-detail-cell__label{color:var(--text-muted);margin-bottom:4px;font-size:11px}.l-room-detail-cell__value{font-size:15px;font-weight:600}.l-tenant-info{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg);padding:20px}.l-tenant-info__header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.l-tenant-info__profile{align-items:center;gap:12px;display:flex}.l-tenant-info__avatar{background:var(--accent-light);width:44px;height:44px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.l-tenant-info__name{color:var(--text-primary);font-size:14px;font-weight:600}.l-tenant-info__role{color:var(--text-muted);font-size:12px}.l-meter-group{background:var(--bg);border-radius:var(--radius-md);border:1px solid var(--border-light);margin-bottom:16px;padding:16px}.l-meter-group__title{color:var(--text-primary);align-items:center;gap:6px;margin-bottom:12px;font-size:13px;font-weight:600;display:flex}.l-meter-group__inputs{grid-template-columns:1fr 1fr;gap:12px;display:grid}.l-history-table-wrap{border:1px solid var(--border-light);border-radius:var(--radius-md);max-height:200px;overflow-y:auto}.l-history-table{border-collapse:collapse;width:100%;font-size:12px}.l-history-table thead{background:var(--bg);position:sticky;top:0}.l-history-table th,.l-history-table td{border-bottom:1px solid var(--border-light);text-align:left;padding:8px 12px}.l-history-table th{color:var(--text-muted);text-transform:uppercase;font-size:11px;font-weight:600}.l-history-table td:last-child,.l-history-table th:last-child{text-align:right}.l-notice-form{flex-direction:column;gap:12px;margin-bottom:32px;display:flex}.l-notice-list{gap:12px;display:grid}.l-notice-item{border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-md);background:var(--bg);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);padding:16px}.l-notice-item:hover{border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.l-notice-item__title{color:var(--text-primary);margin-bottom:6px;font-size:14px;font-weight:600}.l-notice-item__content{color:var(--text-secondary);white-space:pre-line;font-size:13px;line-height:1.6}.l-notice-item__date{color:var(--text-muted);margin-top:10px;font-size:11px}.l-empty{text-align:center;color:var(--text-muted);padding:48px 20px;animation:.3s fadeIn}.l-empty__icon{opacity:.6;margin-bottom:12px;font-size:40px}.l-empty__text{color:var(--text-secondary);font-size:14px;font-weight:600}.l-spinner{text-align:center;padding:48px;animation:.3s fadeIn}.l-spinner__circle{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;margin:0 auto 12px;animation:.7s linear infinite spin}.l-spinner__text{color:var(--text-muted);font-size:13px}@media (width<=768px){.landlord-nav-bar{width:100%;overflow-x:auto}.landlord-nav-bar__btn{padding:8px 12px;font-size:12px}.landlord-header{flex-direction:column}.l-stats-grid{grid-template-columns:1fr}.l-add-room-form{flex-direction:column}.l-add-room-form__field{width:100%}.l-room-detail-grid,.l-meter-group__inputs{grid-template-columns:1fr}.l-request-item{flex-direction:column;align-items:flex-start}.l-chart-bars{gap:6px;height:120px}}.guest-nav{background:var(--border-light);border-radius:var(--radius-md);border:1px solid var(--border);gap:4px;width:fit-content;margin-bottom:20px;padding:4px;display:flex}.guest-nav__item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);color:var(--text-muted);background:0 0;border:none;padding:8px 20px;font-size:13px;font-weight:500}.guest-nav__item--active{background:var(--accent);color:#fff}.guest-toolbar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.guest-header-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px;display:flex}.guest-tag{border-radius:999px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.guest-tag--empty{background:var(--success-light);color:var(--success)}.guest-tag--rented{background:var(--danger-light);color:var(--danger)}.host-card{background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;text-align:center;transition:all var(--transition);padding:20px}.host-card:hover{border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.host-card__avatar{background:var(--accent-light);width:44px;height:44px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 10px;font-size:16px;font-weight:700;display:flex}.host-card__name{color:var(--text-primary);font-size:13px;font-weight:600}.host-profile{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:15px;display:flex}.host-profile__info{align-items:center;gap:14px;display:flex}.host-profile__avatar{width:48px;height:48px;color:var(--success);background:#dcfce7;border-radius:50%;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.host-profile__name{color:var(--success);font-size:15px;font-weight:700}.host-profile__contacts{color:#15803d;flex-wrap:wrap;gap:14px;margin-top:4px;font-size:12px;display:flex}.room-card{background:var(--surface);border-radius:0 0 var(--radius-lg) var(--radius-lg);border:1px solid var(--border);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);padding:20px}.room-card:hover{border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.room-card--empty{border-top:3px solid var(--success)}.room-card--rented{border-top:3px solid var(--danger)}.room-card__header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.room-card__name{color:var(--text-primary);font-size:14px;font-weight:600}.room-card__price-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:10px 0;font-size:13px;display:flex}@media (width<=768px){.guest-header-row{flex-direction:column}.guest-nav{width:100%}.guest-nav__item{text-align:center;flex:1}}.search-engine{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition);margin-bottom:24px;padding:24px}.search-engine:hover{border-color:var(--accent);box-shadow:0 6px 16px var(--accent-glow);transform:translateY(-4px)}.search-engine__title{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:20px;font-size:16px;font-weight:700;display:flex}.search-engine__grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px;display:grid}@media (width>=1024px){.search-engine__grid{grid-template-columns:repeat(4,1fr)}}.search-engine__field{flex-direction:column;gap:6px;min-width:0;display:flex}.search-engine__label{color:var(--text-secondary);font-size:12px;font-weight:600}.search-engine__input,.search-engine__select{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);width:100%;min-width:0;color:var(--text-primary);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:10px 12px;font-size:13px}.search-engine__input:focus,.search-engine__select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.search-engine__range{align-items:center;gap:8px;width:100%;min-width:0;display:flex}.search-engine__range .search-engine__input{flex:1;min-width:0}.search-engine__separator{color:var(--text-muted);font-size:12px}.search-engine__actions{border-top:1px solid var(--border-light);justify-content:flex-end;gap:12px;padding-top:16px;display:flex}.btn-search-primary{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;transition:opacity var(--transition);border:none;align-items:center;gap:6px;padding:10px 20px;font-size:13px;font-weight:600;display:flex}.btn-search-primary:hover{opacity:.9}.btn-search-secondary{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);padding:10px 20px;font-size:13px;font-weight:500}.btn-search-secondary:hover{background:var(--bg);color:var(--text-primary)}.search-mode-selector{background:var(--border-light);border-radius:var(--radius-md);gap:8px;width:fit-content;margin-bottom:20px;padding:4px;display:flex}.search-mode-btn{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all var(--transition);background:0 0;border:none;padding:6px 14px;font-size:12px;font-weight:600}.search-mode-btn--active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}.search-mode-btn:hover:not(.search-mode-btn--active){background:var(--accent-light);color:var(--accent)}.room-card__host-info{border-top:1px solid var(--border-light);align-items:center;gap:8px;margin-top:12px;padding-top:12px;display:flex}.room-card__host-avatar{background:var(--accent-light);width:24px;height:24px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:flex}.room-card__host-name{color:var(--text-secondary);font-size:11px;font-weight:600}.guest-layout-wrapper{grid-template-columns:1fr;align-items:flex-start;gap:24px;margin-top:16px;display:grid}@media (width>=1024px){.guest-layout-wrapper{grid-template-columns:1fr 300px}}.guest-main-column{flex-direction:column;gap:20px;display:flex}.guest-sidebar-column{flex-direction:column;gap:24px;display:flex;position:sticky;top:96px}.guest-results-header{border-bottom:1px solid var(--border);margin-bottom:4px;padding-bottom:12px}.guest-results-title{color:var(--text-primary);letter-spacing:-.5px;font-size:20px;font-weight:800}.guest-results-count{color:var(--text-secondary);margin-top:4px;font-size:13.5px;display:block}.guest-sort-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);align-items:center;gap:8px;padding:6px 12px;display:flex}.guest-sort-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;padding:6px 12px;font-size:12.5px;font-weight:600}.guest-sort-btn:hover{background:var(--border-light);color:var(--text-primary)}.guest-sort-btn--active{background:var(--accent-light);color:var(--accent)}.room-card-horizontal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);box-shadow:var(--shadow-sm);flex-direction:column;margin-bottom:16px;display:flex;overflow:hidden}@media (width>=640px){.room-card-horizontal{flex-direction:row}}.room-card-horizontal:hover{border-color:var(--accent);box-shadow:0 8px 20px var(--accent-glow);transform:translateY(-4px)}.room-card-horizontal--empty{border-left:4px solid var(--success)}.room-card-horizontal--rented{border-left:4px solid var(--danger)}.room-card-horizontal--maintenance{border-left:4px solid var(--warning)}.room-card-horizontal__img-wrap{flex-shrink:0;width:100%;height:200px;position:relative;overflow:hidden}@media (width>=640px){.room-card-horizontal__img-wrap{width:260px;height:100%;min-height:220px}}.room-card-horizontal__content{flex-direction:column;flex:1;justify-content:space-between;padding:20px;display:flex}.room-card-horizontal__header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.room-card-horizontal__title{color:var(--text-primary);text-transform:uppercase;transition:color var(--transition);cursor:pointer;margin-bottom:6px;font-size:15px;font-weight:700;line-height:1.4}.room-card-horizontal__title:hover{color:var(--accent)}.room-card-horizontal__rating{color:#fbbf24;margin-bottom:4px;font-size:13px}.room-card-horizontal__meta-row{flex-wrap:wrap;align-items:center;gap:12px;margin-top:6px;margin-bottom:10px;display:flex}.room-card-horizontal__price{color:var(--success);font-size:16px;font-weight:700}.room-card-horizontal__area{color:var(--text-secondary);font-size:14px;font-weight:600}.room-card-horizontal__dot{color:var(--text-muted)}.room-card-horizontal__address{color:var(--text-secondary);align-items:center;gap:4px;font-size:13px;display:flex}.room-card-horizontal__desc{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;height:40px;margin-top:8px;font-size:13px;line-height:1.6;display:-webkit-box;overflow:hidden}.room-card-horizontal__details{background:var(--bg);border-radius:var(--radius-md);border:1px solid var(--border-light);flex-wrap:wrap;gap:12px;margin-top:12px;padding:10px 14px;font-size:12px;display:flex}.room-card-horizontal__detail-item{color:var(--text-secondary);gap:4px;display:flex}.room-card-horizontal__detail-value{color:var(--text-primary);font-weight:600}.room-card-horizontal__footer{border-top:1px solid var(--border-light);justify-content:space-between;align-items:center;margin-top:16px;padding-top:12px;display:flex}.sidebar-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.sidebar-box__title{color:var(--text-primary);border-bottom:2px solid var(--border-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;padding-bottom:8px;font-size:13px;font-weight:700}.sidebar-box__grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.sidebar-link{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);align-items:center;padding:4px 0;font-size:12.5px;display:flex}.sidebar-link:before{content:"›";color:var(--text-muted);margin-right:4px;font-size:14px}.sidebar-link:hover{color:var(--accent);padding-left:4px}.sidebar-recent-list{flex-direction:column;gap:12px;display:flex}.sidebar-recent-item{cursor:pointer;border-bottom:1px solid var(--border-light);transition:opacity var(--transition);align-items:center;gap:10px;padding-bottom:12px;display:flex}.sidebar-recent-item:last-child{border-bottom:none;padding-bottom:0}.sidebar-recent-item:hover{opacity:.8}.sidebar-recent-item__img-wrap{border-radius:var(--radius-sm);background:var(--bg);flex-shrink:0;width:52px;height:52px;overflow:hidden}.sidebar-recent-item__img{object-fit:cover;width:100%;height:100%}.sidebar-recent-item__avatar{border-radius:var(--radius-sm);background:var(--accent-light);width:52px;height:52px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.sidebar-recent-item__info{flex:1;min-width:0}.sidebar-recent-item__title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:600;overflow:hidden}.sidebar-recent-item__price{color:var(--success);margin-top:2px;font-size:12px;font-weight:700}.guest-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a80;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.guest-modal{background:var(--surface);border-radius:var(--radius-xl);border:1px solid var(--border);width:100%;max-height:90vh;box-shadow:var(--shadow-lg);animation:.25s cubic-bezier(.16,1,.3,1) scaleIn;overflow-y:auto}.guest-modal--md{max-width:540px}.guest-modal__header{border-bottom:1px solid var(--border-light);background:var(--surface);z-index:1;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:sticky;top:0}.guest-modal__title{color:var(--text-primary);font-size:16px;font-weight:700}.guest-modal__subtitle{color:var(--text-muted);margin-top:2px;font-size:12px}.guest-modal__close{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);cursor:pointer;width:32px;height:32px;transition:all var(--transition);justify-content:center;align-items:center;font-size:14px;display:flex}.guest-modal__close:hover{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}.guest-modal__body{padding:24px}.guest-modal__footer{border-top:1px solid var(--border-light);background:var(--surface);z-index:1;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex;position:sticky;bottom:0}.guest-room-detail-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;display:grid}.guest-room-detail-cell{background:var(--bg);border-radius:var(--radius-md);border:1px solid var(--border-light);padding:14px}.guest-room-detail-cell__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px}.guest-room-detail-cell__value{color:var(--text-primary);font-size:14px;font-weight:600}@media (width<=480px){.guest-room-detail-grid{grid-template-columns:1fr}}.tenant-nav{background:var(--border-light);border-radius:var(--radius-md);border:1px solid var(--border);gap:4px;width:fit-content;padding:4px;display:flex}.tenant-nav__item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);color:var(--text-muted);background:0 0;border:none;padding:8px 18px;font-size:13px;font-weight:500}.tenant-nav__item--active{background:var(--surface);color:var(--text-primary);box-shadow:var(--shadow-xs)}.tenant-header-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px;display:flex}.tenant-contract-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;display:grid}.tenant-contract-card{background:var(--bg);border-radius:var(--radius-md);border:1px solid var(--border-light);padding:14px}.tenant-contract-card__label{color:var(--text-muted);margin-bottom:4px;font-size:11px}.tenant-contract-card__value{color:var(--accent);font-size:15px;font-weight:600}.tenant-invoice{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface);transition:all var(--transition);overflow:hidden}.tenant-invoice--paid{opacity:.75;border-color:#d1fae5}.tenant-invoice__header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.tenant-invoice__header--paid{background:#f0fdf4}.tenant-invoice__header--unpaid{background:var(--bg)}.tenant-invoice__period-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px;font-size:11px;font-weight:500}.tenant-invoice__period-value{color:var(--text-primary);font-size:15px;font-weight:700}.tenant-invoice__body{padding:16px 20px}.tenant-invoice__fee-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.tenant-invoice__fee-row:last-of-type{border-bottom:none}.tenant-invoice__fee-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:28px;height:28px;margin-right:10px;font-size:14px;display:flex}.tenant-invoice__total{border-radius:var(--radius-md);background:var(--text-primary);justify-content:space-between;align-items:center;margin-top:12px;padding:12px 14px;display:flex}.tenant-invoice__total-label{color:#a1a1aa;font-size:12px;font-weight:500}.tenant-invoice__total-value{color:#fde68a;font-size:16px;font-weight:700}.tenant-notice{background:var(--bg);border-radius:var(--radius-md);border:1px solid var(--border-light);border-left:3px solid var(--accent);padding:16px}.tenant-notice__title{color:var(--text-primary);margin-bottom:6px;font-size:14px;font-weight:600}.tenant-notice__content{color:var(--text-secondary);white-space:pre-line;font-size:13px;line-height:1.6}.tenant-notice__date{color:var(--text-muted);margin-top:10px;font-size:11px}.tenant-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.tenant-modal{background:var(--surface);border-radius:var(--radius-xl);text-align:center;width:100%;max-width:400px;padding:32px;animation:.25s scaleIn;position:relative}@media (width<=640px){.tenant-contract-grid{grid-template-columns:1fr}.tenant-nav{width:100%}.tenant-nav__item{text-align:center;flex:1}.tenant-header-row{flex-direction:column}}
