/* ============================================================= *
 *  СНТ «Змеиная горка» — сайт. Дизайн «Грядки» (как voting.zmgorka.ru).
 *  Тёплые оливково-садовые зелёные на крафтовой бумаге.
 * ============================================================= */
:root{
  --paper:        oklch(0.962 0.014 94);
  --paper-2:      oklch(0.935 0.020 90);
  --surface:      oklch(0.988 0.008 95);
  --surface-2:    oklch(0.972 0.012 92);
  --ink:          oklch(0.270 0.022 140);
  --ink-2:        oklch(0.470 0.022 132);
  --ink-3:        oklch(0.600 0.020 120);
  --line:         oklch(0.872 0.020 92);
  --line-2:       oklch(0.815 0.024 90);
  --leaf:         oklch(0.520 0.090 143);
  --leaf-deep:    oklch(0.410 0.075 146);
  --leaf-soft:    oklch(0.918 0.045 140);
  --sprout:       oklch(0.700 0.120 138);
  --sage:         oklch(0.640 0.030 128);
  --berry:        oklch(0.560 0.150 33);
  --berry-soft:   oklch(0.928 0.045 40);
  --honey:        oklch(0.740 0.085 78);
  --honey-soft:   oklch(0.930 0.045 84);
  --accent-ink:   oklch(0.985 0.01 95);
  --radius:       18px;
  --radius-sm:    12px;
  --radius-lg:    26px;
  --shadow-sm:    0 1px 2px oklch(0.4 0.03 120 / .06), 0 1px 3px oklch(0.4 0.03 120 / .05);
  --shadow:       0 2px 4px oklch(0.4 0.03 120 / .05), 0 8px 24px oklch(0.4 0.03 120 / .08);
  --shadow-lg:    0 4px 8px oklch(0.4 0.03 120 / .06), 0 20px 48px oklch(0.4 0.03 120 / .14);
  --ring:         oklch(0.520 0.090 143 / .35);
  --serif: "Source Serif 4", Georgia, "Times New Roman", serif;
  --sans:  "Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono:  "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --maxw: 920px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%; scroll-behavior:smooth}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-size:17px; line-height:1.55; font-weight:450; letter-spacing:-0.003em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; min-height:100dvh;
}
body::before{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:0.5;
  background:radial-gradient(120% 70% at 50% -10%, oklch(0.55 0.06 140 / .08), transparent 60%);
}
a{color:var(--leaf-deep); text-underline-offset:3px}
::selection{background:var(--leaf-soft); color:var(--ink)}
h1,h2,h3{margin:0; font-weight:600; letter-spacing:-0.02em; line-height:1.12}
.serif{font-family:var(--serif)}
.mono{font-family:var(--mono)}
.wrap{width:100%; max-width:var(--maxw); margin:0 auto; padding:0 20px}

.eyebrow{
  font-family:var(--mono); font-size:12px; font-weight:500; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--leaf-deep); display:inline-flex; align-items:center; gap:9px;
}
.eyebrow::before{content:""; width:18px; height:1.5px; background:var(--leaf); display:inline-block}

/* ─── HEADER ─── */
.site-header{
  position:sticky; top:0; z-index:50; background:oklch(from var(--paper) l c h / .85);
  -webkit-backdrop-filter:saturate(160%) blur(14px); backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--line);
}
.hrow{max-width:1100px; margin:0 auto; padding:10px 20px; display:flex; align-items:center; gap:14px}
.brand{display:flex; align-items:center; gap:12px; text-decoration:none; color:inherit; min-width:0}
.brand-badge{
  width:50px; height:50px; border-radius:50%; flex:none; overflow:hidden;
  background:var(--leaf-soft); border:1px solid var(--line); box-shadow:var(--shadow-sm);
}
.brand-badge img{width:100%; height:100%; object-fit:cover; display:block}
.brand-text{display:flex; flex-direction:column; min-width:0}
.brand-name{font-family:var(--serif); font-weight:600; font-size:17px; line-height:1.1; white-space:nowrap}
.brand-sub{font-family:var(--mono); font-size:10px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-3); margin-top:2px; white-space:nowrap}
.hspacer{flex:1}
.nav{display:flex; align-items:center; gap:4px}
.nav a{
  font-size:14.5px; font-weight:600; color:var(--ink-2); text-decoration:none;
  padding:9px 13px; border-radius:10px; transition:.15s; white-space:nowrap;
}
.nav a:hover{color:var(--ink); background:var(--surface-2)}
.nav a.active{color:var(--leaf-deep); background:var(--leaf-soft)}
.btn-vote{
  display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  background:var(--leaf); color:var(--accent-ink); font-weight:700; font-size:14.5px;
  padding:10px 16px; border-radius:12px; border:1.5px solid transparent; transition:.16s; box-shadow:var(--shadow-sm);
  white-space:nowrap;
}
.btn-vote:hover{background:var(--leaf-deep); transform:translateY(-1px); box-shadow:var(--shadow)}
.btn-vote svg{width:17px; height:17px}

/* ─── HILL ─── */
.hill{position:relative; height:0}
.hill svg{position:absolute; top:0; left:0; width:100%; height:46px; display:block}
.hill path{fill:var(--leaf-soft)}

/* ─── HERO ─── */
.hero{padding-top:38px; text-align:center}
.hero .eyebrow{justify-content:center}
.hero h1{font-family:var(--serif); font-size:clamp(28px,5.6vw,42px); margin-top:14px; max-width:none; text-wrap:balance; line-height:1.12}
.hero .lead{margin-top:14px; font-size:18px; color:var(--ink-2); max-width:none; text-wrap:pretty; text-align:justify; text-align-last:center}
.hero .meta{margin-top:18px; display:flex; flex-wrap:wrap; gap:10px; justify-content:center}
.tag{display:inline-flex; align-items:center; gap:7px; padding:7px 14px; border-radius:999px;
  background:var(--surface); border:1px solid var(--line); box-shadow:var(--shadow-sm); font-size:13.5px; color:var(--ink-2); white-space:nowrap}
.tag b{color:var(--ink); font-weight:700}
.tag.leaf{background:var(--leaf-soft); border-color:oklch(from var(--leaf) l c h / .3); color:var(--leaf-deep)}
.tag.berry{background:var(--berry-soft); border-color:oklch(from var(--berry) l c h / .3); color:var(--berry)}
.tag.honey{background:var(--honey-soft); border-color:oklch(from var(--honey) l c h / .35); color:oklch(0.5 0.08 70)}

/* ─── CARDS / SECTIONS ─── */
.card{margin-top:28px; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow); overflow:hidden}
.card-head{padding:22px 28px 16px; border-bottom:1px solid var(--line); background:linear-gradient(180deg, oklch(from var(--leaf) l c h / .07), transparent); display:flex; align-items:center; gap:12px}
.card-head .ci{width:38px; height:38px; border-radius:11px; flex:none; background:var(--leaf-soft); color:var(--leaf-deep); display:grid; place-items:center; border:1px solid oklch(from var(--leaf) l c h / .25)}
.card-head .ci svg{width:20px; height:20px}
.card-head h2{font-family:var(--serif); font-size:21px}
.card-body{padding:22px 28px}
.card-body p{margin:0 0 12px; font-size:15.5px; line-height:1.65; color:var(--ink-2); text-align:justify}
.card-body p:last-child{margin-bottom:0}
.card-body b{color:var(--ink); font-weight:600}
.card-body h3{font-family:var(--serif); font-size:17px; margin:18px 0 8px; color:var(--ink)}
.clist{margin:8px 0 0; padding-left:20px; color:var(--ink-2); font-size:15px; line-height:1.7; text-align:justify}
.clist li{margin-bottom:7px}
.clist li::marker{color:var(--leaf-deep)}

/* Повестка собрания */
.agenda{list-style:none; margin:8px 0 0; padding:0; counter-reset:ag}
.agenda > li{position:relative; padding:18px 0 18px 52px; border-top:1px solid var(--line)}
.agenda > li:first-child{border-top:0; padding-top:4px}
.agenda > li::before{counter-increment:ag; content:counter(ag); position:absolute; left:0; top:16px;
  width:34px; height:34px; border-radius:10px; background:var(--leaf-soft); color:var(--leaf-deep);
  border:1px solid oklch(from var(--leaf) l c h / .3); display:grid; place-items:center;
  font-family:var(--serif); font-weight:700; font-size:16px; font-variant-numeric:tabular-nums}
.agenda > li:first-child::before{top:4px}
.agenda .q{font-family:var(--serif); font-size:17px; line-height:1.35; color:var(--ink); margin:0 0 8px; font-weight:600; text-align:left}
.agenda .powers{margin-top:6px}
@media (max-width:560px){ .agenda > li{padding-left:44px} .agenda > li::before{width:30px; height:30px; font-size:15px; top:14px} .agenda > li:first-child::before{top:4px} }

/* выноска */
.callout{
  display:flex; gap:14px; padding:16px 18px; border-radius:var(--radius-sm);
  background:var(--honey-soft); border:1px solid oklch(from var(--honey) l c h / .35); margin:6px 0 4px;
}
.callout svg{width:22px; height:22px; flex:none; color:oklch(0.55 0.09 70); margin-top:1px}
.callout p{margin:0; font-size:14.5px; color:oklch(0.4 0.05 78); text-align:left}
.callout.leaf{background:var(--leaf-soft); border-color:oklch(from var(--leaf) l c h / .3)}
.callout.leaf svg{color:var(--leaf-deep)}
.callout.leaf p{color:oklch(0.33 0.04 145)}

/* ─── TABLE ─── */
.tbl-scroll{overflow-x:auto; margin:6px 0 4px}
table.grid{width:100%; border-collapse:collapse; font-size:14.5px; min-width:520px}
table.grid th, table.grid td{padding:12px 14px; text-align:left; border-bottom:1px solid var(--line)}
table.grid thead th{font-family:var(--mono); font-size:10.5px; letter-spacing:0.05em; text-transform:uppercase; color:var(--ink-3); font-weight:600; background:var(--surface-2); vertical-align:bottom}
table.grid td.num, table.grid th.num{text-align:right; font-variant-numeric:tabular-nums; white-space:nowrap; font-family:var(--mono)}
table.grid td.idx{color:var(--ink-3); font-family:var(--mono); font-size:12.5px; width:30px}
table.grid td.name{font-weight:600; color:var(--ink); line-height:1.35}
table.grid td.name small{display:block; font-weight:450; color:var(--ink-3); font-size:12px; margin-top:2px; letter-spacing:0}
table.grid tbody tr:hover{background:oklch(from var(--leaf) l c h / .035)}
table.grid td.pos{color:var(--berry); font-weight:600} table.grid td.neg{color:var(--leaf-deep); font-weight:600}
table.grid tr.total td{border-top:2px solid var(--line-2); border-bottom:0; background:var(--paper-2); font-weight:800; font-size:15px}
table.grid tr.total td.name{font-family:var(--serif)}
table.grid td.t1{color:var(--leaf-deep); font-weight:600} table.grid td.t2{color:oklch(0.55 0.08 70); font-weight:600}

/* ─── TARIFF CARDS ─── */
.tariffs{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:18px}
.tcard{background:var(--surface); border:1.5px solid var(--line); border-radius:var(--radius); padding:20px 22px; box-shadow:var(--shadow-sm); position:relative; overflow:hidden}
.tcard.year{border-color:oklch(from var(--leaf) l c h / .4)} .tcard.year::before{background:var(--leaf)}
.tcard.summer{border-color:oklch(from var(--honey) l c h / .45)} .tcard.summer::before{background:var(--honey)}
.tcard::before{content:""; position:absolute; left:0; top:0; bottom:0; width:4px}
.tcard .tk{font-family:var(--mono); font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-3)}
.tcard .tv{font-family:var(--serif); font-size:34px; font-weight:700; margin-top:6px; line-height:1; color:var(--ink); font-variant-numeric:tabular-nums}
.tcard .tv span{font-size:18px; color:var(--ink-3); font-weight:600}
.tcard .td{margin-top:8px; font-size:13.5px; color:var(--ink-2); line-height:1.5}

/* ─── DOCUMENTS ─── */
.docs{display:grid; grid-template-columns:1fr; gap:16px; margin-top:28px}
.doccard{
  display:flex; align-items:center; gap:18px; padding:20px 22px; text-decoration:none; color:inherit;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-sm); transition:.18s;
}
.doccard:hover{border-color:var(--leaf); transform:translateY(-2px); box-shadow:var(--shadow)}
.doc-ico{width:54px; height:54px; flex:none; border-radius:14px; display:grid; place-items:center; font-family:var(--mono); font-size:12px; font-weight:700; letter-spacing:0.04em}
.doc-ico.pdf{background:var(--berry-soft); color:var(--berry); border:1px solid oklch(from var(--berry) l c h / .3)}
.doc-ico.doc{background:var(--leaf-soft); color:var(--leaf-deep); border:1px solid oklch(from var(--leaf) l c h / .3)}
.doc-meta{flex:1; min-width:0}
.doc-meta .dt{display:block; font-weight:600; font-size:16.5px; color:var(--ink); line-height:1.3}
.doc-meta .ds{display:block; font-size:13.5px; color:var(--ink-3); margin-top:4px; line-height:1.4}
.doc-dl{flex:none; color:var(--leaf-deep); display:grid; place-items:center; width:40px; height:40px; border-radius:10px; background:var(--surface-2); border:1px solid var(--line)}
.doc-dl svg{width:20px; height:20px}

/* ─── FOOTER ─── */
.page-foot{border-top:1px solid var(--line); margin-top:52px; padding:26px 0 36px; color:var(--ink-3); font-size:13px}
.page-foot .wrap{display:flex; flex-direction:column; align-items:center; gap:8px; text-align:center}
.page-foot a{color:var(--leaf-deep); font-weight:600; text-decoration:none}
.page-foot .byline{font-family:var(--mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-3); opacity:.7; margin-top:4px}
.visit-counter{display:inline-flex; align-items:center; gap:8px; margin-top:6px;
  padding:5px 12px; border:1px solid var(--line); border-radius:999px;
  background:var(--surface); box-shadow:var(--shadow-sm);
  font-family:var(--mono); font-size:11px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-3)}
.visit-counter b{font-weight:600; color:var(--ink-2)}
.visit-counter .vc-sep{opacity:.5}

.screen{padding-bottom:40px}

/* ─── RESPONSIVE / MOBILE ─── */
@media (max-width:760px){
  body{font-size:16px}
  .hrow{padding:9px 14px; gap:10px; flex-wrap:wrap}
  .brand-badge{width:44px; height:44px}
  .brand-sub{display:none}
  .nav a{padding:8px 10px; font-size:13.5px}
  .btn-vote{padding:9px 13px; font-size:13.5px}
  .tariffs{grid-template-columns:1fr}
  .card-body{padding:18px 18px}
  .card-head{padding:18px 18px 14px}
  .hero h1{font-size:25px}
  .hero .lead{font-size:16px}
}
@media (max-width:560px){
  .hspacer{display:none}
  .brand{flex:1 0 100%; padding-bottom:9px; margin-bottom:9px; border-bottom:1px dashed var(--line)}
  .nav{order:2}
  .btn-vote{order:3; margin-left:auto}

  /* Таблицы: карточная раскладка вместо горизонтального скролла */
  .tbl-scroll{overflow-x:visible; margin:10px 0 6px}
  table.grid{min-width:0; display:block; font-size:14px}
  table.grid thead{display:none}
  table.grid tbody{display:block}
  table.grid tr{display:block; border:1px solid var(--line); border-radius:12px; background:var(--surface); box-shadow:var(--shadow-sm); padding:12px 14px; margin-bottom:10px}
  table.grid tbody tr:hover{background:var(--surface)}
  table.grid td{display:flex; justify-content:space-between; align-items:baseline; gap:14px; padding:6px 0; border-bottom:1px solid var(--line); text-align:right}
  table.grid td:last-child{border-bottom:0; padding-bottom:0}
  table.grid td[data-label]:not(.name):not(.idx)::before{content:attr(data-label); flex:none; text-align:left; font-family:var(--mono); font-size:10px; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-3); font-weight:600; align-self:center}
  table.grid td.idx{display:none}
  table.grid td.name{display:block; text-align:left; padding:0 0 8px; margin-bottom:4px; border-bottom:1px solid var(--line); font-size:15px}
  table.grid td.name small{display:block; margin-top:3px}
  table.grid tr.total{background:var(--paper-2); border-color:var(--line-2)}
  table.grid tr.total td{border-top:0; border-bottom:1px solid var(--line-2)}
  table.grid tr.total td:last-child{border-bottom:0}
  table.grid tr.total td.name{font-size:16px}
}
