/* cyrillic-ext */

/* cyrillic */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

  
  *{box-sizing:border-box;margin:0;padding:0}
  html,body{background:var(--canvas);color:var(--ink);font-family:'Manrope',system-ui,sans-serif;-webkit-font-smoothing:antialiased}
  body{font-size:14.5px;line-height:1.5}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  .wrap{max-width:1280px;margin:0 auto;padding:0 24px}

  header.top{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
  .topbar{display:flex;align-items:center;gap:18px;height:64px}
  .logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:17.5px;letter-spacing:-.02em;white-space:nowrap}
  .logo .mark{width:34px;height:34px;border-radius:9px;background:var(--brand);display:grid;place-items:center;color:#fff;font-size:17px;font-weight:800}
  .logo small{display:block;font-size:11px;font-weight:600;color:var(--ink-3);margin-top:-1px;letter-spacing:0}
  .search{flex:1;max-width:420px;display:flex;align-items:center;gap:9px;background:var(--surface-2);border:1px solid transparent;border-radius:10px;padding:9px 14px;color:var(--ink-3);font-weight:500}
  .search:focus-within{background:#fff;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
  .search input{border:0;background:none;outline:none;font:inherit;color:var(--ink);flex:1;font-weight:500}
  .search input::placeholder{color:var(--ink-3)}
  .top-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
  .icon-btn{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;font-size:17px;cursor:pointer;position:relative}
  .icon-btn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--brand);border:2px solid #fff}
  .btn-create{display:flex;align-items:center;gap:7px;background:var(--brand);color:#fff;font-weight:700;padding:10px 16px;border-radius:10px;border:0;font:inherit;font-weight:700;cursor:pointer}
  .me{display:flex;align-items:center;gap:9px}
  .av{border-radius:9px;background:var(--surface-2);display:grid;place-items:center;font-weight:700;color:var(--brand-ink);overflow:hidden;flex:none;font-size:13px}
  .me .av{width:36px;height:36px;background:var(--brand);color:#fff}

  .grid{display:grid;grid-template-columns:212px minmax(0,1fr) 308px;gap:24px;padding:24px 0 80px;align-items:start}
  .rail{position:sticky;top:88px;display:flex;flex-direction:column;gap:16px}

  .nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;font-weight:600;color:var(--ink-2);font-size:14px}
  .nav a .ic{width:20px;text-align:center;font-size:16px;opacity:.85}
  .nav a.on{background:var(--surface);color:var(--brand-ink);box-shadow:inset 0 0 0 1px var(--line);font-weight:700}
  .nav a.on .ic{opacity:1}
  .nav a:hover:not(.on){background:var(--surface-2)}
  .nav .cnt{margin-left:auto;font-size:12px;font-weight:700;color:var(--ink-3)}
  .sep{height:1px;background:var(--line);margin:8px 12px}
  .navlbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-3);padding:4px 12px 6px}

  .composer{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:12px 14px;margin-bottom:16px}
  .composer .av{width:38px;height:38px}
  .composer .ph{flex:1;color:var(--ink-3);font-weight:500}
  .composer .pills{display:flex;gap:6px}
  .composer .pill{font-size:12.5px;font-weight:700;color:var(--ink-2);background:var(--surface-2);padding:8px 11px;border-radius:9px}

  .tabs{display:flex;gap:24px;margin-bottom:8px;border-bottom:1px solid var(--line);padding:0 2px;overflow-x:auto;scrollbar-width:none}
  .tabs::-webkit-scrollbar{display:none}
  .tab{padding:0 0 12px;font-weight:700;font-size:13.5px;color:var(--ink-3);white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1px}
  .tab.on{color:var(--brand-ink);border-color:var(--brand)}

  .feed{display:flex;flex-direction:column;gap:12px;padding-top:16px}
  .post{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;transition:border-color .15s}
  .post:hover{border-color:#D6DEE6}
  .phead{display:flex;align-items:center;gap:10px;margin-bottom:11px}
  .phead .av{width:36px;height:36px;font-size:13px}
  .who{font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
  .badge-rk{display:inline-flex;align-items:center;gap:4px;color:var(--brand-ink);font-size:11px;font-weight:700}
  .meta{color:var(--ink-3);font-size:12px;font-weight:600}
  .chip{margin-left:auto;font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:8px;background:var(--surface-2);color:var(--ink-2);white-space:nowrap}
  .chip.b{background:var(--brand-soft);color:var(--brand-ink)}
  .chip.g{background:var(--good-soft);color:var(--good)}
  .ptitle{font-weight:800;font-size:17px;letter-spacing:-.01em;margin-bottom:5px;line-height:1.3}
  .ptext{color:var(--ink-2);font-weight:500;font-size:14px}
  .ph-img{margin-top:12px;border-radius:12px;height:220px;border:1px solid var(--line);background-image:repeating-linear-gradient(135deg,#EFF3F7,#EFF3F7 11px,#E7ECF1 11px,#E7ECF1 22px);display:grid;place-items:center}
  .ph-img span{font-family:ui-monospace,Menlo,monospace;font-size:12px;color:#9AA7B2;background:rgba(255,255,255,.75);padding:5px 11px;border-radius:7px}
  .pfoot{display:flex;align-items:center;gap:18px;margin-top:14px;padding-top:13px;border-top:1px solid var(--line-2)}
  .act{display:flex;align-items:center;gap:7px;font-weight:700;font-size:13px;color:var(--ink-2);cursor:pointer}
  .act:hover{color:var(--brand)}
  .vote{display:inline-flex;align-items:center;background:var(--surface-2);border-radius:9px;padding:2px;gap:2px}
  .vbtn{width:30px;height:28px;border-radius:7px;display:grid;place-items:center;font-size:13px;color:var(--ink-2);cursor:pointer}
  .vbtn.up.on{background:#fff;color:var(--brand);box-shadow:0 1px 2px rgba(16,26,36,.08)}
  .vcount{font-weight:800;font-size:13.5px;color:var(--brand-ink);padding:0 5px}

  .card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
  .card .ch{display:flex;align-items:center;justify-content:space-between;padding:15px 16px 9px}
  .card .ch h3{font-size:14px;font-weight:800;letter-spacing:-.01em}
  .card .ch a{font-size:12px;font-weight:700;color:var(--brand)}
  .top-list{padding:2px 8px 10px}
  .top-row{display:flex;align-items:center;gap:11px;padding:8px 9px;border-radius:10px}
  .top-row:hover{background:var(--surface-2)}
  .rank{width:20px;text-align:center;font-weight:800;font-size:13px;color:var(--ink-3);flex:none}
  .rank.t1,.rank.t2,.rank.t3{color:var(--brand)}
  .top-row .av{width:34px;height:34px;font-size:12px}
  .top-row>div:not(.pts){flex:1;min-width:0}
  .top-row .nm{font-weight:700;font-size:13px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .top-row .tg{color:var(--ink-3);font-size:11.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .top-row .pts{flex:none}
  .role{color:var(--brand-ink);font-weight:700}
  .top-row .pts{margin-left:auto;text-align:right;font-weight:800;font-size:13px;color:var(--ink)}
  .top-row .pts small{display:block;color:var(--ink-3);font-size:10px;font-weight:600}

  .ev{display:flex;gap:12px;padding:10px 16px;align-items:center;border-top:1px solid var(--line-2)}
  .ev:first-of-type{border-top:0}
  .ev:hover{background:var(--surface-2)}
  .date{flex:none;width:50px;text-align:center;background:var(--surface-2);border-radius:10px;padding:7px 0;color:var(--ink)}
  .date b{display:block;font-size:18px;font-weight:800;line-height:1}
  .date span{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3)}
  .ev .et{font-weight:700;font-size:13px;line-height:1.3}
  .ev .ep{color:var(--ink-3);font-size:11.5px;font-weight:600;margin-top:2px}

  .market{padding:10px 16px 16px;display:grid;grid-template-columns:1fr 1fr;gap:9px}
  .mi{border:1px solid var(--line);border-radius:11px;overflow:hidden}
  .mi .mimg{height:72px;background-image:repeating-linear-gradient(135deg,#EFF3F7,#EFF3F7 9px,#E7ECF1 9px,#E7ECF1 18px)}
  .mi .mp{padding:7px 9px}
  .mi .mp b{display:block;font-size:12.5px;font-weight:800}
  .mi .mp span{font-size:11px;font-weight:600;color:var(--ink-2)}

  .mobile-bar{display:none}
  .m-only{display:none}

  @media(max-width:1080px){.grid{grid-template-columns:minmax(0,1fr) 308px}.rail.left{display:none}}
  @media(max-width:860px){
    .grid{grid-template-columns:minmax(0,1fr);padding-bottom:90px}
    .rail.right{display:none}.search{display:none}.btn-create span{display:none}.m-only{display:block}
  }
  @media(max-width:560px){
    .wrap{padding:0 14px}.topbar{height:58px;gap:10px}.logo small{display:none}
    .btn-create{padding:10px;border-radius:10px}.composer .pills{display:none}
    .tabs{gap:18px}.ph-img{height:185px}
    .mobile-bar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;background:rgba(255,255,255,.94);backdrop-filter:blur(14px);border-top:1px solid var(--line);padding:8px 6px 10px;justify-content:space-around}
    .mobile-bar a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:700;color:var(--ink-3);flex:1}
    .mobile-bar a .ic{font-size:20px}
    .mobile-bar a.on{color:var(--brand)}
    .mobile-bar .fab .ic{width:46px;height:46px;border-radius:13px;background:var(--brand);color:#fff;display:grid;place-items:center;font-size:23px;margin-top:-24px}
  }


/* === bridge: живое CMS-меню (ul.menu) под визуал .nav макета (Шаг 3a) === */
/* base core.css форсит .module.menu{background:var(--site-primary)!important} и .menu a{color:white!important};
   base править нельзя (контракт) — перебиваем тут с !important в контексте .rail */
.rail .module.menu{background:transparent !important;padding:0;border:0;box-shadow:none}
.rail .module.menu ul.menu{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.rail .module.menu li.menu-item{margin:0}
.rail .module.menu li.menu-item > a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:11px;color:var(--ink-2) !important;font-weight:600;font-size:14px;text-decoration:none}
.rail .module.menu li.menu-item > a:hover{background:var(--surface-2);color:var(--ink) !important}
.rail .module.menu li.menu-item > a > i{width:20px;text-align:center;color:var(--ink-3)}
.col-main{min-width:0}

/* === Утилит-бар хедера: виджет погоды/валют/времени в стиле «Северный минимализм» === */
/* Разметка приходит из components/asyncHeader (трогать нельзя): .transparent-card с inline-стилями
   + блоки погоды с margin-top:-14/-30px. Перебиваем inline через !important и собираем в строку-чипы. */
.nv-utilbar{border-bottom:1px solid var(--line-2);background:var(--surface)}
.nv-util{display:flex;justify-content:center}

/* контейнер виджета — ровная центрированная строка вместо space-around */
.nv-util .transparent-card{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  gap:10px !important;
  flex-wrap:wrap !important;
  padding:7px 0 !important;
  font-size:12.5px;
  font-weight:600;
  color:var(--ink-2);
}
/* каждый смысловой блок (время/погода/валюты/переключатель) — чип-карточка макета */
.nv-util .transparent-card > div{
  background:var(--surface-2);
  border-radius:9px;
  padding:5px 11px;
  line-height:1.35;
  display:flex;
  align-items:center;
  gap:7px;
}
/* убрать кривые отрицательные margin-top у строк погоды */
.nv-util .transparent-card > div > div{margin-top:0 !important;display:flex;align-items:center;gap:6px}
/* иконки погоды — компактные, по центру */
.nv-util img{height:20px;width:20px;vertical-align:middle;display:inline-block}
/* валюты: ▲ зелёный / ▼ красный токенами макета */
.nv-util .up-icon{color:var(--good) !important;font-weight:700}
.nv-util .down-icon{color:#D64545 !important;font-weight:700}
.nv-util br{display:none}                       /* USD/EUR в одну строку через gap */
.nv-util .transparent-card > div:nth-child(3){flex-direction:column;align-items:flex-start;gap:1px}
/* пустой блок времени (#nv-news-time пуст) не показываем как чип */
.nv-util #nv-news-time:empty{display:none}
.nv-util .transparent-card > div:has(#nv-news-time:empty){background:none;padding:0}
/* переключатель темы — компактно, в стиле макета */
.nv-util .form-switch{gap:7px}
.nv-util .form-check-label{font-weight:600;color:var(--ink-3);font-size:12px}

/* === Раздел Новости (VK-посты) в стиле «Северный минимализм» (Шаг 3b) === */
/* Разметка из компонента nvNews* (трогать нельзя) — стилизуем только CSS. */

/* меню-навбар раздела: убрать синий Bootstrap-фон, сделать в стиле макета */
.nvNewsMenu .navbar{
  background:var(--surface) !important;
  border:1px solid var(--line);
  border-radius:var(--r);
  min-height:0;
  padding:8px 14px;
}
.nvNewsMenu .navbar .nav-link{color:var(--ink-2) !important;font-weight:600;font-size:14px}
.nvNewsMenu .navbar .nav-link:hover{color:var(--brand-ink) !important}

/* кнопка Назад */
.module.backButton .btn-secondary{
  background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line);
  border-radius:10px;font-weight:700;font-size:13px;padding:8px 14px;
}
.module.backButton .btn-secondary:hover{background:var(--brand-soft);color:var(--brand-ink);border-color:var(--brand-soft)}

/* хлебные крошки */
.module.breadcrumbs .breadcrumb{font-size:13px;font-weight:600;color:var(--ink-3);margin:0}
.module.breadcrumbs a{color:var(--brand)}

/* выбор дня / счётчик публикаций */
.nvNewsDateSelection .days-link{display:inline-block;font-size:12.5px;font-weight:700;color:var(--brand-ink);background:var(--surface-2);border-radius:8px;padding:4px 9px;margin:3px 3px 0 0}
.nvNewsDateSelection .days-link:hover{background:var(--brand-soft)}
.nvNewsCount{color:var(--ink-3);font-size:13px;font-weight:600}

/* === карточка VK-поста (.new-post-card) под .post макета === */
.new-post-card{
  background:var(--surface) !important;
  border:1px solid var(--line) !important;
  border-radius:var(--r) !important;
  padding:16px 18px !important;
  margin-bottom:14px !important;
  max-width:none !important;
  transition:border-color .15s;
}
.new-post-card:hover{border-color:#D6DEE6}

/* шапка поста: автор + дата */
.new-post-card .card_header{display:flex;align-items:center;gap:9px;margin-bottom:10px;font-size:13px}
.new-post-card .card_header span:first-child{font-weight:700;color:var(--ink)}
.new-post-card .card_header span:last-child{color:var(--ink-3);font-weight:600;font-size:12px}

/* метрики: в ряд, как .pfoot макета */
.new-post-card .card_metrics{
  display:flex !important;align-items:center;gap:16px;flex-wrap:wrap;
  margin:12px 0;padding:11px 0;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);
  font-weight:700;font-size:13px;color:var(--ink-2);
}
.new-post-card .card_metrics > div{display:flex;align-items:center;gap:5px}
.new-post-card .ico_card{width:20px;height:20px;border-radius:6px}

/* медиа: скруглённое фото + play-иконка */
.new-post-card .card_media{margin:12px 0}
.new-post-card .card_image{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.new-post-card .card_image img{width:100%;display:block}
.new-post-card .play-icon{position:absolute;inset:0;margin:auto;width:54px;height:54px;border-radius:50%;background:rgba(16,26,36,.55);color:#fff;display:grid;place-items:center;font-size:22px}
.new-post-card .play-icon::before{content:'▶'}

/* текст поста */
.new-post-card .card_text{color:var(--ink);font-weight:500;font-size:14px;line-height:1.55}

/* футер: ID / дата проверки / ссылка — приглушённо */
.new-post-card .card_footer{display:flex;flex-wrap:wrap;gap:14px;margin-top:13px;padding-top:11px;border-top:1px solid var(--line-2);font-size:11.5px;font-weight:600;color:var(--ink-3)}
.new-post-card .card_footer a{color:var(--brand);font-weight:700}

/* .ico_card = VK-иконка по битому пути /templates/site/default/ (404).
   Прячем битую картинку, рисуем чистый VK-бейдж в стиле макета. */
.new-post-card .card_metrics .ico_card{display:none}
.new-post-card .card_metrics > div:first-child{
  background:var(--brand-soft);color:var(--brand-ink);
  border-radius:7px;padding:3px 8px;font-size:11px;font-weight:800;letter-spacing:.02em;
}
.new-post-card .card_metrics > div:first-child::after{content:'VK'}

/* === Раздел спорт-новостей (?dir=_news): карточки .collection-card в стиле макета === */
/* Разметка из nvNews (компонент, трогать нельзя): a > div.card.collection-card > img.card-img-top + .card-body(h6.card-title, small.text-muted, p.card-text). Стилизуем CSS. */
.collection-card{
  background:var(--surface) !important;
  border:1px solid var(--line) !important;
  border-radius:var(--r) !important;
  overflow:hidden;
  transition:border-color .15s, box-shadow .15s;
  box-shadow:none !important;
}
a:hover > .collection-card{border-color:#D6DEE6 !important;box-shadow:0 4px 14px rgba(16,26,36,.06)}
.collection-card-img{
  width:100%;height:170px;object-fit:cover;display:block;
  border-bottom:1px solid var(--line-2);
}
.collection-card .card-body{padding:13px 15px 15px}
.collection-card .card-title{
  font-weight:800 !important;font-size:15px;line-height:1.3;letter-spacing:-.01em;
  color:var(--ink) !important;margin-bottom:6px !important;
}
a:hover .collection-card .card-title{color:var(--brand-ink) !important}
.collection-card .text-muted{
  color:var(--ink-3) !important;font-size:12px;font-weight:600;
}
.collection-card-preview{
  color:var(--ink-2) !important;font-size:13px;line-height:1.5;margin-top:8px !important;
}
/* отступ между карточками в сетке */
.col-md-4{margin-bottom:18px}

/* фильтр-чипы категорий в стиле макета (Все/Новости/Видео/Баскетбол…) */
.nvNewsFilter a, .badge.bg-secondary, .filter-chip{border-radius:9px}
