/* ===== Палитра и базовые переменные «классического журнала» ===== */
:root{
  --ink:#1c1a17;          /* почти чёрный, тёплый */
  --paper:#f4efe6;        /* кремовая бумага */
  --paper-2:#ece4d6;      /* бумага потемнее для врезок */
  --accent:#8c2f1e;       /* приглушённый кирпично-красный */
  --rule:#c9bda8;         /* цвет тонких линеек */
  --muted:#6b6457;        /* серо-коричневый для подписей */
  --serif-display:"Playfair Display", Georgia, serif;
  --serif-body:"PT Serif", Georgia, serif;

  /* ===== Единая шкала размеров шрифта (всего 7 ступеней) ===== */
  --fs-hero:clamp(30px, 5vw, 52px);   /* заголовок в шапке (название журнала) */
  --fs-h1:clamp(26px, 3.4vw, 38px);   /* крупные заголовки статей */
  --fs-h2:clamp(20px, 2.4vw, 26px);   /* подзаголовки и крупные акценты */
  --fs-lead:21px;                     /* лид / курсивный подзаголовок */
  --fs-body:18px;                     /* основной текст */
  --fs-small:15px;                    /* подписи, мета, примечания */
  --fs-eyebrow:13px;                  /* мелкий капс: меню, надзаголовки */
  --fs-kicker:16px;                   /* рубрики-кикеры */
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serif-body);
  font-size:var(--fs-body);
  line-height:1.7;
  background-image:radial-gradient(circle at 20% 10%, rgba(255,255,255,.5), transparent 60%);
}

.page{max-width:1080px; margin:0 auto; padding:0 28px;}

/* ===== Кикеры/рубрики капсом ===== */
.kicker{
  font-family:var(--serif-body);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:var(--fs-kicker);   /* единый размер для всех рубрик-кикеров */
  color:var(--accent);
  margin:0 0 14px;
}
.kicker.muted{color:var(--muted);}

h1,h2,h3{font-family:var(--serif-display); font-weight:900; line-height:1.07; margin:0;}

/* ===== Шапка журнала (masthead) ===== */
.masthead{
  text-align:center;
  padding:34px 0 18px;
  border-bottom:3px double var(--ink);
}
.masthead .title{
  font-family:var(--serif-display);
  font-weight:900;
  font-size:var(--fs-hero);
  letter-spacing:.06em;
  line-height:.95;
  margin:0;
}
.masthead .title a{color:inherit; text-decoration:none;}
.masthead .sub{
  margin-top:14px;
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:var(--fs-small);
  color:var(--muted);
}
/* На телефоне шапку делаем компактнее, чтобы подзаголовок не ломался на много строк */
@media(max-width:720px){
  .masthead{padding:24px 0 14px;}
  .masthead .sub{
    margin-top:10px;
    letter-spacing:.08em;
    font-size:12px;
    line-height:1.6;
  }
}
/* в подвале каждая соцсеть — отдельной строкой (везде) */
.channels-list .ch{display:block; margin-bottom:8px;}
.channels-list .ch:last-child{margin-bottom:0;}

/* ===== Обложка ===== */
.cover{
  display:grid;
  grid-template-columns:520px 1fr;
  gap:44px;
  align-items:start;
  padding:56px 0 40px;
  border-bottom:1px solid var(--rule);
}
@media(max-width:720px){.cover{grid-template-columns:1fr;}}
.cover-photo{
  aspect-ratio:4/5;
  border-radius:2px;
  background:linear-gradient(160deg, #d8cab0 0%, #b59f80 55%, #7d6b52 100%);
  position:relative;
  overflow:hidden;
  box-shadow:0 18px 40px rgba(0,0,0,.18);
  display:flex; align-items:flex-end; justify-content:center;
}
.cover-photo.photo{background:#cdbfa6 center 18%/cover no-repeat;}
.cover-copy h1{font-size:var(--fs-h2); line-height:1.4; margin:6px 0 0; text-align:left;}
.cover-copy .dek{
  font-family:var(--serif-body);
  font-style:italic;
  font-size:var(--fs-lead);
  color:var(--ink);
  margin:22px 0 0;
  max-width:34ch;
}
.cover-topics{
  margin:26px 0 0;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:var(--fs-eyebrow);
  color:var(--muted);
  line-height:2;
  text-align:justify;
  text-align-last:left;
}
/* фразы-заявление на обложке: список с тонкими линейками-разделителями */
.cover-stmt{list-style:none; margin:6px 0 0; padding:0;}
.cover-stmt li{
  font-family:var(--serif-display); font-weight:700;
  font-size:clamp(16px,2vw,21px); line-height:1.35;
  padding:13px 0; border-bottom:1px solid var(--rule);
}
.cover-stmt li:last-child{border-bottom:none;}
/* вся тема — кликабельная; обычный текст чёрный, начало — бордовое */
.cover-stmt a{display:block; color:var(--ink); text-decoration:none; transition:opacity .15s ease;}
.cover-stmt a:hover{opacity:.7;}
.cover-stmt .accent{color:var(--accent);}
.cover-note{
  font-family:var(--serif-body); font-style:italic; color:var(--muted);
  font-size:var(--fs-small); line-height:1.55; margin:18px 0 0; max-width:42ch;
}

/* ===== Кнопки ===== */
.btn{
  display:inline-block;
  margin-top:26px;
  background:var(--accent);
  color:#fff;
  text-decoration:none;
  font-family:var(--serif-body);
  font-weight:700;
  letter-spacing:.04em;
  padding:14px 26px;
  border-radius:2px;
  transition:transform .15s ease, background .15s ease;
}
.btn:hover{background:#73271a; transform:translateY(-1px);}
.btn.ghost{background:transparent; color:var(--accent); border:1.5px solid var(--accent); margin-left:10px;}
.btn.ghost:hover{background:var(--accent); color:#fff;}
.btn.tg{background:#2a6f97;}
.btn.tg:hover{background:#1f5577;}

/* ===== Меню-навигация ===== */
.topnav{
  display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:10px 24px;
  padding:14px 0; border-bottom:1px solid var(--rule);
  text-transform:uppercase; letter-spacing:.16em; font-size:var(--fs-small); font-weight:700;
}
.topnav a{color:var(--muted); text-decoration:none;}
.topnav a:hover{color:var(--accent);}
.topnav a.now{color:var(--accent);}

/* ===== Содержание / карта сайта на главной ===== */
.toc{padding:40px 0; border-bottom:3px double var(--ink);}
.toc h2{font-size:var(--fs-kicker); text-transform:uppercase; letter-spacing:.22em; font-family:var(--serif-body); font-weight:700; color:var(--accent); margin-bottom:22px;}
.toc ol{list-style:none; margin:0; padding:0; column-count:2; column-gap:60px;}
.toc li{
  display:flex; justify-content:space-between; align-items:baseline; gap:10px;
  padding:9px 0; border-bottom:1px dotted var(--rule);
  break-inside:avoid;
}
.toc .t{font-family:var(--serif-display); font-weight:700; font-size:var(--fs-kicker);}
.toc .d{font-size:var(--fs-small); color:var(--muted); font-style:italic; text-align:right; flex:1;}
/* вариант со ссылками (карта страниц) */
.toc li.lnk{padding:0;}
.toc li.lnk a{display:flex; justify-content:space-between; align-items:baseline; gap:10px; width:100%; text-decoration:none; color:inherit; padding:9px 0;}
.toc li.lnk a:hover .t{color:var(--accent);}

/* ===== Статьи / рубрики ===== */
article{padding:54px 0; border-bottom:1px solid var(--rule);}
article .headline{font-size:var(--fs-h1); margin:6px 0 24px;}
article .dek{font-style:italic; font-size:var(--fs-lead); color:var(--muted); margin:18px 0 26px; max-width:46ch;}
.cols{column-count:2; column-gap:46px;}
.cols p{margin:0 0 16px;}
@media(max-width:720px){.cols{column-count:1;}}

/* буквица */
.dropcap p:first-of-type::first-letter{
  font-family:var(--serif-display); font-weight:900; float:left;
  font-size:78px; line-height:.72; padding:8px 12px 0 0; color:var(--accent);
}

ul.editorial{margin:8px 0 0; padding:0; list-style:none;}
ul.editorial li{position:relative; padding-left:26px; margin:0 0 14px;}
ul.editorial li::before{content:"§"; position:absolute; left:0; top:0; color:var(--accent); font-family:var(--serif-display); font-weight:700;}
ul.editorial.two{columns:2; column-gap:46px;}
@media(max-width:720px){ul.editorial.two{columns:1;}}
ul.editorial.two li{break-inside:avoid;}

/* выносная цитата */
blockquote.pull{
  margin:34px 0; padding:26px 30px;
  border-top:2px solid var(--ink); border-bottom:2px solid var(--ink);
  font-family:var(--serif-display); font-style:italic;
  font-size:calc(var(--fs-h1) - 8px); line-height:1.25; text-align:center;
}
blockquote.pull cite{display:block; margin-top:16px; font-family:var(--serif-body); font-style:normal; text-transform:uppercase; letter-spacing:.18em; font-size:var(--fs-eyebrow); color:var(--muted);}

/* врезка */
.sidebar{
  background:var(--paper-2); border-left:4px solid var(--accent);
  padding:18px 22px; margin:26px 0 0; font-size:var(--fs-small); font-style:italic; color:var(--muted);
}

/* плашка «узнаёте себя» */
.callout{background:var(--ink); color:var(--paper); padding:26px 30px; margin:30px 0 0; border-radius:2px;}
.callout .kicker{color:#e6b9a7;}
.callout p{margin:0;}

/* ===== Спецраздел для руководителей ===== */
.leaders{background:var(--paper-2); border-top:3px double var(--ink); border-bottom:3px double var(--ink); padding-left:22px; padding-right:22px;}
.checkup{display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin:24px 0 0;}
@media(max-width:720px){.checkup{grid-template-columns:1fr;}}
.checkup .item{background:var(--paper); border:1px solid var(--rule); padding:16px 18px; border-radius:2px;}
.checkup .item b{display:block; font-family:var(--serif-display); font-size:var(--fs-eyebrow); text-transform:uppercase; letter-spacing:.12em; color:var(--accent); margin-bottom:6px;}
.checkup .item span{font-size:var(--fs-small);}

/* ===== Шаги ===== */
.steps{counter-reset:step; display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:24px;}
@media(max-width:720px){.steps{grid-template-columns:1fr;}}
.steps .step{position:relative; padding-top:54px;}
.steps .step::before{
  counter-increment:step; content:counter(step);
  position:absolute; top:0; left:0;
  font-family:var(--serif-display); font-weight:900; font-size:46px; color:var(--accent); line-height:1;
}
.steps .step b{font-family:var(--serif-display);}

/* ===== Цены ===== */
.price{display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:24px;}
@media(max-width:720px){.price{grid-template-columns:1fr;}}
.price .card{background:var(--paper-2); border:1px solid var(--rule); padding:20px 22px; border-radius:2px;}
.price .card h3{font-family:var(--serif-display); font-size:var(--fs-lead); margin:0 0 8px;}
.price .card .meta{font-size:var(--fs-small); color:var(--muted); font-style:italic; margin:0 0 12px;}
.price .card .sum{font-family:var(--serif-display); font-weight:900; font-size:var(--fs-h2); color:var(--accent);}

/* ===== Колофон ===== */
/* объединённый блок: слева «Я пишу» + соцсети, справа кнопка */
.readme-contact{
  display:grid; grid-template-columns:1fr auto; column-gap:48px; align-items:center;
  padding:36px 0 54px; border-top:3px double var(--ink);
}
.readme-contact .kicker{margin-bottom:10px;}
.readme-contact .headline{margin:0 0 12px;}
.readme-contact p{margin:0 0 10px; max-width:52ch;}
.readme-contact .rc-right{justify-self:end;}
@media(max-width:720px){
  .readme-contact{grid-template-columns:1fr; row-gap:22px;}
  .readme-contact .rc-right{justify-self:start;}
}

/* футер «Связаться» — две колонки: слева подпись+заголовок, справа кнопка+соцсети */
.colophon{
  display:grid; grid-template-columns:1fr 1fr;
  column-gap:48px; row-gap:6px; align-items:center;
  text-align:left; padding:30px 0 44px;
  max-width:760px; margin:0 auto;
}
.colophon .kicker{grid-column:1; grid-row:1; align-self:end; margin:0;
  font-size:var(--fs-kicker); letter-spacing:.14em;}
.colophon .headline{grid-column:1; grid-row:2; align-self:start;}
.colophon > div{grid-column:2; grid-row:1; align-self:end; justify-self:start; margin:0 !important;}
.colophon .channels{grid-column:2; grid-row:2; align-self:start; justify-self:start; margin:0; max-width:none;
  font-family:var(--serif-body); font-weight:700; text-transform:uppercase;
  font-size:var(--fs-kicker); letter-spacing:.14em;}
.colophon form.ask{grid-column:1 / -1; grid-row:3; margin:18px auto 0;}
@media(max-width:720px){
  .colophon{grid-template-columns:1fr; text-align:center; justify-items:center;}
  .colophon .kicker,.colophon .headline,.colophon > div,.colophon .channels{grid-column:1; grid-row:auto; justify-self:center; align-self:auto;}
}
form.ask{margin:26px auto 0; max-width:460px; display:grid; gap:12px;}
form.ask input, form.ask textarea{
  font-family:var(--serif-body); font-size:var(--fs-body); padding:12px 14px;
  border:1px solid var(--rule); background:#fff; border-radius:2px; width:100%;
}
.channels{margin:20px 0 0; font-weight:700; letter-spacing:.1em; text-transform:uppercase; font-size:var(--fs-eyebrow); color:var(--muted);}
.divider-note{font-size:var(--fs-small); color:var(--muted); text-align:center; padding:30px 0; font-style:italic;}

/* фото автора рядом с колонкой */
.editorial-grid{display:grid; grid-template-columns:300px 1fr; gap:36px; align-items:start; margin-top:6px;}
@media(max-width:720px){.editorial-grid{grid-template-columns:1fr;}}
.author-photo{margin:0;}
.author-photo img{
  width:100%; height:auto; display:block; border-radius:2px;
  aspect-ratio:4/5; object-fit:cover; object-position:center 18%;
  box-shadow:0 14px 32px rgba(0,0,0,.17);
}
.author-photo figcaption{font-size:var(--fs-small); color:var(--muted); font-style:italic; margin-top:10px; text-align:center;}

/* «стена дипломов» */
.diplomas{display:flex; flex-wrap:wrap; gap:14px; margin-top:24px;}
.diplomas a{display:block; line-height:0;}
.diplomas img{
  height:200px; width:auto; display:block; background:#fff;
  border:1px solid var(--rule); border-radius:2px; box-shadow:0 6px 16px rgba(0,0,0,.10);
  transition:transform .15s ease, box-shadow .15s ease;
}
.diplomas a:hover img{transform:translateY(-2px); box-shadow:0 12px 26px rgba(0,0,0,.18);}
@media(max-width:720px){.diplomas img{height:140px;}}

/* таймлайн образования */
.edu{margin:26px 0 0; padding:0; list-style:none;}
.edu li{display:grid; grid-template-columns:108px 1fr; gap:18px; padding:14px 0; border-bottom:1px dotted var(--rule); break-inside:avoid;}
.edu .yr{font-family:var(--serif-display); font-weight:900; color:var(--accent); font-size:var(--fs-body);}
.edu .pl{font-family:var(--serif-display); font-weight:700; font-size:var(--fs-body);}
.edu .ds{display:block; font-size:var(--fs-small); color:var(--muted); font-style:italic; margin-top:3px;}
@media(max-width:720px){.edu li{grid-template-columns:74px 1fr; gap:12px;}}
