/* ===== VARIABLES ===== */
:root {
    --primary-red: #A90B20;
    --secondary-blue: #346989;
    --secondary-blue-light: #5d92b1;
    --second-red: #D10000;
    --nav-red: #cc0114;
    --red-light: #f2e8e9;
    --red-dark: #8a0920;
    --text-dark: #232323;
    --text-light: #666666;
    --white: #ffffff;
    --gray-bg: #f1f1f1;
    --red-bg: rgba(207, 173, 170, 0.22);
    --blue-bg: rgba(179, 215, 241, 0.22);
    --gray-border: #e0e0e0;
    --border-radius: 12px;
    --shadow: 0 4px 20px rgba(0,0,0,0.08);
    --shadow-red: 0 4px 20px rgba(169, 11, 32, 0.22);
    --shadow-hover: 0 8px 30px rgba(0,0,0,0.12);
    --text-shadow: 0 2px 4px rgba(0,0,0,0.4);
    --text-shadow-title: 0 1px 1px rgba(0,0,0,0.3);
    --arrow-color: #A90B20;
    --arrow-color-hover: #ff3348;
    --arrow-rotation-prev: 180deg;
    --arrow-rotation-next: 0deg;
    
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body { font-family: 'Inter', sans-serif; background: var(--red-bg); color: var(--text-dark); line-height: 1.5; }

.container { max-width: 1280px; margin: 0 auto; padding: 0px 24px 60px 24px}

.container a {color: var(--nav-red);text-decoration: none;}
    .container a:hover {color: var(--red-dark);}

h1, h2, h3, .logo { font-family: 'Plus Jakarta Sans', sans-serif; }
h1 { font-size: 2.rem; margin-bottom: 2.5rem; font-weight: 500; color: var(--primary-red); position: relative;letter-spacing: 2px;}
h2 { font-size: 2rem; margin-bottom: 1.5rem; font-weight: 300; color: var(--text-dark); position: relative;}

h2:after { content: ''; position: absolute; bottom: -8px; left: 0; width: 60px; height: 3px; background: var(--primary-red); border-radius: 2px; }

.section-header { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; margin-bottom: 32px; }

a.link-arrow {color: var(--secondary-blue); border-top: 1px dashed var(--secondary-blue);border-bottom: 1px dashed var(--secondary-blue); text-decoration: none; font-weight: 600; display: inline-flex; align-items: center; gap: 4px; }
    a.link-arrow:hover { transform: translateX(4px); color: var(--secondary-blue);}

/* ===== BUTTONS ===== */
.btn { display: inline-flex; align-items: center; justify-content: center; padding: 12px 28px; border-radius: 10px; font-weight: 400; text-decoration: none; transition: all 0.3s; font-size: 1.1rem; cursor: pointer; border: none; }
.btn i {padding: 0 5px;font-size: 20px;}
.btn--primary { background: var(--nav-red); color: var(--white) !important; text-decoration: none; border: 1px solid var(--primary-red);}
.btn--primary:hover { background: var(--red-dark); transform: translateY(-2px); border: 1px solid var(--nav-red);color: var(--white) !important; }
.blue { background: var(--secondary-blue-light); color: var(--white); text-decoration: none; border: 1px solid var(--secondary-blue);}
.blue:hover { background: var(--secondary-blue); transform: translateY(-2px); border: 1px solid var(--secondary-blue-light);color: var(--white) !important; }
.btn--outline { background: transparent; border: 2px solid var(--primary-red); color: var(--primary-red); }
.btn--outline:hover { background: var(--primary-red); color: var(--white); }

.btn--small { padding: 8px 20px; font-size: 0.85rem; border-radius: 10px; font-weight: 500; }

/*===== СТРЕЛКИ СЛАЙДЕР =====*/
.swiper-button-prev,
.swiper-button-next { width: 50px; height: 65px; position: absolute; top: 60%; transform: translateY(-50%); z-index: 10; cursor: pointer; color: var(--arrow-color); transition: all 0.3s ease; }
.swiper-button-prev::after,
.swiper-button-next::after { display: none; }
.arrow-icon { width: 100%; height: 100%; display: block; }
.swiper-button-prev .arrow-icon { transform: var(--arrow-rotation-prev); }
.swiper-button-next .arrow-icon { transform: rotate(180deg);}
.swiper-button-prev:hover,
.swiper-button-next:hover { color: var(--secondary-blue-light); }

.news-slider {padding: 0 25px;}
.news-slider .swiper-button-prev {left:0}
.news-slider .swiper-button-next {right:0}

/* ПАРТНЁРЫ - переопределяем переменные */
.partners-slider { --arrow-color: #ffffff; --arrow-color-hover: #cccccc; --arrow-rotation-prev: -90deg; --arrow-rotation-next: 90deg; }

/* НОВОСТИ - переопределяем переменные */
.news-slider { --arrow-color: #A90B20; --arrow-color-hover: #ff3348; --arrow-rotation-prev: 180deg; --arrow-rotation-next: 0deg; }

/* Адаптив */
@media (max-width: 768px) { .swiper-button-prev,
.swiper-button-next { width: 30px; height: 30px; } }


/* ===== FILTERS SECTION ===== */
.filters-section { background: rgba(179, 215, 241, 0.3); padding: 32px 0; }
.filters-section .container { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.filters-row { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; justify-content: center; }
.filter-select { padding: 12px 32px 12px 20px; border: 1px solid rgba(66, 86, 111, 0.3); border-radius: 10px; font-family: 'Inter', sans-serif; font-size: 0.9rem; background: var(--white); color: var(--secondary-blue); cursor: pointer; transition: all 0.3s; }
.filter-select:hover { border-color: rgba(66, 86, 111, 0.6); }
select.filter-select { appearance: none; background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2342566f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e"); background-repeat: no-repeat; background-position: right 16px center; background-size: 14px; }
input.filter-select { background-image: none; }
.btn-submit { background: var(--secondary-blue); border: 2px solid var(--secondary-blue); padding: 12px 28px; border-radius: 10px; font-weight: 500; color: var(--white); cursor: pointer; transition: all 0.3s; font-size: 0.85rem; }
.btn-submit:hover { background: var(--secondary-blue-light); transform: translateY(-2px); border-color: var(--secondary-blue-light); color: var(--white); }
.btn-reset { background: transparent; border: 2px solid var(--secondary-blue); padding: 12px 28px; border-radius: 10px; font-weight: 500; color: var(--secondary-blue); cursor: pointer; transition: all 0.3s; font-size: 0.85rem; }
.btn-reset:hover { background: var(--secondary-blue); transform: translateY(-2px); color: var(--white); }
@media (max-width: 768px) { .filters-row { flex-direction: column; align-items: stretch; } .filter-select { width: 100%; } }

/* ===== HEADER ===== */
.header { background: rgba(255, 255, 255, 1); backdrop-filter: blur(10px); position: sticky; top: 0; z-index: 100; border-bottom: 1px solid rgba(0, 0, 0, 0.08);  box-shadow: var(--shadow-hover);}  

.header-inner { display: flex; justify-content: space-between; align-items: center; padding: 12px 0; gap: 20px; }

.logo { display: inline-block; line-height: 0; }
.logo img { width: 200px; height: auto; display: block; }

/* ===== МЕНЮ ===== */
.nav { display: flex; align-items: center; list-style: none; margin: 0; padding: 0; }
.nav a { position: relative; background: var(--secondary-blue-light); border: none; padding: 2px 30px 4px 30px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.0rem; cursor: pointer; transition: all 0.3s; color: var(--white); text-decoration: none; display: inline-block; border-radius: 0; position: relative; }
.nav a:hover { background: var(--nav-red); color: var(--white);}
.nav a.active { background: var(--nav-red); color: var(--white); text-shadow: var(--text-shadow); }
.nav a:after { content: '';  position: absolute;   right: -20px;   top: 50%;   transform: translateY(-50%);   width: 41px;   height: 63px;   background-image: url(../img/arrow-nav-top.svg);   background-size: contain;   background-repeat: no-repeat;   z-index: 10000;}
/* Стрелка справа у первого элемента */
.nav a:first-child::after { content: ''; position: absolute; right: -20px; top: 50%; transform: translateY(-50%);   width: 41px;   height: 63px;  background-image: url('../img/arrow-nav-top.svg'); fill: var(--white) !important; background-size: contain; background-repeat: no-repeat; }
/* Стрелка слева у первого элемента */
.nav a:first-child::before { content: ''; position: absolute; left: -1px; top: 50%; transform: translateY(-50%);  width: 20px;   height: 30px;  background-image: url('../img/arrow-nav-top-first.svg'); background-size: contain; background-repeat: no-repeat; }
/* Стрелка справа у последней кнопки (если нужна) */
.nav a:last-child::after { content: ''; position: absolute; right: -5px; top: 50%; transform: translateY(-50%); width: 20px;   height: 30px;  background-image: url('../img/arrow-nav-top-last.svg'); background-size: contain; background-repeat: no-repeat; }


/* Мобильное меню */
.mobile-menu-btn { display: none; font-size: 1.8rem; cursor: pointer; background: none; border: none; color: var(--secondary-blue); }

@media (max-width: 768px) {
    .nav { display: none; position: absolute; top: 53px; left: 0; right: 0; background: var(--white); flex-direction: column; /*gap: 16px;*/ padding: 20px; box-shadow: var(--shadow); z-index: 99; }    
    .nav.active { display: flex; }    
    .nav a { width: 100%; text-align: center; padding: 12px 20px; background: none; color: var(--secondary-blue);font-family: 'Plus Jakarta Sans', sans-serif !important; font-size: 1.2rem; border-bottom: 1px dashed var(--secondary-blue-light);} 
    .nav a:hover, .nav a.active {color: var(--nav-red);background: none; text-shadow:none}   
     .nav a.active {font-size: 1.5rem;font-weight: 100;}
    .nav a::after { display: none; }    
    .mobile-menu-btn { display: block; }
}

/* ===== HERO ===== */
.hero { background: #222 url('../img/fon_h.webp'); background-size: cover; background-position: center; padding: 100px 0; text-align: center; color: var(--white); }
.hero-description { max-width: 900px; margin: 0 auto; padding: 24px 32px; background: rgba(180,196,207,0.2); backdrop-filter: blur(10px); border-radius: var(--border-radius); border: 2px solid rgba(180,196,207,0.3); margin-top: -190px;}
.hero-description p { font-size: 1.2rem; line-height: 1.6; color: rgba(255,255,255,0.95); text-shadow: var(--text-shadow); }

/*===  хиро для внутренних ====*/
.page-header { background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 60%, rgba(255,255,255,0) 100%); padding: 40px 0; text-align: center; }
    .page-header .container {padding: 0 !important;}
.page-title { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 2.8rem; letter-spacing: 2px; font-weight: 500; line-height: 1; color: var(--red-dark); margin-bottom: 12px;   padding:60px 0 40px 0;
 background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 178 311'%3E%3Cpath d='M22.4 310.4L0 288L132.8 155.2L0 22.4L22.4 0L177.6 155.2L22.4 310.4Z' fill='%238A0920'/%3E%3C/svg%3E") bottom repeat-x;
  background-size: 3px;
}
.page-description { font-size: 1.2rem; color: var(--secondary-blue); text-shadow: var(--text-shadow-title); padding-bottom: 40px;}

/* ==== Навигация по годам ====== */
.year-nav { display: flex; justify-content: center; margin-bottom: 40px; }
.year-list { display: flex; align-items: center; list-style: none; margin: 0; padding: 0; }
.year-item { position: relative; margin: 0; }

/* Стрелка между кнопками */
.year-item:not(:last-child)::after { content: ''; position: absolute;  right: -20px;  top: 50%;  transform: translateY(-50%);  width: 48px;  height: 63px;   background-image: url(../img/arrow-nav.svg);  background-size: contain;  background-repeat: no-repeat;
    z-index: 80;}

/* Стрелка справа у первого элемента */
.year-item:first-child::after { content: ''; position: absolute; right: -18px; top: 50%; transform: translateY(-50%); width: 48px; height: 63px; background-image: url('../img/arrow-nav.svg'); background-size: contain; background-repeat: no-repeat; }
/* Стрелка слева у первого элемента */
.year-item:first-child::before { content: ''; position: absolute; left: -10px; top: 50%; transform: translateY(-50%); width: 48px; height: 63px; background-image: url('../img/arrow-nav-first.svg'); background-size: contain; background-repeat: no-repeat; }
/* Стрелка справа у последней кнопки (если нужна) */
.year-item:last-child::after { content: ''; position: absolute; right: -20px; top: 50%; transform: translateY(-50%);  width: 48px;  height: 63px; background-image: url('../img/arrow-nav.svg'); background-size: contain; background-repeat: no-repeat; }
.year-btn { background: var(--secondary-blue-light); border: none; padding: 7px 35px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.2rem; font-weight: 800; cursor: pointer; transition: all 0.3s; color: var(--white); border-radius: 0; }
.year-btn.active { background: var(--primary-red); color: var(--white); text-shadow: var(--text-shadow);}
.year-btn:hover:not(.active) { background: var(--secondary-blue);}
@media (max-width: 768px) {
    .year-item::before,
    .year-item::after { display: none; }
    .year-list { gap: 12px; flex-wrap: wrap; justify-content: center; }
    .year-btn { padding: 8px 16px; font-size: 0.85rem; }
}

/* ===== NEWS SECTION INDEX ===== */
/*news-card*/
.news-section, .map-section { padding: 60px 0; background: rgba(179, 215, 241, 0.3); }

.news-slider .news-card { background: var(--white); border-radius: var(--border-radius); padding: 24px 35px; box-shadow: var(--shadow); transition: transform 0.3s, box-shadow 0.3s; text-decoration: none; color: inherit; display: block; }
.news-slider .news-card:hover { transform: none !important; box-shadow: none !important; }
.news-card__title { font-size: 1.2rem; margin-bottom: 12px; color: var(--secondary-blue); font-weight: 700; line-height: 1.2;}
.news-card__announce { color: var(--text-light); margin-bottom: 16px; line-height: 1.4;  line-clamp: 2; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.news-card__hashtags { margin-bottom: 0; border-top: 5px solid var(--blue-bg);}
 .hashtag { color: var(--primary-red); font-size: 0.85rem; font-weight: 500; text-decoration: none; font-style: italic; display: inline-block; margin-right: 8px; }

/*====== отступ внутреннних страниц =========*/
.events-page, .news-page {padding: 60px 0; }

/* ===== TIMELINE (для главной страницы) ===== */
.events-section { padding: 60px 0;}
.timeline { max-width: 800px; margin: 40px auto 0; }
.timeline-year { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 2rem; font-weight: 700; color: var(--primary-red); margin-bottom: 24px; }
.timeline-item { display: flex; gap: 24px; padding: 20px 0; border-left: 2px solid var(--gray-border); margin-left: 20px; padding-left: 30px; position: relative; text-decoration: none; color: inherit; transition: transform 0.2s; }
.timeline-item:hover { transform: translateX(4px); }
.timeline-item:before { content: ''; position: absolute; left: -9px; top: 25px; width: 16px; height: 16px; background: var(--primary-red); border-radius: 50%; transition: transform 0.2s; }
.timeline-item:hover:before { transform: scale(1.3); }
.timeline-date { min-width: 140px; font-weight: 680; color: var(--secondary-blue-light); }
.timeline-title { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 600; margin-bottom: 4px; font-size: 1.3rem;  color: var(--secondary-blue);margin-top: -5px;}
.timeline-location { color: var(--text-light); font-size: 0.9rem; }
.empty-timeline { text-align: center; padding: 60px 20px; color: var(--text-light); font-size: 1rem; }
.archive-link { text-align: right; margin-top: 30px; }

/*========  EVENTS  =============*/
.events-layout { display: flex; gap: 40px; align-items: flex-start; }
.events-layout__calendar { width: 300px; flex-shrink: 0; background: var(--blue-bg);padding: 0 30px;}
.events-layout__info { flex: 1; }
@media (max-width: 768px) { .events-layout { flex-direction: column; } .events-layout__calendar { width: 100%;padding: 0 20px;} }

.info-block { margin-bottom: 16px; padding-left: 24px; position: relative; }
.info-badge { position: absolute; left: 0; top: 6px; width: 12px; height: 12px; border-radius: 2px; }
.info-badge.past { background: var(--text-light); }
.info-badge.current { background: var(--primary-red);}
.info-badge.upcoming { background: var(--secondary-blue);  }
.events-info__content {padding-top: 20px;}
    .events-info__content h2 {padding-top: 60px;}
    .events-info__content p {padding: 20px 0;}
    .events-info__content ul { margin: 12px 0 12px 0; list-style: none; padding: 0 0 0 40px; }
    .events-info__content li { position: relative; padding-left: 24px; margin-bottom: 10px; color: var(--text-light); line-height: 1.5; }
        .events-info__content li::before { content: '>>'; position: absolute; left: 0; top: 2px; color: var(--primary-red); font-size: 0.8rem; font-weight: 800; }

/* ===== CALENDAR (для страницы мероприятий) ===== */
.calendar { background: var(--white); border-radius: 16px; box-shadow: var(--shadow); overflow: hidden; margin-top: 40px; }
.calendar-header { background: var(--primary-red); color: var(--white); padding: 20px; text-align: center; font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.5rem; display: flex; justify-content: space-between; align-items: center; }
.month-nav { background: rgba(255,255,255,0.2); border: none; color: var(--white); width: 36px; height: 36px; border-radius: 50%; cursor: pointer; font-size: 1.2rem; }
.month-nav:hover { background: rgba(255,255,255,0.3); }
.calendar-weekdays { display: grid; grid-template-columns: repeat(7, 1fr); background: var(--gray-bg); border-bottom: 1px solid var(--gray-border); }
.weekday { padding: 12px; text-align: center; font-weight: 600; color: var(--text-dark); }
.calendar-days { display: grid; grid-template-columns: repeat(7, 1fr); }
.calendar-day { min-height: 100px; padding: 8px; border-right: 1px solid var(--gray-border); border-bottom: 1px solid var(--gray-border); position: relative; background: var(--white); transition: 0.2s; cursor: pointer; }
.calendar-day:hover { background: var(--gray-bg); }
.day-number { font-weight: 600;color: var(--secondary-blue-light); font-size: 0.9rem; }
.calendar-day.has-event { background: #fff9f9; }
    .calendar-day.has-event .day-number { color: var(--primary-red); font-weight: 800; }
.event-title { font-size: 0.7rem; font-weight: 600; color: var(--primary-red); line-height: 1.2; word-break: break-word; }
.event-tooltip { position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%); background: var(--white); border-radius: var(--border-radius); box-shadow: var(--shadow-hover); padding: 16px; min-width: 240px; z-index: 100; opacity: 0; visibility: hidden; transition: all 0.2s; pointer-events: none; margin-bottom: 8px; border-top: 3px solid var(--primary-red); }
.calendar-day:hover .event-tooltip { opacity: 1; visibility: visible; }
.tooltip-title { font-weight: 700; font-size: 1rem; margin-bottom: 8px; font-family: 'Plus Jakarta Sans', sans-serif; }
.tooltip-dates { font-size: 0.8rem; color: var(--primary-red); margin-bottom: 6px; }
.tooltip-location { font-size: 0.8rem; color: var(--text-light); margin-bottom: 10px; }
.tooltip-hashtags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.tooltip-hashtag { font-size: 0.7rem; color: var(--primary-red); font-style: italic; }
.tooltip-link { font-size: 0.75rem; color: var(--primary-red); text-decoration: none; font-weight: 600; }

/* ===== EVENTS PAGE (календарь-сетка) ===== */

.months-grid { display: grid; grid-template-columns: repeat(1, 1fr); gap: 24px; margin: 40px 0; }
@media (max-width: 1024px) { .months-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .months-grid { grid-template-columns: 1fr; } }

.month-card { background: var(--gray-bg); border-radius: var(--border-radius); overflow: hidden; box-shadow: var(--shadow); transition: transform 0.2s; cursor: pointer; border: 1px solid var(--blue-bg);}
.month-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); }
.month-header { background: var(--gray-bg); padding: 2px 15px; display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--gray-border); }
.month-header.has-events { background: var(--secondary-blue-light); color: var(--white);   text-shadow: var(--text-shadow);}
.month-name { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 400; font-size: 1rem; }
.event-count { color: var(--white); font-size: 1rem; font-weight: 800;}
.month-days { display: grid; grid-template-columns: repeat(7, 1fr); padding: 12px; gap: 4px; }
.day-cell { aspect-ratio: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; font-weight: 500; color: var(--text-light); border-radius: 8px; position: relative; }
.day-cell.has-event { color: var(--second-red); font-weight: 700; cursor: pointer; /*border: 1px solid var(--second-red);*/text-decoration: none;}
    .day-cell.has-event .day-number {color: var(--nav-red);font-weight: 700; text-decoration: none;}
        .day-cell.has-event .day-number a {text-decoration: none;}
        .day-cell.has-event .day-number a:hover {color: var(--red-dark);}
.day-cell.has-event:hover { background: rgba(169,11,32,0.1); }
.calendar-day.has-event { border: 2px solid var(--primary-red); }
.day-cell.empty { background: transparent; }
.events-list { margin-top: 40px; padding-top: 40px; border-top: 2px solid var(--gray-border); }
.events-list-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; border-top: 1px dashed var(--secondary-blue-light);}
.events-list-header h3 { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.3rem; }
.close-events { background: none; border: none; font-size: 2.1rem; cursor: pointer; color: var(--text-light);}
.events-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
@media (max-width: 768px) { .events-cards { grid-template-columns: 1fr; } }
.event-card { background: var(--white); border-radius: var(--border-radius); padding: 20px; box-shadow: var(--shadow); text-decoration: none; color: inherit; transition: transform 0.2s; display: block; }
.event-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); }
.event-card__date { color: var(--text-dark); font-weight: 600; font-size: 0.8rem; margin-bottom: 8px; color: var(--secondary-blue-light); }
.event-card__title { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1rem; margin-bottom: 8px; color: var(--secondary-blue)}
.event-card__location { color: var(--text-light); font-size: 0.85rem; margin-bottom: 12px; }
.event-card__hashtags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px;}
.empty-events { text-align: center; padding: 40px; color: var(--text-light); }

/* ===== TIMELINE ДЛЯ СТРАНИЦЫ /events/  ===== */
.events-timeline { display: flex; overflow-x: auto; gap: 30px; padding: 20px 0 40px 0; scrollbar-width: thin; }
.events-timeline-year { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.5rem; font-weight: 600; color: var(--primary-red); margin-bottom: 20px; padding-bottom: 10px; border-bottom: 2px solid var(--primary-red); }
.events-timeline-item { display: block; padding: 12px; background: var(--gray-bg); border-radius: 8px; text-decoration: none; transition: all 0.2s; margin-bottom: 0; border-left: none; margin-left: 0; }
.events-timeline-item:hover { transform: translateX(4px); background: var(--white); box-shadow: var(--shadow); }
.events-timeline-item:before { display: none; }
.events-timeline-date { font-size: 0.75rem; color: var(--secondary-blue); margin-bottom: 6px; min-width: auto; }
.events-timeline-content { flex: 1; }
.events-timeline-title { font-weight: 600; margin-bottom: 4px; color: var(--text-dark); }
.events-timeline-location { font-size: 0.75rem; color: var(--text-light); margin-bottom: 6px; }
.events-timeline-hashtags { font-size: 0.7rem; color: var(--primary-red); margin-top: 0; }

.events-timeline-year-column { min-width: 280px; flex-shrink: 0; background: var(--white); border-radius: var(--border-radius); padding: 20px; box-shadow: var(--shadow); }
.events-timeline-events { display: flex; flex-direction: column; gap: 16px; }

@media (max-width: 768px) {
    .events-timeline-item { flex-direction: column; gap: 8px; }
    .events-timeline-date { min-width: auto; }
}

/* ===== EVENT PAGE INNER===== */
/* Hero Grid */
.event-hero { background: var(--secondary-blue); padding: 60px 0; }
.hero-grid { display: flex; align-items: center; gap: 80px; flex-wrap: wrap; }
.hero-content { flex: 1; min-width: 280px; }
.hero-slider { flex: 1.2; min-width: 320px; }

/* Логотип */
.event-logo { margin-bottom: 24px; }
.event-logo img { max-width: 300px; height: auto;filter: brightness(0) invert(1); }
/* Бейдж статуса */
.event-status {padding: 4px 12px; border-radius: 20px 20px 0 0; font-size: 1rem; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 0; background: var(--primary-red); color: var(--white); border: none; text-align: center;}

/* Заголовок */
.event-title { font-size: 2.8rem; margin-bottom: 20px; color: var(--white); text-shadow: var(--text-shadow);}

/* Даты и место */
.event-details { margin-bottom: 32px; }
.event-detail { margin-bottom: 12px; font-size: 1rem; color: var(--white); }
.event-detail i { margin-right: 10px; color: var(--white); width: 24px; }

/* Кнопки */
.buttons {display: flex; justify-content: center; gap: 20px; margin-top: 40px;}
.event-hero .event-buttons { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 32px; }
.event-hero .btn--primary { background: var(--blue-bg); color: var(--white); border: 2px solid var(--blue-bg); padding: 12px 28px; font-weight: 600; cursor: pointer; transition: all 0.3s; }
.event-hero .btn--primary:hover { background: var(--primary-red); transform: translateY(-2px); }
.event-hero .btn--outline { background: transparent; border: 2px solid var(--white); color: var(--white); padding: 12px 28px; font-weight: 600; cursor: pointer; transition: all 0.3s; opacity:0.8 }
.event-hero .btn--outline:hover { background: var(--primary-red); color: var(--white); transform: translateY(-2px); }
@media (max-width: 768px) {
@media (max-width: 768px) { 
    .buttons { 
        flex-direction: column !important; 
        align-items: stretch !important; 
    } 
    .buttons .btn { 
        width: 100% !important; 
        text-align: center !important; 
    } 
}
}

/* Соцсети */
.event-social { display: flex; gap: 16px; }
.event-social a { color: var(--white); font-size: 1.5rem; transition: color 0.3s; }
.event-social a:hover { color: var(--primary-red); }

/* Слайдер */
.gallery-slider { overflow: hidden; border-radius:0 0 20px 20px; box-shadow: var(--shadow); }
.gallery-slider .swiper-slide img { width: 100%; height: 400px; object-fit: cover; display: block; }
.gallery-slider .swiper-button-prev,
.gallery-slider .swiper-button-next { width: 40px; height: 40px; background: rgba(0,0,0,0.5); border-radius: 50%; }
.gallery-slider .swiper-button-prev:after,
.gallery-slider .swiper-button-next:after { font-size: 16px; color: var(--white); }

/* Адаптив */
@media (max-width: 1024px) {
    .gallery-slider .swiper-slide img { height: 350px; }
}

@media (max-width: 768px) {
 .event-hero   {padding: 30px 0;}
    .hero-grid { flex-direction: column; gap: 30px; }
    .hero-content, .hero-slider { flex: none; width: 100%; min-width: auto; }
    .hero-content { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 15px; }
    .event-logo { margin-bottom: 0; flex-shrink: 0; }
    .event-logo img { max-width: 140px; }
    .event-details { margin-bottom: 0; text-align: right; }
    .event-detail { font-size: 0.72rem; margin-bottom: 6px; white-space: nowrap; font-family: 'Plus Jakarta Sans', sans-serif !important;}
    .event-title { width: 100%; text-align: center; margin: 10px 0 0 0; order: 1;font-size: 1.8rem; padding-top: 20px;    border-top: 1px solid var(--white);  opacity: .8;}
    .event-buttons { width: 100%; flex-direction: column; gap: 12px; align-items: center; margin-top: 10px; order: 2; }
    .event-buttons .btn { width: 100%; max-width: 280px; text-align: center; }
    .event-social { width: 100%; justify-content: center; margin-top: 10px; order: 3; }    
    .gallery-slider .swiper-slide img { height: 220px; }
}
    
.stats-section { background: rgba(179, 215, 241, 0.3); padding: 60px 0 15px 0; }
    .stats-section .container {padding: 0 20px 60px 20px;} 
    .stats-wrapper { display: flex; align-items: stretch; gap: 20px; flex-wrap: wrap; border: 2px solid var(--secondary-blue-light);  border-radius: 10px;background: var(--blue-bg);}
    .stats-title-vertical { writing-mode:  sideways-lr; text-align: center; padding: 15px 10px; font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.5rem; font-weight: 500; text-shadow: var(--text-shadow); color: var(--white); background: var(--secondary-blue-light); letter-spacing: 2px; white-space: nowrap; }
    .stats-block { flex: 1; border: 2px solid var(--secondary-blue); background: transparent; padding: 30px; }
    .stats-grid { display: flex; justify-content: center; gap: 25px; flex-wrap: wrap; padding: 40px 20px;}
    .stat-card { background: var(--white); border: 1px solid var(--gray-border); border-radius: 12px; box-shadow: var(--shadow); padding: 30px 20px; text-align: center; min-width: 260px; display: flex; flex-direction: column; justify-content: center; align-items: center; }
    .stat-number { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 2.5rem; font-weight: 700; color: var(--primary-red); margin-bottom: 8px; }
    .stat-label { font-size: 0.85rem; color: var(--text-dark); text-transform: uppercase; letter-spacing: 1px; }

@media (max-width: 768px) {
    .stats-wrapper { flex-direction: column; align-items: flex-start; }
    .stats-title-vertical { writing-mode: horizontal-tb; transform: none; padding: 6px 16px; width: 100%;}
    .stats-block { width: 100%; padding: 20px; }
    .stats-grid { gap: 20px; }
    .stat-number { font-size: 1.5rem; }
    .stat-card { padding: 20px; width: 100%;}
}

.partners-section h2, .related-events h2 {text-align: center; font-size: 1.8rem;color: var(--white); padding: 40px 0 20px;border-bottom:1px dashed var(--blue-bg);}
    .partners-section h2::after, .related-events h2::after {content: none;}
/*====  Партнеры слайдер =====*/
.partners-logos { background: var(--secondary-blue);padding: 0;position: relative;}
.partners-logos .container {padding: 0;}
.vertical-logos-swiper { width: 100%; height: 150px; padding: 0 80px;}
.vertical-logos-swiper .swiper-wrapper {width: 80%;margin: 0 auto;}
.partners-logos-grid {display: grid;    grid-template-columns: repeat(6, 1fr);    grid-template-rows: repeat(2, 1fr);    gap: 20px;    height: 100%;    align-items: center;    justify-items: center;}
.partners-logo-item { padding: 5px;  margin-top: 2px;  transition: all 0.3s ease;   background: rgba(255, 255, 255, 0.5);  border-radius: 8px;}
    .partners-logo-item:hover .partners-logo-img {transform: scale(1.05);}
    .partners-logo-item:hover {transform: scale(1.05);}
.partners-logo-img {    max-width: 150px;    height: 80px;    object-fit: contain; transition: all 0.3s ease;}

.partners-logos .swiper-button-prev,
.partners-logos .swiper-button-next { width: 50px; height: 65px; color: var(--white); opacity: 0.6;position: absolute; top: 50%; transform: translateY(-50%); z-index: 10; cursor: pointer; }
.partners-logos .swiper-button-prev { left: 40px;}
.partners-logos .swiper-button-next { right: 40px;}
.partners-logos .swiper-button-prev::after,
.partners-logos .swiper-button-next::after { display: none; }
.partners-logos .swiper-button-prev .arrow-icon { transform: rotate(-90deg);}
.partners-logos .swiper-button-next .arrow-icon { transform: rotate(90deg);}
.partners-logos .swiper-button-prev:hover,
.partners-logos .swiper-button-next:hover { color: var(--white); opacity: 1;}
.partners-logos .swiper-button-prev:hover {transform: translateY(calc(-50% + 5px));}
.partners-logos .swiper-button-next:hover {transform: translateY(calc(-50% - 5px));}
.arrow-icon { width: 100%; height: 100%; display: block; }

@media (max-width: 768px) {
    .vertical-logos-swiper {height: 200px;padding: 0 40px;width: 90%;}
        .partners-logos-grid {grid-template-columns: repeat(2, 1fr);grid-template-rows: repeat(2, 1fr);gap: 15px;overflow: hidden;}
        .partners-logo-item:nth-child(n+5) {display: none;}
    .partners-logo-img {max-width: 100px;height: 50px;}
    
    .partners-logos .swiper-button-prev,    .partners-logos .swiper-button-next {width: 40px;height: 40px;margin-top: -20px;}    
    .partners-logos .swiper-button-prev img,.partners-logos .swiper-button-next img {width: 24px;}
.partners-logos .swiper-button-prev { left: 0px;}
.partners-logos .swiper-button-next { right: 0px;}
}

@media (max-width: 480px) {
        .vertical-logos-swiper {height: 180px;padding: 0 20px;}
        .exhibitors-logos-grid {gap: 10px;}
    .partners-logo-img {max-width: 80px;height: 40px;}
}

.description-section { padding: 30px 0; }
.description-text { max-width: 1200px; margin: 0 auto; }
.description-text p { margin-bottom: 20px; line-height: 1.5; color: var(--text-light); font-size: 1.2rem; }
    .description-text p b, .description-text p strong {color: var(--primary-red);}
.description-text i { color: var(--primary-red); margin-right: 5px; width: 30px; }
.description-text strong { color: var(--text-dark); }

/*.=====  ТЕМАТИКА =========*/
.themes-section {padding: 60px 0 40px 0;}
    .themes-grid {display: grid;grid-template-columns: repeat(4, 1fr);gap: 30px;max-width: 1280px;margin: 0 auto;padding-top: 20px;}
    .theme-card {position: relative;padding: 40px 30px;border-radius: 12px;background: var(--red-dark);color: var(--white);box-shadow: 0 5px 20px rgba(209, 0, 0, 0.2);transition: transform 0.3s ease, box-shadow 0.3s ease;    overflow: hidden;    display: flex;    flex-direction: column;    align-items: center;    text-align: center;    min-height: 320px;}
        .theme-card:hover {transform: translateY(-8px); box-shadow: 0 15px 35px rgba(209, 0, 0, 0.3)}
    .icon-container { flex-shrink: 0;  width: 60px;  height: 60px;   background: rgba(255, 255, 255, 0.2);   border-radius: 50%;   display: flex;   align-items: center;   justify-content: center;   border: 2px solid rgba(255, 255, 255, 0.3);   margin-bottom: 20px;    transition: transform 0.3s ease;}
    .theme-card:hover .icon-container {transform: scale(1.1);}
    .icon-container .icon {font-size: 28px;color: var(--white);text-align: center;}
    .card-content {flex: 1;display: flex;flex-direction: column;justify-content: center;position: relative;z-index: 2;}
    .theme-card h3 {font-size: 1.2rem;margin-bottom: 15px;font-weight: 600;line-height: 1.2;}
    .theme-card p {font-size: 1.1rem;line-height: 1.4;margin-bottom: 10px;opacity: 0.95;}
    .theme-hover-hint {margin-top: 15px;font-size: 0.85rem;opacity: 0.8;font-style: italic;display:none}
@media (max-width: 768px) {  .themes-grid {grid-template-columns: repeat(1, 1fr);gap: 10px;}}


.program-section { padding: 60px 0; background: var(--white); }
.program-title { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 2rem;  color: var(--text-dark); margin-bottom: 48px; text-align: center; }
.program-days { display: flex; flex-direction: column; gap: 40px; }
.program-day { border-left: 3px solid var(--primary-red); padding-left: 30px; }
.program-day-title { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.3rem;  color: var(--primary-red); margin-bottom: 20px; }
.program-items { display: flex; flex-direction: column; gap: 16px; }
.program-item { display: flex; gap: 20px; padding: 16px 20px; background: var(--gray-bg); border-radius: 12px; transition: transform 0.2s; }
.program-item:hover { transform: translateX(8px); background: var(--white); box-shadow: var(--shadow); }
.program-time { min-width: 110px; font-weight: 600; color: var(--secondary-blue); }
.program-name { font-weight: 600; margin-bottom: 4px; }
.program-speaker { color: var(--text-light); font-size: 0.85rem; }
@media (max-width: 768px) { .program-item { flex-direction: column; gap: 8px; } .program-day { padding-left: 16px; } }

/*=== PARTNERS ===*/
.partners-section { padding:0;}
.exhibitors-logos h2 { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.8rem; color: var(--text-dark); margin-bottom: 20px; margin-top: 60px; text-align: center; color: var(--white);}
.exhibitors-logos h2::after {content: none;}
.partners-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 24px; align-items: center; }
.partner-logo { background: var(--gray-bg); border-radius: 12px; padding: 20px; text-align: center; font-weight: 600; color: var(--text-light); transition: transform 0.2s; }
.partner-logo:hover { transform: translateY(-4px); background: var(--white); box-shadow: var(--shadow); }
@media (max-width: 1024px) { .partners-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px) { .partners-grid { grid-template-columns: repeat(2, 1fr); } }

.event-news-section { padding: 60px 0; background: var(--gray-bg); }
.event-news-title { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 2rem;  color: var(--text-dark); margin-bottom: 48px; text-align: center; }
.event-news-list { display: flex; flex-direction: column; gap: 24px; max-width: 900px; margin: 0 auto; }
.event-news-item { display: flex; gap: 30px; padding: 24px; background: var(--white); border-radius: 16px; box-shadow: var(--shadow); transition: transform 0.2s; }
.event-news-item:hover { transform: translateX(8px); box-shadow: var(--shadow-hover); }
.event-news-date { min-width: 110px; font-weight: 600; color: var(--primary-red); }
.event-news-content { flex: 1; }
.event-news-title-link { font-weight: 700; font-size: 1.1rem; margin-bottom: 8px; color: var(--text-dark); text-decoration: none; }
.event-news-title-link:hover { color: var(--primary-red); }
.event-news-announce { color: var(--text-light); margin-bottom: 8px; line-height: 1.4; }
.event-news-source { font-size: 0.75rem; color: var(--secondary-blue); }
@media (max-width: 768px) { .event-news-item { flex-direction: column; gap: 12px; } .event-news-date { min-width: auto; } }

@media (max-width: 1024px) { .stats-grid { grid-template-columns: repeat(2, 1fr); } .speakers-grid { grid-template-columns: repeat(2, 1fr); } .partners-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px)  { 
    .stats-grid { grid-template-columns: 1fr; } 
    .speakers-grid { grid-template-columns: 1fr; } 
    .partners-grid { grid-template-columns: repeat(2, 1fr); } 
    .program-item { flex-direction: column; gap: 8px; } 
    .news-item { flex-direction: column; gap: 8px; } 
    .event-details { flex-direction: column; gap: 8px; align-items: center; } 
    .event-title { font-size: 2.2rem; } 
}

/* ===== SPEAKERS ===== */
.speakers-page { padding: 60px 0; background: var(--gray-bg); }
    .speakers-page .speakers-title { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 2rem; color: var(--text-dark); margin-bottom: 48px; text-align: center; font-weight: 100; }
    .speakers-page .speakers-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 190px; row-gap: 50px; }
    .speakers-page .speaker-card { display: flex; justify-content: flex-end; position: relative; background: var(--white); min-height: 270px; text-decoration: none;}
        .speaker-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-hover); }
    .speakers-page .speaker-photo { position: absolute; left: -82px; top: 25px; width: 165px; height: 220px; z-index: 1; }
        .speakers-page .speaker-photo img { width: 100%; height: 100%; object-fit: cover; border-radius: 12px; border: 1px solid var(--red-bg); box-shadow: var(--shadow-red);}
    .speakers-page .speaker-info { width: 100%; text-align: left; display: flex; flex-direction: column; justify-content: space-between; padding: 60px 20px 10px 100px !important;}
    .speakers-page .speaker-name { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 1.5rem; font-weight: 100; margin-bottom: 8px; color: var(--red-dark); }
    .speakers-page .speaker-position { font-size: 1.0rem; color: var(--text-light); line-height: 1.4; margin-bottom: 16px; }
    .speakers-page .speaker-stats {margin: auto -20px 27px -100px;   padding: 10px 0 10px 70px;border-top: 1px solid var(--primary-red); background: var(--red-bg);}
    .speakers-page .speaker-events-count { font-size: 0.95rem; color: var(--primary-red); display: inline-block;     padding: 4px 20px 0 40px;}
@media (max-width: 1024px) { .speakers-page .speakers-grid { grid-template-columns: repeat(2, 1fr); } .speakers-page .speaker-photo { left: -41px; } }
@media (max-width: 768px) {
   .speakers-page .speakers-grid {display: grid !important;  gap: 30px !important;  justify-items: center !important; padding: 0 !important;}    
   .speakers-page .speaker-card { max-width: 350px !important; width: 100% !important;text-align: center !important;padding: 25px 0 10px 0 !important;margin: 0 auto !important;border-radius: var(--border-radius);}    
   .speakers-page .speaker-photo {width: 120px !important;height: 120px !important;margin: 0 auto 20px !important;    position: absolute;        left: 50%;
        transform: translateX(-50%);}    
   .speakers-page .speaker-name {text-align: center !important;margin-bottom: 10px !important;font-size: 1.0rem;line-height: 1;}    
   .speakers-page .speaker-position {text-align: center !important;margin-bottom: 12px !important;font-size: .85rem;line-height: 1;}    
   .speakers-page .speaker-info { padding:140px 20px 20px !important;}
   .speakers-page .speaker-stats {text-align: center !important; margin: 0 -20px; padding: 10px 0;font-size: .95rem;} 
   .speakers-page .speaker-events-count {padding: 4px 20px 0 5px;font-size: .9rem; line-height: 1;}
   .speakers-page .speaker-events-count.sep {display: none;}
}


/*======= Новости =======*/
.news-title { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 2rem; font-weight: 100; color: var(--text-dark); text-align: center; }

.news-list { display: flex; flex-direction: column; gap: 24px; max-width: 900px; margin: 0 auto; }
.news-card { background: var(--white); border-radius: var(--border-radius); padding: 24px; box-shadow: var(--shadow); transition: transform 0.3s; }
.news-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); }
.news-date { font-size: 0.75rem; font-weight: 600; color: var(--primary-red); margin-bottom: 12px; text-transform: uppercase; letter-spacing: 1px; }
.news-card-title { font-size: 1.5rem; margin-bottom: 12px; font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 100; }
.news-card-title a { text-decoration: none; color: var(--text-dark); }
.news-card-title a:hover { color: var(--primary-red); }
.news-announce { color: var(--text-light); margin-bottom: 16px; line-height: 1.5; }
.news-hashtags { display: flex; flex-wrap: wrap; gap: 12px; }

.pagination { display: flex; justify-content: center; gap: 20px; margin-top: 48px; }
.pagination-prev, .pagination-next { padding: 10px 24px; border: 1px solid var(--gray-border); border-radius: 40px; text-decoration: none; color: var(--text-dark); font-size: 0.85rem; transition: all 0.3s; }
.pagination-prev:hover, .pagination-next:hover { background: var(--primary-red); color: var(--white); border-color: var(--primary-red); }

@media (max-width: 768px) {
    .news-card { padding: 16px; }
    .pagination-prev, .pagination-next { padding: 6px 16px; }
}

@media (max-width: 768px) {
    .news-filters { flex-direction: column; align-items: stretch; }
    .filter-select { width: 100%; }
    .news-card { padding: 16px; }
}

/* ===== NEWS DETAIL ===== */
.news-detail { padding: 10px 0 0 0; }
.breadcrumbs { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; font-size: 0.9rem;margin-top: auto; padding: 5px; margin: 60px 0 0 20px; background: var(--gray-bg);border-top: 1px dashed var(--text-light);border-bottom: 1px dashed var(--text-light);}
.breadcrumbs a { color: var(--text-light); text-decoration: none; transition: color 0.2s; }
.breadcrumbs a:hover { color: var(--primary-red); }
.breadcrumbs__sep { color: var(--primary-red); opacity: 0.6; }
.breadcrumbs__current { color: var(--text-dark); font-weight: 500; }
.page-header .container { display: flex; flex-direction: column; min-height: 100%; }


.news-detail__title { font-size: 1.8rem; color: var(--secondary-blue); margin-bottom: 20px; line-height: 1.3; }
.news-detail__meta { display: flex; align-items: center; flex-wrap: wrap; gap: 24px; margin-bottom: 30px; }
.news-detail__date { font-size: 1rem; color: var(--text-light); display: flex; align-items: center; gap: 8px; }
.news-detail__date i { color: var(--primary-red); opacity: 0.8; }
.news-detail__hashtags { display: flex; flex-wrap: wrap; gap: 10px; }
.news-detail__hashtags .hashtag { background: rgba(230, 30, 50, 0.08); color: var(--primary-red); font-size: 0.85rem; font-weight: 600; text-decoration: none; padding: 5px 14px; border-radius: 30px; transition: all 0.2s; text-transform: uppercase; letter-spacing: 0.3px; }
.news-detail__hashtags .hashtag:hover { background: var(--primary-red); color: var(--white); }
.news-detail__content { font-size: 1.05rem; line-height: 1.7; color: var(--text-dark); }
.news-detail__announce { font-size: 1.15rem; color: var(--secondary-blue); margin-bottom: 24px; border-left: 3px solid var(--primary-red);padding-left: 20px;}
.news-detail__figure { margin: 30px 0; border-radius: 16px; overflow: hidden; box-shadow: var(--shadow); }
.news-detail__figure img { width: 100%; height: auto; display: block; }
.news-detail__content p { margin-bottom: 20px; }
.news-detail__content a { color: var(--primary-red); text-decoration: none; word-break: break-all; }
.news-detail__content a:hover { text-decoration: underline; color: var(--white);text-decoration: none;}

.related-events { margin-top: 50px; }
    .related-events .container {padding: 0 !important;}
.related-events__list {    display: flex;   justify-content: center;   gap: 25px;   flex-wrap: wrap;   padding: 10px 20px 40px 20px;}
.related-event {  background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.15);  display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 20px; border-radius: 16px; box-shadow: var(--shadow); text-decoration: none; transition: box-shadow 0.2s; border: 1px solid rgba(0,0,0,0.04); max-width: 200px; }
.related-event:hover { box-shadow: var(--shadow-hover); }
.related-event__logo { width: 140px; height: 90px; display: flex; align-items: center; justify-content: center;  border-radius: 12px; padding: 10px; }
.related-event__logo img { width: 100%; height: 100%; object-fit: contain; }
.related-event__name { font-size: 1rem; font-weight: 500; color: var(--white); text-align: center; }
.related-events--blue { background: var(--secondary-blue);  }
.related-events--blue .related-events__title::after {content: none;}
.related-events--blue .related-events__title i { color: var(--white); opacity: 0.8; }
.related-event--white { background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.15); }
.related-event--white .related-event__name { color: var(--white); }
.related-event--white:hover { background: rgba(255,255,255,0.15); }
.news-detail__back { margin-top: 50px; text-align: center; }

@media (max-width: 768px) {
    .news-detail__title { font-size: 1.6rem; }
    .related-events--blue { padding: 24px; }
    .related-event { max-width: 100%; }
}

/*===========  КОНТАКТЫ  ================*/
.form-group { margin-bottom: 20px; }
.form-group label { display: block; margin-bottom: 8px; font-weight: 500; }
.form-control { width: 100%; padding: 12px; border: 1px solid #ddd; border-radius: 8px; font-size: 16px; }
.form-control:focus { outline: none; border-color: #c0392b; }
.contacts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin: 40px 0; }
.contacts-form-block, .contacts-info-block { background: #fff; border-radius: 12px; padding: 30px; box-shadow: 0 2px 10px rgba(0,0,0,0.05); }
.contacts-list { list-style: none; padding: 0; margin: 0 0 30px 0; }
.contact-item { padding: 12px 0; border-bottom: 1px solid #eee; }
.contact-label { font-weight: 600; min-width: 60px; display: inline-block; }
.contact-value { color: #c0392b; text-decoration: none; }
.contact-value:hover { text-decoration: underline; }
.legal-info { margin-top: 30px; padding-top: 20px; border-top: 1px solid #eee; }
.legal-title { font-size: 18px; margin-bottom: 15px; }
.legal-list { list-style: none; padding: 0; margin: 0; font-size: 14px; color: #666; }
.legal-list li { padding: 5px 0; }
.form-status { margin-top: 15px; }
.alert { padding: 12px; border-radius: 8px; font-size: 14px; }
.alert-success { background: #d4edda; color: #155724; border: 1px solid #c3e6cb; }
.alert-error { background: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; }
@media (max-width: 768px) { .contacts-grid { grid-template-columns: 1fr; gap: 30px; } }

/* ===== FOOTER ===== */
.footer { background: var(--dark-bg, #1a1a1a); color: var(--white); padding: 40px 0 20px; }
.footer a { color: var(--white); text-decoration: none; transition: opacity 0.2s; }
.footer a:hover { opacity: 0.7; }
.footer__top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 30px; }
.footer__brand { max-width: 400px; }
.footer__logo { display: inline-block; margin-bottom: 10px; }
.footer__logo img {display: block; }
.footer__slogan { font-size: 0.9rem; opacity: 0.7; line-height: 1.4; }
.footer__contacts { text-align: right; }
.footer__address { font-size: 0.9rem; opacity: 0.7; margin-bottom: 8px; }
.footer__phones { font-size: 1.1rem; font-weight: 500; }
.footer__phones a { white-space: nowrap; }
.footer__menu { border-top: 1px solid rgba(255,255,255,0.2); border-bottom: 1px solid rgba(255,255,255,0.2); padding: 20px 0; margin-bottom: 20px; }
.footer-nav { display: flex; justify-content: center; flex-wrap: wrap; gap: 32px; list-style: none; margin: 0; padding: 0; }
.footer-nav__item { position: relative; }
.footer-nav__item:not(:last-child)::after { content: ">"; position: absolute; right: -20px; color: var(--primary-red); font-size: 1.2rem; line-height: 1; top: 50%; transform: translateY(-50%); }
.footer-nav__item a { font-size: 0.95rem; text-transform: uppercase; letter-spacing: 1px; }
.footer__bottom { display: flex; justify-content: center; flex-wrap: wrap; align-items: center; gap: 8px; font-size: 0.8rem; opacity: 0.6; }
.footer__separator { opacity: 0.5; }
@media (max-width: 768px) {
    .footer__top { flex-direction: column; gap: 20px; text-align: center;}
    .footer__menu, .footer__separator {display:none;}
    .footer__contacts {text-align: center; width: 100%;}
    .footer-nav { gap: 16px; }
    .footer-nav__item:not(:last-child)::after { display: none; }
    .footer__bottom { flex-direction: column; gap: 4px; }
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
    .news-slide-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    .container { padding: 0 20px; }
    .hero h1 { font-size: 2rem; }
    .hero { padding: 60px 0; }
    .nav { display: none; }
    .mobile-menu-btn { display: block; }
    .news-slide-grid { grid-template-columns: 1fr; }
    .news-slider { padding: 0 30px; }
    .timeline-item { flex-direction: column; gap: 8px; }
    .timeline-date { min-width: auto; }
    .footer-grid { grid-template-columns: 1fr; text-align: center; }
    .section-header { flex-direction: column; align-items: flex-start; gap: 16px; }
    .hero-description { margin: -50px 20px 0 20px; padding: 10px 15px;  max-width: 535px;}
        .hero-description p {font-size: .95rem;line-height: 1.3;}
    .calendar-day { min-height: 70px; }
    /*.event-title { font-size: 0.6rem; }*/
    .event-tooltip { display: none; }
}