.hidden{display:none}
:root{--bg:var(--color-bg);--fg:var(--color-text);--muted:var(--color-text-muted);--primary:var(--color-primary);--card:var(--color-surface)}
*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--fg);font:16px/1.5 var(--font-sans)}
.container{max-width:1120px;margin:0 auto;padding:0 16px}
.site-header{position:sticky;top:0;background:var(--color-bg);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-1);z-index:10;}
.site-header .container{display:flex;align-items:center;gap:24px;padding:14px 16px}
.header-row{gap:24px}
.logo--brand{font-weight:800;letter-spacing:.02em;color:var(--color-text-strong)}
.header-search{display:flex;align-items:center;gap:8px;flex:1;max-width:760px;margin-inline:auto;border-bottom:2px solid #cbd5e1;padding-bottom:6px}
.header-search .select{display:flex;align-items:center;gap:8px;color:var(--color-text)}
.select--ghost select{appearance:none;background:transparent;color:var(--color-text);border:0;padding:6px 0}
.select--ghost .icon,.header-search .icon{opacity:.75;color:var(--color-text)}
.select--ghost .caret{opacity:.6}
.header-search .divider{width:1px;height:22px;background:#cbd5e1;display:inline-block}
.header-search input{flex:1;background:transparent;color:var(--color-text);border:0;outline:0;padding:6px 0}
.search-options{display:flex;align-items:center;gap:8px;margin-left:8px}
.checkbox--small{font-size:12px;color:var(--color-text-muted)}
.checkbox--small input[type="checkbox"]{margin:0;width:14px;height:14px}
.actions--icons{display:flex;gap:20px;align-items:center}
.icon-link{position:relative;color:var(--color-text);text-decoration:none;opacity:.85;display:inline-flex;align-items:center;gap:6px}
.icon-link:hover{opacity:1}
.badge{position:static;background:transparent;color:var(--color-text);border-radius:0;padding:0 2px;font-size:14px;min-width:14px;text-align:center}
.actions--icons .divider-v{width:1px;height:24px;background:var(--color-border);display:inline-block;margin:0 4px}

/* Profile dropdown */
.profile-menu{position:absolute;right:16px;top:64px;width:360px;background:#fff;border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-2);padding:12px;z-index:20}
.profile-menu.hidden{display:none}
.pm-head{display:flex;align-items:center;gap:12px;padding:8px 6px}
.pm-avatar{width:36px;height:36px;border-radius:50%;background:#ddd;color:#111;display:flex;align-items:center;justify-content:center;font-weight:700}
.pm-name{font-weight:700}
.pm-rating{color:var(--color-text)}
.pm-row{display:flex;align-items:center;gap:8px;padding:6px 6px}
.pm-spacer{flex:1}
.pm-sep{height:1px;background:var(--color-border);margin:8px 0}
.pm-item{display:block;color:var(--color-text);text-decoration:none;padding:8px 6px}
.pm-item:hover{background:var(--color-surface)}

/* Profile */
.profile{display:grid;grid-template-columns:280px 1fr;gap:32px;padding:24px 0}
.profile-sidebar{position:sticky;top:90px}
.ps-avatar{width:128px;height:128px;border-radius:50%;overflow:hidden;background:#e5e7eb;display:flex;align-items:center;justify-content:center}
.ps-avatar img{width:100%;height:100%;object-fit:cover}
.ps-name{font-weight:800;margin:12px 0}
.ps-nav{display:flex;flex-direction:column;gap:8px}
.ps-link{color:var(--color-text);text-decoration:none;padding:8px 0}
.ps-link.active{font-weight:800}

/* My listings toolbar */
.toolbar{display:flex;gap:24px;align-items:center;margin-bottom:16px}
.tool-btn{display:flex;align-items:center;gap:12px;border:2px solid var(--color-border);border-radius:12px;padding:14px 18px;color:#111;text-decoration:none;font-weight:800}
.tool-btn--ghost{background:#fff}
.tb-ico{opacity:.9}
.avatar-wrap{position:relative;width:128px}
.profile .avatar{position:relative;width:128px;height:128px;border-radius:50%;background:#e5e7eb;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.profile .avatar img{width:100%;height:100%;object-fit:cover}
.avatar-change{position:absolute;right:0;bottom:0;border:0;background:#111827;color:#fff;border-radius:999px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-2);cursor:pointer}
.profile .name{font-weight:700;margin-bottom:4px}
.profile .muted{color:var(--muted)}
.profile__meta{margin-top:16px;border-top:1px solid var(--color-border);padding-top:12px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-grid label{display:flex;flex-direction:column;gap:6px;color:var(--color-text)}
.form-grid input,.form-grid select{border:1px solid var(--color-border);border-radius:8px;padding:10px 12px;background:#fff;color:var(--color-text)}
.form-grid h3{grid-column:1 / -1;margin:12px 0 4px 0}
.form-grid .actions{grid-column:1 / -1;margin-top:12px}

/* Phones block */
.phones-block{margin:12px 0 24px 0}
.phone-row{display:grid;grid-template-columns:1fr auto;align-items:center;padding:10px 2px}
.phone-left{display:flex;align-items:center;gap:12px;font-weight:800;color:#3C4242;font-size:24px}
.phone-ico{font-size:22px;opacity:.8}
.phone-right{font-size:22px;color:#484848}
.phone-add{display:inline-flex;align-items:center;gap:10px;border:0;background:transparent;color:#484848;font-size:24px;padding:8px 0;cursor:pointer}

/* Profile main form like mock */
.profile-form h2{font-size:40px;margin:24px 0 12px 0}
.pf-row{display:grid;grid-template-columns:280px 1fr 80px;align-items:center;gap:16px;padding:8px 0;border-bottom:1px solid var(--color-border)}
.pf-label{font-weight:800;color:#3C4242;font-size:26px}
.pf-field input,.pf-field select{width:100%;font-size:28px;border:0;border-bottom:2px solid #555;padding:8px 4px;background:transparent}
.pf-counter{color:#9ca3af;text-align:right}
.phones-edit{margin-top:8px}
.phone-edit-row{display:grid;grid-template-columns:28px 1fr auto 32px;align-items:center;gap:12px;padding:8px 0}
.phone-edit-row input{font-size:26px;border:0;border-bottom:2px solid #555;padding:6px 2px;background:transparent}
.phone-edit-row input.phone-input.invalid{border-color:#ef4444}
.phone-edit-row .del{background:transparent;border:0;font-size:28px;cursor:pointer}

/* Snackbar */
.snackbar{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:#111827;color:#fff;padding:12px 16px;border-radius:8px;box-shadow:var(--shadow-2);opacity:0;pointer-events:none;transition:opacity .2s ease}
.snackbar.show{opacity:1}
.snackbar.error{background:#dc2626;color:#fff}

/* Modal */
.modal{position:fixed;inset:0;z-index:30}
.modal.hidden{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.4)}
.modal__content{position:relative;background:#fff;border-radius:16px;max-width:480px;margin:10vh auto;padding:20px;box-shadow:var(--shadow-2)}
.modal__close{position:absolute;top:8px;right:8px;border:0;background:transparent;color:#111;font-size:22px;cursor:pointer}
.tabs{display:flex;gap:8px;margin-bottom:12px}
.tab{border:0;background:transparent;color:#3C4242;border-radius:0;padding:6px 8px;cursor:pointer;font-weight:700}
.tab.active{border-bottom:3px solid #3C4242}
.form-col{display:flex;flex-direction:column;gap:0}
.form-col>label+label,.form-col>label+.password-group,.form-col>.password-group+label,.form-col>.password-group+.password-group{margin-top:18px}
.auth-row{display:flex;justify-content:space-between;align-items:center}
.checkbox{display:flex;align-items:center;gap:6px}
.error{display:none;color:#ef4444;font-size:12px}
.phone-input.invalid + .error{display:block}
.error-block{color:#ef4444;font-size:13px;margin-top:6px}
.brand{display:flex;justify-content:center;margin-bottom:8px}
.brand-logo{font-weight:800;font-size:28px;letter-spacing:.04em}
.brand-divider{border-bottom:2px dotted #888;margin:16px 0}
.password-group{display:flex;align-items:center;gap:8px}
.password-group input{flex:1}
.toggle-pass{border:1px solid var(--color-border);background:#fff;border-radius:8px;padding:6px 8px;cursor:pointer}

/* Floating labels */
.form-col label{position:relative;display:flex;flex-direction:column}
.form-col input{border:2px solid #4b5563;border-radius:8px;padding:18px 16px;font-size:20px}
.form-col .field-caption{position:absolute;left:14px;top:-10px;background:#fff;padding:0 6px;font-size:14px;color:#9ca3af}
.password-field{position:relative;display:flex;align-items:center;margin-top: 18px;}
.password-field label{flex:1}
.password-field .toggle-pass{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:36px;height:36px;border:1px solid var(--color-border);border-radius:8px;background:#fff;cursor:pointer}
.filters{display:flex;gap:8px;padding:8px 16px}
.chip{background:#111827;border:1px solid #374151;color:#e5e7eb;border-radius:999px;padding:8px 12px}
.logo{font-weight:700;color:#fff;text-decoration:none}
.nav{display:flex;gap:16px;margin-left:auto}
.nav__link{color:var(--fg);text-decoration:none;opacity:.85}
.nav__link:hover{opacity:1}
.actions{display:flex;gap:8px;margin-top: 10px;}
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:8px;padding:10px 14px;text-decoration:none}
.btn--primary{background:var(--primary);color:#fff}
.btn--ghost{border:1px solid #374151;color:var(--fg)}
.search{display:flex;gap:8px;width:100%}
.search input{flex:1;border:1px solid #374151;border-radius:8px;background:#0f172a;color:#fff;padding:10px 12px}
.search button{border:0;border-radius:8px;padding:10px 14px;background:#374151;color:#fff}
.hero{padding:48px 0;background:linear-gradient(180deg,rgba(79,70,229,.1),transparent)}
.site-footer{border-top:1px solid var(--color-border);margin-top:48px;background:var(--color-primary);color:var(--color-text)}
.site-footer .container{padding:24px 16px}
.footer-head{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;align-items:flex-start}
.footer-brand .logo{font-weight:700;font-size:20px;margin-bottom:8px}
.social-dots{display:flex;gap:8px;margin-top:8px}
.social-dots .dot{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#111827;color:#e5e7eb;text-decoration:none}
.footer-cta{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px}
.cta-title{font-weight:700;font-size:22px;margin-bottom:6px}
.footer-links-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding-top:16px}
.links-title{color:#9ca3af;margin-bottom:8px;font-size:14px}
.links-col a{display:block;color:#e5e7eb;opacity:.9;text-decoration:none;margin:6px 0}
.links-col a:hover{opacity:1}
.legal-text{font-size:12px;color:#9ca3af;opacity:.9}

/* Listing grid */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:24px 0}
.listing-card{background:#fff;border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-1);overflow:hidden}
.listing-card .media{position:relative}
.listing-card .media>img{display:block;width:100%;height:320px;object-fit:cover}
.listing-card .fav{position:absolute;top:10px;right:10px;background:#ffffffc0;border:0;border-radius:999px;padding:6px;cursor:pointer}
.listing-card .separator{height:6px;border-top:4px solid #d1d5db;border-bottom:4px solid #d1d5db;margin:6px 12px;border-radius:6px}
.listing-card .title{font-weight:800;color:var(--color-text-strong);font-size:20px;line-height:1.2;margin:8px 12px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}
.listing-card .price-row{display:flex;align-items:baseline;gap:8px;margin:8px 12px}
.listing-card .price{font-weight:800;font-size:28px;color:var(--color-text-strong)}
.listing-card .per{color:var(--muted)}
.listing-card .meta{display:flex;align-items:center;gap:8px;margin:8px 12px;color:var(--color-text)}
.listing-card .meta .muted{color:var(--muted)}

/* Search page */
.search-header{margin-bottom:24px;padding:16px 0;border-bottom:1px solid var(--color-border)}
.search-header h1{margin:0 0 12px;font:600 24px/1.2 var(--font-sans)}
.search-info{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.search-query{font-weight:500;color:var(--color-primary)}
.search-type{font-size:14px;color:var(--color-text-muted);background:var(--color-surface);padding:4px 8px;border-radius:4px}
.search-controls{display:flex;align-items:center;gap:12px}
.search-form{display:flex;align-items:center;gap:12px}
.search-results{margin-top:24px}
.no-results{text-align:center;padding:48px 24px;color:var(--color-text-muted)}
.no-results h2{margin:0 0 8px;font:600 20px/1.2 var(--font-sans)}

@media (max-width: 1200px){
  .grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 900px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .listing-card .media>img{height:280px}
}
@media (max-width: 600px){
  .grid{grid-template-columns:1fr}
  .listing-card .media>img{height:240px}
}

.modal__content--auth{max-width:720px;padding:40px}
.auth-header{margin-top:8px;margin-bottom:16px}
.brand-divider{border-bottom:2px dotted #888;margin:16px 0}
.auth-tabs{display:flex;gap:24px;justify-content:flex-end}
.auth-tabs .tab{border:0;background:transparent;font-weight:700;font-size:18px;padding:6px 4px;color:#3C4242}
.auth-tabs .tab.active{border-bottom:3px solid #3C4242}
.password-field{position:relative;display:flex;align-items:center}
.password-field input{padding-right:44px}
.toggle-pass{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:32px;height:32px;border:1px solid var(--color-border);border-radius:8px;background:#fff;cursor:pointer}
.auth-forgot{margin-top:12px;margin-bottom:12px}
.auth-cta{width:100%;height:64px;font-size:28px;font-weight:700}

/* New listing page */
.nl h1{margin-top:12px}
.nl-breadcrumbs{color:#3C4242;margin:8px 0}
.nl-breadcrumbs .sep{margin:0 6px;opacity:.6}
.nl-layout{display:grid;grid-template-columns:1fr 320px;gap:24px}
.nl-field{margin:16px 0}
.nl-field-head{display:flex;align-items:center;gap:8px;color:#3C4242}
.nl-counter{margin-left:auto;color:#9ca3af}
.nl-field input[type=text],.nl-field textarea{width:100%;border:1px solid var(--color-border);border-radius:8px;padding:10px 12px;background:#fff;color:#111}
.nl-hint{color:#9ca3af;font-size:12px;margin-top:6px}
.nl-footnote{color:#9ca3af;font-size:12px;margin-top:6px}
.nl-section{margin:24px 0}
.nl-section-head{display:flex;align-items:center;gap:12px}
.nl-section-head .nl-counter{margin-left:8px}
.nl-grid{display:grid;grid-template-columns:200px auto 200px;align-items:center;gap:12px}
.nl-price input,.nl-extra-price{width:100%;border:1px solid var(--color-border);border-radius:8px;padding:10px 12px}
.nl-rub{margin-right:8px}
.nl-unit select,.nl-extra-unit{border:1px solid var(--color-border);border-radius:8px;padding:10px 12px;background:#fff}
.nl-extras{display:flex;flex-direction:column;gap:10px}
.nl-extra-row{display:grid;grid-template-columns:20px 1fr 140px 40px 180px 32px;align-items:center;gap:8px}
.nl-extra-name{border:1px solid var(--color-border);border-radius:8px;padding:10px 12px}
.nl-extra-del{border:0;background:transparent;font-size:22px;cursor:pointer}
.nl-aside{position:sticky;top:90px}
.nl-aside-card{border:1px solid var(--color-border);border-radius:12px;padding:12px;opacity:0;visibility:hidden;transition:opacity .15s ease}
.nl-aside-card.show{opacity:1;visibility:visible}
.nl-grid-2{grid-template-columns:1fr 1fr}
.nl-contacts{display:flex;gap:16px}
.nl-contacts .check{display:flex;align-items:center;gap:8px}
.nl-photo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:10px}
.nl-video-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:10px}
.nl-photo-thumb{position:relative;width:100%;padding-top:100%;background:#f3f4f6;border:1px dashed #cbd5e1;border-radius:8px;overflow:hidden}
.nl-photo-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.nl-photo-add{display:inline-block;border:1px dashed #cbd5e1;border-radius:8px;padding:10px 12px;color:#3C4242;cursor:pointer}
.nl-video-thumb{position:relative;width:100%;padding-top:100%;background:#f3f4f6;border:1px dashed #cbd5e1;border-radius:8px;overflow:hidden}
.nl-video-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.nl-remove-btn{position:absolute;top:4px;right:4px;width:20px;height:20px;background:rgba(0,0,0,0.7);color:white;border:none;border-radius:50%;cursor:pointer;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center}
.nl-actions{display:flex;gap:8px;margin-top:16px}
.nl-map-wrap{margin-top:12px}
.nl-address{width:100%;border:1px solid var(--color-border);border-radius:8px;padding:10px 12px;margin-bottom:8px}
.nl-map-placeholder{height:240px;border:1px solid var(--color-border);border-radius:8px;background:linear-gradient(45deg,#f3f4f6,#e5e7eb);}
.nl-aside-title{font-weight:800;margin-bottom:6px}
.nl-aside-text{color:#3C4242;font-size:14px}
.leaflet-top,.leaflet-bottom{z-index:450 !important;}
/* Responsive */
@media (max-width: 900px){
  .site-header .container{flex-wrap:wrap;gap:12px}
  .header-search{order:3;width:100%;max-width:none;margin-inline:0}
  .actions--icons{margin-left:auto}
}
@media (max-width: 600px){
  .logo--brand{font-size:18px}
  .actions--icons{gap:12px}
  .header-search .select{display:none}
  .header-search .divider{display:none}
  .search-options{display:none}
  .profile-menu{right:8px;left:8px;width:auto;top:56px}
}

@media (max-width: 1000px){
  .profile{grid-template-columns:220px 1fr}
}
@media (max-width: 760px){
  .profile{grid-template-columns:1fr}
  .profile-sidebar{position:static}
  .toolbar{flex-wrap:wrap}
}
@media (max-width: 600px){
  .profile-form h2{font-size:28px}
  .pf-row{grid-template-columns:1fr;gap:8px}
  .pf-label{font-size:18px}
  .pf-field input,.pf-field select{font-size:18px}
  .pf-counter{text-align:left}
  .phone-edit-row{grid-template-columns:28px 1fr 32px}
  .phone-edit-row .usage{display:none}
}

@media (max-width: 1024px){
  .nl-layout{grid-template-columns:1fr}
  .nl-aside{position:static}
  .footer-head{grid-template-columns:repeat(2,1fr)}
  .footer-links-grid{grid-template-columns:repeat(2,1fr)}
  .footer-cta{grid-template-columns:1fr 1fr}
}
@media (max-width: 760px){
  .nl-grid{grid-template-columns:1fr}
  .nl-grid-2{grid-template-columns:1fr}
  .nl-contacts{flex-wrap:wrap}
  .nl-actions{flex-wrap:wrap}
  .nl-photo-grid{grid-template-columns:repeat(3,1fr)}
  .nl-video-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 480px){
  .nl-photo-grid{grid-template-columns:repeat(2,1fr)}
  .nl-video-grid{grid-template-columns:repeat(2,1fr)}
  .tool-btn{width:100%;justify-content:center}
}
@media (max-width: 600px){
  .footer-head{grid-template-columns:1fr}
  .footer-cta{grid-template-columns:1fr}
  .footer-links-grid{grid-template-columns:1fr}
}

/* Slider demo */
.slider{display:flex;flex-direction:column;gap:12px;align-items:center}
.slider-controls{display:flex;gap:12px}
.slider img{max-width:100%;height:auto;border-radius:12px;box-shadow:var(--shadow-1)}