/* ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
   DANTATTOOMAN // NEW ERA OF INK
   DICH-inspired techno landing
░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░ */

:root{
  --ink:#0a0a0c;
  --cream:#f7e0c6;
  --lav:#cabdf3;
  --pink:#eaa9e4;
  --sky-pink:#f3b9c8;
  --yellow:#e9ff4f;
  --line:rgba(10,10,12,.55);
  --line-soft:rgba(10,10,12,.18);
  --pad:clamp(14px,2.6vw,40px);
  --font-d:'Chakra Petch',sans-serif;
  --font-m:'Space Mono',monospace;
  --font-display:'Chakra Petch','Unbounded',sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-d);
  background:var(--ink);
  color:var(--ink);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body.is-locked{overflow:hidden;height:100vh}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--ink);color:var(--yellow)}

.mono{font-family:var(--font-m)}

/* ░░ КУРСОР ░░ */
.cursor{
  position:fixed;top:0;left:0;width:30px;height:30px;border:2px solid #fff;
  border-radius:50%;pointer-events:none;z-index:9999;opacity:0;background:transparent;
  box-shadow:0 0 0 1.5px rgba(10,10,12,.85),0 1px 6px rgba(0,0,0,.35);
  transition:width .22s,height .22s,background .22s,border-color .22s,opacity .25s;
}
.cursor::after{content:"";position:absolute;top:50%;left:50%;width:5px;height:5px;
  border-radius:50%;background:var(--yellow);box-shadow:0 0 0 1px rgba(10,10,12,.9);
  transform:translate(-50%,-50%)}
.cursor.is-hover{width:54px;height:54px;border-color:var(--yellow);
  background:rgba(233,255,79,.18)}
.cursor.is-hover::after{opacity:0}
@media (pointer:fine){.cursor{opacity:1}body{cursor:none}a,button{cursor:none}}
@media (pointer:coarse){.cursor{display:none}}

/* ░░ РАМКА-ТЕРМИНАЛ ░░ */
.frame{position:fixed;inset:0;z-index:900;pointer-events:none;
  --fr:34px;border:8px solid var(--ink);border-radius:var(--fr);
}
/* заливка четырёх уголков цветом рамки, чтобы скругление было цельным (не «дырявым») */
.frame::before{content:"";position:absolute;inset:-8px;z-index:-1;pointer-events:none;
  background:
    radial-gradient(circle var(--fr) at var(--fr) var(--fr),transparent calc(var(--fr) - 1px),var(--ink) var(--fr)) top left,
    radial-gradient(circle var(--fr) at 0 var(--fr),transparent calc(var(--fr) - 1px),var(--ink) var(--fr)) top right,
    radial-gradient(circle var(--fr) at var(--fr) 0,transparent calc(var(--fr) - 1px),var(--ink) var(--fr)) bottom left,
    radial-gradient(circle var(--fr) at 0 0,transparent calc(var(--fr) - 1px),var(--ink) var(--fr)) bottom right;
  background-size:var(--fr) var(--fr);background-repeat:no-repeat;
}
body.theme-dark .frame::before{--ink:#11121a}
.frame__corner{position:absolute;width:26px;height:26px}
.frame__corner::before,.frame__corner::after{content:"";position:absolute;background:var(--cream)}
.frame__corner::before{width:100%;height:3px}
.frame__corner::after{width:3px;height:100%}
.frame__corner--lt{top:16px;left:16px}
.frame__corner--rt{top:16px;right:16px}.frame__corner--rt::before{right:0}.frame__corner--rt::after{right:0}
.frame__corner--lb{bottom:16px;left:16px}.frame__corner--lb::before{bottom:0}
.frame__corner--rb{bottom:16px;right:16px}.frame__corner--rb::before{bottom:0;right:0}.frame__corner--rb::after{right:0}
@media(max-width:640px){.frame{--fr:22px;border-width:6px}.frame::before{inset:-6px}}

/* ░░ ПРЕЛОАДЕР / ВРАТА ░░ */
.loader{position:fixed;inset:0;z-index:1000;background:var(--ink);color:var(--cream);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s ease,visibility .8s;
}
.loader.is-done{opacity:0;visibility:hidden}
.loader__side{position:absolute;top:50%;transform:translateY(-50%);font-family:var(--font-m);
  font-size:16px;line-height:1.9;letter-spacing:.06em;opacity:.8}
.loader__side--l{left:clamp(20px,5vw,80px)}
.loader__side--r{right:clamp(20px,5vw,80px);text-align:right}
.loader__granted{color:var(--yellow);margin-top:8px}
.loader__count{position:absolute;top:9%;left:50%;transform:translateX(-50%);
  font-family:var(--font-m);font-size:clamp(20px,4vw,40px);letter-spacing:.05em}
.loader__count b{font-weight:700}
.loader__tag{position:absolute;bottom:11%;left:50%;transform:translateX(-50%);
  font-family:var(--font-m);font-size:16px;letter-spacing:.18em;text-align:center;opacity:.7;
  width:90%}
.loader__core{position:relative;width:clamp(220px,30vw,330px);aspect-ratio:1;display:grid;place-items:center}
.loader__disc{position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg,var(--lav),var(--sky-pink),var(--cream),var(--yellow),var(--lav));
  filter:blur(2px);animation:spin 14s linear infinite;
  -webkit-mask:radial-gradient(circle,transparent 38%,#000 39%);mask:radial-gradient(circle,transparent 38%,#000 39%);
  opacity:.95}
@keyframes spin{to{transform:rotate(360deg)}}
.loader__enter{position:relative;z-index:2;font-family:var(--font-m);font-size:16px;letter-spacing:.14em;
  color:var(--cream);opacity:0;transform:scale(.9);transition:opacity .5s,transform .5s,color .25s;pointer-events:none}
.loader__enter .chev{color:var(--yellow)}
.loader.is-ready .loader__enter{opacity:1;transform:scale(1);pointer-events:auto}
.loader.is-ready .loader__enter:hover{color:var(--yellow)}

/* ░░ ШАПКА ░░ */
.top{position:fixed;top:0;left:0;width:100%;z-index:800;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(26px,4vw,56px);font-family:var(--font-m);font-size:16px;letter-spacing:.1em;
  mix-blend-mode:difference;color:#fff}
.top__logo{font-size:16px;letter-spacing:.26em}
.top__menu:hover,.top__logo:hover{color:var(--yellow)}
.toggle{display:flex;align-items:center;gap:9px}
.toggle__track{width:42px;height:18px;border:1px solid #fff;border-radius:10px;position:relative;display:block}
.toggle__knob{position:absolute;top:2px;left:2px;width:12px;height:12px;background:var(--yellow);border-radius:50%;
  transition:left .3s}
body.theme-dark .toggle__knob{left:26px}
.toggle__label{min-width:26px}

/* ░░ МЕНЮ ░░ */
.menu{position:fixed;inset:0;z-index:850;background:rgba(10,10,12,.97);color:var(--cream);
  display:flex;flex-direction:column;justify-content:center;padding:0 clamp(28px,8vw,120px);
  opacity:0;visibility:hidden;transition:opacity .45s,visibility .45s}
.menu.is-open{opacity:1;visibility:visible}
.menu__close{position:absolute;top:24px;right:clamp(26px,4vw,56px);font-family:var(--font-m);
  font-size:16px;letter-spacing:.14em}
.menu__close:hover{color:var(--yellow)}
.menu ul{list-style:none}
.menu li a{display:flex;align-items:baseline;gap:18px;font-family:var(--font-display);
  font-weight:700;font-size:clamp(32px,7vw,76px);line-height:1.22;text-transform:uppercase;
  transition:color .25s,transform .35s;transform:translateX(0)}
.menu li a span{font-family:var(--font-m);font-size:16px;font-weight:400;color:var(--yellow);opacity:.8}
.menu li a:hover{color:var(--yellow);transform:translateX(18px)}
.menu__foot{margin-top:40px;font-family:var(--font-m);font-size:16px;letter-spacing:.12em;opacity:.7}

/* ░░ HERO ░░ */
.hero{position:relative;height:100vh;min-height:600px;overflow:hidden}
.hero__sky{position:absolute;inset:0;background:url("../img/era-clouds.jpg") center/cover no-repeat;
  background-color:var(--sky-pink)}
.hero__sky-gl{position:absolute;inset:0;width:100%;height:100%;z-index:1;display:block;pointer-events:none}
.hero__sky::after{content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(120% 80% at 50% 30%,transparent 40%,rgba(243,185,200,.35))}

.hero__word{position:absolute;top:6%;left:0;width:100%;z-index:2;overflow:hidden;
  pointer-events:none;-webkit-mask:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent);
          mask:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent)}
.hero__word-track{display:flex;align-items:center;width:max-content;white-space:nowrap;
  animation:heroMarq 26s linear infinite}
.hero__word-track span,.hero__word-track i{font-family:var(--font-display);font-weight:700;
  font-size:clamp(34px,8vw,116px);line-height:.9;letter-spacing:-.03em;color:var(--ink);
  opacity:.82;text-transform:uppercase}
.hero__word-track i{font-style:normal;opacity:.45;padding:0 .32em;font-size:clamp(20px,4vw,56px)}
@keyframes heroMarq{to{transform:translateX(-50%)}}

.hero__figure{position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  height:94%;z-index:3;display:flex;align-items:flex-end;will-change:transform}
.hero__figure img{height:100%;width:auto;object-fit:contain;
  filter:drop-shadow(0 26px 46px rgba(120,60,30,.28))}
.hero__clouds-fg{position:absolute;bottom:-15%;left:-35%;
  width:170%;height:42vh;max-width:none;object-fit:cover;object-position:center 64%;
  z-index:4;pointer-events:none;opacity:.97;will-change:transform,object-position;
  animation:cloudsDrift 26s ease-in-out infinite alternate;
  -webkit-mask:linear-gradient(to top,transparent 0%,#000 16%,#000 60%,rgba(0,0,0,.4) 82%,transparent 100%);
          mask:linear-gradient(to top,transparent 0%,#000 16%,#000 60%,rgba(0,0,0,.4) 82%,transparent 100%)}
@keyframes cloudsDrift{from{object-position:46% 64%}to{object-position:54% 64%}}

.tag{position:absolute;font-family:var(--font-m);font-size:16px;letter-spacing:.1em;
  color:var(--ink);opacity:.75;z-index:5;writing-mode:vertical-rl;transform:rotate(180deg)}

.hero__aside{position:absolute;top:48%;font-family:var(--font-m);font-size:16px;letter-spacing:.12em;
  line-height:2.1;z-index:5}
.hero__aside--l{left:clamp(26px,4vw,56px)}
.hero__aside--r{right:clamp(26px,4vw,56px);text-align:right}
.hero__aside .plus{color:var(--yellow);letter-spacing:.4em}
.hero__aside .muted{opacity:.6}

.hero__big{position:absolute;bottom:5%;font-weight:700;font-size:clamp(54px,12vw,170px);
  line-height:.8;color:var(--ink);z-index:2;pointer-events:none}
.hero__big--l{left:clamp(20px,3vw,46px)}
.hero__big--r{right:clamp(20px,3vw,46px);transform:scaleX(-1)}

.coords{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);z-index:6;
  font-family:var(--font-m);font-size:16px;letter-spacing:.14em;color:var(--ink);opacity:.92;
  text-shadow:0 1px 8px rgba(255,248,242,.6)}

/* ░░ PILL КНОПКА ░░ */
.pill{position:relative;z-index:7;display:inline-flex;align-items:center;gap:14px;
  font-family:var(--font-m);font-size:16px;letter-spacing:.1em;font-weight:700;
  padding:15px 22px;color:var(--ink);background:var(--yellow);
  clip-path:polygon(0 0,calc(100% - 16px) 0,100% 50%,calc(100% - 16px) 100%,0 100%);
  transition:transform .25s,filter .25s}
.pill .pill__chev{background:var(--ink);color:var(--yellow);padding:6px 8px;margin:-15px -22px -15px 0;
  display:inline-flex;align-items:center}
.pill:hover{transform:translateY(-2px);filter:brightness(1.05)}
/* hero UTP */
.hero__utp{position:absolute;left:50%;bottom:5.5%;transform:translateX(-50%);z-index:7;
  width:min(700px,88vw);text-align:center;display:flex;flex-direction:column;align-items:center;gap:13px;
  text-shadow:0 1px 2px rgba(0,0,0,.28),0 2px 16px rgba(255,248,242,.6)}
.hero__eyebrow{font-family:var(--font-m);font-size:16px;letter-spacing:.1em;text-transform:uppercase;
  font-weight:700;display:flex;align-items:center;gap:9px;color:var(--ink)}
.hero__eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--yellow);
  box-shadow:0 0 0 1px var(--ink)}
.hero__title{font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  font-size:clamp(28px,4.6vw,58px);line-height:.98;letter-spacing:-.01em;color:var(--ink)}
.hero__sub{max-width:520px;font-size:clamp(16px,1.7vw,18px);line-height:1.5;font-weight:600;color:var(--ink)}
.hero__free{font-family:var(--font-m);font-size:16px;letter-spacing:.04em;font-weight:700;color:var(--ink)}
.hero__free b{color:#0e5e2c}
.hero__utp .pill{margin-top:4px}
.pill--dark{background:var(--ink);color:var(--cream)}
.pill--dark .pill__chev{background:var(--yellow);color:var(--ink)}
.pill--big{font-size:16px;padding:20px 30px;margin-top:34px}
.pill--big .pill__chev{margin:-20px -30px -20px 0;padding:8px 11px}

/* ░░ БЕГУЩАЯ СТРОКА ░░ */
.strip{background:var(--ink);color:var(--cream);overflow:hidden;padding:16px 0;
  border-top:1px solid rgba(247,224,198,.2);border-bottom:1px solid rgba(247,224,198,.2)}
.strip__track{display:flex;gap:30px;white-space:nowrap;width:max-content;
  animation:marq 26s linear infinite;font-family:var(--font-m);letter-spacing:.2em;font-size:16px}
.strip__track i{color:var(--yellow)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ░░ ПАНЕЛИ-СЕКЦИИ ░░ */
.panel{position:relative;padding:clamp(60px,9vw,130px) var(--pad) clamp(70px,10vw,150px);
  background-image:radial-gradient(var(--line-soft) 1px,transparent 1px);background-size:26px 26px}
.panel--cream{background-color:var(--cream)}
.panel--lav{background-color:var(--lav)}
.panel--pink{background-color:var(--pink)}
.panel__head{margin-bottom:clamp(30px,5vw,60px)}
.kicker{font-family:var(--font-m);font-size:16px;letter-spacing:.14em;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.kicker .dot{width:8px;height:8px;background:var(--ink);border-radius:50%}
.flip-title{font-family:var(--font-display);font-weight:700;font-size:clamp(46px,10vw,140px);line-height:.85;text-transform:uppercase;letter-spacing:-.01em}
.panel__intro{max-width:620px;font-size:clamp(16px,2vw,20px);line-height:1.5;margin-bottom:42px;font-weight:300}

/* .01 case — фото по центру, код-подписи слева, номер/кнопка справа */
.case{position:relative;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  gap:clamp(18px,3.5vw,56px);margin-bottom:clamp(40px,6vw,84px)}
.case__side{font-family:var(--font-m);font-size:16px;letter-spacing:.08em;line-height:1.8;
  display:flex;flex-direction:column;gap:12px}
.case__side .plus{color:var(--yellow);letter-spacing:.4em}
.case__side .dim{opacity:.5}
.case__side--r{align-items:flex-end;text-align:right}
.case__code{display:flex;flex-direction:column;gap:9px;margin-top:8px;opacity:.92}
.case__side b{font-weight:700;color:var(--ink)}
.case__code b{background:linear-gradient(transparent 62%,rgba(233,255,79,.8) 62%);padding:0 .08em}
.case__side{position:relative}
.case__frame{position:relative;display:grid;place-items:center;padding:clamp(22px,3vw,48px);
  border:1px solid rgba(10,10,12,.12)}
.cb{position:absolute;width:24px;height:24px;border:1.5px solid rgba(10,10,12,.55)}
.cb--lt{top:-1px;left:-1px;border-right:0;border-bottom:0}
.cb--rt{top:-1px;right:-1px;border-left:0;border-bottom:0}
.cb--lb{bottom:-1px;left:-1px;border-right:0;border-top:0}
.cb--rb{bottom:-1px;right:-1px;border-left:0;border-top:0}
.case__disc{width:min(88vh,840px);max-width:84vw;aspect-ratio:1;border-radius:50%;overflow:hidden;
  border:2px solid var(--ink);box-shadow:0 36px 90px rgba(120,60,30,.28)}
.case__disc img{width:100%;height:100%;object-fit:cover}
.case__dash{position:absolute;left:0;bottom:-6%;width:clamp(86px,8vw,140px);height:auto;color:rgba(10,10,12,.4)}
.case__box{width:94px;height:116px;border:1px solid var(--line);display:grid;place-items:center;overflow:hidden;margin-bottom:2px}
.case__box::before{content:"";width:78px;height:78px;border-radius:50%;
  background:repeating-radial-gradient(circle at 50% 50%,rgba(10,10,12,.5) 0 1px,transparent 1px 6px)}
.case__blurb{font-family:var(--font-m);font-size:16px;line-height:1.75;letter-spacing:.02em;
  max-width:240px;margin-top:8px;opacity:.82;text-align:right;margin-left:auto}
.case__statement{max-width:820px;margin:clamp(34px,5vw,68px) auto 0;text-align:center}
.case__statement p{font-family:var(--font-display);font-weight:700;text-transform:none;
  font-size:clamp(24px,3.4vw,42px);line-height:1.12;letter-spacing:-.01em;color:var(--ink)}
.case__statement b{font-weight:700;background:linear-gradient(transparent 58%,rgba(233,255,79,.85) 58%);
  padding:0 .05em}
.case__statement-sub{font-family:var(--font-d)!important;font-weight:400!important;
  font-size:clamp(16px,1.9vw,20px)!important;line-height:1.6!important;letter-spacing:0!important;
  color:var(--ink);opacity:.85;max-width:680px;margin:18px auto 0}
.case__box{width:88px;height:118px;border:1px solid var(--line);display:flex;flex-direction:column;
  justify-content:center;gap:6px;padding:0 14px;margin-bottom:4px}
.case__box span{height:2px;background:var(--ink);opacity:.32}
.case__box span:nth-child(2){width:72%}.case__box span:nth-child(3){width:50%}.case__box span:nth-child(4){width:62%}
.case__num{font-family:var(--font-display);font-weight:700;font-size:clamp(56px,8vw,122px);line-height:.9;letter-spacing:-.02em}
.case__about{max-width:680px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}
.case__lead{font-size:clamp(20px,2.4vw,29px);font-weight:600;line-height:1.28}
.case__text{font-size:clamp(16px,1.7vw,18px);line-height:1.6;font-weight:300;opacity:.85}

/* .02 галерея работ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,1.4vw,18px)}
.gw{position:relative;overflow:hidden;border:1px solid var(--line);aspect-ratio:3/4;display:block;
  padding:0;background:#0a0a0c;transition:transform .35s}
.gw img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s,filter .4s}
.gw:hover{transform:translateY(-5px)}
.gw:hover img{transform:scale(1.06);filter:brightness(.74)}
.gw__n{position:absolute;top:8px;left:10px;z-index:2;font-family:var(--font-m);font-size:16px;
  background:var(--ink);color:var(--cream);padding:2px 7px}
.gw__cap{position:absolute;inset:auto 0 0 0;z-index:2;display:flex;flex-direction:column;gap:2px;
  font-family:var(--font-m);font-size:16px;letter-spacing:.04em;text-align:left;color:var(--cream);
  padding:26px 10px 11px;background:linear-gradient(transparent,rgba(10,10,12,.9));
  opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s}
.gw__cap b{font-family:var(--font-display);font-size:16px;font-weight:700}
.gw:hover .gw__cap,.gw:focus-visible .gw__cap{opacity:1;transform:none}
.panel__more{display:flex;flex-wrap:wrap;align-items:center;gap:22px;margin-top:40px;
  font-family:var(--font-m);font-size:16px;letter-spacing:.04em}

/* лайтбокс */
.lightbox{position:fixed;inset:0;z-index:980;display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__overlay{position:absolute;inset:0;background:rgba(8,8,10,.93);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.lightbox__stage{position:relative;z-index:2;max-width:min(92vw,820px);display:flex;flex-direction:column;gap:14px}
.lightbox__img{max-width:100%;max-height:80vh;object-fit:contain;border:1px solid rgba(247,224,198,.2);
  box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox__cap{display:flex;justify-content:space-between;gap:20px;font-family:var(--font-m);
  font-size:16px;letter-spacing:.06em;color:var(--cream)}
.lightbox__count{opacity:.6;white-space:nowrap}
.lightbox__close{position:absolute;top:20px;right:26px;z-index:3;font-size:30px;line-height:1;color:var(--cream)}
.lightbox__close:hover{color:var(--yellow)}
.lightbox__nav{position:absolute;z-index:3;top:50%;transform:translateY(-50%);width:54px;height:54px;
  border:1px solid rgba(247,224,198,.4);border-radius:50%;font-size:26px;color:var(--cream);
  display:grid;place-items:center;transition:.25s}
.lightbox__nav:hover{background:var(--yellow);color:var(--ink);border-color:var(--yellow)}
.lightbox__nav--prev{left:max(16px,3vw)}.lightbox__nav--next{right:max(16px,3vw)}
@media(max-width:620px){.lightbox__nav{width:42px;height:42px;font-size:22px}
  .lightbox__nav--prev{left:6px}.lightbox__nav--next{right:6px}}

/* .03 process */
.orbit{position:absolute;top:8%;right:6%;width:min(40vw,420px);aspect-ratio:1;pointer-events:none;opacity:.55}
.orbit span{position:absolute;inset:0;border:1px solid var(--ink);border-radius:50%}
.orbit span:nth-child(1){transform:rotate(18deg) scaleY(.32)}
.orbit span:nth-child(2){transform:rotate(-26deg) scaleY(.5)}
.orbit span:nth-child(3){inset:18%;border-style:dashed;animation:spin 30s linear infinite}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,28px);position:relative;z-index:2}
.step{border-top:2px solid var(--ink);padding-top:18px}
.step__n{font-family:var(--font-m);font-size:16px;letter-spacing:.1em}
.step h3{font-size:clamp(19px,2.2vw,26px);font-weight:700;margin:14px 0 10px;text-transform:uppercase}
.step p{font-size:16px;line-height:1.55;font-weight:400;opacity:.88}

/* .04 prices */
.rates{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.6vw,20px)}
.rate{border:1px solid var(--line);padding:26px 24px;display:flex;flex-direction:column;gap:8px;
  background:rgba(255,255,255,.18);transition:background .3s,transform .3s}
.rate:hover{background:rgba(255,255,255,.4);transform:translateY(-4px)}
.rate__name{font-family:var(--font-m);font-size:16px;letter-spacing:.08em;text-transform:uppercase;opacity:.82}
.rate__val{font-weight:700;font-size:clamp(24px,3vw,34px)}
.rate__val.free{color:#1b7a3d}
.rate__note{font-size:16px;font-weight:400;opacity:.8}
.rate--feat{background:var(--ink);color:var(--cream)}
.rate--feat .rate__name{color:var(--yellow);opacity:1}
.rate--feat:hover{background:#16161a}

/* ░░ ФИНАЛ ░░ */
.outro{position:relative;background:var(--ink);color:var(--cream);overflow:hidden;
  padding:clamp(70px,10vw,130px) var(--pad) 40px;text-align:center}
.outro__small{font-family:var(--font-m);font-size:16px;letter-spacing:.16em;opacity:.75}
.outro__title{font-weight:700;font-size:clamp(34px,7.5vw,116px);line-height:.95;letter-spacing:-.01em;
  color:var(--cream);margin:18px 0 6px;text-transform:uppercase}
.outro__topo{font-weight:700;font-size:clamp(120px,32vw,440px);line-height:.8;letter-spacing:.02em;
  color:transparent;-webkit-text-stroke:1px rgba(247,224,198,.28);opacity:.6;margin:-2vw 0}
.outro__contacts{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(20px,5vw,70px);margin-top:10px}
.outro__contacts div{display:flex;flex-direction:column;gap:5px}
.outro__contacts span{font-family:var(--font-m);font-size:16px;letter-spacing:.12em;color:var(--yellow)}
.outro__contacts b{font-size:18px;font-weight:500}
.outro__contacts a:hover{color:var(--yellow)}
.outro__msgs{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;margin-top:34px;
  font-family:var(--font-m);font-size:16px;letter-spacing:.08em}
.outro__msgs a{border:1px solid rgba(247,224,198,.4);padding:11px 18px;transition:.25s}
.outro__msgs a:hover{background:var(--yellow);color:var(--ink);border-color:var(--yellow)}
.outro__foot{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;margin-top:60px;
  padding-top:22px;border-top:1px solid rgba(247,224,198,.2);
  font-family:var(--font-m);font-size:16px;letter-spacing:.08em;opacity:.8;text-align:left}
.outro__foot a:hover{color:var(--yellow)}

/* ░░ МОДАЛКА «СИГНАЛ» ░░ */
.signal{position:fixed;inset:0;z-index:950;visibility:hidden}
.signal.is-open{visibility:visible}
.signal__overlay{position:absolute;inset:0;background:rgba(10,10,12,.55);opacity:0;transition:opacity .4s}
.signal.is-open .signal__overlay{opacity:1}
.signal__panel{position:absolute;top:0;right:0;height:100%;width:min(520px,100%);
  background:var(--ink);color:var(--cream);padding:clamp(26px,4vw,52px);overflow-y:auto;
  transform:translateX(100%);transition:transform .5s cubic-bezier(.6,0,.2,1)}
.signal.is-open .signal__panel{transform:translateX(0)}
.signal__top{display:flex;justify-content:space-between;align-items:center}
.signal__eyebrow{font-family:var(--font-m);font-size:16px;letter-spacing:.12em;opacity:.8}
.signal__close{font-family:var(--font-m);font-size:16px;letter-spacing:.14em}
.signal__close:hover{color:var(--yellow)}
.signal__title{font-family:var(--font-display);font-weight:700;font-size:clamp(48px,10vw,92px);line-height:.85;color:var(--yellow);
  margin:18px 0 22px;text-transform:uppercase}
.signal__lead{font-size:16px;line-height:1.5;font-weight:300;opacity:.9;margin-bottom:34px}
.signal__form{display:flex;flex-direction:column;gap:6px}
.signal__form label{display:flex;flex-direction:column;border-bottom:1px solid rgba(247,224,198,.3);padding:14px 0}
.signal__form span{font-family:var(--font-m);font-size:16px;letter-spacing:.1em;opacity:.7;margin-bottom:6px}
.signal__form input{background:none;border:none;color:var(--cream);font-family:var(--font-d);font-size:18px;outline:none}
.signal__form input::placeholder{color:rgba(247,224,198,.35)}
.signal__send{margin-top:24px;width:100%;justify-content:space-between;
  display:flex;align-items:center;font-family:var(--font-m);font-weight:700;font-size:16px;letter-spacing:.12em;
  background:var(--cream);color:var(--ink);padding:18px 22px;
  clip-path:polygon(0 0,calc(100% - 16px) 0,100% 50%,calc(100% - 16px) 100%,0 100%);transition:.25s}
.signal__send:hover{background:var(--yellow)}
.signal__send .pill__chev{color:var(--ink)}
.signal__foot{margin-top:28px;font-family:var(--font-m);font-size:16px;line-height:1.7;letter-spacing:.05em;opacity:.7}
.signal__ok{display:none;text-align:center;padding-top:30px}
.signal__ok.is-shown{display:block}
.signal__ok-ico{width:64px;height:64px;border-radius:50%;background:var(--yellow);color:var(--ink);
  display:grid;place-items:center;font-size:30px;margin:0 auto 18px}
.signal__ok h4{font-size:26px;font-weight:700;margin-bottom:12px;color:var(--yellow)}
.signal__ok p{font-size:16px;font-weight:300;opacity:.85;margin-bottom:22px}

/* ░░ REVEAL ░░ */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s,transform .8s}
[data-reveal].is-in{opacity:1;transform:none}

/* ░░ ТЁМНАЯ ТЕМА (toggle) ░░ */
/* Светлые панели становятся тёмными — текст должен стать светлым.
   --cream НЕ трогаем глобально: он работает как светлый цвет текста
   на всегда-тёмных блоках (strip, outro, menu, signal). */
body.theme-dark .panel--cream{background-color:#101018;color:#f1e6d6}
body.theme-dark .panel--lav{background-color:#171430;color:#e9e4ff}
body.theme-dark .panel--pink{background-color:#241433;color:#ffe9fb}
body.theme-dark .panel{background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px)}
/* текст с захардкоженным под светлый фон цветом — возвращаем к цвету панели */
body.theme-dark .case__side b,
body.theme-dark .case__statement p,
body.theme-dark .case__statement-sub{color:inherit}
body.theme-dark .rate__val.free,body.theme-dark .hero__free b{color:#5fd98a}
/* декоративные линии и рамки, нарисованные тёмным по тёмному */
body.theme-dark .kicker .dot{background:currentColor}
body.theme-dark .kicker .dot,body.theme-dark .step{border-color:rgba(255,255,255,.5)}
body.theme-dark .case__disc,body.theme-dark .rate,body.theme-dark .case__frame{border-color:rgba(255,255,255,.25)}
body.theme-dark .cb,body.theme-dark .orbit span{border-color:rgba(255,255,255,.4)}
body.theme-dark .case__box{border-color:rgba(255,255,255,.3)}
body.theme-dark .case__box span{background:rgba(255,255,255,.5)}
body.theme-dark .case__dash{color:rgba(255,255,255,.4)}
body.theme-dark .step{border-top-color:rgba(255,255,255,.6)}
body.theme-dark .rate{background:rgba(255,255,255,.05)}
body.theme-dark .frame{border-color:#11121a}

/* ░░ АДАПТИВ ░░ */
@media(max-width:880px){
  /* ░ Блок «Обо мне»: фото → главный текст → кнопка; терминальная статистика скрыта ░ */
  #about{display:flex;flex-direction:column;align-items:center;gap:24px}
  #about .case{display:contents}
  #about .case__side--l{display:none}
  #about .case__side--r{display:contents}
  #about .case__side--r > *:not(.pill){display:none}
  #about .panel__head{order:0;align-self:stretch;margin-bottom:0}
  #about .case__frame{order:1}
  #about .case__statement{order:2;margin:0;text-align:center}
  #about .case__side--r .pill{order:3}
  .case__disc{width:min(78vw,400px)}

  .gallery{grid-template-columns:repeat(2,1fr)}
  .gw__cap{opacity:1;transform:none}
  .steps{grid-template-columns:repeat(2,1fr)}
  .rates{grid-template-columns:1fr 1fr}
  .hero__aside{display:none}
}
@media(max-width:760px){
  .tag{display:none}
  .hero__word{top:9.5%}
  .hero__word-track span,.hero__word-track i{font-size:clamp(26px,8.5vw,70px)}
  .hero__figure{height:auto;width:116%;top:16%;bottom:auto;align-items:flex-start}
  .hero__figure img{width:100%;height:auto;
    -webkit-mask:linear-gradient(to top,transparent 0%,#000 24%,#000 100%);
            mask:linear-gradient(to top,transparent 0%,#000 24%,#000 100%)}
  .hero__clouds-fg{height:36vh;width:200%;left:-50%;bottom:-5%}
  .hero__utp{bottom:3.5%;width:94vw;gap:9px}
  .hero__title{font-size:clamp(20px,6.4vw,32px)}
  .hero__sub{font-size:16px;line-height:1.45;max-width:92vw}
  .hero__eyebrow{font-size:12px;letter-spacing:.08em}
  .hero__free{font-size:12px}
  .coords{font-size:14px;bottom:10px}
}
@media(max-width:560px){
  .rates{grid-template-columns:1fr}
  .loader__side{font-size:16px}
  .hero__figure{width:112%;top:17%}
  .hero__title{font-size:clamp(18px,6.1vw,26px)}
  .hero__eyebrow{font-size:11px;letter-spacing:.05em}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.2s!important}
}
