:root{
  --bg:#faf9f7;
  --ink:#1a1e24;
  --soft:#6b7a8a;
  --glass-bg:rgba(255,255,255,0.75);
  --glass-border:rgba(226,232,240,0.5);
}

/* ----------------------------
   Ambient Green Fields
   ---------------------------- */
.field {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
}

.field::before,
.field::after {
  content: "";
  position: absolute;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  filter: blur(140px);
  opacity: 0.4;
  animation: drift 40s linear infinite;
}

.field::before {
  background: #a7f3d0;
  top: -200px;
  left: -200px;
}

.field::after {
  background: #d1fae5;
  bottom: -200px;
  right: -200px;
  animation-delay: -20s;
}

@keyframes drift {
  0% { transform: translate(0,0); }
  50% { transform: translate(120px, 80px); }
  100% { transform: translate(0,0); }
}

/* ----------------------------
   Body & Global Styles
   ---------------------------- */
*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

body{
  font-family:'Inter',sans-serif;
  background:
    radial-gradient(900px 600px at 50% -20%, #e6fffa 0%, transparent 45%),
    radial-gradient(700px 500px at 80% 120%, #d1fae5 0%, transparent 40%),
    var(--bg);
  color:var(--ink);
  padding:40px 20px;
  overflow-x: hidden;
}

.wrap{
  max-width:900px;
  margin:auto;
}

.whisper{
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--soft);
  margin-bottom:28px;
}

h1{
  font-size:clamp(38px,6vw,70px);
  font-weight:300;
  line-height:1.1;
  margin-bottom:40px;
}

.section{
  margin-bottom:70px;
}

.section-title{
  font-size:14px;
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-bottom:24px;
  color:var(--soft);
  text-align: center; /* заголовок по центру */
}

.cards{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:20px;
}

.card{
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  border-radius:24px;
  padding:24px;
  transition:.25s ease;
}

.card:hover{
  transform:translateY(-3px);
}

.card-title{
  font-weight:500;
  margin-bottom:8px;
}

.card-desc{
  font-size:14px;
  color:var(--soft);
  margin-bottom:16px;
}

.card-info{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:13px;
}

/* Стиль для телефонов и email */
.phone,
.email {
  text-decoration: none;
  color: var(--ink);
  border-bottom: 1px dotted #cbd5e0;
}

.phone:hover,
.email:hover {
  color: var(--ink);
}

.hidden{
  display:none;
}

.show-more{
  margin-top:25px;
  background:none;
  border:none;
  cursor:pointer;
  font-size:13px;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--soft);
}

/* ----------------------------
   Соцсети — центрируем блок и заголовок
   ---------------------------- */
.section .social-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 20px auto 40px auto;  /* вертикальный отступ сверху и снизу, центр */
  justify-content: center;       /* центрируем иконки горизонтально */
  align-items: center;           
  text-align: center;
  max-width: 600px;
}

.social-item{
  padding:10px 18px;
  border-radius:100px;
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  text-decoration:none;
  color:var(--ink);
  font-size:14px;
  display:flex;
  align-items:center;
  gap:6px;
  transition: transform .25s ease, box-shadow .25s ease;
}

.social-item:hover{
  transform: translateY(-2px);
  box-shadow:0 4px 12px rgba(0,0,0,0.08);
}

.social-item img.social-icon{
  width:30px;
  height:30px;
  object-fit:contain;
}

/* Адаптивные иконки соцсетей */
@media (max-width: 768px) {
  .social-grid {
    justify-content: center;
  }

  .social-item {
    flex: 0 0 auto;
    text-align: center;
  }
}

@media (max-width: 480px) {
  .social-item{
    padding: 8px 12px;
    font-size:12px;
  }
  .social-item img.social-icon{
    width:25px;
    height:25px;
  }
}

@media (max-width: 360px) {
  .social-item{
    padding:6px 10px;
    font-size:11px;
  }
  .social-item img.social-icon{
    width:20px;
    height:20px;
  }
}

.presence{
  margin-top:90px;
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--soft);
  display:flex;
  justify-content:space-between;
  border-top:1px solid #e2e8f0;
  padding-top:24px;
}

/* ----------------------------
   Галерея фото мероприятий
   ---------------------------- */
.photo-cards .card{
  padding:0;
  overflow:hidden;
}

.photo-cards .card img{
  width:100%;
  display:block;
  height:200px;
  object-fit:cover;
  border-radius:24px;
  transition: transform .25s ease;
}

.photo-cards .card:hover img{
  transform: scale(1.05);
}
