:root{
  --void:#0A0B0D; --graphite:#101216; --graphite-2:#15181D; --graphite-3:#1B1F26;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.14); --line-3:rgba(255,255,255,.22);
  --text:#ECEEF1; --text-2:#A4AAB3; --text-3:#6C727B;
  --champ:#CBB68E; --champ-soft:#E0D2B6; --champ-dim:rgba(203,182,142,.5);
  --done:#9DBE9A; --done-soft:#B6D0B3;
  --glass:rgba(255,255,255,.035); --glass-2:rgba(255,255,255,.055);
  --r:16px;
  --f:'Manrope',-apple-system,Segoe UI,sans-serif;
  --ser:'Cormorant Garamond',Georgia,serif;
  --shadow:0 30px 80px -30px rgba(0,0,0,.7);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--void);color:var(--text);font-family:var(--f);font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative}
.wrap{max-width:1240px;margin:0 auto;padding:0 36px}
a{color:inherit;text-decoration:none}
::selection{background:var(--champ);color:var(--void)}
:focus-visible{outline:1px solid var(--champ);outline-offset:4px}

/* grain overlay */
.grain{position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.035;mix-blend-mode:soft-light;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.eyebrow{font-family:var(--ser);font-style:italic;font-size:17px;letter-spacing:.04em;color:var(--champ);display:inline-flex;align-items:center;gap:13px}
.eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,transparent,var(--champ));display:inline-block}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:.4s}
header::after{content:"";position:absolute;inset:0;background:rgba(10,11,13,0);border-bottom:1px solid transparent;backdrop-filter:blur(0);transition:.4s;z-index:-1}
header.scrolled::after{background:rgba(11,12,15,.62);border-bottom:1px solid var(--line);backdrop-filter:blur(22px) saturate(1.2)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:14px;font-weight:600;font-size:18px;letter-spacing:-.01em}
.brand .mono{width:40px;height:40px;border:1px solid var(--line-2);border-radius:10px;display:flex;align-items:center;justify-content:center;flex:none;position:relative;background:var(--glass)}
.brand .mono::before{content:"";position:absolute;top:7px;left:7px;width:9px;height:9px;border-top:1px solid var(--champ);border-left:1px solid var(--champ)}
.brand .mono::after{content:"";position:absolute;bottom:7px;right:7px;width:9px;height:9px;border-bottom:1px solid var(--text-3);border-right:1px solid var(--text-3)}
.brand .mono b{font-family:var(--ser);font-weight:500;font-size:15px;color:var(--text);letter-spacing:.02em}
.brand .bt small{display:block;font-family:var(--f);font-weight:500;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--text-3);margin-top:2px}
.nav-right{display:flex;align-items:center;gap:8px}
.nav-right a{font-size:14px;font-weight:500;color:var(--text-2);padding:9px 16px;border-radius:9px;transition:.25s}
.nav-right a:hover{color:var(--text);background:var(--glass)}

/* HERO */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;padding:120px 0 70px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;background:
  radial-gradient(900px 500px at 82% 8%,rgba(203,182,142,.07),transparent 55%),
  radial-gradient(700px 600px at 8% 90%,rgba(130,150,180,.05),transparent 55%),
  linear-gradient(180deg,#0E1014,#0A0B0D)}
.hero-bg .grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:72px 72px;mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,#000,transparent 90%);-webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,#000,transparent 90%)}
.hero-bg .drift{position:absolute;top:-10%;right:-5%;width:60%;height:70%;background:radial-gradient(circle,rgba(203,182,142,.06),transparent 60%);filter:blur(40px);animation:drift 22s ease-in-out infinite alternate}
@keyframes drift{from{transform:translate(0,0)}to{transform:translate(-60px,40px)}}
.hero-inner{position:relative;z-index:2;width:100%}
.hero-eyebrow{margin-bottom:30px;opacity:0;animation:fadeUp .9s ease .1s forwards}
.hero h1{font-weight:200;font-size:clamp(46px,8vw,108px);line-height:1.0;letter-spacing:-.035em}
.hero h1 .l{display:block;overflow:hidden}
.hero h1 .l span{display:block;opacity:0;transform:translateY(40px);animation:fadeUpClip 1s cubic-bezier(.16,1,.3,1) forwards}
.hero h1 .l:nth-child(1) span{animation-delay:.2s}
.hero h1 .l:nth-child(2) span{animation-delay:.34s}
.hero h1 em{font-style:normal;font-weight:400;color:var(--champ-soft)}
@keyframes fadeUpClip{to{opacity:1;transform:none}}
@keyframes fadeUp{to{opacity:1;transform:none}}
.hero-lead{margin-top:34px;font-size:19px;color:var(--text-2);max-width:520px;line-height:1.6;font-weight:300;opacity:0;animation:fadeUp 1s ease .6s forwards}
.hero-meta{margin-top:60px;display:flex;gap:0;max-width:560px;opacity:0;animation:fadeUp 1s ease .8s forwards;border-radius:var(--r);overflow:hidden}
.hero-meta .c{flex:1;padding:24px 28px;border-right:1px solid var(--line)}
.hero-meta .c:last-child{border-right:0}
.hero-meta .c .v{font-family:var(--ser);font-weight:400;font-size:42px;line-height:1;color:var(--text)}
.hero-meta .c .k{font-size:13px;color:var(--text-3);margin-top:10px;letter-spacing:.02em}
.scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0;animation:fadeUp 1s ease 1.1s forwards}
.scroll-cue .t{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--text-3);writing-mode:vertical-rl}
.scroll-cue .ln{width:1px;height:42px;background:linear-gradient(180deg,var(--champ),transparent)}

/* SECTION */
section.block{padding:120px 0;position:relative}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:74px;flex-wrap:wrap}
.sec-head .l-side{max-width:680px}
.sec-head .ix{font-family:var(--ser);font-size:15px;color:var(--champ);letter-spacing:.1em;margin-bottom:18px;font-style:italic}
.sec-head h2{font-weight:200;font-size:clamp(34px,5vw,64px);line-height:1.04;letter-spacing:-.03em}
.sec-head h2 em{font-style:normal;color:var(--champ-soft);font-weight:400}
.sec-head .r-side{max-width:290px;color:var(--text-2);font-size:15px;font-weight:300;padding-bottom:6px}

/* PROJECTS */
.project{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-bottom:120px;position:relative;overflow:hidden}
.project:last-child{margin-bottom:0}
.project:nth-of-type(even) .pj-media{order:2}

.pj-media{position:relative;z-index:1}
.pj-body{position:relative;z-index:1}
.ph{position:relative;aspect-ratio:4/3;border-radius:var(--r);overflow:hidden;border:1px solid var(--line-2);background:linear-gradient(180deg,#0E1014,#0A0B0D);display:flex;align-items:center;justify-content:center}
.ph .g{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:38px 38px;mask-image:radial-gradient(ellipse 90% 80% at 50% 45%,#000,transparent 95%);-webkit-mask-image:radial-gradient(ellipse 90% 80% at 50% 45%,#000,transparent 95%)}
.ph::before,.ph::after{content:"";position:absolute;width:20px;height:20px;border:1px solid var(--champ-dim);z-index:2}
.ph::before{top:16px;left:16px;border-right:0;border-bottom:0}
.ph::after{bottom:16px;right:16px;border-left:0;border-top:0}
.ph .hint{position:relative;z-index:2;text-align:center}
.ph .hint svg{width:34px;height:34px;stroke:var(--champ);fill:none;stroke-width:1.3;opacity:.75}
.ph .hint .t{margin-top:14px;font-size:13px;letter-spacing:.04em;color:var(--text-2)}
.ph .hint .s{font-size:11.5px;color:var(--text-3);margin-top:5px;letter-spacing:.02em}
.ph .wm{position:absolute;left:22px;bottom:18px;z-index:2;font-family:var(--ser);font-weight:500;font-size:clamp(18px,2.4vw,26px);color:rgba(255,255,255,.07);letter-spacing:.01em;max-width:75%}
.pj-num{position:absolute;top:14px;right:18px;z-index:3;font-family:var(--ser);font-size:24px;color:var(--champ)}
.ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;cursor:zoom-in;transition:transform .7s cubic-bezier(.16,1,.3,1)}
.ph:hover .ph-img{transform:scale(1.045)}
.ph-cap{position:absolute;left:0;right:0;bottom:0;z-index:3;display:flex;align-items:center;gap:9px;font-size:12.5px;letter-spacing:.02em;color:var(--text);padding:26px 16px 12px;background:linear-gradient(0deg,rgba(8,9,11,.72),transparent);pointer-events:none}
.ph-cap .d{width:6px;height:6px;border-radius:50%;background:var(--champ);flex:none}
.thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.thumb{flex:0 0 auto;width:88px;height:62px;border-radius:9px;overflow:hidden;border:1px solid var(--line-2);background:none;padding:0;cursor:pointer;position:relative;transition:.25s;opacity:.5}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb:hover{opacity:1;border-color:var(--champ-dim)}
.thumb.is-active{opacity:1;border-color:var(--champ);box-shadow:0 0 0 1px var(--champ)}
/* lightbox */
.lb{position:fixed;inset:0;z-index:1000;background:rgba(8,9,11,.93);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:clamp(16px,4vw,48px);cursor:zoom-out}
.lb.open{display:flex;animation:lbin .3s ease}
@keyframes lbin{from{opacity:0}to{opacity:1}}
.lb img{max-width:100%;max-height:100%;border-radius:10px;box-shadow:0 40px 120px -30px rgba(0,0,0,.85)}
.lb-x{position:absolute;top:22px;right:26px;width:46px;height:46px;border-radius:50%;border:1px solid var(--line-2);background:var(--glass);color:var(--text);font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.25s}
.lb-x:hover{background:var(--glass-2);border-color:var(--champ-dim)}

.pj-dev{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line-2);border-radius:100px;padding:7px 15px 7px 13px;font-size:12px;letter-spacing:.04em;color:var(--text-2);margin-bottom:22px;background:var(--glass)}
.pj-dev b{color:var(--text);font-weight:600;letter-spacing:.06em}
.pj-dev .d{width:6px;height:6px;border-radius:50%;background:var(--champ)}
.pj-body .ix{font-family:var(--ser);font-size:15px;color:var(--champ);letter-spacing:.12em;margin-bottom:14px;font-style:italic}
.pj-body h3{font-weight:300;font-size:clamp(28px,3.4vw,44px);line-height:1.04;letter-spacing:-.02em;margin-bottom:18px}
.pj-desc{color:var(--text-2);font-size:15.5px;font-weight:300;line-height:1.62;max-width:460px;margin:0 0 30px}
.pj-body h3 em{font-style:normal;color:var(--champ-soft);font-weight:400}

.corps{border-top:1px solid var(--line)}
.corp{display:flex;justify-content:space-between;align-items:center;gap:22px;padding:19px 0;border-bottom:1px solid var(--line)}
.corp .cl{min-width:0}
.corp .cn{font-weight:500;font-size:17px;letter-spacing:-.01em}
.corp .cd{font-size:13.5px;color:var(--text-3);margin-top:4px;font-weight:300}
.tag{flex:none;display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:500;letter-spacing:.02em;white-space:nowrap;padding:7px 13px;border:1px solid var(--line);border-radius:100px;color:var(--text-2);background:var(--glass)}
.tag .dot{width:7px;height:7px;border-radius:50%;flex:none}
.tag.done{color:var(--done-soft);border-color:rgba(157,190,154,.3)}
.tag.done .dot{background:var(--done)}
.tag.work{color:var(--champ-soft);border-color:var(--champ-dim)}
.tag.work .dot{background:var(--champ);box-shadow:0 0 0 0 rgba(203,182,142,.5);animation:pulse 2.2s infinite}
.tag.base .dot{background:transparent;border:1px solid var(--champ-dim)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(203,182,142,.45)}70%{box-shadow:0 0 0 7px rgba(203,182,142,0)}100%{box-shadow:0 0 0 0 rgba(203,182,142,0)}}

/* FOOTER */
footer{padding:70px 0 44px;border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(255,255,255,.012))}
.foot{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.foot .fb{display:flex;align-items:center;gap:13px;font-weight:600;font-size:18px}
.foot .fb .mono{width:34px;height:34px;border:1px solid var(--line-2);border-radius:9px;display:flex;align-items:center;justify-content:center;font-family:var(--ser);font-size:14px;color:var(--text)}
.foot .meta{color:var(--text-3);font-size:13px;font-weight:300;text-align:right}

/* hero photo (справа, растворяется в фон) */
.hero-photo{position:absolute;top:0;right:0;bottom:0;width:60%;z-index:1;overflow:hidden;pointer-events:none}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:58% 32%;filter:saturate(.9) brightness(.84) contrast(1.04)}
.hero-photo::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,var(--void) 1%,rgba(10,11,13,.74) 27%,rgba(10,11,13,.1) 74%,rgba(10,11,13,.42) 100%),
  linear-gradient(0deg,var(--void),transparent 28%),
  linear-gradient(180deg,var(--void),transparent 18%)}

/* глубина фона секции объектов: блики + blueprint-сетка */
#objects::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(820px 520px at 90% 6%,rgba(203,182,142,.07),transparent 58%),
    radial-gradient(760px 660px at 3% 96%,rgba(120,140,170,.06),transparent 60%),
    linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);
  background-size:auto,auto,82px 82px,82px 82px;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 6%,#000 94%,transparent);
          mask-image:linear-gradient(180deg,transparent,#000 6%,#000 94%,transparent)}
#objects::after{content:"";position:absolute;left:0;right:0;top:-1px;height:1px;z-index:0;pointer-events:none;
  background:linear-gradient(90deg,transparent,var(--champ-dim),transparent);opacity:.5}
#objects>.wrap{position:relative;z-index:1}

/* крупные «призрачные» номера объектов на фоне */
.project::before{position:absolute;z-index:0;top:50%;transform:translateY(-50%);font-family:var(--ser);font-weight:400;font-size:clamp(150px,23vw,300px);line-height:.66;letter-spacing:-.02em;color:rgba(203,182,142,.05);pointer-events:none;white-space:nowrap}
.project:nth-of-type(2)::before{content:"01"}
.project:nth-of-type(3)::before{content:"02"}
.project:nth-of-type(4)::before{content:"03"}
.project:nth-of-type(5)::before{content:"04"}
.project:nth-of-type(6)::before{content:"05"}
.project:nth-of-type(7)::before{content:"06"}
.project:nth-of-type(even)::before{left:-1.5%}
.project:nth-of-type(odd)::before{right:-1.5%}
@media(max-width:900px){.project::before{font-size:32vw}}

/* завершающая секция (разбавляет чёрный низ) */
.outro{position:relative;overflow:hidden;padding:clamp(92px,12vw,140px) 0;border-top:1px solid var(--line)}
.outro .bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center 32%;opacity:.13;filter:grayscale(.35) brightness(.72)}
.outro::after{content:"";position:absolute;inset:0;z-index:1;background:
  radial-gradient(960px 540px at 78% 24%,rgba(203,182,142,.07),transparent 60%),
  linear-gradient(180deg,var(--void),rgba(10,11,13,.5) 46%,var(--void))}
.outro-inner{position:relative;z-index:2}
.outro .eyebrow{margin-bottom:24px}
.outro h2{font-weight:200;font-size:clamp(32px,5vw,62px);line-height:1.04;letter-spacing:-.03em;margin-bottom:24px}
.outro h2 em{font-style:normal;color:var(--champ-soft);font-weight:400}
.outro p{color:var(--text-2);font-size:17px;font-weight:300;max-width:580px;line-height:1.62}
.outro-devs{display:flex;gap:12px;margin-top:36px;flex-wrap:wrap}
.outro-devs span{display:inline-flex;align-items:center;gap:9px;font-size:13px;letter-spacing:.04em;color:var(--text-2);border:1px solid var(--line-2);border-radius:100px;padding:9px 18px;background:var(--glass);backdrop-filter:blur(8px)}
.outro-devs span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--champ)}
.outro-devs span b{color:var(--text);font-weight:600}

@media(max-width:900px){
  .hero-photo{width:100%;opacity:.3}
  .hero-photo::after{background:linear-gradient(0deg,var(--void) 6%,rgba(10,11,13,.5) 55%,rgba(10,11,13,.82))}
}

/* reveal */
.rv{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.rv.in{opacity:1;transform:none}

@media(max-width:900px){
  .hero-meta{flex-wrap:wrap}
  .hero-meta .c{flex:1 1 50%}
  .project{grid-template-columns:1fr;gap:32px;margin-bottom:84px}
  .project:nth-of-type(even) .pj-media{order:0}
}
@media(max-width:600px){
  .wrap{padding:0 22px}
  .sec-head{flex-direction:column;align-items:flex-start}
  .hero-meta .c{flex:1 1 100%;border-right:0;border-bottom:1px solid var(--line)}
  .block{padding:84px 0}
  .corp{flex-wrap:wrap;gap:12px}
  .foot{flex-direction:column;align-items:flex-start}
  .foot .meta{text-align:left}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .rv{opacity:1;transform:none}
  .hero h1 .l span,.hero-eyebrow,.hero-lead,.hero-meta,.scroll-cue{opacity:1;transform:none}
}

/* ============================================================
   МНОГОСТРАНИЧНОСТЬ: активный пункт навигации
   ============================================================ */
.nav-right a.is-cur{color:var(--text);background:var(--glass)}

/* ============================================================
   СТРАНИЦА «УСЛУГИ»
   ============================================================ */
.page-hero{position:relative;overflow:hidden;padding:158px 0 72px}
.page-hero .hero-bg{position:absolute;inset:0;z-index:0}
.page-hero-inner{position:relative;z-index:2}
.page-hero .eyebrow{margin-bottom:26px}
.page-hero h1{font-weight:200;font-size:clamp(40px,6.4vw,84px);line-height:1.02;letter-spacing:-.035em;max-width:15ch}
.page-hero h1 em{font-style:normal;color:var(--champ-soft);font-weight:400}
.page-hero .lead{margin-top:28px;font-size:18px;color:var(--text-2);max-width:600px;font-weight:300;line-height:1.62}

.svc{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-bottom:120px;position:relative}
.svc:last-child{margin-bottom:0}
.svc--rev .svc-media{order:2}
.svc-media{position:relative;z-index:1}
.svc-body{position:relative;z-index:1}
.svc-num{font-family:var(--ser);font-weight:400;font-size:clamp(42px,5vw,66px);color:var(--champ);line-height:1;margin-bottom:14px}
.svc-body h2{font-weight:300;font-size:clamp(26px,3.3vw,42px);letter-spacing:-.02em;line-height:1.06;margin-bottom:16px}
.svc-body h2 em{font-style:normal;color:var(--champ-soft);font-weight:400}
.svc-desc{color:var(--text-2);font-size:16px;font-weight:300;line-height:1.62;max-width:470px;margin-bottom:26px}
.svc-list{border-top:1px solid var(--line);max-width:480px}
.svc-list .it{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);font-size:15.5px;color:var(--text);font-weight:400}
.svc-list .it::before{content:"";width:7px;height:7px;border:1px solid var(--champ);transform:rotate(45deg);flex:none}

/* кнопка-ссылка (CTA) */
.cta-link{display:inline-flex;align-items:center;gap:10px;margin-top:32px;padding:15px 28px;border:1px solid var(--line-2);border-radius:100px;background:var(--glass);color:var(--text);font-size:15px;font-weight:500;transition:.25s;text-decoration:none}
.cta-link:hover{border-color:var(--champ-dim);background:var(--glass-2);transform:translateY(-2px)}
.cta-link .ar{transition:transform .25s}.cta-link:hover .ar{transform:translateX(4px)}

@media(max-width:900px){
  .svc{grid-template-columns:1fr;gap:30px;margin-bottom:84px}
  .svc--rev .svc-media{order:0}
}

/* ============================================================
   МОБИЛЬНОЕ МЕНЮ (бургер)
   ============================================================ */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:101}
.burger span{width:24px;height:1.6px;background:var(--text);display:block;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
@media(max-width:760px){
  .burger{display:flex}
  .nav-right{position:fixed;top:0;right:0;bottom:0;width:min(80vw,300px);flex-direction:column;align-items:flex-start;gap:4px;background:rgba(12,13,16,.97);backdrop-filter:blur(22px);border-left:1px solid var(--line);padding:96px 26px 28px;transform:translateX(101%);transition:transform .38s cubic-bezier(.16,1,.3,1);z-index:100}
  .nav-right.open{transform:none}
  .nav-right a{font-size:18px;padding:13px 4px;width:100%}
  body.nav-open{overflow:hidden}
}

/* ============================================================
   СТРАНИЦА «О КОМПАНИИ»
   ============================================================ */
.about-lead{font-weight:200;font-size:clamp(24px,3.5vw,40px);line-height:1.22;letter-spacing:-.02em;max-width:920px}
.about-lead em{font-style:normal;color:var(--champ-soft);font-weight:400}
.facts{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:54px 0}
.facts .s{padding:38px 28px 38px 0;border-right:1px solid var(--line)}
.facts .s:last-child{border-right:0}
.facts .s .v{font-family:var(--ser);font-weight:300;font-size:clamp(42px,5vw,70px);line-height:1;color:var(--text)}
.facts .s .v u{font-family:var(--f);font-size:.3em;font-weight:600;color:var(--champ);text-decoration:none;vertical-align:super;margin-left:5px}
.facts .s .k{font-size:14px;color:var(--text-3);margin-top:14px}
.cols3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pcard{padding:32px 28px 34px;border:1px solid var(--line);border-radius:var(--r);background:var(--glass)}
.pcard .pn{font-family:var(--ser);font-style:italic;font-size:15px;color:var(--champ);margin-bottom:14px}
.pcard h3{font-weight:500;font-size:19px;letter-spacing:-.01em;margin-bottom:10px}
.pcard p{color:var(--text-2);font-size:14.5px;font-weight:300;line-height:1.6}

/* ============================================================
   СТРАНИЦА «КОНТАКТЫ»
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;align-items:start}
.contact-card{padding:42px;border:1px solid var(--line);border-radius:var(--r);background:var(--glass);position:relative;overflow:hidden}
.contact-card .ci{padding:22px 0;border-bottom:1px solid var(--line)}
.contact-card .ci:first-child{padding-top:0}
.contact-card .ci:last-child{border-bottom:0}
.contact-card .k{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-3);margin-bottom:9px}
.contact-card .v{font-size:19px;color:var(--text);font-weight:400}
.contact-card .v a{color:var(--text);text-decoration:none;border-bottom:1px solid var(--champ-dim);transition:.2s}
.contact-card .v a:hover{border-color:var(--champ)}
.contact-card .v.sm{font-size:15.5px;font-weight:300;color:var(--text-2);line-height:1.55}
.contact-side{padding:8px 4px}
.contact-side .eyebrow{margin-bottom:22px}
.contact-side h2{font-weight:200;font-size:clamp(26px,3.4vw,40px);line-height:1.1;letter-spacing:-.025em;margin-bottom:18px}
.contact-side h2 em{font-style:normal;color:var(--champ-soft);font-weight:400}
.contact-side p{color:var(--text-2);font-size:16px;font-weight:300;line-height:1.6;max-width:420px}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}.contact-card{padding:30px}.facts{grid-template-columns:1fr}.facts .s{border-right:0;border-bottom:1px solid var(--line);padding:26px 0}.facts .s:last-child{border-bottom:0}.cols3{grid-template-columns:1fr}}

/* ============================================================
   СТРАНИЦА «НАША ТЕХНИКА»
   ============================================================ */
.fleet{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.fcard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--glass);transition:.35s}
.fcard:hover{border-color:var(--line-2);transform:translateY(-5px)}
.fc-ph{position:relative;aspect-ratio:16/11;overflow:hidden;border-bottom:1px solid var(--line)}
.fc-ph .ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;cursor:zoom-in;transition:transform .6s cubic-bezier(.16,1,.3,1)}
.fcard:hover .fc-ph .ph-img{transform:scale(1.05)}
.fc-body{padding:24px 26px 28px}
.fcard .fc-type{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin-bottom:9px}
.fcard h3{font-weight:600;font-size:21px;letter-spacing:-.01em;margin-bottom:14px}
.fcard .spec{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--champ-soft);border:1px solid var(--champ-dim);border-radius:100px;padding:6px 13px}
.fcard .spec .d{width:6px;height:6px;border-radius:50%;background:var(--champ)}

/* опалубка — акцентный блок */
.formwork{position:relative;overflow:hidden;border:1px solid var(--line-2);border-radius:20px;background:var(--glass);padding:56px 50px;display:grid;grid-template-columns:auto 1fr;gap:52px;align-items:center;margin-top:22px}
.formwork::after{content:"";position:absolute;inset:0;background:radial-gradient(700px 360px at 14% 30%,rgba(203,182,142,.1),transparent 60%);pointer-events:none}
.formwork .big{position:relative;z-index:1;font-family:var(--ser);font-weight:300;font-size:clamp(96px,13vw,180px);line-height:.82;color:var(--champ-soft);letter-spacing:-.02em}
.formwork .fw-body{position:relative;z-index:1}
.formwork .fw-body .ix{font-family:var(--ser);font-style:italic;font-size:15px;color:var(--champ);margin-bottom:14px}
.formwork .fw-body h3{font-weight:300;font-size:clamp(24px,3vw,38px);letter-spacing:-.02em;margin-bottom:14px;line-height:1.08}
.formwork .fw-body h3 em{font-style:normal;color:var(--champ-soft);font-weight:400}
.formwork .fw-body p{color:var(--text-2);font-size:16px;font-weight:300;line-height:1.62;max-width:600px}

/* галерея «техника в работе» */
.tech-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

@media(max-width:900px){
  .fleet{grid-template-columns:repeat(2,1fr)}
  .formwork{grid-template-columns:1fr;gap:22px;padding:40px 28px}
  .formwork .big{font-size:104px}
  .tech-gallery{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){.tech-gallery,.fleet{grid-template-columns:1fr}}

.fleet-note{margin-top:24px;font-size:12.5px;color:var(--text-3);font-weight:300;line-height:1.5}

/* ============================================================
   ТЕМАТИЧЕСКИЙ ФОН ПОД ГЕРОЕМ ВНУТРЕННИХ СТРАНИЦ
   ============================================================ */
.page-hero .ph-bg{position:absolute;inset:0;z-index:1;overflow:hidden}
.page-hero .ph-bg img{width:100%;height:100%;object-fit:cover;object-position:center 36%;filter:brightness(.42) saturate(.9) contrast(1.03)}
.page-hero .ph-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,var(--void) 3%,rgba(10,11,13,.6) 46%,rgba(10,11,13,.22) 100%),
  linear-gradient(0deg,var(--void) 1%,transparent 50%),
  linear-gradient(180deg,rgba(10,11,13,.72),transparent 24%)}
@media(max-width:760px){
  .page-hero .ph-bg img{object-position:center 40%}
  .page-hero .ph-bg::after{background:linear-gradient(0deg,var(--void) 4%,rgba(10,11,13,.5) 55%,rgba(10,11,13,.74))}
}

/* ============================================================
   МОБИЛЬНАЯ ПРОИЗВОДИТЕЛЬНОСТЬ: убираем тяжёлые для скролла эффекты
   ============================================================ */
@media(max-width:760px){
  .grain{display:none}          /* fixed + mix-blend-mode — главный источник лагов скролла */
  .hero-bg .drift{display:none} /* анимированный blur-blob */
  header.scrolled::after{backdrop-filter:blur(10px)} /* лёгкий blur вместо 22px */
}
@media(max-width:760px){ .scroll-cue{display:none} }
