/* ===== Авторская Среда — дизайн-система: бело-синий, чёрный текст ===== */
:root{
  --white:#ffffff;
  --black:#111111;
  --blue:#2e1fe0;        /* основной синий — акценты (по образцу Adobe RGB 0.145/0.133/0.786) */
  --blue-dark:#2114b3;   /* темнее — для hover */
  --blue-soft:#ecebfe;   /* светло-синяя заливка */
  --blue-line:#cdc9fb;   /* светлая линия/обводка */
  --navy:#0a0a3c;        /* тёмно-синий фон шапки/подвала */
  --navy-2:#12124f;      /* чуть светлее тёмно-синий */
  --gold:#e6c178;        /* золотой акцент (как на логотипе) — название в шапке/подвале */
  --gray:#666666;
  --gray-line:#e6e6e6;
  --radius:14px;
  --max:1180px;
  --font:'Inter','Helvetica Neue',Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--white);color:var(--black);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
a:hover{color:var(--blue-dark)}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}

/* ---- Шапка (яркая синяя) ---- */
header.site{position:sticky;top:0;z-index:50;background:var(--blue);backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,.12)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{display:flex;align-items:center;gap:12px;font-weight:800;font-size:18px;letter-spacing:.5px;color:#fff;transition:opacity .2s}
.logo:hover{opacity:.85;color:#fff}
.logo img{height:46px;width:46px;border-radius:50%;object-fit:cover;display:block;background:#fff}
.logo .logo-text{color:var(--gold)}
.logo .logo-text b{color:var(--gold)}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{color:rgba(255,255,255,.9);font-weight:500;font-size:15px;position:relative;transition:color .2s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:#fff;transition:width .25s}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.burger{display:none;font-size:26px;background:none;border:none;cursor:pointer;color:#fff}
@media(max-width:820px){
  .nav-links{display:none;position:absolute;top:74px;left:0;right:0;background:var(--blue);flex-direction:column;padding:18px 24px;border-bottom:1px solid rgba(255,255,255,.12);gap:18px}
  .nav-links.open{display:flex}
  .burger{display:block}
}

/* ---- Hero ---- */
.hero{padding:72px 0 48px;text-align:center}
.hero .kicker{color:var(--blue);font-weight:700;letter-spacing:2px;text-transform:uppercase;font-size:14px}
.hero h1{font-size:clamp(38px,6vw,72px);font-weight:800;line-height:1.02;margin:14px 0 18px}
.hero h1 .accent{color:var(--blue)}
.hero p{font-size:18px;color:var(--gray);max-width:640px;margin:0 auto}

/* ---- Кнопки-месяцы (как города на pryamaya) ---- */
.months{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;padding:8px 0 40px}
.month-btn{border:1.5px solid var(--blue-line);background:#fff;color:var(--black);padding:9px 18px;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s}
.month-btn:hover{border-color:var(--blue);color:var(--blue)}
.month-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}

/* ---- Фильтр категорий ---- */
.cats{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;padding-bottom:34px}
.cat-btn{background:none;border:none;color:var(--gray);font-weight:600;font-size:14px;padding:6px 12px;cursor:pointer;border-bottom:2px solid transparent}
.cat-btn:hover{color:var(--blue)}
.cat-btn.active{color:var(--blue);border-bottom-color:var(--blue)}

/* ---- Сетка событий ---- */
.section-title{font-size:28px;font-weight:800;margin:48px 0 24px}
.section-title .bar{display:inline-block;width:36px;height:4px;background:var(--blue);border-radius:2px;vertical-align:middle;margin-right:12px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.card{border:1px solid var(--gray-line);border-radius:var(--radius);overflow:hidden;background:#fff;transition:.18s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(26,68,214,.12);border-color:var(--blue-line)}
.card .ph{aspect-ratio:16/10;background:var(--blue-soft);overflow:hidden}
.card .ph img{width:100%;height:100%;object-fit:cover}
.card .body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:10px;flex:1}
.card .tag{align-self:flex-start;background:var(--blue-soft);color:var(--blue);font-size:12px;font-weight:700;padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px}
.card h3{font-size:19px;font-weight:700;line-height:1.25}
.card .meta{color:var(--gray);font-size:14px;display:flex;flex-direction:column;gap:3px}
.card .meta b{color:var(--black)}
.card .price{font-weight:800;color:var(--blue);font-size:18px}
.card .more{margin-top:auto;font-weight:700;color:var(--blue)}
.empty{color:var(--gray);text-align:center;padding:40px;grid-column:1/-1}

/* ---- Календарь ---- */
.cal-wrap{display:grid;grid-template-columns:1fr;gap:0;max-width:420px;margin:0 auto 10px;border:1px solid var(--gray-line);border-radius:var(--radius);padding:18px}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cal-head button{background:none;border:1px solid var(--blue-line);border-radius:8px;width:34px;height:34px;cursor:pointer;color:var(--blue);font-size:18px}
.cal-head .m{font-weight:800;font-size:17px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;text-align:center}
.cal-grid .dow{font-size:12px;color:var(--gray);font-weight:700;padding:4px 0}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:14px;color:var(--black)}
.cal-day.empty{visibility:hidden}
.cal-day.has-event{background:var(--blue);color:#fff;font-weight:800;cursor:pointer;position:relative}
.cal-day.has-event:hover{background:var(--blue-dark)}
.cal-day.today{outline:2px solid var(--blue-line)}

/* ---- Страница события ---- */
.event-hero{padding:36px 0}
.event-hero .back{color:var(--blue);font-weight:600;font-size:14px}
.event-cover{width:100%;max-height:460px;object-fit:cover;border-radius:var(--radius);margin:18px 0 26px;background:var(--blue-soft)}
.event-title{font-size:clamp(28px,4vw,44px);font-weight:800;margin-bottom:14px}
.event-facts{display:flex;flex-wrap:wrap;gap:14px 28px;margin-bottom:24px;padding:18px 22px;background:var(--blue-soft);border-radius:var(--radius)}
.event-facts div{font-size:15px}
.event-facts .label{color:var(--blue);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.5px}
.event-facts b{font-size:16px}
.event-body{white-space:pre-wrap;font-size:16.5px;line-height:1.7;max-width:760px}
.buy-bar{position:sticky;bottom:0;background:#fff;border-top:1px solid var(--gray-line);padding:16px 0;margin-top:30px}
.buy-bar .container{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.btn-buy{background:var(--blue);color:#fff;font-weight:800;font-size:17px;padding:15px 38px;border-radius:999px;border:none;cursor:pointer;transition:.15s}
.btn-buy:hover{background:var(--blue-dark);color:#fff}
.btn-buy.disabled{background:var(--gray-line);color:var(--gray);cursor:not-allowed}

/* ---- О нас ---- */
.about{padding:60px 0;border-top:1px solid var(--gray-line)}
.about h2{font-size:30px;font-weight:800;margin-bottom:18px}
.about h2 .accent{color:var(--blue)}
.about .lead{font-size:18px;max-width:760px;color:#222}
.about ul{list-style:none;margin-top:22px;display:grid;gap:14px;max-width:760px}
.about li{padding-left:30px;position:relative}
.about li::before{content:"💫";position:absolute;left:0}

/* ---- Подписка ---- */
.subscribe{background:var(--blue);color:#fff;padding:56px 0;text-align:center}
.subscribe h2{font-size:28px;font-weight:800;margin-bottom:8px}
.subscribe p{opacity:.9;margin-bottom:22px}
.sub-form{display:flex;gap:10px;max-width:460px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.sub-form input{flex:1;min-width:200px;padding:14px 18px;border-radius:999px;border:none;font-size:15px}
.sub-form button{background:#fff;color:var(--blue);font-weight:800;border:none;padding:14px 28px;border-radius:999px;cursor:pointer}
.sub-form button:hover{background:var(--blue-soft)}
.sub-msg{margin-top:14px;font-weight:600;min-height:20px}

/* ---- Подвал ---- */
footer.site{background:var(--blue);color:#fff;border-top:1px solid rgba(255,255,255,.12);padding:54px 0 30px}
.foot-grid{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot-grid .logo{margin-bottom:14px;color:var(--gold)}
.foot-grid .logo .logo-text{color:var(--gold)}
.foot-grid .logo .logo-text b{color:var(--gold)}
.foot-grid a{display:block;margin:6px 0;color:rgba(255,255,255,.85);transition:color .2s}
.foot-grid a:hover{color:#fff}
.foot-col h4{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;opacity:.75}
.copyright{color:rgba(255,255,255,.65);font-size:13px;margin-top:34px;border-top:1px solid rgba(255,255,255,.18);padding-top:18px}
.copyright a{color:#fff;text-decoration:underline}
/* Иконки соцсетей */
.socials{display:flex;gap:12px;margin-top:4px}
.socials a{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;margin:0;transition:transform .18s ease, background .18s ease}
.socials a:hover{background:#fff;color:var(--blue);transform:translateY(-3px)}

/* ---- Утилиты ---- */
.center{text-align:center}
.loading{text-align:center;color:var(--gray);padding:40px}

/* ===== Анимации ===== */
/* Появление при загрузке (hero) */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.hero .kicker{animation:fadeUp .6s ease both}
.hero h1{animation:fadeUp .7s ease .08s both}
.hero p{animation:fadeUp .7s ease .16s both}
.months{animation:fadeUp .7s ease .24s both}

/* Кнопка оплаты — лёгкое увеличение */
.btn-buy{transition:transform .15s ease, background .15s ease, box-shadow .2s ease}
.btn-buy:not(.disabled):hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(46,31,224,.28)}
.btn-buy:not(.disabled):active{transform:translateY(0)}

/* Кнопки-месяцы и категории — плавность */
.month-btn{transition:transform .15s ease, border-color .15s ease, color .15s ease, background .15s ease}
.month-btn:hover{transform:translateY(-2px)}
.cat-btn{transition:color .2s ease}

/* Появление при прокрутке — навешивается через JS (класс .reveal) */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:translateY(0)}
/* Лёгкая задержка для карточек по очереди */
.reveal.d1{transition-delay:.06s}
.reveal.d2{transition-delay:.12s}
.reveal.d3{transition-delay:.18s}
.reveal.d4{transition-delay:.24s}

/* Уважение к настройке «уменьшить движение» */
@media(prefers-reduced-motion:reduce){
  .hero .kicker,.hero h1,.hero p,.months{animation:none}
  .reveal{opacity:1;transform:none;transition:none}
}
