@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap');

:root{
  color-scheme:dark;
  --bg:#0d0c0a;
  --surface:#141311;
  --surface-2:#1a1915;
  --surface-3:#252318;
  --border:#3d3724;
  --border-mid:#4a4228;
  --border-hi:#6b5c2e;
  --gold:#d7b85a;
  --gold-light:#f0d68d;
  --gold-dim:#7a6230;
  --gold-faint:#3a2e14;
  --text:#e4d8b5;
  --text-dim:#a79b7d;
  --text-muted:#7b725d;
  --shadow:0 10px 22px rgba(0,0,0,.26);
  --sidebar-width:320px;
  --radius:2px;
}

body.light-theme{
  color-scheme:light;
  --bg:#efe2bf;
  --surface:#f2e8d0;
  --surface-2:#eadcb8;
  --surface-3:#e1cfa5;
  --border:#b09060;
  --border-mid:#9d7a46;
  --border-hi:#7a5c1e;
  --gold:#7a5c1e;
  --gold-light:#8a6a28;
  --gold-dim:#9b7c3d;
  --gold-faint:#d8c393;
  --text:#1a1208;
  --text-dim:#4c3b1f;
  --text-muted:#6b5631;
  --shadow:0 8px 38px rgba(40,24,8,.18);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  background:var(--bg);
  background-image:
    radial-gradient(ellipse 100% 40% at 50% 0%, rgba(200,168,75,0.032) 0%, transparent 60%),
    repeating-linear-gradient(0deg, transparent, transparent 60px, rgba(255,255,255,0.0035) 60px, rgba(255,255,255,0.0035) 61px);
  color:var(--text);
  font-family:'Crimson Pro', Georgia, serif;
  font-size:16px;
  line-height:1.58;
}

a{color:var(--gold-light);text-decoration:none}
a:hover{color:var(--gold);text-decoration:underline}

.layout{
  display:grid;
  grid-template-columns:minmax(280px,var(--sidebar-width)) minmax(0,1fr);
  min-height:100vh;
}

.sidebar{
  position:sticky;
  top:0;
  align-self:start;
  height:100vh;
  padding:18px 16px 18px;
  background:linear-gradient(180deg, rgba(20,19,17,.98) 0%, rgba(13,12,10,.98) 100%);
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  gap:12px;
  overflow:auto;
}
body.light-theme .sidebar{
  background:linear-gradient(180deg, rgba(234,220,184,.98) 0%, rgba(239,226,191,.98) 100%);
}

.brand{
  margin:0;
  font-family:'Cinzel', serif;
  font-size:1.72rem;
  line-height:1.08;
  letter-spacing:.02em;
}
.brand a{color:var(--text);text-decoration:none}
.tagline{
  margin:0 0 2px;
  color:var(--text-dim);
  font-size:.92rem;
}

.nav-block,
.toc-block,
.sidebar-search{
  position:relative;
  background:linear-gradient(180deg, rgba(32,30,22,.96) 0%, rgba(24,22,16,.98) 100%);
  border:1px solid var(--border);
  border-radius:2px;
  box-shadow:var(--shadow);
  padding:14px 16px;
}
body.light-theme .nav-block,
body.light-theme .toc-block,
body.light-theme .sidebar-search{
  background:linear-gradient(180deg, rgba(242,232,208,.96) 0%, rgba(234,220,184,.98) 100%);
}
.nav-block::before,
.toc-block::before,
.sidebar-search::before,
.header::before,
.article section::before,
.card::before,
.subsection-card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--gold-dim), transparent);
}

.nav-block h2,
.toc-block h2{
  margin:0 0 10px;
  font-family:'Cinzel', serif;
  font-size:.92rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--gold);
}
.nav-block ul,
.toc-block ul{
  margin:0;
  padding:0;
  list-style:none;
}
.nav-block li,
.toc-block li{margin:0}
.nav-block a,
.toc-block a{
  display:block;
  padding:.36rem 0;
  color:var(--text);
}
.nav-block a.small,
.nav-block a.is-active{
  color:var(--gold-light);
  font-weight:600;
}
.toc-level-3 a{padding-left:14px;color:var(--text-dim)}

.search-wrap{display:grid;gap:10px}
.search-input{
  width:100%;
  appearance:none;
  border:1px solid var(--border-mid);
  border-radius:2px;
  background:rgba(0,0,0,.12);
  color:var(--text);
  padding:12px 14px;
  font:inherit;
  outline:none;
}
body.light-theme .search-input{background:rgba(255,255,255,.35)}
.search-input:focus{border-color:var(--gold);box-shadow:0 0 0 1px rgba(200,168,75,.16)}
.search-input::placeholder{color:var(--text-muted)}
.search-results{display:none;gap:6px}
.search-results.is-open{display:grid}
.search-result,
.search-empty{
  display:grid;
  gap:2px;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:2px;
  background:rgba(0,0,0,.08);
}
body.light-theme .search-result,
body.light-theme .search-empty{background:rgba(255,255,255,.28)}
.search-result-title{color:var(--text)}
.search-result-meta{font-size:.88rem;color:var(--text-dim)}
.search-empty{color:var(--text-dim)}

.theme-row{
  margin-top:auto;
  padding-top:4px;
}
.theme-btn{
  appearance:none;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid var(--border-mid);
  background:linear-gradient(180deg, rgba(32,30,22,.96) 0%, rgba(24,22,16,.98) 100%);
  color:var(--gold-light);
  box-shadow:var(--shadow);
  cursor:pointer;
  font-size:1.2rem;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
body.light-theme .theme-btn{
  background:linear-gradient(180deg, rgba(242,232,208,.96) 0%, rgba(234,220,184,.98) 100%);
}
.theme-btn:hover{transform:translateY(-1px)}

main{
  min-width:0;
  padding:18px 16px 24px;
}
.article{width:100%;max-width:none}
.header,
.article section,
.card,
.subsection-card{
  position:relative;
  background:linear-gradient(180deg, rgba(32,30,22,.96) 0%, rgba(24,22,16,.98) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
body.light-theme .header,
body.light-theme .article section,
body.light-theme .card,
body.light-theme .subsection-card{
  background:linear-gradient(180deg, rgba(242,232,208,.96) 0%, rgba(234,220,184,.98) 100%);
}
.header{padding:28px 28px 24px;margin:0 0 18px}
.article section{padding:22px 22px 18px;margin:0 0 18px}
.kicker{
  margin:0 0 10px;
  color:var(--gold-dim);
  text-transform:uppercase;
  letter-spacing:.20em;
  font-size:.78rem;
  font-family:'Cinzel', serif;
}
.header h1,
.article h2,
.article h3,
.card h3{
  margin:0 0 12px;
  font-family:'Cinzel', serif;
  color:var(--gold-light);
  letter-spacing:.02em;
  line-height:1.2;
}
body.light-theme .header h1,
body.light-theme .article h2,
body.light-theme .article h3,
body.light-theme .card h3{color:var(--gold)}
.header h1{font-size:1.92rem;text-shadow:0 0 40px rgba(200,168,75,.10)}
.article h2{font-size:1.34rem}
.article h3,.card h3{font-size:1.08rem}
.lead{
  margin:0;
  color:var(--text-dim);
  font-size:1rem;
  max-width:none;
}
.article p,
.article ul,
.article ol,
.article blockquote{margin:0 0 1rem}
.article ul,.article ol{padding-left:1.3rem}
.article li{margin:.28rem 0}
.article blockquote{
  padding:14px 16px;
  border-left:3px solid var(--gold-dim);
  background:rgba(0,0,0,.08);
  border-radius:2px;
}
body.light-theme .article blockquote{background:rgba(255,255,255,.28)}

.grid-cards,
.subsections-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:14px;
}
.card,
.subsection-card{padding:18px 18px 14px}
.subsection-card > *:last-child,
.card > *:last-child{margin-bottom:0}

.footer-nav{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding-top:6px;
}
.footer-nav a{
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  border:1px solid var(--border);
  border-radius:999px;
  background:linear-gradient(180deg, rgba(32,30,22,.96) 0%, rgba(24,22,16,.98) 100%);
}
body.light-theme .footer-nav a{
  background:linear-gradient(180deg, rgba(242,232,208,.96) 0%, rgba(234,220,184,.98) 100%);
}

.article table{
  width:100%;
  border-collapse:collapse;
  margin:1rem 0 1.3rem;
  background:rgba(0,0,0,.08);
  border:1px solid var(--border);
  border-radius:2px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
body.light-theme .article table{background:rgba(255,255,255,.28)}
.article thead th,
.article tbody td,
.article tbody th{
  text-align:left;
  vertical-align:top;
  padding:12px 14px;
  border-bottom:1px solid var(--border);
}
.article thead th{
  font-family:'Cinzel', serif;
  font-size:.76rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--gold);
  background:rgba(0,0,0,.10);
}
body.light-theme .article thead th{background:rgba(255,255,255,.24)}
.article tbody tr:last-child td,
.article tbody tr:last-child th{border-bottom:none}
.article tbody tr:nth-child(even) td,
.article tbody tr:nth-child(even) th{background:rgba(255,255,255,.02)}
body.light-theme .article tbody tr:nth-child(even) td,
body.light-theme .article tbody tr:nth-child(even) th{background:rgba(255,255,255,.18)}

.note{
  padding:16px 18px;
  border-left:3px solid var(--gold-dim);
  border-radius:2px;
  background:rgba(0,0,0,.08);
}
body.light-theme .note{background:rgba(255,255,255,.28)}

@media (max-width: 1100px){
  .layout{grid-template-columns:1fr}
  .sidebar{
    position:relative;
    height:auto;
    border-right:none;
    border-bottom:1px solid var(--border);
  }
  .theme-row{margin-top:0}
  main{padding-top:12px}
}

@media (max-width: 720px){
  body{font-size:15.5px}
  .sidebar{padding:14px}
  main{padding:12px}
  .header{padding:22px 18px 18px}
  .article section{padding:18px 16px 14px}
  .header h1{font-size:1.62rem}
  .article h2{font-size:1.34rem}
  .grid-cards,
  .subsections-grid{grid-template-columns:1fr}
  .article table{display:block;overflow-x:auto}
}

::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--gold-dim)}


/* Убирает перемигивание левого блока при переходах */
.sidebar{
  visibility:hidden;
}
.sidebar.is-ready{
  visibility:visible;
}


.site-back{
  position:relative;
  background:linear-gradient(180deg, rgba(32,30,22,.96) 0%, rgba(24,22,16,.98) 100%);
  border:1px solid var(--border);
  border-radius:2px;
  box-shadow:var(--shadow);
  padding:12px 16px;
}
body.light-theme .site-back{
  background:linear-gradient(180deg, rgba(242,232,208,.96) 0%, rgba(234,220,184,.98) 100%);
}
.site-back::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--gold-dim), transparent);
}
.site-back-link{
  display:block;
  color:var(--text);
  font-family:'Cinzel', serif;
  font-size:.86rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
}
.site-back-link:hover{
  color:var(--gold-light);
  text-decoration:none;
}


/* Обычный поток текста для проблемных разделов */
.article section#months,
.article section#cities,
.article section#main-cities,
.article section#months .subsections-grid,
.article section#cities .subsections-grid,
.article section#main-cities .subsections-grid {
  column-count: 1 !important;
  columns: auto !important;
  display: block !important;
}

.article section#months .subsection-card,
.article section#cities .subsection-card,
.article section#main-cities .subsection-card {
  break-inside: auto !important;
  page-break-inside: auto !important;
  display: block !important;
  width: auto !important;
  margin-bottom: 16px !important;
}


/* Проблемные разделы: карточки остаются, но идут сверху вниз */
.article section#months .subsections-grid,
.article section#main-cities .subsections-grid,
.article section#cities .subsections-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
}

.article section#months .subsection-card,
.article section#main-cities .subsection-card,
.article section#cities .subsection-card {
  width: auto !important;
  max-width: none !important;
}
