.navbar{width:100%;position:sticky;top:0;z-index:100;background:#f8f6f2e0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(24,50,45,.06);box-shadow:0 4px 18px #00000008}.navbar-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.navbar-left{display:flex;align-items:center;gap:1.4rem;min-width:0}.navbar-main{display:flex;align-items:center;gap:.8rem}.navbar-right{display:flex;align-items:center;justify-content:flex-end;gap:.7rem}.navbar-logo{display:flex;align-items:center;gap:.7rem;text-decoration:none;flex-shrink:0}.logo-icon{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,#e78059,#dca74d);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;box-shadow:0 8px 18px #e780592e}.logo-text{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:#18322d}.nav-pill{appearance:none;border:none;background:transparent;text-decoration:none;color:#355b54;font-weight:500;font-size:.98rem;line-height:1;padding:.72rem 1rem;border-radius:999px;cursor:pointer;transition:background-color .22s ease,color .22s ease,transform .22s ease}.nav-pill:hover{background-color:#e780591f;color:#e78059;transform:translateY(-1px)}.primary-btn{text-decoration:none;padding:.78rem 1.2rem;border-radius:14px;background:linear-gradient(135deg,#e78059,#dca74d);color:#fff;font-weight:600;transition:transform .22s ease,box-shadow .22s ease,opacity .22s ease;box-shadow:0 10px 20px #e7805929}.primary-btn:hover{transform:translateY(-1px);box-shadow:0 14px 22px #e7805938;opacity:.96}.logout-btn{font-family:inherit}.hamburger{display:none;width:44px;height:44px;border:none;background:#e7805914;border-radius:12px;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px;transition:background-color .22s ease}.hamburger:hover{background:#e7805924}.hamburger span{display:block;width:20px;height:2px;border-radius:999px;background-color:#18322d;transition:transform .28s ease,opacity .28s ease}.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{max-height:0;overflow:hidden;opacity:0;transition:max-height .3s ease,opacity .25s ease;background:#f8f6f2f5;border-top:1px solid rgba(24,50,45,.05)}.mobile-menu.open{max-height:500px;opacity:1}.mobile-menu-inner{max-width:1200px;margin:0 auto;padding:.5rem 2rem 1.2rem;display:flex;flex-direction:column;gap:.35rem}.mobile-link{appearance:none;border:none;background:transparent;text-decoration:none;color:#355b54;font-family:inherit;font-size:1rem;font-weight:500;text-align:left;padding:.95rem 1rem;border-radius:16px;cursor:pointer;transition:background-color .22s ease,color .22s ease}.mobile-link:hover{background-color:#e780591f;color:#e78059}.mobile-primary{background:linear-gradient(135deg,#e7805924,#dca74d24);color:#c96f4d;font-weight:700}.mobile-logout{font-family:inherit}.desktop-only{display:flex}@media(max-width:980px){.desktop-only{display:none}.hamburger{display:flex}.navbar-container{padding:.95rem 1.25rem}.mobile-menu-inner{padding:.5rem 1.25rem 1.2rem}}@media(max-width:640px){.navbar-container{padding:.9rem 1rem}.mobile-menu-inner{padding:.45rem 1rem 1rem}.logo-text{font-size:1.2rem}.logo-icon{width:36px;height:36px;border-radius:10px}.hamburger{width:42px;height:42px}}.spinner-page{height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:Poppins,sans-serif}.spinner-wrapper{position:relative;width:100px;height:100px}.spinner-ring{width:100px;height:100px;border:4px solid #eee;border-top:4px solid #e78059;border-radius:50%;animation:spin 1.2s linear infinite}.spinner-house{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:40px}.spinner-logo{margin-top:14px;font-size:28px;font-weight:700}.logo-nest{color:#333}.logo-mate{color:#e78059}.spinner-text{font-size:14px;color:#777}.spinner-dots{margin-top:10px}.spinner-dots span{width:8px;height:8px;background:#e78059;border-radius:50%;display:inline-block;margin:0 4px;animation:blink 1.4s infinite}.spinner-dots span:nth-child(2){animation-delay:.2s}.spinner-dots span:nth-child(3){animation-delay:.4s}@keyframes spin{to{transform:rotate(360deg)}}@keyframes blink{0%,80%,to{opacity:0}40%{opacity:1}}.footer{margin-top:auto;background-color:#f8f6f2;border-top:1px solid rgba(24,50,45,.06);box-shadow:0 -4px 18px #00000008;padding:0 2rem}.footer-container{width:100%;max-width:1200px;margin:0 auto;min-height:84px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem}.footer-logo{display:flex;align-items:center;gap:.6rem;justify-self:start}.footer-icon{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#e78059,#dca74d);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}.footer-text{font-weight:700;font-size:1.2rem;color:#18322d}.footer-copy{margin:0;text-align:center;color:#6f847d;font-size:.9rem;justify-self:center}.footer-links{display:flex;gap:2rem;justify-self:end}.footer-links a{text-decoration:none;color:#355b54;font-weight:500}@media(max-width:768px){.footer{padding:1rem 1.25rem}.footer-container{min-height:auto;grid-template-columns:1fr;gap:.8rem}.footer-logo{transition:transform .2s ease}.footer-logo:hover{transform:translateY(-1px)}.footer-copy,.footer-links{justify-self:start}.footer-links{gap:1.2rem;flex-wrap:wrap}}.footer-pill{padding:.45rem .9rem;border-radius:20px;text-decoration:none;color:#355b54;font-weight:500;transition:all .25s ease}.footer-pill:hover{background-color:#e780591f;color:#e78059;transform:translateY(-1px)}.homepage{width:100%;background-color:#f8f6f2;color:#18322d;font-family:Arial,Helvetica,sans-serif;overflow-x:hidden}.hero{position:relative;width:100%;min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:0 24px;background-size:cover;background-position:center;background-repeat:no-repeat}.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,#f8f6f2e6,#f8f6f2bf 35%,#f8f6f233)}.hero-content{position:relative;z-index:2;width:100%;max-width:1200px;margin:0 auto}.hero-text{max-width:620px}.hero-badge{display:inline-block;background-color:#f8e6db;color:#e67a52;padding:.7rem 1rem;border-radius:999px;font-size:.95rem;margin-bottom:1.5rem}.hero h1{font-size:5rem;line-height:1;margin:0 0 1.5rem;font-weight:800}.hero h1 span{color:#e67a52}.hero p{font-size:1.3rem;line-height:1.7;color:#5b746e;margin-bottom:2rem}.hero-search{display:flex;align-items:center;gap:.5rem;width:100%;max-width:560px;background-color:#fff;border-radius:18px;padding:.5rem;box-shadow:0 10px 30px #00000014;margin-bottom:1.5rem}.hero-search input{flex:1;min-width:0;border:none;outline:none;padding:1rem 1.2rem;font-size:1rem;border-radius:14px;background:transparent}.hero-search button{border:none;background:linear-gradient(135deg,#e78059,#dca74d);color:#fff;padding:1rem 1.8rem;border-radius:14px;font-size:1rem;cursor:pointer;white-space:nowrap}.hero-stats{display:flex;gap:1.5rem;flex-wrap:wrap;color:#6f847d;font-size:1rem}.section-label{color:#e67a52;font-size:.95rem;letter-spacing:1px;font-weight:700;padding-top:3rem;margin:3rem 0 1rem;text-transform:uppercase}.how-it-works{width:100%;text-align:center;padding:18rem 2rem 6rem;background-color:#fffdf9}.how-it-works h2{font-size:3.5rem;margin:0 0 3rem}.steps-grid{width:100%;max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.step-card{padding:1rem}.step-icon{width:74px;height:74px;margin:0 auto 1.5rem;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;background:linear-gradient(135deg,#e78059,#dca74d)}.step-number{color:#6f847d;font-weight:700;letter-spacing:1px;font-size:.9rem}.step-card h3{font-size:2rem;margin:.8rem 0 1rem}.step-card p:last-child{color:#5b746e;line-height:1.7;font-size:1.05rem}.cta-section{width:100%;padding:3rem 2rem 6rem;background-color:#fffdf9}.cta-box{width:100%;max-width:1200px;margin:0 auto;background:linear-gradient(135deg,#3f816f,#5b9a84);border-radius:28px;text-align:center;padding:5rem 2rem;color:#fff}.cta-box h2{font-size:3.5rem;margin-bottom:1rem}.cta-box p{font-size:1.3rem;max-width:680px;margin:0 auto 2rem;line-height:1.7;color:#ffffffe6}.cta-button{display:inline-block;text-decoration:none;background:linear-gradient(135deg,#e78059,#dca74d);color:#fff;padding:1rem 2rem;border-radius:14px;font-weight:700}.featured-rooms{width:100%;padding:6rem 2rem;text-align:center;background-color:#f8f6f2}.featured-rooms h2{font-size:4rem;margin:.5rem 0 1rem}.featured-subtitle{max-width:700px;margin:0 auto 4rem;color:#5b746e;font-size:1.3rem;line-height:1.7}.listings-grid{width:100%;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2rem;text-align:left}.room-card{background-color:#fffdf9;border-radius:24px;overflow:hidden;box-shadow:0 8px 24px #0000000f;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;height:100%}.room-image-wrapper{position:relative;aspect-ratio:4 / 3}.room-image{width:100%;height:320px;object-fit:cover;object-position:center;display:block}.fav-btn{position:absolute;top:16px;right:16px;width:48px;height:48px;border:none;border-radius:50%;background-color:#fffffff2;font-size:1.4rem;cursor:pointer}.room-tags{position:absolute;left:16px;bottom:16px;display:flex;gap:.7rem;flex-wrap:wrap}.room-tag{background-color:#fffffff2;color:#18322d;padding:.45rem .85rem;border-radius:999px;font-size:.9rem}.room-info{padding:1.4rem 1.4rem 1.6rem;display:flex;flex-direction:column;flex:1}.room-title-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}.room-title-row h3{margin:0;font-size:1.5rem}.room-rating{white-space:nowrap;color:#18322d;font-weight:600}.room-city{color:#6f847d;margin:.9rem 0 1.3rem;font-size:1.05rem}.room-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:auto}.room-price{color:#e67a52;font-size:2rem;font-weight:800}.room-flatmates{color:#6f847d;font-size:1rem}@media(max-width:1100px){.hero h1{font-size:4rem}.steps-grid,.rooms-grid{grid-template-columns:1fr;max-width:700px}}@media(max-width:768px){.hero{min-height:auto;padding:5rem 1.25rem}.hero-content,.steps-grid,.rooms-grid,.cta-box{max-width:100%}.hero h1{font-size:3rem}.hero p,.featured-subtitle,.cta-box p{font-size:1.05rem}.hero-search{flex-direction:column;align-items:stretch}.hero-search button{width:100%}.how-it-works h2,.cta-box h2,.featured-rooms h2{font-size:2.4rem}.room-price{font-size:1.6rem}.room-bottom,.room-title-row,.hero-stats h3{margin:0 0 .6rem;font-size:1.4rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}}.room-card-link{text-decoration:none;color:inherit;display:block}.listing-card{background-color:#fffdf9;border-radius:24px;overflow:hidden;box-shadow:0 8px 24px #0000000f;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;height:100%}.listing-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px #00000014}.listing-card-link{display:block;text-decoration:none;color:inherit}.listing-image-wrapper{position:relative;width:100%;aspect-ratio:4 / 3;height:auto;overflow:hidden}.listing-image{width:100%;height:100%;object-fit:cover;display:block}.favorite-btn{position:absolute;top:14px;right:14px;width:38px;height:38px;border:none;border-radius:50%;background:#ffffffd9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-size:1.1rem;color:#18322d;cursor:pointer;display:flex;align-items:center;justify-content:center}.favorite-btn:hover{transform:scale(1.1)}.listing-tags{position:absolute;left:16px;bottom:16px;display:flex;gap:.7rem;flex-wrap:wrap}.listing-tag{background-color:#fffffff2;color:#18322d;padding:.5rem .95rem;border-radius:999px;font-size:.95rem;font-weight:500}.listing-info{padding:1.4rem 1.4rem 1.6rem;display:flex;flex-direction:column;flex:1}.listing-title{margin:0 0 .8rem;font-size:2rem;line-height:1.2;font-weight:700;color:#18322d;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.listing-city{margin:0 0 1.6rem;color:#6f847d;font-size:1.15rem}.listing-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:auto}.listing-price{margin:0;color:#e67a52;font-size:2rem;font-weight:800}.listing-extra{margin:0;color:#6f847d;font-size:1.05rem}.listing-tag.smoking,.listing-tag.no-smoking{background:#fffffff2}.listings-page{max-width:1200px;margin:0 auto;padding:3rem 2rem 5rem}.listings-page h1{font-size:3rem;margin-bottom:2.5rem;color:#18322d}.listings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}@media(max-width:1100px){.listings-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:700px){.listings-page h1{font-size:2.5rem}.listings-grid{grid-template-columns:1fr}}.favorite-success{text-align:center;margin-top:6px;font-size:.9rem;color:#3f816f}.filters-bar{display:flex;gap:12px;flex-wrap:wrap;margin:20px 0 30px;align-items:center}.filters-bar input,.filters-bar select{padding:8px 12px;border-radius:8px;border:1px solid #ddd;font-size:14px}.filters-bar label{display:flex;align-items:center;gap:6px;font-size:14px}.favorite-popup{position:absolute;top:18px;right:72px;z-index:20;display:inline-flex!important;align-items:center!important;gap:6px;width:max-content!important;height:auto!important;min-width:0!important;min-height:0!important;max-width:none!important;max-height:none!important;margin:0!important;padding:.55rem .95rem!important;border:none!important;border-radius:999px!important;background:#c95b5b!important;color:#fff!important;font-family:Arial,Helvetica,sans-serif!important;font-size:.9rem!important;font-weight:600!important;line-height:1.1!important;white-space:nowrap!important;text-align:center!important;box-shadow:0 8px 18px #00000024!important;animation:toastIn .18s ease}.favorite-popup.success{background:#3f816f!important}.favorite-popup.error{background:#c95b5b!important}@keyframes toastIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.login-page{width:100%;flex:1;background:#f6f7fb;padding:40px 20px;display:flex;justify-content:center;align-items:center}.login-card{width:100%;max-width:480px;background:#fff;border-radius:20px;padding:32px;box-shadow:0 10px 30px #00000014}.login-card h1{margin:0 0 8px;font-size:2rem;color:#222}.login-subtitle{margin:0 0 28px;color:#666;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:18px}.login-form-group{display:flex;flex-direction:column;gap:8px}.login-form-group label{font-size:.95rem;font-weight:600;color:#333}.login-form-group input{width:100%;padding:12px 14px;border:1px solid #d8dce5;border-radius:12px;font-size:1rem;background:#fff;color:#222;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.login-form-group input:focus{outline:none;border-color:#7c5cff;box-shadow:0 0 0 4px #7c5cff1f}.login-button{width:100%;margin-top:8px;border:none;background:#7c5cff;color:#fff;padding:14px 18px;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:transform .15s ease,opacity .2s ease,box-shadow .2s ease;box-shadow:0 8px 20px #7c5cff40}.login-button:hover{opacity:.95;transform:translateY(-1px)}.login-button:active{transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.login-error{margin:6px 0 0;color:#e5484d;font-size:.9rem;font-weight:500}.login-footer-text{margin-top:18px;text-align:center;font-size:.95rem;color:#666}.login-footer-text a{color:#7c5cff;text-decoration:none;font-weight:600}.login-footer-text a:hover{text-decoration:underline}@media(max-width:768px){.login-page{padding:24px 14px}.login-card{padding:22px;border-radius:16px}.login-card h1{font-size:1.7rem}}.signup-page{width:100%;flex:1;background:#f6f7fb;padding:40px 20px;display:flex;justify-content:center;align-items:center}.signup-card{width:100%;max-width:480px;background:#fff;border-radius:20px;padding:32px;box-shadow:0 10px 30px #00000014}.signup-card h1{margin:0 0 8px;font-size:2rem;color:#222}.signup-subtitle{margin:0 0 28px;color:#666;font-size:.95rem}.signup-form{display:flex;flex-direction:column;gap:18px}.signup-form-group{display:flex;flex-direction:column;gap:8px}.signup-form-group label{font-size:.95rem;font-weight:600;color:#333}.signup-form-group input{width:100%;padding:12px 14px;border:1px solid #d8dce5;border-radius:12px;font-size:1rem;background:#fff;color:#222;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.signup-form-group input:focus{outline:none;border-color:#7c5cff;box-shadow:0 0 0 4px #7c5cff1f}.signup-button{width:100%;margin-top:8px;border:none;background:#7c5cff;color:#fff;padding:14px 18px;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:transform .15s ease,opacity .2s ease,box-shadow .2s ease;box-shadow:0 8px 20px #7c5cff40}.signup-button:hover{opacity:.95;transform:translateY(-1px)}.signup-button:active{transform:translateY(0)}.signup-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.signup-error{margin-top:6px;color:#e5484d;font-size:.9rem;font-weight:500}.signup-footer-text{margin-top:18px;text-align:center;font-size:.95rem;color:#666}.signup-footer-text a{color:#7c5cff;text-decoration:none;font-weight:600}.signup-footer-text a:hover{text-decoration:underline}@media(max-width:768px){.signup-page{padding:24px 14px}.signup-card{padding:22px;border-radius:16px}.signup-card h1{font-size:1.7rem}}.profile-page{max-width:1100px;margin:0 auto;padding:3rem 2rem 5rem}.profile-card{background-color:#fffdf9;border-radius:28px;overflow:hidden;box-shadow:0 10px 28px #0000000f;padding:2rem;position:relative;min-height:640px;display:flex;flex-direction:column}.profile-header{display:flex;align-items:flex-start;gap:2rem;margin-bottom:2.5rem;min-height:220px}.profile-avatar{width:220px;height:220px;object-fit:cover;border-radius:24px;flex-shrink:0}.profile-header-info{display:flex;flex-direction:column;justify-content:center;height:220px}.profile-header-info h1{margin:0 0 .8rem;font-size:3rem;line-height:1.1;color:#18322d;min-height:66px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.profile-city{margin:0 0 1.2rem;color:#6f847d;font-size:1.15rem;min-height:20px}.profile-badges{display:flex;flex-wrap:wrap;gap:.8rem;min-height:40px}.profile-badge{background:#f4eee7;color:#18322d;padding:.55rem 1rem;border-radius:999px;font-size:.95rem;font-weight:500}.profile-content{display:flex;flex-direction:column;gap:2rem;flex:1;min-height:280px}.profile-section h2{margin:0 0 1rem;font-size:1.5rem;color:#18322d}.profile-section p{margin:0;color:#5b746e;line-height:1.8;font-size:1.05rem;min-height:40px}.profile-details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem 2rem}.profile-details-grid p{margin:0;color:#355b54}.profile-actions{display:flex;gap:1rem;margin-top:auto}.profile-btn{border:none;border-radius:14px;padding:.95rem 1.4rem;font-size:1rem;font-weight:600;cursor:pointer}.profile-btn.primary,.profile-btn.secondary{background:#e9e9e9;color:#484848}.profile-btn.primary:hover,.profile-btn.secondary:hover{background:linear-gradient(135deg,#e78059,#dca74d);color:#fff;transform:translateY(-1px)}.profile-loading{text-align:center;margin-top:4rem;color:#5b746e;font-size:1.1rem}.profile-edit-top{position:absolute;top:20px;right:20px;background:#e9e9e9;color:#333;border:none;padding:8px 14px;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:800;font-style:strong}.profile-edit-top:hover{background:linear-gradient(135deg,#e78059,#dca74d);color:#fff}.profile-edit-top:active{background:#dcdcdc}.profile-listings-count{margin:.4rem 0 .8rem;font-weight:500;color:#555}@media(max-width:768px){.profile-page{padding:2rem 1rem 4rem}.profile-card{padding:1.5rem;min-height:auto}.profile-header{flex-direction:column;align-items:flex-start;min-height:auto}.profile-avatar{width:100%;max-width:280px;height:280px}.profile-header-info{height:auto}.profile-header-info h1{font-size:2.2rem}.profile-details-grid{grid-template-columns:1fr}.profile-actions{flex-direction:column;margin-top:1rem}}.edit-profile-page{max-width:1100px;margin:0 auto;padding:3rem 2rem 5rem}.edit-profile-card{background-color:#fffdf9;border-radius:28px;box-shadow:0 10px 28px #0000000f;padding:2rem}.edit-profile-header{display:flex;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:2rem}.edit-profile-header h1{margin:0 0 .5rem;font-size:3rem;line-height:1.1;color:#18322d}.edit-profile-header p{margin:0;color:#6f847d;font-size:1.1rem}.edit-profile-preview{width:180px;height:180px;object-fit:cover;border-radius:24px;flex-shrink:0;background:#f1ede7}.edit-profile-form{display:flex;flex-direction:column;gap:1.5rem}.edit-profile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem 1.6rem}.form-group{display:flex;flex-direction:column;gap:.55rem}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:600;color:#18322d}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd6cc;border-radius:14px;padding:.95rem 1rem;font-size:1rem;background:#fff;color:#18322d;outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#dca74d;box-shadow:0 0 0 3px #dca74d1f}.form-group input:disabled{background:#f3f0ea;color:#7a7a7a;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:130px}.checkbox-row{display:flex;gap:1rem;flex-wrap:wrap}.checkbox-pill{display:inline-flex;align-items:center;gap:.6rem;background:#f4eee7;border-radius:999px;padding:.8rem 1rem;color:#18322d;font-weight:500}.checkbox-pill input{accent-color:#e78059}.form-error{margin:0;color:#c0392b;font-weight:500}.form-actions{display:flex;justify-content:flex-end;gap:1rem}.edit-profile-btn{border:none;border-radius:14px;padding:.95rem 1.4rem;font-size:1rem;font-weight:600;cursor:pointer}.edit-profile-btn.primary{background:linear-gradient(135deg,#e78059,#dca74d);color:#fff}.edit-profile-btn.primary:hover{background:linear-gradient(135deg,#e06f4b,#dca74d);transform:translateY(-1px)}.edit-profile-btn.secondary{background:#edf3ef;color:#18322d}.edit-profile-btn.secondary:hover{background:#e0e8e3;transform:translateY(-1px)}.edit-profile-btn:disabled{opacity:.7;cursor:not-allowed}@media(max-width:768px){.edit-profile-page{padding:2rem 1rem 4rem}.edit-profile-card{padding:1.5rem}.edit-profile-header{flex-direction:column;align-items:flex-start}.edit-profile-header h1{font-size:2.2rem}.edit-profile-preview{width:140px;height:140px}.edit-profile-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}}.create-listing-page{width:100%;flex:1;min-height:100%;background:#f6f7fb;padding:40px 20px;display:flex;justify-content:center;align-items:flex-start}.create-listing-card{width:100%;max-width:720px;background:#fff;border-radius:20px;padding:32px;box-shadow:0 10px 30px #00000014}.create-listing-card h1{margin:0 0 8px;font-size:2rem;color:#222}.create-listing-subtitle{margin:0 0 28px;color:#666;font-size:.95rem}.create-listing-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:8px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group label{font-size:.95rem;font-weight:600;color:#333}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 14px;border:1px solid #d8dce5;border-radius:12px;font-size:1rem;background:#fff;color:#222;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#7c5cff;box-shadow:0 0 0 4px #7c5cff1f}.form-group textarea{min-height:120px;resize:vertical}.checkbox-group{display:flex;gap:20px;flex-wrap:wrap;margin-top:4px}.checkbox-item{display:flex;align-items:center;gap:8px;font-size:.95rem;color:#333}.checkbox-item input[type=checkbox]{width:16px;height:16px;accent-color:#7c5cff}.create-listing-button{margin-top:10px;border:none;background:linear-gradient(135deg,#e78059,#dca74d);color:#fff;padding:14px 18px;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:transform .15s ease,opacity .2s ease,box-shadow .2s ease;box-shadow:0 8px 20px #7c5cff40}.create-listing-button:hover{opacity:.95;transform:translateY(-1px)}.create-listing-button:active{transform:translateY(0)}@media(max-width:768px){.create-listing-page{padding:24px 14px}.create-listing-card{padding:22px;border-radius:16px}.create-listing-card h1{font-size:1.7rem}.form-row{grid-template-columns:1fr}.checkbox-group{flex-direction:column;gap:12px}}.create-listing-preview{width:220px;height:220px;object-fit:cover;border-radius:18px;border:1px solid #E5E5E5;display:block;margin:1rem auto 1.5rem}.edit-listing-page{min-height:100vh;background-color:#f8f6f2;padding:2rem;font-family:Arial,Helvetica,sans-serif}.edit-listing-card{max-width:800px;margin:0 auto;background:#fff;border-radius:24px;padding:2rem;box-shadow:0 8px 24px #0000000f;border:1px solid rgba(0,0,0,.05)}.edit-listing-header{margin-bottom:2rem}.edit-listing-header h2{margin:0 0 .4rem;font-size:2rem;color:#222}.edit-listing-header p{margin:0;color:#666}.edit-listing-form{display:flex;flex-direction:column;gap:1.5rem}.edit-listing-section{padding-top:.5rem}.edit-listing-section h3{margin-bottom:1rem;font-size:1.1rem;color:#333}.edit-listing-form label{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1rem;font-weight:500;color:#333}.edit-listing-form input,.edit-listing-form textarea,.edit-listing-form select{width:100%;padding:.9rem 1rem;border:1px solid #ddd;border-radius:14px;font-size:1rem;background:#fff;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.edit-listing-form input:focus,.edit-listing-form textarea:focus,.edit-listing-form select:focus{outline:none;border-color:#dca74d;box-shadow:0 0 0 3px #dca74d26}.edit-listing-form input:disabled{background:#f3f3f3;color:#777;cursor:not-allowed}.edit-listing-form textarea{min-height:130px;resize:vertical}.checkbox-label{flex-direction:row!important;align-items:center;gap:.65rem!important;font-weight:400!important}.checkbox-label input{width:auto;margin:0}.edit-listing-error{color:#b42318;background:#fef3f2;border:1px solid #fecdca;padding:.85rem 1rem;border-radius:12px;margin:0}.edit-listing-actions{display:flex;justify-content:flex-end;gap:.4rem;margin-top:.5rem}.edit-listing-btn{border:none;background:#e9e9e9;color:#484848;padding:.9rem 1.4rem;border-radius:14px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .15s ease,opacity .2s ease}.edit-listing-btn:hover{transform:translateY(-1px);background:linear-gradient(135deg,#e78059,#dca74d);color:#fff}.edit-listing-btn-secondary{border:none;border-radius:14px;padding:.95rem 1.4rem;font-size:1rem;font-weight:600;cursor:pointer;background:#e9e9e9;color:#484848}.edit-listing-btn-secondary:hover{transform:translateY(-1px);background:linear-gradient(135deg,#e78059,#dca74d);color:#fff}.edit-listing-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}@media(max-width:768px){.edit-listing-page{padding:1rem}.edit-listing-card{padding:1.25rem;border-radius:18px}.edit-listing-header h2{font-size:1.6rem}.edit-listing-actions{justify-content:stretch}.edit-listing-btn{width:100%}}.edit-listing-preview{width:220px;height:220px;object-fit:cover;border-radius:14px;border:1px solid #e5e5e5}.listing-card-wrapper{position:relative}.favorite-popup{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000bf;color:#fff;padding:10px 18px;border-radius:20px;font-size:14px;font-weight:500;pointer-events:none;animation:fadePopup 1.8s ease}@keyframes fadePopup{0%{opacity:0;transform:translate(-50%,-40%)}20%{opacity:1;transform:translate(-50%,-50%)}80%{opacity:1}to{opacity:0}}.favorites-page{max-width:1200px;margin:0 auto;padding:2rem}.favorites-page h1{font-size:3rem;margin-bottom:2.5rem;margin-bottom:2rem}.favorites-empty{font-size:1.25rem;color:#555}.favorites-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start}@media(max-width:992px){.favorites-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.favorites-grid{grid-template-columns:1fr}}.conversations-page{background-color:#f8f6f2;padding:2rem}.conversations-container{max-width:900px;margin:0 auto;height:clamp(500px,72vh,760px);display:flex;flex-direction:column}.conversations-header{margin-bottom:1.5rem;flex-shrink:0;position:sticky;top:0;background:#f8f6f2;z-index:5;box-shadow:0 4px 10px #00000008}.conversations-title{margin:0;font-size:2rem;color:#222}.conversations-list{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;padding-top:.5rem;padding-right:4px}.conversation-card{background:#fff;border-radius:20px;border:1px solid rgba(0,0,0,.05);box-shadow:0 6px 18px #0000000d;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease,background .15s ease;flex-shrink:0}.conversation-card:hover{transform:translateY(-2px);box-shadow:0 12px 26px #00000014;background:#faf9f7}.conversation-link{display:grid;grid-template-columns:64px 1fr 96px;align-items:center;gap:1rem;text-decoration:none;color:inherit;padding:1.2rem 1.3rem}.conversation-left{display:flex;align-items:center;justify-content:center}.conversation-center{min-width:0}.conversation-right{display:flex;align-items:center;justify-content:flex-end;gap:1rem}.conversation-user-image{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid rgba(0,0,0,.05);background:#f2f2f2}.conversation-listing-image{width:88px;height:72px;border-radius:14px;object-fit:cover;background:#f2f2f2}.conversation-info{display:flex;flex-direction:column;gap:.45rem}.conversation-user{margin:0;font-size:1.15rem;font-weight:700;color:#222}.conversation-listing-title{margin:0;font-size:.98rem;color:#444;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-meta{display:flex;align-items:center;gap:1rem;margin-top:.25rem}.conversation-city{color:#777;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-price{color:#222;font-weight:700;font-size:.95rem;background:#f2eee7;padding:8px 14px;border-radius:999px;white-space:nowrap}.conversations-loading,.conversations-empty{min-height:50vh;display:flex;align-items:center;justify-content:center;font-size:1.05rem;color:#666;padding:2rem}.conversations-list::-webkit-scrollbar{width:8px}.conversations-list::-webkit-scrollbar-thumb{background:#0000001f;border-radius:999px}.conversations-list::-webkit-scrollbar-track{background:transparent}@media(max-width:768px){.conversations-page{padding:1rem}.conversations-container{height:clamp(420px,70vh,680px)}.conversations-title{font-size:1.6rem}.conversation-link{grid-template-columns:52px 1fr;gap:.9rem;padding:1rem}.conversation-right{display:none}.conversation-user-image{width:48px;height:48px}.conversation-price{font-size:.95rem;padding:6px 12px}}.listing-details-page{max-width:1200px;margin:0 auto;padding:2rem;font-family:Arial,Helvetica,sans-serif}.listing-details-card{background-color:#fffdf9;border-radius:28px;overflow:hidden;box-shadow:0 10px 28px #0000000f;max-height:clamp(620px,78vh,820px);display:flex;flex-direction:column}.listing-details-image-wrapper{position:relative;width:100%;height:clamp(260px,42vh,400px);overflow:hidden;flex-shrink:0}.listing-details-image{width:100%;height:100%;object-fit:cover;display:block}.listing-details-tags{position:absolute;left:24px;bottom:24px;display:flex;gap:.8rem;flex-wrap:wrap}.listing-details-tag{background:#fffffff2;color:#18322d;padding:.6rem 1rem;border-radius:999px;font-size:.95rem;font-weight:500}.listing-details-content{padding:1.6rem 2rem 1.8rem;overflow:hidden}.listing-details-header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:1.2rem}.listing-details-header h1{margin:0 0 .5rem;font-size:2.5rem;line-height:1.1;color:#18322d}.listing-details-city{margin:0;color:#6f847d;font-size:1.1rem}.listing-details-price{margin:0;color:#e67a52;font-size:2.2rem;font-weight:800;white-space:nowrap}.listing-details-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem 2rem;margin-bottom:1.6rem;color:#355b54}.listing-details-meta p{margin:0;font-size:1rem}.listing-details-actions{display:flex;gap:1rem;margin-bottom:1.8rem}.listing-details-btn{border:none;border-radius:14px;padding:.9rem 1.3rem;font-size:1rem;font-weight:600;cursor:pointer;background:#edf3ef;color:#18322d}.listing-details-btn:hover{background:linear-gradient(135deg,#e78059,#dca74d);color:#fff}.listing-details-btn.primary,.listing-details-btn.secondary{background:#edf3ef;color:#18322d}.listing-details-btn.primary:hover,.listing-details-btn.secondary:hover{background:linear-gradient(135deg,#e78059,#dca74d);color:#fff}.listing-details-description h2{margin:0 0 .8rem;font-size:1.5rem;color:#18322d}.listing-details-description p{margin:0;color:#5b746e;line-height:1.6;font-size:1rem}.favorite-success{margin-top:10px;color:#3f816f;font-weight:500;font-size:.95rem}@media(max-width:768px){.listing-details-page{padding:1rem}.listing-details-card{max-height:none}.listing-details-image-wrapper{height:280px}.listing-details-content{padding:1.25rem}.listing-details-header{flex-direction:column;gap:.8rem}.listing-details-header h1{font-size:2rem}.listing-details-price{font-size:1.9rem}.listing-details-meta{grid-template-columns:1fr}.listing-details-actions{flex-direction:column}}.chat-page{background-color:#f8f6f2;padding:2rem}.chat-container{max-width:900px;height:clamp(500px,70vh,700px);margin:0 auto;background:#fff;border-radius:28px;border:1px solid rgba(0,0,0,.05);box-shadow:0 10px 28px #0000000f;display:flex;flex-direction:column;overflow:hidden}.chat-header{padding:1.5rem 1.75rem;border-bottom:1px solid rgba(0,0,0,.06);background:#fff}.chat-title{margin:0;font-size:1.8rem;color:#222}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;background:linear-gradient(to bottom,#fcfbf9,#f8f6f2)}.chat-empty{margin:auto;color:#666;font-size:1rem}.chat-message{display:flex;flex-direction:column;max-width:72%}.chat-message-mine{align-self:flex-end;align-items:flex-end}.chat-message-other{align-self:flex-start;align-items:flex-start}.chat-message-header{margin-bottom:.35rem}.chat-sender{font-size:.9rem;color:#666;font-weight:600}.chat-bubble{padding:.9rem 1rem;border-radius:20px;word-break:break-word;box-shadow:0 4px 12px #0000000a}.chat-message-mine .chat-bubble{background:linear-gradient(135deg,#e78059,#dca74d);color:#fff;border-bottom-right-radius:8px}.chat-message-other .chat-bubble{background:#fff;color:#222;border:1px solid rgba(0,0,0,.06);border-bottom-left-radius:8px}.chat-text{margin:0;line-height:1.5;font-size:.98rem}.chat-input-form{display:flex;gap:.75rem;padding:1rem 1.25rem 1.25rem;border-top:1px solid rgba(0,0,0,.06);background:#fff}.chat-input{flex:1;border:1px solid #ddd;border-radius:999px;padding:.95rem 1rem;font-size:1rem;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.chat-input:focus{outline:none;border-color:#dca74d;box-shadow:0 0 0 3px #dca74d26}.chat-send-button{border:none;border-radius:999px;padding:.95rem 1.3rem;font-size:.98rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#e78059,#dca74d);cursor:pointer;transition:transform .15s ease,opacity .2s ease;white-space:nowrap}.chat-send-button:hover{transform:translateY(-1px)}.chat-send-button:active{transform:translateY(0)}@media(max-width:768px){.chat-page{padding:1rem}.chat-container{height:calc(100vh - 120px);border-radius:20px}.chat-header{padding:1.1rem 1rem}.chat-title{font-size:1.5rem}.chat-messages{padding:1rem}.chat-message{max-width:88%}.chat-input-form{padding:.9rem}.chat-send-button{padding:.9rem 1.1rem}.chat-header-top{align-items:flex-start}.chat-refresh-button{padding:.6rem .9rem;font-size:.9rem}}.chat-header-info{display:flex;align-items:center;gap:12px}.chat-user-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid rgba(0,0,0,.05)}.chat-header-info{display:flex;align-items:center;gap:.9rem}.chat-header-text{display:flex;flex-direction:column}.chat-user-avatar{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid rgba(0,0,0,.05);background:#f2f2f2}.chat-subtitle{margin:.2rem 0 0;color:#777;font-size:.95rem}.chat-header-top{display:flex;justify-content:space-between;align-items:center;gap:1rem}.chat-refresh-button{border:1px solid rgba(0,0,0,.08);background:#fff;color:#333;border-radius:999px;padding:.7rem 1rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.chat-refresh-button:hover{background:#f7f4ee;border-color:#0000001f}.chat-refresh-button:disabled{opacity:.6;cursor:not-allowed}.my-listings-page{max-width:1200px;margin:0 auto;padding:2rem}.my-listings-page h2{margin-bottom:1.5rem}.my-listings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}.my-listing-card{background-color:#fff;border:1px solid rgba(0,0,0,.08);border-radius:16px;overflow:hidden;padding:1rem;box-shadow:0 4px 12px #0000000a}.my-listing-image{width:100%;height:200px;object-fit:cover;border-radius:12px;margin-bottom:1rem}.my-listing-card h3{margin-bottom:.5rem}.my-listing-card p{margin:.3rem 0}.my-listing-actions{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.my-listing-actions a,.my-listing-actions button{border:none;background:#e9e9e9;color:#484848;padding:.65rem 1rem;border-radius:10px;cursor:pointer;text-decoration:none;font-weight:700;font-size:.95rem}.my-listing-actions button:hover,.my-listing-actions a:hover{background:linear-gradient(135deg,#e78059,#dca74d);color:#fff;transform:translateY(-1px)}.about-page{background-color:#f8f6f2;color:#1f1f1f;min-height:100vh}.about-hero{padding:6rem 2rem 5rem;background:linear-gradient(135deg,#fffaf5,#f3ede4);border-bottom:1px solid rgba(0,0,0,.05)}.about-hero-content{max-width:900px;margin:0 auto;text-align:center}.about-title{font-size:3rem;line-height:1.1;font-weight:700;margin-bottom:1.5rem;color:#1f1f1f}.about-subtitle{font-size:1.15rem;line-height:1.8;color:#5f5b53;max-width:700px;margin:0 auto}.about-section{padding:5rem 2rem}.about-container{max-width:1000px;margin:0 auto}.about-heading{font-size:2rem;font-weight:700;margin-bottom:1.5rem;color:#1f1f1f}.about-text{font-size:1.05rem;line-height:1.9;color:#4f4a43;margin-bottom:1.25rem;max-width:800px}.about-solution{background-color:#fffdf9}.about-features{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:2rem}.about-feature{background-color:#fff;padding:1.8rem;border-radius:18px;box-shadow:0 8px 24px #0000000f;border:1px solid rgba(0,0,0,.04);transition:transform .2s ease,box-shadow .2s ease}.about-feature:hover{transform:translateY(-4px);box-shadow:0 12px 28px #00000014}.feature-title{font-size:1.2rem;font-weight:600;margin-bottom:.8rem;color:#1f1f1f}.feature-text{font-size:1rem;line-height:1.7;color:#5f5b53}.about-creators{background-color:#f3ede4;border-top:1px solid rgba(0,0,0,.04)}@media(max-width:768px){.about-hero{padding:4.5rem 1.5rem 4rem}.about-title{font-size:2.2rem}.about-subtitle{font-size:1rem;line-height:1.7}.about-section{padding:4rem 1.5rem}.about-heading{font-size:1.6rem}.about-text{font-size:1rem;line-height:1.8}.about-features{grid-template-columns:1fr}.about-feature{padding:1.5rem}}.contact-page{min-height:100vh;background-color:#f8f6f2;padding:4rem 2rem}.contact-container{max-width:900px;margin:0 auto;text-align:center}.contact-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.contact-text{font-size:1rem;color:#5f5b53;line-height:1.8;max-width:650px;margin:0 auto 1rem}.contact-cards{display:flex;gap:2rem;justify-content:center;margin-top:3rem;flex-wrap:wrap}.contact-card{background:#fff;padding:2rem;border-radius:18px;width:260px;box-shadow:0 8px 24px #0000000f;display:flex;flex-direction:column;gap:.8rem}.contact-name{font-size:1.2rem;font-weight:600;margin-bottom:.5rem}.contact-link{text-decoration:none;color:#e78059;font-weight:500;transition:opacity .2s ease}.contact-link:hover{opacity:.7}:root{font-family:Arial,Helvetica,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#18322d;background-color:#f8f6f2}*,*:before,*:after{box-sizing:border-box}html,body,#root{width:100%;min-height:100%;margin:0;padding:0}body{min-width:320px;min-height:100vh;overflow-x:hidden;background-color:#f8f6f2;color:#18322d;font-family:Arial,Helvetica,sans-serif}a{text-decoration:none;color:inherit}button,input,textarea,select{font:inherit}img{display:block;max-width:100%}#root{min-height:100vh}.app-container{width:100%;min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;width:100%;display:flex;flex-direction:column}.page-container{width:100%;max-width:1200px;margin:0 auto;padding:0 2rem}.section-spacing{margin-top:4rem}body{background-color:#f8f7f4;color:#18322d}a,button{color:inherit}@media(max-width:768px){.page-container{padding:0 1.25rem}.section-spacing{margin-top:3rem}}@media(max-width:480px){.page-container{padding:0 1rem}.section-spacing{margin-top:2.5rem}}
