
:root{
  --red:#b22234;
  --red-dark:#8b1a27;
  --blue:#3c3b6e;
  --ink:#1b1b1b;
  --bg:#f5f6f8;
  --card:#ffffff;
  --muted:#5b5b5b;
  --radius:14px;
  --shadow:0 6px 18px rgba(0,0,0,.14);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}

.container{
  max-width:1440px;
  margin:48px auto;
  padding:0 32px;
}

header.site-header{
  background:linear-gradient(135deg,var(--red) 60%,var(--blue));
  color:#fff;
  padding:56px 0 28px;
  position:relative;
  overflow:hidden;
}

.brand{
  max-width:1440px;
  margin:0 auto;
  padding:0 32px;
  display:flex;
  align-items:center;
  gap:16px;
}

.brand img{width:64px;height:64px}
.brand h1{
  font-size: clamp(28px,4vw,40px);
  margin:0;
  line-height:1.1;
}
.brand p{margin:4px 0 0;opacity:.9}

nav.site-nav{
  background:var(--blue);
  position:sticky;top:0;z-index:30;
  box-shadow:0 4px 12px rgba(0,0,0,.15);
}
.nav-inner{
  max-width:1440px;margin:0 auto;padding:0 16px;
  display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap;
}
nav a{
  color:#fff;text-decoration:none;font-weight:700;
  padding:14px 18px;border-radius:8px;display:inline-block;
}
nav a:hover{background:rgba(255,255,255,.12)}

.hero{
  max-width:1440px;margin:28px auto 0;padding:0 32px 32px;color:#fff;
}
.hero h2{
  font-size: clamp(24px,3vw,34px);
  margin:12px 0 6px;
}
.hero .tagline{opacity:.95;font-size:18px}

.card{
  background:var(--card);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:48px;
}

.grid-2{
  display:grid;gap:36px;
  grid-template-columns:1fr 1fr;
}
.grid-3{
  display:grid;gap:24px;
  grid-template-columns:repeat(3,1fr);
}
@media (max-width: 1024px){.grid-2,.grid-3{grid-template-columns:1fr}}
.card h2{
  margin:0 0 20px;
  font-size: clamp(22px,2.6vw,30px);
  color:var(--red);
  border-left:8px solid var(--blue);
  padding-left:14px;
}

.lead{font-size:20px;color:#2b2b2b}
.muted{color:var(--muted)}

.btn{
  display:inline-block;background:var(--red);
  color:#fff;padding:14px 28px;border-radius:10px;
  font-weight:800;text-decoration:none;letter-spacing:.3px;
}
.btn:hover{background:var(--red-dark);text-decoration:none}

footer.site-footer{
  background:var(--blue);color:#fff;margin-top:48px;
  padding:28px 0;
}
.footer-inner{max-width:1440px;margin:0 auto;padding:0 32px;text-align:center}
footer small{opacity:.8;display:block;margin-top:6px}

/* таблица событий */
.table{
  width:100%;border-collapse:collapse;border-radius:12px;overflow:hidden;
}
.table th,.table td{padding:16px 18px;text-align:left}
.table thead{background:#eef0f6}
.table tr{background:#fff;border-bottom:1px solid #eceff4}
.table tr:hover{background:#fafafa}

/* галерея */
.gallery{
  display:grid;gap:18px;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
}
.gallery figure{margin:0}
.gallery img{
  width:100%;height:220px;object-fit:cover;border-radius:12px;
  box-shadow:0 4px 12px rgba(0,0,0,.18);cursor:pointer;
}

/* блоки преимуществ */
.badge{
  display:inline-block;background:#fff;border:2px solid var(--blue);
  color:var(--blue);font-weight:800;padding:6px 12px;border-radius:999px
}

/* формы */
input,textarea,select{
  width:100%;padding:14px 16px;border:1px solid #d9dce4;border-radius:10px;
  font:inherit;background:#fff
}
label{font-weight:700;margin-bottom:6px;display:block}
.form-row{display:grid;gap:16px;grid-template-columns:1fr 1fr}
@media(max-width:900px){.form-row{grid-template-columns:1fr}}
.form-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:10px}

/* модалка (лайтбокс) */
.modal{
  position:fixed;inset:0;background:rgba(0,0,0,.7);
  display:none;align-items:center;justify-content:center;z-index:60;
}
.modal.open{display:flex}
.modal img{max-width:92vw;max-height:85vh;border-radius:12px;box-shadow:0 10px 28px rgba(0,0,0,.5)}
.modal .close{
  position:absolute;top:24px;right:24px;background:#fff;border:none;
  padding:10px 14px;border-radius:999px;font-weight:800;cursor:pointer
}

/* --- Мобильная адаптация --- */
@media (max-width: 768px) {
  nav {
    flex-direction: column;
    text-align: center;
  }
  nav a {
    padding: 0.8rem;
    border-top: 1px solid rgba(255,255,255,0.2);
  }
  .container {
    padding: 1rem;
  }
  section {
    padding: 1.5rem;
  }
  header h1 {
    font-size: 1.8rem;
  }
}
