@font-face{font-family:'Gilroy';src:url('../fonts/Gilroy-Light.otf') format('opentype');font-weight:400;font-display:swap;}
@font-face{font-family:'Gilroy';src:url('../fonts/Gilroy-ExtraBold.otf') format('opentype');font-weight:700;font-display:swap;}
@font-face{font-family:'Gilroy';src:url('../fonts/Gilroy-ExtraBold.otf') format('opentype');font-weight:800;font-display:swap;}
@font-face{font-family:'Gilroy';src:url('../fonts/Gilroy-ExtraBold.otf') format('opentype');font-weight:900;font-display:swap;}
@font-face{font-family:'Montserrat';src:url('../fonts/Montserrat-Regular.ttf') format('truetype');font-weight:400;font-display:swap;}
@font-face{font-family:'Montserrat';src:url('../fonts/Montserrat-Medium.ttf') format('truetype');font-weight:500;font-display:swap;}
@font-face{font-family:'Montserrat';src:url('../fonts/Montserrat-Bold.ttf') format('truetype');font-weight:700;font-display:swap;}
@font-face{font-family:'Montserrat';src:url('../fonts/Montserrat-Black.ttf') format('truetype');font-weight:900;font-display:swap;}
:root{--black:#0a0a0a;--card-border:rgba(255,255,255,0.08);--ff:'Gilroy','Montserrat',sans-serif;}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--ff);background:var(--black);color:#fff;overflow-x:hidden;}

/* ── NAV HEADER (NEW) ── */
.nav-header{position:fixed;top:0;left:0;right:0;z-index:999;display:flex;align-items:center;justify-content:space-between;padding:14px 32px;background:rgba(10,10,10,0.55);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,0.06);transition:background 0.3s,padding 0.3s;}
.nav-header.scrolled{background:rgba(10,10,10,0.85);padding:10px 32px;}
.nav-logo{display:flex;align-items:center;cursor:pointer;flex-shrink:0;}
.nav-logo img{height:34px;width:auto;object-fit:contain;display:block;}
.nav-logo-fb{font-size:14px;font-weight:900;letter-spacing:0.18em;display:none;align-items:center;gap:2px;color:#fff;}
.nav-menu{display:flex;align-items:center;gap:6px;}
.nav-link{padding:8px 16px;font-size:12px;font-weight:700;letter-spacing:0.13em;text-transform:uppercase;color:rgba(255,255,255,0.7);background:transparent;border:none;cursor:pointer;border-radius:20px;transition:background 0.2s,color 0.2s;font-family:var(--ff);position:relative;}
.nav-link:hover{color:#fff;background:rgba(255,255,255,0.07);}
.nav-link.active{color:#fff;background:rgba(255,255,255,0.12);}
.nav-right{display:flex;align-items:center;gap:14px;flex-shrink:0;}
.nav-burger{display:none;width:36px;height:36px;flex-direction:column;justify-content:center;align-items:center;gap:5px;cursor:pointer;background:transparent;border:none;padding:0;}
.nav-burger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:transform 0.3s,opacity 0.3s;}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

@media(max-width:1100px){
  .nav-link{padding:7px 12px;font-size:11px;letter-spacing:0.1em;}
}
@media(max-width:900px){
  .nav-header{padding:12px 18px;}
  .nav-header.scrolled{padding:10px 18px;}
  .nav-burger{display:flex;}
  .nav-menu{position:fixed;top:0;left:0;right:0;background:rgba(10,12,18,0.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;align-items:stretch;padding:80px 24px 28px;gap:4px;transform:translateY(-100%);transition:transform 0.4s cubic-bezier(.22,1,.36,1);border-bottom:1px solid rgba(255,255,255,0.08);}
  .nav-menu.open{transform:translateY(0);}
  .nav-link{padding:14px 18px;font-size:13px;letter-spacing:0.14em;text-align:left;border-radius:12px;}
  .nav-logo img{height:28px;}
}

/* Отступ для всего контента из-за фиксированной шапки */
body{padding-top:62px;}
@media(max-width:900px){body{padding-top:56px;}}

/* ── LANG SWITCHER ── */
.lang-switch{display:flex;gap:0;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.15);border-radius:20px;padding:3px;}
.lang-btn{padding:5px 12px;font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.55);background:transparent;border:none;cursor:pointer;border-radius:16px;transition:background 0.2s,color 0.2s;font-family:var(--ff);}
.lang-btn.active{background:rgba(255,255,255,0.95);color:#0a0a0a;}
.lang-btn:hover:not(.active){color:rgba(255,255,255,0.9);}

/* ── CTA BUTTON ── */
.cta-btn{display:inline-flex;align-items:center;gap:14px;padding:16px 32px;background:#fff;color:#0a0a0a;font-family:var(--ff);font-size:13px;font-weight:800;letter-spacing:0.13em;text-transform:uppercase;border:none;border-radius:50px;cursor:pointer;transition:transform 0.2s,box-shadow 0.2s,background 0.2s;text-decoration:none;}
.cta-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,255,255,0.18);background:#f0f0f0;}
.cta-btn svg{width:14px;height:14px;}
.cta-btn-dark{background:rgba(255,255,255,0.08);color:#fff;border:1px solid rgba(255,255,255,0.25);}
.cta-btn-dark:hover{background:rgba(255,255,255,0.15);}

/* ── MODAL ── */
#kp-modal{position:fixed;inset:0;background:rgba(0,0,0,0.85);z-index:99998;display:none;align-items:center;justify-content:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:20px;}
#kp-modal.open{display:flex;}
.kp-modal-box{background:linear-gradient(160deg,#0e1118 0%,#161b28 100%);border:1px solid rgba(255,255,255,0.1);border-radius:18px;width:100%;max-width:620px;max-height:92vh;overflow-y:auto;padding:38px 42px 34px;position:relative;box-shadow:0 20px 80px rgba(0,0,0,0.6);}
.kp-modal-close{position:absolute;top:16px;right:20px;font-size:30px;color:rgba(255,255,255,0.55);cursor:pointer;line-height:1;font-weight:300;background:none;border:none;transition:color 0.2s;}
.kp-modal-close:hover{color:#fff;}
.kp-modal-title{font-size:clamp(22px,2.2vw,28px);font-weight:900;letter-spacing:0.02em;text-transform:uppercase;margin-bottom:6px;color:#fff;}
.kp-modal-sub{font-size:13px;color:rgba(255,255,255,0.5);margin-bottom:24px;line-height:1.5;}
.kp-form-group{margin-bottom:18px;}
.kp-form-group label{display:block;font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-bottom:8px;}
.kp-form-group input,.kp-form-group textarea{width:100%;padding:13px 16px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.12);border-radius:10px;color:#fff;font-family:var(--ff);font-size:14px;outline:none;transition:border-color 0.2s,background 0.2s;resize:none;}
.kp-form-group input:focus,.kp-form-group textarea:focus{border-color:rgba(255,255,255,0.4);background:rgba(255,255,255,0.07);}
.kp-form-group textarea{min-height:110px;font-family:var(--ff);line-height:1.5;}
.kp-form-group .hint{font-size:11px;color:rgba(255,255,255,0.35);margin-top:5px;line-height:1.4;}
.kp-submit-btn{width:100%;padding:16px;background:#fff;color:#0a0a0a;font-family:var(--ff);font-size:13px;font-weight:800;letter-spacing:0.16em;text-transform:uppercase;border:none;border-radius:50px;cursor:pointer;transition:transform 0.2s,box-shadow 0.2s;margin-top:8px;}
.kp-submit-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,255,255,0.15);}
.kp-submit-btn:disabled{opacity:0.6;cursor:wait;}
@media(max-width:768px){.kp-modal-box{padding:28px 22px 24px;border-radius:14px;}.kp-modal-title{font-size:20px;}}

/* ── SLIDES ── */
.slide{width:100%;min-height:calc(100vh - 62px);position:relative;display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(36px);transition:opacity 0.8s cubic-bezier(.22,1,.36,1),transform 0.8s cubic-bezier(.22,1,.36,1);scroll-margin-top:62px;}
@media(max-width:900px){.slide{min-height:calc(100vh - 56px);scroll-margin-top:56px;}}
.slide.visible{opacity:1;transform:translateY(0);}
.slide.visible .fc{animation:fadeUp 0.7s cubic-bezier(.22,1,.36,1) both;}
.fc:nth-child(1){animation-delay:0.05s;}.fc:nth-child(2){animation-delay:0.15s;}.fc:nth-child(3){animation-delay:0.25s;}.fc:nth-child(4){animation-delay:0.35s;}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}

/* ── TOPBAR ── */
.tb{display:flex;align-items:center;padding:20px 48px;position:relative;z-index:10;flex-shrink:0;}
.tb-logo-img{height:48px;width:auto;object-fit:contain;display:block;flex-shrink:0;}
.tb-logo-fallback{font-size:14px;font-weight:900;letter-spacing:0.18em;display:flex;align-items:center;gap:2px;flex-shrink:0;}
.ls{display:inline-block;width:14px;height:14px;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 40'%3E%3Cg stroke='white' stroke-width='2.5' fill='none'%3E%3Cline x1='20' y1='2' x2='20' y2='38'/%3E%3Cline x1='2' y1='20' x2='38' y2='20'/%3E%3Cline x1='6' y1='6' x2='34' y2='34'/%3E%3Cline x1='34' y1='6' x2='6' y2='34'/%3E%3C/g%3E%3C/svg%3E") center/contain no-repeat;}
.ls-b{display:inline-block;width:14px;height:14px;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 40'%3E%3Cg stroke='black' stroke-width='2.5' fill='none'%3E%3Cline x1='20' y1='2' x2='20' y2='38'/%3E%3Cline x1='2' y1='20' x2='38' y2='20'/%3E%3Cline x1='6' y1='6' x2='34' y2='34'/%3E%3Cline x1='34' y1='6' x2='6' y2='34'/%3E%3C/g%3E%3C/svg%3E") center/contain no-repeat;}
.tb-line{flex:1;height:1px;background:rgba(255,255,255,0.18);margin:0 22px;}
.tb-num{font-size:11px;font-weight:500;color:rgba(255,255,255,0.7);flex-shrink:0;}

/* ── BOTTOMBAR ── */
.bb{display:flex;align-items:center;padding:16px 48px;margin-top:auto;position:relative;z-index:10;flex-shrink:0;}
.bb-lbl{font-size:10px;color:rgba(255,255,255,0.5);letter-spacing:0.16em;text-transform:lowercase;flex-shrink:0;}
.bb-line{flex:1;height:1px;background:rgba(255,255,255,0.15);margin:0 18px;}
.arr{width:32px;height:32px;border:1px solid rgba(255,255,255,0.28);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background 0.2s,border-color 0.2s;flex-shrink:0;}
.arr:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.6);}
.arr svg{width:15px;height:15px;}

/* ── HERO ── */
.s1{background:#0a0a0a;}
.h-bg{position:absolute;inset:0;background:linear-gradient(135deg,#0d1525,#1a2540) center/cover no-repeat;opacity:0.9;}
.h-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0.6) 0%,rgba(0,0,0,0.15) 40%,rgba(0,0,0,0.7) 100%);}
.h-body{position:relative;z-index:5;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 40px 40px;}
.h-logo-wrap{margin-bottom:30px;animation:fadeUp 1s .3s both;display:flex;align-items:center;justify-content:center;}
.h-logo-wrap img{height:120px;width:auto;max-width:340px;object-fit:contain;}
.h-title{font-size:clamp(44px,7vw,92px);font-weight:900;text-transform:uppercase;letter-spacing:0.04em;line-height:1;margin-bottom:26px;text-shadow:0 2px 40px rgba(0,0,0,0.55);animation:fadeUp 1s .45s both;}
.h-srv{font-size:clamp(12px,1.2vw,15px);font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.75);line-height:2.3;animation:fadeUp 1s .65s both;margin-bottom:36px;}
.h-cta-wrap{animation:fadeUp 1s .8s both;}
.dot{margin:0 14px;opacity:0.35;}

/* ── НАПРАВЛЕНИЯ (АККОРДЕОН) ── */
.s-dir{background:#0a0a0a;position:relative;}
.s-dir-bg{position:absolute;inset:0;background:linear-gradient(155deg,#0c0e12 0%,#111520 55%,#171b28 100%);pointer-events:none;z-index:0;}
.dir-layout{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;padding:0 48px 30px;min-height:0;}
.dir-hdr{padding-bottom:24px;flex-shrink:0;}
.dir-hdr-title{font-size:clamp(42px,6.5vw,86px);font-weight:900;text-transform:uppercase;letter-spacing:0.03em;line-height:1;}

.dir-acc-wrap{display:flex;flex-direction:column;gap:10px;flex:1;min-height:0;}
.dir-acc{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:16px;overflow:hidden;transition:background 0.3s,border-color 0.3s;}
.dir-acc:hover{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.18);}
.dir-acc.open{background:rgba(255,255,255,0.07);border-color:rgba(255,255,255,0.25);}
.dir-acc-head{display:flex;align-items:center;padding:18px 26px;cursor:pointer;user-select:none;gap:20px;}
.dir-acc-num{font-size:clamp(20px,1.8vw,26px);font-weight:900;color:rgba(255,255,255,0.35);letter-spacing:-0.01em;flex-shrink:0;min-width:38px;}
.dir-acc-title{font-size:clamp(15px,1.5vw,22px);font-weight:800;letter-spacing:0.06em;text-transform:uppercase;color:#fff;flex:1;}
.dir-acc-badge{font-size:9px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.4);background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);padding:4px 10px;border-radius:30px;flex-shrink:0;margin-right:6px;}
.dir-acc-toggle{width:32px;height:32px;border:1px solid rgba(255,255,255,0.25);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform 0.3s,background 0.2s,border-color 0.2s;}
.dir-acc.open .dir-acc-toggle{transform:rotate(45deg);background:#fff;border-color:#fff;}
.dir-acc-toggle svg{width:14px;height:14px;transition:stroke 0.2s;}
.dir-acc.open .dir-acc-toggle svg{stroke:#0a0a0a;}
.dir-acc-body{max-height:0;overflow:hidden;transition:max-height 0.4s cubic-bezier(.4,0,.2,1);}
.dir-acc.open .dir-acc-body{max-height:600px;}
.dir-acc-body-inner{padding:0 26px 22px 84px;}
.dir-acc-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:6px 30px;}
.dir-acc-list li{font-size:clamp(12px,1vw,15px);color:rgba(255,255,255,0.72);padding:6px 0 6px 16px;position:relative;line-height:1.45;}
.dir-acc-list li::before{content:'—';position:absolute;left:0;color:rgba(255,255,255,0.3);font-size:13px;top:7px;}

.dir-star-deco{position:absolute;right:-60px;bottom:-60px;width:340px;height:340px;opacity:0.04;pointer-events:none;z-index:0;}
.dir-star-deco img{width:100%;height:100%;}

/* ── CLIENTS ── */
:root{
  --cl-title-size:clamp(68px,7vw,100px);
  --cl-title-weight:700;
  --cl-title-mb:40px;
  --cl-body-justify:center;
  --cl-body-pad:20px 48px 40px;
  --cl-row-gap:14px;
  --cl-logo-w:240px;
  --cl-logo-h:140px;
  --cl-logo-pad:0 10px;
  --cl-img-max-w:200px;
  --cl-img-max-h:140px;
  --cl-text-size:10px;
}
.s4{background:#0a0a0a;}
.c-bg{position:absolute;top:0;left:0;bottom:0;width:60%;background:linear-gradient(135deg,#0d1018,#1a2035) left center/cover no-repeat;opacity:1;}
.c-bg::after{content:'';position:absolute;top:0;right:-200px;bottom:0;width:260px;background:linear-gradient(to right,rgba(10,10,10,0) 0%,#0a0a0a 100%);}
.c-body{position:relative;z-index:5;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:var(--cl-body-justify);padding:var(--cl-body-pad);}
.c-title{font-size:var(--cl-title-size);font-weight:var(--cl-title-weight);letter-spacing:0;text-transform:uppercase;line-height:1.1;margin-bottom:var(--cl-title-mb);text-align:center;}
.lgrid{display:flex;flex-direction:column;gap:var(--cl-row-gap);}
.lgrid-row{display:flex;align-items:center;justify-content:center;gap:0;}
.lph{width:var(--cl-logo-w);height:var(--cl-logo-h);background:transparent;border:none;display:flex;align-items:center;justify-content:center;position:relative;overflow:visible;padding:var(--cl-logo-pad);flex-shrink:0;}
.lph:hover{opacity:0.7;}
.lph img{max-width:var(--cl-img-max-w);max-height:var(--cl-img-max-h);object-fit:contain;display:block;filter:brightness(0) invert(1);}
.lph .lph-text{font-size:var(--cl-text-size);font-weight:600;letter-spacing:0.07em;color:rgba(255,255,255,0.35);text-align:center;line-height:1.4;}

/* ── CASES SLIDE ── */
.s5{background:#0a0a0a;position:relative;height:calc(100vh - 62px);max-height:calc(100vh - 62px);overflow:hidden;}
@media(max-width:900px){.s5{height:calc(100vh - 56px);max-height:calc(100vh - 56px);}}
.s5-bg-layer{position:absolute;inset:0;background:center/cover no-repeat;opacity:1;z-index:0;transition:opacity 0.6s ease;}
.s5-ov-layer{position:absolute;inset:0;background:none;z-index:1;pointer-events:none;}
.cw{overflow:hidden;position:relative;flex:1;min-height:0;z-index:2;display:flex;flex-direction:column;}
.ctrack{display:flex;gap:0;flex:1;overflow-x:scroll;overflow-y:hidden;user-select:none;cursor:grab;scrollbar-width:none;-ms-overflow-style:none;align-items:stretch;}
.ctrack::-webkit-scrollbar{display:none;}
.ctrack.grabbing{cursor:grabbing;}
.cprog{height:2px;background:rgba(255,255,255,0.1);margin:6px 48px 0;border-radius:2px;flex-shrink:0;position:relative;z-index:5;}
.cpf{height:100%;background:#fff;border-radius:2px;transition:width 0.08s linear;width:8%;}
.cc{flex:0 0 calc(100vw - 72px);height:100%;position:relative;display:flex;flex-direction:row;align-items:stretch;margin-right:0;}
.cc-sep{display:none;}
.cw{position:relative;}
.cc-next-btn{position:absolute;top:0;bottom:0;right:100px;width:72px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;cursor:pointer;z-index:20;background:rgba(0,0,0,0.4);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-left:1px solid rgba(255,255,255,0.08);border-right:1px solid rgba(255,255,255,0.06);transition:background 0.25s;}
.cc-next-btn:hover{background:rgba(255,255,255,0.07);}
.cc-next-btn-line{width:1px;flex:1;max-height:90px;background:rgba(255,255,255,0.18);}
.cc-next-btn-arr{width:38px;height:38px;border:1px solid rgba(255,255,255,0.3);border-radius:50%;display:flex;align-items:center;justify-content:center;background:transparent;transition:border-color 0.2s,background 0.2s,transform 0.15s;flex-shrink:0;}
.cc-next-btn:hover .cc-next-btn-arr{border-color:rgba(255,255,255,0.7);background:rgba(255,255,255,0.08);transform:translateX(2px);}
.cc-next-btn-arr svg{width:14px;height:14px;opacity:0.75;}
.cc-next-btn:hover .cc-next-btn-arr svg{opacity:1;}
.cc-col-l{position:relative;z-index:5;flex:0 0 28%;display:flex;flex-direction:column;justify-content:center;padding:16px 24px 16px 48px;gap:40px;}
.cc-client-logo{max-height:100px;max-width:300px;object-fit:contain;display:block;margin-bottom:4px;}
.cc-client-logo-ph{font-size:clamp(30px,3.5vw,46px);font-weight:900;letter-spacing:0.04em;line-height:1;margin-bottom:4px;}
.cc-client-sub{font-size:12px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-bottom:0;}
.cc-desc{font-size:clamp(13px,1.1vw,15px);color:rgba(255,255,255,0.78);line-height:1.7;max-width:460px;}
.cc-res-label{font-size:13px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:#fff;margin-bottom:8px;}
.cc-link-label{font-size:13px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:#fff;margin-bottom:8px;}
.cc-ig-btn{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,0.7);cursor:pointer;}
.cc-res-list{list-style:none;}
.cc-res-list li{font-size:clamp(13px,1.1vw,15px);color:rgba(255,255,255,0.82);padding:5px 0 5px 18px;position:relative;line-height:1.6;}
.cc-res-list li::before{content:'·';position:absolute;left:2px;color:rgba(255,255,255,0.45);}
.cc-col-r{position:relative;z-index:5;flex:0 0 38%;display:flex;align-items:center;justify-content:center;padding:16px 24px 16px 8px;overflow:hidden;}
.cc-photo{object-fit:contain;display:block;border-radius:10px;max-height:calc(100% - 16px);max-width:100%;width:auto;height:auto;}
.cc-photo-ph{width:100%;max-width:560px;aspect-ratio:4/3;border-radius:10px;background:rgba(255,255,255,0.05);border:1px dashed rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;position:relative;}
.cc-photo-ph-num{font-size:36px;font-weight:900;color:rgba(255,255,255,0.3);}
.cc-photo-ph-label{font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.3);}
.cases-hdr-row{display:flex;align-items:baseline;gap:20px;padding:0 48px 0;position:relative;z-index:5;flex-shrink:0;}
.cases-hdr-t{font-size:clamp(36px,6vw,80px);font-weight:900;text-transform:uppercase;letter-spacing:0.03em;color:#fff;line-height:1;}
.cases-hdr-s{font-size:clamp(14px,1.6vw,20px);font-weight:700;letter-spacing:0.1em;color:rgba(255,255,255,0.75);text-transform:uppercase;align-self:flex-end;padding-bottom:8px;}
.cases-hdr-div{width:1px;height:24px;background:rgba(255,255,255,0.35);align-self:flex-end;padding-bottom:8px;margin-bottom:6px;}
.dh{display:flex;align-items:center;gap:8px;padding:0 48px 6px;color:rgba(255,255,255,0.35);font-size:10px;letter-spacing:0.1em;position:relative;z-index:5;flex-shrink:0;}
.dh-i{width:20px;height:14px;position:relative;}
.dh-i::before,.dh-i::after{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border:1px solid rgba(255,255,255,0.35);border-radius:10px;}
.dh-i::before{width:18px;height:12px;}.dh-i::after{width:10px;height:7px;}
.case-nav-dots{display:flex;gap:8px;padding:6px 48px 0;position:relative;z-index:5;flex-shrink:0;}
.case-nav-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.2);cursor:pointer;transition:background 0.2s,transform 0.2s;}
.case-nav-dot.active{background:#fff;transform:scale(1.4);}

/* ── LIGHTBOX ── */
#lightbox{position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:99999;display:none;align-items:center;justify-content:center;backdrop-filter:blur(8px);}
#lightbox.open{display:flex;}
#lb-img{max-width:85vw;max-height:82vh;object-fit:contain;border-radius:8px;box-shadow:0 8px 60px rgba(0,0,0,0.8);transition:opacity 0.25s;}
#lb-img.fading{opacity:0;}
#lb-close{position:absolute;top:24px;right:32px;font-size:32px;color:rgba(255,255,255,0.7);cursor:pointer;line-height:1;font-weight:300;transition:color 0.2s;}
#lb-close:hover{color:#fff;}
#lb-prev,#lb-next{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border:1px solid rgba(255,255,255,0.3);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background 0.2s,border-color 0.2s;color:#fff;}
#lb-prev:hover,#lb-next:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.6);}
#lb-prev{left:24px;}#lb-next{right:24px;}
#lb-prev svg,#lb-next svg{width:18px;height:18px;}
#lb-counter{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-size:12px;color:rgba(255,255,255,0.5);letter-spacing:0.12em;}

/* ── KP ── */
.s6{background:linear-gradient(160deg,#08090c 0%,#0d1018 55%,#131824 100%);}
.kp-sb{position:absolute;right:40px;top:50%;transform:translateY(-50%);width:500px;height:500px;opacity:0.12;}
.kp-b{position:relative;z-index:5;flex:1;display:flex;flex-direction:column;justify-content:center;padding:20px 48px 40px;}
.kp-t{font-size:clamp(60px,10vw,140px);font-weight:900;text-transform:uppercase;letter-spacing:0.02em;line-height:0.95;margin-bottom:18px;}
.kp-d{height:1px;background:rgba(255,255,255,0.18);margin-bottom:20px;}
.kp-s{font-size:clamp(18px,2vw,26px);font-weight:500;color:rgba(255,255,255,0.55);margin-bottom:16px;}
.kp-p{font-size:clamp(14px,1.4vw,18px);color:rgba(255,255,255,0.42);line-height:1.75;max-width:700px;margin-bottom:36px;}
.kp-cta-row{display:flex;gap:16px;flex-wrap:wrap;}

/* ── CONTACTS ── */
.s7{background:linear-gradient(160deg,#08090c 0%,#0d1018 60%,#131824 100%);}
.ct-b{position:relative;z-index:5;flex:1;display:flex;flex-direction:column;justify-content:flex-start;padding:10px 48px 20px;}
.ct-t{font-size:clamp(72px,10vw,140px);font-weight:900;text-transform:uppercase;letter-spacing:0.03em;line-height:1;margin-bottom:40px;}
.ct-g{display:grid;grid-template-columns:1fr 1fr;gap:40px 80px;max-width:720px;margin-bottom:auto;}
.ct-i{display:flex;align-items:flex-start;gap:18px;}
.ct-ic{width:56px;height:56px;flex-shrink:0;border:1.5px solid rgba(255,255,255,0.25);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:border-color 0.25s,background 0.25s;}
.ct-i:hover .ct-ic{border-color:rgba(255,255,255,0.55);background:rgba(255,255,255,0.05);}
.ct-ic svg{width:26px;height:26px;stroke:white;fill:none;stroke-width:1.5;}
.ct-lb{font-size:12px;font-weight:700;letter-spacing:0.09em;margin-bottom:5px;}
.ct-vl{font-size:clamp(15px,1.3vw,18px);font-weight:400;color:rgba(255,255,255,0.6);}
.ct-ft{margin-top:auto;padding-top:30px;}
.ct-ft p{font-size:11px;color:rgba(255,255,255,0.28);line-height:2.2;}
.ct-ft strong{color:rgba(255,255,255,0.52);font-weight:600;font-size:13px;}

.spin{transform-origin:center;}
@keyframes rspin{to{transform:rotate(360deg);}}

/* ══ ПРИНУДИТЕЛЬНЫЕ РАЗМЕРЫ — КОНТАКТЫ ══ */
.s7{background:linear-gradient(180deg,#0a0a0a 0%,#0a0c14 30%,#111a30 60%,#8a9bb5 85%,#c8d4e6 100%) !important;}
.ct-t{font-size:162px !important;font-weight:800 !important;line-height:175px !important;margin-bottom:44px !important;font-family:'Gilroy','Montserrat',sans-serif !important;}
.ct-g{gap:44px 100px !important;max-width:900px !important;}
.ct-i{gap:20px !important;}
.ct-ic{width:64px !important;height:64px !important;border:2px solid rgba(255,255,255,0.3) !important;}
.ct-ic svg{width:30px !important;height:30px !important;}
.ct-lb{font-size:35px !important;font-weight:700 !important;line-height:113% !important;font-family:'Montserrat',sans-serif !important;margin-bottom:6px !important;color:#fff !important;}
.ct-vl{font-size:35px !important;font-weight:400 !important;line-height:113% !important;font-family:'Montserrat',sans-serif !important;color:#fff !important;}
.ct-ft{margin-top:60px !important;padding-top:0 !important;}
.ct-ft p{font-size:35px !important;font-weight:400 !important;line-height:180% !important;font-family:'Montserrat',sans-serif !important;color:#fff !important;}
.ct-ft strong{font-size:35px !important;font-weight:500 !important;line-height:180% !important;font-family:'Montserrat',sans-serif !important;color:#fff !important;}

/* ══ ПРИНУДИТЕЛЬНЫЕ РАЗМЕРЫ — КП ══ */
.s6{background:linear-gradient(180deg,#0a0a0a 0%,#0a0c14 40%,#111a30 80%,#8a9bb5 95%,#c8d4e6 100%) !important;}
.kp-t{font-size:150px !important;line-height:162.5px !important;font-family:'Gilroy','Montserrat',sans-serif !important;font-weight:800 !important;margin-bottom:20px !important;}
.kp-s{font-size:47px !important;font-family:'Gilroy','Montserrat',sans-serif !important;font-weight:300 !important;line-height:113% !important;color:#fff !important;margin-bottom:30px !important;}
.kp-d{background:#fff !important;height:2px !important;margin-bottom:40px !important;}
.kp-p{font-size:38px !important;font-family:'Gilroy','Montserrat',sans-serif !important;font-weight:300 !important;line-height:113% !important;max-width:100% !important;color:#fff !important;}
.kp-sb{left:-40px !important;right:auto !important;width:500px !important;height:500px !important;opacity:0.18 !important;}

/* ════════════════════════════════
   MOBILE — до 768px
   ════════════════════════════════ */
@media(max-width:768px){

  /* TOPBAR */
  .tb{padding:16px 20px;}
  .tb-logo-img{height:32px;}
  .tb-num{font-size:9px;}

  /* BOTTOMBAR */
  .bb{padding:12px 20px;}

  /* HERO */
  .h-body{padding:0 20px 60px;}
  .h-title{font-size:clamp(36px,10vw,56px);}
  .h-srv{font-size:11px;line-height:2;margin-bottom:28px;}

  /* НАПРАВЛЕНИЯ */
  .dir-layout{padding:0 16px 20px;}
  .dir-hdr-title{font-size:clamp(28px,8vw,44px);white-space:normal;}
  .dir-acc-head{padding:14px 18px;gap:12px;}
  .dir-acc-num{font-size:18px;min-width:28px;}
  .dir-acc-title{font-size:14px;letter-spacing:0.04em;}
  .dir-acc-badge{display:none;}
  .dir-acc-toggle{width:28px;height:28px;}
  .dir-acc-body-inner{padding:0 18px 16px 56px;}
  .dir-acc-list{grid-template-columns:1fr;gap:2px;}
  .dir-acc-list li{font-size:12px;}

  /* КЛИЕНТЫ */
  .c-body{padding:16px 20px 40px;}
  .c-title{font-size:clamp(36px,10vw,56px);}
  .lgrid{grid-template-columns:repeat(2,1fr) !important;gap:16px 20px !important;max-width:100% !important;}
  .lgrid-row{display:contents !important;}
  .lph{height:56px !important;padding:6px 10px !important;}
  .lph img{max-width:100px !important;max-height:40px !important;}

  /* ══ КЕЙСЫ ══ */
  .s5{height:auto !important;max-height:none !important;min-height:calc(100vh - 56px);overflow:visible !important;}
  .cw{overflow:visible !important;}
  .ctrack{align-items:flex-start !important;overflow-x:scroll;overflow-y:hidden;}

  .cc{
    flex-direction:column !important;
    flex:0 0 88vw !important;
    height:auto !important;
    min-height:auto !important;
    overflow:visible !important;
    gap:0 !important;
    align-items:stretch !important;
  }

  .cc > div{
    flex:none !important;
    width:100% !important;
    max-width:100% !important;
    padding-left:20px !important;
    padding-right:20px !important;
  }

  .cc-col-l{
    flex:none !important;
    width:100% !important;
    padding:16px 20px 10px 20px !important;
  }

  .cc-col-r{
    flex:none !important;
    width:100% !important;
    padding:8px 20px 20px 20px !important;
    max-height:320px !important;
    justify-content:flex-start !important;
    align-items:center !important;
  }

  .cc-photo{
    max-height:260px !important;
    width:auto !important;
    max-width:100% !important;
    border-radius:8px !important;
  }

  .cc-photo-ph{
    max-width:100% !important;
    aspect-ratio:3/2 !important;
  }

  .cc-client-logo{
    max-height:50px !important;
    max-width:160px !important;
  }

  .cc-res-list li{
    font-size:12px !important;
    line-height:1.45 !important;
    padding:3px 0 3px 14px !important;
  }

  .cc-client-logo-ph{
    font-size:20px !important;
  }

  .cc-res-label,
  .cc-link-label{
    font-size:11px !important;
    margin-bottom:6px !important;
  }

  .cases-hdr-row{padding:0 20px;flex-wrap:wrap;gap:8px;}
  .cases-hdr-t{font-size:clamp(28px,8vw,44px);}
  .dh{padding:0 20px 6px;}
  .cprog{margin:6px 20px 0;}
  .case-nav-dots{padding:6px 20px 0;flex-wrap:wrap;}

  .cc-next-btn{display:none !important;}

  .cc div[style*="transform:translateY"]{
    transform:none !important;
  }

  .cc > div[style*="flex:0 0 20%"],
  .cc > div[style*="flex:0 0 28%"]{
    flex:none !important;
    width:100% !important;
    max-width:100% !important;
    padding:16px 20px !important;
  }

  .cc > div[style*="gap:40px"],
  .cc > div[style*="gap:48px"],
  .cc > div[style*="gap:28px"],
  .cc > div[style*="gap:24px"],
  .cc > div[style*="gap:20px"]{
    gap:12px !important;
  }

  .cc div[style*="font-size:clamp(22px"],
  .cc div[style*="font-size:clamp(24px"]{
    font-size:18px !important;
  }

  /* ══ КП — мобилка ══ */
  .s6{background:linear-gradient(180deg,#0a0a0a 0%,#0a0c14 40%,#111a30 80%,#8a9bb5 95%,#c8d4e6 100%) !important;}
  .kp-b{padding:20px 20px 40px;}
  .kp-t{font-size:clamp(32px,9vw,48px) !important;line-height:115% !important;margin-bottom:12px !important;font-weight:800 !important;}
  .kp-d{max-width:100%;margin-bottom:16px !important;height:1px !important;}
  .kp-s{font-size:16px !important;margin-bottom:10px !important;line-height:140% !important;font-weight:400 !important;color:rgba(255,255,255,0.7) !important;}
  .kp-p{font-size:14px !important;line-height:160% !important;font-weight:400 !important;color:rgba(255,255,255,0.55) !important;margin-bottom:24px !important;}
  .kp-sb{width:180px !important;height:180px !important;opacity:0.08 !important;left:-20px !important;right:auto !important;}
  .cta-btn{padding:14px 22px;font-size:11px;}

  /* ══ КОНТАКТЫ — мобилка ══ */
  .s7{background:linear-gradient(180deg,#0a0a0a 0%,#0a0c14 30%,#111a30 60%,#8a9bb5 85%,#c8d4e6 100%) !important;}
  .ct-b{padding:10px 20px 20px;}
  .ct-t{font-size:clamp(32px,9vw,48px) !important;line-height:115% !important;margin-bottom:24px !important;font-weight:800 !important;}
  .ct-g{grid-template-columns:1fr !important;gap:20px !important;max-width:100% !important;}
  .ct-i{gap:14px !important;}
  .ct-ic{width:44px !important;height:44px !important;border-width:1.5px !important;}
  .ct-ic svg{width:20px !important;height:20px !important;}
  .ct-lb{font-size:16px !important;font-weight:700 !important;line-height:130% !important;margin-bottom:2px !important;color:#fff !important;}
  .ct-vl{font-size:14px !important;font-weight:400 !important;line-height:140% !important;color:rgba(255,255,255,0.7) !important;}
  .ct-ft{margin-top:30px !important;padding-top:0 !important;}
  .ct-ft p{font-size:12px !important;font-weight:400 !important;line-height:180% !important;color:rgba(255,255,255,0.4) !important;}
  .ct-ft strong{font-size:15px !important;font-weight:600 !important;line-height:180% !important;color:rgba(255,255,255,0.6) !important;}
}

/* TABLET — 768–1024px */
@media(min-width:769px) and (max-width:1024px){
  .tb{padding:16px 28px;}
  .dir-layout{padding:0 28px 24px;}
  .dir-hdr-title{font-size:clamp(32px,5vw,52px);}
  .dir-acc-num{font-size:22px;}
  .dir-acc-title{font-size:16px;}
  .c-body{padding:16px 28px 40px;}
  .kp-b{padding:20px 28px 40px;}
  .ct-b{padding:10px 28px 20px;}
  .cases-hdr-row{padding:0 28px;}
  .dh{padding:0 28px 6px;}
  .cprog{margin:6px 28px 0;}
  .case-nav-dots{padding:6px 28px 0;}
  .cc{flex:0 0 92vw;}
}

/* ══════════════════════════════════════════════════════
   МОБИЛЬНЫЙ OVERRIDE
   ══════════════════════════════════════════════════════ */
@media(max-width:768px){
  .kp-t{font-size:clamp(32px,9vw,48px) !important;line-height:115% !important;margin-bottom:10px !important;}
  .kp-s{font-size:16px !important;margin-bottom:12px !important;line-height:140% !important;}
  .kp-d{margin-bottom:16px !important;}
  .kp-p{font-size:14px !important;line-height:160% !important;max-width:100% !important;}
  .kp-sb{width:180px !important;height:180px !important;opacity:0.08 !important;}

  .ct-t{font-size:clamp(32px,9vw,48px) !important;line-height:115% !important;margin-bottom:20px !important;}
  .ct-g{grid-template-columns:1fr !important;gap:20px !important;max-width:100% !important;}
  .ct-i{gap:14px !important;}
  .ct-ic{width:44px !important;height:44px !important;}
  .ct-ic svg{width:20px !important;height:20px !important;}
  .ct-lb{font-size:16px !important;line-height:130% !important;margin-bottom:2px !important;}
  .ct-vl{font-size:14px !important;line-height:140% !important;}
  .ct-ft{margin-top:30px !important;}
  .ct-ft p{font-size:12px !important;line-height:180% !important;}
  .ct-ft strong{font-size:15px !important;line-height:180% !important;}

  .c-bg{width:100% !important;right:0 !important;}
  .c-bg::after{display:none !important;}
  .lgrid{display:grid !important;grid-template-columns:repeat(2,1fr) !important;gap:12px 16px !important;flex-direction:initial !important;flex-wrap:initial !important;}
  .lgrid-row{display:contents !important;}
  .lph{flex:initial !important;width:auto !important;height:52px !important;padding:4px 8px !important;}
  .lph img{max-width:90px !important;max-height:36px !important;}
}