/* ===================================================
   MY COMPUTER ACADEMY — STYLESHEET v3
   =================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
button,a,[role="button"]{touch-action:manipulation;-webkit-tap-highlight-color:transparent}

:root {
  --color-primary:      #6C47FF;
  --color-primary-dark: #5533EE;
  --color-primary-light:#EEE9FF;
  --color-primary-mid:  #8B6FFF;
  --color-success:      #22C55E;
  --color-bg:           #FFFFFF;
  --color-bg-soft:      #F8F7FF;
  --color-border:       #E8E8F0;
  --color-text:         #0F0E1A;
  --color-text-2:       #6B6B80;
  --color-text-muted:   #9999AA;
  --dark-bg:            #0D0C1A;
  --dark-border:        rgba(255,255,255,.09);
  --font: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 24px; --r-full: 9999px;
  --sh-sm: 0 1px 3px rgba(108,71,255,.08);
  --sh-md: 0 4px 16px rgba(108,71,255,.12),0 2px 6px rgba(0,0,0,.05);
  --sh-lg: 0 10px 40px rgba(108,71,255,.16),0 4px 12px rgba(0,0,0,.06);
  --sh-xl: 0 20px 60px rgba(108,71,255,.18),0 8px 24px rgba(0,0,0,.08);
  --t: .2s ease; --ts: .4s ease;
}

html{scroll-behavior:smooth}
/* FIX 1: prevent horizontal overflow */
html,body{max-width:100%;overflow-x:hidden}
body{font-family:var(--font);font-size:16px;line-height:1.6;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}
.container{max-width:1160px;margin:0 auto;padding:0 24px;width:100%}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.gradient-text{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-mid));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font);font-weight:600;border:none;cursor:pointer;transition:all var(--t);text-decoration:none;white-space:nowrap;border-radius:var(--r-full)}
.btn--primary{background:var(--color-primary);color:#fff;box-shadow:0 4px 14px rgba(108,71,255,.4)}
.btn--primary:hover{background:var(--color-primary-dark);box-shadow:0 6px 20px rgba(108,71,255,.5);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--color-text);border:1.5px solid var(--color-border)}
.btn--ghost:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}
.btn--sm{font-size:14px;padding:9px 20px;min-height:44px}
.btn--lg{font-size:16px;padding:14px 28px}
.btn--full{width:100%;justify-content:center;border-radius:var(--r-md)}

/* ---------- SECTION COMMON ---------- */
.section-header{text-align:center;max-width:620px;margin:0 auto 56px}
.section-header--left{text-align:left;margin-left:0}
.section-badge{display:inline-block;background:var(--color-primary-light);color:var(--color-primary);font-size:13px;font-weight:600;padding:5px 14px;border-radius:var(--r-full);margin-bottom:16px;letter-spacing:.3px}
.section-title{font-size:clamp(26px,4vw,40px);font-weight:800;line-height:1.2;margin-bottom:14px}
.section-subtitle{font-size:16px;color:var(--color-text-2);line-height:1.7}

/* ===================================================
   HEADER
   =================================================== */
.header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid transparent;border-radius:0 0 16px 16px;transition:border-color var(--t),box-shadow var(--t)}
.header.scrolled{border-color:var(--color-border);box-shadow:0 4px 24px rgba(108,71,255,.08),0 1px 4px rgba(0,0,0,.04)}
.nav{display:flex;align-items:center;height:68px;gap:20px}
.nav__logo{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:500;flex-shrink:0;z-index:102;position:relative}
.nav__logo strong{font-weight:800}
.nav__menu{display:flex;list-style:none;gap:2px;margin-left:auto}
.nav__link{font-size:14px;font-weight:500;color:var(--color-text-2);padding:6px 12px;border-radius:var(--r-full);transition:all var(--t)}
.nav__link:hover{color:var(--color-primary);background:var(--color-primary-light)}

/* Courses dropdown */
.nav__has-dropdown{position:relative}
.nav__link--drop::after{content:'▾';margin-left:3px;font-size:10px;opacity:.7}
.nav__dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-6px);
  background:#fff;border:1px solid var(--color-border);border-radius:var(--r-lg);
  box-shadow:0 8px 30px rgba(108,71,255,.12),0 2px 8px rgba(0,0,0,.05);
  padding:6px;min-width:230px;z-index:200;
  opacity:0;pointer-events:none;transition:opacity .18s,transform .18s}
.nav__has-dropdown:hover .nav__dropdown,.nav__has-dropdown.open .nav__dropdown{
  opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav__dropdown a{display:flex;align-items:center;gap:10px;padding:9px 12px;
  border-radius:var(--r-md);font-size:13px;font-weight:500;color:var(--color-text-2);
  transition:all var(--t);white-space:nowrap}
.nav__dropdown a:hover{background:var(--color-primary-light);color:var(--color-primary)}
.nav__dropdown-emoji{font-size:17px;flex-shrink:0}

/* "Детальніше" ghost button on dark course cards */
.course-card__footer .btn--ghost-sm{
  font-size:13px;font-weight:600;color:rgba(255,255,255,.75);
  border:1.5px solid rgba(255,255,255,.22);border-radius:var(--r-full);
  padding:6px 14px;transition:all var(--t);white-space:nowrap;background:transparent;
  display:inline-block}
.course-card__footer .btn--ghost-sm:hover{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.4)}

.nav__actions{display:flex;align-items:center;gap:10px}
.nav__phone{font-size:14px;font-weight:500;color:var(--color-text-2);transition:color var(--t)}
.nav__phone:hover{color:var(--color-primary)}

/* Lang switcher */
.lang-switcher{display:flex;align-items:center;background:var(--color-bg-soft);border:1px solid var(--color-border);border-radius:var(--r-full);padding:3px}
.lang-btn{background:none;border:none;cursor:pointer;font-family:var(--font);font-size:12px;font-weight:700;color:var(--color-text-muted);padding:4px 10px;border-radius:var(--r-full);transition:all var(--t);letter-spacing:.5px}
.lang-btn.active{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px rgba(108,71,255,.35)}
.lang-divider{width:1px;height:14px;background:var(--color-border)}

.nav__burger{
  display:none;width:44px;height:44px;
  align-items:center;justify-content:center;
  background:var(--color-bg-soft);
  border:1.5px solid var(--color-border);
  border-radius:var(--r-md);cursor:pointer;
  margin-left:auto;flex-shrink:0;
  transition:background .25s,border-color .25s,box-shadow .25s;position:relative;z-index:102;
}
.nav__burger:hover{background:var(--color-primary-light);border-color:var(--color-primary)}
.nav__burger[aria-expanded="true"]{
  background:var(--color-primary);border-color:var(--color-primary);
  box-shadow:0 4px 16px rgba(108,71,255,.4);
}
.nav__burger span{
  display:block;position:absolute;
  width:20px;height:2px;
  background:var(--color-text);border-radius:2px;
  transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .2s,background .25s,width .2s;
}
.nav__burger span:nth-child(1){transform:translateY(-6px)}
.nav__burger span:nth-child(2){width:14px;transform:translateX(-3px)}
.nav__burger span:nth-child(3){transform:translateY(6px)}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(0) rotate(45deg);background:#fff;width:20px}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(0) rotate(-45deg);background:#fff;width:20px}

/* ===================================================
   HERO — FIX 3 + FIX 10
   =================================================== */
.hero{padding:90px 0 72px;position:relative;overflow:hidden;background:linear-gradient(155deg,#FDFCFF 0%,#EDE8FF 45%,#F5F3FF 100%)}
.hero__inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}

.hero__badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.9);border:1px solid var(--color-border);border-radius:var(--r-full);padding:6px 16px;font-size:13px;font-weight:500;color:var(--color-text-2);margin-bottom:24px;box-shadow:var(--sh-sm)}
.badge-dot{width:8px;height:8px;background:var(--color-success);border-radius:50%;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}
.hero__title{font-size:clamp(34px,5vw,56px);font-weight:900;line-height:1.1;letter-spacing:-.02em;margin-bottom:20px}
.hero__subtitle{font-size:17px;color:var(--color-text-2);line-height:1.7;max-width:480px;margin-bottom:32px}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.hero__trust{display:flex;flex-wrap:wrap;gap:16px}
.trust-item{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--color-text-2)}
.hero__mobile-stats{display:none}

/* Mockup — FIX 10: move up */
.hero__visual{transform:translateY(-16px)}
.mockup-window{background:#1A1A2E;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-xl);border:1px solid rgba(255,255,255,.08)}
.mockup-bar{display:flex;align-items:center;gap:8px;padding:14px 20px;background:#242435;border-bottom:1px solid rgba(255,255,255,.06)}
.dot{width:12px;height:12px;border-radius:50%}
.dot--red{background:#FF5F57}.dot--yellow{background:#FFBD2E}.dot--green{background:#28CA41}
.mockup-title{font-size:13px;color:#888899;margin-left:8px;font-family:'Courier New',monospace}
/* FIX 10: improved code contrast */
.mockup-code{padding:22px 24px 18px;font-family:'Courier New',Courier,monospace;font-size:14px;line-height:2.1}
.code-line{display:flex;gap:0;flex-wrap:nowrap;min-height:1.5em}.code-line.indent{padding-left:22px}
.c-keyword{color:#C792EA;font-weight:600}
.c-module {color:#82AAFF}
.c-func   {color:#82AAFF}
.c-var    {color:#C3E88D}
.c-num    {color:#F78C6C}
.c-op     {color:#89DDFF}
.c-punc   {color:#BFC7D5}
.c-comment{color:#7D8FA6;font-style:italic}
.code-cursor{width:2px;height:20px;background:var(--color-primary);margin-top:4px;animation:blink 1.2s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

.mockup-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.stat-card{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--color-border);border-radius:var(--r-lg);padding:14px 16px;box-shadow:var(--sh-sm)}
.stat-icon{font-size:22px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md)}
.stat-icon--purple{background:var(--color-primary-light)}.stat-icon--green{background:#E8FFF2}
.stat-value{font-size:22px;font-weight:800;line-height:1}
.stat-label{font-size:12px;color:var(--color-text-2);margin-top:2px}

.hero__bg-shapes{position:absolute;inset:0;pointer-events:none;z-index:0}
.hero__content,.hero__visual{position:relative;z-index:1}
.shape{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4}
.shape--1{width:500px;height:500px;background:radial-gradient(circle,#8B6FFF,transparent);top:-200px;right:-100px}
.shape--2{width:300px;height:300px;background:radial-gradient(circle,#FF6B35,transparent);bottom:-100px;left:-50px;opacity:.15}
.shape--3{width:200px;height:200px;background:radial-gradient(circle,#6C47FF,transparent);top:50%;left:45%;opacity:.12}

/* ===================================================
   PARTNERS
   =================================================== */
.partners{padding:36px 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}
.partners__label{text-align:center;font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:20px}
.partners__logos{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:32px}
.partner-logo{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--color-text-muted);transition:color var(--t)}
.partner-logo:hover{color:var(--color-primary)}
.partner-logo__icon{font-size:22px}

/* ===================================================
   BENEFITS — LIGHT (restored)
   =================================================== */
.benefits{padding:88px 0;background:var(--color-bg)}
.benefits__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

.benefit-card{background:var(--color-bg-soft);border:1px solid var(--color-border);border-radius:var(--r-xl);padding:32px 28px;transition:all var(--t)}
.benefit-card:hover{border-color:var(--color-primary);box-shadow:var(--sh-md);transform:translateY(-2px)}

/* Featured: premium gradient card */
.benefit-card--featured{background:linear-gradient(145deg,#6C47FF 0%,#7C5CFF 50%,#9B72FF 100%);border-color:transparent;position:relative;overflow:hidden;box-shadow:0 8px 32px rgba(108,71,255,.35),0 2px 8px rgba(108,71,255,.15)}
.benefit-card--featured::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.14) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.benefit-card--featured::after{content:'';position:absolute;bottom:-50px;left:-30px;width:160px;height:160px;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.benefit-card--featured:hover{background:linear-gradient(145deg,#5533EE 0%,#6C47FF 50%,#8B6FFF 100%);transform:translateY(-3px);box-shadow:0 16px 48px rgba(108,71,255,.5),0 4px 16px rgba(108,71,255,.25)}
.benefit-card--featured h3{color:#fff !important;font-weight:800;font-size:20px;margin-bottom:12px;position:relative;z-index:1}
.benefit-card--featured p{color:rgba(255,255,255,.85) !important;font-size:14.5px;line-height:1.65;position:relative;z-index:1}
.benefit-card__featured-badge{display:inline-flex;align-items:center;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);color:rgba(255,255,255,.95);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:4px 12px;border-radius:var(--r-full);margin-bottom:16px;position:relative;z-index:1}
.benefit-card__icon-wrap{width:52px;height:52px;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.28);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);position:relative;z-index:1;transition:background var(--t),transform var(--t)}
.benefit-card--featured:hover .benefit-card__icon-wrap{background:rgba(255,255,255,.22);transform:scale(1.04)}

.benefit-card__icon{font-size:32px;margin-bottom:16px;line-height:1}
.benefit-card h3{font-size:18px;font-weight:700;margin-bottom:10px;color:var(--color-text)}
.benefit-card p{font-size:14px;color:var(--color-text-2);line-height:1.7}

/* ===================================================
   FIX 9: COURSES — DARK PREMIUM
   =================================================== */
.courses{padding:88px 0;background:var(--dark-bg);position:relative;overflow:hidden}
.courses::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(108,71,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(108,71,255,.04) 1px,transparent 1px);background-size:48px 48px;pointer-events:none}
.courses::after{content:'';position:absolute;bottom:-200px;left:-100px;width:500px;height:500px;background:radial-gradient(ellipse,rgba(108,71,255,.12) 0%,transparent 70%);pointer-events:none}

.courses .section-header{position:relative;z-index:1}
.courses .section-badge{background:rgba(108,71,255,.18);color:#A78BFA;border:1px solid rgba(108,71,255,.3)}
.courses .section-title{color:#fff}
.courses .section-subtitle{color:rgba(255,255,255,.55)}

.courses__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;align-items:stretch;position:relative;z-index:1}

.course-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-xl);overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column}
.course-card:hover{box-shadow:0 20px 60px rgba(0,0,0,.5);transform:translateY(-4px);border-color:rgba(108,71,255,.5)}
.course-card--popular{border-color:rgba(108,71,255,.5);box-shadow:0 0 0 2px rgba(108,71,255,.15)}

.course-card__header{padding:28px 28px 22px}
.course-card__header--scratch{background:linear-gradient(135deg,rgba(255,152,0,.2),rgba(255,111,0,.12))}
.course-card__header--python {background:linear-gradient(135deg,rgba(33,150,243,.2),rgba(3,169,244,.12))}
.course-card__header--roblox {background:linear-gradient(135deg,rgba(76,175,80,.2),rgba(0,200,83,.12))}
.course-card__header--web    {background:linear-gradient(135deg,rgba(233,30,99,.2),rgba(156,39,176,.12))}

.course-card__header-row{display:flex;align-items:flex-start;justify-content:space-between}
.course-card__badges{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
/* Non-popular header: flex row */
.course-card__header:not(:has(.course-card__header-row)){display:flex;align-items:flex-start;justify-content:space-between}

.course-card__emoji{font-size:44px;line-height:1}
.popular-badge{background:var(--color-primary);color:#fff;font-size:12px;font-weight:700;padding:4px 12px;border-radius:var(--r-full);white-space:nowrap;box-shadow:0 2px 8px rgba(108,71,255,.5)}
.course-card__age-badge{background:rgba(255,255,255,.12);backdrop-filter:blur(4px);font-size:12px;font-weight:700;padding:5px 12px;border-radius:var(--r-full);color:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.15);white-space:nowrap}

.course-card__body{padding:22px 28px 26px;flex:1;display:flex;flex-direction:column}
.course-card__title{font-size:19px;font-weight:800;margin-bottom:10px;color:#fff}
.course-card__desc{font-size:14px;color:rgba(255,255,255,.55);line-height:1.7;margin-bottom:16px}
.course-card__features{list-style:none;display:flex;flex-direction:column;gap:7px;flex:1}
.course-card__features li{font-size:14px;font-weight:500;color:rgba(255,255,255,.8)}
.course-card__footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:20px;margin-top:auto;border-top:1px solid rgba(255,255,255,.08)}
.course-card__info{display:flex;flex-direction:column;gap:4px;font-size:13px;color:rgba(255,255,255,.45)}

/* ===================================================
   HOW IT WORKS
   =================================================== */
.how-it-works{padding:88px 0}
.steps{display:flex;align-items:flex-start}
.step{flex:1;text-align:center;padding:0 12px}
.step__connector{flex-shrink:0;width:60px;height:2px;background:linear-gradient(90deg,var(--color-primary-light),var(--color-primary));margin-top:36px;position:relative}
.step__connector::after{content:'';position:absolute;right:-6px;top:-5px;width:12px;height:12px;background:var(--color-primary);border-radius:50%}
.step__number{width:64px;height:64px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-mid));color:#fff;font-size:20px;font-weight:800;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 8px 24px rgba(108,71,255,.35)}
.step__content h3{font-size:16px;font-weight:700;margin-bottom:8px}
.step__content p{font-size:13px;color:var(--color-text-2);line-height:1.7}

/* ===================================================
   STATS
   =================================================== */
.stats{padding:88px 0;background:var(--dark-bg);position:relative;overflow:hidden}
.stats::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(108,71,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(108,71,255,.06) 1px,transparent 1px);background-size:48px 48px;pointer-events:none}
.stats::after{content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:600px;height:400px;background:radial-gradient(ellipse,rgba(108,71,255,.25) 0%,transparent 70%);pointer-events:none}

.stats__header{text-align:center;margin-bottom:48px;position:relative;z-index:1}
.stats__header .section-badge{background:rgba(108,71,255,.18);color:#A78BFA;border:1px solid rgba(108,71,255,.3)}
.stats__title{font-size:clamp(24px,4vw,36px);font-weight:800;color:#fff}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;position:relative;z-index:1}

.stats__card{background:rgba(255,255,255,.04);border:1px solid var(--dark-border);border-radius:var(--r-xl);padding:28px 22px 22px;transition:all .3s ease;position:relative;overflow:hidden;display:flex;flex-direction:column}
.stats__card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;border-radius:var(--r-xl) var(--r-xl) 0 0;opacity:0;transition:opacity .3s}
.stats__card:nth-child(1)::before{background:linear-gradient(90deg,#6C47FF,#8B6FFF)}
.stats__card:nth-child(2)::before{background:linear-gradient(90deg,#3B82F6,#60A5FA)}
.stats__card:nth-child(3)::before{background:linear-gradient(90deg,#22C55E,#4ADE80)}
.stats__card:nth-child(4)::before{background:linear-gradient(90deg,#F59E0B,#FCD34D)}
.stats__card:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.16);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.4)}
.stats__card:hover::before{opacity:1}
.stats__card-top{margin-bottom:16px}
.stats__card-icon{width:48px;height:48px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:22px}
.stats__card-icon--purple{background:rgba(108,71,255,.2)}
.stats__card-icon--blue  {background:rgba(59,130,246,.2)}
.stats__card-icon--green {background:rgba(34,197,94,.2)}
.stats__card-icon--orange{background:rgba(245,158,11,.2)}
.stats__card-body{flex:1;margin-bottom:16px}
.stats__card-number{display:flex;align-items:baseline;gap:2px;margin-bottom:6px}
.stats__number{font-size:48px;font-weight:900;line-height:1;background:linear-gradient(135deg,#fff,rgba(255,255,255,.75));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stats__unit{font-size:26px;font-weight:900;color:var(--color-primary-mid)}
.stats__card-label{font-size:15px;font-weight:700;color:#fff;margin-bottom:6px}
.stats__card-desc{font-size:12px;color:rgba(255,255,255,.4);line-height:1.6}
.stats__card-bar{height:4px;background:rgba(255,255,255,.08);border-radius:var(--r-full);overflow:hidden;margin-top:auto}
.stats__card-bar-fill{height:100%;border-radius:var(--r-full);background:linear-gradient(90deg,var(--color-primary),var(--color-primary-mid))}
.stats__card-bar-fill--green{background:linear-gradient(90deg,#22C55E,#4ADE80)}
.stats__card-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:auto}
.stats__card-tags span{font-size:10px;font-weight:600;background:rgba(108,71,255,.2);color:#A78BFA;border:1px solid rgba(108,71,255,.25);padding:3px 9px;border-radius:var(--r-full)}
.stats__card-stars{display:flex;gap:3px;margin-top:auto}
.stats__card-stars span{color:#F59E0B;font-size:17px}

/* ===================================================
   FIX 6: REVIEWS — slider on mobile
   =================================================== */
.reviews{padding:88px 0;background:var(--color-bg-soft)}
.reviews__track{overflow:hidden}
.reviews__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.review-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--r-xl);padding:26px;transition:all var(--t)}
.review-card:hover{box-shadow:var(--sh-md);border-color:var(--color-primary);transform:translateY(-2px)}
.review-card__stars{color:#FFB800;font-size:15px;letter-spacing:2px;margin-bottom:12px}
.review-card__text{font-size:14px;line-height:1.7;font-style:italic;margin-bottom:18px}
.review-card__author{display:flex;align-items:center;gap:12px}
.review-card__avatar{width:42px;height:42px;background:var(--color-primary-light);color:var(--color-primary);font-size:12px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.review-card__name{font-size:14px;font-weight:700}
.review-card__meta{font-size:12px;color:var(--color-text-muted);margin-top:2px}
.reviews__dots{display:none;justify-content:center;gap:6px;margin-top:16px}
.reviews__dot{width:8px;height:8px;background:var(--color-border);border-radius:50%;transition:all var(--t);cursor:pointer}
.reviews__dot.active{background:var(--color-primary);width:20px;border-radius:4px}

/* ===================================================
   FAQ
   =================================================== */
.faq{padding:88px 0}
.faq__inner{display:grid;grid-template-columns:1fr 2fr;gap:72px;align-items:start}
.faq__list{display:flex;flex-direction:column;gap:8px}
.faq-item{border:1px solid var(--color-border);border-radius:var(--r-lg);overflow:hidden;transition:border-color var(--t)}
.faq-item.active{border-color:var(--color-primary)}
.faq-item__question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:17px 20px;background:transparent;border:none;cursor:pointer;font-family:var(--font);font-size:14px;font-weight:600;text-align:left;transition:all var(--t)}
.faq-item__question:hover{background:var(--color-bg-soft)}
.faq-item.active .faq-item__question{background:var(--color-primary-light);color:var(--color-primary)}
.faq-item__icon{flex-shrink:0;transition:transform var(--t)}
.faq-item.active .faq-item__icon{transform:rotate(180deg)}
.faq-item__answer{max-height:0;overflow:hidden;transition:max-height var(--ts)}
.faq-item.active .faq-item__answer{max-height:200px}
.faq-item__answer p{padding:4px 20px 18px;font-size:13px;color:var(--color-text-2);line-height:1.7}

/* ===================================================
   FIX 7: CONTACT — grid-area layout, mobile separation
   =================================================== */
.contact{padding:32px 0 88px;background:var(--color-bg-soft)}
.contact__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-areas:"intro form" "details form";
  column-gap:72px;row-gap:40px;
  align-items:start;
}
.contact__intro{grid-area:intro}
.contact__form-wrap{grid-area:form}
.contact__details{grid-area:details}

.contact__title{font-size:clamp(26px,4vw,38px);font-weight:800;line-height:1.2;margin:8px 0 14px}

/* Contact details */
.contact__info-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-muted);margin-top:20px;margin-bottom:10px}
.contact__info-title:first-child{margin-top:0}
.contact__phones{display:flex;flex-direction:column;gap:10px}
.contact__phone-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.contact__phone-number{font-size:16px;font-weight:700;color:var(--color-text);transition:color var(--t)}
.contact__phone-number:hover{color:var(--color-primary)}
.contact__phone-links{display:flex;gap:6px}
.messenger-btn{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--t);color:#fff;flex-shrink:0}
.messenger-btn--viber   {background:#7360F2}
.messenger-btn--whatsapp{background:#25D366}
.messenger-btn--telegram{background:#0088CC}
.messenger-btn:hover{transform:scale(1.12);box-shadow:0 4px 12px rgba(0,0,0,.2)}
.contact__email{font-size:15px;font-weight:600;color:var(--color-primary);transition:color var(--t);word-break:break-all}
.contact__email:hover{color:var(--color-primary-dark);text-decoration:underline}
.contact__social{display:flex;gap:10px;margin-top:4px}
.contact__social-link{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--color-text-2);background:var(--color-bg);border:1px solid var(--color-border);padding:7px 14px;border-radius:var(--r-full);transition:all var(--t)}
.contact__social-link:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}

/* Form */
.contact-form{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--r-xl);padding:32px;box-shadow:var(--sh-md);width:100%;min-width:0;overflow:hidden}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{margin-bottom:16px;min-width:0}
.form-label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;letter-spacing:.2px}
/* FIX 1: inputs never overflow */
.form-input{display:block;width:100%;min-width:0;max-width:100%;padding:11px 14px;border:1.5px solid var(--color-border);border-radius:var(--r-md);font-family:var(--font);font-size:14px;color:var(--color-text);background:var(--color-bg);transition:border-color var(--t),box-shadow var(--t);outline:none;-webkit-appearance:none;appearance:none;box-sizing:border-box}
.form-input::placeholder{color:var(--color-text-muted)}
.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(108,71,255,.1)}
.form-select{cursor:pointer}
/* Submit button — allow text wrap on narrow screens */
.btn--full{white-space:normal;text-align:center;line-height:1.3}
.form-note{font-size:11px;color:var(--color-text-muted);text-align:center;margin-top:12px;line-height:1.5}
.form-note a{color:var(--color-primary)}
.form-success{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--r-xl);padding:44px 32px;text-align:center;box-shadow:var(--sh-md)}
.form-success__icon{font-size:52px;margin-bottom:14px}
.form-success h3{font-size:22px;font-weight:800;margin-bottom:10px}
.form-success p{font-size:14px;color:var(--color-text-2)}

/* ===================================================
   FOOTER
   =================================================== */
.footer{background:var(--color-text);color:rgba(255,255,255,.7);padding:56px 0 28px}
.footer__inner{display:grid;grid-template-columns:1fr 2fr;gap:48px;margin-bottom:40px}
.footer__logo span{color:#fff}
.footer__desc{font-size:13px;line-height:1.7;color:rgba(255,255,255,.45);margin-top:12px;max-width:240px}
.footer__social{display:flex;gap:8px;margin-top:18px}
.social-link{width:36px;height:36px;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.45);transition:all var(--t)}
.social-link:hover{border-color:var(--color-primary);color:var(--color-primary);background:rgba(108,71,255,.1)}
.footer__links{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.footer__col h4{font-size:12px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer__col a{font-size:13px;color:rgba(255,255,255,.45);transition:color var(--t)}
.footer__col a:hover{color:var(--color-primary-mid)}
.footer__payments{display:flex;align-items:center;gap:14px;padding:14px 0;border-top:1px solid rgba(255,255,255,.08);margin-top:4px;flex-wrap:wrap}
.footer__payments-label{font-size:12px;font-weight:600;color:rgba(255,255,255,.4);white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}
.footer__payment-icons{display:flex;gap:7px;flex-wrap:wrap}
.pay-badge{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:6px;padding:4px 10px;font-size:11px;font-weight:700;color:rgba(255,255,255,.6);white-space:nowrap;transition:border-color .2s}
.pay-badge:hover{border-color:rgba(108,71,255,.5);color:rgba(108,71,255,.9)}
.footer__bottom{padding-top:20px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:rgba(255,255,255,.3)}
.footer__bottom-left{display:flex;flex-direction:column;gap:6px}
.footer__bottom p{color:rgba(255,255,255,.3)}
.footer__bottom a{color:rgba(255,255,255,.3);transition:color var(--t)}
.footer__bottom a:hover{color:var(--color-primary-mid)}
.footer__fop{font-size:11px;color:rgba(255,255,255,.22)!important;line-height:1.6}
.footer__fop a{color:rgba(255,255,255,.22)!important}
.footer__fop a:hover{color:var(--color-primary-mid)!important}
/* SEO-only hidden text */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ===================================================
   FOOTER LEGAL LINKS
   =================================================== */
.footer__legal{
  display:flex;flex-wrap:wrap;gap:8px 20px;
  padding:16px 0;
  border-top:1px solid rgba(255,255,255,.08);
  margin-bottom:0;
}
.footer__legal a{
  font-size:12px;color:rgba(255,255,255,.35);
  transition:color var(--t);white-space:nowrap;
}
.footer__legal a:hover{color:var(--color-primary-mid)}
.footer__bottom-sep{color:rgba(255,255,255,.2);font-size:12px}

/* ===================================================
   COOKIE BANNER
   =================================================== */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:300;
  background:rgba(15,14,26,.97);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-top:1px solid rgba(255,255,255,.1);
  box-shadow:0 -8px 40px rgba(0,0,0,.4);
  animation:cookieSlideUp .4s cubic-bezier(.34,1.56,.64,1);
}
@keyframes cookieSlideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}

.cookie-banner__inner{
  max-width:1160px;margin:0 auto;padding:16px 24px;
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;flex-wrap:wrap;
}
.cookie-banner__text{
  display:flex;align-items:flex-start;gap:12px;flex:1;min-width:200px;
}
.cookie-banner__icon{color:#A78BFA;flex-shrink:0;margin-top:2px}
.cookie-banner__text p{
  font-size:13px;color:rgba(255,255,255,.7);line-height:1.5;
}
.cookie-banner__text strong{color:#fff;font-weight:600}
.cookie-banner__text a{
  color:#A78BFA;margin-left:4px;
  transition:color var(--t);text-decoration:underline;
}
.cookie-banner__text a:hover{color:#fff}
.cookie-banner__actions{display:flex;gap:10px;flex-shrink:0}

.cookie-btn{
  font-family:var(--font);font-size:13px;font-weight:600;
  padding:9px 18px;border-radius:var(--r-full);cursor:pointer;
  transition:all var(--t);white-space:nowrap;border:none;
}
.cookie-btn--primary{background:var(--color-primary);color:#fff;box-shadow:0 2px 10px rgba(108,71,255,.4)}
.cookie-btn--primary:hover{background:var(--color-primary-dark);transform:translateY(-1px)}
.cookie-btn--secondary{background:rgba(255,255,255,.1);color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.15)}
.cookie-btn--secondary:hover{background:rgba(255,255,255,.18);color:#fff}

@media(max-width:600px){
  .cookie-banner__inner{padding:14px 16px;gap:12px}
  .cookie-banner__text p{font-size:13px}
  .cookie-banner__actions{width:100%;justify-content:stretch}
  .cookie-btn{flex:1;text-align:center}
  .footer__legal{gap:6px 14px}
  .footer__legal a{font-size:11px}
}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;padding:13px 18px;border-radius:var(--r-lg);font-size:13px;font-weight:500;box-shadow:var(--sh-xl);transform:translateY(80px);opacity:0;transition:all .35s cubic-bezier(.34,1.56,.64,1);z-index:1000;max-width:300px}
.toast.show{transform:translateY(0);opacity:1}
.toast--success{background:#064E3B;color:#fff;border-left:4px solid var(--color-success)}
.toast--error  {background:#7F1D1D;color:#fff;border-left:4px solid #EF4444}

/* Animations */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up:nth-child(1){transition-delay:0s}
.fade-up:nth-child(2){transition-delay:.08s}
.fade-up:nth-child(3){transition-delay:.16s}
.fade-up:nth-child(4){transition-delay:.24s}
.fade-up:nth-child(5){transition-delay:.32s}
.fade-up:nth-child(6){transition-delay:.40s}

/* ===================================================
   RESPONSIVE — all mobile fixes
   =================================================== */
@media (max-width:1024px){
  .hero__inner{gap:40px}
  .benefits__bento{grid-template-columns:repeat(2,1fr)}
  .benefit-card--featured{grid-column:1/3;grid-row:auto}
  .faq__inner{grid-template-columns:1fr;gap:36px}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .contact__grid{grid-template-columns:1fr 1fr;grid-template-areas:"intro form" "details form"}
}

@media (max-width:768px){
  /* FIX 5: reduced section padding */
  .benefits,.courses,.how-it-works,.stats,.reviews,.faq,.contact{padding:56px 0}
  .partners{padding:28px 0}
  .hero{padding:90px 0 52px}

  /* Restored simple mobile menu */
  .nav__menu,
  .nav__actions .nav__cta,
  .nav__phone{display:none}
  .nav__burger{display:flex}

  .nav__menu.open{
    display:flex;flex-direction:column;
    position:fixed;top:68px;left:12px;right:12px;
    background:rgba(255,255,255,.97);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border:1.5px solid var(--color-border);
    border-radius:var(--r-xl);
    padding:12px 12px 16px;
    box-shadow:0 8px 40px rgba(108,71,255,.12),0 2px 12px rgba(0,0,0,.06);
    gap:2px;z-index:99;
    animation:menuDrop .22s cubic-bezier(.4,0,.2,1) both;
  }
  @keyframes menuDrop{
    from{opacity:0;transform:translateY(-6px) scale(.98)}
    to{opacity:1;transform:translateY(0) scale(1)}
  }
  .nav__menu.open .nav__link{
    font-size:15px;font-weight:500;color:var(--color-text-2);
    padding:11px 14px;border-radius:var(--r-md);
    display:block;transition:all var(--t);
  }
  .nav__menu.open .nav__link:hover{color:var(--color-primary);background:var(--color-primary-light)}
  .nav__menu.open li:last-child .nav__link{
    margin-top:6px;
    background:var(--color-primary);color:#fff;
    text-align:center;font-weight:700;
    border-radius:var(--r-full);
    box-shadow:0 4px 14px rgba(108,71,255,.4);
  }
  /* Dropdown inline in mobile menu */
  .nav__dropdown{
    position:static;transform:none!important;opacity:1;pointer-events:auto;
    box-shadow:none;border:none;background:transparent;
    padding:0 0 4px 8px;display:none
  }
  .nav__has-dropdown.open .nav__dropdown{display:block}
  .nav__dropdown a{font-size:14px;padding:7px 14px;color:var(--color-text-2)}
  .nav__link--drop::after{content:' ▾'}

  /* Hero */
  .hero__inner{grid-template-columns:1fr}
  .hero__visual{display:none}
  .hero{padding:90px 0 80px !important;background:linear-gradient(160deg,#FDFCFF 0%,#E4DAFF 18%,#EDE8FF 50%,#F5F3FF 100%)}
  .shape--1{width:300px;height:300px;top:-100px;right:-80px;opacity:.55}
  .hero__title{font-size:clamp(28px,8vw,40px)}
  .hero__subtitle{font-size:15px;max-width:100%}

  /* FIX 3: hero mobile trust as cards */
  .hero__trust{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .trust-item{background:rgba(255,255,255,.75);backdrop-filter:blur(8px);border:1px solid rgba(108,71,255,.15);border-radius:var(--r-md);padding:10px 12px;font-size:12px}
  .trust-item:last-child{grid-column:1/3}
  /* Mobile hero stats bar */
  .hero__mobile-stats{display:flex;align-items:center;justify-content:space-around;background:rgba(255,255,255,.82);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(108,71,255,.12);border-radius:var(--r-xl);padding:16px 20px;margin-top:20px;box-shadow:0 4px 24px rgba(108,71,255,.1)}
  .hero__mstat{text-align:center;flex:1}
  .hero__mstat-value{display:block;font-size:22px;font-weight:800;color:var(--color-primary);line-height:1;letter-spacing:-.02em}
  .hero__mstat-label{display:block;font-size:11px;color:var(--color-text-2);font-weight:500;margin-top:3px}
  .hero__mstat-sep{width:1px;height:36px;background:var(--color-border);flex-shrink:0}

  /* Benefits bento → 1 col */
  .benefits__bento{grid-template-columns:1fr}
  .benefit-card--featured{grid-column:1;grid-row:auto}
  .benefit-card--featured h3{font-size:18px;padding-top:0}
  .benefit-card__number{font-size:40px}
  .benefit-card--featured .benefit-card__number{font-size:52px}

  /* Courses */
  .courses__grid{grid-template-columns:1fr}

  /* Steps */
  .steps{flex-direction:column;align-items:flex-start;gap:20px}
  .step{text-align:left;display:flex;gap:14px;align-items:flex-start;padding:0}
  .step__number{margin:0;flex-shrink:0;width:48px;height:48px;font-size:16px}
  .step__connector{width:2px;height:32px;margin:0 0 0 23px;background:linear-gradient(180deg,var(--color-primary-light),var(--color-primary))}
  .step__connector::after{right:-5px;top:auto;bottom:-6px}

  /* Stats */
  .stats__grid{grid-template-columns:1fr 1fr;gap:12px}
  .stats__number{font-size:32px}
  .stats__unit{font-size:20px}
  .stats__card-label{font-size:14px}
  .step__number{width:44px;height:44px;font-size:14px}
  .step__content h3{font-size:15px}
  .step__content p{font-size:13px}

  /* FIX 6: Reviews slider on mobile */
  .reviews__track{overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin:0 -24px;padding:0 24px}
  .reviews__track::-webkit-scrollbar{display:none}
  .reviews__grid{display:flex;flex-wrap:nowrap;gap:14px;width:max-content;align-items:flex-start}
  .review-card{min-width:78vw;max-width:78vw;scroll-snap-align:start;flex-shrink:0;height:auto}
  .reviews__dots{display:flex}

  /* FAQ */
  .faq__inner{grid-template-columns:1fr;gap:28px}

  /* FIX 3: Contact grid stacked, details full-width */
  .contact__grid{
    display:flex;flex-direction:column;gap:24px;
  }
  .contact__details{
    background:var(--color-bg);
    border:1px solid var(--color-border);
    border-radius:var(--r-xl);
    padding:22px 20px;
    box-shadow:var(--sh-sm);
    width:100%;
    box-sizing:border-box;
    /* fix: no extra bottom margin */
    margin-bottom:0;
  }
  .contact__info-title:first-child{margin-top:0}
  /* Reduce contact section bottom padding on mobile + purple gradient */
  .contact{padding-bottom:36px;background:linear-gradient(160deg,#f8f7ff 0%,#ede9ff 40%,#ddd5ff 100%)}

  /* FIX 2: FAQ — reduce header bottom margin on mobile */
  .faq__inner .section-header{margin-bottom:20px}
  .faq{padding:44px 0}

  /* MOBILE-DESIGN: touch targets */
  /* messenger buttons: 32px → 44px touch area */
  .messenger-btn{width:44px;height:44px}
  .contact__phone-links{gap:6px}
  /* lang-btn: expand touch area */
  .lang-btn{padding:8px 12px;font-size:13px;min-height:44px}

  /* MOBILE-DESIGN: minimum font sizes on mobile */
  .stat-label{font-size:13px}
  .partners__label{font-size:13px}
  .stats__card-tags span{font-size:11px}
  .module-body p{font-size:13px}
  .info-compact-val{font-size:15px}

  /* Form row stacked on mobile */
  .form-row{grid-template-columns:1fr}
  .contact-form{padding:22px 16px}
  .modal__dialog{padding:24px 20px;max-height:95vh}

  /* Footer */
  .footer__inner{grid-template-columns:1fr;gap:32px}
  .footer__links{grid-template-columns:repeat(2,1fr)}
  .footer__bottom{flex-direction:column;gap:8px;text-align:center}
}

@media (max-width:480px){
  .container{padding:0 16px}  .hero{padding:80px 0 60px !important}  .hero__actions{flex-direction:column}
  .hero__actions .btn{width:100%;justify-content:center}
  .stats__grid{grid-template-columns:1fr}
  .footer__links{grid-template-columns:1fr}
  .partners__logos{gap:20px}
  .lang-switcher{display:none}
  .benefits__grid{grid-template-columns:1fr}
}

/* ===================================================
   MODAL — Fix 5
   =================================================== */
.modal{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;
}
.modal.open{opacity:1;pointer-events:all}

.modal__backdrop{
  position:absolute;inset:0;
  background:rgba(10,9,25,.65);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}

.modal__dialog{
  position:relative;z-index:1;
  background:#fff;
  border-radius:var(--r-xl);
  padding:36px;
  width:calc(100% - 48px);
  max-width:520px;
  max-height:90vh;
  overflow-y:auto;
  overscroll-behavior:contain;
  box-shadow:0 32px 80px rgba(0,0,0,.35),0 8px 24px rgba(108,71,255,.15);
  transform:translateY(24px) scale(.97);
  transition:transform .35s cubic-bezier(.34,1.56,.64,1);
  scrollbar-width:thin;
}
.modal.open .modal__dialog{transform:translateY(0) scale(1)}

.modal__close{
  position:absolute;top:16px;right:16px;
  background:var(--color-bg-soft);border:1px solid var(--color-border);
  border-radius:50%;width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--color-text-muted);
  transition:all var(--t);
}
.modal__close:hover{background:var(--color-border);color:var(--color-text)}

.modal__header{margin-bottom:24px}
.modal__badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--color-primary-light);color:var(--color-primary);
  font-size:12px;font-weight:600;padding:4px 12px;
  border-radius:var(--r-full);margin-bottom:12px;
}
.modal__title{font-size:22px;font-weight:800;margin-bottom:6px}
.modal__subtitle{font-size:14px;color:var(--color-text-2)}

/* Modal form shares .form-input/.form-label styles */
.modal-form .form-group{margin-bottom:14px}
.modal-success{padding:32px 24px}

/* Prevent body scroll when modal is open */
body.modal-open{overflow:hidden}

/* ===================================================
   SEO SECTION
   =================================================== */
.seo-section{padding:56px 0;background:var(--color-bg-soft);border-top:1px solid var(--color-border)}
.seo-section__title{font-size:clamp(18px,3vw,26px);font-weight:800;margin-bottom:16px;color:var(--color-text)}
.seo-section__inner p{font-size:14px;color:var(--color-text-2);line-height:1.8;margin-bottom:12px;max-width:780px}
.seo-section__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:32px}

.seo-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--r-lg);padding:20px 22px}
.seo-card h3{font-size:14px;font-weight:700;color:var(--color-text);margin-bottom:12px;line-height:1.3}
.seo-card ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.seo-card li{font-size:13px;color:var(--color-text-2);line-height:1.5}
.seo-card a{font-size:13px;color:var(--color-primary);transition:color var(--t)}
.seo-card a:hover{color:var(--color-primary-dark);text-decoration:underline}

@media (max-width:1024px){.seo-section__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px) {.seo-section__grid{grid-template-columns:1fr}}

/* ===================================================
   RESULT NOTIFICATION — submission feedback modal
   =================================================== */
.result-notify{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  z-index:9999;min-width:300px;max-width:calc(100vw - 32px);
  border-radius:16px;overflow:hidden;
  box-shadow:0 8px 40px rgba(0,0,0,.22);
  animation:notifyIn .35s cubic-bezier(.34,1.56,.64,1);
}
.result-notify--out{animation:notifyOut .3s ease forwards}
@keyframes notifyIn{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
@keyframes notifyOut{to{opacity:0;transform:translateX(-50%) translateY(16px)}}

.result-notify--success .result-notify__inner{background:#1a3a2a}
.result-notify--error   .result-notify__inner{background:#3a1a1a}

.result-notify__inner{
  display:flex;align-items:center;gap:14px;
  padding:16px 20px;
}
.result-notify__icon{font-size:28px;flex-shrink:0}
.result-notify__body{flex:1}
.result-notify__title{font-size:15px;font-weight:700;color:#fff;line-height:1.3}
.result-notify__sub{font-size:13px;color:rgba(255,255,255,.75);margin-top:3px;line-height:1.4}
.result-notify__close{
  background:none;border:none;color:rgba(255,255,255,.5);
  font-size:16px;cursor:pointer;padding:4px 6px;flex-shrink:0;
  border-radius:6px;transition:color .15s;
}
.result-notify__close:hover{color:#fff}

.result-notify__bar{height:3px;background:rgba(255,255,255,.15)}
.result-notify--success .result-notify__bar{background:rgba(255,255,255,.12)}
.result-notify--error   .result-notify__bar{background:rgba(255,255,255,.12)}
.result-notify__progress{height:100%;background:rgba(255,255,255,.5);width:100%}

@media(max-width:480px){
  .result-notify{bottom:16px;min-width:calc(100vw - 32px)}
}

/* ===================================================
   BENEFIT CARDS — compact on mobile
   =================================================== */
@media(max-width:768px){
  .benefit-card{
    display:flex;align-items:flex-start;gap:14px;
    padding:16px 18px;
    border-radius:var(--r-md);
  }
  .benefit-card__icon{font-size:24px;margin-bottom:0;flex-shrink:0;margin-top:2px}
  .benefit-card h3{font-size:15px;margin-bottom:4px}
  .benefit-card p{font-size:13px;line-height:1.5}
  .benefit-card--featured{display:flex;flex-direction:column;align-items:flex-start;gap:0;padding:22px 20px;border-radius:var(--r-lg)}
  .benefit-card--featured .benefit-card__icon-wrap{width:44px;height:44px;border-radius:12px;margin-bottom:12px}
}

/* ===================================================
   FORM FIELD VALIDATION ERRORS
   =================================================== */
.field-error{
  display:none;
  font-size:12px;color:#e53e3e;margin-top:5px;
  padding-left:2px;line-height:1.4;
}
.form-input--error{
  border-color:#e53e3e !important;
  box-shadow:0 0 0 3px rgba(229,62,62,.15) !important;
}
.form-input--error:focus{border-color:#e53e3e !important}

/* PHONE WRAP — code selector + input */
.phone-wrap{display:flex;gap:0;border-radius:var(--r-md);overflow:hidden;border:1.5px solid var(--color-border)}
.phone-wrap:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(108,71,255,.15)}
.phone-wrap .form-input{border:none !important;box-shadow:none !important;border-radius:0 !important}
.phone-code-sel{
  flex-shrink:0;width:auto;min-width:90px;max-width:108px;
  background:var(--color-bg-soft);border-right:1.5px solid var(--color-border) !important;
  border-radius:0 !important;padding:0 8px;font-size:13px;cursor:pointer;
}
.phone-wrap .form-input--error,
.phone-wrap:has(.form-input--error){border-color:#e53e3e !important;box-shadow:0 0 0 3px rgba(229,62,62,.15) !important}

/* NAV LOGO IMAGE */
.nav__logo-img{
  width:38px;height:38px;border-radius:50%;
  object-fit:cover;flex-shrink:0;
}
.nav__logo{display:flex;align-items:center;gap:10px}

/* ===================================================
   PRICING SECTION
   =================================================== */
.pricing{background:var(--color-bg-soft);padding:80px 0}
.pricing__header{text-align:center;margin-bottom:40px}
.pricing__title{font-size:clamp(28px,4vw,42px);font-weight:900;color:var(--color-text);margin-bottom:16px}
.pricing__meta{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:10px;max-width:900px;margin:0 auto;padding:0 8px}
.pricing__meta-left{color:var(--color-text-2);font-size:15px}
.pricing__meta-left strong{color:var(--color-primary)}
.pricing__meta-right{color:var(--color-text-muted);font-size:14px;max-width:420px;text-align:right}
.pricing__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

.pricing-card{background:#fff;border-radius:16px;padding:28px 24px;position:relative;display:flex;flex-direction:column;border:1.5px solid var(--color-border);transition:transform .2s,box-shadow .2s}
.pricing-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.pricing-card--featured{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),var(--sh-md)}
.pricing-card--featured:hover{box-shadow:0 0 0 1px var(--color-primary),var(--sh-lg)}
.pricing-card__badge{position:absolute;top:-1px;right:20px;background:#22C55E;color:#fff;font-size:11px;font-weight:800;padding:4px 12px;border-radius:0 0 8px 8px;text-transform:uppercase;letter-spacing:.6px}
.pricing-card--featured .pricing-card__badge{background:var(--color-primary)}
.pricing-card__title{font-size:18px;font-weight:800;color:var(--color-text);margin:12px 0 16px;line-height:1.3}
.pricing-card__features{list-style:none;margin-bottom:20px;flex:1}
.pricing-card__features li{display:flex;align-items:flex-start;gap:8px;font-size:14px;color:var(--color-text-2);margin-bottom:10px;line-height:1.5}
.pricing-card__features li::before{content:'★';color:#F0B429;flex-shrink:0;margin-top:1px}
.pricing-card__price{margin-bottom:18px;padding-top:14px;border-top:1px solid var(--color-border)}
.pricing-card__price-label{font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.pricing-card__price-val{font-size:24px;font-weight:900;color:var(--color-text);display:flex;align-items:baseline;flex-wrap:wrap;gap:5px}
.pricing-card__price-val span{font-size:13px;font-weight:500;color:var(--color-text-muted)}
.pricing-card__price-old{font-size:13px;color:#bbb;text-decoration:line-through;font-weight:400}
.pricing-card__btn{display:flex;align-items:center;justify-content:center;padding:13px 20px;background:var(--color-primary);color:#fff;font-size:15px;font-weight:700;border-radius:var(--r-full);cursor:pointer;border:none;font-family:var(--font);transition:all var(--t);text-decoration:none;margin-top:auto;box-shadow:0 4px 14px rgba(108,71,255,.35)}
.pricing-card__btn:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(108,71,255,.45)}

@media(max-width:900px){
  .pricing__grid{grid-template-columns:1fr 1fr}
  .pricing__meta-right{text-align:left}
  .pricing-card:nth-child(3){grid-column:1/-1;max-width:480px;margin:0 auto;width:100%}
}
@media(max-width:600px){
  .pricing{padding:56px 0}
  .pricing__grid{grid-template-columns:1fr}
  .pricing-card:nth-child(3){grid-column:auto;max-width:none}
}

/* ===================================================
   CERTIFICATE SECTION
   =================================================== */
.certificate-section{background:var(--dark-bg);padding:80px 0;border-top:1px solid rgba(255,255,255,.06)}
.cert-section__inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.cert-section__title{font-size:clamp(24px,3.5vw,36px);font-weight:800;color:#fff;margin-bottom:16px;line-height:1.2}
.cert-section__desc{color:rgba(255,255,255,.6);font-size:16px;line-height:1.7;margin-bottom:24px}
.cert-section__list{list-style:none;display:flex;flex-direction:column;gap:12px}
.cert-section__list li{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:rgba(255,255,255,.75)}
.cert-section__list li::before{content:'✓';background:#6C47FF;color:#fff;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;margin-top:1px}

.cert-section__cards{display:flex;justify-content:flex-start}
.cert-preview{border-radius:16px;padding:28px 24px;display:flex;flex-direction:column;gap:10px;border:1px solid rgba(255,255,255,.12);position:relative;overflow:hidden;max-width:340px;width:100%}
.cert-preview--silver{background:linear-gradient(135deg,#0f0f1f,#1e1e30);border-color:rgba(160,160,200,.25)}
.cert-preview__header{display:flex;align-items:center;gap:10px}
.cert-preview__seal{font-size:28px;flex-shrink:0}
.cert-preview__brand{font-size:13px;font-weight:700;color:rgba(255,255,255,.85);line-height:1.3}
.cert-preview__title-text{font-size:11px;color:rgba(255,255,255,.5);border-bottom:1px solid rgba(255,255,255,.15);padding-bottom:8px}
.cert-preview__lines{display:flex;flex-direction:column;gap:6px;flex:1}
.cert-preview__line{font-size:10px;color:rgba(255,255,255,.4);line-height:1.5}
.cert-preview__line--blank{height:14px;background:rgba(255,255,255,.08);border-radius:3px;margin-top:2px}
.cert-preview__footer{display:flex;justify-content:space-between;font-size:11px;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.5px;margin-top:auto;padding-top:8px;border-top:1px solid rgba(255,255,255,.1)}

@media(max-width:900px){
  .cert-section__inner{grid-template-columns:1fr;gap:36px}
  .cert-preview{max-width:100%}
}
@media(max-width:500px){
  .certificate-section{padding:56px 0}
}

/* ── ARTICLES SECTION ────────────────────────────────────────────────────────── */
.articles-section{padding:80px 0;background:#f8f7ff}
.articles-slider{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.article-card{display:flex;flex-direction:column;background:#fff;border-radius:20px;overflow:hidden;border:1.5px solid #e8e4ff;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s}
.article-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(108,71,255,.12)}
.article-card__top{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 0;gap:8px}
.article-card__emoji{font-size:32px;line-height:1}
.article-card__cat{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 10px;border-radius:20px;background:#f0eeff;color:#6C47FF}
.article-card__body{padding:16px 20px;flex:1}
.article-card__title{font-size:16px;font-weight:700;line-height:1.4;margin-bottom:10px;color:#1a1a2e}
.article-card__excerpt{font-size:13px;color:#666;line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.article-card__footer{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid #f0eeff}
.article-card__date{font-size:13px;color:#aaa}
.article-card__read{font-size:13px;font-weight:600;color:#6C47FF}
.articles-dots{display:none;justify-content:center;gap:6px;margin-top:20px}
.articles-dot{width:8px;height:8px;border-radius:50%;background:#c9bfff;cursor:pointer;transition:background .2s,transform .2s}
.articles-dot.active{background:#6C47FF;transform:scale(1.3)}

@media(max-width:900px){
  .articles-slider{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .articles-section{padding:56px 0}
  .articles-slider{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:16px;padding-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none;grid-template-columns:none}
  .articles-slider::-webkit-scrollbar{display:none}
  .article-card{scroll-snap-align:start;flex-shrink:0;width:300px}
  .articles-dots{display:flex}
}

/* ===================================================
   PYTHON COURSE FULL-WIDTH BLOCK
   =================================================== */
.python-course-block{display:grid;grid-template-columns:2fr 1fr;gap:48px;align-items:start;margin-top:40px}
.python-course-content{padding:24px;background:linear-gradient(135deg,rgba(108,71,255,.05),rgba(108,71,255,.02));border:1.5px solid rgba(108,71,255,.1);border-radius:20px}

/* Age tabs */
.age-tabs{display:flex;gap:8px;margin-bottom:28px;background:rgba(108,71,255,.06);border-radius:12px;padding:5px}
.age-tab{flex:1;padding:10px 8px;border:none;border-radius:9px;background:transparent;font-size:14px;font-weight:600;color:var(--color-text-2);cursor:pointer;transition:all .2s}
.age-tab:hover{color:var(--color-text)}
.age-tab.active{background:#fff;color:var(--color-primary);box-shadow:0 2px 8px rgba(108,71,255,.15)}

/* Age programs */
.age-program{display:none}
.age-program.active{display:block}

.program-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.program-emoji{font-size:36px;flex-shrink:0}
.program-title{font-size:20px;font-weight:800;color:#fff;margin-bottom:4px}
.program-sub{font-size:13px;color:rgba(255,255,255,.5)}

/* Module list — scrollable */
.modules-list{display:flex;flex-direction:column;gap:8px;max-height:380px;overflow-y:auto;padding-right:4px}
.modules-list::-webkit-scrollbar{width:4px}
.modules-list::-webkit-scrollbar-track{background:rgba(255,255,255,.05);border-radius:4px}
.modules-list::-webkit-scrollbar-thumb{background:rgba(108,71,255,.4);border-radius:4px}
.module-item{display:flex;align-items:flex-start;gap:14px;padding:11px 14px;background:rgba(255,255,255,.92);border-radius:10px;border:1px solid rgba(255,255,255,.15);transition:box-shadow .15s;flex-shrink:0}
.module-item:hover{box-shadow:0 4px 16px rgba(108,71,255,.18)}
.module-item--final{background:linear-gradient(135deg,rgba(108,71,255,.35),rgba(108,71,255,.2));border-color:rgba(108,71,255,.5)}
.module-num{min-width:28px;font-size:12px;font-weight:800;color:var(--color-primary);opacity:.8;padding-top:2px;flex-shrink:0}
.module-item--final .module-num{font-size:20px;opacity:1}
.module-body h4{font-size:14px;font-weight:700;color:var(--color-text);margin-bottom:2px}
.module-body p{font-size:12px;color:var(--color-text-2);line-height:1.5;margin:0}
.module-item--final .module-body h4{color:#fff}
.module-item--final .module-body p{color:rgba(255,255,255,.75)}

/* Right panel — compact info */
.python-course-info{display:flex;flex-direction:column;gap:16px}
.python-info-compact{background:#fff;border:1.5px solid var(--color-border);border-radius:16px;padding:24px;display:flex;flex-direction:column;gap:14px}
.info-compact-row{display:flex;align-items:center;gap:12px}
.info-compact-icon{font-size:22px;flex-shrink:0;width:36px;text-align:center}
.info-compact-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;color:var(--color-text-muted);letter-spacing:.4px;margin-bottom:2px}
.info-compact-val{display:block;font-size:14px;font-weight:600;color:var(--color-text)}

@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

@media(max-width:1024px){
  .python-course-block{grid-template-columns:1fr;gap:32px}
}
@media(max-width:600px){
  .python-course-block{gap:16px}
  .python-course-content{padding:16px}
  .python-info-compact{padding:16px}
  .age-tab{font-size:13px;padding:8px 4px}
}

/* ===================================================
   PAIN POINTS SECTION
   =================================================== */
.pain-points{display:none !important;}
.pain-points-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:48px}
.pain-point-card{padding:32px;background:linear-gradient(135deg,#fff,#f8f7ff);border:1.5px solid #e8e4ff;border-radius:16px;text-align:center;transition:transform .2s,box-shadow .2s}
.pain-point-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(108,71,255,.12)}
.pain-icon{font-size:40px;margin-bottom:16px;display:inline-block}
.pain-point-card h3{font-size:18px;font-weight:700;color:var(--color-text);margin-bottom:12px;line-height:1.3}
.pain-point-card p{font-size:14px;color:var(--color-text-2);line-height:1.6}

@media(max-width:768px){
  .pain-points{padding:56px 0}
  .pain-points-grid{grid-template-columns:1fr;gap:20px}
  .pain-point-card{padding:24px}
  .pain-icon{font-size:32px}
  .pain-point-card h3{font-size:16px}
}

/* ===================================================
   ENHANCED MOBILE HERO
   =================================================== */
@media(max-width:768px){
  .hero{padding:90px 0 80px !important}
  .hero__title{font-size:clamp(28px,6vw,36px);line-height:1.2}
  .hero__subtitle{font-size:15px;line-height:1.6;margin-bottom:24px}
  .hero__buttons{gap:12px}
  .hero-mockup{height:280px}
}
@media(max-width:480px){
  .hero{padding:80px 0 60px !important}
  .hero__title{font-size:clamp(24px,5vw,28px)}
  .hero__subtitle{font-size:14px;margin-bottom:20px}
  .hero-mockup{display:none}
  .btn--lg{padding:12px 20px;font-size:14px}
}

/* ===================================================
   PAGE LOADER
   =================================================== */
#page-loader{
  position:fixed;top:0;left:0;z-index:9999;
  width:0%;height:3px;
  background:linear-gradient(90deg,var(--color-primary),var(--color-primary-mid),#C084FC);
  transition:width .5s cubic-bezier(.4,0,.2,1);
  pointer-events:none;
  box-shadow:0 0 8px rgba(108,71,255,.6);
}
#page-loader.done{
  width:100%;
  opacity:0;
  transition:width .3s ease,opacity .35s ease .15s;
}

/* ===================================================
   SKELETON SCREENS
   =================================================== */
@keyframes skel-shimmer{
  0%{background-position:-800px 0}
  100%{background-position:800px 0}
}
.skel-block{
  display:block;
  background:linear-gradient(90deg,#eeeaff 0%,#ddd8ff 40%,#eeeaff 80%);
  background-size:1600px 100%;
  animation:skel-shimmer 1.6s ease-in-out infinite;
  border-radius:var(--r-sm);
}
.review-card--skel{
  pointer-events:none;
  box-shadow:none;
}
.review-card--skel .skel-avatar{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
}

/* ===================================================
   CONTENT-VISIBILITY — skip off-screen rendering
   =================================================== */
.benefits{content-visibility:auto;contain-intrinsic-size:0 560px}
.courses{content-visibility:auto;contain-intrinsic-size:0 900px}
.how-it-works{content-visibility:auto;contain-intrinsic-size:0 480px}
.stats{content-visibility:auto;contain-intrinsic-size:0 320px}
.reviews{content-visibility:auto;contain-intrinsic-size:0 480px}
.faq{content-visibility:auto;contain-intrinsic-size:0 640px}
.contact{content-visibility:auto;contain-intrinsic-size:0 680px}
