/* ============================================================
   УЛЬМАГИ — Лодки из HDPE
   Размерная система откалибрована под все экраны:
   · Ноутбук 2К 150% → viewport ~1707×960px
   · Ноутбук 1080p 100% → viewport 1920×1080px
   · Планшет → 768–1080px
   · Телефон → 360–680px
   ============================================================ */

/* ===================== ТЕМЫ ===================== */
:root{
  --accent:#D86A27;
  --accent-deep:#b9531a;
  --ff-head:'Oswald',sans-serif;
  --ff-body:'Inter',sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:1480px;
  --pad:clamp(16px,3.5vw,64px);
}
:root,[data-theme="light"]{
  --bg:#EDEFF1;
  --bg-2:#F5F6F8;
  --surface:#E1E4E7;
  --ink:#15191C;
  --ink-soft:#404850;
  --mut:#6c747a;
  --line:rgba(21,25,28,.13);
  --line-strong:rgba(21,25,28,.24);
  --nav-scrolled-bg:rgba(237,239,241,.92); /* для плавной анимации nav без color-mix */
}
[data-theme="dark"]{
  --bg:#0D0F11;
  --bg-2:#080A0B;
  --surface:#1A1F24;
  --ink:#EDEFF1;
  --ink-soft:#bfc6cc;
  --mut:#7a8590;
  --line:rgba(183,190,196,.14);
  --line-strong:rgba(183,190,196,.28);
  --nav-scrolled-bg:rgba(13,15,17,.92);
}

/* ===================== СБРОС И БАЗА ===================== */
*{margin:0;padding:0;box-sizing:border-box}
/* overflow-x:clip на html, а не на body —
   иначе body становится scroll-контейнером и position:fixed «уплывает» на мобиле */
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--ff-body);line-height:1.6;
  -webkit-font-smoothing:antialiased;
  transition:background-color .35s ease, color .35s ease;
}
body.loading{overflow:hidden;height:100vh}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}
h1,h2,h3{font-family:var(--ff-head);font-weight:600;line-height:1.05;text-transform:uppercase;letter-spacing:-.01em;color:var(--ink);transition:color .35s ease}
.accent{color:var(--accent)}

/* ===================== ТИПОГРАФИКА-ШКАЛА =====================
   vw-процент откалиброван под 1707px (2К 150%):
   4vw → ~68px | 5vw → ~85px
   При 1920px: 4vw → 77px | 5vw → 96px  — нормально
   ============================================================ */
.t-hero   {font-size:clamp(36px, 6vw,   90px)}  /* герой */
.t-h1     {font-size:clamp(28px, 4.5vw, 64px)}  /* главные заголовки секций */
.t-h2     {font-size:clamp(22px, 3.2vw, 46px)}  /* подзаголовки */
.t-h3     {font-size:clamp(16px, 2vw,   28px)}  /* карточки / блоки */
.t-body   {font-size:clamp(14px, 1.2vw, 17px)}  /* основной текст */
.t-small  {font-size:clamp(12px, 1vw,   14px)}  /* подписи */

/* ===================== ОБЩИЕ КОМПОНЕНТЫ ===================== */
.kicker{
  font-family:var(--ff-head);font-weight:500;
  font-size:clamp(11px,1vw,13px);letter-spacing:.26em;
  text-transform:uppercase;color:var(--accent);display:inline-block;
}
.kicker::before{
  content:"";display:inline-block;width:26px;height:2px;
  background:var(--accent);vertical-align:middle;
  margin-right:12px;transform:translateY(-3px);
}

.section-head{
  padding:clamp(38px,5.2vw,78px) var(--pad) clamp(20px,3vw,42px);
  max-width:var(--maxw);margin:0 auto;
}
.section-head h2{font-size:clamp(26px,4vw,56px);margin-top:16px}
.section-note{margin-top:14px;color:var(--mut);font-size:clamp(13px,1.1vw,16px);max-width:480px}

.arrow{width:20px;height:9px;display:inline-block;position:relative;flex:none}
.arrow::before{content:"";position:absolute;top:50%;left:0;width:100%;height:2px;background:currentColor;transform:translateY(-50%)}
.arrow::after{content:"";position:absolute;top:50%;right:0;width:7px;height:7px;border-top:2px solid currentColor;border-right:2px solid currentColor;transform:translateY(-50%) rotate(45deg)}

/* ===================== КНОПКИ ===================== */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--ff-head);font-weight:500;
  font-size:clamp(13px,1.1vw,15px);letter-spacing:.06em;text-transform:uppercase;
  padding:clamp(12px,1.2vw,16px) clamp(18px,2vw,28px);
  border:2px solid transparent;cursor:pointer;
  position:relative;overflow:hidden;transition:.4s var(--ease);
}
.btn span,.btn i{position:relative;z-index:2}
.btn--solid{background:var(--accent);color:#fff}
.btn--solid::after{content:"";position:absolute;inset:0;background:var(--accent-deep);transform:translateY(101%);transition:transform .4s var(--ease);z-index:1}
.btn--solid:hover::after{transform:translateY(0)}
.btn--ghost{border-color:rgba(255,255,255,.55);color:#fff}
.btn--ghost:hover{background:#fff;color:#15191C;border-color:#fff}
.btn--line{border-color:var(--line-strong);color:var(--ink)}
.btn--line:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.btn--line:hover .arrow{transform:translateX(5px)}
.btn--line .arrow{transition:transform .4s var(--ease)}

.link-underline{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ff-head);font-weight:500;
  font-size:clamp(13px,1.1vw,15px);letter-spacing:.06em;text-transform:uppercase;
  padding-bottom:4px;border-bottom:2px solid var(--line-strong);transition:.4s var(--ease);
}
.link-underline:hover{color:var(--accent);border-color:var(--accent)}
.link-underline:hover .arrow{transform:translateX(5px)}
.link-underline .arrow{transition:transform .4s var(--ease)}

/* ===================== ЗАГРУЗЧИК ===================== */
.loader{position:fixed;inset:0;z-index:1000;background:var(--bg-2);display:flex;align-items:center;justify-content:center}
.loader.done{transform:translateY(-100%);transition:transform .9s var(--ease)}
.loader__inner{width:min(400px,80vw);text-align:center}
.loader__mark{
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);
}
.loader__logo-svg{
  height:clamp(32px,5vw,52px);width:auto;display:block;
}
.loader__bar{height:3px;background:var(--line);margin:20px 0 12px;overflow:hidden}
.loader__bar span{display:block;height:100%;width:0;background:var(--accent);transition:width .2s linear}
.loader__meta{display:flex;justify-content:space-between;font-family:var(--ff-head);font-size:11px;letter-spacing:.2em;color:var(--mut)}
.loader__meta span:first-child{color:var(--accent)}

/* ===================== ШАПКА ===================== */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:120;
  padding:clamp(10px,1.2vw,16px) var(--pad);
  border-bottom:1px solid transparent;
  transition:padding .4s var(--ease),background .4s var(--ease),border-color .4s,box-shadow .4s,backdrop-filter .4s;
}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
/* всегда белый текст/логотип на герое */
.nav__logo-svg,.nav__links a,.nav__cta{color:#fff;transition:color .4s var(--ease)}
.nav.scrolled{
  padding:clamp(8px,1vw,12px) var(--pad);
  background:var(--nav-scrolled-bg); /* прямое rgba — хорошо анимируется */
  backdrop-filter:blur(12px);
  border-color:var(--line);
  box-shadow:0 4px 20px rgba(0,0,0,.1);
}
.nav.scrolled .nav__logo-svg,
.nav.scrolled .nav__links a,.nav.scrolled .nav__cta{color:var(--ink)}
.nav.scrolled .nav__burger span{background:var(--ink)}
.nav__brand{display:flex;align-items:center;line-height:1}
.nav__logo-svg{
  height:clamp(28px,2.8vw,40px);
  width:auto;
  display:block;
  flex:none;
  transition:color .4s var(--ease);
}
.nav__links{display:flex;gap:clamp(16px,2vw,30px)}
.nav__links a{
  font-family:var(--ff-head);font-size:clamp(12px,1vw,14px);
  letter-spacing:.05em;text-transform:uppercase;
  position:relative;padding:4px 0;
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--accent);transition:width .4s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__right{display:flex;align-items:center;gap:14px}
.nav__cta{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ff-head);font-weight:500;
  font-size:clamp(12px,1vw,14px);letter-spacing:.06em;text-transform:uppercase;
  border:2px solid rgba(255,255,255,.5);
  padding:clamp(8px,.9vw,12px) clamp(14px,1.4vw,20px);
  transition:.4s var(--ease);
}
.nav.scrolled .nav__cta{border-color:var(--line-strong)}
.nav__cta:hover{background:var(--accent);border-color:var(--accent)!important;color:#fff!important}
.nav__cta:hover .arrow{transform:translateX(4px)}
.nav__cta .arrow{transition:transform .4s var(--ease)}

/* Переключатель темы */
.theme-toggle{
  background:none;border:none;cursor:pointer;padding:3px;
  display:flex;align-items:center;gap:6px;
  -webkit-tap-highlight-color:transparent;  /* убираем серый квадратик на iOS */
  -webkit-appearance:none;
}
.theme-toggle__sun,
.theme-toggle__moon{
  display:block;flex:none;
  color:#fff;  /* совпадает с остальными иконками nav над героем */
  transition:opacity .35s ease, transform .35s ease, color .35s ease;
}
/* активная иконка ярче, неактивная — полупрозрачная */
[data-theme="light"] .theme-toggle__sun  { opacity:1; transform:scale(1.15) }
[data-theme="light"] .theme-toggle__moon { opacity:0.38 }
[data-theme="dark"]  .theme-toggle__sun  { opacity:0.38 }
[data-theme="dark"]  .theme-toggle__moon { opacity:1; transform:scale(1.15) }
/* цвет иконок: белый над героем, тёмный/светлый в прокрученной шапке */
.nav.scrolled .theme-toggle__sun,
.nav.scrolled .theme-toggle__moon { color: var(--ink); transition: color .35s ease }
[data-theme="light"] .nav.scrolled .theme-toggle__sun,
[data-theme="light"] .nav.scrolled .theme-toggle__moon { color: #15191C }
[data-theme="dark"]  .nav.scrolled .theme-toggle__sun,
[data-theme="dark"]  .nav.scrolled .theme-toggle__moon { color: #EDEFF1 }
.theme-toggle__track{
  position:relative;width:44px;height:24px;
  border:2px solid rgba(255,255,255,.5);border-radius:40px;
  display:block;transition:border-color .4s;flex:none;
}
.nav.scrolled .theme-toggle__track{border-color:var(--line-strong)}
.theme-toggle__knob{
  position:absolute;top:2px;left:2px;width:16px;height:16px;
  border-radius:50%;background:var(--accent);
  transition:transform .4s var(--ease);
}
[data-theme="dark"] .theme-toggle__knob{transform:translateX(20px)}
.theme-toggle:hover .theme-toggle__track{border-color:var(--accent)}

.nav__burger{display:none;flex-direction:column;gap:5px;width:28px;height:20px;background:none;border:none;cursor:pointer;justify-content:center;-webkit-tap-highlight-color:transparent}
.nav__burger span{display:block;height:2px;width:100%;background:#fff;transition:.4s var(--ease)}
.nav.scrolled .nav__burger span,
.nav.menu-open .nav__burger span{background:var(--ink)}

/* ── Меню открыто: шапка получает фон и тёмные иконки ──────────── */
.nav.menu-open{
  background:var(--nav-scrolled-bg);
  backdrop-filter:blur(12px);
  border-color:var(--line);
}
.nav.menu-open .nav__logo-svg,
.nav.menu-open .nav__cta,
.nav.menu-open .theme-toggle__sun,
.nav.menu-open .theme-toggle__moon{color:var(--ink)}
.nav.menu-open .theme-toggle__track{border-color:var(--line-strong)}
/* [data-theme] для надёжности на мобильном Safari */
[data-theme="light"] .nav.menu-open .nav__logo-svg,
[data-theme="light"] .nav.menu-open .nav__cta,
[data-theme="light"] .nav.menu-open .theme-toggle__sun,
[data-theme="light"] .nav.menu-open .theme-toggle__moon{color:#15191C}
[data-theme="dark"]  .nav.menu-open .nav__logo-svg,
[data-theme="dark"]  .nav.menu-open .nav__cta,
[data-theme="dark"]  .nav.menu-open .theme-toggle__sun,
[data-theme="dark"]  .nav.menu-open .theme-toggle__moon{color:#EDEFF1}
[data-theme="dark"]  .nav.menu-open .nav__burger span{background:#EDEFF1}
.nav__burger.open span:nth-child(1){transform:translateY(3.5px) rotate(45deg)}
.nav__burger.open span:nth-child(2){transform:translateY(-3.5px) rotate(-45deg)}

.mobile-menu{
  position:fixed;inset:0;z-index:110;background:var(--bg-2);
  display:flex;flex-direction:column;justify-content:flex-start;
  padding:clamp(64px,9vw,88px) var(--pad) clamp(24px,4vw,40px);
  transform:translateX(100%);transition:transform .6s var(--ease),background-color .35s ease;
}
.mobile-menu.open{transform:translateX(0)}

/* Контакты — над пунктами меню */
.mobile-menu__contacts{
  display:flex;flex-direction:column;gap:2px;
  padding-bottom:clamp(14px,2.5vw,22px);
  margin-bottom:clamp(10px,2vw,18px);
  border-bottom:1px solid var(--line);
}
.mobile-menu .mobile-menu__contacts a{
  font-family:var(--ff-head);font-weight:500;
  font-size:clamp(16px,4.5vw,24px);
  text-transform:none;letter-spacing:.01em;
  color:var(--mut);border-bottom:none;padding:3px 0;
  transition:color .35s ease;
}
.mobile-menu .mobile-menu__contacts a:hover,
.mobile-menu .mobile-menu__contacts a:active{color:var(--accent)}

/* Навигационные пункты */
.mobile-menu__nav{display:flex;flex-direction:column;gap:0}
.mobile-menu__nav a{
  font-family:var(--ff-head);font-weight:600;
  font-size:clamp(22px,5.5vw,36px);text-transform:uppercase;
  color:var(--ink);border-bottom:1px solid var(--line);
  padding:10px 0;transition:color .35s ease,transform .4s var(--ease);
}
.mobile-menu__nav a:hover,
.mobile-menu__nav a:active{color:var(--accent);transform:translateX(10px)}

/* ===================== ГЕРОЙ — 100svh, фон и текст уезжают вместе ===================== */
.hero{position:relative;height:100svh;min-height:500px;max-height:1440px;overflow:hidden;max-width:2560px;margin-left:auto;margin-right:auto}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__bg,.hero__video{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.hero__scrim{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,10,12,.55) 0%,rgba(8,10,12,.2) 42%,rgba(8,10,12,.6) 100%),
             linear-gradient(90deg,rgba(8,10,12,.65) 0%,transparent 60%);
}
.hero__content{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;justify-content:center;
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
}
.hero__tag{
  display:inline-flex;align-self:flex-start;align-items:center;
  font-family:var(--ff-head);font-size:clamp(11px,.85vw,16px);
  letter-spacing:.18em;text-transform:uppercase;
  color:#fff;border:2px solid rgba(255,255,255,.4);
  padding:6px 13px;margin-bottom:clamp(14px,1.8vw,32px);
}
.hero__title{
  color:#fff;
  font-size:clamp(34px,5.4vw,120px);
  letter-spacing:-.02em;
  margin-bottom:clamp(12px,1.6vw,32px);
}
.hero__title .line{display:block;overflow:hidden;padding:.14em 0;margin:-.14em 0}
.hero__title .word{display:inline-block;transform:translateY(110%);transition:transform .9s var(--ease)}
.hero.in .hero__title .word{transform:translateY(0)}
.hero.in .line:nth-child(2) .word{transition-delay:.1s}
.hero.in .line:nth-child(3) .word{transition-delay:.2s}
.hero__lead{
  color:rgba(255,255,255,.9);max-width:clamp(500px,32vw,680px);
  font-size:clamp(13px,1.15vw,24px);
  margin-bottom:clamp(18px,2.2vw,42px);
}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap}
.hero__scroll{
  position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-family:var(--ff-head);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.8);
}
.hero__scroll i{width:2px;height:36px;background:rgba(255,255,255,.28);position:relative;overflow:hidden}
.hero__scroll i::after{content:"";position:absolute;top:0;left:0;width:100%;height:50%;background:var(--accent);animation:scrolldot 1.8s ease-in-out infinite}
@keyframes scrolldot{0%{transform:translateY(-100%)}100%{transform:translateY(220%)}}

/* секции — свой фон поверх возможного fixed-слоя */
.make,.works,.lineup,.hdpe,.cases,.process,.contact{position:relative;z-index:5;background:var(--bg);transition:background-color .35s ease}
/* «Как делаем» — прозрачный фон, сетка не нужна */
.process{background:transparent}

/* ===================== ОБ УЛЬМАГАХ ===================== */
.make{max-width:var(--maxw);margin:0 auto;padding:clamp(38px,5.2vw,78px) var(--pad)}
.make__top{
  display:grid;grid-template-columns:1.1fr .9fr;
  gap:clamp(24px,3.6vw,72px);align-items:start;
  margin-bottom:clamp(28px,3.8vw,56px);
}
.make__title .kicker{margin-bottom:14px}
.make__title h2{font-size:clamp(26px,4vw,56px)}
.make__intro{display:flex;flex-direction:column;gap:18px;padding-top:8px}
.make__intro p{
  color:var(--ink-soft);font-size:clamp(13px,1.1vw,16px);line-height:1.7;
}
.make__intro p + p{border-top:1px solid var(--line);padding-top:18px}
.make__facts{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(14px,2vw,32px);
  border-top:1px solid var(--line);
  padding-top:clamp(22px,3vw,40px);
}
.fact{padding-top:18px;border-top:3px solid var(--accent)}
.fact__n{font-family:var(--ff-head);font-size:12px;letter-spacing:.1em;color:var(--accent)}
.fact h3{font-size:clamp(16px,1.8vw,22px);margin:8px 0 8px}
.fact p{color:var(--ink-soft);font-size:clamp(13px,1.1vw,15px);max-width:280px;line-height:1.65}

/* ===================== ВЫПОЛНЕННЫЕ РАБОТЫ ===================== */
.works{overflow:hidden}

.works__head{
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(32px,4.4vw,64px) var(--pad) clamp(18px,2.2vw,32px);
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.works__head-left .kicker{margin-bottom:12px}
.works__head-left h2{font-size:clamp(24px,3.6vw,50px)}
.works__head-right{flex:none}
.works__nav{display:flex;align-items:center;gap:16px}
.works__counter{
  font-family:var(--ff-head);font-size:clamp(16px,1.5vw,20px);
  letter-spacing:.04em;color:var(--mut);min-width:72px;text-align:center;
}
.works__counter span:first-child{color:var(--accent);font-size:1.3em}
.works__btn{
  width:clamp(38px,3.2vw,46px);height:clamp(38px,3.2vw,46px);
  border:2px solid var(--line-strong);background:none;cursor:pointer;
  position:relative;flex:none;transition:.4s var(--ease);color:var(--ink);
}
.works__btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.works__btn--prev::before,.works__btn--next::before{
  content:"";position:absolute;top:50%;left:50%;
  width:10px;height:10px;
  border-top:2px solid currentColor;border-left:2px solid currentColor;
  transform:translate(-30%,-50%) rotate(-45deg);
}
.works__btn--next::before{transform:translate(-70%,-50%) rotate(135deg)}

/* CSS Grid trick — все слайды в одной ячейке */
.works__track{
  display:grid;grid-template-areas:"slide";
  max-width:var(--maxw);margin:0 auto;  /* ограничение по ширине как у других секций */
}
.work{
  grid-area:slide;
  display:grid;
  grid-template-columns:42fr 58fr;
  align-items:stretch;
  /* высота = контент слева, но фото не растянет блок выше потолка */
  min-height:clamp(300px,42vh,480px);
  max-height:clamp(460px,58vh,580px);
  opacity:0;pointer-events:none;
  transition:opacity .5s var(--ease),transform .5s var(--ease);
  transform:translateX(50px);
}
.work.is-active{opacity:1;pointer-events:auto;transform:translateX(0)}

/* Левая панель */
.work__info{
  display:flex;flex-direction:column;justify-content:flex-start;
  padding:clamp(18px,2.5vw,40px) clamp(16px,2.5vw,48px) clamp(18px,2.5vw,40px) var(--pad);
  overflow:hidden;            /* при max-height контент не вылезет */
}
.work__num{
  font-family:var(--ff-head);font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--accent);margin-bottom:8px;display:block;flex:none;
}
.work__title{font-size:clamp(18px,2.4vw,36px);margin-bottom:10px;line-height:1.05;flex:none}
.work__desc{
  color:var(--ink-soft);font-size:clamp(13px,1.1vw,15px);
  margin-bottom:14px;max-width:440px;line-height:1.6;flex:none;
}
.work__params{
  list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);margin-bottom:18px;flex:none;
}
.work__param{background:var(--bg-2);padding:8px 12px;transition:background .3s}
.work__param:hover{background:var(--surface)}
.work__param dt{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--mut);margin-bottom:3px}
.work__param dd{font-family:var(--ff-head);font-weight:600;font-size:clamp(13px,1.3vw,18px);color:var(--ink)}

/* Правая панель — галерея */
.work__gallery{
  display:flex;flex-direction:column;
  overflow:hidden;background:var(--surface);
}
.work__main{
  flex:1;min-height:0;
  overflow:hidden;
  position:relative; /* якорь для абсолютной картинки */
}
.work__main-img{
  /* position:absolute — картинка вне потока, смена src не меняет геометрию блока */
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;
  transition:opacity .32s ease;
}
.work__main-img.is-changing{opacity:0;}

/* Миниатюры — квадратные */
.work__thumbs{
  display:flex;gap:4px;flex:none;
  padding:4px 4px 4px 0;
  background:var(--bg-2);
}
.work__thumb{
  width:clamp(60px,7.5vh,86px);
  height:clamp(60px,7.5vh,86px);
  aspect-ratio:1;
  flex:none;overflow:hidden;
  padding:0;border:none;cursor:pointer;background:none;
  position:relative;outline:3px solid transparent;outline-offset:-3px;
  transition:outline-color .3s var(--ease),filter .3s var(--ease);
}
.work__thumb img{width:100%;height:100%;object-fit:cover;filter:brightness(.65);transition:filter .4s var(--ease);display:block}
.work__thumb.is-active{outline-color:var(--accent)}
.work__thumb.is-active img,.work__thumb:hover img{filter:brightness(1)}

/* прогресс-бар удалён по запросу */

/* ===================== НАШИ ЛОДКИ ===================== */
.lineup .section-head{padding-bottom:clamp(16px,2.5vw,32px)}
.model{
  display:grid;grid-template-columns:1.05fr .95fr;
  gap:clamp(20px,3.4vw,52px);align-items:center;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(24px,3.4vw,52px) var(--pad);
  border-top:1px solid var(--line);
}
.model--rev .model__media{order:2}
.model__media{position:relative;overflow:hidden;aspect-ratio:16/10;background:var(--surface)}
.model__media img{width:100%;height:100%;object-fit:cover;filter:contrast(1.03);transition:transform .9s var(--ease);will-change:transform;display:block}
.model:hover .model__media img{transform:scale(1.05)}
.model__class{font-family:var(--ff-head);font-size:clamp(11px,.85vw,12px);letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.model__name{font-size:clamp(20px,2.9vw,42px);margin:8px 0 12px}
.model__info p{color:var(--ink-soft);max-width:420px;margin-bottom:20px;font-size:clamp(13px,1.05vw,15px)}
.model__specs{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);margin-bottom:22px;
}
.model__specs>div{background:var(--bg-2);padding:clamp(9px,.9vw,14px) clamp(9px,.9vw,13px)}
.model__specs dt{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--mut);margin-bottom:5px}
.model__specs dd{font-family:var(--ff-head);font-weight:600;font-size:clamp(15px,1.4vw,20px);color:var(--ink)}

/* ===================== ПОЧЕМУ ПЛАСТИК ===================== */
.hdpe{
  display:grid;grid-template-columns:.95fr 1.05fr;
  gap:clamp(20px,3.4vw,52px);
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(38px,5.2vw,78px) var(--pad);
  align-items:start;
}
.hdpe__sticky{position:sticky;top:72px}
.hdpe__title{font-size:clamp(22px,3.4vw,50px);margin:16px 0 16px}
.hdpe__lead{color:var(--ink-soft);max-width:360px;font-size:clamp(13px,1.05vw,15px)}
.hdpe__panels{display:flex;flex-direction:column}
.hpanel{
  padding:clamp(14px,1.7vw,26px) 0;border-top:1px solid var(--line);
  display:grid;grid-template-columns:40px 1fr;gap:5px 16px;
}
.hpanel:last-child{border-bottom:1px solid var(--line)}
.hpanel__num{grid-row:span 2;font-family:var(--ff-head);font-weight:700;font-size:clamp(26px,3.2vw,42px);color:var(--accent);line-height:.9}
.hpanel h3{font-size:clamp(16px,1.8vw,25px);transition:transform .5s var(--ease)}
.hpanel p{color:var(--ink-soft);font-size:clamp(13px,1.05vw,15px)}
.hpanel:hover h3{transform:translateX(8px)}

/* ===================== ВИДЕО ===================== */
.cases .section-head{max-width:var(--maxw)}
.vcases__grid{
  max-width:var(--maxw);margin:0 auto;
  padding:0 var(--pad) clamp(26px,3.4vw,52px);
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:clamp(170px,22vh,250px);
  gap:8px;
  grid-auto-flow:dense; /* плотная упаковка — браузер сам затыкает дыры */
}
/* ── Бенто-паттерн: каждые 5 карточек образуют блок 4×2 без пустых мест
   5n+1 → широкая (2 колонки)        итого: 2+2+1+2+1 = 8 ячеек = 4×2 ✓
   5n+2 → высокая (2 строки)
   5n+4 → широкая (2 колонки)                                            */
.vcard:nth-child(5n+1){grid-column:span 2}
.vcard:nth-child(5n+2){grid-row:span 2}
.vcard:nth-child(5n+4){grid-column:span 2}

/* Сама карточка — высота из grid-auto-rows, без aspect-ratio */
.vcard{
  position:relative;
  overflow:hidden;background:#0c0e10;cursor:pointer;
}
.vcard__img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .9s var(--ease);
}
.vcard:hover .vcard__img{transform:scale(1.07)}

/* Оверлей: постоянный градиент снизу, при ховере — полумрак */
.vcard__overlay{
  position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.68) 100%);
  display:flex;align-items:center;justify-content:center;
  transition:background .4s var(--ease);
}
.vcard:hover .vcard__overlay{background:rgba(0,0,0,.54)}

/* Иконка play — центр, всегда видна */
.vcard__play{
  flex:none;
  filter:drop-shadow(0 2px 12px rgba(0,0,0,.6));
  transition:transform .4s var(--ease),opacity .4s var(--ease);
}
.vcard:hover .vcard__play{transform:scale(1.18)}

/* Подпись — скрыта, появляется снизу при ховере */
.vcard__cap{
  position:absolute;bottom:0;left:0;right:0;
  padding:clamp(10px,1.2vw,16px) clamp(12px,1.4vw,18px);
  opacity:0;transform:translateY(8px);
  transition:opacity .4s var(--ease),transform .4s var(--ease);
}
.vcard:hover .vcard__cap{opacity:1;transform:translateY(0)}
.vcard__ttl{
  font-family:var(--ff-head);font-size:clamp(12px,1.1vw,16px);
  color:#fff;letter-spacing:.05em;text-transform:uppercase;margin-bottom:4px;
}
.vcard__dsc{
  color:rgba(255,255,255,.82);font-size:clamp(11px,.9vw,13px);
  line-height:1.45;
}
/* Тач-устройства: подпись всегда видна */
@media(hover:none){
  .vcard__cap{opacity:1;transform:none}
  .vcard__overlay{background:rgba(0,0,0,.48)}
}

/* ===================== КАК ДЕЛАЕМ ===================== */
.process .section-head{max-width:var(--maxw)}
.timeline{
  list-style:none;max-width:var(--maxw);margin:0 auto;
  padding:0 var(--pad) clamp(32px,4.4vw,64px);
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,2vw,28px);
}
.tl{
  background:transparent;
  padding:clamp(16px,2.2vw,32px) 0;
  border-top:1px solid var(--line);
  position:relative;overflow:hidden;transition:color .4s var(--ease);
}
.tl::before{content:"";position:absolute;left:0;top:0;width:100%;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.tl:hover::before{transform:scaleX(1)}
.tl__n{
  display:flex;align-items:center;justify-content:center;
  width:clamp(36px,3.5vw,48px);height:clamp(36px,3.5vw,48px);
  border:2px solid var(--accent);border-radius:50%;
  font-family:var(--ff-head);font-weight:700;
  font-size:clamp(16px,1.6vw,20px);color:var(--accent);margin-bottom:16px;
}
.tl__c h3{font-size:clamp(16px,1.8vw,24px);margin-bottom:8px}
.tl__c p{color:var(--ink-soft);font-size:clamp(12px,1vw,14px);max-width:240px}

/* ===================== ЛОДКА ПОД ЗАКАЗ — ограничен по ширине ===================== */
.custom{
  position:relative;z-index:5;
  max-width:var(--maxw);width:calc(100% - var(--pad) * 2);
  margin:clamp(24px,3.4vw,52px) auto;
  min-height:clamp(300px,48vh,500px);
  display:flex;align-items:center;overflow:hidden;background:#0c0e10;
}
/* инсет -18% даёт запас ~70px сверху/снизу — параллакс никогда не обнажает фон */
.custom__bg{position:absolute;inset:-18%;z-index:0}
.custom__bg img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) brightness(.65);will-change:transform;display:block}
.custom__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(10,12,14,.9) 0%,rgba(10,12,14,.55) 55%,rgba(10,12,14,.18) 100%)}
.custom__in{position:relative;z-index:2;width:100%;padding:clamp(28px,4vw,56px) clamp(24px,3.5vw,56px)}
.custom__in h2{color:#fff;font-size:clamp(24px,3.6vw,52px);margin:14px 0 16px}
.custom__in p{color:rgba(255,255,255,.9);max-width:480px;font-size:clamp(13px,1.1vw,16px);margin-bottom:24px}

/* ===================== КОНТАКТЫ ===================== */
.contact{padding:clamp(38px,5.2vw,80px) var(--pad)}
.contact__head,.contact__body{max-width:var(--maxw);margin:0 auto}
.contact__head{margin-bottom:clamp(24px,3.4vw,48px)}
.contact__head h2{font-size:clamp(26px,4vw,58px);margin-top:14px}
.contact__big{
  display:flex;flex-direction:column;gap:6px;
  padding:clamp(16px,2.2vw,30px) 0;border-top:1px solid var(--line);
  transition:transform .45s var(--ease), border-color .4s var(--ease);
}
.contact__big:hover,
.contact__big:active{transform:translateX(16px)}
.contact__lbl{font-family:var(--ff-head);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.contact__val{font-family:var(--ff-head);font-weight:500;font-size:clamp(20px,3vw,48px);transition:color .4s var(--ease)}
.contact__big:hover .contact__val,
.contact__big:active .contact__val{color:var(--accent)}
.contact__row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
  border-top:1px solid var(--line);padding-top:24px;margin-top:8px;
}
.contact__row p{color:var(--ink-soft);margin-top:8px;font-size:clamp(13px,1.1vw,15px)}
.contact__row a{color:var(--ink);border-bottom:2px solid var(--line-strong);transition:.3s}
.contact__row a:hover{color:var(--accent);border-color:var(--accent)}

/* ===================== ПОДВАЛ ===================== */
.footer{
  position:relative;z-index:5;background:#0B0D0E;
  border-top:1px solid rgba(255,255,255,.08);
  padding:clamp(26px,3.6vw,52px) var(--pad);
}
.footer__inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px;
}
.footer__brand{display:flex;align-items:center;color:#fff}
.footer__logo-svg{height:clamp(22px,2.2vw,32px);width:auto;display:block;flex:none}
.footer__cols{display:flex;gap:clamp(16px,2vw,26px);flex-wrap:wrap}
.footer__cols a{font-family:var(--ff-head);font-size:clamp(12px,1vw,14px);letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.72);transition:.3s}
.footer__cols a:hover{color:var(--accent)}
.footer__legal{font-size:clamp(11px,.9vw,13px);color:rgba(255,255,255,.5)}

/* ===================== ПЕРЕХОДЫ ТЕМЫ =====================
   Механика: вместо class-trick — постоянные transitions +
   явные цвета через [data-theme="light/dark"].
   Смена data-theme = изменение каскада (не CSS-переменной) →
   браузер надёжно захватывает «from»-значение на любом устройстве,
   включая мобильный Safari.                                        */

/* h2/h3: явный цвет для каждой темы (каскадное изменение)
   h1 не трогаем — у героя он всегда белый */
[data-theme="light"] h2,
[data-theme="light"] h3 { color: #15191C }
[data-theme="dark"]  h2,
[data-theme="dark"]  h3 { color: #EDEFF1 }
/* Исключение: заголовок «Лодка под заказ» — всегда белый (на фото) */
[data-theme] .custom__in h2 { color: #fff }

/* Шапка — логотип, ссылки и CTA при прокрутке */
[data-theme="light"] .nav.scrolled .nav__logo-svg,
[data-theme="light"] .nav.scrolled .nav__links a,
[data-theme="light"] .nav.scrolled .nav__cta { color: #15191C }
[data-theme="dark"]  .nav.scrolled .nav__logo-svg,
[data-theme="dark"]  .nav.scrolled .nav__links a,
[data-theme="dark"]  .nav.scrolled .nav__cta { color: #EDEFF1 }

/* Бургер-полоски в прокрученной шапке */
.nav__burger span { transition: background-color .35s ease, transform .4s var(--ease) }
[data-theme="light"] .nav.scrolled .nav__burger span { background: #15191C }
[data-theme="dark"]  .nav.scrolled .nav__burger span { background: #EDEFF1 }

/* Ползунок переключателя темы */
.theme-toggle__knob { transition: transform .4s var(--ease), background-color .35s ease }

/* Кнопки .btn--line и слайдер-стрелки */
[data-theme="light"] .btn--line  { color: #15191C }
[data-theme="dark"]  .btn--line  { color: #EDEFF1 }
[data-theme="light"] .works__btn { color: #15191C }
[data-theme="dark"]  .works__btn { color: #EDEFF1 }

/* Ссылки мобильного меню */
[data-theme="light"] .mobile-menu__nav a { color: #15191C }
[data-theme="dark"]  .mobile-menu__nav a { color: #EDEFF1 }

/* ===================== БУРГЕР-МЕНЮ В ЛАНДШАФТЕ =====================
   На мобильных в альбомном режиме элементы меню слишком крупные
   и не помещаются по высоте → уменьшаем шрифт, добавляем скролл.  */
@media (max-height: 480px) and (orientation: landscape) {
  .mobile-menu {
    padding-top: 56px;
    padding-bottom: 12px;
    justify-content: flex-start;
    overflow-y: auto;
  }
  .mobile-menu__nav a {
    font-size: clamp(16px, 4vh, 22px);
    padding: 7px 0;
  }
  .mobile-menu .mobile-menu__contacts a {
    font-size: clamp(13px, 3vh, 16px);
  }
}

/* ===================== АНИМАЦИИ ===================== */
.reveal,.reveal-block{opacity:0;transform:translateY(28px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.reveal.in,.reveal-block.in{opacity:1;transform:translateY(0)}
.reveal-lines span{
  display:block;overflow:hidden;
  padding:.14em 0;margin:-.14em 0;   /* запас от обрезки букв */
  transform:translateY(110%);transition:transform .85s var(--ease);
}
.reveal-lines.in span{transform:translateY(0)}
.reveal-lines.in span:nth-child(2){transition-delay:.07s}
.reveal-lines.in span:nth-child(3){transition-delay:.14s}

/* ===================== ПЛАНШЕТ (≤1080px) ===================== */
@media(max-width:1080px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}

  .make__top{grid-template-columns:1fr;gap:20px;align-items:start}
  .make__facts{grid-template-columns:1fr 1fr;gap:clamp(12px,2vw,24px)}

  /* Работы: вертикальный макет */
  .works__head{flex-direction:column;align-items:flex-start;gap:16px}
  .work{
    grid-template-columns:1fr;
    grid-template-rows:auto clamp(240px,40vh,360px);
    min-height:0;max-height:none;  /* вертикально: высота авто */
  }
  .work__info{padding:clamp(16px,3vw,32px) var(--pad);overflow:visible}
  .work__params{grid-template-columns:repeat(3,1fr)}

  .hdpe{grid-template-columns:1fr;gap:28px}
  .hdpe__sticky{position:relative;top:0}

  .model,.model--rev{grid-template-columns:1fr;gap:22px}
  .model--rev .model__media{order:0}
  .model__specs{grid-template-columns:repeat(2,1fr)}

  /* Видео: 2 колонки, сброс бенто — равномерные тайлы */
  .vcases__grid{grid-template-columns:repeat(2,1fr)}
  .vcard:nth-child(5n+1),
  .vcard:nth-child(5n+4){grid-column:span 1}
  .vcard:nth-child(5n+2){grid-row:span 1}

  .timeline{grid-template-columns:repeat(2,1fr)}

  .contact__row{grid-template-columns:repeat(2,1fr)}
}

/* ===================== ТЕЛЕФОН (≤680px) ===================== */
@media(max-width:680px){
  :root{--pad:16px}

  /* Ограничиваем высоту героя: не выше 1.8× ширины экрана (≈ 700px на iPhone 14).
     Без этого на очень высоких экранах ландшафтное фото кадрируется по бокам
     и лодка не помещается в кадр. */
  .hero{max-height:calc(100vw * 1.8)}
  /* Смещаем фото вправо — объект находится в правой части изображения */
  .hero__bg{object-position:75% center}

  .hero__scroll{display:none}

  .make__facts{grid-template-columns:1fr}

  .work{grid-template-rows:auto clamp(180px,34vh,280px)}
  .work__params{grid-template-columns:repeat(2,1fr)}
  .work__thumb{width:clamp(52px,12vw,70px);height:clamp(52px,12vw,70px)}

  /* Видео: 1 колонка, полный сброс бенто */
  .vcases__grid{grid-template-columns:1fr}
  .vcard:nth-child(5n+1),
  .vcard:nth-child(5n+4){grid-column:span 1}
  .vcard:nth-child(5n+2){grid-row:span 1}

  .timeline{grid-template-columns:1fr}

  .contact__row{grid-template-columns:1fr;gap:18px}

  .footer__inner{flex-direction:column;align-items:flex-start}
}

/* ===================== СНИЖЕННОЕ ДВИЖЕНИЕ ===================== */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  .reveal,.reveal-block{opacity:1;transform:none}
  .hero__title .word,.reveal-lines span{transform:none}
}
