/*
  СО‑Творение — современная, лёгкая верстка
  ВАЖНО: тексты не менялись, обновлены только дизайн/отступы/адаптив.
*/

:root{
  /* Layout */
  --container: 1160px;
  --nav-h: 72px;
  --radius-lg: 26px;
  --radius-md: 18px;
  --radius-sm: 14px;

  /* Colors */
  --page-bg: #f7f4ff;
  --page-bg-alt: #fdfaff;
  --surface: rgba(255, 255, 255, 0.94);
  --surface-2: rgba(255, 255, 255, 0.86);
  --border: rgba(141, 120, 255, 0.22);
  --shadow: 0 22px 70px rgba(141, 120, 255, 0.18);
  --shadow-2: 0 26px 90px rgba(143, 107, 255, 0.24);

  --text: #262649;
  --muted: #6c6fa0;

  --accent: #8e6bff;
  --accent-2: #ffb8f2;
  --accent-3: #8fd6ff;

  --focus: rgba(142, 107, 255, 0.35);
}

/* Reset */
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family: Manrope, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  line-height: 1.55;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  background:
    radial-gradient(circle at top, #ffffff 0, var(--page-bg) 42%, #fef6ff 100%);
  background-attachment: fixed;
}

img{ max-width:100%; display:block; }

a{ color: inherit; }

:focus-visible{
  outline: 3px solid var(--focus);
  outline-offset: 2px;
  border-radius: 10px;
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *, *::before, *::after{ transition: none !important; animation: none !important; }
}

/* Utilities */
.container{ max-width: var(--container); margin: 0 auto; padding: 0 18px; }
.sr-only{ position:absolute!important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }
.skip-link{ position:absolute; left:-9999px; top:0; background:#fff; color:#000; padding:10px 14px; border-radius:12px; box-shadow: 0 12px 30px rgba(0,0,0,.12); }
.skip-link:focus{ left: 12px; top: 12px; z-index: 9999; }

.muted{ color: var(--muted); }

/* Header */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(18px) saturate(160%);
  border-bottom: 1px solid rgba(142, 107, 255, 0.16);
  box-shadow: 0 10px 40px rgba(122, 92, 255, 0.18);
}

.header__inner{
  height: var(--nav-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.brand{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
}

.brand__mark{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 30% 10%, #ffffff 0, #ffe3ff 30%, #c1b2ff 65%, #f7f0ff 100%);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.75),
    0 12px 32px rgba(140, 112, 255, 0.55);
  color: #7b5cff;
  font-weight: 800;
}

.brand__text small{ color: var(--muted); font-weight: 700; }

.nav{ display: flex; align-items: center; gap: 10px; }
.nav a{
  text-decoration: none;
  color: var(--muted);
  font-weight: 700;
  padding: 10px 10px;
  border-radius: 14px;
  transition: color 160ms ease, background 160ms ease;
}

.nav a:hover{ color: var(--accent); background: rgba(142, 107, 255, 0.08); }

.nav [aria-current="page"]{
  color: var(--text);
  background: rgba(142, 107, 255, 0.12);
}

.burger{
  display: none;
  background: transparent;
  border: 0;
  color: var(--text);
  padding: 10px;
  border-radius: 14px;
}

.burger:hover{ background: rgba(142, 107, 255, 0.08); }

@media (max-width: 960px){
  .burger{ display: inline-flex; }
  .nav{
    position: fixed;
    inset: var(--nav-h) 12px auto 12px;
    display: grid;
    gap: 8px;
    padding: 14px;
    border-radius: 18px;
    background: rgba(255,255,255,0.94);
    backdrop-filter: blur(18px) saturate(160%);
    border: 1px solid rgba(142, 107, 255, 0.18);
    box-shadow: 0 26px 80px rgba(143, 107, 255, 0.18);
    transform: translateY(-14px);
    opacity: 0;
    pointer-events: none;
    transition: transform 220ms ease, opacity 220ms ease;
  }
  body.menu-open .nav{ transform: translateY(0); opacity: 1; pointer-events: auto; }
}

/* Scroll progress bar */
.scrollbar{ height: 3px; background: transparent; }
.scrollbar span{
  display: block;
  height: 100%;
  transform-origin: 0 50%;
  transform: scaleX(0);
  background: linear-gradient(90deg, var(--accent-2), var(--accent));
}

/* Hero */
.hero{
  position: relative;
  min-height: min(92vh, 880px);
  display: grid;
  align-items: stretch;
  scroll-margin-top: calc(var(--nav-h) + 18px);
}

.hero__media{ position: absolute; inset: 0; overflow: hidden; }
.hero__media img{ width: 100%; height: 100%; object-fit: cover; filter: saturate(1.08) brightness(1.12); }
.hero__tint{
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 0 0, rgba(255, 255, 255, 0.80), rgba(170, 144, 255, 0.32));
  mix-blend-mode: screen;
  opacity: 1;
}

.hero__content{
  position: relative;
  min-height: min(80vh, 720px);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(3.5rem, 6vw, 6rem) 0;
}

.display{ font-size: clamp(34px, 5vw, 58px); line-height: 1.05; margin: 0; }
.gradient{ background: linear-gradient(90deg, var(--accent-3), var(--accent-2), var(--accent)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.lead{ max-width: 720px; font-size: 1.125rem; margin: 14px 0 0; color: var(--muted); }

.cta-row{ display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }

/* Sections */
.section{
  position: relative;
  padding: clamp(3.5rem, 6vw, 5.5rem) 0;
  scroll-margin-top: calc(var(--nav-h) + 18px);
}

.section::before{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at top right, rgba(255, 255, 255, 0.70), transparent 55%);
  opacity: 0.6;
  z-index: -1;
}

.section--alt{
  background: radial-gradient(circle at top left, #ffffff 0, var(--page-bg-alt) 40%, #ffffff 100%);
}

.section__title{
  margin: 0 0 18px;
  font-size: clamp(28px, 3.6vw, 40px);
  text-shadow: 0 0 1px rgba(255, 255, 255, 0.9);
}

.section__title::after{
  content: "";
  display: block;
  width: 72px;
  height: 3px;
  margin-top: 0.75rem;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent-2), var(--accent));
  opacity: 0.85;
}

/* Grid */
.grid{ display: grid; gap: 22px; }
.grid--2{ grid-template-columns: 1fr; }
.grid--3{ grid-template-columns: 1fr; }

@media (min-width: 820px){
  .grid--2{ grid-template-columns: 1fr 1fr; }
}

@media (min-width: 980px){
  .grid--3{ grid-template-columns: 1fr 1fr 1fr; }
}

/* Card */
.card{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 22px;
  box-shadow: var(--shadow);
}

.card--hover{
  transition: transform 220ms ease, box-shadow 220ms ease, background 220ms ease;
}

.card--hover:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow-2);
  background: linear-gradient(145deg, rgba(255, 255, 255, 1), rgba(246, 236, 255, 1));
}

.card--accent{
  border-color: rgba(142, 107, 255, 0.28);
  background: linear-gradient(145deg, rgba(255,255,255,0.96), rgba(242, 234, 255, 0.96));
}

.card h2, .card h3, .card h4{ margin: 0 0 10px; }
.card p{ margin: 0; }
.card p + p{ margin-top: 12px; }

/* Lists */
.ticks{ padding-left: 0; margin: 10px 0 0; }
.ticks li{ list-style: none; margin: 8px 0 0; display: flex; gap: 10px; }
.ticks li::before{ content: "✔"; color: var(--accent); flex: 0 0 auto; }

.badges{ display:flex; gap:10px; flex-wrap:wrap; list-style:none; padding:0; margin: 0; }
.badges li{
  background: rgba(142, 107, 255, 0.08);
  color: var(--muted);
  border-radius: 999px;
  border: 1px solid rgba(142, 107, 255, 0.16);
  padding: 8px 12px;
}

/* Chips */
.chip{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(142, 107, 255, 0.25);
  background: rgba(142, 107, 255, 0.08);
  color: var(--text);
  font-weight: 700;
  text-decoration: none;
  transition: transform 160ms ease, background 160ms ease;
}

.chip:hover{ background: rgba(142, 107, 255, 0.12); transform: translateY(-1px); }

/* Buttons */
.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 20px;
  border-radius: 999px;
  font-weight: 700;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.btn--primary{
  background-image: linear-gradient(135deg, var(--accent-2), var(--accent));
  color: #2a103f;
  box-shadow: 0 14px 40px rgba(143, 107, 255, 0.45);
}

.btn--primary:hover{ transform: translateY(-1px); box-shadow: 0 20px 60px rgba(143, 107, 255, 0.55); }

/* 1) Стеклянная линза */
.btn--glass-lens{
  position: relative;
  border-radius: 999px;
  background: radial-gradient(circle at 0 0, rgba(255, 255, 255, 0.96), rgba(243, 232, 255, 0.90));
  box-shadow: 0 18px 38px rgba(143, 107, 255, 0.42);
  color: var(--text);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.95);
  overflow: hidden;
}

.btn--glass-lens::before{
  content: "";
  position: absolute;
  inset: -40%;
  background: conic-gradient(from 180deg, rgba(255, 255, 255, 0.0), rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.0));
  opacity: 0;
  transform: translate3d(-120%, 0, 0);
}

.btn--glass-lens:hover::before{
  opacity: 0.9;
  transform: translate3d(120%, 0, 0);
  transition: transform 900ms ease-out, opacity 900ms ease-out;
}

/* 2) Telegram */
.btn--telegram{
  position: relative;
  border-radius: 999px;
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.78);
  background: linear-gradient(135deg, #2aa7ff, #7b5cff);
  box-shadow: 0 18px 46px rgba(42, 167, 255, 0.28), 0 18px 46px rgba(123, 92, 255, 0.22);
  overflow: hidden;
}

.btn--telegram::before{
  content: "";
  position: absolute;
  inset: -50%;
  background:
    radial-gradient(140px 70px at 20% 75%, rgba(255, 195, 90, 0.22), transparent 60%),
    radial-gradient(120px 70px at 70% 40%, rgba(255, 255, 255, 0.18), transparent 60%),
    linear-gradient(105deg, transparent 0%, rgba(255,255,255,0.18) 45%, rgba(255,255,255,0.06) 55%, transparent 100%);
  transform: translateX(-55%) rotate(8deg);
  opacity: 0.9;
}

.btn--telegram:hover{ transform: translateY(-1px); }
.btn--telegram:hover::before{ transform: translateX(55%) rotate(8deg); transition: transform 900ms ease; }

/* Photo frame */
.photo{ margin: 18px 0; }
.photo--square .photo__frame{ aspect-ratio: 1 / 1; }
.photo__frame{
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 26px 80px rgba(143, 107, 255, 0.28);
  border: 1px solid rgba(255, 255, 255, 0.9);
  background: radial-gradient(circle at top, #ffffff, #f5ecff);
}

.photo__frame > img{ width: 100%; height: 100%; object-fit: cover; display:block; }

/* Video highlight section */
.section--video-highlight{
  padding-block: clamp(3rem, 6vw, 4.5rem);
  background: radial-gradient(circle at top, rgba(255, 255, 255, 1), #f7f1ff 40%, #ffffff 100%);
  border-top: 1px solid rgba(142, 107, 255, 0.12);
  border-bottom: 1px solid rgba(142, 107, 255, 0.12);
}

.section--video-highlight .section__title,
.section--video-highlight .section__subtitle{ text-align: center; }

.section--video-highlight .section__subtitle{
  max-width: 32rem;
  margin: 0 auto 2.5rem;
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--muted);
}

.work-video-shell{
  position: relative;
  width: 100%;
  max-width: 880px;
  margin: 0 auto;
  padding: 0 18px;
}

.work-video-frame{
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  box-shadow: 0 26px 90px rgba(143, 107, 255, 0.35);
  background: #000;
  border: 1px solid rgba(255, 255, 255, 0.9);
}

.work-video-frame::before{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at top, rgba(255, 255, 255, 0.36), transparent 65%);
  mix-blend-mode: screen;
  opacity: 0.85;
}

.work-video{ width: 100%; height: auto; display: block; border-radius: inherit; }

@media (max-width: 768px){
  .section::before{ opacity: 0.35; }
  .work-video-shell{ max-width: 100%; }
  .work-video-frame{ box-shadow: 0 18px 50px rgba(143, 107, 255, 0.30); }
}

/* Reviews */
.reviews-grid{
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  align-items: start;
}

.card.card--video{
  padding: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
  max-width: 406px;
  justify-self: center;
}

.card.card--video .review-video{
  width: 100%;
  height: auto;
  aspect-ratio: 9 / 16;
  object-fit: cover;
  display: block;
}

/* Forms */
.form label{ display:block; font-weight: 700; margin-bottom: 12px; }
.form input, .form textarea{
  width: 100%;
  border-radius: var(--radius-md);
  border: 1px solid rgba(142, 107, 255, 0.22);
  padding: 12px 14px;
  background: rgba(255,255,255,0.9);
  color: var(--text);
  outline: none;
  transition: box-shadow 160ms ease, border-color 160ms ease;
}

.form input::placeholder, .form textarea::placeholder{ color: rgba(108, 111, 160, 0.85); }

.form textarea{ min-height: 120px; resize: vertical; }
.form input:focus, .form textarea:focus{ border-color: rgba(142, 107, 255, 0.65); box-shadow: 0 0 0 6px rgba(142, 107, 255, 0.14); }

.form-status{ margin-top: 12px; color: var(--muted); font-weight: 700; }

.hp{ display:none; }

.actions{ display:flex; flex-wrap:wrap; gap: 10px; margin-top: 14px; }

/* Footer */
.site-footer{
  border-top: 1px solid rgba(142, 107, 255, 0.16);
  background: linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,0.65));
  padding: 44px 0 70px;
}

.footer__inner{ display:flex; align-items:flex-start; justify-content:space-between; gap: 18px; flex-wrap: wrap; }

.links{ display:flex; flex-wrap:wrap; gap: 8px; margin-top: 8px; }

/* to top */
.to-top{
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  text-decoration: none;
  color: #2a103f;
  background-image: linear-gradient(135deg, var(--accent-2), var(--accent));
  box-shadow: 0 14px 40px rgba(143, 107, 255, 0.35);
  opacity: 0.92;
  transform: translateY(8px);
  transition: transform 180ms ease, opacity 180ms ease;
}

.to-top:hover{ opacity: 1; transform: translateY(0); }

/* --- Прелоадер-коридор для Telegram --- */
.tg-preloader{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  background: radial-gradient(closest-side, rgba(10,12,20,0.92), rgba(10,12,20,0.98));
}

.tg-preloader.is-active{ display: flex; }

.tg-tunnel{
  position: relative;
  width: min(92vw, 900px);
  height: min(62vh, 520px);
  background:
    radial-gradient(circle at 50% 50%, rgba(79,209,255,0.18), rgba(79,209,255,0) 35%),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.08) 0 2px, rgba(255,255,255,0) 2px 14px),
    repeating-linear-gradient(0deg,  rgba(255,255,255,0.05) 0 2px, rgba(255,255,255,0) 2px 14px),
    radial-gradient(1200px 500px at 50% 50%, rgba(26,32,60,0.6), rgba(15,18,32,1) 60%);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 18px;
  box-shadow: 0 16px 50px rgba(0,0,0,0.45), inset 0 0 60px rgba(79,209,255,0.15);
  overflow: hidden;
  transform: perspective(900px) rotateX(6deg);
}

.tg-tunnel::before{
  content: "";
  position: absolute;
  inset: -60% -10%;
  background:
    radial-gradient(220px 220px at 50% 50%, rgba(79,209,255,0.28), rgba(255,255,255,0) 70%),
    repeating-conic-gradient(from 0deg, rgba(79,209,255,0.25) 0 6deg, rgba(79,209,255,0) 6deg 18deg);
  mix-blend-mode: screen;
  filter: blur(10px);
  animation: tunnel 1.1s linear infinite;
}

@keyframes tunnel{
  0%   { transform: translateZ(0) rotate(0deg) scale(1); }
  100% { transform: translateZ(200px) rotate(30deg) scale(1.2); }
}

/* --- Toast (результат отправки формы) --- */
.toast{
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(6px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
  z-index: 9999;
}

.toast.is-active{ opacity: 1; pointer-events: auto; }

.toast__card{
  position: relative;
  isolation: isolate;
  min-width: 300px;
  max-width: min(92vw, 560px);
  padding: 18px 20px;
  border-radius: 18px;
  color: #ECF3FF;
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(90,145,255,0.18), rgba(18,20,31,0.92)),
    rgba(13,17,23,0.98);
  box-shadow: 0 12px 48px rgba(0,0,0,0.45), 0 0 0 1px rgba(129,155,255,0.26) inset;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  transform: translateY(8px) scale(0.98);
  transition: transform 220ms ease;
}

.toast.is-active .toast__card{ transform: translateY(0) scale(1); }

.toast__card::before{
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 20px;
  padding: 1px;
  background: linear-gradient(120deg, rgba(136,182,255,0.6), rgba(255,255,255,0.25), rgba(120,220,180,0.6));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0.9;
}

.toast.is-error .toast__card::before{
  background: linear-gradient(120deg, rgba(255,145,145,0.8), rgba(255,255,255,0.25), rgba(255,120,180,0.8));
}

.toast__card::after{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 18px;
  background: linear-gradient(105deg, transparent 0%, rgba(255,255,255,0.08) 40%, rgba(255,255,255,0.18) 50%, rgba(255,255,255,0.08) 60%, transparent 100%);
  transform: translateX(-140%) skewX(-18deg);
  opacity: 0;
}

.toast.is-active .toast__card::after{ animation: toast-glint 1.6s ease 0.05s both; }

@keyframes toast-glint{
  from{ transform: translateX(-140%) skewX(-18deg); opacity: 0; }
  20%{ opacity: 1; }
  80%{ opacity: 1; }
  to{ transform: translateX(140%) skewX(-18deg); opacity: 0; }
}

.toast__icon{
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 18px;
  color: #ffffff;
  box-shadow: 0 4px 16px rgba(46,213,115,0.35), 0 0 0 1px rgba(46,213,115,0.35) inset;
  background: linear-gradient(180deg, #33d17a, #1ea35f);
}

.toast.is-error .toast__icon{
  box-shadow: 0 4px 16px rgba(255,80,80,0.35), 0 0 0 1px rgba(255,80,80,0.35) inset;
  background: linear-gradient(180deg, #ff5c5c, #c71f31);
}

.toast__msg{
  align-self: center;
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.2px;
  text-shadow: 0 1px 0 rgba(0,0,0,0.35);
}

.toast.is-error .toast__msg{ color: #FFECEF; }
/* ===== VIDEO SLIDER (ЭФИРЫ) ===== */
.video-slider{
  position: relative;
  width: 100%;
  max-width: 420px;
  margin: 0 auto;
}

.vs-track{
  display: flex;
  overflow: hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  border-radius: 28px;
  box-shadow: 0 26px 90px rgba(143, 107, 255, 0.35);
  background: #000;
  border: 1px solid rgba(255, 255, 255, 0.9);
  touch-action: pan-y;
}

.vs-track.is-dragging{ cursor: grabbing; }

.vs-slide{
  flex: 0 0 100%;
  scroll-snap-align: center;
}

.vs-slide video{
  width: 100%;
  height: auto;
  aspect-ratio: 9 / 16; /* как YouTube mobile / Shorts */
  object-fit: cover;
  display: block;
}

/* arrows (top & bottom) */
.vs-arrow{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.45);
  cursor: pointer;
  font-size: 30px;
  line-height: 1;
  color: #fff;
  background: rgba(0,0,0,0.42);
  backdrop-filter: blur(10px) saturate(140%);
  box-shadow: 0 10px 26px rgba(0,0,0,0.28);
  display: grid;
  place-items: center;
}

.vs-prev{ top: -22px; }
.vs-next{ bottom: -22px; }

.vs-arrow:hover{
  background: rgba(142,107,255,0.80);
}


#reviews .card.card--video{
  max-width: 320px;
}

@media (max-width: 700px){
  #reviews .reviews-grid{
    grid-template-columns: 1fr;
  }
  #reviews .card.card--video{
    max-width: 420px;
  }
}
/* ===== REVIEWS CAROUSEL (ОТЗЫВЫ) ===== */
.reviews-title{
  text-align: center;
}

.reviews-subtitle{
  text-align: center;
  max-width: 34rem;
  margin: 0 auto 2.25rem;
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--muted);
}


/* ===== CAROUSEL WIDE (горизонтальные видео) ===== */
.video-slider--wide{
  max-width: 980px; /* шире, под экран */
}

@media (max-width: 1020px){
  .video-slider--wide{ max-width: 100%; }
}

.vs-track.carousel-wide .vs-slide video{
  aspect-ratio: 16 / 9; /* горизонтальный формат */
  object-fit: cover;
}
/* ===== REVIEWS: 2 видео по ширине (и на мобилке тоже) ===== */
.video-slider--reviews{
  max-width: 980px; /* на десктопе может быть шире */
}

.video-slider--reviews .vs-track{
  gap: 14px;
}

.video-slider--reviews .vs-slide{
  flex: 0 0 calc((100% - 14px) / 2); /* ровно 2 видео в видимой области */
  scroll-snap-align: start;
}

/* чуть плотнее на очень узких */
@media (max-width: 520px){
  .video-slider--reviews .vs-track{ gap: 10px; }
  .video-slider--reviews .vs-slide{
    flex: 0 0 calc((100% - 10px) / 2);
  }
}
/* ===== HERO: COPY BOTTOM CENTERED ===== */
.hero__content--center{
  /* внутри .hero__content (который уже flex/justify-content:flex-end) */
  width: 100%;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end; /* прижать вниз */
  align-items: center;       /* центр по горизонтали */
  text-align: center;
}

.hero__copy{
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  display: grid;
  gap: 18px;
  padding-bottom: 24px; /* отступ от низа */
}

.hero__kicker{
  margin: 0;
  font-weight: 800;
  letter-spacing: 0.18px;
  color: rgba(38, 38, 73, 0.88);
  text-shadow: 0 0 1px rgba(255,255,255,0.9);
}

.hero-quote__ru{
  margin: 0;
  font-size: clamp(18px, 2.6vw, 22px);
  font-weight: 800;
  line-height: 1.35;
  color: #f1c363;
}

.hero-quote__en{
  margin: 10px 0 0;
  font-size: 0.98rem;
  color: var(--muted);
  font-weight: 700;
}

.hero__cta{
  justify-content: center;
}

/* ===== PROMO PHOTO CAROUSEL (VERTICAL) ===== */
.video-slider--promo{
  max-width: 420px; /* вертикальный формат как мобильный YouTube */
  margin: 0 auto;
}

@media (max-width: 520px){
  .video-slider--promo{ max-width: 100%; padding: 0 18px; }
}

.video-slider--promo .vs-track{
  border-radius: 28px;
  box-shadow: 0 26px 90px rgba(143, 107, 255, 0.35);
  background: radial-gradient(circle at top, #ffffff, #f5ecff);
  border: 1px solid rgba(255, 255, 255, 0.9);
}

.video-slider--promo img{
  width: 100%;
  height: auto;
  aspect-ratio: 9 / 16; /* вертикально */
  object-fit: cover;
  display: block;
}

/* =========================================================
   PATCH: .card рамки + вензеля (по вашей "outer/mid/inner" идее)
   Основано на структуре/стилях из strukt.html и venzel-zagatovka.txt
   Вензель: img/venzel.png (должен существовать в проекте)
========================================================= */

:root {
  --gold-frame: #DE9B72;
}

/* Чтобы рамки и декор не "вылазили" и не ломали layout */
.card {
  position: relative;
  isolation: isolate;
  overflow: hidden; /* важно для уголков внутри карточки */
}

/*
  3 рамки:
  - внешняя: border 2px
  - средняя: border 6px (через ::before)
  - внутренняя: border 2px (через ::after)
  Толщины взяты из вашего примера.
*/
.card {
  border: 2px solid var(--gold-frame);
  /* место под рамки и уголки */
  padding: calc(1.25rem + 22px);
}

.card::before {
  content: "";
  position: absolute;
  inset: 6px;
  border: 6px solid var(--gold-frame);
  border-radius: calc(var(--radius-lg) - 6px);
  pointer-events: none;
  z-index: 0;
}

.card::after {
  content: "";
  position: absolute;
  inset: 18px;
  border: 2px solid var(--gold-frame);
  border-radius: calc(var(--radius-lg) - 18px);
  pointer-events: none;
  z-index: 1;

      /* Угловые вензеля: 4 отдельные картинки */
  background-image:
    url('img/venzelTL.png'),
    url('img/venzelTR.png'),
    url('img/venzelBR.png'),
    url('img/venzelBL.png');
background-repeat: no-repeat;
  background-size: 3em;
  background-position:
    left -3px top -3px,
    right -3px top -3px,
    right -3px bottom -3px,
    left -3px bottom -3px;

  filter: drop-shadow(0 2px 3px rgba(0,0,0,.10));
  opacity: 0.98;
}

/* Контент карточки поверх рамок/декора */
.card > * {
  position: relative;
  z-index: 2;
}

/* Responsive размеры уголков — как в вашем CSS */
@media (min-width: 768px) {
  .card::after {
    background-size: 3.5em;
    background-position:
      left -4px top -4px,
      right -4px top -4px,
      right -4px bottom -4px,
      left -4px bottom -4px;
  }
}
@media (min-width: 992px) {
  .card::after {
    background-size: 4em;
    background-position:
      left -5px top -5px,
      right -5px top -5px,
      right -5px bottom -5px,
      left -5px bottom -5px;
  }
}
@media (min-width: 1200px) {
  .card::after {
    background-size: 5em;
    background-position:
      left -6px top -6px,
      right -6px top -6px,
      right -6px bottom -6px,
      left -6px bottom -6px;
  }
}

/* Чтобы hover-анимация не "трясла" рамку */
.card--hover:hover {
  transform: translateY(-4px);
}

/* ===== HERO QUOTE MOBILE PATCH =====
   Требование:
   - плашка .hero__copy: 80% ширины экрана на мобиле
   - опустить ниже на 50px
   Влияет только на мобильные размеры.
==================================== */
@media (max-width: 600px){
  .hero__copy{
    width: 80%;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    top: 50px;
  }
}

/* ===== HERO QUOTE: plain text + calligraphic Cyrillic =====
   Требование:
   - позицию .hero__copy оставить как есть
   - убрать рамку/плашку (только текст)
   - убрать кавычки (сделано в HTML: удалены « »)
   - каллиграфический шрифт кириллицы: Marck Script
=========================================================== */

.hero__copy,
.hero-quote,
.hero-quote__ru{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.hero-quote__ru{
  font-family: "Marck Script", cursive;
  font-weight: 400;
  font-size: clamp(22px, 5.2vw, 42px);
  line-height: 1.25;
  letter-spacing: 0.2px;
  text-align: center;
  color: var(--text, #1f1a24);
  text-shadow: 0 2px 10px rgba(0,0,0,.18);
}

/* если где-то добавлялись кавычки через псевдоэлементы — отключаем */
.hero-quote__ru::before,
.hero-quote__ru::after{
  content: none !important;
}

/* ===== FORCE hero quote color ===== */
.hero__copy .hero-quote__ru{
  color: #f1c363 !important;
}

/* ===== HERO QUOTE DESKTOP POSITION =====
   На десктопе переносим цитату вниз к краю hero-картинки
   с отступом 30px.
======================================== */
@media (min-width: 601px){
  .hero{
    position: relative;
  }
  .hero__copy{
    width: min(720px, 70%);
    margin: 0;
    position: absolute;
    left: 50%;
    bottom: 30px;
    top: auto;
    transform: translateX(-50%);
    z-index: 3;
  }
}

/* ===== VIDEO FIT FIX (Эфиры и Практики) =====
   Проблема: видео "крамсается" (обрезаются края) из-за object-fit: cover.
   Решение: показываем видео целиком (contain) + оставляем аккуратные скругления трека.
============================================= */
.video-slider--wide .vs-slide video{
  object-fit: contain !important; /* вместо cover */
  background: transparent;
}

/* ===== HERO QUOTE DESKTOP: 2 lines at bottom (no column) =====
   Основа оставлена прежней (flex-end в .hero__content).
   На десктопе:
   - убираем абсолютное позиционирование/transform у .hero__copy (если было)
   - прижимаем к низу через padding-bottom контейнера
   - ограничиваем ширину строки, чтобы было 2 строки, а не "столбик"
=============================================================== */
@media (min-width: 601px){
  .hero__content{
    padding-bottom: 30px !important;
  }

  .hero__copy{
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;

    width: min(720px, 70%) !important;
    max-width: 720px;
    margin-left: auto !important;
    margin-right: auto !important;

    display: block !important;
  }

  .hero__copy .hero-quote__ru{
    max-width: 46ch;
    margin-left: auto;
    margin-right: auto;
    white-space: normal;
    overflow-wrap: normal;
    word-break: normal;
    hyphens: none;
  }
}

/* ===== HERO QUOTE: forced 2-line break ===== */
.hero__copy .hero-quote__ru br { display: block; content: ""; margin: 0.15em 0; }

/* ===== HERO QUOTE: keep exactly 2 lines on desktop ===== */
.hero__copy .hero-quote__line{
  display: block;
  white-space: nowrap; /* не даём каждой строке переноситься */
}

/* На десктопе даём чуть больше ширины, чтобы строки не ломались */
@media (min-width: 601px){
  .hero__copy{
    width: min(900px, 86%) !important;
  }
}

/* ===== HERO QUOTE WRAPPER REMOVED =====
   blockquote.hero-quote удалён из HTML — на всякий случай
   сбрасываем возможные стили для старого класса.
======================================== */
.hero-quote{ margin: 0 !important; padding: 0 !important; border: 0 !important; background: transparent !important; }

/* ===== HERO QUOTE CENTERING (mobile + desktop) ===== */
.hero__copy{
  margin-left: auto !important;
  margin-right: auto !important;
  left: 0;
  right: 0;
  text-align: center;
}

.hero__copy .hero-quote__ru,
.hero__copy .hero-quote__line{
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}
