/* 
 * CSS переменные и utility классы перенесены в /shared/shared.css
 * Этот файл содержит только специфичные стили для лендинга ProgKids
 */
html{
  scroll-behavior:smooth;
  overflow-x:hidden;
  width:100%;
}
body{
  margin:0; 
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial;
  color:var(--text); 
  background:var(--bg);
  line-height:1.55;
  width:100%;
  overflow-x:hidden;
  position:relative;
}

/* HEADER */
.header{
  position:sticky; 
  top:0; 
  z-index:100;
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(12px); 
  -webkit-backdrop-filter: blur(12px);
  border-bottom:1px solid rgba(255,255,255,0.1);
  width:100%;
  max-width:100vw;
  overflow:hidden;
}
.header-inner{
  max-width:1400px; 
  margin:0 auto; 
  padding:12px 20px;
  display:flex; 
  align-items:center; 
  justify-content:space-between; 
  gap:24px;
  width:100%;
  box-sizing:border-box;
}
.logo{ 
  display:flex; align-items:center; text-decoration:none; 
  transition: var(--transition-normal);
}
.logo:hover{ opacity:0.8; transform:scale(1.02); }
.logo img{ height:28px; width:auto; }
.btn-header{
  padding:var(--spacing-sm) var(--spacing-lg); 
  border-radius:var(--radius-sm); 
  background:var(--accent); color:#0a0a0a;
  border:none; font-weight:700; font-size:15px;
  cursor:pointer; transition: var(--transition-normal);
  text-decoration:none;
  box-shadow:0 4px 16px rgba(30,239,83,.3);
}
.btn-header:hover{ 
  transform: translateY(-2px);
  box-shadow:0 6px 20px rgba(30,239,83,.5);
}
@media (max-width: 768px){
  .header-inner{ padding:10px 16px; }
  .logo img{ height:24px; }
  .btn-header{ 
    display:none;
  }
}

/* SECTIONS */
.section{
  position:relative; 
  padding:clamp(60px,10vw,120px) 24px;
  isolation:isolate;
  width:100%;
  max-width:100vw;
  overflow:hidden;
}
.container{ 
  max-width:1200px; 
  margin:0 auto;
  width:100%;
  padding:0 clamp(8px,2vw,0px);
}
@media (max-width: 768px){
  .section{ 
    padding:clamp(40px,8vw,60px) 16px;
    overflow:hidden;
  }
  .container{
    padding:0;
  }
}

/* Soft glows */
.glow-bg::before,
.glow-bg::after{
  content:""; position:absolute; width:50vmax; height:50vmax; 
  border-radius:50%; filter:blur(100px); pointer-events:none; z-index:-1;
}
.glow-bg::before{ 
  left:-15vw; top:-10vw; 
  background:radial-gradient(closest-side, rgba(59,130,246,0.25), transparent 70%); 
}
.glow-bg::after{ 
  right:-10vw; bottom:-15vw; 
  background:radial-gradient(closest-side, rgba(236,72,153,0.2), transparent 70%); 
}

/* HERO */
.hero{
  min-height:90vh; display:flex; align-items:center; justify-content:center;
}
.hero-container{
  display:grid; 
  grid-template-columns: 1.1fr 1fr; 
  gap:clamp(32px,5vw,64px);
  align-items:center; 
  max-width:1200px; 
  margin:0 auto;
  width:100%;
}
.hero-content{ 
  max-width:600px;
  width:100%;
}
.hero h1{
  font-size:clamp(32px,5.5vw,56px); font-weight:900; line-height:1.1;
  margin:0 0 24px; 
  background: linear-gradient(135deg, #ffffff 0%, var(--accent) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-lead{
  font-size:clamp(16px,1.8vw,19px); color:var(--muted); 
  margin:0 0 32px; line-height:1.6;
}
.hero-cta{
  display:flex; flex-direction:column; gap:12px; align-items:flex-start;
}
.btn-primary{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:18px 36px; border-radius:var(--radius-md); font-weight:700; font-size:18px;
  text-decoration:none; transition: var(--transition-normal); border:none;
  background:var(--accent); color:#0a0a0a; 
  box-shadow:0 0 0 0 var(--ring), 0 8px 32px rgba(30,239,83,.5);
  cursor:pointer;
}
.btn-primary:hover{ 
  transform: translateY(-2px); 
  box-shadow:0 0 0 8px rgba(30,239,83,.15), 0 12px 40px rgba(30,239,83,.7); 
}
.hero-note{
  font-size:14px; color:var(--muted); margin-top:8px;
}
.hero-note strong{ color:var(--accent); }

/* Hero Image with Glass Effect */
.hero-image{
  position:relative;
}
.hero-image-glass{
  position:relative; 
  border-radius:var(--radius-xl); 
  overflow:hidden;
  border:2px solid var(--glass-border);
  box-shadow: var(--shadow), 0 20px 60px rgba(30,239,83,.2);
  aspect-ratio: 4/5;
  transition:all var(--transition-slow);
}
.hero-image-glass::before{
  content:""; 
  position:absolute; 
  inset:0;
  background: linear-gradient(135deg, rgba(30,239,83,0.1), rgba(59,130,246,0.1));
  z-index:1;
  pointer-events:none;
  mix-blend-mode:overlay;
}
.hero-image-glass::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:22px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.2), inset 0 -1px 0 rgba(0,0,0,0.2);
  z-index:2;
  pointer-events:none;
}
.hero-image-glass:hover{
  transform:scale(1.03);
  box-shadow: var(--shadow), 0 25px 70px rgba(30,239,83,.3);
  border-color:rgba(30,239,83,0.5);
}
.hero-image-glass img{
  width:100%;
  height:100%;
  max-width:100%;
  object-fit:cover;
  display:block;
  position:relative;
  z-index:0;
}

@media (max-width: 980px){
  .hero{ min-height:auto; padding:60px 0 40px; }
  .hero-container{ 
    grid-template-columns:1fr; 
    text-align:center; 
    gap:32px;
  }
  .hero h1{ 
    font-size:clamp(28px,7vw,42px); 
    margin:0 0 16px;
    line-height:1.15;
  }
  .hero-lead{ 
    font-size:16px; 
    margin:0 0 24px;
    line-height:1.5;
  }
  .hero-cta{ 
    align-items:center;
    width:100%;
  }
  .btn-primary{
    width:100%;
    max-width:320px;
    padding:16px 32px;
    font-size:16px;
  }
  .hero-note{ font-size:13px; }
  .hero-image{ 
    order:-1; 
    max-width:320px; 
    margin:0 auto;
  }
  .hero-image-glass{
    aspect-ratio: 1;
    border-radius:20px;
  }
  .hero-image-glass img{
    object-position:center;
  }
}

/* BENEFITS SECTION */
.benefits-grid{
  display:grid; 
  grid-template-columns: repeat(3, 1fr);
  gap:20px; 
  margin-top:48px;
  width:100%;
  max-width:100%;
}
@media (max-width: 980px){
  .benefits-grid{ 
    grid-template-columns: repeat(2, 1fr); 
    gap:16px;
    margin-top:32px;
  }
}
@media (max-width: 640px){
  .benefits-grid{ 
    grid-template-columns: 1fr; 
    gap:16px;
    margin-top:32px;
  }
}
.benefit-card{
  position:relative; 
  padding:var(--spacing-xl) 28px; 
  border-radius:var(--radius-xl);
  background: linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,255,255,0.05));
  border:1px solid rgba(255,255,255,0.15);
  backdrop-filter: blur(20px); 
  -webkit-backdrop-filter: blur(20px);
  overflow:hidden;
  transition: all var(--transition-cubic);
}
/* Карточка 3 занимает 2 колонки на больших экранах */
.benefit-card:nth-child(3){
  grid-column: span 2;
  display:grid;
  grid-template-columns: auto 1fr;
  gap:24px;
  align-items:center;
}
@media (max-width: 980px){
  .benefit-card:nth-child(3){ grid-column: span 1; grid-template-columns: 1fr; }
}

/* Градиентный фон для каждой карточки */
.benefit-card::before{
  content:""; 
  position:absolute; 
  inset:0;
  background: radial-gradient(circle at 0% 0%, rgba(30,239,83,0.08), transparent 70%);
  opacity:0;
  transition: opacity .4s ease;
}
.benefit-card:hover::before{ opacity:1; }

/* Светящаяся рамка при hover */
.benefit-card::after{
  content:""; 
  position:absolute; 
  inset:-1px;
  background: linear-gradient(135deg, var(--accent), #76ff9c);
  border-radius:24px;
  opacity:0;
  z-index:-1;
  transition: opacity .4s ease;
}
.benefit-card:hover::after{ opacity:0.4; }

.benefit-card:hover{
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 20px 60px rgba(30,239,83,.3), 0 0 0 1px rgba(30,239,83,.5);
  border-color: rgba(30,239,83,.4);
}

.benefit-icon-wrapper{
  position:relative;
  width:64px; 
  height:64px; 
  border-radius:18px; 
  background: rgba(255,255,255,0.12);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 2px solid var(--accent);
  display:grid; 
  place-items:center;
  box-shadow: 0 8px 24px rgba(30,239,83,.3), inset 0 1px 0 rgba(255,255,255,0.2);
  transition: all .4s cubic-bezier(0.4, 0, 0.2, 1);
  margin-bottom:20px;
}
.benefit-icon-wrapper::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:16px;
  background: linear-gradient(135deg, rgba(30,239,83,0.15), rgba(118,255,156,0.1));
  z-index:0;
}
.benefit-card:nth-child(3) .benefit-icon-wrapper{
  margin-bottom:0;
}
.benefit-card:hover .benefit-icon-wrapper{
  transform: scale(1.1) rotate(-5deg);
  background: rgba(255,255,255,0.18);
  border-color: #76ff9c;
  box-shadow: 0 12px 32px rgba(30,239,83,.5), 0 0 0 4px rgba(30,239,83,.1), inset 0 1px 0 rgba(255,255,255,0.3);
}
.benefit-icon{
  font-size:36px;
  position:relative;
  z-index:1;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.3));
}

.benefit-content{
  position:relative; 
  z-index:1;
}
.benefit-card h3{
  font-size:19px; 
  margin:0 0 12px; 
  font-weight:700;
  line-height:1.3;
  background: linear-gradient(135deg, #ffffff, rgba(255,255,255,0.9));
  -webkit-background-clip:text; 
  background-clip:text;
}
.benefit-card p{
  margin:0; 
  color:var(--muted); 
  font-size:14px; 
  line-height:1.6;
}

/* Номера карточек */
.benefit-number{
  position:absolute; 
  top:20px; 
  right:20px;
  width:32px; 
  height:32px;
  border-radius:50%;
  background: rgba(30,239,83,0.15);
  border:1px solid rgba(30,239,83,0.3);
  display:grid; 
  place-items:center;
  font-size:14px; 
  font-weight:700;
  color:var(--accent);
  transition: all .3s ease;
}
.benefit-card:hover .benefit-number{
  background: rgba(30,239,83,0.25);
  transform: scale(1.1);
}

/* Мобильные стили для карточек */
@media (max-width: 640px){
  .benefit-card{
    padding:24px 20px;
    border-radius:20px;
  }
  .benefit-card:nth-child(3){
    grid-column: span 1;
    grid-template-columns: 1fr;
  }
  .benefit-icon-wrapper{
    width:56px;
    height:56px;
    margin-bottom:16px;
  }
  .benefit-icon{
    font-size:30px;
  }
  .benefit-card h3{
    font-size:17px;
    margin:0 0 10px;
  }
  .benefit-card p{
    font-size:14px;
    line-height:1.5;
  }
  .benefit-number{
    width:28px;
    height:28px;
    font-size:12px;
    top:16px;
    right:16px;
  }
}

/* SECTION TITLE */
.section-title{
  font-size:clamp(28px,4vw,48px); font-weight:800; 
  text-align:center; margin:0 0 16px;
}
.section-subtitle{
  font-size:clamp(16px,1.8vw,20px); color:var(--muted);
  text-align:center; max-width:700px; margin:0 auto 48px;
  line-height:1.6;
}
@media (max-width: 640px){
  .section-title{
    font-size:clamp(24px,6vw,32px);
    margin:0 0 12px;
  }
  .section-subtitle{
    font-size:15px;
    margin:0 auto 32px;
    line-height:1.5;
  }
}

/* COURSE SECTION - CARD STYLE */
.course-wrapper{
  max-width:1000px;
  width:100%;
  margin:0 auto;
  padding:48px;
  border-radius:var(--radius-xl);
  background: var(--glass);
  border:1px solid var(--glass-border);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: var(--shadow);
  box-sizing:border-box;
}
.course-content{
  display:flex;
  flex-direction:column;
  gap:32px;
}
.course-header{
  text-align:center;
}
.course-header h2{
  font-size:clamp(28px,4vw,42px); 
  font-weight:800; 
  margin:0 0 20px; 
  line-height:1.2;
  background: linear-gradient(135deg, #ffffff, var(--accent));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.course-header p{
  font-size:clamp(16px,1.8vw,19px); 
  color:var(--muted);
  line-height:1.7; 
  margin:0 auto;
  max-width:700px;
}

/* Image with Code Elements */
.course-visual{
  position:relative;
  margin:24px 0;
  width:100%;
  max-width:100%;
}
.course-image{
  position:relative; 
  border-radius:24px; 
  overflow:hidden;
  border:2px solid rgba(30,239,83,0.3);
  box-shadow: 0 20px 60px rgba(30,239,83,.25);
  aspect-ratio: 21/9;
  transition:all .4s ease;
  width:100%;
  max-width:100%;
}
.course-image::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(135deg, rgba(30,239,83,0.06), transparent 50%, rgba(59,130,246,0.06));
  z-index:1;
  pointer-events:none;
}
.course-image:hover{
  transform:scale(1.02);
  box-shadow: 0 25px 70px rgba(30,239,83,.35);
  border-color:rgba(30,239,83,0.5);
}
.course-image img{
  width:100%;
  height:100%;
  max-width:100%;
  object-fit:cover;
  display:block;
  position:relative;
  z-index:0;
}

/* Floating Code Snippets */
.code-snippets{
  position:absolute;
  inset:-60px;
  pointer-events:none;
  z-index:10;
}
.code-item{
  position:absolute;
  padding:12px 18px;
  border-radius:12px;
  background: rgba(0,0,0,0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border:1.5px solid var(--accent);
  font-family: 'Courier New', monospace;
  font-size:14px;
  font-weight:600;
  color:var(--accent);
  white-space:nowrap;
  box-shadow: 0 8px 24px rgba(0,0,0,0.7), 0 0 40px rgba(30,239,83,0.3);
  animation: floatSmooth 6s ease-in-out infinite;
}
.code-item:nth-child(1){
  top:10%;
  left:2%;
  animation-delay:0s;
}
.code-item:nth-child(2){
  top:15%;
  right:3%;
  animation-delay:2s;
}
.code-item:nth-child(3){
  bottom:15%;
  left:0;
  animation-delay:4s;
}
.code-item:nth-child(4){
  bottom:12%;
  right:5%;
  animation-delay:1s;
}
@keyframes floatSmooth {
  0%, 100% { 
    transform: translateY(0px) scale(1); 
    opacity:0.8;
  }
  50% { 
    transform: translateY(-20px) scale(1.05); 
    opacity:1;
  }
}

/* Feature Tags Below */
.course-features{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:16px;
  margin-top:8px;
}
.feature-pill{
  padding:14px 24px;
  border-radius:16px;
  background: linear-gradient(135deg, rgba(30,239,83,0.12), rgba(30,239,83,0.06));
  border:1px solid rgba(30,239,83,0.3);
  font-size:15px;
  font-weight:700;
  color:var(--accent);
  display:flex;
  align-items:center;
  gap:10px;
  transition:.3s ease;
  cursor:default;
}
.feature-pill:hover{
  background: linear-gradient(135deg, rgba(30,239,83,0.2), rgba(30,239,83,0.1));
  transform:scale(1.05);
}
.feature-icon{
  font-size:24px;
}

@media (max-width: 980px){
  .course-wrapper{
    padding:32px 24px;
    width:calc(100% - 0px);
  }
  .course-visual{
    margin:20px 0;
  }
  .code-snippets{ display:none; }
}
@media (max-width: 640px){
  .course-wrapper{
    padding:24px 16px;
    border-radius:20px;
    width:100%;
    margin:0;
  }
  .course-header h2{
    font-size:clamp(24px,6vw,28px);
    margin:0 0 16px;
  }
  .course-header p{
    font-size:15px;
    line-height:1.6;
  }
  .course-visual{
    margin:16px 0;
  }
  .course-image{
    aspect-ratio: 16/9;
    border-radius:16px;
  }
  .course-features{
    gap:10px;
    flex-direction:column;
  }
  .feature-pill{
    padding:12px 18px;
    font-size:14px;
    width:100%;
    justify-content:center;
  }
  .feature-icon{
    font-size:20px;
  }
}

/* HOW IT WORKS - TIMELINE STYLE */
.steps{
  max-width:900px;
  width:100%;
  margin:48px auto 0;
  position:relative;
}
/* Вертикальная линия по центру */
.steps::before{
  content:"";
  position:absolute;
  left:50%;
  top:40px;
  bottom:40px;
  width:3px;
  background: linear-gradient(180deg, 
    var(--accent) 0%,
    rgba(30,239,83,0.5) 50%,
    var(--accent) 100%
  );
  transform:translateX(-50%);
  border-radius:2px;
  box-shadow: 0 0 20px rgba(30,239,83,0.3);
}

.step{
  position:relative;
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  gap:32px;
  margin-bottom:40px;
  transition: all .3s ease;
}
.step:last-child{
  margin-bottom:0;
}

/* Четные шаги - контент справа */
.step:nth-child(even){
  direction:ltr;
}
.step:nth-child(even) .step-content{
  grid-column:3;
  text-align:left;
}
.step:nth-child(even) .step-number{
  grid-column:2;
}
.step:nth-child(even) .step-spacer{
  grid-column:1;
}

/* Нечетные шаги - контент слева */
.step:nth-child(odd) .step-content{
  grid-column:1;
  text-align:right;
}
.step:nth-child(odd) .step-number{
  grid-column:2;
}
.step:nth-child(odd) .step-spacer{
  grid-column:3;
}

.step-spacer{
  width:100%;
}

.step-content{
  padding:28px;
  border-radius:var(--radius-lg);
  background: var(--glass);
  border:1px solid var(--glass-border);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: var(--shadow);
  transition: all var(--transition-normal);
}
.step:hover .step-content{
  transform: scale(1.05);
  box-shadow: 0 12px 40px rgba(30,239,83,.25), var(--shadow);
  border-color: rgba(30,239,83,.3);
  background: rgba(255,255,255,0.15);
}

.step-number{
  width:64px;
  height:64px;
  border-radius:50%;
  background: linear-gradient(135deg, var(--accent), #76ff9c);
  color:#0a0a0a;
  font-size:28px;
  font-weight:800;
  display:grid;
  place-items:center;
  box-shadow: 0 0 0 8px rgba(0,0,0,0.9), 0 8px 24px rgba(30,239,83,.5);
  transition: all .3s ease;
  position:relative;
  z-index:2;
}
.step:hover .step-number{
  transform: scale(1.15) rotate(10deg);
  box-shadow: 0 0 0 8px rgba(0,0,0,0.9), 0 12px 32px rgba(30,239,83,.7);
}

.step h3{
  font-size:20px;
  margin:0 0 10px;
  font-weight:700;
  color:var(--text);
}
.step p{
  margin:0;
  color:var(--muted);
  font-size:15px;
  line-height:1.6;
}

/* Mobile version - обычный вертикальный список */
@media (max-width: 768px){
  .steps::before{
    left:24px;
    top:30px;
    bottom:30px;
  }
  .step{
    display:flex;
    flex-direction:row;
    gap:20px;
    margin-bottom:32px;
    align-items:start;
  }
  .step-number{
    width:48px;
    height:48px;
    font-size:20px;
    flex-shrink:0;
    box-shadow: 0 0 0 6px rgba(0,0,0,0.9), 0 6px 20px rgba(30,239,83,.5);
    order:1;
  }
  .step-content{
    text-align:left !important;
    padding:20px;
    order:2;
    flex:1;
  }
  .step-spacer{
    display:none !important;
  }
  .step h3{
    font-size:17px;
    margin:0 0 8px;
  }
  .step p{
    font-size:14px;
  }
}

/* Refund Note */
.refund-note{
  margin-top:48px;
  padding:20px 24px;
  border-radius:16px;
  background: linear-gradient(135deg, rgba(30,239,83,0.1), rgba(30,239,83,0.05));
  border:1px solid rgba(30,239,83,0.3);
  color:var(--muted);
  font-size:15px;
  line-height:1.6;
  text-align:center;
  width:100%;
  max-width:100%;
  box-sizing:border-box;
}
.refund-note strong{
  color:var(--accent);
  font-weight:700;
}
@media (max-width: 640px){
  .refund-note{
    margin-top:32px;
    padding:16px;
    font-size:14px;
  }
}

/* TESTIMONIALS */
.testimonials{
  display:grid; 
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap:24px; 
  margin-top:48px;
  width:100%;
  max-width:100%;
}
@media (max-width: 768px){
  .testimonials{ 
    grid-template-columns: repeat(2, 1fr);
    gap:16px; 
    margin-top:32px;
  }
}
@media (max-width: 600px){
  .testimonials{ 
    grid-template-columns: 1fr;
    gap:16px;
  }
}
.testimonial{
  padding:28px var(--spacing-lg); 
  border-radius:var(--radius-lg);
  background: var(--glass);
  border:1px solid var(--glass-border);
  backdrop-filter: blur(20px); 
  -webkit-backdrop-filter: blur(20px);
  box-shadow: var(--shadow);
  transition: all var(--transition-normal);
}
.testimonial:hover{
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(30,239,83,.2), var(--shadow);
  border-color: rgba(30,239,83,.25);
}
.testimonial-header{
  display:flex; align-items:center; gap:16px; margin-bottom:16px;
}
.testimonial-avatar{
  width:48px; height:48px; border-radius:50%;
  background: linear-gradient(135deg, var(--accent), #76ff9c);
  display:grid; place-items:center; font-size:24px;
  box-shadow: 0 4px 16px rgba(30,239,83,.3);
}
.testimonial-name{
  font-weight:700; font-size:18px;
}
.testimonial-text{
  color:var(--muted); line-height:1.6; font-size:15px;
}
@media (max-width: 640px){
  .testimonial{
    padding:24px 20px;
  }
  .testimonial-avatar{
    width:44px;
    height:44px;
    font-size:22px;
  }
  .testimonial-name{
    font-size:16px;
  }
  .testimonial-text{
    font-size:14px;
    line-height:1.5;
  }
}

/* CTA SECTION */
.cta-section{
  padding:clamp(60px, 10vw, 100px) 24px;
  background:var(--bg);
  position:relative;
}
.cta-card{
  max-width:1300px;
  margin:0 auto;
  padding:clamp(60px, 7vw, 80px) clamp(40px, 5vw, 60px);
  border-radius:28px;
  background:linear-gradient(135deg, #0d1f18 0%, #0a1410 100%);
  border:1px solid rgba(30,239,83,0.12);
  position:relative;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.6);
}
.cta-card::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:
    radial-gradient(circle at 10% 20%, rgba(30,239,83,0.05) 0%, transparent 50%),
    radial-gradient(circle at 90% 80%, rgba(30,239,83,0.04) 0%, transparent 50%);
  pointer-events:none;
  z-index:0;
}
.cta-logo{
  position:absolute;
  top:clamp(-50px, -3.5vw, -30px);
  left:clamp(32px, 4vw, 48px);
  z-index:2;
}
.cta-logo img{
  width:clamp(200px, 22vw, 300px);
  height:auto;
  filter:drop-shadow(0 15px 40px rgba(30,239,83,0.4));
  animation:float3D 6s ease-in-out infinite;
}
.cta-main{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px, 5vw, 64px);
  align-items:center;
  margin-top:clamp(60px, 8vw, 100px);
  position:relative;
  z-index:1;
}
@keyframes float3D {
  0%, 100% {
    transform:translateY(0) rotateY(0deg) rotateX(5deg);
  }
  50% {
    transform:translateY(-15px) rotateY(10deg) rotateX(-5deg);
  }
}
.cta-content{
  text-align:left;
  padding-left:0;
}
.cta-title{
  font-size:clamp(28px, 4vw, 44px);
  font-weight:900;
  line-height:1.2;
  margin:0 0 16px;
  color:var(--text);
  letter-spacing:-0.02em;
}
.cta-description{
  font-size:clamp(15px, 1.5vw, 17px);
  color:var(--muted);
  line-height:1.65;
  margin:0;
}
.cta-right{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
}
.cta-form{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.cta-form-group{
  position:relative;
}
.cta-input{
  width:100%;
  padding:16px 22px;
  border-radius:14px;
  background:rgba(255,255,255,0.95);
  border:2px solid rgba(255,255,255,0.1);
  color:#333;
  font-size:15px;
  font-family:inherit;
  transition:all 0.3s ease;
  box-sizing:border-box;
}
.cta-input::placeholder{
  color:rgba(0,0,0,0.4);
}
.cta-input:focus{
  outline:none;
  border-color:var(--accent);
  background:#fff;
  box-shadow:0 0 0 4px rgba(30,239,83,0.15);
}
.cta-input.phone-error{
  border-color:#ef4444;
  background:rgba(255,255,255,0.9);
}
.cta-submit{
  width:100%;
  padding:18px 32px;
  border-radius:14px;
  background:var(--accent);
  color:#0a0a0a;
  border:none;
  font-size:19px;
  font-weight:700;
  cursor:pointer;
  transition:all 0.3s ease;
  box-shadow:0 8px 32px rgba(30,239,83,0.5);
  margin-top:6px;
}
.cta-submit:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 40px rgba(30,239,83,0.7);
}
.cta-submit:active{
  transform:translateY(0);
}
.cta-submit:disabled{
  opacity:0.6;
  cursor:not-allowed;
}
.cta-submit.shake{
  animation:shake 0.5s;
}

/* Мобильная версия */
@media (max-width:980px){
  .cta-section{
    padding:clamp(48px, 8vw, 60px) 16px;
  }
  .cta-card{
    padding:clamp(32px, 5vw, 48px) clamp(20px, 4vw, 32px);
    border-radius:24px;
  }
  .cta-logo{
    position:static;
    text-align:center;
    margin-bottom:24px;
  }
  .cta-logo img{
    width:clamp(140px, 20vw, 180px);
  }
  .cta-main{
    grid-template-columns:1fr;
    gap:32px;
    margin-top:0;
  }
  .cta-content{
    text-align:center;
    padding-left:0;
  }
  .cta-title{
    font-size:clamp(24px, 6vw, 36px);
    margin:0 0 16px;
  }
  .cta-description{
    font-size:15px;
  }
}
@media (max-width:640px){
  .cta-card{
    padding:28px 20px;
    border-radius:20px;
  }
  .cta-logo img{
    width:clamp(120px, 22vw, 160px);
  }
  .cta-main{
    gap:24px;
  }
  .cta-title{
    font-size:clamp(22px, 6vw, 28px);
  }
  .cta-input{
    padding:14px 18px;
    font-size:15px;
    border-radius:12px;
  }
  .cta-submit{
    padding:16px 28px;
    font-size:17px;
    border-radius:12px;
  }
}

/* FAQ */
.faq{
  max-width:800px; 
  width:100%;
  margin:48px auto 0;
}
@media (max-width: 640px){
  .faq{ 
    margin:32px auto 0;
    width:100%;
  }
}
.faq-item{
  margin-bottom:var(--spacing-md); 
  border-radius:var(--radius-md); 
  overflow:hidden;
  background: var(--glass);
  border:1px solid var(--glass-border);
  backdrop-filter: blur(20px); 
  -webkit-backdrop-filter: blur(20px);
  box-shadow: var(--shadow);
  transition: all var(--transition-normal);
}
.faq-item:hover{
  border-color: rgba(30,239,83,.25);
}
.faq-item.active{
  border-color: var(--accent);
  box-shadow: 0 8px 32px rgba(30,239,83,.2), var(--shadow);
}
.faq-question{
  padding:20px var(--spacing-lg); 
  cursor:pointer; font-weight:600; font-size:18px;
  display:flex; justify-content:space-between; align-items:center;
  transition: var(--transition-fast);
}
.faq-question:hover{
  background:rgba(255,255,255,0.08);
}
.faq-answer{
  padding:0 24px 20px; color:var(--muted); line-height:1.7;
  display:none;
}
.faq-item.active .faq-answer{
  display:block;
}
.faq-icon{
  font-size:20px; 
  transition: var(--transition-normal); 
  color:var(--accent);
}
.faq-item.active .faq-icon{
  transform: rotate(45deg);
}
@media (max-width: 640px){
  .faq-item{
    margin-bottom:12px;
    border-radius:14px;
  }
  .faq-question{
    padding:16px 18px;
    font-size:16px;
  }
  .faq-answer{
    padding:0 18px 16px;
    font-size:14px;
  }
  .faq-icon{
    font-size:18px;
  }
}

/* FOOTER */
.footer{
  padding:48px 24px; 
  text-align:center;
  border-top:1px solid rgba(255,255,255,0.1);
  color:var(--muted); 
  font-size:14px;
  width:100%;
  max-width:100vw;
  overflow:hidden;
  box-sizing:border-box;
}
.footer-logo{
  margin:0 auto 16px; display:flex; justify-content:center;
}
.footer-logo img{
  height:32px; width:auto; opacity:0.7;
}
@media (max-width: 640px){
  .footer{
    padding:32px 16px 100px;
    font-size:13px;
  }
  .footer-logo img{
    height:28px;
  }
}

/* 
 * Popup modal и floating button стили перенесены в /shared/shared.css
 */

