/* s-nulya.css — Лендинг «С нуля» */
/* Цветовая схема: Rose Smoke доминирует, Paprika — акценты */

/* ============================
   ОБЩИЕ СЕКЦИИ
   ============================ */

.section { padding-block: clamp(2.5rem, 5vw, 3.5rem); }

.section__title {
  font-family: var(--font-heading); font-weight: 700;
  font-size: clamp(1.6rem, 3.5vw, 2.75rem);
  line-height: 1.15; letter-spacing: -0.02em; margin-bottom: var(--space-lg);
}

.container { padding-inline: clamp(24px, 5vw, 80px); }

/* ============================
   HERO
   ============================ */

.section--hero {
  background-color: var(--paprika); color: var(--white);
  padding-top: calc(var(--header-height) + clamp(2rem, 4vh, 3.5rem));
  padding-bottom: clamp(2rem, 4vh, 3.5rem); overflow: hidden;
}
.section--hero .container {
  display: grid; grid-template-columns: 1fr; gap: var(--space-md); width: 100%;
}
.hero__content { order: 1; } .hero__visual { order: 2; }

.hero__title {
  font-family: var(--font-heading); font-weight: 700;
  font-size: clamp(1.8rem, 4.5vw, 3.5rem); line-height: 1.1; letter-spacing: -0.03em; margin-bottom: var(--space-sm);
}
.hero__description { font-size: clamp(0.9rem, 1.8vw, 1.05rem); line-height: 1.65; opacity: 0.9; margin-bottom: var(--space-md); }

.hero__experts { display: flex; align-items: center; gap: var(--space-sm); margin-top: var(--space-xs); }
.hero__experts-avatars { display: flex; flex-shrink: 0; }
.hero__avatar {
  width: 78px; height: 78px; border-radius: 50%; object-fit: cover;
  background-color: var(--white); border: 2.5px solid var(--rose-smoke);
  box-shadow: 0 3px 12px rgba(0,0,0,0.3); display: block; flex-shrink: 0;
}
.hero__avatar--veronika { margin-left: -18px; object-position: center 15%; }
@keyframes avatarPulse {
  0%,80%,100% { transform: scale(1); } 85% { transform: scale(1.06); } 90% { transform: scale(1); }
}
.hero__avatar--victoria { animation: avatarPulse 5s ease-in-out infinite; }
.hero__avatar--veronika { animation: avatarPulse 5s ease-in-out infinite; animation-delay:.5s; }
@media (prefers-reduced-motion:reduce) { .hero__avatar--victoria,.hero__avatar--veronika { animation:none; } }
.hero__experts-info { display: flex; flex-direction: column; gap: 0.2rem; }
.hero__experts-names { font-family: var(--font-heading); font-weight: 700; font-size: 0.95rem; color: var(--white); line-height: 1.2; }
.hero__experts-desc  { font-family: var(--font-body); font-style: italic; font-size: 0.78rem; color: var(--rose-smoke); line-height: 1.3; opacity: 0.9; }

.hero__visual { display: flex; flex-direction: column; align-items: center; gap: var(--space-sm); }
.hero__leopard { position: relative; width: 100%; max-width: 320px; height: clamp(240px, 48vw, 400px); }
.hero__leopard-img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; object-position: bottom center; transition: opacity 0.6s ease;
}
.hero__leopard-img--shy       { opacity: 1; }
.hero__leopard-img--confident { opacity: 0; }
.hero__leopard.is-confident .hero__leopard-img--shy       { opacity: 0; }
.hero__leopard.is-confident .hero__leopard-img--confident { opacity: 1; }

.toggle { display: inline-flex; align-items: center; gap: var(--space-sm); }
.toggle__label { font-family: var(--font-heading); font-weight: 600; font-size: clamp(0.95rem,1.8vw,1.05rem); color: var(--white); }
.toggle__button {
  position: relative; width: 62px; height: 34px; border-radius: var(--radius-pill);
  background-color: rgba(255,255,255,0.22); border: 2px solid rgba(255,255,255,0.45);
  cursor: pointer; flex-shrink: 0; transition: background-color var(--transition-base), border-color var(--transition-base);
}
.toggle__button[aria-pressed="true"] { background-color: var(--rose-smoke); border-color: var(--rose-smoke); }
.toggle__circle {
  position: absolute; top: 3px; left: 3px; width: 24px; height: 24px;
  border-radius: 50%; background-color: var(--white);
  box-shadow: 0 2px 6px rgba(0,0,0,0.22); transition: transform var(--transition-base);
}
.toggle__button[aria-pressed="true"] .toggle__circle { transform: translateX(28px); }
.hero__toggle-hint { margin-top: 8px; font-size: 0.78rem; font-style: italic; color: var(--rose-smoke); opacity: 0.8; text-align: center; }
@keyframes togglePulse { 0%,70%,100% { box-shadow: 0 0 0 0 rgba(238,193,193,0); } 85% { box-shadow: 0 0 30px 6px rgba(238,193,193,0.65); } }
.toggle__button { animation: togglePulse 4s ease-in-out infinite; }
.toggle--activated .toggle__button { animation: none; box-shadow: none; }
.toggle__button:hover { box-shadow: 0 0 28px 4px rgba(238,193,193,0.55); }
@media (prefers-reduced-motion:reduce) { .toggle__button { animation:none; } }

@media (max-width: 767px) {
  .hero__leopard { max-width: 280px; height: clamp(200px,60vw,360px); margin-inline: auto; }
  .toggle { justify-content: center; } .hero__toggle-hint { text-align: center; }
  .hero__visual { padding-top: var(--space-sm); }
}
@media (min-width: 768px) {
  .section--hero .container { grid-template-columns: 1fr 1fr; align-items: center; gap: clamp(1.5rem,4vw,4rem); }
  .hero__content { order:1; } .hero__visual { order:2; }
  .hero__leopard { max-width: 100%; height: clamp(360px,55vh,580px); }
}

/* ============================
   MANIFESTO
   ============================ */

.section--manifesto { background-color: var(--paprika-dark); color: var(--white); text-align: center; padding-block: 80px; }
.manifesto {
  font-family: var(--font-handwritten);
  font-size: clamp(1.35rem, 2.8vw, 2.1rem); line-height: 1.55; max-width: 720px; margin-inline: auto;
}
.manifesto p { font-family: var(--font-handwritten); font-style: normal; font-size: inherit; margin-bottom: var(--space-md); }
.manifesto p:last-child { margin-bottom: 0; }
.manifesto strong, .manifesto b { font-family: var(--font-handwritten); font-weight: 700; color: var(--white); font-style: normal; letter-spacing: 0.02em; }
.manifesto__closing { font-family: var(--font-handwritten); font-style: italic; color: var(--rose-smoke); font-size: clamp(1.4rem, 2.8vw, 2rem); }

/* ============================
   PAINS — светлый фон (отличие от Усилителя)
   ============================ */

.section--pains { background-color: var(--rose-smoke-light); color: var(--paprika); }
.section--pains .section__title { color: var(--paprika); }

.pains__list { display: flex; flex-direction: column; gap: clamp(1rem,2.5vw,1.5rem); margin-bottom: var(--space-md); }
.pains__item {
  background-color: var(--paprika); color: var(--white); border-radius: var(--radius-md);
  padding: clamp(0.85rem,2vw,1.1rem) var(--space-md); display: flex; align-items: center;
  gap: var(--space-md); min-height: clamp(64px,11vw,85px); font-weight: 500;
  box-shadow: 0 4px 12px rgba(141,2,31,0.2);
}
.pains__icon { flex-shrink: 0; display: flex; align-items: center; justify-content: center; width: 56px; height: 56px; background: rgba(255,255,255,0.15); border-radius: 50%; }
.pains__icon svg { display: block; stroke: var(--white); }
.pains__item-text { font-size: clamp(0.875rem,1.8vw,1.05rem); line-height: 1.5; margin: 0; color: var(--white); }

@media (min-width: 768px) {
  .pains__item:nth-child(1) { margin-right: clamp(0px,8vw,80px); }
  .pains__item:nth-child(2) { margin-left: clamp(0px,4vw,40px); margin-right: clamp(0px,4vw,40px); }
  .pains__item:nth-child(3) { margin-left: clamp(0px,8vw,80px); }
  .pains__item:nth-child(4) { margin-left: clamp(0px,12vw,120px); }
}
@media (max-width: 767px) {
  .pains__item { margin-left:0!important; margin-right:0!important; }
  .section--manifesto { padding-block: 56px; }
}

.fade-in-pain { opacity: 1; transform: none; transition: none; }
.fade-in-pain.is-visible { opacity: 1; transform: none; }

.pains__conclusion {
  font-family: var(--font-heading); font-weight: 700;
  font-size: clamp(1.35rem,3vw,2.25rem); line-height: 1.2; letter-spacing: -0.02em;
  text-align: center; color: var(--paprika);
}
.pains__conclusion p { margin-bottom: 0.2em; }
.pains__conclusion p:last-child { margin-bottom: 0; }

/* ============================
   CAREERS — «Кем ты сможешь работать»
   ============================ */

.section--careers { background-color: var(--paprika-dark); color: var(--white); }
.section--careers .section__title { color: var(--white); }
.careers__subtitle {
  font-family: var(--font-handwritten); font-style: italic;
  font-size: clamp(1.25rem,2.2vw,1.55rem); color: var(--rose-smoke); opacity: 0.9;
  margin-top: calc(-1 * var(--space-md)); margin-bottom: var(--space-lg);
}
.careers__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-sm); }
@media (min-width: 480px) { .careers__grid { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1024px) { .careers__grid { grid-template-columns: repeat(4,1fr); } }

.career-card {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(238,193,193,0.25);
  border-radius: 16px;
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
  box-shadow: 0 2px 12px rgba(0,0,0,0.2);
}
.career-card:hover {
  transform: scale(1.03);
  background: rgba(255,255,255,0.12);
  box-shadow: 0 8px 28px rgba(0,0,0,0.35);
  border-color: rgba(238,193,193,0.5);
}
.career-card__icon { font-size: 2rem; line-height: 1; margin-bottom: 0.25rem; }
.career-card__title { font-family: var(--font-heading); font-weight: 700; font-size: clamp(1rem,2vw,1.15rem); color: var(--white); line-height: 1.25; }
.career-card__income { font-family: var(--font-heading); font-weight: 800; font-size: clamp(1.15rem,2.5vw,1.45rem); color: var(--rose-smoke); line-height: 1.1; }
.career-card__desc { font-size: clamp(0.8rem,1.5vw,0.9rem); color: rgba(255,255,255,0.75); line-height: 1.5; margin-top: auto; }

/* ============================
   CLIENTS
   ============================ */

.section--clients { background-color: var(--paprika); color: var(--white); }
.section--clients .section__title { color: var(--white); }
.clients__subtitle {
  font-family: var(--font-handwritten); font-style: italic;
  font-size: clamp(1.3rem,2.2vw,1.55rem); color: var(--rose-smoke); opacity: 0.85;
  margin-top: calc(-1 * var(--space-sm)); margin-bottom: var(--space-lg);
}
.clients__grid { display: grid; grid-template-columns: 1fr; gap: 24px; }
.client-card {
  background: var(--white); border-radius: 16px; overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.15);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
  display: flex; align-items: center; justify-content: center; min-height: 180px;
}
.client-card:hover { transform: scale(1.02); box-shadow: 0 8px 32px rgba(0,0,0,0.22); }
.client-card img { display: block; width: 100%; height: auto; max-height: 280px; object-fit: contain; }
@media (min-width: 480px) { .clients__grid { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 768px) { .clients__grid { grid-template-columns: repeat(3,1fr); gap: 20px; } }
@media (min-width: 1024px) { .clients__grid { grid-template-columns: repeat(3,1fr); gap: 24px; } }
.client-card--extra { display: none; }
@media (min-width: 768px) { .client-card--extra { display: flex; } }
.clients__grid.is-expanded .client-card--extra { display: flex; }
.clients__more-wrap { display: flex; justify-content: center; margin-top: var(--space-sm); }
.clients__show-more { display: none; background: transparent; color: var(--rose-smoke); border: 1.5px solid var(--rose-smoke); font-family: var(--font-heading); font-weight: 600; font-size: 0.9rem; padding: 0.6rem 1.8rem; border-radius: var(--radius-pill); cursor: pointer; transition: background var(--transition-fast), color var(--transition-fast); }
.clients__show-more:hover { background: var(--rose-smoke); color: var(--paprika); }
@media (max-width: 767px) { .clients__show-more { display: inline-block; } }

/* ============================
   EXPERTS
   ============================ */

.section--experts { background-color: var(--rose-smoke-light); color: var(--paprika); }
.section--experts .section__title { color: var(--paprika); }
.experts__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
@media (min-width: 768px) { .experts__grid { grid-template-columns: 1fr 1fr; max-width: 880px; margin-inline: auto; gap: var(--space-lg); } }

.expert-card { background: transparent; border: none; padding: 0; text-align: center; }
.expert-card__stage {
  position: relative; width: 100%; max-width: 300px;
  height: clamp(280px,50vw,440px); border-radius: var(--radius-lg);
  overflow: hidden; margin-inline: auto; margin-bottom: var(--space-sm);
}
@media (min-width: 768px) { .expert-card__stage { max-width: 340px; } }
.expert-card__curtain {
  position: absolute; inset: 0; border-radius: 0;
  background: repeating-linear-gradient(90deg, #6B0117 0px, #7A0120 12px, #8D021F 24px, #7A0120 36px, #6B0117 48px), #6B0117;
  box-shadow: inset 0 6px 24px rgba(0,0,0,0.28); z-index: 0;
}
.expert-card__photo-full { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; object-position: bottom center; z-index: 1; filter: drop-shadow(0 4px 16px rgba(0,0,0,0.25)); }
.expert-card__overlay { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(to top, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.45) 55%, transparent 100%); padding: var(--space-md) var(--space-sm) var(--space-sm); z-index: 2; text-align: left; }
.expert-card__name-overlay { display: block; font-family: var(--font-heading); font-weight: 700; font-size: clamp(1.1rem,2.5vw,1.5rem); letter-spacing: 0.1em; text-transform: uppercase; color: var(--white); line-height: 1; margin-bottom: 0.2rem; }
.expert-card__stat-overlay { display: flex; align-items: baseline; gap: 0.35rem; }
@keyframes numGlow { 0%,60%,100% { text-shadow: none; filter: none; } 80% { text-shadow: 0 0 12px rgba(238,193,193,0.9), 0 0 28px rgba(238,193,193,0.5); filter: brightness(1.15); } }
.expert-card__number-overlay { font-family: var(--font-heading); font-weight: 800; font-size: clamp(2rem,5vw,3.2rem); line-height: 1; color: var(--rose-smoke); animation: numGlow 3.5s ease-in-out infinite; }
.expert-card__unit-overlay { font-size: clamp(0.78rem,1.5vw,0.9rem); color: rgba(255,255,255,0.85); }
.expert-card__list { text-align: left; display: flex; flex-direction: column; gap: var(--space-xs); max-width: 300px; margin-inline: auto; padding: var(--space-xs) 0; }
.expert-card__list li { font-size: clamp(0.875rem,1.6vw,0.975rem); line-height: 1.5; padding-left: var(--space-sm); position: relative; color: var(--paprika); }
.expert-card__list li::before { content: '—'; position: absolute; left: 0; color: var(--paprika-light); }

/* ============================
   PROGRAM — 12 папок
   ============================ */

.section--program { background-color: var(--white); color: var(--paprika); }
.section--program .section__title { color: var(--paprika); }

/* Мобильная: 1 колонка */
.program-grid { display: grid; grid-template-columns: 1fr; gap: 40px; padding-top: 36px; margin-bottom: var(--space-md); }
.program-row { display: contents; }
.program-card { margin-top: 0 !important; }

/* Скрыть 4-10 на мобильной */
.program-card[data-week="4"],.program-card[data-week="5"],.program-card[data-week="6"],
.program-card[data-week="7"],.program-card[data-week="8"],.program-card[data-week="9"],
.program-card[data-week="10"] { display: none; }
#program.is-expanded .program-card { display: flex !important; }

.program-more-wrap { display: flex; justify-content: center; margin-top: var(--space-lg); margin-bottom: var(--space-sm); }
.program-show-more { display: inline-block; background: transparent; color: var(--paprika); border: 2px solid var(--paprika); font-family: var(--font-heading); font-weight: 700; font-size: 1.1rem; padding: 16px 48px; border-radius: 10px; cursor: pointer; transition: background var(--transition-fast), color var(--transition-fast); }
.program-show-more:hover { background: var(--paprika); color: var(--white); }
@media (max-width: 767px) { .program-card:hover { transform: none; } }

/* Планшет: 2 колонки, все видны */
@media (min-width: 768px) {
  .program-grid { grid-template-columns: repeat(2,1fr); gap: 40px 16px; }
  .program-card[data-week="4"],.program-card[data-week="5"],.program-card[data-week="6"],
  .program-card[data-week="7"],.program-card[data-week="8"],.program-card[data-week="9"],
  .program-card[data-week="10"] { display: flex; }
  .program-more-wrap { display: none; }
}
/* Десктоп: 4-4-2, последний ряд центрирован */
@media (min-width: 1024px) {
  .program-grid { display: flex; flex-direction: column; gap: 0; padding-top: 0; }
  .program-row { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--space-sm); padding-top: 36px; }
  .program-row + .program-row { margin-top: var(--space-md); }
  .program-row[data-row="3"] { grid-template-columns: repeat(2,1fr); max-width: 50%; margin-left: auto; margin-right: auto; }
  .program-more-wrap { display: none; }
}

/* Стилизация папок */
.program-card {
  position: relative; background: var(--paprika); border-radius: 12px;
  box-shadow: 0 4px 20px rgba(141,2,31,0.35); cursor: pointer; overflow: visible;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
  border: none; width: 100%; display: flex; flex-direction: column; text-align: left; color: var(--white);
}
.program-card__folder-tab { position: absolute; top: -36px; left: 16px; width: 80px; height: 36px; background: var(--paprika); color: var(--rose-smoke); font-family: var(--font-heading); font-weight: 800; font-size: 1.1rem; letter-spacing: 0.05em; border-radius: 8px 8px 0 0; display: flex; align-items: center; justify-content: center; pointer-events: none; }
.program-card:hover { transform: translateY(-4px); box-shadow: 0 10px 32px rgba(141,2,31,0.5); }
.program-card.is-open { transform: none; box-shadow: 0 6px 24px rgba(141,2,31,0.4); }
.program-card__body { padding: var(--space-sm); display: flex; flex-direction: column; flex: 1; gap: 0.4rem; }
@media (min-width: 1024px) { .program-card__body { min-height: 120px; } }
.program-card__week-name { font-family: var(--font-heading); font-weight: 700; font-size: clamp(0.85rem,1.5vw,1rem); color: var(--white); line-height: 1.25; display: block; }
.program-card__hook { font-family: var(--font-body); font-weight: 400; font-size: clamp(0.72rem,1.2vw,0.8rem); color: var(--rose-smoke); line-height: 1.45; margin: 0; flex: 1; font-style: italic; opacity: 0.9; }
.program-card__chevron { font-size: 0.6rem; color: var(--paprika); background: rgba(238,193,193,0.9); border-radius: 50%; width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; align-self: flex-end; margin-top: auto; flex-shrink: 0; transition: transform var(--transition-base), background var(--transition-fast); }
.program-card:hover .program-card__chevron { background: var(--rose-smoke); }
.program-card.is-open .program-card__chevron { transform: rotate(180deg); }
.program-card__details { border-top: 1px solid rgba(238,193,193,0.2); background: var(--paprika); display: flex; flex-direction: column; gap: 0; padding: 0; border-radius: 0 0 12px 12px; overflow: hidden; }
.program-card__details[hidden] { display: none; }
.program-card__section { padding: var(--space-sm) var(--space-sm) 0; }
.program-card__section:last-child { padding-bottom: var(--space-sm); }
.program-card__section--zoom { border-top: 1px solid rgba(238,193,193,0.2); padding-top: var(--space-sm) !important; margin-top: var(--space-xs); }
.program-card__section-head { display: flex; align-items: center; gap: 0.4rem; margin-bottom: 0.4rem; }
.program-card__detail-icon { flex-shrink: 0; font-size: 1rem; line-height: 1; }
.program-card__section-head strong { font-family: var(--font-heading); font-weight: 700; font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--rose-smoke); }
.program-card__bullets { display: flex; flex-direction: column; gap: 0.2rem; padding-left: 0; list-style: none; margin-bottom: 0; }
.program-card__bullets li { font-size: clamp(0.75rem,1.3vw,0.82rem); line-height: 1.5; color: rgba(255,255,255,0.85); padding-left: 0.8rem; position: relative; }
.program-card__bullets li::before { content: '·'; position: absolute; left: 0; color: var(--rose-smoke); font-weight: 700; }
.program-card__practice-text { font-size: clamp(0.75rem,1.3vw,0.82rem); line-height: 1.5; color: rgba(255,255,255,0.85); margin: 0; }
.zoom-icon-img { width: 20px; height: 20px; border-radius: 5px; object-fit: contain; flex-shrink: 0; }
.zoom-badge { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 6px; background: #2D8CFF; color: var(--white); font-family: var(--font-heading); font-weight: 800; font-size: 0.7rem; flex-shrink: 0; line-height: 1; }
/* Placeholder: занимает место zoom-секции, но невидим */
.program-card__section--zoom-placeholder {
  visibility: hidden;
  pointer-events: none;
}
@media (max-width: 1023px) {
  .program-card__section--zoom-placeholder { display: none; }
  .program-card__details { padding-bottom: var(--space-sm); }
}
@media (min-width: 1024px) {
  .program-row { align-items: stretch; }
  .program-card__body { flex: none; min-height: 160px; }
  .program-card__details { flex: 1; }
  .program-card__section:first-child { flex: 1; }
  .program-card__section:nth-child(2) { min-height: 80px; }
  .program-card__section--zoom,
  .program-card__section--zoom-placeholder { min-height: 80px; }
}

.program__footnote { text-align: center; font-family: var(--font-handwritten); font-style: italic; font-size: clamp(1.25rem,2vw,1.55rem); color: var(--paprika); line-height: 1.55; max-width: 600px; margin-inline: auto; }

/* ============================
   REMINDER
   ============================ */

.section--reminder { background-color: var(--paprika); }
.reminder-widget { background: var(--white); color: var(--paprika); border-radius: var(--radius-lg); box-shadow: 0 10px 42px rgba(0,0,0,0.22); padding: var(--space-lg); max-width: 520px; margin-inline: auto; text-align: center; }
.reminder-widget__header { margin-bottom: var(--space-md); padding-bottom: var(--space-sm); border-bottom: 1px solid var(--rose-smoke); }
.reminder-widget__title { font-family: var(--font-heading); font-weight: 700; font-size: 0.8rem; letter-spacing: 0.12em; color: var(--paprika); }
.reminder-widget__body { margin-bottom: var(--space-lg); }
.reminder-widget__body p { font-family: var(--font-handwritten); font-style: italic; font-size: clamp(1.3rem,2.5vw,1.6rem); line-height: 1.5; color: var(--paprika); margin-bottom: var(--space-xs); }
.reminder-widget__body p:last-child { margin-bottom: 0; }
.reminder-widget__actions { display: flex; justify-content: center; }
@keyframes acceptPulse { 0%,70%,100% { box-shadow: 0 0 0 rgba(141,2,31,0); } 85% { box-shadow: 0 0 28px 6px rgba(141,2,31,0.4); } }
.reminder-widget__btn--accept { background: var(--paprika); color: var(--white); border: none; padding: 0.75rem 2.5rem; border-radius: var(--radius-pill); font-family: var(--font-heading); font-weight: 600; font-size: 1rem; cursor: pointer; animation: acceptPulse 4s ease-in-out infinite; transition: transform var(--transition-fast); }
.reminder-widget__btn--accept:hover { animation: none; transform: scale(1.05); }
@keyframes stampPress { 0% { opacity:0; transform:scale(2) rotate(-20deg); } 60% { opacity:1; transform:scale(0.95) rotate(-15deg); } 100% { opacity:1; transform:scale(1) rotate(-12deg); } }
.stamp-success { display: inline-block; padding: 18px 28px; border-radius: 50%; background: var(--paprika); color: var(--white); font-family: var(--font-handwritten); font-size: clamp(1.1rem,2.5vw,1.4rem); font-weight: 700; font-style: italic; transform: rotate(-12deg); box-shadow: 0 8px 24px rgba(141,2,31,0.4); animation: stampPress 0.6s cubic-bezier(0.34,1.56,0.64,1) forwards; text-align: center; line-height: 1.3; max-width: 160px; }

/* ============================
   PRICE
   ============================ */

.section--price { background-color: var(--rose-smoke-light); color: var(--paprika); }
.price-card { position: relative; background: var(--white); border-radius: var(--radius-lg); box-shadow: 0 8px 40px rgba(141,2,31,0.1); padding: var(--space-xl) var(--space-lg); max-width: 560px; margin-inline: auto; overflow: visible; }
.price-card__stamp { position: absolute; top: -20px; right: -20px; width: clamp(110px,15vw,165px); height: auto; transform: rotate(-12deg); filter: drop-shadow(0 4px 14px rgba(141,2,31,0.45)); z-index: 2; pointer-events: none; }
.price-card__title { font-family: var(--font-heading); font-weight: 700; font-size: clamp(1.25rem,2.8vw,1.7rem); color: var(--paprika); margin-bottom: 0.35rem; padding-right: 80px; }
.price-card__tagline { font-family: var(--font-handwritten); font-style: italic; font-size: clamp(1.25rem,2.2vw,1.5rem); color: var(--paprika-light); margin-bottom: var(--space-sm); }
.price-card__all-list { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: var(--space-sm); padding-block: var(--space-sm); }
.price-list-item { display: flex; align-items: flex-start; gap: 12px; }
.price-list-item::before { content: none; }
.price-list-icon { flex-shrink: 0; display: flex; align-items: center; margin-top: 2px; }
.price-list-icon svg { display: block; }
.price-card__all-list li { font-size: clamp(0.875rem,1.6vw,0.975rem); line-height: 1.45; color: var(--paprika); }
.price-card__divider { border: none; border-top: 1.5px solid var(--rose-smoke); margin-top: var(--space-sm); margin-bottom: var(--space-md); }
.price-card__amount { font-family: var(--font-heading); font-weight: 800; font-size: clamp(2.5rem,5.5vw,3.75rem); color: var(--paprika); line-height: 1; text-align: center; margin-bottom: 0.4rem; }
.price-card__date { text-align: center; font-size: 0.875rem; opacity: 0.6; margin-bottom: var(--space-md); }
.price-card__cta { display: flex; width: 100%; justify-content: center; font-size: 1.05rem; padding: 0.95rem 2rem; transition: transform var(--transition-fast), box-shadow var(--transition-fast); }
.price-card__cta:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(141,2,31,0.25); }

/* ============================
   CONTACT
   ============================ */

.section--contact { background-color: var(--paprika); color: var(--white); overflow: hidden; }
.contact__inner--with-calendar { display: flex; flex-direction: column; align-items: center; gap: var(--space-lg); }
.contact__content { display: flex; flex-direction: column; align-items: flex-start; text-align: left; width: 100%; }
.contact__content .section__title { color: var(--white); }
.contact__subdesc { font-size: clamp(0.95rem,1.8vw,1.1rem); color: var(--white); opacity: 0.95; font-weight: 600; margin-bottom: 0.35rem; margin-top: 0; }
.contact__description { font-size: clamp(0.9rem,1.7vw,1rem); line-height: 1.6; opacity: 0.85; margin-bottom: var(--space-md); }
.contact__buttons { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.contact__messenger-icon { display: inline-flex; align-items: center; justify-content: center; width: 66px; height: 66px; border-radius: 50%; overflow: hidden; background: rgba(255,255,255,0.15); transition: transform 0.2s ease, box-shadow 0.2s ease; flex-shrink: 0; }
.contact__messenger-icon img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
@keyframes iconGlow { 0%,70%,100% { box-shadow: 0 0 0 rgba(238,193,193,0); } 85% { box-shadow: 0 0 20px rgba(238,193,193,0.6); } }
.contact__messenger-icon--tg { animation: iconGlow 5s ease-in-out infinite; }
.contact__messenger-icon--max { animation: iconGlow 5s ease-in-out infinite; animation-delay: 0.8s; }
.contact__messenger-icon:hover { transform: scale(1.1); box-shadow: 0 0 20px rgba(238,193,193,0.7); animation: none; }
.contact-calendar { width: 200px; height: 240px; background: var(--white); border-radius: 16px; box-shadow: 0 12px 32px rgba(0,0,0,0.3); overflow: hidden; display: flex; flex-direction: column; flex-shrink: 0; transform: rotate(-3deg); transition: transform 0.4s ease; position: relative; }
.contact-calendar:hover { transform: rotate(-1deg) scale(1.02); }
.contact-calendar::before { content: ''; position: absolute; top: -9px; left: 50%; transform: translateX(-50%); width: 18px; height: 18px; background: radial-gradient(circle at 40% 35%, #a01025 0%, var(--paprika-dark) 70%); border-radius: 50%; box-shadow: 0 2px 6px rgba(0,0,0,0.4); z-index: 10; }
.contact-calendar__header { background: var(--paprika-dark); color: var(--white); font-family: var(--font-heading); font-weight: 700; font-size: 13px; letter-spacing: 0.06em; padding: 10px 8px; text-align: center; }
.contact-calendar__date { font-family: var(--font-heading); font-weight: 800; font-size: 100px; color: var(--paprika); text-align: center; line-height: 1; flex: 1; display: flex; align-items: center; justify-content: center; }
.contact-calendar__day { color: var(--paprika); font-family: var(--font-heading); font-size: 14px; font-weight: 600; letter-spacing: 0.1em; text-align: center; padding-bottom: 16px; }
@media (min-width: 768px) { .contact__inner--with-calendar { flex-direction: row; align-items: center; gap: var(--space-xl); } .contact__content { flex: 1; } }
@media (max-width: 767px) { .contact__inner--with-calendar { align-items: center; text-align: center; } .contact__content { align-items: center; text-align: center; } .contact__buttons { justify-content: center; } }

/* ============================
   FAQ
   ============================ */

.section--faq { background-color: var(--rose-smoke-light); color: var(--paprika); }
.faq-chat { max-width: 680px; margin-inline: auto; border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 6px 32px rgba(141,2,31,0.09); }
.faq-chat__header { background: var(--paprika); color: var(--white); padding: 0.75rem var(--space-md); display: flex; align-items: center; gap: var(--space-xs); }
.faq-chat__name { font-family: var(--font-heading); font-weight: 700; font-size: 1rem; flex: 1; }
.faq-chat__messages { background: var(--white); padding: var(--space-sm); display: flex; flex-direction: column; }
.faq-item { border-bottom: 1px solid var(--rose-smoke-light); }
.faq-item:last-child { border-bottom: none; }
.faq-item__question { width: 100%; text-align: left; background: none; border: none; cursor: pointer; padding: 0.85rem var(--space-sm); font-family: var(--font-body); font-weight: 600; font-size: clamp(1rem,1.7vw,1.1rem); color: var(--paprika); line-height: 1.4; display: flex; justify-content: space-between; align-items: flex-start; gap: var(--space-sm); transition: background-color var(--transition-fast); }
.faq-item__question:hover { background-color: var(--rose-smoke-light); }
.faq-item__question::after { content: '▼'; font-size: 0.6rem; opacity: 0.45; flex-shrink: 0; margin-top: 0.2rem; transition: transform var(--transition-base); }
.faq-item.is-open .faq-item__question::after { transform: rotate(180deg); }
.faq-item__answer-wrap { max-height: 0; overflow: hidden; transition: max-height 0.4s ease; }
.faq-item.is-open .faq-item__answer-wrap { max-height: 600px; }
.faq-item__answer { background: var(--paprika); color: var(--white); border-radius: 0 var(--radius-md) var(--radius-md) var(--radius-md); margin: 0 var(--space-xs) var(--space-sm) var(--space-md); padding: var(--space-sm) var(--space-md); font-size: clamp(1rem,1.6vw,1.05rem); line-height: 1.65; }

/* ============================
   FOOTER
   ============================ */

.footer .container { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-sm); padding-inline: clamp(24px,5vw,80px); }
.footer__logo { font-size: clamp(2.5rem,6.5vw,4.9rem) !important; }
.footer__leopard-img { height: clamp(72px,13vw,132px); width: auto; object-fit: contain; filter: drop-shadow(0 4px 16px rgba(0,0,0,0.3)); }
.footer__messengers { display: flex; gap: var(--space-md); align-items: center; justify-content: center; }
.footer__messenger-icon { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; border-radius: 50%; overflow: hidden; background: rgba(255,255,255,0.12); transition: transform 0.2s ease; }
.footer__messenger-icon img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.footer__messenger-icon:hover { transform: scale(1.1); }
.footer__links { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--space-sm); font-size: var(--font-size-small); opacity: 0.65; }
.footer__links a:hover { opacity: 1; text-decoration: underline; }
.footer__links-sep { opacity: 0.5; }
.footer__legal { font-size: 0.75rem; color: var(--rose-smoke); opacity: 0.65; line-height: 1.5; }
.footer__legal .nowrap { white-space: nowrap; }
.footer__instagram-disclaimer { font-size: 11px; color: var(--rose-smoke); opacity: 0.55; font-style: italic; line-height: 1.5; max-width: 560px; }
@media (max-width: 767px) {
  .footer .container { gap: var(--space-sm); padding-inline: clamp(16px,5vw,40px); }
  .footer__logo { font-size: clamp(2rem,10vw,3.2rem) !important; }
  .footer__leopard-img { height: clamp(80px,22vw,120px); }
  .footer__links { flex-direction: column; gap: 0.5rem; align-items: center; }
  .footer__links-sep { display: none; }
}

/* ============================
   МОБИЛЬНАЯ ТИПОГРАФИКА
   ============================ */

@media (max-width: 767px) {
  .section__title { font-size: 28px !important; line-height: 1.15 !important; }
  .hero__title { font-size: 30px !important; }
  .manifesto, .manifesto p { font-size: 22px !important; line-height: 1.45 !important; }
  .clients__subtitle, .careers__subtitle { font-size: 22px !important; line-height: 1.4 !important; }
  .program__footnote { font-size: 23px !important; line-height: 1.45 !important; }
  .price-card__tagline { font-size: 24px !important; line-height: 1.35 !important; }
  .reminder-widget__body p { font-size: 24px !important; line-height: 1.5 !important; }
  .hero__experts-desc { font-size: 0.78rem !important; }
  .faq-item__question { font-size: 18px !important; padding: 1rem var(--space-sm) !important; }
  .faq-item__answer { font-size: 17px !important; }
  .program-card__week-name { font-size: 18px !important; }
  .program-card__hook { font-size: 15px !important; }
  .program-card__section-head strong { font-size: 13px !important; }
  .program-card__bullets li,
  .program-card__practice-text { font-size: 14px !important; line-height: 1.5 !important; }
  .footer__legal, .footer__instagram-disclaimer { font-size: 13px !important; }
}

/* ============================
   АНИМАЦИИ
   ============================ */

.fade-in-up { opacity: 0; transform: translateY(24px); transition: opacity var(--transition-slow), transform var(--transition-slow); }
.fade-in-up.is-visible { opacity: 1; transform: translateY(0); }

/* ============================
   HERO — оба леопарда одного размера
   ============================ */

.hero__leopard-img--shy,
.hero__leopard-img--confident {
  object-fit: contain;
  object-position: bottom center;
}

/* ============================
   SIDEBAR — блок sn-* (уникальные классы, без конфликтов)
   ============================ */

/* Эксперты в ряд */
.sn-experts {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: var(--space-sm);
}

.sn-experts__avatars {
  display: flex;
  flex-shrink: 0;
  align-items: center;
}

.sn-experts__avatar {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center 15%;
  border: 2px solid var(--rose-smoke);
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
  background-color: var(--white);
  display: block;
  flex-shrink: 0;
}

.sn-experts__avatar:last-child {
  margin-left: -12px;
}

.sn-experts__label {
  font-size: 0.78rem;
  font-style: italic;
  color: var(--rose-smoke);
  opacity: 0.85;
  line-height: 1.35;
}

/* Промо-текст */
.sn-promo-title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--rose-smoke);
  line-height: 1.3;
  margin-bottom: 0.3rem;
}

.sn-promo-text {
  font-size: 0.82rem;
  color: var(--white);
  opacity: 0.7;
  line-height: 1.45;
  margin-bottom: var(--space-sm);
}

.sn-promo-btn {
  display: inline-block;
  align-self: flex-start; /* не растягивать на всю ширину */
  background: var(--white);
  color: var(--paprika);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.88rem;
  padding: 0.75rem 1.6rem;
  border-radius: var(--radius-pill);
  text-decoration: none;
  white-space: nowrap;
  box-shadow: 0 4px 14px rgba(0,0,0,0.18);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.sn-promo-btn:hover {
  transform: scale(1.04);
  box-shadow: 0 6px 20px rgba(0,0,0,0.25);
}

/* «Старт — 6 июля» — рукописный шрифт */
.sidebar__start-date {
  font-family: var(--font-handwritten) !important;
  font-size: clamp(1rem, 3vw, 1.15rem) !important;
  font-style: normal !important;
}

/* sidebar__divider как div — убрать стиль hr */
.sidebar .sidebar__divider {
  height: 1px;
  background: rgba(238,193,193,0.35);
  margin-block: var(--space-md);
  border: none;
  display: block;
}

/* Контакты */
.sn-contacts {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
}

.sn-contacts__label {
  font-size: 0.875rem;
  color: var(--rose-smoke);
  opacity: 0.9;
  line-height: 1.45;
}

.sn-contacts__icons {
  display: flex;
  gap: 1.5rem;
  align-items: center;
  justify-content: center;
}

.sn-contacts__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  overflow: hidden;
  background: rgba(255,255,255,0.1);
  flex-shrink: 0;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.sn-contacts__icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}

@keyframes sn-iconGlow {
  0%,70%,100% { box-shadow: 0 0 0 rgba(238,193,193,0); }
  85%          { box-shadow: 0 0 20px rgba(238,193,193,0.6); }
}

.sn-contacts__icon:first-child { animation: sn-iconGlow 5s ease-in-out infinite; }
.sn-contacts__icon:last-child  { animation: sn-iconGlow 5s ease-in-out infinite; animation-delay: 0.7s; }
.sn-contacts__icon:hover       { transform: scale(1.1); box-shadow: 0 0 20px rgba(238,193,193,0.7); animation: none; }

/* ============================
   PAINS — анимация последовательного выделения
   ============================ */

