/* #1 mestskyprehled — макет "Civic portal": фикс. левый сайдбар + контент */
:root{--ink:#16202e;--muted:#5b6b7e;--brand:#1f6feb;--brand-d:#13243b;--line:#dbe3ee;--soft:#eef3f9;--accent:#ffb020}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Segoe UI",Roboto,Arial,sans-serif;color:var(--ink);line-height:1.6;background:#fff;display:grid;grid-template-columns:268px 1fr}
img{max-width:100%;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{line-height:1.2;margin:0 0 .4em}

/* sidebar */
.side{position:sticky;top:0;align-self:start;height:100vh;background:var(--brand-d);color:#cdd9e7;padding:26px 22px;display:flex;flex-direction:column;gap:22px;overflow:auto}
.side .brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:800;font-size:1.05rem}
.side .brandmark{width:40px;height:40px;border-radius:9px;background:var(--brand);display:grid;place-items:center;font-weight:800}
.side nav{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.side nav a{color:#bccadb;padding:9px 12px;border-radius:8px;font-weight:600;font-size:.94rem}
.side nav a:hover{background:rgba(255,255,255,.08);color:#fff;text-decoration:none}
.side .infobox{margin-top:auto;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:14px;font-size:.85rem}
.side .infobox b{color:var(--accent)}

/* main */
main{min-width:0}
.inner{max-width:920px;padding:0 40px}
.hero-band{background:linear-gradient(120deg,#eef3f9,#dfe9f6);padding:48px 40px;border-bottom:3px solid var(--brand)}
.hero-band .eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--brand);font-weight:800}
.hero-band h1{font-size:2.2rem;max-width:18ch}
.hero-band p{color:var(--muted);max-width:60ch}
.hero-band .quick{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.chip{background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-weight:600;font-size:.88rem;color:var(--ink)}

section{padding:46px 0}
.eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--brand);font-weight:800}
h2{font-size:1.55rem}

/* agendy: definition rows */
.agenda{border-top:1px solid var(--line)}
.agenda .row{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:20px 0;border-bottom:1px solid var(--line)}
.agenda .row h3{font-size:1.05rem;margin:0;color:var(--brand-d)}
.agenda .row p{margin:0;color:var(--muted)}

/* numbered process horizontal */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:0;counter-reset:f;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.flow .s{padding:20px;border-right:1px solid var(--line)}
.flow .s:last-child{border-right:0}
.flow .s::before{counter-increment:f;content:"0" counter(f);font-weight:800;color:var(--brand);font-size:1.3rem;display:block;margin-bottom:6px}
.flow .s b{display:block;margin-bottom:4px}
.flow .s p{margin:0;color:var(--muted);font-size:.9rem}

/* photo strip */
.strip{display:flex;gap:10px;overflow:auto;padding-bottom:6px}
.strip img{height:150px;border-radius:10px;flex:0 0 auto}

/* faq */
.qa details{border-bottom:1px solid var(--line);padding:14px 0}
.qa summary{cursor:pointer;font-weight:700;list-style:none}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";float:right;color:var(--brand)}
.qa details[open] summary::after{content:"–"}
.qa p{color:var(--muted);margin:.6em 0 0}

/* contact */
.contact{background:var(--soft);border:1px solid var(--line);border-radius:14px;padding:28px;display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:center}
.contact form{display:grid;gap:10px}
.contact input,.contact textarea{padding:11px 13px;border:1px solid var(--line);border-radius:9px;font:inherit}
.btn{display:inline-block;background:var(--brand);color:#fff;border:0;border-radius:9px;padding:11px 20px;font-weight:700;cursor:pointer}
.btn:hover{background:#1a5fd0;text-decoration:none}
.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}

footer{background:var(--brand-d);color:#9fb3c8;padding:30px 40px;margin-top:30px}
footer a{color:#bccadb;margin-right:16px}
footer .small{margin-top:12px;font-size:.82rem;color:#7f95ab}

/* legal pages */
.legal-page{max-width:780px;padding:46px 40px}
.legal-page .back{display:inline-block;margin-bottom:18px}
.legal-page h1{font-size:1.9rem}
.legal-page h2{font-size:1.2rem;margin-top:1.5em}
.legal-page p,.legal-page li{color:#33414f}

/* cookie banner */
.cookie{position:fixed;left:18px;right:18px;bottom:18px;z-index:90;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 44px rgba(0,0,0,.2);padding:16px 18px;display:none;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cookie.show{display:flex}
.cookie p{margin:0;font-size:.88rem;color:#33414f;max-width:60ch}
.cookie .actions{display:flex;gap:8px}

@media(max-width:860px){
  body{grid-template-columns:1fr}
  .side{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center}
  .side nav{flex-direction:row;flex-wrap:wrap}
  .side .infobox{display:none}
  .inner,.hero-band,.legal-page,footer{padding-left:20px;padding-right:20px}
  .agenda .row,.flow,.contact{grid-template-columns:1fr}
  .flow .s{border-right:0;border-bottom:1px solid var(--line)}
  .metrics,.cards,.checklist,.scenarios,.twocol{grid-template-columns:1fr !important}
  .tabs-btns{flex-wrap:wrap}
}

/* metrics band */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center;background:var(--soft);border:1px solid var(--line);border-radius:14px;padding:24px}
.metrics b{display:block;font-size:1.9rem;color:var(--brand)}
.metrics span{color:var(--muted);font-size:.88rem}
/* two column text+image */
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
.twocol img{border-radius:12px}
.twocol ul{padding-left:18px;color:var(--muted)}
/* info cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cards .c{border:1px solid var(--line);border-radius:12px;padding:20px;background:#fff}
.cards .c h3{font-size:1.05rem;margin:0 0 .3em;color:var(--brand-d)}
.cards .c p{margin:0;color:var(--muted);font-size:.93rem}
/* checklist */
.checklist{display:grid;grid-template-columns:1fr 1fr;gap:10px 26px}
.checklist div{padding:10px 0 10px 30px;position:relative;border-bottom:1px solid var(--line);color:var(--muted)}
.checklist div::before{content:"✓";position:absolute;left:0;color:var(--brand);font-weight:800}
/* doc table */
.doctable{width:100%;border-collapse:collapse;font-size:.94rem}
.doctable th,.doctable td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line)}
.doctable th{background:var(--soft);color:var(--brand-d)}
.doctable td{color:var(--muted)}
/* tabs */
.tabs-btns{display:flex;gap:8px;margin-bottom:16px}
.tabs-btns button{border:1px solid var(--line);background:#fff;padding:9px 16px;border-radius:999px;font:inherit;font-weight:600;cursor:pointer;color:var(--ink)}
.tabs-btns button.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.tab-pane{display:none}.tab-pane.active{display:block}
/* scenarios */
.scenarios{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.scenarios figure{margin:0;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
.scenarios img{height:130px;width:100%;object-fit:cover}
.scenarios figcaption{padding:12px}
.scenarios h3{font-size:1rem;margin:0 0 .2em}
.scenarios p{margin:0;color:var(--muted);font-size:.88rem}
/* notice callout */
.notice{border-left:4px solid var(--brand);background:var(--soft);border-radius:0 10px 10px 0;padding:18px 22px;color:var(--ink)}
/* mini survey */
.survey{background:var(--soft);border:1px solid var(--line);border-radius:14px;padding:24px}
.survey .opts{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.survey .opts button{border:1px solid var(--line);background:#fff;padding:10px 18px;border-radius:999px;font:inherit;cursor:pointer}
.survey .opts button:hover{border-color:var(--brand);color:var(--brand)}
.survey .thanks{margin-top:12px;color:var(--brand-d);font-weight:600;display:none}
/* gallery grid full */
.gal{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.gal img{height:96px;width:100%;object-fit:cover;border-radius:8px}
/* second/mini form (varied placement) */
.miniform{border:1px solid var(--line);border-radius:12px;padding:16px;background:#f6f7f9;display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:12px}
.miniform h4{flex-basis:100%;margin:0 0 4px;font-size:1.02rem}
.miniform p.sub{flex-basis:100%;margin:0 0 6px;color:var(--muted);font-size:.9rem}
.miniform input{flex:1;min-width:170px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font:inherit}
.miniform small{flex-basis:100%;color:var(--muted);font-size:.83rem;margin-top:2px}
