@import url("components.css");
  :root{
    --primary:#2BA4DE;
    --hdr1:#1C8FCB;
    --hdr2:#36ABE0;
    --deep:#1B75BB;
    --teal:#16B5A5;
    --green:#4CAF50;
    --green2:#5BB85C;
    --gear:#2E86C1;
    --red:#E0231B;
    --txt:#2A3B47;
    --muted:#5e7280;
    --sect:#F2F5F7;
    --bd:#E3E9ED;
    --white:#ffffff;
    --radius:18px;
    --radius-sm:12px;
    --shadow-sm:0 2px 8px rgba(27,117,187,.07);
    --shadow:0 10px 30px -12px rgba(27,117,187,.22), 0 4px 12px rgba(27,117,187,.07);
    --shadow-lg:0 24px 60px -20px rgba(27,117,187,.35);
    --glass:rgba(255,255,255,.62);
    --glass-bd:rgba(255,255,255,.7);
    --maxw:1280px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
  body{
    font-family:'Manrope','Plus Jakarta Sans',system-ui,sans-serif;
    color:var(--txt);
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
    background:
      radial-gradient(1100px 520px at 12% -8%, rgba(54,171,224,.20), transparent 60%),
      radial-gradient(900px 520px at 96% 4%, rgba(22,181,165,.13), transparent 55%),
      linear-gradient(180deg,#f5fafd 0%, #eef4f8 40%, #f2f5f7 100%);
    background-attachment:fixed;
  }
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  button{font-family:inherit;cursor:pointer;border:none;background:none}
  h1,h2,h3,h4{font-family:'Plus Jakarta Sans','Manrope',sans-serif;line-height:1.15;letter-spacing:-.01em}
  ul{list-style:none}
  :focus-visible{outline:3px solid rgba(43,164,222,.55);outline-offset:2px;border-radius:6px}

  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 16px}
  @media(min-width:768px){.wrap{padding:0 28px}}

  .back-link{position:fixed;top:10px;left:10px;z-index:120;display:inline-flex;align-items:center;gap:6px;
    background:rgba(255,255,255,.9);backdrop-filter:blur(8px);color:var(--deep);font-weight:700;font-size:13px;
    padding:8px 13px;border-radius:999px;box-shadow:var(--shadow-sm);border:1px solid var(--bd);min-height:36px}
  .back-link:hover{background:#fff}

  /* ============ HEADER ============ */
  .utility{background:linear-gradient(90deg,var(--hdr1),var(--hdr2));color:#fff}
  .utility .wrap{display:flex;align-items:center;gap:14px;min-height:42px;padding-top:6px;padding-bottom:6px;flex-wrap:wrap}
  .utility .tagline{font-size:11px;line-height:1.3;opacity:.95;flex:1;min-width:0;display:none}
  @media(min-width:980px){.utility .tagline{display:block}}
  .util-right{display:flex;align-items:center;gap:8px;margin-left:auto}
  .util-search{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.32);
    border-radius:999px;padding:5px 10px;min-height:34px}
  .util-search input{background:none;border:none;color:#fff;font-size:13px;width:100px;outline:none}
  .util-search input::placeholder{color:rgba(255,255,255,.8)}
  .util-search svg{width:15px;height:15px}
  .lang{display:flex;gap:2px;background:rgba(255,255,255,.16);border-radius:999px;padding:3px}
  .lang button{color:#fff;font-size:11.5px;font-weight:700;padding:4px 9px;border-radius:999px;min-height:26px}
  .lang button.on{background:#fff;color:var(--deep)}

  .masthead{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);backdrop-filter:blur(14px) saturate(1.3);
    border-bottom:1px solid var(--bd);box-shadow:0 4px 20px -14px rgba(27,117,187,.4)}
  .masthead .wrap{display:flex;align-items:center;gap:14px;min-height:62px}
  .logo{display:flex;align-items:baseline;font-family:'Plus Jakarta Sans';font-size:23px;font-weight:800;letter-spacing:-.02em;white-space:nowrap}
  .logo .m{color:var(--deep)}
  .logo .e{color:var(--primary);font-weight:600}
  .logo .gt{color:var(--teal);font-weight:800;margin:0 1px}
  nav.main{display:none;margin-left:auto}
  @media(min-width:1080px){nav.main{display:flex;gap:2px;flex-wrap:wrap;justify-content:flex-end}}
  nav.main a{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.01em;color:var(--deep);
    padding:8px 9px;border-radius:9px;position:relative;transition:.18s;white-space:nowrap}
  nav.main a:hover{background:rgba(43,164,222,.1);color:var(--hdr1)}
  nav.main a.active{color:var(--primary)}
  nav.main a.active::after{content:"";position:absolute;left:11px;right:11px;bottom:3px;height:2.5px;border-radius:2px;background:var(--primary)}
  .header-cta{margin-left:auto;display:flex;align-items:center;gap:10px}
  @media(min-width:1080px){.header-cta{display:none}} /* на ПК пустой → скрываем, меню к краю */
  .btn-sub{display:none;background:linear-gradient(120deg,var(--hdr1),var(--hdr2));color:#fff;font-weight:700;font-size:13px;
    padding:10px 18px;border-radius:999px;box-shadow:var(--shadow-sm);transition:.2s;align-items:center;gap:7px}
  .header-cta .btn-sub{display:none} /* «Подписаться» убрана из шапки → предподвальный блок */
  .btn-sub:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
  .hamburger{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;
    color:var(--deep);background:rgba(43,164,222,.08)}
  @media(min-width:1080px){.hamburger{display:none}}
  .hamburger svg{width:24px;height:24px}

  /* drawer */
  /* обёртка-клиппер: создаёт containing block (transform) + обрезает off-canvas drawer,
     чтобы уехавшее вправо меню не расширяло страницу и не создавало пустоту справа на мобиле */
  .menu-root{position:fixed;inset:0;z-index:200;overflow:hidden;pointer-events:none;transform:translateZ(0)}
  .menu-root .overlay,.menu-root .drawer{pointer-events:auto}
  .overlay{position:fixed;inset:0;background:rgba(20,50,75,.42);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:.25s;z-index:200}
  .overlay.open{opacity:1;visibility:visible}
  .drawer{position:fixed;top:0;right:0;height:100%;width:min(86vw,340px);background:#fff;z-index:210;
    transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}
  .drawer.open{transform:translateX(0)}
  .drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;
    background:linear-gradient(120deg,var(--hdr1),var(--hdr2));color:#fff}
  .drawer-head .logo .m,.drawer-head .logo .e{color:#fff}
  .drawer-head .logo .gt{color:#cfeefb}
  .drawer-close{width:40px;height:40px;border-radius:10px;color:#fff;background:rgba(255,255,255,.18);display:inline-flex;align-items:center;justify-content:center}
  .drawer nav{padding:8px 10px;overflow-y:auto;flex:1}
  .drawer nav a{display:flex;align-items:center;gap:12px;padding:14px 14px;font-weight:800;text-transform:uppercase;
    font-size:13px;letter-spacing:.02em;color:var(--deep);border-radius:12px;min-height:48px}
  .drawer nav a:hover{background:var(--sect)}
  .drawer nav a svg{width:18px;height:18px;color:var(--primary)}
  .drawer-foot{padding:16px 18px;border-top:1px solid var(--bd)}
  .drawer-foot .btn-sub{display:flex;justify-content:center;width:100%}

  /* ============ HERO SLIDER ============ */
  .slider-band{position:relative;padding:18px 0 6px}
  @media(min-width:768px){.slider-band{padding:26px 0 10px}}
  .slider-shell{position:relative;max-width:var(--maxw);margin:0 auto;padding:0 12px}
  @media(min-width:768px){.slider-shell{padding:0 52px}}
  .slider-track{display:flex;gap:0;overflow-x:auto;scroll-snap-type:x mandatory;
    scroll-behavior:smooth;padding:6px 0 14px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .slider-track::-webkit-scrollbar{display:none}
  /* фиксированная ширина баннера → на широком экране влезает БОЛЬШЕ баннеров, а не растягиваются */
  .slide{flex:0 0 clamp(260px,88vw,380px);scroll-snap-align:start;position:relative;border-radius:0;
    overflow:hidden;min-height:230px;isolation:isolate;background:#0b2e44}
  .slide:first-child{border-top-left-radius:var(--radius);border-bottom-left-radius:var(--radius)}
  .slide:last-child{border-top-right-radius:var(--radius);border-bottom-right-radius:var(--radius)}
  @media(min-width:560px){.slide{flex:0 0 360px;min-height:300px}}
  @media(min-width:1280px){.slide{flex:0 0 400px;min-height:340px}}
  .slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .6s ease}
  .slide:hover img{transform:scale(1.05)}
  .slide .scrim{position:absolute;inset:0;z-index:-1;
    background:linear-gradient(180deg,rgba(8,40,62,.12) 0%,rgba(8,40,62,.55) 55%,rgba(7,32,50,.92) 100%)}
  .slide-body{position:relative;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:18px;min-height:230px;color:#fff}
  @media(min-width:560px){.slide-body{min-height:300px;padding:22px}}
  @media(min-width:980px){.slide h3{font-size:21px;line-height:1.22}.slide-body{padding:24px}}
  @media(min-width:1280px){.slide-body{min-height:340px}.slide h3{font-size:24px}}
  /* во всю ширину экрана на ПК (full-bleed) */
  @media(min-width:1080px){
    .slider-shell{max-width:none;margin:0;padding:0}
    .slide:first-child,.slide:last-child{border-radius:0}
    .slider-arrow.prev{left:16px}.slider-arrow.next{right:16px}
  }
  .chip-cat{align-self:flex-start;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;
    padding:5px 11px;border-radius:999px;margin-bottom:auto;background:rgba(255,255,255,.92);color:var(--deep);box-shadow:0 2px 8px rgba(0,0,0,.18)}
  .chip-cat.featured{background:var(--red);color:#fff}
  .slide h3{font-size:16.5px;line-height:1.25;margin:10px 0 8px;font-weight:800;text-shadow:0 2px 12px rgba(0,0,0,.3)}
  .slide .meta{display:flex;align-items:center;gap:6px;font-size:12px;opacity:.94;margin-bottom:12px;flex-wrap:wrap}
  .slide .meta svg{width:14px;height:14px}
  .slide .more{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;
    background:linear-gradient(120deg,var(--hdr1),var(--hdr2));color:#fff;padding:9px 15px;border-radius:999px;
    min-height:38px;transition:.2s;box-shadow:0 6px 16px -6px rgba(0,0,0,.5)}
  .slide .more:hover{transform:translateY(-2px)}
  .slide .more svg{width:14px;height:14px}

  .slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:6;width:44px;height:44px;border-radius:50%;
    background:rgba(255,255,255,.92);backdrop-filter:blur(6px);color:var(--deep);box-shadow:var(--shadow);
    display:flex;align-items:center;justify-content:center;border:1px solid var(--bd);transition:.2s}
  .slider-arrow:hover{background:#fff;color:var(--primary);transform:translateY(-50%) scale(1.08)}
  .slider-arrow.prev{left:2px}
  .slider-arrow.next{right:2px}
  @media(min-width:768px){.slider-arrow{width:50px;height:50px}.slider-arrow.prev{left:6px}.slider-arrow.next{right:6px}}
  .slider-arrow svg{width:22px;height:22px}
  .slider-dots{display:flex;justify-content:center;gap:7px;margin-top:2px}
  .slider-dots button{width:8px;height:8px;border-radius:999px;background:rgba(27,117,187,.25);transition:.25s;padding:0}
  .slider-dots button.on{width:24px;background:var(--primary)}
  .slider-progress{display:none} /* полоса-прогресс убрана */
  .slider-progress i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--teal),var(--primary));border-radius:999px}

  /* ============ SECTION SHARED ============ */
  section{position:relative}
  .sec{padding:34px 0}
  @media(min-width:768px){.sec{padding:48px 0}}
  .sec-head{display:flex;align-items:center;gap:12px;margin-bottom:20px}
  .sec-head h2{font-size:clamp(20px,4.5vw,30px);font-weight:800;color:var(--deep)}
  .sec-head .line{flex:1;height:1px;background:linear-gradient(90deg,var(--bd),transparent)}
  .sec-head .navs{display:flex;gap:8px}
  .sec-head .navs button{width:40px;height:40px;border-radius:50%;background:#fff;border:1px solid var(--bd);
    color:var(--deep);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;transition:.18s}
  .sec-head .navs button:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
  .sec-head .navs svg{width:18px;height:18px}
  .eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:800;text-transform:uppercase;
    letter-spacing:.08em;color:var(--teal);margin-bottom:8px}
  .eyebrow svg{width:15px;height:15px}

  /* ============ РАЗДЕЛЫ circles ============ */
  .razdely{display:flex;gap:14px;overflow-x:auto;padding:6px 2px 12px;scroll-snap-type:x mandatory;scrollbar-width:none}
  .razdely::-webkit-scrollbar{display:none}
  @media(min-width:768px){.razdely{justify-content:center;flex-wrap:wrap;overflow:visible}}
  .razdel{flex:0 0 auto;scroll-snap-align:start;display:flex;flex-direction:column;align-items:center;gap:10px;
    width:96px;background:none;text-align:center}
  .razdel .ic{width:74px;height:74px;border-radius:50%;display:flex;align-items:center;justify-content:center;
    color:#fff;box-shadow:var(--shadow);transition:.22s;position:relative}
  .razdel .ic::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid transparent;transition:.22s}
  .razdel:hover .ic{transform:translateY(-4px) scale(1.04)}
  .razdel.on .ic::after{border-color:currentColor;opacity:.4}
  .razdel .ic svg{width:32px;height:32px}
  .razdel span{font-size:12.5px;font-weight:700;color:var(--txt)}
  .razdel.on span{color:var(--deep)}
  .ic.c-news{background:linear-gradient(135deg,#1ec5b6,var(--teal))}
  .ic.c-conf{background:linear-gradient(135deg,#62c466,var(--green))}
  .ic.c-cat{background:linear-gradient(135deg,#6dc46f,var(--green2))}
  .ic.c-tech{background:linear-gradient(135deg,#3a96d4,var(--gear))}
  .ic.c-phyto{background:linear-gradient(135deg,#7bc97f,#3f9d44)}

  /* segmented filter control (как в 23) */
  .chip-row{display:flex;gap:5px;overflow-x:auto;padding:5px;margin:0;scrollbar-width:none;
    background:#fff;border:1px solid var(--bd);border-radius:999px;box-shadow:var(--shadow-sm);-webkit-overflow-scrolling:touch}
  .chip-row::-webkit-scrollbar{display:none}
  @media(min-width:768px){.chip-row{overflow:visible;width:max-content;max-width:100%;margin-left:auto;margin-right:auto}}
  .chip{flex:0 0 auto;font-size:13px;font-weight:700;padding:9px 16px;border-radius:999px;background:transparent;
    border:none;color:var(--muted);min-height:40px;white-space:nowrap;cursor:pointer;
    transition:transform .2s,background .2s,color .2s}
  .chip:hover{color:var(--deep)}
  .chip[aria-pressed="true"]{background:linear-gradient(120deg,var(--hdr1),var(--hdr2));color:#fff;box-shadow:var(--shadow-sm)}

  /* tactile / spring micro-interactions (как в 23) */
  .razdel .ic,.card,.chip,.razdel,.read,.all-link,.more,.slider-arrow,.sec-head .navs button,.tabbar a{transition-timing-function:cubic-bezier(.34,1.56,.64,1)}
  .razdel:active{transform:scale(.95)}
  .razdel:active .ic{transform:scale(.9)}
  .chip:active{transform:scale(.93)}
  .card:active{transform:scale(.992)}
  .read:active,.all-link:active{transform:scale(.95)}
  .more:active{transform:scale(.94)}
  .slider-arrow:active{transform:translateY(-50%) scale(.92)}
  .sec-head .navs button:active{transform:scale(.9)}
  .tabbar a:active{transform:scale(.9)}
  @media(prefers-reduced-motion:reduce){
    .razdel:active,.razdel:active .ic,.chip:active,.card:active,.read:active,.all-link:active,.more:active,.slider-arrow:active,.sec-head .navs button:active,.tabbar a:active{transform:none}
  }

  /* feed header */
  .feed-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:20px 0 14px}
  .feed-head h2{font-family:'Plus Jakarta Sans';font-size:clamp(20px,3vw,26px);font-weight:800;color:var(--deep)}
  .feed-head .all-link{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:800;color:var(--primary);white-space:nowrap}
  .feed-head .all-link svg{width:16px;height:16px;transition:transform .2s}
  .feed-head .all-link:hover svg{transform:translateX(4px)}

  /* feed list — расширенные новости (image left, lead + read link) */
  .feed{display:flex;flex-direction:column;gap:16px}
  .card{position:relative;background:var(--glass);backdrop-filter:blur(12px) saturate(1.2);border:1px solid var(--glass-bd);
    border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.25s;display:flex;flex-direction:column}
  @media(min-width:640px){.card{flex-direction:row}}
  .card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(43,164,222,.45)}
  .card .thumb{position:relative;overflow:hidden;flex:0 0 auto;height:clamp(170px,46vw,210px)}
  @media(min-width:640px){.card .thumb{width:220px;height:auto;align-self:stretch}}
  @media(min-width:980px){.card .thumb{width:290px}}
  .card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
  .card:hover .thumb img{transform:scale(1.05)}
  .type-badge{position:absolute;top:10px;left:10px;z-index:2;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;
    padding:5px 10px;border-radius:999px;color:#fff;background:rgba(27,117,187,.92);backdrop-filter:blur(4px);box-shadow:0 2px 8px rgba(0,0,0,.2)}
  .type-badge.t-rep{background:rgba(22,181,165,.94)}
  .type-badge.t-event{background:rgba(224,35,27,.94)}
  .card .body{padding:16px 18px 18px;flex:1;min-width:0;display:flex;flex-direction:column;gap:9px}
  .card h3{font-size:16.5px;line-height:1.32;font-weight:800;color:var(--deep);transition:color .2s}
  @media(min-width:980px){.card h3{font-size:19px}}
  .card:hover h3{color:var(--primary)}
  .card .meta{display:flex;align-items:center;gap:14px;font-size:12.5px;color:var(--muted);font-weight:700;flex-wrap:wrap}
  .card .meta .it{display:inline-flex;align-items:center;gap:5px}
  .card .meta .views{margin-left:auto}
  .card .meta svg{width:14px;height:14px;color:var(--primary)}
  .card .lead{font-size:13.5px;line-height:1.6;color:var(--muted);
    display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
  @media(min-width:980px){.card .lead{-webkit-line-clamp:4}}
  .card .read{margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:6px;
    font-size:13.5px;font-weight:800;color:var(--primary);transition:.2s}
  .card .read svg{width:16px;height:16px;transition:transform .2s}
  .card .read:hover{color:var(--deep)}
  .card .read:hover svg{transform:translateX(4px)}
  .card .read::after{content:"";position:absolute;inset:0;z-index:1} /* stretched link — вся карточка кликабельна */
  .empty-state{text-align:center;padding:48px 20px;color:var(--muted);display:none}
  .empty-state svg{width:48px;height:48px;color:var(--bd);margin:0 auto 14px}
  .empty-state.show{display:block}

  /* ===== main two-column layout (структура как в референсе) ===== */
  .main-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:24px;margin-top:8px}
  @media(min-width:980px){.main-grid{grid-template-columns:minmax(0,1fr) 336px;align-items:start}}
  .main-col{min-width:0}
  .side-col{display:flex;flex-direction:column;gap:18px;min-width:0}
  .panel-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}
  .panel-head h3{font-size:17px;font-weight:800;color:var(--deep);display:flex;align-items:center;gap:8px;margin:0}
  .panel-head h3 svg{width:19px;height:19px;color:var(--teal)}
  .panel-head .line{flex:1;height:1px;background:var(--bd)}
  .panel-head .navs{display:flex;gap:6px}
  .panel-head .navs button{width:34px;height:34px;border-radius:50%;background:#fff;border:1px solid var(--bd);color:var(--deep);
    box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;transition:.18s;cursor:pointer}
  .panel-head .navs button:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
  .panel-head .navs button:active{transform:scale(.9)}
  .panel-head .navs svg{width:16px;height:16px}
  .side-col .journals{padding-bottom:6px}
  .side-col .jcard{flex:0 0 128px}
  .stats-strip{background:var(--sect)}

  /* mobile polish (≤560px) — компактнее и чётче на телефоне */
  @media(max-width:560px){
    .razdely{gap:10px}
    .razdel{width:78px;gap:8px}
    .razdel .ic{width:58px;height:58px}
    .razdel .ic svg{width:24px;height:24px}
    .razdel span{font-size:11.5px}
    .card h3{font-size:16px}
    .card .body{padding:14px 15px 16px;gap:8px}
    .card .lead{font-size:13px;-webkit-line-clamp:3}
    .main-col .sec-head .navs{display:none}      /* стрелки новостей не нужны — скролл естественный */
    .feed-head{margin:14px 0 12px}
  }

  /* ===== news preview modal (bottom-sheet на мобиле, центр на десктопе) ===== */
  .modal-overlay{position:fixed;inset:0;z-index:120;background:rgba(8,28,48,.55);backdrop-filter:blur(6px);
    display:flex;align-items:flex-end;justify-content:center;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}
  .modal-overlay.open{opacity:1;visibility:visible}
  @media(min-width:680px){.modal-overlay{align-items:center;padding:24px}}
  .modal{background:#fff;width:100%;max-width:680px;max-height:92vh;overflow-y:auto;border-radius:24px 24px 0 0;
    box-shadow:var(--shadow-lg);transform:translateY(48px);transition:transform .32s cubic-bezier(.34,1.4,.64,1);
    position:relative;-webkit-overflow-scrolling:touch}
  @media(min-width:680px){.modal{border-radius:24px;transform:translateY(24px) scale(.98)}}
  .modal-overlay.open .modal{transform:none}
  .modal-handle{width:40px;height:4px;border-radius:999px;background:rgba(255,255,255,.85);position:absolute;top:10px;left:50%;
    transform:translateX(-50%);z-index:3}
  @media(min-width:680px){.modal-handle{display:none}}
  .modal-close{position:absolute;top:12px;right:12px;z-index:3;width:40px;height:40px;border-radius:50%;border:none;
    background:rgba(255,255,255,.92);backdrop-filter:blur(6px);color:var(--deep);box-shadow:var(--shadow-sm);
    display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.18s}
  .modal-close:hover{background:var(--primary);color:#fff}
  .modal-close:active{transform:scale(.9)}
  .modal-close svg{width:20px;height:20px}
  .modal-media{position:relative;aspect-ratio:16/9;overflow:hidden}
  .modal-media img{width:100%;height:100%;object-fit:cover}
  .modal-body{padding:18px 20px 26px}
  .modal-body .meta{display:flex;gap:14px;font-size:12.5px;color:var(--muted);font-weight:700;margin-bottom:10px;flex-wrap:wrap}
  .modal-body .meta .views{margin-left:auto}
  .modal-body .meta svg{width:14px;height:14px;color:var(--primary)}
  .modal-body h2{font-family:'Plus Jakarta Sans';font-size:clamp(20px,3.4vw,27px);font-weight:800;line-height:1.25;color:var(--deep);margin-bottom:14px}
  .modal-text p{font-size:14.5px;line-height:1.72;color:var(--txt);margin-bottom:12px}
  .modal-actions{margin-top:6px}

  /* stats */
  .stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:6px}
  @media(min-width:768px){.stats{grid-template-columns:repeat(4,1fr)}}
  .stat{background:var(--glass);backdrop-filter:blur(10px);border:1px solid var(--glass-bd);border-radius:var(--radius);
    padding:20px 16px;text-align:center;box-shadow:var(--shadow-sm)}
  .stat b{display:block;font-family:'Plus Jakarta Sans';font-size:30px;font-weight:800;
    background:linear-gradient(120deg,var(--deep),var(--teal));-webkit-background-clip:text;background-clip:text;color:transparent}
  .stat span{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}

  /* journals */
  .journals{display:flex;gap:16px;overflow-x:auto;padding:6px 2px 16px;scroll-snap-type:x mandatory;scrollbar-width:none}
  .journals::-webkit-scrollbar{display:none}
  .jcard{flex:0 0 160px;scroll-snap-align:start}
  @media(min-width:768px){.jcard{flex:0 0 200px}}
  .jcard .cover{aspect-ratio:3/4;border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow);position:relative;transition:.25s}
  .jcard:hover .cover{transform:translateY(-5px) rotate(-1deg);box-shadow:var(--shadow-lg)}
  .jcard .cover img{width:100%;height:100%;object-fit:cover}
  .jcard .cover .badge{position:absolute;top:0;left:0;background:linear-gradient(120deg,var(--hdr1),var(--hdr2));color:#fff;
    font-size:11px;font-weight:800;padding:6px 12px;border-bottom-right-radius:12px}
  .jcard .lbl{margin-top:10px;font-size:13px;font-weight:700;color:var(--deep)}
  .jcard .lbl small{display:block;color:var(--muted);font-weight:600;font-size:11.5px}

  /* lower grid */
  .lower{display:grid;grid-template-columns:1fr;gap:18px}
  @media(min-width:880px){.lower{grid-template-columns:1fr 1fr}}
  .panel{background:var(--glass);backdrop-filter:blur(12px) saturate(1.2);border:1px solid var(--glass-bd);
    border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);min-width:0;overflow:hidden}
  .panel h3{font-size:18px;font-weight:800;color:var(--deep);margin-bottom:16px;display:flex;align-items:center;gap:9px}
  .panel h3 svg{width:20px;height:20px;color:var(--teal)}

  /* calendar */
  .cal-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
  .cal-top b{font-size:15px;color:var(--deep)}
  .cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;text-align:center}
  .cal-grid .dow{font-size:11px;font-weight:800;color:var(--muted);padding:4px 0;text-transform:uppercase}
  .cal-grid .day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;
    border-radius:10px;color:var(--txt);min-height:34px}
  .cal-grid .day.mute{color:#c4cfd6}
  .cal-grid .day.ev{background:rgba(22,181,165,.14);color:var(--teal);font-weight:800;position:relative}
  .cal-grid .day.ev::after{content:"";position:absolute;bottom:5px;width:4px;height:4px;border-radius:50%;background:var(--teal)}
  .cal-grid .day.today{background:linear-gradient(120deg,var(--hdr1),var(--hdr2));color:#fff;font-weight:800;box-shadow:var(--shadow-sm)}

  /* intl news */
  .intl-item{display:flex;gap:13px;padding:13px 0;border-bottom:1px solid var(--bd)}
  .intl-item>div{min-width:0}
  .intl-item .ttl{overflow-wrap:anywhere}
  .intl-item:last-child{border-bottom:none;padding-bottom:0}
  .intl-flag{font-size:24px;flex-shrink:0;width:42px;height:42px;display:flex;align-items:center;justify-content:center;
    background:#fff;border-radius:12px;box-shadow:var(--shadow-sm)}
  .intl-item .ttl{font-size:14px;font-weight:700;color:var(--deep);line-height:1.3}
  .intl-item .sub{font-size:12px;color:var(--muted);margin-top:3px}
  .badge-eu{font-size:10px;font-weight:800;color:var(--gear);background:rgba(46,134,193,.12);padding:2px 8px;border-radius:999px;margin-left:6px}
  .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
  .tag{font-size:12px;font-weight:700;color:var(--deep);background:rgba(43,164,222,.1);padding:6px 13px;border-radius:999px;transition:.18s}
  .tag:hover{background:var(--primary);color:#fff}

  /* featured red banner */
  .hot{background:linear-gradient(120deg,#c61f17,var(--red));border-radius:var(--radius);padding:22px;color:#fff;
    box-shadow:var(--shadow);position:relative;overflow:hidden;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
  .hot::before{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.1)}
  .hot .tag-hot{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;background:#fff;color:var(--red);
    padding:5px 12px;border-radius:999px;flex-shrink:0}
  .hot .htext{flex:1;min-width:200px}
  .hot h3{font-size:19px;font-weight:800;margin-bottom:4px;color:#fff}
  .hot p{font-size:13px;opacity:.92}
  .hot .more{flex-shrink:0;background:#fff;color:var(--red);font-weight:800;font-size:13px;padding:11px 20px;border-radius:999px;
    display:inline-flex;align-items:center;gap:7px;min-height:44px}
  .hot .more svg{width:16px;height:16px}

  /* ============ FOOTER ============ */
  footer{background:linear-gradient(180deg,#0e4e74,#0a3c5a);color:#cfe5f2;margin-top:40px;padding-bottom:96px}
  @media(min-width:1080px){footer{padding-bottom:0}}
  .foot-grid{display:grid;grid-template-columns:1fr;gap:28px;padding:42px 0 30px}
  @media(min-width:680px){.foot-grid{grid-template-columns:1.4fr 1fr 1fr}}
  @media(min-width:980px){.foot-grid{grid-template-columns:1.6fr 1fr 1fr 1fr}}
  footer .logo .m,footer .logo .e{color:#fff}
  footer .logo .gt{color:#7fd0ee}
  .foot-grid p.about{font-size:13px;line-height:1.6;color:#a9cee2;margin-top:14px;max-width:300px}
  .foot-col h4{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#fff;margin-bottom:14px}
  .foot-col a{display:block;font-size:13.5px;color:#bcd9ea;padding:6px 0;transition:.15s}
  .foot-col a:hover{color:#fff;padding-left:4px}
  .foot-social{display:flex;gap:10px;margin-top:16px}
  .foot-social a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;transition:.2s}
  .foot-social a:hover{background:var(--primary)}
  .foot-social svg{width:18px;height:18px}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding:18px 0;font-size:12.5px;color:#9cc1d6;text-align:center}

  /* bottom tab bar (mobile) */
  .tabbar{position:fixed;bottom:0;left:0;right:0;z-index:90;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);
    border-top:1px solid var(--bd);display:flex;justify-content:space-around;padding:6px 4px env(safe-area-inset-bottom,6px);
    box-shadow:0 -8px 24px -12px rgba(27,117,187,.3)}
  @media(min-width:1080px){.tabbar{display:none}}
  .tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 2px;color:var(--muted);
    font-size:10.5px;font-weight:700;min-height:48px;justify-content:center;border-radius:12px}
  .tabbar a.on{color:var(--primary)}
  .tabbar a svg{width:22px;height:22px}

  /* back to top */
  .to-top{position:fixed;right:14px;bottom:84px;z-index:88;width:46px;height:46px;border-radius:50%;
    background:linear-gradient(120deg,var(--hdr1),var(--hdr2));color:#fff;box-shadow:var(--shadow-lg);
    display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.25s;transform:translateY(10px)}
  .to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
  @media(min-width:1080px){.to-top{bottom:24px}}
  .to-top svg{width:22px;height:22px}

  @media(prefers-reduced-motion:reduce){
    *{animation:none!important;scroll-behavior:auto!important;transition-duration:.01ms!important}
    .slider-track{scroll-behavior:auto}
  }

  /* ===== horizontal carousel rows (видео-доклады / репортажи / related) ===== */
  .vrow{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 2px 14px;
    -webkit-overflow-scrolling:touch;scrollbar-width:none}
  .vrow::-webkit-scrollbar{display:none}
  .vcard{flex:0 0 86%;scroll-snap-align:start;background:var(--glass);backdrop-filter:blur(12px) saturate(1.2);
    border:1px solid var(--glass-bd);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
    display:flex;flex-direction:column;transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s;min-width:0}
  @media(min-width:560px){.vcard{flex:0 0 calc(50% - 8px)}}
  @media(min-width:980px){.vcard{flex:0 0 calc((100% - 32px)/3)}}
  .vcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
  .vthumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:#0b2e44}
  .vthumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
  .vcard:hover .vthumb img{transform:scale(1.05)}
  .vthumb .play{position:absolute;inset:0;margin:auto;width:56px;height:56px;border-radius:50%;
    background:rgba(255,255,255,.92);color:var(--primary);display:flex;align-items:center;justify-content:center;
    box-shadow:0 6px 20px rgba(0,0,0,.3);transition:.22s}
  .vcard:hover .vthumb .play{transform:scale(1.1);background:#fff}
  .vthumb .play svg{width:24px;height:24px;margin-left:2px}
  .vthumb .dur{position:absolute;bottom:8px;right:8px;background:rgba(11,46,68,.85);color:#fff;font-size:11px;
    font-weight:700;padding:3px 8px;border-radius:6px;display:inline-flex;align-items:center;gap:4px}
  .vthumb .dur svg{width:12px;height:12px}
  .vbody{padding:14px 16px 16px;display:flex;flex-direction:column;gap:8px;flex:1;min-width:0}
  .vbody h3{font-size:16px;font-weight:800;color:var(--deep);line-height:1.3;transition:color .2s}
  .vcard:hover .vbody h3{color:var(--primary)}
  .vbody .meta{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--muted);font-weight:700;flex-wrap:wrap}
  .vbody .meta .it{display:inline-flex;align-items:center;gap:5px}
  .vbody .meta .views{margin-left:auto}
  .vbody .meta svg{width:13px;height:13px;color:var(--primary)}
  .vbody .lead{font-size:13px;line-height:1.55;color:var(--muted);
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .vcard .read{margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:6px;
    font-size:13px;font-weight:800;color:var(--primary)}
  .vcard .read svg{width:15px;height:15px;transition:transform .2s}
  .vcard:hover .read svg{transform:translateX(3px)}
