/* ==================== TOKENS ==================== */
:root {
  --brand:#2d4e9d;
  --brand-2:#4596d2;
  --text:#333333;
  --muted:#6b7280;
  --bg:#f6f8fb;
  --card:#ffffff;
  --border:#e6ebf2;
  --radius:12px;
  --shadow:0 10px 30px rgba(17,24,39,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;}
body{margin:0;padding:0}
body{
  font-family:"Hedvig Letters Sans",system-ui,-apple-system,Segoe UI,Roboto,Arial,Helvetica,sans-serif;
  color:var(--text);
  background:#fff;
  line-height:1.55;
}
/* ==================== /TOKENS ==================== */


/* ==================== TYPOGRAPHY ==================== */
h1{font-size:42px;line-height:1.15;margin:.6rem 0 1rem}
h2{font-size:46px;font-weight:600;margin:0 0 30px}
h3{font-weight:600;font-size:1.17em}
@media (max-width:720px){
  h1{font-size:32px}
  h2 {
    font-size: 38px
}
}
a{color:var(--brand);text-decoration:none}
a:hover{opacity:.9}
/* ==================== /TYPOGRAPHY ==================== */


/* ==================== UTILITIES ==================== */
.container{width:min(1180px,92%);margin-inline:auto}
.muted {
    color: var(--muted);
    font-size: 16px;
    font-style: italic;
}
.muted-autor {
    color: var(--muted);
    font-size: 18px;
    font-style: italic;
}
.bullets{padding-left:18px;margin:0}
.bullets li{margin:6px 0}
/* ==================== /UTILITIES ==================== */


/* ==================== HEADER ==================== */
.site-header{position:sticky;top:0;z-index:30;background:#fff;border-bottom:1px solid var(--border)}
.header-row{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:10px;padding:.45rem 0}
.logo img{display:block}
.docs-links{display:flex;align-items:center;justify-self:end;gap:18px;flex-wrap:wrap}
.doc-item{display:inline-flex;align-items:center;gap:10px;line-height:1.2}
.dot-link{position:relative}
.dot-link:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:0;border-bottom:1px dotted var(--brand)}
.docs-links>img{width:30px;height:30px;display:inline-block}

@media (max-width:1024px){
  .header-row{grid-template-columns:auto 1fr;align-items:start;padding:8px 0}
  .docs-links{
    justify-self:end;align-items:flex-end;display:flex;flex-direction:column;gap:4px;
    margin:4px 0 6px 0;padding:0 0 8px 0;border-bottom:1px solid var(--border)
  }
  .docs-links>img{display:none}
  .doc-item{display:block;line-height:1.2;padding:0;text-align:right}
  .doc-item span{font-size:15px;text-decoration:underline dotted var(--brand);text-underline-offset:4px;display:inline-block}
  .dot-link:after{display:none}
}
@media (max-width:720px){
  .header-row{grid-template-columns:1fr;align-items:start;gap:6px;padding:8px 0}
  .docs-links{
    width:100%;margin:6px 0 8px 0;padding:0 0 8px 0;border-bottom:1px solid var(--border);
    display:flex;flex-direction:column;gap:4px;justify-self:start;align-items:flex-start
  }
  .docs-links>img{display:none}
  .doc-item{display:block;line-height:1.25;padding:2px 0}
  .doc-item span{font-size:14px;text-decoration:underline dotted var(--brand);text-underline-offset:4px}
  .dot-link:after{display:none}
}
/* ==================== /HEADER ==================== */


/* ==================== HERO (перерисованный блок) ==================== */
.hero--v2{padding:28px 0 10px;background:transparent}
.hero-box{background:#e7f3ff;border-radius:20px;padding:48px 32px}
.badge{display:inline-flex;align-items:center;gap:8px;border-radius:999px;font-weight:600;font-size:.95rem;line-height:1.1}
.badge-plain{border:none;background:none;color:var(--brand)}
.badge-ico{display:block}
.hero--v2 .hero-text{max-width:1100px;margin-inline:auto}
.hero--v2 h1{color:#2d4e9d;font-weight:800;font-size:clamp(36px,6vw,84px);line-height:1;margin:10px 0 40px}
.hero-kicker{display:inline-flex;margin:0 0 22px;color:#2d4e9d}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:0}
.chip{display:inline-flex;align-items:center;gap:6px;padding:.38rem .6rem;border-radius:8px;font-weight:600;font-size:.85rem;border:1px solid var(--brand);background:#e7f3ff;color:var(--brand)}
.chip-outline{border:1px solid var(--brand);background:#e7f3ff;color:var(--brand)}
.hero--v2 .lead{color:#2d4e9d;font-size:clamp(16px,1.6vw,20px);max-width:68ch}
.hero--v2 .btn-ghost{border-color:#2d4e9d;color:#2d4e9d}
.hero--v2 .btn-ghost:hover{background:rgba(45,78,157,.06)}
.hero--v2 .btn-primary{background:#2d4e9d}

/* иконка внутри чипа */
.chip { display:inline-flex; align-items:center; gap:4px; }
.chip-ico { width:20px; height:20px; flex:0 0 auto; display:block; }

.chip--start .chip-ico { color:#2d4e9d; }   /* цвет иконки */


@media (max-width:1024px){
  .hero-box{padding:36px 24px}
}
@media (max-width:720px){
  .hero--v2 h1{font-size:clamp(28px,8vw,40px)}
  .hero-box{padding:30px 18px}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%}
}
/* ==================== /HERO (перерисованный блок) ==================== */


/* ==================== PROGRAM ==================== */
.program{padding:60px 0;background:#fff}
.accordion{display:grid;gap:12px;margin-top:16px}
.acc-item{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:28px 22px;box-shadow:var(--shadow)}
.acc-item summary{cursor:pointer;padding:0;list-style:none;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px}
.mod-prefix{color:var(--brand);margin-right:4px;white-space:nowrap}
.acc-item summary::-webkit-details-marker{display:none}
.acc-pad{padding-top:10px}
.acc-list{margin:0;padding:0;display:grid;row-gap:6px}
.acc-list li{list-style:none;display:grid;grid-template-columns:auto 1fr;column-gap:10px;align-items:start}
.acc-list .lesson{font-style:italic}
.acc-list li.control{color:var(--brand-2);font-weight:600;grid-template-columns:1fr}
.acc-list li.final{color:#156b3a;font-weight:700;grid-template-columns:1fr}

@media (max-width:720px){
  .acc-item summary{flex-wrap:wrap}
  .acc-item summary .mod-prefix{display:block;width:100%;margin:0 0 6px 0;white-space:nowrap}
}
/* ==================== /PROGRAM ==================== */


/* ==================== КОРОТКО О КУРСЕ (brief) ==================== */
.tv-brief{padding:60px 0;background:#fff;}
.tv-brief__container{width:min(1180px,92%);margin-inline:auto;}
.tv-brief__title{font-size:46px;font-weight:600;margin:0 0 12px;color:#333333;}
.tv-brief__subtitle{margin:0 0 24px;color:var(--muted);font-size:18px;}

.tv-brief__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:26px;
}

.brief-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  padding:20px 20px 40px 20px;
  box-shadow:var(--shadow);
}

.brief-ico{
  width:56px;height:56px;border-radius:12px;
  background:#e7f3ff;                /* нежный фон под иконку */
  color:#2d4e9d;                      /* цвет иконки */
  display:grid;place-items:center;
  margin-bottom:12px;
}

.brief-title {
    margin: 0 0 16px;
    font-weight: 600;
    font-size: 24px;
    color: #333333;
}

/* выравнивание булетов в brief */
.brief-list{ list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.brief-list li{
  display:grid;
  grid-template-columns: 20px 1fr;   /* колонка под иконку + текст */
  column-gap:10px;
  align-items:start;                 /* ориентируемся на первую строку */
  line-height:1.6;
}

/* сам маркер – оптически по центру первой строки */
.brief-list .check{
  width:18px; height:18px; color:#2d4e9d;
  align-self:start;
  margin-top:.25em;                  /* сдвиг, чтобы попасть в центр 1-й строки */
  flex:0 0 18px; display:block;
}

@media (max-width:1024px){
  .tv-brief__grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:720px){
  .tv-brief{padding:48px 0;}
  .tv-brief__grid{grid-template-columns:1fr;gap:18px;}
  .tv-brief__title{font-size:38px;margin-bottom:8px;}
}
/* ==================== /КОРОТКО О КУРСЕ (brief) ==================== */



/* ==================== FEATURES ==================== */
.features{padding:60px 0;background:var(--bg)}
.features h2{margin-top:0;text-align:left}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:22px}
.feature-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow)}
.feature-card .icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--brand-2));margin-bottom:10px}
.feature-icon{width:44px;height:44px;display:block;margin-bottom:10px}

@media (max-width:1024px){
  .feature-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .feature-grid{grid-template-columns:1fr}
}
/* ==================== /FEATURES ==================== */

/* --- PRICING (namespaced) --- */
.tv-pricing {
  padding: 56px 0;
  background: #ffffff;
}
.tv-pricing__container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}
.tv-pricing__title {
  font-size: 46px;
  line-height: 1.2;
  font-weight: 600;
  text-align: center;
  margin: 0 0 32px;
  color: #333333;
}
.tv-pricing__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
@media (min-width: 768px) {
  .tv-pricing__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .tv-pricing__grid { grid-template-columns: repeat(3, 1fr); }
}

.tv-price-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  border: 1px solid #e9edf3;           /* проектный бордер */
  border-radius: 20px;                  /* скругления как в задаче */
  background: #fff;
  padding: 28px;
  box-shadow: 0 1px 2px rgba(16, 24, 40, 0.04);
}
.tv-price-card--featured {
  box-shadow: 0 6px 20px rgba(16, 24, 40, 0.08);
}

.tv-price-card__head {
  text-align: center;
  margin-bottom: 16px;
}
.tv-price-card__name {
  margin: 0 0 8px;
  font-size: 32px;
  font-weight: 700;
  color: #333333;
}
.tv-price-card__price {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
}
.tv-price-card__amount {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: 0.2px;
  color: #333333;
}
.tv-price-card__currency {
  font-size: 24px;
  color: #0f172a;
}

.tv-price-card__list {
  list-style: none;
  margin: 16px 0 24px;
  padding: 0;
  display: grid;
  gap: 12px;
}
.tv-feature {
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 10px;
  align-items: start;
  font-size: 16px;
  line-height: 1.5;
  color: #1f2937;
}
.tv-feature__icon {
  width: 20px;
  height: 20px;
  color: #16a34a; /* зелёная галочка как в референсе */
}

.tv-price-card__cta {
  margin-top: auto;
}
.tv-btn {
  display: inline-flex;
  width: 100%;
  justify-content: center;
  align-items: center;
  gap: 8px;
  border-radius: 12px;
  padding: 14px 18px;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  transition: background-color .2s ease, box-shadow .2s ease, transform .02s ease;
}
.tv-btn--primary {
  color: #fff;
  background-color: #2d4e9d;          /* наш синий */
  box-shadow: 0 1px 0 rgba(0,0,0,.04), inset 0 -1px 0 rgba(0,0,0,.06);
}
.tv-btn--primary:hover { background-color: #274588; }
.tv-btn--primary:active { transform: translateY(1px); }
.tv-btn--primary:focus-visible {
  outline: 2px solid #2d4e9d;
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(45,78,157,.18);
}

/* --- PRICING tweaks --- */
/* уже существующие стили блока остаются; ниже — добавления/правки */

.tv-feature--disabled{
  color:#9ca3af;
  text-decoration: line-through;
}
.tv-feature--disabled .tv-feature__icon{
  color:#cbd5e1;
}

.tv-feature--disabled .tv-feature__addon-icon{
  color:#cbd5e1;
}

.tv-feature__addon-icon{
  width: 20px;
    height: 20px;
    color: #ff5e5e;
}



/* ==================== SPEAKERS ==================== */
.speakers{padding:60px 0;background:var(--bg)}
.author-card {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 22px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 20px 20px 40px 20px;
    box-shadow: var(--shadow);
    margin-bottom: 22px
}
.author-card img{border-radius:10px;object-fit:cover;width:100%;height:auto}
.speaker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.sp-card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 18px 18px 40px 18px;
    box-shadow: var(--shadow)
}
.sp-card img{width:100%;height:auto;border-radius:10px;margin-bottom:10px}
.sp-card h4 {
    margin: .3rem 0;
    font-weight: 600;
    font-size: 22px;
}

.author-card h3 {
    margin: .3rem 0;
    font-weight: 600;
    font-size: 26px;
}

@media (max-width:1024px){
  .author-card{grid-template-columns:1fr}
  .speaker-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .speaker-grid{grid-template-columns:1fr}
}

/* Author bullets – фиксируем штрих и цвет, чтобы глобальные стили не ломали SVG */
.author-list{
  list-style:none; margin:10px 0 0; padding:0; display:grid; gap:10px;
}
.author-list li{
  display:grid; grid-template-columns:24px 1fr; column-gap:10px;
  align-items:start; color:#333333; line-height:1.6;
}
.author-check{
  width:24px; height:24px; align-self:start; margin-top:.22em;
  /* защитимся от глобальных правил */
  stroke:#333333 !important; fill:none !important;
}
.author-check path{
  stroke:#333333 !important; fill:none !important;
  stroke-width:2; stroke-linecap:round; stroke-linejoin:round;
}

/* Speaker bullets — как у автора */
.speaker-list{
  list-style:none;
  margin:8px 0 0;
  padding:0;
  display:grid;
  gap:10px;
}
.speaker-list li{
  display:grid;
  grid-template-columns:24px 1fr;   /* колонка под иконку + текст */
  column-gap:10px;
  align-items:start;
  color:#333333;
  line-height:1.6;
}
.speaker-check{
  width:24px; height:24px;
  align-self:start;
  margin-top:.22em;                 /* выравниваем по 1-й строке текста */
  stroke:#333333 !important;
  fill:none !important;
}
.speaker-check path{
  stroke:#333333 !important;
  fill:none !important;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}


/* ==================== /SPEAKERS ==================== */


/* ==================== CTA ==================== */
.cta{padding:56px 0;background:#e7f3ff}
.cta-box{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;background:#e7f3ff;border:0;border-radius:12px;padding:22px;box-shadow:none}
.cta-box h2,.cta-box p{color:var(--brand)}

@media (max-width:720px){
  .cta-box{grid-template-columns:1fr;text-align:left}
}
/* ==================== /CTA ==================== */


/* ==================== FAQ (Q&A) — 2 колонки ==================== */
.tv-faq{padding:60px 0;background:#fff;}
.tv-faq__container{width:min(1180px,92%);margin-inline:auto;}
/* заголовок блока по гайдам */
.tv-faq__title{
  font-size:46px;font-weight:600;margin:0 0 30px;color:#333333;
}

/* две независимые колонки */
.tv-faq__cols{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px 40px;                 /* вертикальный и горизонтальный интервалы */
  border-top:1px solid var(--border);
  padding-top:22px;
}
.tv-faq__col{
  display:flex;
  flex-direction:column;
  gap:40px;                      /* ровный шаг между карточками внутри колонки */
}

/* карточка вопрос/ответ */
.tv-faq__item{
  display:flex;flex-direction:column;
  gap:8px;                       /* отступ между вопросом и ответом */
  margin:0;padding:0;
}

/* обнуление возможных внешних отступов из глобальных стилей */
.tv-faq__item > *{margin:0;padding:0;}

.tv-faq__q{
  font-weight:500;
  font-size:20px;
  line-height:1.35;
  color:#333333;                 /* цвет вопросов */
}
.tv-faq__a{
  color:var(--text);
  line-height:1.6;
}

/* мобильный: одна колонка */
@media (max-width:1024px){
  .tv-faq__cols{gap:14px 28px;}
}
@media (max-width:720px){
  .tv-faq__cols{grid-template-columns:1fr;gap:16px;}
  .tv-faq__title{font-size:38px;margin-bottom:24px;}
}
/* ==================== /FAQ (Q&A) ==================== */


/* ==================== CONTACT: Написать нам ==================== */

.section-title--center{
  text-align:center;
}

.contact-us{ padding:56px 0; background:#fff; }

.contact-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(240px,1fr));
  gap:40px;
  justify-items:center;
  align-items:start;
}

.contact-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:10px;
  text-decoration:none;
}

.contact-ico{
  width:80px; height:80px;
  border-radius:16px;
  background:#eef3f8;          
  display:grid; place-items:center;
  box-shadow: inset 0 0 0 1px #e6ebf2;
}

.contact-ico-t{
  width:70px; height:80px;
  border-radius:16px;
  background:#eef3f8;           
  display:grid; place-items:center;
  box-shadow: inset 0 0 0 1px #e6ebf2;
}

.ico-svg {
    width: 28px;
    height: 28px;
    color: #2d4e9d;
}

.ico-svg-tg {
    width: 35px;
    height: 35px;
    color: #2d4e9d;
}


.contact-ttl{
  font-weight:600;
  color:#333333;
  margin-top:6px;
  font-size: 24px;
}

.contact-link{
  color:#2d4e9d;
  font-weight:600;
  font-size: 20px; 
}

.contact-item:hover .contact-link{ opacity:.9; text-decoration:underline; }

@media (max-width: 720px){
  .contact-grid{ grid-template-columns:1fr; gap:28px; }
}



/* ==================== CONTACT ==================== */
.contact{padding:60px 0;background:var(--bg)}
.form-note-top{margin:0 0 10px;color:var(--muted);font-size:.95rem}
.contact-form{background:#fff;border:1px solid var(--border);border-radius:12px;padding:22px;box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.form-field{display:flex;flex-direction:column;gap:8px}
.form-field span{font-weight:600}
.form-field--full{grid-column:1/-1}
input,textarea{font:inherit;padding:.9rem 1rem;border:1px solid var(--border);border-radius:10px;outline:none;background:#fff;color:var(--text);transition:border-color .2s,box-shadow .2s}
input:hover,textarea:hover{border-color:var(--brand-2)}
input:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in srgb, var(--brand) 18%, transparent)}
.form-check{display:flex;align-items:center;gap:10px}
.form-actions{display:flex;align-items:center;gap:14px}
.form-actions .btn{padding:.9rem 4rem}

@media (max-width:1024px){
  .form-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .form-grid{grid-template-columns:1fr}
}
/* ==================== /CONTACT ==================== */


/* ==================== FOOTER ==================== */
.site-footer{padding:40px 0 60px;background:#0f172a;color:#d9e2f1}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:22px}
.site-footer .logo img{filter:brightness(0) invert(1)}
.ft-links{list-style:none;padding:0;margin:10px 0 0 0}
.ft-links li{margin:6px 0}
.ft-links a{color:#d9e2f1;text-decoration:none}
.ft-links a:hover{opacity:.9}

@media (max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .footer-grid{grid-template-columns:1fr;gap:16px;text-align:left}
}
/* ==================== /FOOTER ==================== */


/* ==================== VIDEO BLOCK ==================== */
.video-block{padding:60px 0;background:#fff}
.video-block h2{margin-bottom:16px}
.video-preview{position:relative;border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:16/9;cursor:pointer;isolation:isolate}
.video-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.video-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:84px;height:84px;border-radius:999px;border:0;display:grid;place-items:center;cursor:pointer;background:#2d4e9d;backdrop-filter:saturate(180%) blur(2px);transition:transform .2s ease,opacity .2s ease}
.video-play svg{width:38px;height:38px}
.video-preview:hover .video-play{transform:translate(-50%,-50%) scale(1.06);opacity:.95}
.video-play:focus{outline:3px solid color-mix(in srgb,#fff 50%, var(--brand))}
.video-modal{position:fixed;inset:0;display:none;z-index:1000;align-items:center;justify-content:center;padding:20px}
.video-modal.active{display:flex}
.video-modal__backdrop{position:absolute;inset:0;background:rgba(17,24,39,.6)}
.video-box{position:relative;z-index:1;width:min(1200px,92vw);aspect-ratio:16/9;background:#000;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.video-el{width:100%;height:100%;display:block;background:#000}
.video-close{position:absolute;top:8px;right:10px;width:36px;height:36px;border-radius:10px;border:0;cursor:pointer;color:#fff;background:rgba(255,255,255,.15);display:grid;place-items:center;font-size:22px;line-height:1}
.video-close:hover{background:rgba(255,255,255,.25)}
.no-scroll{overflow:hidden}

@media (max-width:1024px){
  .video-block{padding:48px 0}
  .video-play{width:76px;height:76px}
  .video-play svg{width:34px;height:34px}
}
@media (max-width:720px){
  .video-block{padding:40px 0}
  .video-play{width:68px;height:68px}
  .video-play svg{width:30px;height:30px}
}
/* ==================== /VIDEO BLOCK ==================== */
