* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Segoe UI', sans-serif;
  line-height: 1.6;
  background: #fff;
  color: #222;
}


:root{
  --pe-bg: #0b0b10;             /* пантерно-чёрный */
  --pe-bg-2: #101018;           /* глубокая тень */
  --pe-accent: #ff2e7e;         /* неоновый розовый */
  --pe-accent-2: #7d2ae8;       /* электро-фиолетовый */
  --pe-text: #f4f4f6;
  --pe-muted: rgba(244,244,246,.72);
  --pe-border: rgba(255,255,255,.08);
}

/* Градиентная неоновая кромка сверху */
header {
  position: relative;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 6vw;
  background:
          linear-gradient(180deg, rgba(255,46,126,.06), rgba(125,42,232,.06)) ,
          linear-gradient(180deg, var(--pe-bg), var(--pe-bg-2));
  border-bottom: 1px solid var(--pe-border);
  box-shadow: 0 10px 30px rgba(0,0,0,.35), inset 0 -1px 0 rgba(255,255,255,.04);
}

a {
  color: inherit;
  text-decoration: none;
}

header::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0; height:3px;
  background: linear-gradient(90deg, var(--pe-accent), var(--pe-accent-2));
  box-shadow: 0 0 12px rgba(255,46,126,.55);
}

/* ЛОГО: строгая капитель + тонкое неоновое свечение */
header .logo{
  font-family: 'Bebas Neue', 'Cinzel', 'Cinzel Decorative', serif;
  font-size: 2.2rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--pe-text);
  text-shadow: 0 0 10px rgba(125,42,232,.25);
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  transform: translateZ(0);
  transition: filter .25s ease, opacity .25s ease;
}

/* маленький «коготь» после логотипа */
header .logo::after{
  content:"";
  width: 32px; height: 2px;
  background: linear-gradient(90deg, var(--pe-accent), var(--pe-accent-2));
  display:inline-block;
  border-radius: 2px;
  box-shadow: 0 0 8px rgba(255,46,126,.5);
}
header .logo:hover{ filter: brightness(1.08); opacity: .95; }

/* НАВИГАЦИЯ: острые подчёркивания-«царапины» */
header nav{
  display:flex; align-items:center; gap: 28px;
}
header nav a{
  position:relative;
  font-family: 'Montserrat', ui-sans-serif, system-ui, -apple-system, Arial, sans-serif;
  font-size: .98rem;
  letter-spacing: .04em;
  color: var(--pe-muted);
  text-decoration: none;
  padding: 4px 2px;
  transition: color .25s ease, opacity .25s ease;
  opacity: .95;
}
header nav a::after{
  content:"";
  position:absolute; left:0; right:0; bottom:-6px; height:2px;
  background: linear-gradient(90deg, var(--pe-accent), var(--pe-accent-2));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .28s ease;
  border-radius: 2px;
  box-shadow: 0 0 8px rgba(255,46,126,.4);
}
header nav a:hover{
  color: #fff;
}
header nav a:hover::after{
  transform: scaleX(1);
}

/* КОНТАКТЫ: стеклянные таблетки + неоновая кнопка */
header .contacts{
  display:flex; align-items:center; gap: 14px;
}

header .contacts a{
  color:#e9e9ee; text-decoration:none;
  font-size:.95rem; letter-spacing:.02em;
  padding:8px 12px; border-radius:10px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--pe-border);
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
header .contacts a:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.16);
  color:#fff;
}

/* Главная CTA — «пантерная» кнопка */
header .contacts .btn-call{
  background: linear-gradient(90deg, var(--pe-accent), var(--pe-accent-2));
  color: #0b0710;
  border: none;
  border-radius: 999px;
  padding: 10px 22px;
  font-weight: 700;
  font-size: .96rem;
  letter-spacing: .04em;
  cursor: pointer;
  box-shadow: 0 6px 22px rgba(125,42,232,.35), 0 0 0 1px rgba(255,255,255,.06) inset;
  transition: transform .18s ease, box-shadow .25s ease, filter .25s ease;
}
header .contacts .btn-call:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(125,42,232,.45), 0 0 0 1px rgba(255,255,255,.08) inset;
  filter: saturate(1.15);
}

/* МОБИЛЬНАЯ АДАПТАЦИЯ */
@media (max-width: 920px){
  header{
    flex-direction: column;
    gap: 12px;
    padding: 14px 5vw;
    text-align: center;
  }
  header nav{ flex-wrap: wrap; gap: 18px; }
  header .contacts{ justify-content: center; flex-wrap: wrap; }
  header .logo{ font-size: 1.8rem; letter-spacing:.12em; }
}

/* ДОП: компактный вид для очень узких экранов */
@media (max-width: 520px){
  header nav a{ font-size:.94rem; }
  header .contacts a{ padding:7px 10px; }
  header .contacts .btn-call{ padding:9px 18px; font-size:.92rem; }
}


.contacts {
    align-items: center;
}

.hero{
  position: relative;
  overflow: hidden;
  color: var(--pe-text);
  text-align: center;
  padding: clamp(64px, 10vw, 120px) 6vw;
  background:
          radial-gradient(80% 60% at 50% -10%, rgba(125,42,232,.18), transparent 60%),
          radial-gradient(70% 50% at 90% 20%, rgba(255,46,126,.12), transparent 60%),
          linear-gradient(180deg, var(--pe-bg), var(--pe-bg-2));
  box-shadow: inset 0 -1px 0 rgba(255,255,255,.05);
}

/* Динамическая «аура» */
.hero::before,
.hero::after{
  content:"";
  position:absolute;
  border-radius: 50%;
  filter: blur(40px);
  pointer-events:none;
  opacity:.45;
}
.hero::before{
  width: 520px; height:520px;
  left:-180px; top:-180px;
  background: radial-gradient(circle, rgba(255,46,126,.25), transparent 60%);
  animation: pe-orb-1 16s linear infinite;
}
.hero::after{
  width: 620px; height:620px;
  right:-220px; bottom:-220px;
  background: radial-gradient(circle, rgba(125,42,232,.25), transparent 60%);
  animation: pe-orb-2 18s linear infinite reverse;
}
@keyframes pe-orb-1{ from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes pe-orb-2{ from{transform:rotate(0)} to{transform:rotate(360deg)} }

/* Контейнер для контента, чтобы текст не «лип» к краям */
.hero .container{
  max-width: 1040px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

/* Заголовок: градиент в буквах + лёгкое свечение */
.hero h1{
  font-size: clamp(2rem, 5vw, 3.6rem);
  line-height: 1.08;
  margin: 0 0 14px;
  letter-spacing: .12em;
  text-transform: uppercase;
  background: linear-gradient(90deg, var(--pe-accent), var(--pe-accent-2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 0 14px rgba(125,42,232,.25);
}

/* Подзаголовок */
.hero p{
  font-size: clamp(1rem, 2.2vw, 1.22rem);
  line-height: 1.8;
  color: var(--pe-muted);
  margin: 0 auto;
  max-width: 820px;
}

/* Группа CTA */
.hero .cta-group{
  display: inline-flex;
  gap: 14px;
  margin-top: clamp(18px, 3vw, 28px);
  flex-wrap: wrap;
  justify-content: center;
}

/* Кнопки */
.hero .btn-primary,
.hero .btn-ghost{
  appearance: none;
  border: none;
  cursor: pointer;
  font-weight: 700;
  letter-spacing: .04em;
  padding: 12px 22px;
  border-radius: 999px;
  transition: transform .18s ease, box-shadow .25s ease, filter .25s ease, background .25s ease, color .25s ease;
}

/* Главная кнопка — неоновая капсула */
.hero .btn-primary{
  background: linear-gradient(90deg, var(--pe-accent), var(--pe-accent-2));
  color: #0b0710;
  box-shadow: 0 10px 28px rgba(125,42,232,.35), 0 0 0 1px rgba(255,255,255,.06) inset;
}
.hero .btn-primary:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 34px rgba(125,42,232,.45), 0 0 0 1px rgba(255,255,255,.08) inset;
  filter: saturate(1.12);
}

/* Вторичная — стеклянная таблетка с неоновой обводкой при hover */
.hero .btn-ghost{
  background: rgba(255,255,255,.06);
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 2px 10px rgba(0,0,0,.25);
}
.hero .btn-ghost:hover{
  border-color: transparent;
  background:
          linear-gradient(90deg, rgba(255,46,126,.18), rgba(125,42,232,.18));
  box-shadow:
          0 0 0 1px rgba(255,255,255,.08) inset,
          0 10px 26px rgba(0,0,0,.3);
}

/* Микроадаптация */
@media (max-width: 560px){
  .hero .cta-group{ gap: 10px; }
  .hero .btn-primary, .hero .btn-ghost{ padding: 11px 18px; font-size: .95rem; }
}

/* Галерея с сеткой */
.gallery{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 2rem;
  padding: clamp(1.5rem, 4vw, 3rem);
  background: linear-gradient(180deg, var(--pe-bg), var(--pe-bg-2));
}

/* Карточка модели */
.model-card{
  position: relative;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  overflow: hidden;
  text-align: center;
  box-shadow: 0 6px 20px rgba(0,0,0,0.35);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.model-card:hover{
  transform: translateY(-6px);
  border-color: rgba(255,46,126,0.4);
  box-shadow: 0 14px 36px rgba(125,42,232,0.4), 0 0 20px rgba(255,46,126,0.25);
}

/* Фото модели */
.model-card img{
  width: 100%;
  height: 320px;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease, filter 0.4s ease;
  border-bottom: 2px solid var(--pe-accent);
}

.model-card:hover img{
  transform: scale(1.06);
  filter: brightness(1.08);
}

/* Имя модели */
.model-card h3{
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--pe-text);
  margin: 14px 0 6px;
  letter-spacing: 0.5px;
}

/* Описание */
.model-card p{
  font-size: 0.95rem;
  color: var(--pe-muted);
  margin-bottom: 18px;
  padding: 0 14px;
  line-height: 1.5;
}

/* Лёгкая неоновая подсветка снизу */
.model-card::after{
  content: '';
  position: absolute;
  left: 50%;
  bottom: -30px;
  transform: translateX(-50%);
  width: 60%;
  height: 60px;
  background: radial-gradient(circle, rgba(255,46,126,0.35), transparent 70%);
  filter: blur(30px);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.model-card:hover::after{
  opacity: 1;
}

/* Адаптивность */
@media (max-width: 700px){
  .gallery{
    gap: 1.2rem;
    padding: 1.5rem;
  }
  .model-card img{
    height: 260px;
  }
}


footer {
  text-align: center;
  padding: 1rem;
  background: #001433;
  font-size: 0.9rem;
}



/* Секция: глубокий фон + мягкие неоновые всполохи */
.intro{
  position: relative;
  padding: clamp(40px, 6vw, 72px) 6vw;
  color: var(--pe-text);
  background:
          radial-gradient(80% 60% at 10% 0%, rgba(255,46,126,.10), transparent 60%),
          radial-gradient(70% 50% at 100% 20%, rgba(125,42,232,.10), transparent 60%),
          linear-gradient(180deg, var(--pe-bg), var(--pe-bg-2));
  overflow: hidden;
}

/* Декоративные «ауры» */
.intro::before,
.intro::after{
  content:"";
  position:absolute;
  width: 520px; height: 520px;
  border-radius: 50%;
  filter: blur(42px);
  opacity: .35;
  pointer-events: none;
}
.intro::before{
  top: -180px; left: -180px;
  background: radial-gradient(circle, rgba(255,46,126,.22), transparent 60%);
  animation: intro-orb-1 18s linear infinite;
}
.intro::after{
  bottom: -220px; right: -220px;
  background: radial-gradient(circle, rgba(125,42,232,.22), transparent 60%);
  animation: intro-orb-2 20s linear infinite reverse;
}
@keyframes intro-orb-1{ from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes intro-orb-2{ from{transform:rotate(0)} to{transform:rotate(360deg)} }

/* Карточка контента (glass) */
.intro .container{
  position: relative;
  z-index: 1;
  max-width: 960px;
  margin: 0 auto;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--pe-border);
  border-radius: 20px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 12px 36px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.05);
  padding: clamp(22px, 4.5vw, 40px) clamp(18px, 4vw, 36px);
}

/* Заголовки с градиентом внутри букв */
.intro h1,
.intro h2{
  margin: 0 0 16px;
  font-weight: 800;
  line-height: 1.12;
  text-align: center;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: clamp(1.6rem, 3.2vw, 2.4rem);
  background: linear-gradient(90deg, var(--pe-accent), var(--pe-accent-2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 0 10px rgba(125,42,232,.25);
}

/* Тонкий декоративный разделитель */
.intro .divider{
  width: 120px; height: 3px;
  margin: 12px auto 22px;
  background: linear-gradient(90deg, var(--pe-accent), var(--pe-accent-2));
  border-radius: 2px;
  box-shadow: 0 0 10px rgba(255,46,126,.35);
}

/* Параграфы: комфортная чтебельность */
.intro p{
  font-size: clamp(1rem, 1.9vw, 1.12rem);
  line-height: 1.8;
  color: var(--pe-muted);
  margin: 0 0 1rem;
  text-align: justify;
}

/* Акцентные элементы текста */
.intro em,
.intro strong{
  color: #fff;
}

/* Цитата/блок-выделение */
.intro blockquote{
  margin: 18px 0 20px;
  padding: 14px 16px;
  border-left: 3px solid var(--pe-accent);
  background: rgba(255,255,255,.05);
  color: var(--pe-text);
  border-radius: 10px;
}

/* Список преимуществ/пунктов */
.intro ul{
  margin: 12px 0 6px 0;
  padding-left: 18px;
}
.intro ul li{
  margin: 6px 0;
  color: var(--pe-muted);
}
.intro ul li::marker{
  color: var(--pe-accent);
}

/* Кнопки CTA внутри intro (если нужны) */
.intro .cta{
  display:flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-top: 10px;
}
.intro .btn{
  appearance: none;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: #fff;
  border-radius: 999px;
  padding: 10px 18px;
  font-weight: 700;
  letter-spacing: .04em;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease;
}
.intro .btn:hover{
  background: linear-gradient(90deg, rgba(255,46,126,.18), rgba(125,42,232,.18));
  border-color: transparent;
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(0,0,0,.28);
}

/* Мобильная адаптация */
@media (max-width: 768px){
  .intro{ padding: 40px 5vw; }
  .intro .container{ padding: 18px 16px; border-radius: 16px; }
  .intro h1, .intro h2{ letter-spacing: .06em; }
}


.advantages-section{
  position: relative;
  padding: clamp(56px, 8vw, 84px) 0;
  background:
          radial-gradient(70% 50% at 10% 0%, rgba(255,46,126,.08), transparent 60%),
          radial-gradient(65% 48% at 100% 20%, rgba(125,42,232,.08), transparent 60%),
          linear-gradient(180deg, var(--pe-bg), var(--pe-bg-2));
  overflow: hidden;
}

/* мягкие «ауры» */
.advantages-section::before,
.advantages-section::after{
  content:"";
  position:absolute; pointer-events:none;
  width: 520px; height:520px; border-radius:50%;
  filter: blur(44px); opacity:.28;
}
.advantages-section::before{
  top:-180px; left:-180px;
  background: radial-gradient(circle, rgba(255,46,126,.22), transparent 60%);
  animation: adv-orb-1 22s linear infinite;
}
.advantages-section::after{
  right:-220px; bottom:-220px;
  background: radial-gradient(circle, rgba(125,42,232,.22), transparent 60%);
  animation: adv-orb-2 24s linear infinite reverse;
}
@keyframes adv-orb-1{ from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes adv-orb-2{ from{transform:rotate(0)} to{transform:rotate(360deg)} }

.advantages-section .container{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(16px, 4vw, 28px);
  position: relative;
  z-index: 1;
}

/* заголовок с градиентом внутри букв */
.advantages-section h2{
  font-size: clamp(1.6rem, 3.4vw, 2.4rem);
  text-align: center;
  margin: 0 0 36px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: linear-gradient(90deg, var(--pe-accent), var(--pe-accent-2));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  text-shadow: 0 0 12px rgba(125,42,232,.25);
}

.advantages-list{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(16px, 3vw, 28px);
}

/* карточка — стекло + тонкая подсветка рамки */
.advantage-item{
  position: relative;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--pe-border);
  border-radius: 18px;
  padding: clamp(18px, 3vw, 26px) clamp(16px, 2.6vw, 22px);
  text-align: center;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  box-shadow: 0 10px 28px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.05);
  overflow: hidden;
}
.advantage-item:hover{
  transform: translateY(-6px);
  border-color: rgba(255,46,126,.35);
  box-shadow: 0 16px 38px rgba(125,42,232,.38), 0 0 18px rgba(255,46,126,.22);
}

/* сияние-блик при ховере */
.advantage-item::after{
  content:"";
  position:absolute;
  top:-60%; left:-20%;
  width: 60%; height: 220%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
  transform: rotate(18deg);
  opacity: 0;
  transition: opacity .35s ease;
}
.advantage-item:hover::after{ opacity: 1; }

/* иконка — круг с контуром-неоном */
.advantage-item .icon{
  width: 64px; height: 64px;
  margin: 4px auto 14px;
  border-radius: 50%;
  display: grid; place-items:center;
  color: #fff; font-size: 1.5rem;
  background: radial-gradient(circle at 50% 35%, rgba(255,255,255,.06), transparent 70%);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow:
          0 0 0 2px rgba(255,255,255,.04) inset,
          0 4px 16px rgba(0,0,0,.25),
          0 0 12px rgba(255,46,126,.28);
}

/* заголовок карточки */
.advantage-item h3{
  font-size: 1.18rem;
  color: var(--pe-text);
  font-weight: 700;
  letter-spacing: .02em;
  margin: 10px 0 10px;
}

/* текст карточки */
.advantage-item p{
  color: var(--pe-muted);
  font-size: 1.02rem;
  line-height: 1.7;
  margin: 0;
}

/* компактная адаптация */
@media (max-width: 820px){
  .advantages-section h2{ margin-bottom: 26px; }
  .advantage-item{ padding: 18px 14px; }
}


.contact-icons {
  background: #f7f7f7;
  padding: 3rem 0rem;
  text-align: center;
}

.contact-icons h2 {
  font-size: 2rem;
  margin-bottom: 1rem;
}

.contact-icons p {
  font-size: 1rem;
  margin-bottom: 2rem;
}

.messenger-links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1.5rem;
}

.messenger {
  display: flex;
  align-items: center;
  background: #fff;
  padding: 0.75rem 1.5rem;
  border-radius: 10px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
  text-decoration: none;
  font-weight: 500;
  font-size: 1rem;
  color: #222;
  transition: transform 0.2s;
}

.messenger:hover {
  transform: translateY(-3px);
}

.messenger img {
  width: 24px;
  height: 24px;
  margin-right: 0.5rem;
}

.services-page {
  padding: 4rem 1rem;
  background: #fff;
}

.services-page .container {
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
}

.services-page h1 {
  font-size: 2.5rem;
  margin-bottom: 0.5rem;
}

.services-page .subtitle {
  font-size: 1.2rem;
  color: #555;
  margin-bottom: 3rem;
}

.service-grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.service-card {
  background: #f9f9f9;
  border-radius: 16px;
  padding: 2rem 1.5rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  text-align: center;
}

.service-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
}

.service-card .icon {
  font-size: 2.5rem;
  margin-bottom: 1rem;
}

.service-card h3 {
  font-size: 1.3rem;
  margin-bottom: 0.5rem;
  color: #222;
}

.service-card p {
  font-size: 1rem;
  color: #555;
  line-height: 1.6;
}





.contact-page {
  background: #f7f6fa;
  padding: 48px 0 64px 0;
  font-family: 'Segoe UI', Arial, sans-serif;
}

.contact-page .container {
  max-width: 900px;
  margin: 0 auto;
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 8px 32px rgba(34, 19, 46, 0.10);
  padding: 48px 32px 32px 32px;
}

.contact-page h1 {
  font-size: 2.5rem;
  margin-bottom: 18px;
  color: #321d44;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-align: left;
}

.contact-page .subtitle {
  font-size: 1.25rem;
  color: #5c4072;
  margin-bottom: 36px;
  text-align: left;
  line-height: 1.6;
}

.contact-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 32px;
  margin-top: 16px;
  margin-bottom: 36px;
}

.contact-card {
  background: linear-gradient(135deg, #eee6fa 0%, #f9f6ff 100%);
  border-radius: 16px;
  box-shadow: 0 3px 14px rgba(60,30,90,0.07);
  padding: 30px 20px 24px 20px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  transition: box-shadow 0.25s;
  border: 1.5px solid #ece2fa;
  min-height: 170px;
}

.contact-card:hover {
  box-shadow: 0 8px 28px rgba(51,20,90,0.12);
  border-color: #a27cff;
}

.contact-card .icon {
  font-size: 2.2rem;
  margin-bottom: 10px;
  color: #6b44c5;
  background: #ede4ff;
  border-radius: 50%;
  padding: 8px 13px;
  box-shadow: 0 2px 12px rgba(160, 120, 255, 0.08);
}

.contact-card h3 {
  font-size: 1.18rem;
  color: #321d44;
  margin-bottom: 7px;
  margin-top: 0;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.contact-card p {
  font-size: 1.06rem;
  color: #46315c;
  margin: 0;
  line-height: 1.5;
  word-break: break-word;
}

.contact-card a {
  color: #8e63f6;
  text-decoration: none;
  font-weight: 500;
  transition: color 0.2s;
  word-break: break-all;
}
.contact-card a:hover {
  color: #321d44;
  text-decoration: underline;
}

.contact-page .legal {
  font-size: 1rem;
  color: #9986c3;
  background: #f8f4ff;
  border-radius: 10px;
  padding: 12px 16px;
  text-align: left;
  margin-top: 18px;
  letter-spacing: 0.01em;
  line-height: 1.6;
  box-shadow: 0 2px 6px rgba(120,100,180,0.07);
}

@media (max-width: 600px) {
  .contact-page .container {
    padding: 18px 4vw;
  }
  .contact-page h1 {
    font-size: 1.5rem;
    text-align: left;
  }
  .contact-page .subtitle {
    font-size: 1.07rem;
    text-align: left;
  }
}




.about-page{
  position: relative;
  padding: clamp(56px, 8vw, 96px) 0;
  background:
          radial-gradient(70% 50% at 12% 0%, rgba(255,46,126,.08), transparent 60%),
          radial-gradient(65% 48% at 100% 20%, rgba(125,42,232,.08), transparent 60%),
          linear-gradient(135deg, var(--pe-bg) 0%, var(--pe-bg-2) 100%);
  overflow: hidden;
}

/* Декоративные «сферы» */
.about-page::before,
.about-page::after{
  content:"";
  position:absolute; border-radius:50%;
  filter: blur(44px); opacity:.28; pointer-events:none;
}
.about-page::before{
  width: 520px; height:520px; top:-180px; left:-180px;
  background: radial-gradient(circle, rgba(255,46,126,.22), transparent 60%);
  animation: about-orb-1 20s linear infinite;
}
.about-page::after{
  width: 640px; height:640px; right:-240px; bottom:-240px;
  background: radial-gradient(circle, rgba(125,42,232,.22), transparent 60%);
  animation: about-orb-2 24s linear infinite reverse;
}
@keyframes about-orb-1{ from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes about-orb-2{ from{transform:rotate(0)} to{transform:rotate(360deg)} }

/* Карточка-контейнер (glass) */
.about-page .container{
  max-width: 960px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--pe-border);
  border-radius: 24px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 14px 40px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.05);
  padding: clamp(24px, 5vw, 48px) clamp(20px, 4.5vw, 36px);
}

/* Заголовок: градиент в буквах */
.about-page h1{
  font-family: 'Playfair Display', 'Cinzel', serif;
  font-size: clamp(1.8rem, 4.6vw, 2.8rem);
  font-weight: 800;
  text-align: center;
  letter-spacing: .08em;
  margin: 0 0 22px;
  text-transform: uppercase;
  background: linear-gradient(90deg, var(--pe-accent), var(--pe-accent-2));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  text-shadow: 0 0 14px rgba(125,42,232,.25);
}

/* Интро-блок (мягкий акцент) */
.about-page .intro{
  font-size: clamp(1.02rem, 2.2vw, 1.22rem);
  font-weight: 600;
  color: var(--pe-text);
  line-height: 1.75;
  text-align: center;
  margin: 0 0 18px;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--pe-border);
  border-radius: 16px;
  padding: clamp(14px, 3vw, 22px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}

/* Обычные абзацы */
.about-page p{
  font-size: clamp(1rem, 1.9vw, 1.14rem);
  color: var(--pe-muted);
  margin: 0 0 18px;
  line-height: 1.8;
  letter-spacing: 0.01em;
}

/* Юридический/внимание-блок */
.about-page p.legal{
  color: var(--pe-text);
  font-size: 1rem;
  font-style: italic;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--pe-border);
  padding: 14px 16px;
  border-radius: 14px;
  margin-top: 24px;
  margin-bottom: 0;
  display: flex; align-items: center; gap: 10px;
}

/* Маркеры списков в фирменном цвете */
.about-page ul{ margin: 12px 0 6px 0; padding-left: 18px; }
.about-page ul li{ margin: 6px 0; color: var(--pe-muted); }
.about-page ul li::marker{ color: var(--pe-accent); }

/* Ссылки внутри about */
.about-page a{ color: var(--pe-accent); text-decoration: none; }
.about-page a:hover{ color: #fff; text-shadow: 0 0 8px rgba(255,46,126,.6); }

/* Адаптация */
@media (max-width: 700px){
  .about-page .container{ border-radius: 18px; padding: 18px 16px; }
  .about-page .intro{ padding: 12px 12px; }
}



.pricing-page {
  padding: 4rem 1rem;
  background-color: #fff;
  text-align: center;
}

.pricing-page .container {
  max-width: 1000px;
  margin: 0 auto;
}

.pricing-page h1 {
  font-size: 2.5rem;
  margin-bottom: 1rem;
}

.pricing-page .subtitle {
  font-size: 1.1rem;
  color: #555;
  margin-bottom: 3rem;
}

.price-grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.price-card {
  background: #f9f9f9;
  border-radius: 16px;
  padding: 2rem 1.5rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  text-align: left;
}

.price-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
}

.price-card h3 {
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
  color: #222;
}

.price-card .price {
  font-size: 1.3rem;
  font-weight: bold;
  color: #d43f3a;
  margin-bottom: 0.5rem;
}

.price-card .desc {
  font-size: 1rem;
  color: #555;
  line-height: 1.6;
}

.site-footer {
  background:
          radial-gradient(60% 50% at 15% 10%, rgba(255,46,126,0.06), transparent 70%),
          radial-gradient(60% 50% at 85% 20%, rgba(125,42,232,0.06), transparent 70%),
          linear-gradient(160deg, var(--pe-bg) 0%, var(--pe-bg-2) 100%);
  color: var(--pe-muted);
  font-size: 0.96rem;
  padding: clamp(2.5rem, 5vw, 3.5rem) 1rem clamp(2rem, 4vw, 2.5rem) 1rem;
  line-height: 1.75;
  position: relative;
  overflow: hidden;
}

.site-footer::before {
  content: "";
  position: absolute;
  top: -35%;
  left: -35%;
  width: 170%;
  height: 170%;
  background: radial-gradient(circle, rgba(255,46,126,0.07) 0%, transparent 80%);
  z-index: 0;
  animation: footer-glow 24s linear infinite;
}

@keyframes footer-glow {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.site-footer .container {
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.site-footer p {
  margin: 0 0 1.2rem 0;
}

.site-footer a {
  color: var(--pe-accent);
  text-decoration: none;
  font-weight: 500;
  transition: color 0.25s ease, text-shadow 0.25s ease;
}

.site-footer a:hover {
  color: #fff;
  text-shadow: 0 0 8px rgba(255,46,126,0.6);
}

.site-footer strong {
  color: var(--pe-text);
}

.site-footer .confidential {
  margin-top: 2rem;
  font-size: 0.88rem;
  color: rgba(244,244,246,0.6);
  border-top: 1px solid rgba(255,46,126,0.15);
  padding-top: 1rem;
}

@media (max-width: 768px) {
  .site-footer {
    font-size: 0.9rem;
    padding: 2.5rem 1rem;
  }
  .site-footer .confidential {
    font-size: 0.82rem;
  }
}


.faq-section {
  padding: clamp(48px, 6vw, 80px) 0;
  background:
          radial-gradient(60% 50% at 10% 10%, rgba(255,46,126,0.08), transparent 60%),
          radial-gradient(60% 50% at 90% 10%, rgba(125,42,232,0.08), transparent 60%),
          linear-gradient(180deg, var(--pe-bg), var(--pe-bg-2));
  color: var(--pe-text);
  position: relative;
  overflow: hidden;
}

.faq-section h2 {
  text-align: center;
  font-size: clamp(1.6rem, 3.4vw, 2.4rem);
  font-weight: 800;
  margin-bottom: 44px;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: linear-gradient(90deg, var(--pe-accent), var(--pe-accent-2));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  text-shadow: 0 0 14px rgba(125,42,232,.25);
}

.faq-list {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 clamp(14px, 3vw, 24px);
}

.faq-item {
  background: rgba(255,255,255,0.04);
  border-radius: 14px;
  border: 1px solid var(--pe-border);
  padding: clamp(18px, 3vw, 28px) clamp(18px, 3vw, 26px);
  margin-bottom: 22px;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(0,0,0,0.25);
}

.faq-item::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 6px;
  height: 100%;
  background: linear-gradient(180deg, var(--pe-accent) 0%, var(--pe-accent-2) 100%);
}

.faq-item::after {
  content: "";
  position: absolute;
  top: -50%;
  left: -30%;
  width: 60%;
  height: 200%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.14), transparent);
  transform: rotate(20deg);
  opacity: 0;
  transition: opacity .35s ease;
}

.faq-item:hover {
  background: rgba(255,255,255,0.06);
  transform: translateY(-3px);
  border-color: rgba(255,46,126,.35);
  box-shadow: 0 14px 34px rgba(125,42,232,0.35), 0 0 18px rgba(255,46,126,.18);
}

.faq-item:hover::after {
  opacity: 1;
}

.faq-item h3 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--pe-text);
  margin-bottom: 12px;
  padding-left: 12px;
}

.faq-item p {
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--pe-muted);
  margin: 0;
}

.faq-item:last-child {
  margin-bottom: 0;
}

@media (max-width: 700px) {
  .faq-section {
    padding: 40px 0;
  }
  .faq-section h2 {
    font-size: 1.5rem;
    margin-bottom: 28px;
  }
  .faq-item {
    padding: 16px 14px;
  }
}

