/* Общий layout-CSS каркаса (header / tabs / drawer / фильтр / слайдер / footer / botnav).
   Подключается подстраницами вместе с tokens.css. Источник — Главная.html. */

/* ====== TOP UTILITY ====== */
.utility{background:#0F0B0A;border-bottom:1px solid var(--line);font-size:12.5px}
.utility .wrap{display:flex;align-items:center;justify-content:space-between;height:38px;gap:16px}
.utility .age{display:inline-flex;align-items:center;gap:8px;color:var(--text-muted);font-weight:600}
.utility .age b{color:var(--rose-soft)}
.utility .u-links{display:flex;gap:18px}
.utility .u-links a{color:var(--text-soft);font-weight:600}
.utility .u-links a:hover{color:var(--text)}
@media(max-width:720px){
  .utility .wrap{height:34px;justify-content:center;gap:0;overflow:hidden}
  .utility .age{min-width:0;max-width:100%;white-space:nowrap;overflow:hidden;font-size:0;gap:0}
  .utility .age b{font-size:12px}
  .utility .age::after{content:"Только для совершеннолетних";font-size:12px;margin-left:7px;color:var(--text-muted)}
  .utility .u-links{display:none}
}

/* ====== HEADER ====== */
.header{position:sticky;top:0;z-index:40;background:rgba(21,16,15,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.header .wrap{display:flex;align-items:center;gap:18px;height:72px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:24px;flex:none}
.lk-mark{display:block;width:auto}
.brand .lk-mark{height:30px}
.gate-mark .lk-mark{height:50px}
.botnav .fab .lk-mark{height:30px}
.city{display:inline-flex;align-items:center;gap:7px;height:42px;padding:0 14px;border-radius:var(--r-pill);background:var(--surface-3);border:1px solid var(--line);font-weight:700;font-size:14px;color:var(--text-soft);flex:none}
.city svg{width:15px;height:15px;color:var(--rose-soft)}
.city-wrap{position:relative;flex:none}
.city-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:210px;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:6px;z-index:45;opacity:0;visibility:hidden;transform:translateY(-6px);transition:.16s}
.city-menu.open{opacity:1;visibility:visible;transform:none}
.city-menu a{display:block;padding:11px 14px;border-radius:var(--r-sm);font-size:14px;font-weight:600;color:var(--text-soft);transition:.13s}
.city-menu a:hover{background:var(--surface-2);color:var(--text)}
.city-menu a.is-active{color:var(--rose-soft)}
.h-search{flex:1;max-width:420px}
.h-actions{display:flex;align-items:center;gap:10px;margin-left:auto;flex:none}
.icon-btn{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--surface-3);border:1px solid var(--line);color:var(--text-soft);position:relative;transition:.16s}
.icon-btn:hover{background:var(--surface-2);color:var(--text)}
.icon-btn svg{width:20px;height:20px}
.icon-btn .count{position:absolute;top:-3px;right:-3px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--rose);color:#fff;font-size:11px;font-weight:800;display:grid;place-items:center}
.hide-mobile{display:inline-flex}
.only-mobile{display:none}

/* ====== NAV TABS ====== */
.tabs{border-bottom:1px solid var(--line);background:var(--bg)}
.tabs .wrap{display:flex;gap:6px;height:54px;align-items:center;overflow-x:auto;scrollbar-width:none}
.tabs .wrap::-webkit-scrollbar{display:none}
.tab{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 16px;border-radius:var(--r-pill);font-size:14px;font-weight:700;color:var(--text-soft);white-space:nowrap;transition:.15s}
.tab:hover{background:var(--surface-2);color:var(--text)}
.tab.is-active{background:var(--grad-rose);color:#fff}
.tab .c{font-size:12px;opacity:.8;font-weight:700}

/* ====== SECTION GENERIC ====== */
.alt{background:var(--bg-2)}
.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:1100px){.cards-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:820px){.cards-grid{grid-template-columns:repeat(2,1fr)}}
.scroller .card{width:250px;flex:none}

/* sort row */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:22px;flex-wrap:wrap}
.toolbar .count{font-size:14px;color:var(--text-muted);font-weight:700}
.toolbar .count b{color:var(--text)}
.sort{display:flex;gap:8px;flex-wrap:wrap}

/* category chips */
.cat-chips{display:flex;flex-wrap:wrap;gap:10px}
.metro-grid{display:flex;flex-wrap:wrap;gap:10px}
.metro-chip{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 14px;border-radius:var(--r-pill);background:var(--surface);border:1px solid var(--line);font-size:14px;font-weight:600;color:var(--text-soft);transition:.15s}
.metro-chip:hover{border-color:var(--rose);color:var(--text)}
.metro-chip .c{font-size:12px;color:var(--rose-soft);font-weight:800}
.metro-chip .m{width:9px;height:9px;border-radius:50%;background:var(--rose)}

/* blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:820px){.blog-grid{grid-template-columns:1fr}}
.post{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:.2s}
.post:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.post .ph{position:relative;aspect-ratio:16/10}
.post .body{padding:18px}
.post .date{font-size:12px;color:var(--text-muted);font-weight:700;letter-spacing:.05em}
.post h3{font-size:16px;margin:8px 0 0;line-height:1.35}
.post .excerpt{color:var(--text-muted);font-size:13.5px;line-height:1.55;margin:8px 0 14px}
.post .more{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:700;color:var(--rose-soft)}
.post .more svg{width:14px;height:14px;flex:none}

/* footer */
.footer{background:#0F0B0A;border-top:1px solid var(--line);padding:48px 0 30px;margin-bottom:64px}
.footer-cols{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:28px}
@media(max-width:900px){.footer-cols{grid-template-columns:1fr 1fr}}
.footer h4{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin:0 0 14px}
.footer a{display:block;color:var(--text-soft);font-size:14px;padding:5px 0}
.footer a:hover{color:var(--rose-soft)}
.footer .disclaimer{margin-top:34px;padding-top:24px;border-top:1px solid var(--line);color:var(--text-faint);font-size:12.5px;line-height:1.6;max-width:80ch}

/* mobile bottom nav */
.botnav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:50;background:rgba(15,11,10,.94);backdrop-filter:blur(14px);border-top:1px solid var(--line);padding:8px 6px calc(8px + env(safe-area-inset-bottom))}
.botnav .row{display:flex;justify-content:space-around}
.botnav a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10.5px;font-weight:700;color:var(--text-muted);flex:1;padding:4px 0}
.botnav a svg{width:22px;height:22px}
.botnav a.is-active{color:var(--rose-soft)}
.botnav .fabwrap{flex:1;display:flex;justify-content:center}
.botnav .fab{width:52px;height:52px;border-radius:50%;background:var(--grad-rose);display:grid;place-items:center;margin-top:-22px;box-shadow:var(--shadow-rose);color:#fff}
.botnav .fab svg{width:24px;height:24px}

/* ====== FILTER DRAWER ====== */
.overlay{position:fixed;inset:0;background:rgba(8,5,5,.6);backdrop-filter:blur(3px);z-index:60;opacity:0;visibility:hidden;transition:.25s}
.overlay.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(420px,92vw);height:100dvh;max-height:100dvh;overflow:hidden;background:var(--bg);border-left:1px solid var(--line);z-index:70;transform:translateX(100%);visibility:hidden;pointer-events:none;transition:transform .3s ease,visibility 0s linear .3s;display:flex;flex-direction:column}
@supports not (height:100dvh){.drawer{height:100vh;max-height:100vh}}
.drawer.open{transform:none;visibility:visible;pointer-events:auto;transition:transform .3s ease}
.drawer-head{display:flex;align-items:center;justify-content:space-between;flex:0 0 auto;padding:20px 22px;border-bottom:1px solid var(--line)}
.drawer-head h3{margin:0;font-family:var(--font-display);font-weight:400;font-size:22px}
.drawer-body{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:20px 22px}
.drawer-foot{flex:0 0 auto;padding:16px 22px;border-top:1px solid var(--line);display:flex;gap:10px}
.fgroup{border-top:1px solid var(--line);padding:16px 0}
.fgroup:first-child{border-top:0;padding-top:0}
.fgroup > summary{list-style:none;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-weight:700;font-size:15px}
.fgroup > summary::-webkit-details-marker{display:none}
.fgroup .chev{transition:transform .25s;color:var(--text-muted)}
.fgroup[open] .chev{transform:rotate(180deg)}
.fopts{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.fcount{font-size:12px;font-weight:800;color:var(--rose-soft);margin-left:5px}
.fsearch{margin:14px 0 12px;height:44px}
.metro-scroll{max-height:236px;overflow-y:auto;margin:0 -6px;padding:2px 6px 2px;display:flex;flex-wrap:wrap;gap:8px;align-content:flex-start}
.metro-scroll::-webkit-scrollbar{width:8px}
.metro-scroll::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:8px}
.metro-empty{color:var(--text-muted);font-size:13px;padding:8px 2px}
.metro-scroll .tag[data-zero]{opacity:.5}
.price-range{display:flex;align-items:center;gap:10px;margin-top:14px}
.price-range .pin{flex:1;display:flex;align-items:center;gap:7px;height:48px;padding:0 14px;border-radius:var(--r-md);background:var(--surface-3);border:1px solid var(--line);transition:.16s}
.price-range .pin:focus-within{border-color:var(--rose)}
.price-range .pin .lab{font-size:12px;font-weight:700;color:var(--text-muted)}
.price-range .pin input{border:0;background:transparent;color:var(--text);font-family:inherit;font-size:15px;font-weight:700;width:100%;outline:none}
.price-range .sep{color:var(--text-faint);font-weight:800}
.price-presets{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}

@media(max-width:720px){
  .hide-mobile{display:none}
  .only-mobile{display:inline-flex}
  .botnav{display:block}
  .header .wrap{height:60px;gap:8px}
  .brand{font-size:22px;gap:8px}
  .brand .lk-mark{height:28px}
  .h-search{display:none}
  .city{height:40px;padding:0 11px;gap:6px;font-size:13.5px}
  .city .lab{display:inline-block;max-width:86px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .h-actions{gap:8px}
  .icon-btn{width:42px;height:42px}
  .section{padding:34px 0}
  .wrap{padding:0 16px}
}
@media(max-width:360px){
  .header .wrap{gap:7px}
  .brand{font-size:20px;gap:7px}
  .brand .lk-mark{height:26px}
  .city{height:38px;padding:0 9px;font-size:13px}
  .city .lab{max-width:68px}
  .icon-btn{width:40px;height:40px}
}

/* ====== Хлебные крошки / заголовок страницы ====== */
.crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);padding:20px 0 0}
.crumbs a{color:var(--text-muted)}.crumbs a:hover{color:var(--rose-soft)}
.crumbs .sep{opacity:.5}
.page-head{padding:14px 0 6px}
.page-head h1{font-family:var(--font-display);font-weight:400;font-size:clamp(28px,4vw,40px);line-height:1.1;margin:0 0 8px}
.page-head p{color:var(--text-soft);font-size:15px;margin:0;max-width:70ch}

/* ====== SEO-текст, пагинация, рейтинг ====== */
.seo{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 30px;margin-top:44px}
.seo h2{margin:0 0 10px;font-family:var(--font-display);font-weight:400;font-size:22px}
.seo p{color:var(--text-soft);line-height:1.7;font-size:14.5px;max-width:82ch;margin:0 0 12px}
.seo a{color:var(--rose-soft);font-weight:700}
.pager{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:36px;flex-wrap:wrap}
.pager a{min-width:42px;height:42px;padding:0 12px;border-radius:var(--r-md);display:grid;place-items:center;background:var(--surface);border:1px solid var(--line);font-weight:700;font-size:14px;color:var(--text-soft);transition:.15s}
.pager a:hover{border-color:var(--rose);color:var(--text)}
.pager a.is-active{background:var(--grad-rose);color:#fff;border-color:transparent}
.pager .gap{color:var(--text-faint)}
.rating-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 26px;text-align:center;max-width:520px;margin:0 auto}
.rating-box .score{font-family:var(--font-display);font-size:38px;line-height:1}
.rating-box .score small{font-size:17px;color:var(--text-muted)}
.rating-box .cnt{color:var(--text-muted);font-size:13.5px;margin-top:4px}
.rating-box .hint{color:var(--text-soft);font-size:14px;margin:16px 0 8px}
.stars{display:inline-flex;gap:6px}
.stars button{all:unset;cursor:pointer;color:var(--text-faint);transition:.12s;line-height:0}
.stars button svg{width:32px;height:32px}
.stars button.on{color:var(--gold)}
.rating-thanks{color:var(--verified);font-weight:700;margin-top:12px;display:none}
.rating-box.rated .rating-thanks{display:block}
.rating-box.rated .hint,.rating-box.rated .stars{display:none}
.rating-title{font-family:var(--font-display);font-weight:400;font-size:24px;text-align:center;margin:0 0 16px}
