/* =====================================================
   severny-kipr.ru — REDESIGN 2.0
   Стиль: современный, воздушный, природа + премиум
   ===================================================== */
:root {
  --bg:      #f0f2ed;      /* светлый фон */
  --bg2:     #e8ebe3;      /* чуть темнее фон */
  --ink:     #1a1f4a;      /* тёмно-синий */
  --ink2:    #2d3363;      /* синий светлее */
  --sea:     #2d6a9f;      /* синий */
  --gold:    #c8a84b;      /* золотой акцент */
  --gold2:   #e6c96a;
  --green:   #5a8a5a;      /* природный зелёный */
  --green2:  #7ab050;
  --white:   #ffffff;
  --text:    #2c3040;
  --muted:   #7a8090;
  --border:  rgba(26,31,74,.1);
  --r:       16px;         /* скругление */
  --r-sm:    10px;
  --shadow:  0 4px 24px rgba(26,31,74,.08);
  --shadow2: 0 12px 48px rgba(26,31,74,.14);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Raleway', sans-serif;
  font-weight: 400;
  color: var(--text);
  background: var(--bg);
  line-height: 1.6;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--sea); text-decoration: none; transition: color .2s; }
a:hover { color: var(--gold); }

/* ---- TYPOGRAPHY ---- */
h1,h2,h3,h4 {
  font-family: 'Raleway', sans-serif;
  font-weight: 800;
  line-height: 1.15;
  color: var(--ink);
  letter-spacing: -.02em;
}
h1 { font-size: clamp(32px,5vw,60px); }
h2 { font-size: clamp(26px,3.5vw,42px); }
h3 { font-size: clamp(20px,2.5vw,28px); }
h4 { font-size: 18px; }
p  { line-height: 1.75; }

.serif { font-family: 'Playfair Display', serif; }
.upper { text-transform: uppercase; letter-spacing: .1em; font-size: .75em; font-weight: 700; }
.muted { color: var(--muted); }

/* ---- LAYOUT ---- */
.container { max-width: 1160px; margin: 0 auto; padding: 0 24px; }
.section    { padding: 96px 0; }
.section-sm { padding: 56px 0; }

/* ---- BUTTONS ---- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 28px; border-radius: 50px;
  font-family: 'Raleway', sans-serif;
  font-size: 14px; font-weight: 700;
  letter-spacing: .02em;
  cursor: pointer; transition: all .25s;
  border: 2px solid transparent; text-decoration: none;
}
.btn-gold { background: var(--gold); color: var(--ink); }
.btn-gold:hover { background: var(--gold2); color: var(--ink); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(200,168,75,.35); }
.btn-dark { background: var(--ink); color: var(--white); }
.btn-dark:hover { background: var(--ink2); color: var(--white); transform: translateY(-2px); }
.btn-outline { background: transparent; color: var(--white); border-color: rgba(255,255,255,.4); }
.btn-outline:hover { border-color: var(--white); color: var(--white); background: rgba(255,255,255,.1); }
.btn-outline-dark { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn-outline-dark:hover { background: var(--ink); color: var(--white); }
.btn-lg { padding: 17px 36px; font-size: 15px; }
.btn-sm { padding: 9px 20px; font-size: 12px; }
.btn-green { background: var(--green2); color: var(--white); }
.btn-green:hover { background: var(--green); color: var(--white); transform: translateY(-2px); }

/* ---- TAGS ---- */
.tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 6px 14px; border-radius: 50px;
}
.tag-gold  { background: rgba(200,168,75,.12); color: var(--gold); border: 1px solid rgba(200,168,75,.3); }
.tag-sea   { background: rgba(45,106,159,.1);  color: var(--sea);  border: 1px solid rgba(45,106,159,.2); }
.tag-green { background: rgba(90,138,90,.1);   color: var(--green);border: 1px solid rgba(90,138,90,.2); }
.tag-dark  { background: var(--ink); color: var(--white); }

/* ---- DIVIDER ---- */
.gold-line { width: 40px; height: 3px; background: var(--gold); border-radius: 2px; margin: 14px 0 22px; }
.gold-line.center { margin: 14px auto 22px; }

/* ---- HEADER ---- */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  padding: 12px 0;
  transition: all .3s;
}
.site-header.scrolled {
  background: rgba(20,25,55,.94);
  backdrop-filter: blur(20px);
  box-shadow: 0 2px 32px rgba(26,31,74,.3);
}
.header-inner {
  display: flex; align-items: center;
  justify-content: space-between;
  height: 56px; padding: 0 32px;
  max-width: 1280px; margin: 0 auto;
}
.logo {
  font-family: 'Raleway', sans-serif;
  font-size: 18px; font-weight: 900;
  color: var(--white); text-decoration: none;
  letter-spacing: -.02em;
  transition: color .3s;
}
.logo.dark { color: var(--ink); }
.logo span { color: var(--gold); }
.logo small {
  display: block; font-family: 'Raleway', sans-serif;
  font-size: 10px; font-weight: 500;
  letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.5); margin-top: 1px;
  transition: color .3s;
}
.logo.dark small { color: var(--muted); }
.nav { display: flex; align-items: center; gap: 6px; }
.nav a {
  color: rgba(255,255,255,.75);
  font-size: 13px; font-weight: 600;
  letter-spacing: .02em;
  text-decoration: none; transition: color .2s;
  padding: 8px 12px; border-radius: 8px;
}
.nav a:hover { color: var(--white); background: rgba(255,255,255,.1); }
.nav a.active { color: var(--gold); }
.nav.dark a { color: var(--muted); }
.nav.dark a:hover { color: var(--ink); background: rgba(26,31,74,.06); }
.nav-cta {
  background: var(--gold) !important;
  color: var(--ink) !important;
  border-radius: 50px !important;
  padding: 10px 20px !important;
  font-weight: 700 !important;
}
.nav-cta:hover { background: var(--gold2) !important; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(200,168,75,.4) !important; }
.burger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 4px; }
.burger span { display: block; width: 22px; height: 2px; background: var(--white); border-radius: 2px; transition: background .3s; }
.burger.dark span { background: var(--ink); }
/* Шапка при скролле - тёмный полупрозрачный фон */
.site-header.scrolled {
  background: rgba(26,31,74,.97) !important;
  backdrop-filter: blur(16px);
  box-shadow: 0 2px 24px rgba(26,31,74,.2);
}
.site-header.scrolled .logo { color: var(--white) !important; }
.site-header.scrolled .logo small { color: rgba(255,255,255,.5) !important; }
.site-header.scrolled .nav a { color: rgba(255,255,255,.75) !important; }
.site-header.scrolled .nav a:hover { color: var(--white) !important; background: rgba(255,255,255,.1) !important; }
.site-header.scrolled .nav-cta { color: var(--ink) !important; background: var(--gold) !important; }
.site-header.scrolled .burger span { background: var(--white) !important; }

/* ---- FOOTER ---- */
.site-footer { background: var(--ink); color: rgba(255,255,255,.55); padding: 72px 0 32px; margin-top: 0; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 56px; }
.footer-brand .logo { font-size: 20px; color: var(--white) !important; }
.footer-brand .logo small { color: rgba(255,255,255,.4) !important; }
.footer-brand p { font-size: 13px; line-height: 1.7; color: rgba(255,255,255,.4); margin-top: 16px; max-width: 260px; }
.footer-col h4 { font-family: 'Raleway', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); margin-bottom: 18px; }
.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: 10px; }
.footer-col a { color: rgba(255,255,255,.45); font-size: 13px; transition: color .2s; }
.footer-col a:hover { color: var(--gold); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.07); padding-top: 24px; display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: rgba(255,255,255,.3); }

/* ---- CARDS ---- */
.card {
  background: var(--white);
  border-radius: var(--r);
  overflow: hidden;
  transition: transform .25s, box-shadow .25s;
  box-shadow: var(--shadow);
}
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow2); }
.card-body { padding: 28px; }

/* ---- SECTION HEADER ---- */
.section-header { margin-bottom: 56px; }
.section-header.center { text-align: center; }
.section-header .tag { margin-bottom: 14px; }

/* ---- BREADCRUMB ---- */
.breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--muted); margin-bottom: 32px; flex-wrap: wrap; }
.breadcrumb a { color: var(--muted); }
.breadcrumb a:hover { color: var(--sea); }
.breadcrumb span { opacity: .4; }

/* ---- FORM ---- */
.form-group { margin-bottom: 18px; }
.form-group label { display: block; font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
.form-group input, .form-group select, .form-group textarea {
  width: 100%; padding: 13px 18px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  font-family: 'Raleway', sans-serif;
  font-size: 15px; color: var(--text);
  background: var(--bg);
  transition: border-color .2s, background .2s;
  outline: none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--sea); background: var(--white); }
.form-group textarea { resize: vertical; min-height: 120px; }
.form-note { font-size: 12px; color: var(--muted); margin-top: 8px; line-height: 1.5; }

/* ---- PAGE HERO (подстраницы) ---- */
.page-hero { background: var(--ink); padding: 120px 24px 64px; border-bottom: none; border-radius: 0 0 32px 32px; }
.page-hero h1 { color: var(--white); margin-bottom: 12px; }
.page-hero p { color: rgba(255,255,255,.65); font-size: 17px; max-width: 580px; line-height: 1.7; }

/* ---- CTA SECTION ---- */
.cta-section { background: var(--ink); border-radius: 32px; padding: 72px 48px; text-align: center; }
.cta-section h2 { color: var(--white); margin-bottom: 16px; }
.cta-section p { font-size: 17px; color: rgba(255,255,255,.6); max-width: 540px; margin: 0 auto 36px; }
.cta-section .tag { margin: 0 auto 20px; display: inline-flex; }

/* ---- UTILS ---- */
.text-center { text-align: center; }
.text-gold   { color: var(--gold); }
.bg-white    { background: var(--white); }
.bg-bg       { background: var(--bg); }
.bg-bg2      { background: var(--bg2); }
.bg-ink      { background: var(--ink); }
.mt-8  { margin-top: 8px; } .mt-16 { margin-top: 16px; }
.mt-24 { margin-top: 24px; } .mt-32 { margin-top: 32px; }
.mb-8  { margin-bottom: 8px; } .mb-16 { margin-bottom: 16px; }
.mb-24 { margin-bottom: 24px; } .mb-32 { margin-bottom: 32px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }

/* ---- RESPONSIVE ---- */
@media(max-width:1024px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .cta-section { margin: 0 16px 72px; padding: 56px 32px; }
}
@media(max-width:768px) {
  .section { padding: 56px 0; }
  .nav { display: none; }
  .nav.open {
    display: flex; flex-direction: column; align-items: flex-start;
    position: fixed; top: 80px; left: 0; right: 0;
    background: var(--bg); padding: 24px 20px; gap: 4px;
    border-bottom: 1px solid var(--border);
    box-shadow: 0 12px 32px rgba(26,31,74,.1);
    z-index: 199;
  }
  .nav.open a {
    color: var(--ink) !important; width: 100%;
    padding: 12px 14px; border-radius: 10px;
    font-size: 15px;
  }
  .nav.open .nav-cta {
    background: var(--gold) !important; color: var(--ink) !important;
    margin-top: 8px;
  }
  .burger { display: flex; }
  .footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .footer-bottom { flex-direction: column; gap: 10px; text-align: center; }
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .cta-section { border-radius: 20px; padding: 48px 24px; }
  .page-hero { border-radius: 0 0 20px 20px; padding: 100px 20px 48px; }
  .page-hero h1 { font-size: 32px; }
  .btn-lg { padding: 14px 24px; font-size: 14px; }
  /* article mobile */
  .article-layout { grid-template-columns: 1fr !important; padding: 32px 20px 56px; }
  .article-sidebar { position: static !important; }
  .article-hero { padding: 90px 20px 40px; }
  .article-hero h1 { font-size: 28px; }
}
@media(max-width:480px) {
  .header-inner { padding: 0 16px; }
  .container { padding: 0 16px; }
  h1 { font-size: 28px !important; }
  h2 { font-size: 24px !important; }
  .stats-inner { grid-template-columns: repeat(2,1fr); }
  .stat-num { font-size: 36px; }
  .icon-box { width: 40px; height: 40px; border-radius: 12px; }
}

/* ---- FOOTER SPACING ---- */
section + footer,
div + footer { margin-top: 0; }
.site-footer { position: relative; }
/* Отступ между последним контентом и футером */
main + footer,
.cta-wrapper + footer { margin-top: 0; }

/* ---- MATERIAL ICONS ---- */
.ms {
  font-family: 'Material Symbols Rounded';
  font-weight: normal; font-style: normal;
  font-size: 22px; line-height: 1;
  letter-spacing: normal; text-transform: none;
  display: inline-block; white-space: nowrap;
  word-wrap: normal; direction: ltr;
  -webkit-font-smoothing: antialiased;
  user-select: none;
}
.icon-box {
  width: 48px; height: 48px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.icon-box-gold  { background: rgba(200,168,75,.15); }
.icon-box-gold .ms  { color: var(--gold); }
.icon-box-white { background: rgba(255,255,255,.12); }
.icon-box-white .ms { color: var(--white); }
.icon-box-ink   { background: rgba(26,31,74,.08); }
.icon-box-ink .ms   { color: var(--ink); }
.icon-box-sea   { background: rgba(45,106,159,.1); }
.icon-box-sea .ms   { color: var(--sea); }

/* ---- FOOTER SPACING ---- */
.site-footer { margin-top: 0; }
section:last-of-type,
div[style*="padding:0 24px 96px"]:last-of-type { margin-bottom: 0; }

/* ─── Pre-footer gap ─── */
.pre-footer { padding-bottom: 96px; }

/* ─── Lists in articles and pages ─── */
.article-content ul, .article-content ol,
.methods-list, .page-list {
  list-style: none;
  margin: 16px 0 20px;
}
.article-content ul li, .article-content ol li {
  position: relative;
  padding-left: 22px;
  margin-bottom: 10px;
  font-size: 15px;
  line-height: 1.7;
  color: var(--text);
}
.article-content ul li::before {
  content: '';
  position: absolute;
  left: 0; top: 10px;
  width: 7px; height: 7px;
  background: var(--gold);
  border-radius: 50%;
}
.article-content ol {
  counter-reset: list;
}
.article-content ol li {
  position: relative;
  padding-left: 28px;
}
.article-content ol li::before {
  counter-increment: list;
  content: counter(list);
  position: absolute; left: 0; top: 0;
  width: 20px; height: 20px;
  background: var(--gold); color: var(--ink);
  border-radius: 50%; font-size: 11px;
  font-weight: 800; display: flex;
  align-items: center; justify-content: center;
}

/* ─── Material Symbols fallback (мобильные) ─── */
.ms {
  font-family: 'Material Symbols Rounded', sans-serif;
  font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

/* ─── Скрываем дублирующий h1 в теле статей ─── */
.article-content h1,
.article-content > h1:first-child {
  display: none !important;
}

/* ─── Единый стиль для всех статей (старых и новых) ─── */
.article-hero {
  background: var(--ink) !important;
  padding: 110px 24px 56px !important;
  border-radius: 0 0 32px 32px !important;
  border-bottom: none !important;
}
.article-hero h1 {
  color: var(--white) !important;
  font-family: 'Raleway', sans-serif !important;  font-weight: 800;
  max-width: 800px;
  margin-bottom: 16px;
}
.article-hero .breadcrumb a { color: rgba(255,255,255,.45) !important; }
.article-hero .breadcrumb span { color: rgba(255,255,255,.2) !important; }
.article-hero .meta { color: rgba(255,255,255,.5) !important; }
.article-hero .tag { margin-bottom: 16px; }
.article-hero .gold-line { background: var(--gold); }
@media(max-width:768px) {
  .article-hero { border-radius: 0 0 20px 20px !important; padding: 90px 20px 40px !important; }
  .article-hero h1 { font-size: 28px !important; }
}

/* ─── Konsultaciya page ─── */
.konsult-grid { display: grid; grid-template-columns: 1fr 420px; gap: 64px; align-items: start; }
.benefit-list { list-style: none; margin: 0; display: flex; flex-direction: column; gap: 0; }
.benefit-list li { display: flex; gap: 16px; align-items: flex-start; padding: 18px 0; border-bottom: 1px solid var(--border); }
.benefit-list li:last-child { border-bottom: none; }
.benefit-icon { flex-shrink: 0; }
.benefit-title { font-size: 15px; font-weight: 800; color: var(--ink); margin-bottom: 4px; }
.benefit-desc { font-size: 13px; color: var(--muted); line-height: 1.6; }
.format-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 24px 0; }
.format-card { background: var(--white); border: 1px solid var(--border); border-radius: 16px; padding: 20px; box-shadow: var(--shadow); }
.format-card-icon { font-size: 28px; margin-bottom: 12px; display: flex; }
.format-card h4 { font-size: 15px; font-weight: 800; color: var(--ink); margin-bottom: 6px; }
.format-card p { font-size: 13px; color: var(--muted); line-height: 1.5; }
.konsult-form-card { background: var(--white); border-radius: 24px; padding: 36px 32px; box-shadow: var(--shadow2); position: sticky; top: 96px; }
.konsult-form-card h3 { font-size: 22px; font-weight: 800; color: var(--ink); margin-bottom: 6px; }
@media(max-width:900px) { .konsult-grid { grid-template-columns: 1fr; } .konsult-form-card { position: static; } }
@media(max-width:600px) { .format-cards { grid-template-columns: 1fr; } }
