/* ============================================================
   lalafo — design system
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fafafb;
  --surface:#ffffff;
  --ink:#0e0e14;
  --ink-2:#5b5b6b;
  --ink-3:#9a9aac;
  --line:#ececf1;
  --line-2:#e2e2e9;
  --brand:#ff5247;
  --brand-2:#ff8a3d;
  --brand-grad:linear-gradient(135deg,#ff5247 0%,#ff8a3d 100%);
  --brand-grad-soft:linear-gradient(135deg,rgba(255,82,71,.12) 0%,rgba(255,138,61,.12) 100%);
  --accent:#7c5cff;
  --ok:#16a06b;
  --warn:#f59e0b;
  --danger:#ef4444;
  --shadow-sm:0 1px 2px rgba(15,15,30,.04),0 1px 1px rgba(15,15,30,.03);
  --shadow:0 8px 24px -8px rgba(15,15,30,.12),0 2px 6px rgba(15,15,30,.04);
  --shadow-lg:0 24px 48px -16px rgba(15,15,30,.18),0 8px 16px -8px rgba(15,15,30,.08);
  --radius:16px;
  --radius-sm:10px;
  --radius-lg:24px;
}
html{overflow-x:clip}
html,body{background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
body{overflow-x:clip;max-width:100%}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;cursor:pointer;background:none;border:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}
.container{max-width:1280px;margin:0 auto;padding:0 24px}
.muted{color:var(--ink-3)}
.hidden{display:none!important}
.spacer{flex:1}
@media(max-width:640px){.container{padding:0 16px}}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:999px;font-weight:600;font-size:14px;transition:transform .15s,background .15s,box-shadow .2s,border-color .15s;white-space:nowrap;border:1.5px solid transparent}
.btn:active{transform:translateY(1px)}
.btn svg{flex-shrink:0}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{transform:translateY(-1px);background:#222}
.btn-brand{background:var(--brand-grad);color:#fff;box-shadow:0 6px 16px -6px rgba(255,82,71,.5)}
.btn-brand:hover{transform:translateY(-1px);box-shadow:0 10px 22px -6px rgba(255,82,71,.55)}
.btn-ghost{color:var(--ink-2);padding:10px 16px}
.btn-ghost:hover{background:var(--bg);color:var(--ink)}
.btn-outline{border-color:var(--line-2);color:var(--ink);background:var(--surface)}
.btn-outline:hover{border-color:var(--ink-3)}
.btn-danger{background:#fff;border-color:rgba(239,68,68,.3);color:var(--danger)}
.btn-danger:hover{background:rgba(239,68,68,.06)}
.btn-block{width:100%}
.btn-lg{padding:14px 26px;font-size:15px}
.btn-sm{padding:8px 14px;font-size:13px}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.btn .spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--line)}
.header-row{display:flex;align-items:center;gap:18px;height:72px}
.logo{font-weight:900;font-size:26px;letter-spacing:-.02em;background:var(--brand-grad);-webkit-background-clip:text;background-clip:text;color:transparent;flex-shrink:0}
.logo .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--brand);margin-left:2px;vertical-align:middle;transform:translateY(-2px)}
.search{flex:1;display:flex;align-items:center;gap:8px;background:var(--surface);border:1.5px solid var(--line);border-radius:999px;padding:6px 6px 6px 18px;transition:border-color .2s,box-shadow .2s;max-width:680px}
.search:focus-within{border-color:var(--brand);box-shadow:0 0 0 4px rgba(255,82,71,.12)}
.search svg{flex-shrink:0;opacity:.55}
.search input{flex:1;border:none;outline:none;background:transparent;font-size:15px;padding:8px 0;min-width:0}
.search .city{display:flex;align-items:center;gap:6px;padding:8px 14px;border-left:1px solid var(--line);color:var(--ink-2);font-weight:500;font-size:14px;white-space:nowrap;cursor:pointer}
.search .city select{border:none;background:transparent;outline:none;font-weight:500;color:var(--ink-2);cursor:pointer;max-width:120px}
.search .go{display:inline-flex;align-items:center;gap:7px;background:var(--brand-grad);color:#fff;padding:10px 22px;border-radius:999px;font-weight:600;font-size:14px;transition:transform .15s,box-shadow .2s;border:none}
.search .go:hover{transform:translateY(-1px);box-shadow:0 8px 16px -6px rgba(255,82,71,.45)}
.nav-actions{display:flex;align-items:center;gap:6px}
.icon-btn{position:relative;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-2);transition:background .15s,color .15s}
.icon-btn:hover{background:var(--bg);color:var(--ink)}
.icon-btn .count{position:absolute;top:2px;right:2px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--brand);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--brand-grad);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;overflow:hidden;flex-shrink:0}
.avatar img{width:100%;height:100%;object-fit:cover}
.user-menu{position:relative}
.user-menu>button{display:flex;align-items:center;gap:8px;padding:4px 4px 4px 10px;border-radius:999px;border:1.5px solid var(--line);transition:border-color .15s}
.user-menu>button:hover{border-color:var(--ink-3)}
.user-menu .uname{font-weight:600;font-size:14px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.menu-pop{position:absolute;top:calc(100% + 10px);right:0;min-width:220px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:8px;z-index:60;animation:pop .15s ease-out}
.menu-pop a,.menu-pop button{display:flex;align-items:center;gap:12px;width:100%;padding:11px 12px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--ink);text-align:left;transition:background .12s}
.menu-pop a:hover,.menu-pop button:hover{background:var(--bg)}
.menu-pop .sep{height:1px;background:var(--line);margin:6px 4px}
.menu-pop svg{opacity:.6;flex-shrink:0}
@keyframes pop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
@media(max-width:900px){.search .city{display:none}.nav-actions .label-hide{display:none}}
@media(max-width:720px){
  .header-row{flex-wrap:wrap;height:auto;min-height:64px;padding:10px 0;gap:10px 12px}
  .nav-actions{margin-left:auto}
  .search{order:5;flex-basis:100%;max-width:100%}
  /* the bottom tab bar already has a prominent "Подать" — drop the redundant top one */
  .nav-actions a.btn-brand{display:none}
}
@media(max-width:640px){.search .go span{display:none}.search .go{padding:10px 15px}.search>svg{display:none}.logo{font-size:22px}.user-menu .uname{display:none}}

/* ---------- Forms ---------- */
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.field label{font-size:13px;font-weight:600;color:var(--ink-2)}
.field .hint{font-size:12px;color:var(--ink-3)}
.input,.field input,.field textarea,.field select{width:100%;padding:13px 15px;border:1.5px solid var(--line-2);border-radius:var(--radius-sm);background:var(--surface);font-size:15px;outline:none;transition:border-color .15s,box-shadow .15s}
.input:focus,.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--brand);box-shadow:0 0 0 4px rgba(255,82,71,.1)}
.field textarea{resize:vertical;min-height:120px;line-height:1.55}
.field.error input,.field.error textarea,.field.error select{border-color:var(--danger)}
.field .err{font-size:12px;color:var(--danger)}
.input-prefix{position:relative}
.input-prefix .pfx{position:absolute;right:15px;top:50%;transform:translateY(-50%);color:var(--ink-3);font-weight:600;pointer-events:none}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.checkbox{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:var(--ink-2);font-weight:500}
.checkbox input{width:18px;height:18px;accent-color:var(--brand);cursor:pointer}
.seg{display:inline-flex;background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:4px;gap:2px}
.seg button{padding:8px 16px;border-radius:999px;font-size:13px;font-weight:600;color:var(--ink-2);transition:all .15s}
.seg button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}
@media(max-width:560px){.row-2{grid-template-columns:1fr}}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(14,14,20,.5);backdrop-filter:blur(6px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fade .2s ease-out}
.modal{position:relative;background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);overflow:hidden;animation:rise .3s cubic-bezier(.2,.8,.2,1);max-height:92vh;overflow-y:auto}
.modal.wide{max-width:600px}
.modal-head{padding:26px 28px 0;position:relative}
.modal-head h2{font-size:24px;font-weight:800;letter-spacing:-.02em}
.modal-head p{color:var(--ink-2);font-size:14px;margin-top:6px}
.modal-close{position:absolute;top:18px;right:18px;z-index:3;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-2);background:var(--bg);transition:background .15s,color .15s}
.modal-close:hover{background:var(--bg);color:var(--ink)}
.modal-body{padding:22px 28px 28px}
.modal-tabs{display:flex;gap:4px;background:var(--bg);border-radius:999px;padding:4px;margin:20px 28px 0}
.modal-tabs button{flex:1;padding:10px;border-radius:999px;font-weight:600;font-size:14px;color:var(--ink-2);transition:all .15s}
.modal-tabs button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ---------- Toasts ---------- */
.toasts{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:10px;align-items:center;width:max-content;max-width:92vw}
.toast{display:flex;align-items:center;gap:10px;padding:13px 18px;border-radius:999px;background:var(--ink);color:#fff;font-size:14px;font-weight:500;box-shadow:var(--shadow-lg);animation:toastin .3s cubic-bezier(.2,.8,.2,1)}
.toast.ok{background:var(--ok)}
.toast.err{background:var(--danger)}
.toast svg{flex-shrink:0}
@keyframes toastin{from{opacity:0;transform:translateY(16px) scale(.95)}to{opacity:1;transform:none}}

/* ---------- Hero ---------- */
.hero{position:relative;padding:64px 0 32px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:-200px -200px auto auto;width:700px;height:700px;background:radial-gradient(closest-side,rgba(255,138,61,.35),transparent 70%);filter:blur(40px);pointer-events:none;z-index:0;animation:float 14s ease-in-out infinite}
.hero::after{content:"";position:absolute;inset:auto auto -200px -200px;width:600px;height:600px;background:radial-gradient(closest-side,rgba(124,92,255,.25),transparent 70%);filter:blur(40px);pointer-events:none;z-index:0;animation:float 18s ease-in-out infinite reverse}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-30px,40px) scale(1.08)}}
.hero-inner{position:relative;z-index:1;text-align:center;max-width:820px;margin:0 auto}
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 14px 6px 8px;border-radius:999px;background:var(--surface);border:1px solid var(--line);font-size:13px;font-weight:500;color:var(--ink-2);margin-bottom:24px;box-shadow:var(--shadow-sm)}
.eyebrow .pulse{display:inline-block;width:8px;height:8px;background:var(--ok);border-radius:50%;box-shadow:0 0 0 0 rgba(22,160,107,.5);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(22,160,107,.5)}70%{box-shadow:0 0 0 10px rgba(22,160,107,0)}100%{box-shadow:0 0 0 0 rgba(22,160,107,0)}}
h1{font-size:clamp(40px,6vw,72px);font-weight:900;letter-spacing:-.03em;line-height:1.05;margin-bottom:20px}
h1 .grad{background:var(--brand-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:18px;color:var(--ink-2);max-width:560px;margin:0 auto 32px}
.hero-search{display:flex;gap:8px;background:var(--surface);border:1.5px solid var(--line);border-radius:999px;padding:7px 7px 7px 20px;max-width:600px;margin:0 auto;box-shadow:var(--shadow);align-items:center}
.hero-search:focus-within{border-color:var(--brand);box-shadow:0 0 0 4px rgba(255,82,71,.12),var(--shadow)}
.hero-search input{flex:1;border:none;outline:none;background:transparent;font-size:16px;min-width:0}
.hero-search button{background:var(--brand-grad);color:#fff;padding:12px 26px;border-radius:999px;font-weight:600;border:none;transition:transform .15s}
.hero-search button:hover{transform:translateY(-1px)}
.hero-stats{display:flex;justify-content:center;gap:40px;margin-top:44px;flex-wrap:wrap}
.stat{text-align:center}
.stat .num{font-size:28px;font-weight:800;letter-spacing:-.02em}
.stat .lbl{font-size:13px;color:var(--ink-3);margin-top:2px}

/* ---------- Sections ---------- */
.section{padding:56px 0}
.section.tight{padding:32px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:28px;gap:20px}
.section-head h2{font-size:clamp(22px,3vw,32px);font-weight:800;letter-spacing:-.02em}
.section-head .more{color:var(--brand);font-weight:600;font-size:14px;display:flex;align-items:center;gap:4px;transition:gap .15s}
.section-head .more:hover{gap:8px}

/* ---------- Categories ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
.cat{position:relative;display:flex;flex-direction:column;align-items:start;gap:14px;padding:20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);transition:transform .2s cubic-bezier(.2,.8,.2,1),box-shadow .2s,border-color .2s;overflow:hidden;cursor:pointer}
.cat::before{content:"";position:absolute;inset:0;background:var(--brand-grad-soft);opacity:0;transition:opacity .2s;pointer-events:none}
.cat:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.cat:hover::before{opacity:1}
.cat .ico{position:relative;z-index:1;width:48px;height:48px;border-radius:14px;background:var(--brand-grad);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 6px 14px -4px rgba(255,82,71,.5)}
.cat .ico svg{width:24px;height:24px}
.cat .label{position:relative;z-index:1;font-weight:600;font-size:15px}
.cat .count{position:relative;z-index:1;font-size:12px;color:var(--ink-3);margin-top:-8px}
.cat:nth-child(7n+2) .ico{background:linear-gradient(135deg,#7c5cff,#5b8cff);box-shadow:0 6px 14px -4px rgba(124,92,255,.5)}
.cat:nth-child(7n+3) .ico{background:linear-gradient(135deg,#16a06b,#0bbf7a);box-shadow:0 6px 14px -4px rgba(22,160,107,.5)}
.cat:nth-child(7n+4) .ico{background:linear-gradient(135deg,#f59e0b,#fbbf24);box-shadow:0 6px 14px -4px rgba(245,158,11,.5)}
.cat:nth-child(7n+5) .ico{background:linear-gradient(135deg,#ec4899,#f472b6);box-shadow:0 6px 14px -4px rgba(236,72,153,.5)}
.cat:nth-child(7n+6) .ico{background:linear-gradient(135deg,#06b6d4,#22d3ee);box-shadow:0 6px 14px -4px rgba(6,182,212,.5)}
.cat:nth-child(7n+0) .ico{background:linear-gradient(135deg,#8b5cf6,#a78bfa);box-shadow:0 6px 14px -4px rgba(139,92,246,.5)}

/* compact category icons (home) — all visible, no scroll */
.cat-compact{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.cat-c{display:flex;flex-direction:column;align-items:center;gap:10px;padding:8px 4px;border-radius:var(--radius);transition:transform .15s;animation:rise .5s ease-out backwards}
.cat-c:hover{transform:translateY(-3px)}
.cat-c .ci{width:62px;height:62px;border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 18px -8px rgba(255,82,71,.45)}
.cat-c .ci svg{width:28px;height:28px}
.cat-c .nm{font-size:13px;font-weight:600;color:var(--ink-2);text-align:center;line-height:1.25}
.cat-c:hover .nm{color:var(--ink)}
.cat-c:nth-child(10n+1) .ci{background:linear-gradient(135deg,#ff5247,#ff8a3d)}
.cat-c:nth-child(10n+2) .ci{background:linear-gradient(135deg,#7c5cff,#5b8cff);box-shadow:0 8px 18px -8px rgba(124,92,255,.45)}
.cat-c:nth-child(10n+3) .ci{background:linear-gradient(135deg,#16a06b,#0bbf7a);box-shadow:0 8px 18px -8px rgba(22,160,107,.45)}
.cat-c:nth-child(10n+4) .ci{background:linear-gradient(135deg,#f59e0b,#fbbf24);box-shadow:0 8px 18px -8px rgba(245,158,11,.45)}
.cat-c:nth-child(10n+5) .ci{background:linear-gradient(135deg,#ec4899,#f472b6);box-shadow:0 8px 18px -8px rgba(236,72,153,.45)}
.cat-c:nth-child(10n+6) .ci{background:linear-gradient(135deg,#06b6d4,#22d3ee);box-shadow:0 8px 18px -8px rgba(6,182,212,.45)}
.cat-c:nth-child(10n+7) .ci{background:linear-gradient(135deg,#8b5cf6,#a78bfa);box-shadow:0 8px 18px -8px rgba(139,92,246,.45)}
.cat-c:nth-child(10n+8) .ci{background:linear-gradient(135deg,#10b981,#34d399);box-shadow:0 8px 18px -8px rgba(16,185,129,.45)}
.cat-c:nth-child(10n+9) .ci{background:linear-gradient(135deg,#ef4444,#f87171);box-shadow:0 8px 18px -8px rgba(239,68,68,.45)}
.cat-c:nth-child(10n+0) .ci{background:linear-gradient(135deg,#0ea5e9,#38bdf8);box-shadow:0 8px 18px -8px rgba(14,165,233,.45)}
@media(max-width:760px){.cat-compact{grid-template-columns:repeat(5,1fr);gap:10px}.cat-c .ci{width:54px;height:54px;border-radius:17px}.cat-c .ci svg{width:24px;height:24px}.cat-c .nm{font-size:11.5px}}
@media(max-width:460px){.cat-compact{grid-template-columns:repeat(4,1fr)}}

/* ---------- Chips ---------- */
.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;margin-bottom:24px;-ms-overflow-style:none;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{padding:8px 16px;border-radius:999px;background:var(--surface);border:1px solid var(--line);font-size:14px;font-weight:500;color:var(--ink-2);white-space:nowrap;transition:all .15s;cursor:pointer}
.chip:hover{border-color:var(--ink-3);color:var(--ink)}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---------- Listings grid + card ---------- */
.listings{display:grid;grid-template-columns:repeat(auto-fill,minmax(208px,1fr));gap:16px}
.card{background:var(--surface);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,border-color .25s;cursor:pointer;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card .photo{position:relative;aspect-ratio:4/3;overflow:hidden;background:#f1f1f5}
.card .photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.card:hover .photo img{transform:scale(1.06)}
.card .photo .ph-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--ink-3);background:repeating-linear-gradient(45deg,#f3f3f7,#f3f3f7 12px,#eeeef3 12px,#eeeef3 24px)}
.card .fav{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;color:var(--ink-2);transition:all .15s;z-index:2}
.card .fav:hover{background:#fff;color:var(--brand);transform:scale(1.1)}
.card .fav.active{color:var(--brand)}
.card .fav.active svg{fill:var(--brand)}
.card .badge{position:absolute;top:10px;left:10px;padding:5px 10px;border-radius:999px;background:rgba(15,15,30,.75);backdrop-filter:blur(8px);color:#fff;font-size:11px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;z-index:1;display:flex;align-items:center;gap:4px}
.card .badge.top{background:var(--brand-grad)}
.card .badge.new{background:rgba(22,160,107,.92)}
.card .badge.sold{background:rgba(15,15,30,.82)}
.card .info{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.card .price{font-size:18px;font-weight:800;letter-spacing:-.01em}
.card .price small{font-weight:500;color:var(--ink-3);font-size:12px;margin-left:4px}
.card .title{font-size:14px;font-weight:500;color:var(--ink);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:38px}
.card .meta{display:flex;align-items:center;gap:6px;color:var(--ink-3);font-size:12px;margin-top:auto;padding-top:6px}
.card .meta .dot-sep{width:3px;height:3px;background:var(--ink-3);border-radius:50%}
.card.is-sold .photo img{filter:grayscale(.6) brightness(.9)}

/* skeleton */
.sk{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.sk .ph{aspect-ratio:4/3;background:var(--line)}
.sk .ln{height:12px;border-radius:6px;background:var(--line);margin:10px 16px}
.sk .ln.sm{width:40%}
.sk *{animation:shimmer 1.4s infinite}
@keyframes shimmer{0%,100%{opacity:1}50%{opacity:.5}}

/* ---------- CTA banner ---------- */
.cta-banner{position:relative;border-radius:var(--radius-lg);padding:56px 48px;background:var(--brand-grad);color:#fff;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;box-shadow:0 20px 40px -16px rgba(255,82,71,.4)}
.cta-banner::before{content:"";position:absolute;inset:auto -100px -200px auto;width:500px;height:500px;background:radial-gradient(closest-side,rgba(255,255,255,.25),transparent 70%);pointer-events:none}
.cta-banner::after{content:"";position:absolute;inset:-150px auto auto -100px;width:400px;height:400px;background:radial-gradient(closest-side,rgba(255,255,255,.18),transparent 70%);pointer-events:none}
.cta-banner>*{position:relative;z-index:1}
.cta-banner h3{font-size:clamp(24px,3.5vw,36px);font-weight:800;letter-spacing:-.02em;margin-bottom:8px;max-width:540px;line-height:1.15}
.cta-banner p{opacity:.92;max-width:520px}
.cta-banner .cta-btn{padding:16px 28px;background:#fff;color:var(--ink);border-radius:999px;font-weight:700;display:inline-flex;align-items:center;gap:8px;transition:transform .15s,box-shadow .2s;font-size:15px}
.cta-banner .cta-btn:hover{transform:translateY(-2px);box-shadow:0 12px 24px -8px rgba(0,0,0,.3)}

/* ---------- Cities ---------- */
.cities{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.city-card{position:relative;padding:18px 20px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;transition:all .2s;cursor:pointer;overflow:hidden}
.city-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brand-grad);transform:scaleY(0);transform-origin:bottom;transition:transform .25s}
.city-card:hover{border-color:transparent;box-shadow:var(--shadow);transform:translateX(4px)}
.city-card:hover::before{transform:scaleY(1)}
.city-card .name{font-weight:600;font-size:15px}
.city-card .num{font-size:13px;color:var(--ink-3);font-weight:500}

/* ---------- Pagination ---------- */
.pager{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:40px}
.pager button{min-width:42px;height:42px;padding:0 12px;border-radius:var(--radius-sm);border:1.5px solid var(--line);background:var(--surface);font-weight:600;font-size:14px;color:var(--ink-2);transition:all .15s}
.pager button:hover:not(:disabled){border-color:var(--ink-3);color:var(--ink)}
.pager button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.pager button:disabled{opacity:.4;cursor:not-allowed}

/* ---------- Breadcrumbs ---------- */
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-3);margin:24px 0;flex-wrap:wrap}
.crumbs a:hover{color:var(--ink)}
.crumbs .sep{opacity:.5}

/* ---------- Empty state ---------- */
.empty{text-align:center;padding:72px 24px;max-width:420px;margin:0 auto}
.empty .ico{width:72px;height:72px;border-radius:20px;background:var(--brand-grad-soft);display:flex;align-items:center;justify-content:center;color:var(--brand);margin:0 auto 20px}
.empty h3{font-size:20px;font-weight:700;margin-bottom:8px}
.empty p{color:var(--ink-2);margin-bottom:22px}

/* ---------- Filters bar (search page) ---------- */
.filters{display:flex;gap:12px;flex-wrap:wrap;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin-bottom:24px}
.filters .field{margin:0}
.filters select,.filters input{padding:10px 13px;border:1.5px solid var(--line-2);border-radius:var(--radius-sm);background:var(--surface);outline:none;font-size:14px}
.filters .price-range{display:flex;align-items:center;gap:6px}
.filters .price-range input{width:110px}
.results-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.results-head h1{font-size:clamp(22px,3vw,30px);font-weight:800;letter-spacing:-.02em}
.results-head .count{color:var(--ink-3);font-size:14px;font-weight:500}

/* ---------- Listing detail ---------- */
.detail{display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:start;margin:8px 0 40px}
.gallery .main{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:#f1f1f5;aspect-ratio:4/3}
.gallery .main img{width:100%;height:100%;object-fit:cover}
.gallery .main .nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:transform .15s}
.gallery .main .nav:hover{transform:translateY(-50%) scale(1.08)}
.gallery .main .nav.prev{left:14px}
.gallery .main .nav.next{right:14px}
.gallery .main .counter{position:absolute;bottom:14px;right:14px;padding:5px 12px;border-radius:999px;background:rgba(15,15,30,.7);color:#fff;font-size:12px;font-weight:600}
.gallery .thumbs{display:flex;gap:10px;margin-top:12px;overflow-x:auto;scrollbar-width:none}
.gallery .thumbs::-webkit-scrollbar{display:none}
.gallery .thumbs img{width:88px;height:66px;border-radius:10px;object-fit:cover;cursor:pointer;border:2px solid transparent;flex-shrink:0;opacity:.7;transition:all .15s}
.gallery .thumbs img.active{border-color:var(--brand);opacity:1}
.detail-body{margin-top:28px}
.detail-body h1{font-size:clamp(24px,3.5vw,34px);font-weight:800;letter-spacing:-.02em;line-height:1.15;margin-bottom:14px}
.detail-price{font-size:32px;font-weight:900;letter-spacing:-.02em;margin-bottom:18px}
.detail-price small{font-size:16px;font-weight:600;color:var(--ink-3);margin-left:6px}
.detail-meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--ink-3);font-size:14px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.detail-meta span{display:flex;align-items:center;gap:6px}
.detail-section{margin-bottom:28px}
.detail-section h3{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin-bottom:12px}
.detail-section p{font-size:15px;line-height:1.7;color:var(--ink);white-space:pre-wrap}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.spec-grid .spec{display:flex;justify-content:space-between;padding:12px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);font-size:14px}
.spec-grid .spec b{font-weight:600}
.sidebar{position:sticky;top:92px;display:flex;flex-direction:column;gap:16px}
.seller-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.seller-card .who{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.seller-card .who .avatar{width:52px;height:52px;font-size:20px}
.seller-card .who .nm{font-weight:700;font-size:16px}
.seller-card .who .sub{font-size:13px;color:var(--ink-3)}
.phone-reveal{font-size:20px;font-weight:800;letter-spacing:.01em;padding:14px;background:var(--bg);border-radius:var(--radius-sm);text-align:center;margin-bottom:12px;font-feature-settings:"tnum"}
.safety-note{font-size:12px;color:var(--ink-3);line-height:1.5;margin-top:14px;display:flex;gap:8px}
.safety-note svg{flex-shrink:0;margin-top:1px;color:var(--ok)}
@media(max-width:920px){.detail{grid-template-columns:1fr}.sidebar{position:static}.spec-grid{grid-template-columns:1fr}}

/* ---------- New / edit ad form ---------- */
.form-wrap{max-width:680px;margin:0 auto;padding:8px 0 48px}
.form-wrap h1{font-size:clamp(26px,4vw,38px);font-weight:800;letter-spacing:-.02em;margin-bottom:6px}
.form-wrap .sub{color:var(--ink-2);margin-bottom:32px}
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;margin-bottom:20px}
.form-card>h2{font-size:18px;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.form-card .step-n{width:28px;height:28px;border-radius:50%;background:var(--brand-grad);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center}
.cat-pick{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
.cat-pick button{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 10px;border:1.5px solid var(--line-2);border-radius:var(--radius);background:var(--surface);transition:all .15s;text-align:center}
.cat-pick button .ci{width:40px;height:40px;border-radius:12px;background:var(--brand-grad-soft);color:var(--brand);display:flex;align-items:center;justify-content:center}
.cat-pick button span{font-size:13px;font-weight:600}
.cat-pick button:hover{border-color:var(--ink-3)}
.cat-pick button.active{border-color:var(--brand);background:var(--brand-grad-soft)}
.cat-pick button.active .ci{background:var(--brand-grad);color:#fff}
/* uploader */
.uploader{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.up-cell{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--line)}
.up-cell img{width:100%;height:100%;object-fit:cover}
.up-cell .rm{position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;background:rgba(15,15,30,.7);color:#fff;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.up-cell .rm:hover{background:var(--danger)}
.up-cell.main-badge::after{content:"Главное";position:absolute;bottom:6px;left:6px;padding:3px 8px;border-radius:999px;background:var(--brand-grad);color:#fff;font-size:10px;font-weight:700}
.up-add{aspect-ratio:1;border:2px dashed var(--line-2);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--ink-3);font-size:12px;font-weight:600;transition:all .15s;cursor:pointer;text-align:center;padding:8px}
.up-add:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-grad-soft)}
.up-cell.loading{display:flex;align-items:center;justify-content:center;background:var(--bg)}
.up-cell.loading .spin{width:24px;height:24px;border:3px solid var(--line);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}
.gen-box{margin-top:14px;padding:16px;border-radius:var(--radius);background:var(--brand-grad-soft);border:1px solid rgba(255,82,71,.18)}
.gen-box .gh{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;margin-bottom:6px}
.gen-box .gd{font-size:12.5px;color:var(--ink-2);margin-bottom:12px}
.gen-box .grow{display:flex;gap:8px}
.gen-box input{flex:1;padding:11px 14px;border:1.5px solid var(--line-2);border-radius:var(--radius-sm);outline:none;font-size:14px;background:var(--surface)}
.gen-box input:focus{border-color:var(--brand)}

/* ---------- Profile ---------- */
.profile-head{display:flex;align-items:center;gap:20px;padding:28px 0;flex-wrap:wrap}
.profile-head .avatar{width:84px;height:84px;font-size:34px}
.profile-head .ph-info h1{font-size:26px;font-weight:800;letter-spacing:-.02em}
.profile-head .ph-info .sub{color:var(--ink-3);font-size:14px;margin-top:4px}
.profile-tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:28px;overflow-x:auto;scrollbar-width:none}
.profile-tabs::-webkit-scrollbar{display:none}
.profile-tabs button{padding:14px 18px;font-weight:600;font-size:15px;color:var(--ink-2);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:color .15s,border-color .15s}
.profile-tabs button.active{color:var(--ink);border-bottom-color:var(--brand)}
.profile-tabs button .pill{margin-left:6px;font-size:12px;padding:1px 7px;border-radius:999px;background:var(--bg);color:var(--ink-3)}
.my-card-actions{display:flex;gap:8px;padding:0 16px 14px;flex-wrap:wrap}
.my-card-actions .btn{flex:1;min-width:auto}
.settings-card{max-width:560px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;margin-bottom:20px}
.settings-card h2{font-size:18px;font-weight:700;margin-bottom:20px}

/* ---------- Chat ---------- */
.chat-layout{display:grid;grid-template-columns:340px 1fr;gap:0;height:calc(100vh - 72px - 48px);min-height:480px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;margin:24px 0}
.conv-list{border-right:1px solid var(--line);overflow-y:auto}
.conv-list .ch{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);cursor:pointer;transition:background .12s}
.conv-list .ch:hover{background:var(--bg)}
.conv-list .ch.active{background:var(--brand-grad-soft)}
.conv-list .ch .thumb{width:48px;height:48px;border-radius:10px;object-fit:cover;background:var(--line);flex-shrink:0}
.conv-list .ch .c-mid{flex:1;min-width:0}
.conv-list .ch .c-mid .nm{font-weight:600;font-size:14px;display:flex;justify-content:space-between;gap:8px}
.conv-list .ch .c-mid .nm time{font-size:11px;color:var(--ink-3);font-weight:500;flex-shrink:0}
.conv-list .ch .c-mid .lt{font-size:13px;color:var(--ink-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}
.conv-list .ch .c-mid .subt{font-size:11px;color:var(--ink-3);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.conv-list .ch .unread{min-width:20px;height:20px;border-radius:10px;background:var(--brand);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;align-self:center;padding:0 5px}
.chat-main{display:flex;flex-direction:column;min-width:0}
.chat-top{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line)}
.chat-top .thumb{width:42px;height:42px;border-radius:10px;object-fit:cover;background:var(--line)}
.chat-top .nm{font-weight:700}
.chat-top .lt{font-size:12px;color:var(--ink-3)}
.chat-feed{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:8px;background:var(--bg)}
.bubble{max-width:72%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.45;word-wrap:break-word}
.bubble.them{background:var(--surface);border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px}
.bubble.me{background:var(--brand-grad);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.bubble time{display:block;font-size:10px;opacity:.6;margin-top:3px;text-align:right}
.chat-composer{display:flex;gap:10px;padding:14px 18px;border-top:1px solid var(--line)}
.chat-composer input{flex:1;padding:12px 16px;border:1.5px solid var(--line-2);border-radius:999px;outline:none;font-size:14px}
.chat-composer input:focus{border-color:var(--brand)}
.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--ink-3);gap:12px;padding:24px;text-align:center}
@media(max-width:760px){.chat-layout{grid-template-columns:1fr}.chat-layout.show-thread .conv-list{display:none}.chat-layout:not(.show-thread) .chat-main{display:none}}

/* ---------- Footer ---------- */
.footer{margin-top:80px;background:var(--ink);color:#fff;padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:48px;margin-bottom:48px}
@media(max-width:780px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
.footer-grid h4{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.5);margin-bottom:16px}
.footer-grid ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-grid a{color:rgba(255,255,255,.8);font-size:14px;transition:color .15s}
.footer-grid a:hover{color:#fff}
.footer-brand .logo{font-size:28px;margin-bottom:14px;display:inline-block}
.footer-brand p{color:rgba(255,255,255,.6);font-size:14px;max-width:340px;line-height:1.6}
.footer-bottom{padding-top:32px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;color:rgba(255,255,255,.5);font-size:13px}
.socials{display:flex;gap:10px}
.socials a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;transition:all .2s;color:#fff}
.socials a:hover{background:var(--brand);transform:translateY(-2px)}

@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.cat,.card,.city-card{animation:rise .5s ease-out backwards}

/* iOS Safari auto-zooms on focus when a field's font-size < 16px.
   Placed at end of file so it overrides earlier same-specificity base rules. */
@media(max-width:768px){
  input,select,textarea,.input,
  .search input,.hero-search input,
  .field input,.field select,.field textarea,
  .filters input,.filters select,
  .chat-composer input,.gen-box input{font-size:16px}
}

/* ============================================================
   Category nav bar (under header, all key pages)
   ============================================================ */
.catnav{background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:72px;z-index:40}
.catnav .inner{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding:11px 0}
.catnav .inner::-webkit-scrollbar{display:none}
.catnav a{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:999px;white-space:nowrap;font-size:13.5px;font-weight:600;color:var(--ink-2);background:var(--bg);border:1px solid var(--line);transition:background .15s,color .15s,border-color .15s;flex-shrink:0}
.catnav a:hover{border-color:var(--ink-3);color:var(--ink)}
.catnav a.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.catnav a svg{width:16px;height:16px;opacity:.7}
.catnav a.active svg{opacity:1}
@media(max-width:720px){.catnav{position:static}.catnav .inner{padding:9px 0}}

/* ============================================================
   Mobile bottom tab bar — app-like navigation
   ============================================================ */
.bottom-nav{display:none}
@media(max-width:720px){
  .bottom-nav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:95;
    background:rgba(255,255,255,.97);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);
    border-top:1px solid var(--line);justify-content:space-around;align-items:flex-end;
    padding:7px 4px calc(7px + env(safe-area-inset-bottom,0px))}
  .bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:2px 0;color:var(--ink-3);font-size:10.5px;font-weight:600;position:relative;letter-spacing:.01em}
  .bottom-nav a.active{color:var(--brand)}
  .bottom-nav a .bn-ico{display:flex;align-items:center;justify-content:center;height:24px}
  .bottom-nav a.post .bn-ico{width:48px;height:48px;border-radius:16px;background:var(--brand-grad);color:#fff;box-shadow:0 8px 18px -5px rgba(255,82,71,.6);margin-top:-22px;border:3px solid var(--surface)}
  .bottom-nav a.post.active{color:var(--ink-2)}
  .bottom-nav .bn-badge{position:absolute;top:-2px;left:calc(50% + 6px);min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--brand);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}
  body.has-bottomnav{padding-bottom:66px}
  /* chat already fills the screen — keep its own bottom area clear of the bar */
  body.has-bottomnav .chat-layout{height:calc(100vh - 66px)}
}

/* ============================================================
   Denser cards on phones — 2-column grid like the real app
   ============================================================ */
@media(max-width:600px){
  .listings{grid-template-columns:repeat(2,1fr);gap:10px}
  .card .info{padding:9px 10px 11px;gap:4px}
  .card .price{font-size:15px}
  .card .title{font-size:12.5px;min-height:34px;line-height:1.3}
  .card .meta{font-size:11px}
  .card .fav{width:30px;height:30px;top:7px;right:7px}
  .card .badge{padding:3px 7px;font-size:9.5px;top:7px;left:7px}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .section{padding:32px 0}
  .hero{padding:36px 0 20px}
}

/* ============================================================
   Horizontal card rows (ТОП / недавно смотрели)
   ============================================================ */
.row-scroll{display:flex;gap:16px;overflow-x:auto;scrollbar-width:none;padding:2px 2px 8px;scroll-snap-type:x proximity}
.row-scroll::-webkit-scrollbar{display:none}
.row-scroll > .card{flex:0 0 230px;scroll-snap-align:start}
.section-head button.more{background:none;border:none;cursor:pointer}
@media(max-width:600px){.row-scroll{gap:10px}.row-scroll > .card{flex:0 0 158px}}

/* online / last-seen indicator on seller card */
.online-ind{font-size:13px;color:var(--ink-3);font-weight:500;margin:2px 0 1px}
.online-ind.on{color:var(--ok);font-weight:600;display:flex;align-items:center;gap:6px}
.online-ind.on::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 rgba(22,160,107,.5);animation:pulse 2s infinite}
.seller-card .who .badge-v{display:inline-flex;vertical-align:middle;margin-left:5px;color:var(--ok)}
