/* Self-hosted fonts: Golos Text + Unbounded (cyrillic+latin) */
@font-face{font-family:'Golos Text';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/self/golos-400-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Golos Text';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/self/golos-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Golos Text';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/self/golos-500-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Golos Text';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/self/golos-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Golos Text';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/self/golos-600-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Golos Text';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/self/golos-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Golos Text';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/self/golos-700-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Golos Text';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/self/golos-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Unbounded';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/self/unbounded-500-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Unbounded';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/self/unbounded-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Unbounded';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/self/unbounded-600-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Unbounded';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/self/unbounded-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Unbounded';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/self/unbounded-700-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;}
@font-face{font-family:'Unbounded';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/self/unbounded-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}

/* ============================================================
   ЭкоСибирь — design system (2026 rebuild)
   Palette: сибирская хвоя + фирменный зелёный + латунь (драгметаллы)
   Type: Golos Text (UI/body) + Unbounded (signature display)
   ============================================================ */

:root{
  /* surfaces */
  --paper:        #F4F6EF;   /* cool, green-tinted off-white (not warm cream) */
  --paper-2:      #FFFFFF;
  --tint:         #E8F0DF;   /* light green surface */
  --line:         #E0E5D6;

  /* ink */
  --ink:          #16201A;
  --muted:        #586458;

  /* brand */
  --pine:         #14301E;   /* deep forest — dark sections */
  --pine-2:       #1B3E27;
  --pine-soft:    #24492F;
  --green:        #4F9A2E;   /* brand action */
  --green-bright: #76BD3D;
  --green-ink:    #2C5E1B;

  /* signature accent: recovered precious metals / аффинаж */
  --brass:        #B68A3E;
  --brass-2:      #CBA763;
  --brass-tint:   #F1E8D3;

  --radius:   16px;
  --radius-s: 10px;
  --radius-l: 26px;

  --shadow:    0 1px 2px rgba(20,48,30,.05), 0 8px 28px -12px rgba(20,48,30,.18);
  --shadow-lg: 0 2px 6px rgba(20,48,30,.06), 0 30px 60px -24px rgba(20,48,30,.28);

  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 56px);

  --ff-body: "Golos Text", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --ff-disp: "Unbounded", var(--ff-body);
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
html,body{ overflow-x:clip; }
img,svg{ display:block; max-width:100%; }
picture{ display:contents; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:0; }
ul,ol{ list-style:none; padding:0; }
:focus-visible{ outline:3px solid var(--green-bright); outline-offset:2px; border-radius:4px; }

/* scroll offset for sticky header anchors */
section[id]{ scroll-margin-top:84px; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(64px, 9vw, 120px); }
.section--tight{ padding-block:clamp(48px,6vw,80px); }

/* dark section */
.dark{ background:var(--pine); color:#EAF0E4; }
.dark .eyebrow{ color:var(--green-bright); }
.dark .lead{ color:#C4D2BD; }

/* ---------- type ---------- */
.eyebrow{
  font-family:var(--ff-disp);
  font-weight:600;
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--green-ink);
  display:inline-flex; align-items:center; gap:.55em;
  margin-bottom:18px;
}
.eyebrow::before{
  content:""; width:26px; height:2px; background:currentColor; border-radius:2px;
}
h1,h2,h3{ line-height:1.08; font-weight:600; letter-spacing:-.01em; }
.h-sec{ font-size:clamp(28px, 4vw, 44px); font-weight:600; }
.h-sec .accent{ color:var(--green); }
.lead{ font-size:clamp(17px,2vw,20px); color:var(--muted); max-width:60ch; }
.section-head{ max-width:64ch; margin-bottom:clamp(36px,5vw,56px); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-weight:600; font-size:16px; line-height:1;
  padding:16px 26px; border-radius:999px;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  white-space:nowrap;
}
.btn svg{ width:19px; height:19px; }
.btn--primary{
  background:var(--green); color:#fff;
  box-shadow:0 10px 24px -10px rgba(79,154,46,.7);
}
.btn--primary:hover{ background:#458a28; transform:translateY(-2px); box-shadow:0 16px 30px -12px rgba(79,154,46,.8); }
.btn--ghost{ background:transparent; color:inherit; box-shadow:inset 0 0 0 1.5px currentColor; }
.btn--ghost:hover{ background:rgba(255,255,255,.08); transform:translateY(-2px); }
.dark .btn--ghost{ color:#EAF0E4; }
.btn--light{ background:#fff; color:var(--pine); }
.btn--light:hover{ transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.btn--brass{ background:var(--brass); color:#23170a; }
.btn--brass:hover{ background:#caa153; transform:translateY(-2px); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
  padding-block:14px;
}
.site-header__inner{ display:flex; align-items:center; gap:24px; }
.brand{ display:flex; align-items:center; gap:10px; flex:0 0 auto; }
.brand img{ height:42px; width:auto; }
.site-nav{ margin-left:auto; display:flex; align-items:center; gap:30px; }
.site-nav a.navlink{
  font-size:15px; font-weight:500; color:#EAF0E4;
  position:relative; padding-block:6px; opacity:.9; transition:opacity .2s;
}
.site-nav a.navlink::after{
  content:""; position:absolute; left:0; bottom:0; height:2px; width:0;
  background:var(--green-bright); transition:width .25s ease;
}
.site-nav a.navlink:hover{ opacity:1; }
.site-nav a.navlink:hover::after{ width:100%; }
.header-phone{ font-weight:600; font-size:16px; color:#fff; display:inline-flex; align-items:center; gap:8px; }
.header-phone svg{ width:17px; height:17px; color:var(--green-bright); }

/* scrolled state */
.site-header.scrolled{
  background:rgba(18,40,26,.92);
  backdrop-filter:blur(10px);
  box-shadow:0 10px 30px -18px rgba(0,0,0,.6);
  padding-block:9px;
}

/* burger */
.burger{ display:none; width:44px; height:44px; border-radius:10px; align-items:center; justify-content:center; color:#fff; }
.burger svg{ width:26px; height:26px; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; color:#fff; isolation:isolate;
  padding-top:clamp(130px,18vh,200px); padding-bottom:clamp(60px,9vw,110px);
  background:#0d2415;
}
.hero__bg{ position:absolute; inset:0; z-index:-2; object-fit:cover; width:100%; height:100%; }
.hero::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(13,32,21,.78) 0%, rgba(13,32,21,.58) 40%, rgba(13,32,21,.86) 100%),
    radial-gradient(120% 80% at 12% 10%, rgba(13,32,21,.55), transparent 60%);
}
.hero__inner{ max-width:760px; }
.hero h1{
  font-size:clamp(34px, 5.4vw, 62px);
  font-weight:600; letter-spacing:-.02em; margin-bottom:22px;
}
.hero h1 .hl{ color:var(--green-bright); }
.hero__sub{ font-size:clamp(17px,2.1vw,21px); color:#D4E0CC; max-width:56ch; margin-bottom:34px; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero__note{ margin-top:22px; font-size:14.5px; color:#AEC1A4; display:inline-flex; align-items:center; gap:9px; }
.hero__note svg{ width:18px; height:18px; color:var(--green-bright); flex:0 0 auto; }

/* trust strip */
.trust{
  margin-top:clamp(40px,6vw,64px);
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius); overflow:hidden;
}
.trust__cell{ background:rgba(13,32,21,.55); padding:22px 22px; display:flex; gap:14px; align-items:flex-start; }
.trust__ico{ flex:0 0 auto; width:38px; height:38px; border-radius:10px; display:grid; place-items:center;
  background:rgba(118,189,61,.16); color:var(--green-bright); }
.trust__ico svg{ width:21px; height:21px; }
.trust__t{ display:block; font-weight:600; font-size:15.5px; line-height:1.25; }
.trust__d{ display:block; font-size:13px; color:#A9BCA0; margin-top:3px; }

/* ============================================================
   CLIENTS marquee (logos)
   ============================================================ */
.clients-bar{ background:var(--paper-2); border-bottom:1px solid var(--line); }
.clients-bar .wrap{ display:flex; align-items:center; gap:clamp(24px,5vw,56px); flex-wrap:wrap; justify-content:center; padding-block:26px; }
.clients-bar__label{ font-size:13px; letter-spacing:.04em; color:var(--muted); font-weight:500; }
.clients-bar img{ height:30px; width:auto; filter:grayscale(1); opacity:.62; transition:filter .25s, opacity .25s; }
.clients-bar img:hover{ filter:grayscale(0); opacity:1; }

/* ============================================================
   ABOUT
   ============================================================ */
.about{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,6vw,72px); align-items:center; }
.about__body p{ color:var(--muted); margin-bottom:16px; }
.about__body p strong{ color:var(--ink); }
.about__figure{ position:relative; }
.about__figure img{ width:100%; height:100%; object-fit:cover; border-radius:var(--radius-l); box-shadow:var(--shadow-lg); }
.about__badge{
  position:absolute; left:-18px; bottom:-18px; background:#fff; border-radius:var(--radius);
  padding:18px 22px; box-shadow:var(--shadow-lg); display:flex; gap:14px; align-items:center; max-width:280px;
}
.about__badge .n{ font-family:var(--ff-disp); font-weight:700; font-size:30px; color:var(--green); line-height:1; white-space:nowrap; }
.about__badge .t{ font-size:13.5px; color:var(--muted); line-height:1.3; }

.pledge{ margin-top:18px; font-family:var(--ff-disp); font-weight:500; font-size:clamp(18px,2.4vw,24px); color:var(--green-ink); }

/* ============================================================
   RECYCLE grid (Что утилизируем)
   ============================================================ */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.card{
  background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius);
  padding:26px; transition:transform .2s ease, box-shadow .2s ease, border-color .2s;
}
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:#cfe0c0; }
.card__ico{ width:48px; height:48px; border-radius:12px; display:grid; place-items:center;
  background:var(--tint); color:var(--green-ink); margin-bottom:16px; }
.card__ico svg{ width:25px; height:25px; }
.card h3{ font-size:18px; font-weight:600; margin-bottom:6px; }
.card p{ font-size:14.5px; color:var(--muted); }

/* ============================================================
   WHY (editorial split, dark)
   ============================================================ */
.why{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,72px); align-items:center; }
.why__media img{ border-radius:var(--radius-l); width:100%; height:clamp(320px,42vw,520px); object-fit:cover; box-shadow:var(--shadow-lg); }
.why ul{ display:grid; gap:14px; margin-top:8px; }
.why li{ display:flex; gap:13px; align-items:flex-start; color:#D4E0CC; }
.why li svg{ width:22px; height:22px; color:var(--green-bright); flex:0 0 auto; margin-top:2px; }
.why li b{ color:#fff; font-weight:600; }

/* ============================================================
   PROCESS — signature loop
   ============================================================ */
.process{ position:relative; }
.process-block{ margin-top:clamp(36px,5vw,52px); }
.process-block + .process-block{ margin-top:clamp(44px,6vw,64px); }
.process-block__head{ display:flex; align-items:baseline; gap:16px; flex-wrap:wrap; margin-bottom:28px; padding-bottom:16px; border-bottom:1px solid var(--line); }
.process-block__title{ font-family:var(--ff-disp); font-size:clamp(18px,2.2vw,22px); font-weight:600; color:var(--ink); }
.process-block__note{ font-size:14.5px; color:var(--muted); max-width:52ch; }
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; position:relative; }
.steps--3{ grid-template-columns:repeat(3,1fr); }
.steps--4{ grid-template-columns:repeat(4,1fr); }
.steps::before{
  content:""; position:absolute; left:6%; right:6%; top:38px; height:2px;
  background:repeating-linear-gradient(90deg,var(--line) 0 14px, transparent 14px 26px);
  z-index:0;
}
.step{ position:relative; z-index:1; }
.step__n{
  font-family:var(--ff-disp); font-weight:700; font-size:22px;
  width:76px; height:76px; border-radius:50%; display:grid; place-items:center;
  background:var(--paper); color:var(--green); border:2px solid var(--green);
  margin-bottom:18px; position:relative;
}
.steps .step:last-child .step__n{ color:var(--brass); border-color:var(--brass); background:var(--brass-tint); }
.step__chev{ position:absolute; right:-6px; top:50%; transform:translateY(-50%); color:var(--green-bright); }
.step__chev svg{ width:22px; height:22px; }
.step:last-child .step__chev{ display:none; }
.step h3{ font-size:18px; font-weight:600; margin-bottom:7px; }
.step p{ font-size:14.5px; color:var(--muted); }

/* ============================================================
   DOCUMENTS
   ============================================================ */
.docs{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.doc{
  display:flex; flex-direction:column; gap:14px; min-height:158px;
  background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius);
  padding:22px; transition:transform .2s, box-shadow .2s, border-color .2s;
}
.doc:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:#cfe0c0; }
.doc__ico{ width:46px; height:46px; border-radius:11px; display:grid; place-items:center; color:#fff; flex:0 0 auto; }
.doc__ico svg{ width:24px; height:24px; }
.ic-pdf{ background:#C0392B; }
.ic-doc{ background:#2B6CB0; }
.ic-xls{ background:#2F855A; }
.ic-img{ background:#6B46C1; }
.ic-link{ background:var(--green); }
.doc__t{ font-size:14.5px; font-weight:500; line-height:1.35; }
.doc__more{ margin-top:auto; font-size:13px; color:var(--green); font-weight:600; display:inline-flex; align-items:center; gap:6px; }
.doc__more svg{ width:15px; height:15px; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:840px; margin-inline:auto; }
.faq details{ border-bottom:1px solid var(--line); }
.faq summary{
  list-style:none; cursor:pointer; padding:22px 44px 22px 0; position:relative;
  font-weight:600; font-size:clamp(16px,2vw,19px);
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:""; position:absolute; right:6px; top:26px; width:14px; height:14px;
  border-right:2px solid var(--green); border-bottom:2px solid var(--green);
  transform:rotate(45deg); transition:transform .25s ease;
}
.faq details[open] summary::after{ transform:rotate(-135deg); }
.faq details p{ color:var(--muted); padding:0 44px 22px 0; margin-top:-4px; }

/* ============================================================
   CONTACTS
   ============================================================ */
.contacts{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(32px,5vw,56px); align-items:start; }
.contact-list{ display:grid; gap:22px; }
.contact-item{ display:flex; gap:15px; align-items:flex-start; }
.contact-item__ico{ width:44px; height:44px; flex:0 0 auto; border-radius:12px; display:grid; place-items:center;
  background:var(--tint); color:var(--green-ink); }
.contact-item__ico svg{ width:22px; height:22px; }
.contact-item__label{ display:block; font-size:13px; color:var(--muted); margin-bottom:3px; }
.contact-item__val{ display:block; font-size:17px; font-weight:600; }
.contact-item__val a:hover{ color:var(--green); }
.contact-item__val span{ display:block; font-weight:500; font-size:15px; color:var(--muted); }
.contact-cta{ margin-top:30px; display:flex; flex-wrap:wrap; gap:12px; }
.review-links{ margin-top:26px; }
.review-links__label{ display:block; font-size:13.5px; color:#A9BCA0; margin-bottom:10px; }
.review-links__row{ display:flex; gap:12px; flex-wrap:wrap; }
.review-chip{ display:inline-flex; align-items:center; gap:8px; padding:10px 16px; border-radius:999px;
  font-size:14.5px; font-weight:600; color:#EAF0E4; background:rgba(255,255,255,.06);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.16); transition:background .2s, transform .2s; }
.review-chip:hover{ background:rgba(255,255,255,.12); transform:translateY(-2px); color:#fff; }
.review-chip svg{ width:17px; height:17px; color:var(--brass-2); }

.map-frame{ border-radius:var(--radius-l); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--line); }
.map-frame iframe{ display:block; width:100%; height:440px; border:0; }

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{ background:linear-gradient(120deg,var(--pine) 0%, var(--pine-2) 60%, var(--green-ink) 130%); color:#fff; }
.cta-band__inner{ display:flex; gap:30px; align-items:center; justify-content:space-between; flex-wrap:wrap; }
.cta-band h2{ font-size:clamp(24px,3.4vw,38px); font-weight:600; max-width:18ch; }
.cta-band p{ color:#C4D2BD; margin-top:10px; max-width:46ch; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:#0E2415; color:#9FB295; padding-block:56px 30px; }
.site-footer a{ color:#C7D6BD; }
.site-footer a:hover{ color:var(--green-bright); }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.4fr; gap:32px clamp(24px,4vw,48px); }
.footer-col img{ height:46px; width:auto; opacity:.95; margin-bottom:16px; }
.footer-col--brand p{ font-size:14px; line-height:1.6; color:#90A487; max-width:34ch; }
.footer-h{ font-family:var(--ff-disp); font-size:13px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:#EAF0E4; margin-bottom:16px; }
.footer-col ul{ display:grid; gap:10px; }
.footer-col li a{ font-size:14.5px; }
.site-footer address{ font-style:normal; font-size:14.5px; line-height:1.7; color:#B9C8AE; }
.site-footer address a{ font-weight:500; }
.footer-cta{ margin-top:18px; }
.footer-bottom{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:40px; padding-top:22px; border-top:1px solid rgba(255,255,255,.08); }
.footer-bottom small{ font-size:13px; color:#7E9276; }
@media (max-width:860px){ .footer-grid{ grid-template-columns:1fr 1fr; } .footer-col--brand{ grid-column:1 / -1; } }
@media (max-width:520px){ .footer-grid{ grid-template-columns:1fr; } .footer-bottom{ flex-direction:column; gap:6px; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .trust{ grid-template-columns:repeat(2,1fr); }
  .cards{ grid-template-columns:repeat(2,1fr); }
  .docs{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); gap:30px 22px; }
  .steps::before{ display:none; }
  .step__chev{ display:none; }
}
@media (max-width:820px){
  .site-nav{ position:fixed; inset:0 0 0 auto; width:min(82vw,340px); flex-direction:column;
    align-items:flex-start; gap:8px; background:var(--pine); padding:90px 28px 28px;
    transform:translateX(100%); transition:transform .3s ease; box-shadow:-20px 0 50px -20px rgba(0,0,0,.6); }
  .site-nav.open{ transform:translateX(0); }
  .site-nav a.navlink{ font-size:18px; padding-block:10px; width:100%; }
  .header-phone span{ display:none; }
  .burger{ display:flex; margin-left:auto; z-index:101; }
  .nav-backdrop{ position:fixed; inset:0; background:rgba(8,18,12,.5); opacity:0; visibility:hidden; transition:.3s; z-index:99; }
  .nav-backdrop.show{ opacity:1; visibility:visible; }
  .about,.why,.contacts{ grid-template-columns:1fr; }
  .why__media{ order:-1; }
  .about__badge{ left:auto; right:14px; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .cards,.docs{ grid-template-columns:1fr; }
  .trust{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .hero__cta .btn{ flex:1 1 auto; }
}

/* print-ish / reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; animation:none !important; }
}

/* reveal-on-scroll */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; } }
