@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800&display=swap');

:root{
  --graphite:#2A2F36;
  --slate:#3E4752;
  --light-gray:#E6E8EB;
  --off-white:#F7F7F8;
  --steel-blue:#6F8FAF;
  --steel-blue-dk:#4F6E8C;
  --silver:#C7CCD3;
  --ink:#1A1F26;
  --bg:#ffffff;
  --shadow-sm:0 4px 14px -6px rgba(42,47,54,.10);
  --shadow-md:0 18px 50px -22px rgba(42,47,54,.22);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Montserrat',sans-serif;
  font-weight:400;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img,svg{max-width:100%;display:block}
button{font-family:inherit}
a{color:inherit}

.container{max-width:1320px;margin:0 auto;padding:0 48px}

/* === REVEAL ANIMATIONS === */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease, transform .9s ease}
.reveal.is-in, .reveal.active{opacity:1;transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}
.reveal[data-delay="5"]{transition-delay:.40s}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}

/* === NAV === */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(42,47,54,.08);
  padding:14px 0;
  transition:padding .3s, background .3s;
}
.nav.is-scrolled{padding:10px 0;background:rgba(255,255,255,.94)}
.nav .container{display:flex;justify-content:space-between;align-items:center;gap:24px}
.logo-link{
  display:flex;align-items:center;gap:14px;text-decoration:none;
  font-weight:800;font-size:14px;letter-spacing:.28em;color:var(--graphite)
}
.logo-link .logo-mark{width:42px;height:42px;color:var(--graphite);flex-shrink:0}
.nav-menu{display:flex;gap:38px;list-style:none}
.nav-menu a{
  color:var(--slate);text-decoration:none;font-size:13px;font-weight:500;
  letter-spacing:.05em;transition:color .25s;position:relative;
}
.nav-menu a::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:1.5px;
  background:var(--steel-blue);transform:scaleX(0);transform-origin:left;
  transition:transform .3s;
}
.nav-menu a:hover{color:var(--steel-blue)}
.nav-menu a:hover::after{transform:scaleX(1)}

.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--graphite)}
.nav-toggle svg{width:24px;height:24px}

/* === HERO === */
.hero{
  min-height:100vh;padding:160px 0 100px;position:relative;overflow:hidden;
  background:linear-gradient(180deg,#fff 0%, #F7F7F8 100%);
}
.hero::before{
  content:"";position:absolute;right:-10%;top:20%;
  width:680px;height:680px;
  background:radial-gradient(circle at center,
    rgba(111,143,175,.14) 0%, transparent 65%);
  pointer-events:none;
  animation:sunPulse 10s ease-in-out infinite alternate;
}
@keyframes sunPulse{
  0%{transform:scale(1);opacity:1}
  100%{transform:scale(1.08);opacity:.85}
}

.hero-graphic{
  position:absolute;right:6%;top:40%;transform:translateY(-50%);
  width:520px;height:520px;pointer-events:none;opacity:.9;
}
.hero-graphic svg{width:100%;height:100%;overflow:visible}

/* Сигнатурная анимация горизонта */
.hg-horizon-line,.hg-arc,.hg-ray{
  stroke-dasharray:520;stroke-dashoffset:520;
  animation:drawLine 1.8s ease-out forwards;
}
.hg-arc{animation-delay:.2s}
.hg-ray-1{animation-delay:.6s}
.hg-ray-2{animation-delay:.75s}
.hg-ray-3{animation-delay:.9s}
.hg-ray-4{animation-delay:1.05s}
.hg-ray-5{animation-delay:1.2s}
.hg-glow{opacity:0;animation:fadeIn 1.2s ease-out 1.4s forwards}
@keyframes drawLine{to{stroke-dashoffset:0}}
@keyframes fadeIn{to{opacity:1}}

.hero .container{position:relative;z-index:2}
.hero-eyebrow{
  font-size:11px;letter-spacing:.32em;font-weight:600;
  color:var(--steel-blue);text-transform:uppercase;
  display:inline-flex;align-items:center;gap:14px;margin-bottom:40px;
}
.hero-eyebrow::before{content:"";width:48px;height:1px;background:var(--steel-blue)}

.hero h1{
  font-size:clamp(52px,7.5vw,112px);
  font-weight:300;line-height:.95;letter-spacing:-.03em;
  color:var(--graphite);max-width:1000px;margin-bottom:36px;
}
.hero h1 b{font-weight:700}
.hero h1 .accent{
  font-weight:500;font-style:italic;color:var(--steel-blue);
}
.hero-sub{
  font-size:18px;color:var(--slate);max-width:560px;
  margin-bottom:56px;font-weight:400;line-height:1.65;
}
.hero-cta{display:flex;gap:16px;align-items:center;flex-wrap:wrap}

.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 34px;font-family:inherit;font-size:13px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;text-decoration:none;
  border:none;cursor:pointer;transition:all .3s;
}
.btn-primary{background:var(--graphite);color:#fff}
.btn-primary:hover{background:var(--steel-blue-dk);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-ghost{background:transparent;color:var(--graphite);border:1px solid var(--graphite)}
.btn-ghost:hover{background:var(--graphite);color:#fff}
.btn .arrow{display:inline-block;transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

.hero-stats{
  margin-top:80px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--light-gray);padding-top:30px;
}
.hero-stat{padding-right:24px}
.hero-stat-num{
  font-size:42px;font-weight:300;color:var(--graphite);
  letter-spacing:-.02em;line-height:1;margin-bottom:8px;
}
.hero-stat-num b{font-weight:600;color:var(--steel-blue)}
.hero-stat-lbl{font-size:11px;color:var(--slate);letter-spacing:.08em;text-transform:uppercase;font-weight:500}

/* === SECTIONS === */
section{padding:120px 0;position:relative}
.section-label{
  font-size:11px;letter-spacing:.32em;font-weight:600;
  color:var(--steel-blue);text-transform:uppercase;margin-bottom:24px;
  display:flex;align-items:center;gap:14px;
}
.section-label::before{content:"";width:32px;height:1px;background:var(--steel-blue)}
.section-title{
  font-size:clamp(34px,5vw,62px);font-weight:300;
  color:var(--graphite);letter-spacing:-.02em;line-height:1.06;
  margin-bottom:48px;max-width:900px;
}
.section-title b{font-weight:600}
.section-title .acc{color:var(--steel-blue);font-style:italic;font-weight:500}

/* === ABOUT === */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:start}
.about-text{font-size:17px;color:var(--slate);line-height:1.8;font-weight:400}
.about-text p{margin-bottom:22px}
.about-text p.lead{font-size:21px;color:var(--graphite);font-weight:500;line-height:1.5;border-left:2px solid var(--steel-blue);padding-left:22px;margin-bottom:28px}
.about-visual{
  aspect-ratio:1/1.15;background:var(--off-white);
  position:relative;overflow:hidden;border:1px solid var(--light-gray);
}
.about-visual::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(135deg,transparent 50%,rgba(111,143,175,.10) 100%),
    repeating-linear-gradient(90deg,transparent 0,transparent 49px,rgba(42,47,54,.04) 50px);
}
.about-visual-mark{
  position:absolute;bottom:60px;left:60px;right:60px;
}
.about-visual-mark svg{width:100%;height:auto;color:var(--graphite)}

/* === VALUES === */
.values{background:var(--off-white)}
.values-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;
  border-top:1px solid var(--light-gray);border-left:1px solid var(--light-gray);}
.value-card{
  padding:42px 28px;background:#fff;
  border-right:1px solid var(--light-gray);
  border-bottom:1px solid var(--light-gray);
  transition:background .3s, transform .3s;
  position:relative;
}
.value-card:hover{background:#fbfbfc;transform:translateY(-3px)}
.value-num{
  font-size:11px;color:var(--silver);letter-spacing:.18em;
  font-weight:600;margin-bottom:32px;
}
.value-icon{
  width:32px;height:32px;margin-bottom:24px;color:var(--steel-blue);
  transition:transform .35s;
}
.value-card:hover .value-icon{transform:scale(1.1) rotate(-2deg)}
.value-card h3{
  font-size:17px;font-weight:600;color:var(--graphite);
  margin-bottom:12px;letter-spacing:-.01em;
}
.value-card p{font-size:13px;color:var(--slate);line-height:1.6}

/* === HIGHLIGHTS === */
.highlights-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:56px;flex-wrap:wrap;gap:32px;
}
.highlights-header .section-title{margin-bottom:0}
.highlights-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:20px;
}
.hl-card{
  position:relative;background:#fff;border:1px solid var(--light-gray);
  overflow:hidden;transition:all .3s; isolation:isolate;
}
.hl-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
.hl-card.large{grid-column:span 7;aspect-ratio:16/10}
.hl-card.small{grid-column:span 5;aspect-ratio:4/5}
.hl-card.medium{grid-column:span 6;aspect-ratio:16/11}
.hl-img{
  position:absolute;inset:0;
  background:var(--graphite);
  overflow:hidden;
}
.hl-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s cubic-bezier(.16, 1, .3, 1), filter .6s;
}
.hl-card:hover .hl-img img{
  transform:scale(1.05);
  filter:brightness(0.7);
}
.hl-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.72) 100%);
}
.hl-img::before{
  content:"";position:absolute;right:-20%;top:-20%;width:60%;height:60%;
  background:radial-gradient(circle,rgba(111,143,175,.4) 0%,transparent 70%);
}
.hl-content{
  position:absolute;bottom:0;left:0;right:0;padding:32px 32px 28px;color:#fff;z-index:2;
}
.hl-tag{
  display:inline-block;font-size:10px;letter-spacing:.18em;font-weight:600;
  color:var(--steel-blue);text-transform:uppercase;margin-bottom:14px;
}
.hl-content h3{
  font-size:24px;font-weight:500;
  line-height:1.2;margin-bottom:10px;letter-spacing:-.01em;
}
.hl-content p{font-size:13px;color:rgba(255,255,255,.75);line-height:1.55;max-width:480px}
.hl-card.small .hl-content p{display:none}
.hl-year{
  position:absolute;top:24px;right:24px;z-index:2;color:#fff;
  font-size:11px;font-weight:600;letter-spacing:.12em;
  border:1px solid rgba(255,255,255,.3);padding:5px 11px;
}

/* === ALL PROJECTS === */
.projects{background:linear-gradient(135deg, #4A6B8C 0%, #2A3B4C 100%);color:#fff}
.projects .section-label{color:#fff;opacity:.7}
.projects .section-title{color:#fff}
.year-block{
  display:grid;grid-template-columns:200px 1fr;gap:80px;
  padding:48px 0;border-top:1px solid rgba(255,255,255,.1);
}
.year-block.hidden{display:none}
.year-num{
  font-size:72px;font-weight:300;color:#fff;letter-spacing:-.03em;
  line-height:1;position:sticky;top:120px;
}
.year-num span{color:#fff;font-weight:500;opacity:.85}
.proj-list{display:flex;flex-direction:column;gap:0}
.proj-item{
  padding:20px 0;border-bottom:1px solid rgba(255,255,255,.08);
  display:flex;align-items:flex-start;gap:24px;
  transition:padding-left .3s,color .3s;cursor:default;
}
.proj-item:hover{padding-left:14px;color:#fff}
.proj-item:hover .proj-dot{background:#fff;transform:scale(1.4)}
.proj-dot{
  width:6px;height:6px;background:var(--silver);margin-top:9px;flex-shrink:0;
  transition:background .25s, transform .25s;
}
.proj-name{font-size:16px;color:rgba(255,255,255,.82);line-height:1.5;font-weight:400}

/* === TEAM === */
.team{background:#fff}
.team-grid{display:grid;grid-template-columns:minmax(280px,560px);gap:24px}
.team-card{
  background:var(--off-white);padding:32px 28px 28px;border:1px solid var(--light-gray);
  transition:all .35s;text-align:left;
}
.team-card:hover{background:#fff;border-color:var(--steel-blue);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.avatar{
  width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,var(--steel-blue) 0%,var(--steel-blue-dk) 100%);
  display:flex;align-items:center;justify-content:center;color:#fff;
  font-size:30px;font-weight:300;letter-spacing:.05em;margin-bottom:22px;
}
.team-name{font-size:17px;font-weight:600;color:var(--graphite);margin-bottom:6px;letter-spacing:-.01em}
.team-role{font-size:12px;color:var(--steel-blue);font-weight:600;letter-spacing:.12em;text-transform:uppercase}
.team-desc{font-size:13px;color:var(--slate);line-height:1.6;margin-top:14px}
.team-card.head{background:linear-gradient(135deg,var(--graphite) 0%,var(--slate) 100%);color:#fff;border-color:transparent}
.team-card.head .avatar{background:#fff;color:var(--graphite)}
.team-card.head .team-name{color:#fff}
.team-card.head .team-role{color:var(--steel-blue)}
.team-card.head .team-desc{color:rgba(255,255,255,.75)}

/* === PARTNERS === */
.partners-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--light-gray);
  border:1px solid var(--light-gray);
}
.partner{
  background:#fff;padding:44px 24px;display:flex;align-items:center;justify-content:center;
  min-height:128px;text-align:center;
  font-size:13px;font-weight:600;color:var(--graphite);line-height:1.3;
  transition:background .3s;position:relative;overflow:hidden;
}
.partner:hover{background:var(--off-white)}
.partner::before{
  content:"";position:absolute;left:0;right:0;top:0;height:2px;
  background:var(--steel-blue);transform:scaleX(0);transform-origin:center;
  transition:transform .35s;
}
.partner:hover::before{transform:scaleX(1)}
.partner img{max-height:58px;width:auto;max-width:180px;object-fit:contain;transition:transform .35s}
.partner:hover img{transform:translateY(-2px)}
.partner--dark{background:var(--graphite)}
.partner--dark:hover{background:var(--slate)}
.partner--dark .partner-index{color:rgba(255,255,255,.42)}
.partner--first img{max-height:74px}

/* === CONTACT FORM === */
.contact{background:var(--off-white)}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:start}
.contact-info p{font-size:16px;color:var(--slate);line-height:1.7;margin-bottom:14px}
.contact-info .info-line{
  display:flex;align-items:center;gap:14px;padding:18px 0;border-bottom:1px solid var(--light-gray);
  font-size:14px;color:var(--graphite);
}
.contact-info .info-line strong{font-weight:600;min-width:120px;color:var(--slate);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.contact-info .info-line a{color:var(--graphite);text-decoration:none;transition:color .25s}
.contact-info .info-line a:hover{color:var(--steel-blue)}

.contact-form{background:#fff;padding:40px 36px;border:1px solid var(--light-gray)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.form-row.single{grid-template-columns:1fr}
.form-field label{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);margin-bottom:8px;font-weight:600}
.form-field input,.form-field textarea{
  width:100%;font-family:inherit;font-size:14px;color:var(--graphite);
  background:transparent;border:none;border-bottom:1.5px solid var(--light-gray);
  padding:10px 0;transition:border-color .25s;
}
.form-field input:focus,.form-field textarea:focus{outline:none;border-bottom-color:var(--steel-blue)}
.form-field textarea{resize:vertical;min-height:80px;font-family:inherit}
.form-consent{display:flex;align-items:flex-start;gap:10px;font-size:12px;color:var(--slate);line-height:1.5;margin:22px 0}
.form-consent input{margin-top:3px;accent-color:var(--steel-blue);flex-shrink:0}
.form-consent a{color:var(--steel-blue);text-decoration:underline}
.contact-form .btn{width:100%;justify-content:center}

/* === CTA === */
.cta{
  background:var(--graphite);color:#fff;text-align:center;padding:140px 0;
  position:relative;overflow:hidden;
}
.cta::before{
  content:"";position:absolute;left:50%;top:50%;
  width:1200px;height:1200px;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(111,143,175,.15) 0%,transparent 50%);
}
.cta .container{position:relative;z-index:2}
.cta h2{
  font-size:clamp(36px,5.5vw,72px);font-weight:300;
  letter-spacing:-.02em;line-height:1.05;margin-bottom:32px;
}
.cta h2 b{font-weight:600;color:var(--steel-blue)}
.cta p{font-size:17px;color:rgba(255,255,255,.75);margin-bottom:48px;max-width:560px;margin-left:auto;margin-right:auto}
.cta .btn-primary{background:var(--steel-blue);color:var(--graphite)}
.cta .btn-primary:hover{background:#fff;color:var(--graphite)}

/* === FOOTER === */
footer{background:#000;color:rgba(255,255,255,.5);padding:64px 0 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand{font-size:13px;letter-spacing:.28em;font-weight:700;color:#fff;margin-bottom:16px;display:flex;align-items:center;gap:12px}
.footer-brand .logo-mark{width:32px;height:32px;color:#fff}
.footer-tag{font-size:13px;line-height:1.65;max-width:300px}
.footer-grid h4{color:#fff;font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
.footer-grid a{display:block;color:rgba(255,255,255,.5);text-decoration:none;font-size:13px;margin-bottom:10px;transition:color .25s}
.footer-grid a:hover{color:var(--steel-blue)}
.footer-legal{
  border-top:1px solid rgba(255,255,255,.1);padding-top:28px;font-size:11px;color:rgba(255,255,255,.4);line-height:1.7
}
.footer-legal p{margin-bottom:8px}
.footer-legal strong{color:rgba(255,255,255,.65);font-weight:600}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);padding-top:20px;margin-top:24px;
  display:flex;justify-content:space-between;font-size:11px;letter-spacing:.06em;gap:16px;flex-wrap:wrap;
}

/* === LEGAL PAGE === */
.page-legal{padding:140px 0 80px;background:var(--off-white);min-height:100vh}
.legal-title{font-size:clamp(34px,4.5vw,54px);font-weight:300;color:var(--graphite);margin-bottom:18px;letter-spacing:-.02em}
.legal-title b{font-weight:600}
.legal-sub{font-size:16px;color:var(--slate);max-width:780px;margin-bottom:56px;line-height:1.65}
.legal-card{background:#fff;border:1px solid var(--light-gray);padding:40px 44px;margin-bottom:24px}
.legal-card h2{font-size:20px;font-weight:600;color:var(--graphite);margin-bottom:6px;letter-spacing:-.01em}
.legal-card .legal-sub2{font-size:13px;color:var(--steel-blue);letter-spacing:.14em;text-transform:uppercase;font-weight:600;margin-bottom:26px}
.legal-table{display:grid;grid-template-columns:280px 1fr;gap:14px 28px}
.legal-table dt{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);font-weight:600;padding-top:3px}
.legal-table dd{font-size:14px;color:var(--graphite);line-height:1.55;word-break:break-word}
.legal-back{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--steel-blue);text-decoration:none;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:30px}
.legal-back:hover{color:var(--graphite)}

.privacy-content{background:#fff;padding:50px 56px;border:1px solid var(--light-gray);font-size:15px;color:var(--slate);line-height:1.75;max-width:880px}
.privacy-content h2{font-size:22px;color:var(--graphite);margin:32px 0 14px;font-weight:600}
.privacy-content h2:first-child{margin-top:0}
.privacy-content h3{font-size:16px;color:var(--graphite);margin:22px 0 10px;font-weight:600}
.privacy-content p{margin-bottom:14px}
.privacy-content ul{margin:0 0 14px 24px}
.privacy-content li{margin-bottom:8px}

/* === COOKIE BANNER === */
.cookie{
  position:fixed;left:20px;right:20px;bottom:20px;z-index:200;
  background:var(--graphite);color:#fff;padding:18px 24px;
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 24px 60px -20px rgba(0,0,0,.4);
  transform:translateY(120%);transition:transform .5s;font-size:13px;line-height:1.5;
  max-width:880px;margin:0 auto;
}
.cookie.is-show{transform:translateY(0)}
.cookie p{margin:0;flex:1;min-width:240px}
.cookie a{color:var(--steel-blue);text-decoration:underline}
.cookie button{
  background:var(--steel-blue);color:var(--graphite);border:none;
  padding:11px 24px;font-size:11px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;cursor:pointer;transition:background .25s;
}
.cookie button:hover{background:#fff}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .container{padding:0 28px}
  .nav-menu{display:none}
  .nav-menu.is-open, .nav-menu.active{display:flex;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:24px 28px;border-bottom:1px solid var(--light-gray);gap:18px}
  .nav-toggle{display:block}
  .hero{padding:130px 0 80px}
  .hero-graphic{opacity:.35;width:350px;height:350px;right:-80px}
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:24px}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .highlights-grid{grid-template-columns:1fr;gap:18px}
  .hl-card.large,.hl-card.medium,.hl-card.small{grid-column:span 1;aspect-ratio:4/3}
  .year-block{grid-template-columns:1fr;gap:24px}
  .year-num{position:static;font-size:48px}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .partners-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .legal-table{grid-template-columns:1fr;gap:4px 0}
  .legal-table dt{margin-top:18px}
  .legal-table dt:first-child{margin-top:0}
  .privacy-content{padding:32px 24px}
  .legal-card{padding:28px 24px}
}
@media(max-width:560px){
  .hero h1{font-size:44px}
  .hero-stats{grid-template-columns:1fr 1fr;gap:18px}
  .hero-stat-num{font-size:32px}
  .values-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .partners-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .cookie{flex-direction:column;align-items:stretch}
  .cookie button{width:100%}
}


/* === PREMIUM CASES + POLISH === */
body.has-open-modal{overflow:hidden}
.case-more{
  display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:10px 14px;
  border:1px solid currentColor;background:rgba(255,255,255,.08);color:inherit;
  font:inherit;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  cursor:pointer;transition:transform .25s, background .25s, border-color .25s;
}
.case-more:hover{transform:translateY(-2px);background:rgba(255,255,255,.16)}
.case-modal{position:fixed;inset:0;z-index:500;display:none;align-items:center;justify-content:center;padding:28px;}
.case-modal.is-open{display:flex}
.case-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.68);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.case-modal__dialog{position:relative;z-index:2;width:min(1040px,100%);max-height:min(760px,92vh);display:grid;grid-template-columns:.92fr 1.08fr;overflow:hidden;box-shadow:0 40px 120px rgba(0,0,0,.35);outline:none}
.case-modal__close{position:absolute;top:18px;right:18px;z-index:5;width:42px;height:42px;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.25);color:#fff;font-size:26px;line-height:1;cursor:pointer;transition:background .25s, transform .25s}
.case-modal__close:hover{background:rgba(255,255,255,.14);transform:rotate(90deg)}
.case-modal__visual{min-height:520px;position:relative;overflow:hidden;background:#111}
.case-modal__visual::before{content:"";position:absolute;inset:0;background:var(--case-visual,linear-gradient(135deg,#1b1f26,#6f8faf));}
.case-modal__visual::after{content:"";position:absolute;inset:28px;border:1px solid rgba(255,255,255,.22);background:repeating-linear-gradient(90deg,transparent 0,transparent 54px,rgba(255,255,255,.06) 55px),repeating-linear-gradient(0deg,transparent 0,transparent 54px,rgba(255,255,255,.05) 55px)}
.case-modal__body{padding:50px;overflow:auto}
.case-modal__meta{font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;opacity:.72}
.case-modal__body h3{font-size:clamp(28px,3.5vw,46px);line-height:1.05;margin:0 0 18px;letter-spacing:-.02em}
.case-modal__lead{font-size:17px;line-height:1.7;margin-bottom:28px;opacity:.82}
.case-modal__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:28px}
.case-modal__grid div{padding:18px;border:1px solid currentColor;background:rgba(255,255,255,.04)}
.case-modal__grid strong{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:8px;opacity:.6}
.case-modal__grid span{font-size:13px;line-height:1.55;opacity:.88}
.case-modal__cta{width:max-content;max-width:100%}
.avatar{overflow:hidden;flex-shrink:0}
.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
@media (max-width:760px){.case-modal{padding:12px}.case-modal__dialog{grid-template-columns:1fr;max-height:94vh}.case-modal__visual{min-height:220px}.case-modal__body{padding:28px 22px}.case-modal__grid{grid-template-columns:1fr}.case-modal__close{top:12px;right:12px}}

.hero{background:linear-gradient(180deg,#fff 0%,#f6f7f8 55%,#edf1f5 100%)}
.hero::after{content:"";position:absolute;left:-12%;bottom:-18%;width:540px;height:540px;background:radial-gradient(circle,rgba(42,47,54,.08),transparent 66%);pointer-events:none}
.about-grid{align-items:center;gap:72px}.about-visual{aspect-ratio:4/3;border-radius:0;background:linear-gradient(135deg,#f7f7f8,#e9edf1)}.about-visual-mark{inset:70px;display:flex;align-items:center;justify-content:center}.about-visual-mark svg{max-height:210px}.about-visual-chip{position:absolute;top:28px;left:28px;z-index:2;padding:9px 12px;background:#fff;border:1px solid var(--light-gray);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--slate);font-weight:700}.about-visual::after{content:"";position:absolute;right:28px;bottom:28px;width:120px;height:120px;border-right:1px solid rgba(42,47,54,.18);border-bottom:1px solid rgba(42,47,54,.18)}
.hl-img img{display:block}.hl-img{background:linear-gradient(135deg,var(--graphite),var(--slate))}.hl-card[data-case="g-vdnh"] .hl-img{background:linear-gradient(135deg,#24313d,#6f8faf)}.hl-card[data-case="g-zarnitsa"] .hl-img{background:linear-gradient(135deg,#2a2f36,#8b8f96)}.hl-card[data-case="g-orlyonok"] .hl-img{background:linear-gradient(135deg,#314256,#7f9ebb)}.hl-card[data-case="g-firstaid"] .hl-img{background:linear-gradient(135deg,#27333f,#9aa6b4)}.hl-card[data-case="g-spring"] .hl-img{background:linear-gradient(135deg,#2f3742,#6f8faf)}.hl-card[data-case="g-plener"] .hl-img{background:linear-gradient(135deg,#29313a,#c7ccd3)}.hl-card[data-case="g-together"] .hl-img{background:linear-gradient(135deg,#1f2833,#6f8faf)}.hl-img::before{z-index:1;background:radial-gradient(circle at 70% 20%,rgba(255,255,255,.24),transparent 34%),repeating-linear-gradient(90deg,transparent 0,transparent 44px,rgba(255,255,255,.08) 45px)}
.case-modal__dialog{background:#fff;color:var(--graphite);border:1px solid rgba(255,255,255,.5)}.case-modal__meta{color:var(--steel-blue)}.case-modal__grid div{border-color:var(--light-gray);background:var(--off-white)}.case-modal__visual{--case-visual:linear-gradient(135deg,#2A2F36 0%,#6F8FAF 100%)}

/* === FOLLOW-UP PREMIUM POLISH === */
.leadership-grid{grid-template-columns:minmax(300px,720px)}
.leadership-card{
  display:grid;
  grid-template-columns:minmax(180px,260px) 1fr;
  gap:30px;
  align-items:end;
  padding:0;
  min-height:340px;
  background:linear-gradient(135deg,#2A2F36 0%,#39424d 100%);
}
.leader-portrait{
  align-self:stretch;
  min-height:340px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:28px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,0)),
    repeating-linear-gradient(90deg,rgba(255,255,255,.09) 0 1px,transparent 1px 44px),
    linear-gradient(135deg,#eef1f4,#c7ccd3);
  color:var(--graphite);
  position:relative;
  overflow:hidden;
}
.leader-portrait::before{
  content:"";
  position:absolute;
  inset:28px;
  border:1px solid rgba(42,47,54,.18);
}
.leader-portrait::after{
  content:"";
  position:absolute;
  right:-40px;
  top:42px;
  width:170px;
  height:170px;
  border:1px solid rgba(42,47,54,.18);
  transform:rotate(12deg);
}
.leader-portrait span{
  position:relative;
  z-index:1;
  font-size:72px;
  font-weight:300;
  line-height:1;
  letter-spacing:-.08em;
}
.leadership-card .team-name,
.leadership-card .team-role,
.leadership-card .team-desc{margin-right:34px}
.leadership-card .team-desc{font-size:15px;max-width:360px;margin-bottom:34px}
.partners-ledger{
  grid-template-columns:repeat(5,minmax(0,1fr));
  background:#fff;
  gap:0;
  border-top:1px solid var(--light-gray);
  border-left:0;
  border-right:0;
}
.partners-ledger .partner{
  justify-content:center;
  text-align:center;
  min-height:118px;
  padding:34px 24px 28px;
  border-right:1px solid var(--light-gray);
  border-bottom:1px solid var(--light-gray);
}
.partner-index{
  position:absolute;
  left:24px;
  top:31px;
  color:var(--silver);
  font-size:10px;
  font-weight:700;
  letter-spacing:.18em;
}
.case-modal{padding:36px}
.case-modal__backdrop{
  background:rgba(26,31,38,.36);
  backdrop-filter:blur(18px) saturate(110%);
  -webkit-backdrop-filter:blur(18px) saturate(110%);
}
.case-modal__dialog{
  width:min(1080px,100%);
  grid-template-columns:360px 1fr;
  background:#f8f8f9;
  color:var(--graphite);
  border:1px solid rgba(42,47,54,.14);
  box-shadow:0 34px 100px rgba(42,47,54,.28);
}
.case-modal__dialog::before{
  content:"";
  position:absolute;
  inset:18px;
  border:1px solid rgba(42,47,54,.10);
  pointer-events:none;
}
.case-modal__visual{
  min-height:560px;
  background:#e7ebef;
  --case-visual:
    radial-gradient(circle at 72% 22%,rgba(111,143,175,.36),transparent 30%),
    linear-gradient(135deg,#f4f5f6 0%,#c9d1d9 48%,#2A2F36 100%);
}
.case-modal__visual::after{
  inset:24px;
  border-color:rgba(42,47,54,.24);
  background:
    linear-gradient(90deg,rgba(42,47,54,.20),rgba(42,47,54,0) 40%),
    repeating-linear-gradient(90deg,transparent 0,transparent 42px,rgba(42,47,54,.08) 43px),
    repeating-linear-gradient(0deg,transparent 0,transparent 42px,rgba(42,47,54,.06) 43px);
}
.case-modal__body{
  padding:64px 58px 54px;
  background:
    linear-gradient(90deg,rgba(230,232,235,.74),rgba(255,255,255,0) 32%),
    #fff;
}
.case-modal__body h3{font-weight:400}
.case-modal__grid{gap:1px;background:var(--light-gray);border:1px solid var(--light-gray)}
.case-modal__grid div{border:0;background:#fff}
.case-modal__close{background:#fff;color:var(--graphite);border-color:var(--light-gray)}
@media(max-width:760px){
  .leadership-card{grid-template-columns:1fr}
  .leader-portrait{min-height:220px}
  .leadership-card .team-name,.leadership-card .team-role,.leadership-card .team-desc{margin-left:24px;margin-right:24px}
  .leadership-card .team-desc{margin-bottom:28px}
  .partners-ledger{grid-template-columns:1fr}
}

/* === GORIZONT FINAL PASS === */
.hero-stats{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1px;
  border-top:0;
  padding-top:0;
  background:rgba(42,47,54,.10);
  max-width:1060px;
}
.hero-stat{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.55);
  padding:26px 24px;
  min-height:132px;
}
.hero-stat-num{font-size:clamp(34px,4vw,48px)}
.hero-stat-num.stat-word{
  font-size:clamp(24px,2.7vw,36px);
  letter-spacing:-.04em;
  white-space:nowrap;
}
.hero-stat-num.stat-word b{color:var(--graphite)}
.hero-stat-lbl{line-height:1.45}
.about-visual{
  min-height:520px;
  overflow:hidden;
  border-radius:34px;
  background:
    radial-gradient(circle at 50% 52%,rgba(111,143,175,.20),transparent 36%),
    linear-gradient(135deg,#f7f7f8,#e6ebf0);
}
.about-visual::before{border-radius:34px}
.about-visual-chip{
  border-radius:999px;
  box-shadow:0 18px 45px -30px rgba(42,47,54,.45);
}
.about-visual-mark{
  left:84px;
  right:84px;
  top:auto;
  bottom:34px;
  z-index:2;
  filter:drop-shadow(0 22px 40px rgba(42,47,54,.18));
  animation:gorizontSunFloat 8s ease-in-out infinite;
}
.about-floating-tags{
  position:absolute;
  inset:0;
  z-index:4;
  pointer-events:none;
}
.about-floating-tags span{
  position:absolute;
  padding:9px 13px;
  border:1px solid rgba(42,47,54,.12);
  border-radius:999px;
  background:rgba(255,255,255,.74);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  color:var(--slate);
  font-size:10px;
  font-weight:700;
  letter-spacing:.13em;
  text-transform:uppercase;
  box-shadow:0 18px 45px -32px rgba(42,47,54,.6);
  animation:tagFloat 7s ease-in-out infinite;
}
.about-floating-tags span:nth-child(1){left:6%;top:10%;animation-delay:-1s}
.about-floating-tags span:nth-child(2){right:8%;top:13%;animation-delay:-2.4s}
.about-floating-tags span:nth-child(3){left:5%;top:44%;animation-delay:-3.1s}
.about-floating-tags span:nth-child(4){right:5%;top:42%;animation-delay:-1.8s}
.about-floating-tags span:nth-child(5){left:31%;top:24%;animation-delay:-4s}
.about-floating-tags span:nth-child(6){right:24%;top:28%;animation-delay:-2.9s}
.about-floating-tags span:nth-child(7){left:45%;top:9%;animation-delay:-5.2s}
.about-floating-tags span:nth-child(8){left:8%;top:68%;animation-delay:-3.7s}
.about-floating-tags span:nth-child(9){left:20%;top:57%;animation-delay:-5.5s}
.about-floating-tags span:nth-child(10){right:13%;top:70%;animation-delay:-2.1s}
.about-floating-tags span:nth-child(11){left:46%;top:50%;animation-delay:-4.7s}
@keyframes gorizontSunFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes tagFloat{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(5px,-7px,0)}}
.hl-card{cursor:pointer;border-radius:0}
.hl-img img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(.96) contrast(1.04) brightness(.82);
}
.hl-img::after{
  background:
    linear-gradient(180deg,rgba(0,0,0,.04) 18%,rgba(0,0,0,.42) 58%,rgba(0,0,0,.84) 100%),
    radial-gradient(circle at 72% 22%,rgba(111,143,175,.18),transparent 34%);
}
.hl-img::before{
  opacity:.42;
  mix-blend-mode:screen;
}
.leadership-grid{
  grid-template-columns:minmax(320px,880px);
  justify-content:center;
}
.leadership-card{
  grid-template-columns:minmax(260px,360px) 1fr;
  grid-template-rows:auto auto;
  gap:0;
  align-content:center;
  align-items:center;
  min-height:430px;
  width:min(880px,100%);
  margin:0 auto;
  border-radius:34px;
  overflow:hidden;
  box-shadow:0 28px 80px -46px rgba(42,47,54,.58);
}
.leadership-card .leader-portrait{
  grid-row:1 / 3;
  min-height:430px;
  padding:0;
  background:#dfe4ea;
}
.leader-portrait img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 18%;
  filter:saturate(.96) contrast(1.04);
}
.leader-portrait::before{
  z-index:2;
  inset:22px;
  border-color:rgba(255,255,255,.24);
}
.leader-portrait::after{
  z-index:2;
  right:-64px;
  top:34px;
  width:190px;
  height:190px;
  border-color:rgba(255,255,255,.20);
}
.leadership-card .team-name,
.leadership-card .team-role,
.leadership-card .team-desc{
  grid-column:2;
  margin-left:44px;
  margin-right:44px;
}
.leadership-card .team-name{
  align-self:end;
  font-size:clamp(24px,3vw,34px);
  line-height:1.08;
  max-width:420px;
}
.leadership-card .team-role{margin-top:10px}
.leadership-card .team-desc{
  max-width:440px;
  font-size:16px;
  line-height:1.7;
  margin-top:16px;
  margin-bottom:0;
}
.case-modal__img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  z-index:1;
  display:none;
  filter:saturate(.98) contrast(1.04) brightness(.86);
}
.case-modal__visual::before{z-index:0}
.case-modal__visual::after{
  z-index:2;
  pointer-events:none;
  background:
    linear-gradient(180deg,rgba(42,47,54,.04),rgba(42,47,54,.44)),
    repeating-linear-gradient(90deg,transparent 0,transparent 42px,rgba(255,255,255,.08) 43px);
}
@media(max-width:1024px){
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .partners-ledger{grid-template-columns:repeat(3,minmax(0,1fr))}
  .about-visual{min-height:440px;overflow:hidden}
  .leadership-card{grid-template-columns:1fr;max-width:520px}
  .leadership-card .leader-portrait{grid-row:auto;min-height:420px}
  .leadership-card .team-name,.leadership-card .team-role,.leadership-card .team-desc{grid-column:1}
}
@media(max-width:560px){
  .container{padding:0 18px}
  .hero{padding:112px 0 64px}
  .hero h1{font-size:clamp(34px,11vw,44px);line-height:1}
  .hero-stats{grid-template-columns:1fr 1fr}
  .partners-ledger{grid-template-columns:1fr}
  .hero-stat-num.stat-word{font-size:22px}
  .about-visual{min-height:380px}
  .about-floating-tags span{font-size:7px;padding:6px 8px;letter-spacing:.08em}
  .about-floating-tags span:nth-child(8){left:5%;top:70%}
  .about-floating-tags span:nth-child(9){left:14%;top:54%}
  .about-floating-tags span:nth-child(10){right:8%;top:70%}
  .about-floating-tags span:nth-child(11){left:50%;top:45%}
  .about-visual-mark{left:54px;right:30px;bottom:22px}
  .leadership-card .leader-portrait{min-height:340px}
  .leadership-card .team-name,.leadership-card .team-role,.leadership-card .team-desc{margin-left:26px;margin-right:26px}
  input,textarea,select{font-size:16px}
}
