/*
  Важливо для подальших правок: CSS редагуємо прямо у базових класах.
  Не додаємо ланцюжки фінальних patch/override-блоків, щоб файл не розростався.
*/
:root {
  --bg: #ffffff;
  --surface: #f6f8fb;
  --surface-2: #edf1f6;
  --ink: #132033;
  --ink-2: #334155;
  --muted: #637083;
  --line: #d7dee8;
  --line-strong: #a9b3c2;
  --accent: #f2b84b;
  --accent-dark: #b98222;
  --blue: #1d3d63;
  --coal: #0b111b;
  --header-h: 116px;
  --shadow: 0 12px 35px rgba(11, 17, 27, .12);
  --font-main: "Manrope", "Segoe UI", Roboto, Arial, sans-serif;
  --font-heading: var(--font-main);
}
html { scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 28px); }
body {
  font-family: var(--font-main);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.55;
  letter-spacing: .002em;
  padding-top: var(--header-h);
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
  font-synthesis: none;
  font-variant-numeric: lining-nums proportional-nums;
  font-feature-settings: "lnum" 1, "pnum" 1, "tnum" 0;
}
body.menu-open { overflow: hidden; }
.skip-link { position:absolute; left:-999px; top:0; background:var(--ink); color:#fff; padding:10px 14px; z-index:9999; }
.skip-link:focus { left: 10px; }
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 1000;
  background: #fff;
  border-bottom: 1px solid var(--line);
  box-shadow: 0 4px 18px rgba(11,17,27,.08);
}
.topline {
  background: var(--coal);
  color: #fff;
  font-size: 13px;
  letter-spacing: .01em;
}
.topline .container { min-height: 36px; display: flex; justify-content: space-between; align-items: center; gap: 18px; }
.topline a { color: #fff; opacity: .96; }
.topline__left, .topline__right { display: flex; gap: 18px; align-items: center; flex-wrap: wrap; }
.header-main .container { min-height: 80px; display:flex; justify-content: space-between; align-items:center; gap: 22px; position:relative; }

.brand { display:flex; align-items:center; gap:18px; min-width:300px; }
.brand__main { display:flex; align-items:center; gap:14px; min-width:0; }
.brand__icon { display:block; width:48px; height:auto; flex:0 0 auto; filter: drop-shadow(0 8px 18px rgba(19,32,51,.12)); }
.brand__text { display:flex; flex-direction:column; gap:4px; min-width:0; }
.brand__name { display:block; color:var(--blue); font-size:32px; line-height:1; font-weight:800; letter-spacing:.02em; }
.brand__subtitle { display:block; color:var(--muted); font-size:12px; line-height:1.4; font-weight:700;
				   letter-spacing:.15em; text-transform:uppercase; }

footer .brand__name { color:#c8d1dc; }
footer .brand__subtitle { line-height:1.6; border-top: 1px solid var(--accent); }

.brand__ministry { border-left: 3px solid var(--accent); padding-left: 12px; font-size: 13px; line-height: 1.5;
				   color: var(--muted); text-transform: uppercase; font-weight: 700; letter-spacing: .08em; }

.nav-toggle { display:none; width:44px; height:44px; border:1px solid var(--ink); background:#fff; cursor:pointer; }
.nav-toggle span { display:block; width:22px; height:2px; margin:5px auto; background:var(--ink); transition:.2s ease; }
.main-nav { display:flex; align-items:center; gap: 3px; }
.nav-list { display:flex; align-items:center; gap: 2px; list-style:none; margin:0; padding:0; }
.nav-item { position:relative; }
.nav-link, .nav-button {
  display:flex; align-items:center; gap:6px; padding: 29px 14px;
  color: var(--ink); font-weight:700; font-size:14px; text-transform:uppercase;
  border:0; background:transparent; cursor:pointer;
}
.nav-link:hover, .nav-button:hover, .nav-link.is-active { background: var(--surface); color: var(--blue); }
.nav-button::after { content:""; border-left:4px solid transparent; border-right:4px solid transparent; border-top:5px solid currentColor; margin-top:2px; }
.dropdown { position:absolute; top:100%; left:0; min-width: 265px; background:#fff; border:1px solid var(--line-strong); box-shadow: var(--shadow); padding:8px 0; list-style:none; opacity:0; visibility:hidden; transform:translateY(8px); transition:.16s ease; }
.nav-item:hover .dropdown, .nav-item:focus-within .dropdown, .nav-item.is-open .dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.dropdown a { display:block; padding:11px 16px; color:var(--ink); border-left:3px solid transparent; }
.dropdown a:hover { background:var(--surface); border-left-color:var(--accent); }
.language { display:flex; gap:6px; align-items:center; margin-left:8px; }
.language a { border:1px solid var(--line); padding:7px 9px; font-weight:700; font-size:12px; }
.language a.is-active { background: var(--ink); color:#fff; border-color:var(--ink); }
.hero { position:relative; min-height: 640px; display:flex; align-items:stretch; background:var(--coal); color:#fff; overflow:hidden; }
.hero::before { content:""; position:absolute; inset:0; background:url('../img/photos/hero-coal.jpg') center/cover no-repeat; opacity:1; transform:scale(1.02); }
.hero::after { content:""; position:absolute; inset:0; background:
    linear-gradient(90deg, rgba(8,13,22,.88) 0%, rgba(8,13,22,.70) 42%, rgba(8,13,22,.26) 100%),
    linear-gradient(180deg, rgba(8,13,22,.06) 0%, rgba(8,13,22,.56) 100%),
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px),
    radial-gradient(circle at 78% 20%, rgba(242,184,75,.16), rgba(242,184,75,0) 36%);
  background-size:auto, auto, 38px 38px, 38px 38px, auto;
  background-position:0 0, 0 0, 0 0, 0 0, 0 0; }
.hero .container { position:relative; z-index:1; display:grid; grid-template-columns:minmax(0, 1.1fr) minmax(360px, .55fr); gap:34px; align-items:center; padding-block:72px; }
.eyebrow { display:inline-flex; align-items:center; flex-wrap:wrap; gap:10px; color:#fff; text-transform:uppercase; letter-spacing:.14em; font-size:13px; font-weight:800; margin-bottom:20px; }
.eyebrow::before { content:""; width:18px; height:3px; background:var(--accent); }
.eyebrow span { display:inline-flex; align-items:center; gap:10px; }
.eyebrow span + span::before { content:""; width:18px; height:3px; background:var(--accent); display:inline-block; }
.hero h1 { font-family:var(--font-heading); font-size: clamp(28px, 3.2vw, 46px); line-height: 1.1; margin:0 0 18px; font-weight:800; letter-spacing:.006em; max-width: 860px; }
.hero-copy p { max-width: 760px; color:#e3e8ef; font-size: clamp(17px, 1.6vw, 22px); margin:0 0 32px; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.btn { display:inline-flex; align-items:center; justify-content:center; min-height:50px; padding:13px 20px; border:2px solid transparent; font-weight:800; text-transform:uppercase; letter-spacing:.04em; font-size:13px; cursor:pointer; transition:.15s ease; }
.btn-primary { background:var(--accent); color:#161616; border-color:var(--accent); }
.btn-primary:hover { background:#fff; border-color:#fff; }
.btn-outline { color:#fff; border-color:rgba(255,255,255,.62); background:rgba(255,255,255,.04); }
.btn-outline:hover { color:var(--ink); background:#fff; }
.hero-panel { background:rgba(255,255,255,.96); color:var(--ink); border:1px solid rgba(255,255,255,.45); box-shadow:var(--shadow); }
.hero-panel__head { padding:18px 22px; background:var(--accent); color:#161616; font-weight:900; text-transform:uppercase; letter-spacing:.07em; }
.hero-panel__body { padding:22px; }
.hero-panel dl { margin:0; display:grid; gap:14px; }
.hero-panel dt { color:var(--muted); text-transform:uppercase; font-size:12px; font-weight:800; letter-spacing:.08em; }
.hero-panel dd { margin:2px 0 0; font-weight:800; font-size:18px; }
.section { padding:86px 0; }
.section--soft { background: var(--surface); }
.section--dark { background: var(--ink); color:#fff; }
.section__head { display:flex; align-items:end; justify-content:space-between; gap:32px; margin-bottom:34px; border-bottom:1px solid var(--line); padding-bottom:24px; }
.section--dark .section__head { border-color:rgba(255,255,255,.18); }
.section-kicker { margin:0 0 10px; color:var(--accent-dark); font-weight:900; letter-spacing:.14em; text-transform:uppercase; font-size:13px; }
.section-title { margin:0; font-family:var(--font-heading); font-size:clamp(23px, 2.2vw, 34px); line-height:1.16; font-weight:800; letter-spacing:.004em; }
.section-subtitle { max-width:700px; margin:0; color:var(--muted); font-size:17px; }
.section--dark .section-subtitle { color:#c8d1dc; }
.grid { display:grid; gap:24px; }
.grid-3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
.content .grid-3 { margin-top:34px; }
.card { background:#fff; border:1px solid var(--line); border-top:4px solid var(--ink); padding:28px; min-height:100%; transition: .18s ease; }
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-top-color: var(--accent); }
.card__icon { width:58px; height:58px; margin-bottom:22px; }
.card h3 { margin:0 0 12px; font-family:var(--font-heading); font-size:20px; line-height:1.2; font-weight:800; letter-spacing:.003em; }
.card p { margin:0 0 18px; color:var(--muted); }
.card a { display:inline-flex; align-items:center; gap:10px; font-weight:900; color:var(--blue); text-transform:uppercase; font-size:13px; }
.card a::after { content:"→"; color:var(--accent-dark); }

.card--media { padding:0; overflow:hidden; }
.card--media .card__thumb { aspect-ratio: 16 / 9; background-size:cover; background-position:center; border-bottom:1px solid var(--line); }
.card--media .card__body { padding:26px 28px 28px; }
.card--media .card__icon { margin-bottom:18px; }
.card__thumb--plant { background-image:url('../img/photos/premium-tower.jpg'); }
.card__thumb--steam { background-image:url('../img/photos/premium-mill.jpg'); }
.card__thumb--stack { background-image:url('../img/photos/premium-rail.jpg'); }
.docs-list { display:grid; gap:12px; }
.doc-row {
  background:#fff; border:1px solid var(--line); overflow:hidden; scroll-margin-top:calc(var(--header-h) + 28px);
  transition:border-color .22s ease, box-shadow .22s ease;
}
.doc-row:hover, .doc-row.is-open { border-color:var(--line-strong); box-shadow:0 10px 24px rgba(11,17,27,.08); }
.doc-row__toggle {
  width:100%; display:grid; grid-template-columns:56px minmax(0,1fr) auto 18px; gap:18px; align-items:center;
  padding:18px; border:0; background:transparent; color:inherit; text-align:left; cursor:pointer; font:inherit;
}
.doc-row__toggle:focus-visible { outline:3px solid rgba(242,184,75,.45); outline-offset:-3px; }
.doc-row__icon { width:52px; height:52px; background:var(--surface); padding:10px; border:1px solid var(--line); }
.doc-row__text { min-width:0; }
.doc-row__title { display:block; margin:0 0 3px; font-family:var(--font-heading); font-size:18px; line-height:1.25; color:var(--ink); font-weight:800; }
.doc-row__desc { display:block; margin:0; color:var(--muted); font-size:15px; }
.doc-row__meta { color:var(--blue); font-weight:900; text-transform:uppercase; font-size:12px; white-space:nowrap; }
.doc-row__chevron { width:14px; height:14px; border-right:2px solid var(--accent-dark); border-bottom:2px solid var(--accent-dark); transform:rotate(45deg); transition:transform .32s ease; }
.doc-row.is-open .doc-row__chevron { transform:rotate(-135deg); }
.doc-row__panel {
  --doc-panel-x:18px; --doc-panel-left:92px; --doc-panel-bottom:18px;
  max-height:0; overflow:hidden; opacity:0; visibility:hidden;
  padding:0 var(--doc-panel-x) 0 var(--doc-panel-left); border-top:0 solid transparent;
  background:linear-gradient(180deg, #fff 0%, var(--surface) 100%);
  transition:max-height .48s cubic-bezier(.22,.61,.36,1), opacity .28s ease, padding .42s cubic-bezier(.22,.61,.36,1), border-color .28s ease, visibility 0s linear .48s;
}
.doc-row.is-open .doc-row__panel {
  max-height:420px; opacity:1; visibility:visible; padding:0 var(--doc-panel-x) var(--doc-panel-bottom) var(--doc-panel-left);
  border-top-width:1px; border-top-color:var(--line); transition-delay:0s;
}
.doc-links { list-style:none; margin:0; padding:16px 0 0; display:grid; gap:9px; }
.doc-links li { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:10px 12px; background:#fff; border:1px solid var(--line); }
.doc-links a { position:relative; padding-left:18px; color:var(--blue); font-weight:800; }
.doc-links a::before { content:""; position:absolute; left:0; top:.62em; width:7px; height:7px; background:var(--accent); }
.doc-links a:hover { color:var(--accent-dark); }
.doc-links__type { color:var(--muted); font-weight:900; text-transform:uppercase; font-size:11px; letter-spacing:.06em; white-space:nowrap; }
.split { display:grid; grid-template-columns: 0.95fr 1.05fr; gap: 48px; align-items:center; }
.contact-grid { display:grid; grid-template-columns: .85fr 1.15fr; gap:24px; }
.contact-card, .form-card { background:#fff; border:1px solid var(--line); padding:28px; }
.contact-line { display:grid; gap:4px; padding:16px 0; border-bottom:1px solid var(--line); }
.contact-line:last-child { border-bottom:0; }
.contact-line > span { color:var(--muted); font-weight:800; text-transform:uppercase; font-size:12px; letter-spacing:.08em; }
.contact-line strong, .contact-line a {
  font-size:18px; color:var(--ink); font-weight:700;
  font-variant-numeric: lining-nums proportional-nums;
  font-feature-settings:"lnum" 1, "pnum" 1, "tnum" 0;
}
.contact-line--schedule strong { display:grid; gap:2px; line-height:1.5; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-field { display:grid; gap:6px; }
.form-field.full { grid-column:1 / -1; }
label { font-weight:800; color:var(--ink); }
input, textarea { width:100%; border:1px solid var(--line-strong); background:#fff; color:var(--ink); padding:13px 14px; outline:none; }
input:focus, textarea:focus { border-color:var(--blue); box-shadow:0 0 0 3px rgba(29,61,99,.13); }
textarea { resize:vertical; min-height:140px; }
.breadcrumbs { background:var(--surface); border-bottom:1px solid var(--line); }
.breadcrumbs .container { padding:18px 0; display:flex; gap:8px; flex-wrap:wrap; color:var(--muted); font-weight:700; }
.breadcrumbs a { color:var(--blue); }
.page-hero { position:relative; padding:68px 0 54px; background:var(--ink); color:#fff; border-bottom:5px solid var(--accent); overflow:hidden; }
.page-hero::before { content:""; position:absolute; inset:0; background:url('../img/photos/premium-page-cover.jpg') center/cover no-repeat; opacity:.38; }
.page-hero::after { content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(19,32,51,.92) 0%, rgba(19,32,51,.74) 55%, rgba(19,32,51,.68) 100%); }
.page-hero .container { position:relative; z-index:1; }
.page-hero h1 { margin:0 0 10px; font-family:var(--font-heading); font-size:clamp(26px, 2.4vw, 38px); line-height:1.1; font-weight:800; letter-spacing:.006em; }
.page-hero p { max-width:840px; color:#c8d1dc; font-size:18px; margin:0; }
.content { padding:64px 0 90px; }
.content h2 { font-family:var(--font-heading); font-size:24px; margin:0 0 16px; font-weight:800; letter-spacing:.004em; }
.content h3 { font-family:var(--font-heading); font-size:20px; margin:30px 0 12px; font-weight:800; letter-spacing:.003em; }
.content p { color:var(--ink-2); }
.content hr { border:0; border-top:1px solid var(--line); margin:34px 0; }
.lead { font-size:17px; color:var(--ink-2); }
.directions-content ul { list-style:none; margin:0 0 26px; padding:0; display:grid; gap:12px; }
.directions-content li { position:relative; padding-left:20px; color:var(--ink-2); line-height:1.68; }
.directions-content li::before { content:""; position:absolute; left:0; top:.72em; width:7px; height:7px; background:var(--accent); }
.directions-content hr { margin:34px 0; }
.table-wrap { overflow:auto; border:1px solid var(--line); }
table { width:100%; border-collapse:collapse; background:#fff; }
th, td { padding:16px 18px; border-bottom:1px solid var(--line); text-align:left; vertical-align:top; }
th { background:var(--surface); text-transform:uppercase; letter-spacing:.06em; font-size:12px; color:var(--ink); }
.partner-table th:first-child, .partner-table td:first-child { min-width:250px; font-weight:800; color:var(--ink); }
.docs-list, .management-list { margin-top:28px; }
.management-list { display:grid; gap:16px; }
.person { display:grid; grid-template-columns:64px 1fr; gap:18px; align-items:center; padding:22px; border:1px solid var(--line); background:#fff; }
.person__avatar {
  position:relative; width:64px; height:64px; overflow:hidden; flex:0 0 64px;
  background:linear-gradient(135deg, #f8fbff 0%, #edf3f9 100%);
  box-shadow:inset 0 0 0 1px #cfd8e6, 0 8px 18px rgba(19,32,51,.06);
}
.person__avatar::before {
  content:""; position:absolute; left:8px; top:8px; bottom:8px; width:3px;
  background:linear-gradient(180deg, var(--accent), var(--accent-dark));
}
.person__avatar::after {
  content:""; position:absolute; left:calc(50% + 4px); top:50%; width:38px; height:38px;
  transform:translate(-50%, -45%); background:#53657d; opacity:.96;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M32 34c8.3 0 15-6.7 15-15S40.3 4 32 4 17 10.7 17 19s6.7 15 15 15Zm0 6C18.8 40 8 48.1 8 58.1V60h48v-1.9C56 48.1 45.2 40 32 40Z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M32 34c8.3 0 15-6.7 15-15S40.3 4 32 4 17 10.7 17 19s6.7 15 15 15Zm0 6C18.8 40 8 48.1 8 58.1V60h48v-1.9C56 48.1 45.2 40 32 40Z'/%3E%3C/svg%3E") center/contain no-repeat;
}
.person h3 { margin:0 0 4px; }
.person p { margin:0; color:var(--muted); font-weight:700; }
.site-footer { background:var(--coal); color:#fff; }
.footer-main { padding:54px 0; border-bottom:1px solid rgba(255,255,255,.16); }
.footer-grid { display:grid; grid-template-columns:1.3fr .8fr .8fr 1fr; gap:28px; }

.site-footer .brand { min-width:0; margin-bottom:18px; }
.site-footer .brand__icon { filter:none; }

.site-footer p, .site-footer li { color:#c8d1dc; }
.footer-title { color:#fff; text-transform:uppercase; letter-spacing:.08em; font-size:13px; font-weight:800; margin:0 0 18px; }
.footer-links { list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.footer-links a:hover { color:var(--accent); }
.footer-bottom { padding:18px 0; color:#c8d1dc; font-size:13px; }
.footer-bottom .container { display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; }
.to-top { position:fixed; right:20px; bottom:20px; z-index:900; width:46px; height:46px; border:1px solid var(--line-strong); background:#fff; color:var(--ink); display:grid; place-items:center; opacity:0; pointer-events:none; transform:translateY(12px); transition:.18s ease; box-shadow:var(--shadow); }
.to-top.is-visible { opacity:1; pointer-events:auto; transform:translateY(0); }
.auth-modal {
  position:fixed; inset:0; z-index:1300; display:grid; place-items:center; padding:24px;
  opacity:0; visibility:hidden; pointer-events:none; transition:opacity .24s ease, visibility 0s linear .24s;
}
.auth-modal.is-open { opacity:1; visibility:visible; pointer-events:auto; transition-delay:0s; }
.auth-modal__backdrop { position:absolute; inset:0; background:rgba(11,17,27,.68); backdrop-filter:blur(7px); }
.auth-modal__dialog {
  position:relative; width:min(100%, 430px); background:#fff; border:1px solid rgba(255,255,255,.24); border-top:4px solid var(--accent);
  box-shadow:0 30px 80px rgba(0,0,0,.32); transform:translateY(18px) scale(.985); opacity:.96;
  transition:transform .28s cubic-bezier(.22,.61,.36,1), opacity .24s ease;
}
.auth-modal.is-open .auth-modal__dialog { transform:translateY(0) scale(1); opacity:1; }
.auth-modal__close {
  position:absolute; right:14px; top:14px; width:38px; height:38px; border:1px solid var(--line); background:#fff; color:var(--ink);
  font-size:24px; line-height:1; cursor:pointer; display:grid; place-items:center; transition:background .18s ease, border-color .18s ease, color .18s ease;
}
.auth-modal__close:hover { background:var(--surface); border-color:var(--line-strong); color:var(--blue); }
.auth-modal__head { padding:30px 30px 18px; background:linear-gradient(180deg, #fff, #f8fafc); border-bottom:1px solid var(--line); }
.auth-modal__brand { display:flex; align-items:center; gap:14px; margin-bottom:20px; padding-right:42px; }
.auth-modal__brand img { width:42px; height:auto; filter:drop-shadow(0 8px 18px rgba(19,32,51,.12)); }
.auth-modal__brand strong { display:block; color:var(--blue); font-size:24px; line-height:1; font-weight:800; letter-spacing:.02em; }
.auth-modal__brand span { display:block; margin-top:4px; color:var(--muted); font-size:11px; line-height:1.35; font-weight:700; letter-spacing:.14em; text-transform:uppercase; }
.auth-modal__head h2 { margin:0 0 8px; font-family:var(--font-heading); font-size:24px; line-height:1.18; color:var(--ink); font-weight:800; }
.auth-modal__head p { margin:0; color:var(--muted); }
.auth-modal__form { display:grid; gap:16px; padding:24px 30px 30px; }
.auth-field { display:grid; gap:7px; }
.auth-field span { color:var(--muted); font-size:12px; line-height:1; font-weight:800; text-transform:uppercase; letter-spacing:.08em; }
.auth-field input { width:100%; border:1px solid var(--line); background:#fff; color:var(--ink); padding:13px 14px; font:inherit; font-weight:600; transition:border-color .18s ease, box-shadow .18s ease; }
.auth-field input:focus { outline:none; border-color:var(--accent-dark); box-shadow:0 0 0 3px rgba(242,184,75,.22); }
.auth-modal__actions { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-top:4px; }
.auth-modal__link { color:var(--blue); font-weight:800; font-size:13px; text-transform:uppercase; letter-spacing:.04em; }
.auth-modal__status { min-height:20px; margin:0; color:var(--muted); font-size:13px; }
body.auth-modal-open { overflow:hidden; }

@media (max-width: 1180px) {
  :root { --header-h: 104px; }
  .brand__name { font-size:30px; }
  .brand__subtitle { font-size:11px; letter-spacing:.16em; }
  
  .brand__icon { width:44px; }

  .brand__ministry { display:none; }
  .nav-link, .nav-button { padding-inline:10px; font-size:13px; }
  .nav-link::before, .nav-button::before { display:none; }
  .hero .container { grid-template-columns:1fr; }
  .hero-panel { max-width:620px; }
}
@media (max-width: 920px) {
  :root { --header-h: 92px; }
  .topline { display:none; }
  .header-main .container { min-height:92px; }
  .nav-toggle { display:block; position:relative; z-index:1006; }
  .main-nav { position:absolute; top:100%; right:0; left:0; bottom:auto; z-index:1005; max-height:calc(100vh - 92px); background:#fff; border-top:1px solid var(--line); display:none; overflow:auto; padding:10px 16px 30px; box-shadow:0 18px 36px rgba(19,32,51,.12); }
  .main-nav.is-open { display:block; }
  .nav-list { display:block; }
  .nav-link, .nav-button { width:100%; padding:16px 0; border-bottom:1px solid var(--line); justify-content:space-between; }
  .nav-link::before, .nav-button::before { display:none; }
  .dropdown { position:static; min-width:0; border:0; box-shadow:none; transform:none; opacity:1; visibility:visible; display:none; padding:0 0 8px 14px; }
  .nav-item.is-open .dropdown { display:block; }
  .language { margin:16px 0 0; }
  .hero { min-height: auto; }
  .hero .container { padding-block:58px; }
  .hero::after { background:
    linear-gradient(90deg, rgba(11,17,27,.82) 0%, rgba(11,17,27,.78) 48%, rgba(11,17,27,.68) 100%),
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
    background-size:auto, 32px 32px, 32px 32px; }
  .section { padding:64px 0; }
  .section__head { display:block; }
  .section-subtitle { margin-top:14px; }
  .grid-3, .split, .contact-grid, .footer-grid { grid-template-columns:1fr; }
  .doc-row__toggle { grid-template-columns:48px minmax(0,1fr) 18px; gap:14px; padding:16px; }
  .doc-row__icon { width:48px; height:48px; }
  .doc-row__meta { grid-column:2; grid-row:2; }
  .doc-row__chevron { grid-column:3; grid-row:1 / span 2; }
  .doc-row__panel { --doc-panel-x:16px; --doc-panel-left:78px; --doc-panel-bottom:16px; }
  .doc-links li { align-items:flex-start; }
}
@media (max-width: 560px) {
  .auth-modal { padding:14px; }
  .auth-modal__head { padding:24px 22px 16px; }
  .auth-modal__form { padding:22px; }
  .auth-modal__brand strong { font-size:21px; }
  body { font-size:15px; }
  .brand { min-width:0; gap:12px; }
  .brand__main { gap:10px; }

  .brand__icon { width:38px; }
  .doc-row__toggle { grid-template-columns:44px minmax(0,1fr) 16px; gap:12px; }
  .doc-row__icon { width:44px; height:44px; padding:8px; }
  .doc-row__panel { --doc-panel-x:14px; --doc-panel-left:14px; --doc-panel-bottom:14px; }
  .doc-links li { display:grid; gap:5px; }

  .brand__name { font-size:23px; }
  .brand__subtitle { font-size:9px; letter-spacing:.12em; }
  .hero-actions { display:grid; }
  .btn { width:100%; }
  .card, .contact-card, .form-card { padding:22px; }
  .form-grid { grid-template-columns:1fr; }
  .footer-bottom .container { display:block; }
}

/* === Базові візуальні налаштування === */
html, body { overflow-x: hidden; }
a, button, input, textarea { transition: color .18s ease, background-color .18s ease, border-color .18s ease, box-shadow .18s ease, transform .18s ease, opacity .18s ease; }
.site-header {
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: box-shadow .18s ease, background-color .18s ease, border-color .18s ease;
}
.site-header.is-scrolled { box-shadow: 0 8px 28px rgba(11,17,27,.12); }
.header-main { position: relative; }
.header-main::after {
  content:""; position:absolute; left:0; right:0; bottom:0; height:1px;
  background: linear-gradient(90deg, rgba(242,184,75,0) 0%, rgba(242,184,75,.92) 50%, rgba(242,184,75,0) 100%);
  opacity:.55;
}

.nav-link, .nav-button { position:relative; }
.nav-link::before, .nav-button::before {
  content:""; position:absolute; left:14px; right:14px; bottom:18px; height:2px; background:var(--accent);
  transform:scaleX(0); transform-origin:left; transition:transform .18s ease;
}
.nav-link:hover::before, .nav-link.is-active::before, .nav-button:hover::before { transform:scaleX(1); }
.hero { isolation:isolate; }
.hero::before {
  transform: translateY(var(--hero-shift, 0px)) scale(1.035);
  transition: transform .2s linear;
}

.hero .container::before,
.hero .container::after {
  content:""; position:absolute;
  border:1px solid rgba(255,255,255,.12); box-shadow: inset 0 0 0 1px rgba(242,184,75,.16);
  background:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 36px 36px;
  pointer-events:none;
}
.hero .container::before {
  right:-40px; top:32px; width:min(38vw,520px); height:min(38vw,520px);
  opacity:.55; animation: heroFrameFloat 12s ease-in-out infinite;
}
.hero .container::after {
  right:190px; top:72px; width:min(30vw,410px); height:min(30vw,410px);
  opacity:.34; animation: heroFrameFloatSecondary 15s ease-in-out infinite reverse;
}
.hero .container > * { position:relative; z-index:1; }
.hero h1 {
  text-shadow: 0 12px 26px rgba(0,0,0,.18);
}
.hero-copy p { max-width: 780px; }
.hero-actions { margin-bottom: 26px; }
.btn {
  position:relative; overflow:hidden;
  box-shadow: 0 8px 20px rgba(11,17,27,.12);
}
.btn::before {
  content:""; position:absolute; top:0; bottom:0; left:-120%; width:55%;
  background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.42), rgba(255,255,255,0));
  transform: skewX(-24deg);
}
.btn:hover::before { animation: sweepShine .8s ease; }
.btn:hover { transform: translateY(-2px); }
.btn-primary { box-shadow: 0 10px 22px rgba(242,184,75,.22); }
.btn-outline { backdrop-filter: blur(4px); }
.hero-panel {
  position:relative; overflow:hidden; border-top:4px solid var(--accent);
  animation:none;
}
.hero-panel::before {
  content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(242,184,75,.08), rgba(242,184,75,0) 30%);
  pointer-events:none;
}
.hero-panel__body dl > div { padding:12px 0; border-bottom:1px solid var(--line); }
.hero-panel__body dl > div:last-child { border-bottom:0; padding-bottom:0; }
.hero-facts {
  display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; max-width:760px;
}
.hero-fact {
  padding:16px 18px; border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.06);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
}
.hero-fact strong { display:block; color:#fff; font-size:13px; text-transform:uppercase; letter-spacing:.08em; margin-bottom:6px; }
.hero-fact span { color:#dce5ef; font-size:14px; }

.hero-copy .eyebrow,
.hero h1,
.hero-copy > p,
.hero-actions,
.hero-facts {
  opacity:0;
  transform:translateY(18px);
  filter:blur(4px);
  animation:heroIntroFade .72s cubic-bezier(.22,.82,.24,1) forwards;
}
.hero-copy .eyebrow { animation-delay:.08s; }
.hero h1 { animation-delay:.18s; }
.hero-copy > p { animation-delay:.28s; }
.hero-actions { animation-delay:.38s; }
.hero-facts { animation-delay:.5s; }
.hero .hero-panel {
  opacity:0;
  transform:translateY(22px) scale(.985);
  animation:heroIntroPanel .82s cubic-bezier(.22,.82,.24,1) .44s forwards;
}

.section--soft {
  background:
    linear-gradient(180deg, #f8fafc 0%, #f4f7fb 100%);
}
.section__head { position:relative; }
.section__head::after {
  content:""; position:absolute; left:0; bottom:-1px; width:120px; height:2px; background:linear-gradient(90deg, var(--accent), rgba(242,184,75,0));
}
.card {
  position:relative; overflow:hidden; border-top-width:5px; box-shadow:0 12px 28px rgba(19,32,51,.06);
}
.card::before {
  content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(242,184,75,.05), rgba(242,184,75,0) 28%);
  opacity:0; transition:opacity .18s ease; pointer-events:none;
}
.card:hover::before { opacity:1; }
.card--media .card__thumb { overflow:hidden; }
.card--media .card__thumb::after {
  content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(19,32,51,.04), rgba(19,32,51,.18));
}
.card--media .card__thumb { position:relative; }
.card--media:hover .card__thumb { transform: scale(1.03); }
.card--media .card__thumb { transition: transform .55s ease; }
.card h3 { transition: color .18s ease; }
.card:hover h3 { color: var(--blue); }
.doc-row, .contact-card, .form-card, .person, .table-wrap {
  box-shadow: 0 12px 28px rgba(19,32,51,.05);
}
.doc-row { position:relative; }
.doc-row.is-open .doc-row__toggle { background:linear-gradient(90deg, rgba(242,184,75,.08), rgba(242,184,75,0) 55%); }
.page-hero::before { transform: scale(1.03); animation: slowPan 18s ease-in-out infinite alternate; }
.page-hero h1 { text-shadow: 0 10px 24px rgba(0,0,0,.16); }
.page-hero .section-kicker { color: #f5c86c; }
.person {
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.person:hover { transform: translateY(-2px); border-color: var(--line-strong); box-shadow: 0 18px 34px rgba(19,32,51,.08); }
.contact-card, .form-card {
  position:relative; overflow:hidden;
}
.contact-card::before, .form-card::before {
  content:""; position:absolute; left:0; right:0; top:0; height:3px; background:linear-gradient(90deg, var(--accent), rgba(242,184,75,0));
}
.table-wrap { border-radius: 0; }
.partner-table tbody tr { transition: background-color .16s ease; }
.partner-table tbody tr:hover { background: #fbfcfe; }
.footer-main {
  position:relative; overflow:hidden;
}
.footer-main::before {
  content:""; position:absolute; left:0; right:0; top:0; height:2px; background:linear-gradient(90deg, rgba(242,184,75,0), rgba(242,184,75,.9), rgba(242,184,75,0));
  opacity:.7;
}
.footer-bottom { background: rgba(255,255,255,.02); }
.to-top {
  border-color: rgba(19,32,51,.1);
  box-shadow: 0 14px 30px rgba(19,32,51,.12);
}
.to-top:hover { transform: translateY(-2px); }
.reveal {
  opacity:0; transform: translateY(20px); transition: opacity .7s ease, transform .7s ease; transition-delay: var(--reveal-delay, 0ms);
}
.reveal.is-visible {
  opacity:1; transform: translateY(0);
}
@keyframes sweepShine {
  from { left:-120%; }
  to { left:140%; }
}
@keyframes heroFrameFloat {
  0%,100% { transform: translate3d(0,0,0) rotate(0deg); }
  50% { transform: translate3d(-10px,-10px,0) rotate(.45deg); }
}
@keyframes heroFrameFloatSecondary {
  0%,100% { transform: translate3d(0,0,0) rotate(0deg) scale(1); }
  50% { transform: translate3d(14px,12px,0) rotate(-.55deg) scale(1.02); }
}

@keyframes heroIntroFade {
  from { opacity:0; transform:translateY(18px); filter:blur(4px); }
  to { opacity:1; transform:translateY(0); filter:blur(0); }
}
@keyframes heroIntroPanel {
  from { opacity:0; transform:translateY(22px) scale(.985); filter:blur(4px); }
  to { opacity:1; transform:translateY(0) scale(1); filter:blur(0); }
}

@keyframes coalPointFade {
  from { opacity:0; }
  to { opacity:1; }
}
@keyframes coalLabelFade {
  from { opacity:0; }
  to { opacity:1; }
}
@keyframes coalLegendFade {
  from { opacity:0; transform:translateY(6px); }
  to { opacity:1; transform:translateY(0); }
}
@keyframes coalTextFade {
  from { opacity:0; transform:translateY(8px); }
  to { opacity:1; transform:translateY(0); }
}
@keyframes coalStatRise {
  from { opacity:0; transform:translateY(10px); }
  to { opacity:1; transform:translateY(0); }
}
@keyframes slowPan {
  from { transform: scale(1.03) translateX(-1.2%); }
  to { transform: scale(1.07) translateX(1.2%); }
}
@media (max-width: 1180px) {
  .hero-facts { grid-template-columns:1fr; max-width:620px; }
}
@media (max-width: 1180px) {
  .hero .container::before,
  .hero .container::after { display:none; }
}
@media (max-width: 920px) {
  .header-main::after { opacity:.42; }
  .hero-facts { grid-template-columns:1fr; }
}
@media (max-width: 560px) {
  .hero-fact { padding:14px 16px; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .reveal,
  .hero-copy .eyebrow,
  .hero h1,
  .hero-copy > p,
  .hero-actions,
  .hero-facts,
  .hero .hero-panel {
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
  }
}

/* === Блоки головної сторінки === */
.card__icon {
  width:58px; height:58px; margin-bottom:22px; padding:8px; background:#fff; border:1px solid var(--line); box-shadow:0 10px 22px rgba(19,32,51,.05);
}
.doc-row__icon { background:#fff; }
.hero-panel--coal { display:grid; }
.hero-panel__stats {
  display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--line);
}
.hero-panel__stats div { padding:18px 16px; border-right:1px solid var(--line); display:flex; flex-direction:column; gap:6px; }
.hero-panel__stats div:last-child { border-right:0; }
.hero-panel__stats strong { display:block; font-size:22px; line-height:1; color:var(--blue); margin-bottom:0; }
.hero-panel__stats span { font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); }

.hero-panel--coal {
  background: linear-gradient(180deg, rgba(255,255,255,.985), rgba(246,248,251,.985));
  box-shadow: 0 20px 40px rgba(8,13,22,.18);
}
.hero-panel--coal .hero-panel__head {
  display:flex; align-items:center; justify-content:space-between; gap:14px;
}
.hero-panel--coal .hero-panel__head small {
  display:inline-flex; align-items:center; padding:5px 10px; border-radius:999px;
  background:rgba(19,32,51,.06); color:rgba(22,22,22,.72); font-size:11px; line-height:1.2; text-transform:none; letter-spacing:.03em; font-weight:800;
}
.coal-chart {
  position:relative; min-height:190px; margin:0 0 14px; padding:12px 10px 4px; background:linear-gradient(180deg, rgba(19,32,51,.045), rgba(19,32,51,.015)); border:1px solid var(--line); overflow:hidden;
}
.coal-chart__grid {
  position:absolute; inset:12px 10px 26px; background:
    linear-gradient(rgba(19,32,51,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(19,32,51,.055) 1px, transparent 1px);
  background-size:100% 25%, 20% 100%; pointer-events:none;
}
.coal-chart__svg { position:relative; z-index:1; display:block; width:100%; height:170px; color:var(--accent-dark); overflow:visible; }
.coal-chart__axis { stroke:rgba(19,32,51,.22); stroke-width:1; }
.coal-chart__line { fill:none; stroke-width:4; stroke-linecap:round; stroke-linejoin:round; transition:filter .2s ease; }
.coal-chart__line--supply { stroke:var(--accent-dark); }
.coal-chart__line--use { stroke:var(--blue); stroke-width:3; opacity:.78; }
.coal-chart__point { fill:#fff; stroke-width:3; opacity:0; animation: coalPointFade .55s ease forwards; }
.coal-chart__point--supply { stroke:var(--accent-dark); }
.coal-chart__point--use { stroke:var(--blue); }
.coal-chart__label { fill:var(--muted); font-size:11px; font-weight:800; opacity:0; animation: coalLabelFade .55s ease forwards; }
.coal-chart.is-ready .coal-chart__line--supply,
.coal-chart.is-ready .coal-chart__line--use { filter: drop-shadow(0 4px 10px rgba(19,32,51,.08)); }
.coal-legend { display:flex; gap:16px; align-items:center; flex-wrap:wrap; margin:0 0 12px; color:var(--ink-2); font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; }
.coal-legend span { display:inline-flex; align-items:center; gap:7px; opacity:0; animation: coalLegendFade .45s ease forwards; }
.coal-legend span:nth-child(1) { animation-delay:.55s; }
.coal-legend span:nth-child(2) { animation-delay:.68s; }
.coal-legend__line { display:inline-block; width:24px; height:3px; background:var(--accent-dark); }
.coal-legend__line--primary { background:var(--accent-dark); }
.coal-legend__line--muted { background:var(--blue); opacity:.78; }
.hero-panel--coal .coal-panel__title { display:block; width:100%; max-width:none; margin:0 0 8px; color:#1f2f45; font-size:100%; line-height:1.25; font-weight:700; letter-spacing:0; opacity:0; animation: coalTextFade .55s ease .72s forwards; }
.coal-panel__source { display:inline-flex; color:var(--muted); font-size:10px; line-height:1.2; font-weight:700; text-transform:uppercase; letter-spacing:.035em; opacity:0; animation: coalTextFade .55s ease .84s forwards; }
.hero-panel__stats--coal strong { font-size:18px; order:2; }
.hero-panel__stats--coal span { font-size:8.5px; line-height:1.1; order:1; text-transform:uppercase; letter-spacing:.03em; color:var(--muted); white-space:nowrap; }
.hero-panel__stats--coal div { opacity:0; transform:translateY(10px); animation: coalStatRise .55s ease forwards; }
.hero-panel__stats--coal div:nth-child(1) { animation-delay:.72s; }
.hero-panel__stats--coal div:nth-child(2) { animation-delay:.82s; }
.hero-panel__stats--coal div:nth-child(3) { animation-delay:.92s; }

.landing-kpis { margin-top:-34px; position:relative; z-index:2; padding-top:0; }
.kpi-grid {
  display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:18px;
}
.kpi-card {
  background:#fff; border:1px solid var(--line); padding:24px; box-shadow:0 18px 34px rgba(19,32,51,.08); position:relative; overflow:hidden;
}
.kpi-card::before {
  content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:linear-gradient(180deg, var(--accent), rgba(242,184,75,0));
}
.kpi-card__label { display:block; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; font-size:12px; font-weight:800; margin-bottom:12px; }
.kpi-card strong { display:block; font-size:22px; line-height:1.12; margin-bottom:10px; letter-spacing:-.02em; }
.kpi-card p { margin:0; color:var(--ink-2); }
.feature-grid-premium {
  display:grid; grid-template-columns:1.1fr .9fr .9fr; gap:22px; align-items:stretch;
}
.feature-card-premium {
  display:flex; flex-direction:column; min-height:100%; background:#fff; border:1px solid var(--line); box-shadow:0 18px 36px rgba(19,32,51,.07); overflow:hidden; position:relative;
}
.feature-card-premium::before {
  content:""; position:absolute; inset:0; pointer-events:none; background:linear-gradient(180deg, rgba(242,184,75,.05), rgba(242,184,75,0) 24%); opacity:0; transition:opacity .18s ease;
}
.feature-card-premium:hover::before { opacity:1; }
.feature-card-premium__media {
  min-height:220px; background-size:cover; background-position:center; position:relative; transition:transform .6s ease;
}
.feature-card-premium__media::after {
  content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(19,32,51,.03), rgba(19,32,51,.26));
}
.feature-card-premium:hover .feature-card-premium__media { transform:scale(1.04); }
.feature-card-premium__body { padding:28px; display:flex; flex-direction:column; flex:1; }
.feature-card-premium__eyebrow { display:block; margin-bottom:10px; font-size:12px; text-transform:uppercase; letter-spacing:.1em; font-weight:800; color:var(--accent-dark); }
.feature-card-premium h3 { margin:0 0 12px; font-family:var(--font-heading); font-size:26px; line-height:1.14; font-weight:800; letter-spacing:.004em; }
.feature-card-premium:not(.feature-card-premium--main) h3 { font-size:22px; }
.feature-card-premium p { margin:0 0 16px; color:var(--ink-2); }
.feature-card-premium a { margin-top:auto; display:inline-flex; align-items:center; gap:8px; font-weight:900; color:var(--blue); text-transform:uppercase; font-size:13px; }
.feature-card-premium a::after { content:"→"; color:var(--accent-dark); }
.feature-points { list-style:none; margin:0 0 18px; padding:0; display:grid; gap:10px; }
.feature-points li { position:relative; padding-left:18px; color:var(--ink); font-weight:700; }
.feature-points li::before { content:""; position:absolute; left:0; top:.55em; width:8px; height:8px; background:var(--accent); }
.landing-showcase__grid { display:grid; grid-template-columns:1.03fr .97fr; gap:34px; align-items:center; }
.showcase-points { display:grid; gap:16px; margin-top:30px; }
.showcase-point {
  display:grid; grid-template-columns:72px 1fr; gap:16px; align-items:start; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); padding:18px;
}
.showcase-point .card__icon { background:rgba(255,255,255,.96); margin-bottom:0; }
.showcase-point h3 { margin:0 0 6px; font-family:var(--font-heading); font-size:20px; font-weight:800; letter-spacing:.003em; }
.showcase-point p { margin:0; color:#cad4df; }
.showcase-visual {
  position:relative; min-height:560px; overflow:hidden; border:1px solid rgba(255,255,255,.14); box-shadow:0 26px 44px rgba(0,0,0,.18);
}
.showcase-visual__bg {
  position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.03);
}
.showcase-visual::before {
  content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(11,17,27,.28), rgba(11,17,27,.86));
}
.showcase-visual__panel {
  position:absolute; z-index:2; max-width:280px; background:rgba(255,255,255,.97); color:var(--ink); border:1px solid var(--line); box-shadow:0 16px 32px rgba(11,17,27,.16); padding:22px;
}
.showcase-visual__panel span { display:block; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; font-size:12px; font-weight:800; margin-bottom:8px; }
.showcase-visual__panel strong { display:block; font-family:var(--font-heading); font-size:21px; line-height:1.16; margin-bottom:8px; font-weight:800; letter-spacing:.003em; }
.showcase-visual__panel p { margin:0; color:var(--ink-2); }
.showcase-visual__panel--a { top:32px; right:30px; }
.showcase-visual__panel--b { left:28px; bottom:32px; }
.quick-links-grid { display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:18px; }
.quick-link-card {
  background:#fff; border:1px solid var(--line); padding:26px; display:block; color:inherit; box-shadow:0 18px 36px rgba(19,32,51,.06); position:relative; overflow:hidden;
}
.quick-link-card::before { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(242,184,75,.05), rgba(242,184,75,0) 24%); opacity:0; transition:opacity .18s ease; }
.quick-link-card:hover::before { opacity:1; }
.quick-link-card:hover { transform:translateY(-3px); box-shadow:0 24px 42px rgba(19,32,51,.1); }
.quick-link-card h3 { margin:0 0 10px; font-family:var(--font-heading); font-size:21px; font-weight:800; letter-spacing:.003em; }
.quick-link-card p { margin:0; color:var(--ink-2); }
.split--premium { align-items:center; }
.docs-preview-list { display:grid; gap:14px; margin-top:24px; }
.docs-preview-item {
  display:block; padding:18px 20px; border:1px solid var(--line); background:#fff; box-shadow:0 12px 28px rgba(19,32,51,.05);
}
.docs-preview-item strong { display:block; font-size:19px; margin-bottom:4px; color:var(--ink); }
.docs-preview-item span { color:var(--ink-2); }
.landing-docs-visual { position:relative; min-height:520px; }
.landing-docs-visual__image {
  position:absolute; inset:0; background-size:cover; background-position:center; border:1px solid var(--line); box-shadow:0 22px 44px rgba(19,32,51,.1);
}
.landing-docs-visual__image::after {
  content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(19,32,51,.06), rgba(19,32,51,.36));
}
.landing-docs-visual__badge {
  position:absolute; right:26px; bottom:26px; z-index:2; display:grid; grid-template-columns:72px 1fr; gap:14px; align-items:center;
  background:rgba(255,255,255,.97); border:1px solid var(--line); box-shadow:0 16px 32px rgba(19,32,51,.16); padding:18px 20px; max-width:340px;
}
.landing-docs-visual__badge .card__icon { margin-bottom:0; }
.landing-docs-visual__badge strong { display:block; font-size:18px; margin-bottom:4px; }
.landing-docs-visual__badge span { color:var(--ink-2); }
.landing-cta__grid { display:grid; grid-template-columns:1fr auto; gap:28px; align-items:center; }
.landing-cta__actions { display:flex; gap:12px; flex-wrap:wrap; justify-content:flex-end; }
@media (max-width: 1180px) {
  .kpi-grid, .quick-links-grid { grid-template-columns:repeat(2, minmax(0,1fr)); }
  .feature-grid-premium { grid-template-columns:1fr; }
  .landing-showcase__grid, .landing-cta__grid { grid-template-columns:1fr; }
  .landing-cta__actions { justify-content:flex-start; }
}
@media (max-width: 920px) {
  .landing-kpis { margin-top:0; padding-top:24px; }
  .kpi-grid, .quick-links-grid { grid-template-columns:1fr; }
  .hero-panel__stats { grid-template-columns:1fr; }
  .hero-panel__stats div { border-right:0; border-bottom:1px solid var(--line); }
  .hero-panel__stats div:last-child { border-bottom:0; }
  .showcase-visual { min-height:440px; }
  .showcase-visual__panel { max-width:250px; }
  .landing-docs-visual { min-height:380px; }
}
@media (max-width: 560px) {
  .showcase-point { grid-template-columns:1fr; }
  .landing-docs-visual__badge { position:relative; right:auto; bottom:auto; margin:18px 0 0; max-width:none; }
  .landing-docs-visual { min-height:auto; }
  .landing-docs-visual__image { position:relative; min-height:260px; }
}
