site.css 43 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842
  1. /* ================================================
  2. ISHIYAMA — Premium Light Automotive
  3. Unbounded + Manrope | avadge-inspired
  4. Fixed: no horizontal scroll down to 360px
  5. ================================================ */
  6. @import url('https://fonts.googleapis.com/css2?family=Unbounded:wght@400;600;700;900&family=Manrope:wght@300;400;500;600;700&display=swap');
  7. :root {
  8. --w: #ffffff;
  9. --bg: #f7f6f3;
  10. --bg2: #f0efe9;
  11. --dark: #141414;
  12. --dark2: #1c1c1c;
  13. --dark3: #252525;
  14. --line: #e8e6e0;
  15. --text: #181818;
  16. --muted: #6e6e6e;
  17. --light: #aaa;
  18. --red: #d12626;
  19. --red2: #b01f1f;
  20. --red-lt: rgba(209,38,38,0.08);
  21. /* avadge orange accent */
  22. --orange: #F28500;
  23. --orange2: #d97600;
  24. --tg: #229ED9;
  25. --r-sm: 8px;
  26. --r: 16px;
  27. --sh: 0 2px 20px rgba(0,0,0,0.06);
  28. --sh2: 0 12px 48px rgba(0,0,0,0.14);
  29. --tr: 0.2s ease;
  30. --fh: 'Unbounded', sans-serif;
  31. --fb: 'Manrope', sans-serif;
  32. }
  33. /* ===== RESET & BASE ===== */
  34. *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  35. html{scroll-behavior:smooth;overflow-x:hidden}
  36. body{background:var(--bg);color:var(--text);font-family:var(--fb);font-size:16px;line-height:1.6;
  37. -webkit-font-smoothing:antialiased;overflow-x:hidden;min-width:0}
  38. a{color:inherit;text-decoration:none;transition:color var(--tr)}
  39. img{max-width:100%;display:block}
  40. ul{list-style:none}
  41. /* No element should escape the viewport */
  42. .container{width:100%;max-width:1240px;margin:0 auto;padding:0 clamp(16px,4vw,32px)}
  43. /* ===== ANIMATIONS ===== */
  44. .reveal{opacity:0;transform:translateY(24px);
  45. transition:opacity .65s cubic-bezier(.22,.68,0,1.1),transform .65s cubic-bezier(.22,.68,0,1.1)}
  46. .reveal.in{opacity:1;transform:none}
  47. .reveal-up{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
  48. .reveal-up.in{opacity:1;transform:none}
  49. .stagger>*{opacity:0;transform:translateY(18px);transition:opacity .45s ease,transform .45s ease}
  50. .stagger.in>*:nth-child(1){opacity:1;transform:none;transition-delay:.00s}
  51. .stagger.in>*:nth-child(2){opacity:1;transform:none;transition-delay:.06s}
  52. .stagger.in>*:nth-child(3){opacity:1;transform:none;transition-delay:.12s}
  53. .stagger.in>*:nth-child(4){opacity:1;transform:none;transition-delay:.18s}
  54. .stagger.in>*:nth-child(5){opacity:1;transform:none;transition-delay:.24s}
  55. .stagger.in>*:nth-child(6){opacity:1;transform:none;transition-delay:.30s}
  56. .stagger.in>*:nth-child(7){opacity:1;transform:none;transition-delay:.36s}
  57. .stagger.in>*:nth-child(8){opacity:1;transform:none;transition-delay:.42s}
  58. .stagger.in>*:nth-child(9){opacity:1;transform:none;transition-delay:.48s}
  59. .stagger.in>*:nth-child(10){opacity:1;transform:none;transition-delay:.54s}
  60. .stagger.in>*:nth-child(11){opacity:1;transform:none;transition-delay:.60s}
  61. .stagger.in>*:nth-child(12){opacity:1;transform:none;transition-delay:.66s}
  62. /* ===== BUTTONS ===== */
  63. .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  64. padding:13px clamp(16px,3vw,28px);font-family:var(--fb);font-size:14px;font-weight:600;
  65. letter-spacing:.02em;border:none;cursor:pointer;transition:all var(--tr);
  66. border-radius:var(--r-sm);white-space:nowrap;flex-shrink:0}
  67. .btn-primary{background:var(--dark);color:#fff}
  68. .btn-primary:hover{background:var(--dark3);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,0.2)}
  69. .btn-red{background:var(--red);color:#fff}
  70. .btn-red:hover{background:var(--red2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(209,38,38,0.25)}
  71. .btn-outline{background:transparent;border:1.5px solid var(--line);color:var(--text)}
  72. .btn-outline:hover{border-color:var(--text);background:var(--text);color:#fff}
  73. .btn-outline-w{background:transparent;border:1.5px solid rgba(255,255,255,0.3);color:#fff}
  74. .btn-outline-w:hover{border-color:#fff;background:rgba(255,255,255,0.08)}
  75. .btn-tg{background:var(--tg);color:#fff;border-radius:var(--r-sm)}
  76. .btn-tg:hover{background:#1a8bbf}
  77. .btn-sm{padding:9px 18px;font-size:13px}
  78. .btn-lg{padding:16px clamp(20px,3vw,36px);font-size:15px}
  79. /* ===== CHIP ===== */
  80. .chip{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:99px;
  81. font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
  82. .chip-dark{background:var(--dark);color:#fff}
  83. .chip-red{background:var(--red);color:#fff}
  84. .chip-green{background:#1a9e4a;color:#fff}
  85. .chip-outline{background:transparent;border:1.5px solid var(--line);color:var(--muted)}
  86. /* ===== SECTION HEADER ===== */
  87. .sh{margin-bottom:clamp(32px,5vw,52px)}
  88. .sh-label{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--red);
  89. display:flex;align-items:center;gap:8px;margin-bottom:10px}
  90. .sh-label::before{content:'';width:20px;height:2px;background:var(--red);border-radius:1px;flex-shrink:0}
  91. .sh h2{font-family:var(--fh);font-size:clamp(24px,4vw,46px);font-weight:700;letter-spacing:-.01em;
  92. line-height:1.1;margin-bottom:12px}
  93. .sh p{color:var(--muted);font-size:15px;max-width:560px;line-height:1.75}
  94. .sh-row{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
  95. /* ===== TOPBAR ===== */
  96. .topbar{background:var(--dark);padding:8px 0}
  97. .topbar .container{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
  98. .topbar a,.topbar span{font-size:12px;color:rgba(255,255,255,.5);transition:color var(--tr)}
  99. .topbar a:hover{color:#fff}
  100. .topbar-l,.topbar-r{display:flex;align-items:center;gap:16px}
  101. .topbar-soc{display:flex;gap:7px}
  102. .topbar-soc a{width:26px;height:26px;border:1px solid rgba(255,255,255,.12);border-radius:50%;
  103. display:flex;align-items:center;justify-content:center;font-size:11px;color:rgba(255,255,255,.4);
  104. transition:all var(--tr)}
  105. .topbar-soc a:hover{border-color:var(--orange);color:var(--orange)}
  106. /* ===== NAVBAR ===== */
  107. .navbar{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.97);
  108. backdrop-filter:blur(16px);border-bottom:1px solid var(--line);transition:box-shadow var(--tr)}
  109. .navbar.scrolled{box-shadow:var(--sh)}
  110. .navbar .container{display:flex;align-items:center;justify-content:space-between;
  111. height:clamp(60px,8vw,72px);gap:12px}
  112. .logo{display:flex;align-items:center;flex-shrink:0;text-decoration:none}
  113. .logo-img{height:36px;width:auto;display:block}
  114. .nav-links{display:flex;align-items:center;gap:2px}
  115. .nav-links a{font-family:var(--fb);font-size:14px;font-weight:500;color:var(--muted);
  116. padding:7px 12px;border-radius:var(--r-sm);transition:all var(--tr)}
  117. .nav-links a:hover,.nav-links a.active{color:var(--text);background:var(--bg)}
  118. .nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
  119. .burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;flex-shrink:0}
  120. .burger span{width:22px;height:1.5px;background:var(--text);transition:all var(--tr);display:block}
  121. /* ── Иконка-кнопки в nav-right (TG, телефон) ── */
  122. .nav-icon-btn{display:inline-flex;align-items:center;justify-content:center;
  123. width:42px;height:42px;border-radius:var(--r-sm);border:none;
  124. cursor:pointer;transition:all var(--tr);flex-shrink:0;text-decoration:none}
  125. .nav-icon-btn svg{width:20px;height:20px;flex-shrink:0}
  126. .nav-icon-btn--tg{background:var(--red);color:#fff}
  127. .nav-icon-btn--tg:hover{background:var(--red2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(209,38,38,0.25)}
  128. .nav-icon-btn--call{background:var(--dark);color:#fff}
  129. .nav-icon-btn--call:hover{background:var(--dark3);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,0.2)}
  130. /* ── Избранное в nav-right ── */
  131. .nav-fav-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;
  132. width:42px;height:42px;border-radius:var(--r-sm);background:transparent;
  133. border:1.5px solid var(--line);color:var(--muted);cursor:pointer;
  134. transition:all var(--tr);flex-shrink:0;text-decoration:none}
  135. .nav-fav-btn svg{width:20px;height:20px;flex-shrink:0;transition:fill var(--tr),stroke var(--tr)}
  136. .nav-fav-btn:hover{border-color:var(--red);color:var(--red)}
  137. .nav-fav-btn.has-items{border-color:var(--red);color:var(--red);background:var(--red-lt)}
  138. .nav-fav-btn.has-items svg{fill:var(--red);stroke:var(--red)}
  139. .nav-fav-count{display:none;position:absolute;top:-7px;right:-7px;
  140. background:var(--red);color:#fff;font-size:10px;font-weight:700;
  141. min-width:18px;height:18px;border-radius:99px;
  142. align-items:center;justify-content:center;padding:0 4px;
  143. line-height:1;border:2px solid var(--w)}
  144. /* ===== HERO ===== */
  145. .hero{background:var(--dark);overflow:hidden;position:relative;
  146. min-height:clamp(480px,92vh,900px);display:flex;align-items:center}
  147. .hero-media{position:absolute;inset:0}
  148. .hero-media img{width:100%;height:100%;object-fit:cover;opacity:.25}
  149. .hero-overlay{position:absolute;inset:0;
  150. background:linear-gradient(100deg,rgba(20,20,20,.92) 0%,rgba(20,20,20,.55) 60%,rgba(20,20,20,.25) 100%)}
  151. .hero .container{position:relative;z-index:2;padding-top:clamp(48px,8vw,80px);padding-bottom:clamp(48px,8vw,80px)}
  152. .hero-eyebrow{font-size:clamp(10px,2vw,12px);font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  153. color:rgba(255,255,255,.45);margin-bottom:clamp(14px,3vw,22px);opacity:0;animation:fin .5s .1s forwards}
  154. @keyframes fin{to{opacity:1}}
  155. .hero-title{font-family:var(--fh);font-weight:900;
  156. font-size:clamp(36px,9vw,92px);line-height:.95;letter-spacing:-.02em;color:#fff;
  157. margin-bottom:clamp(16px,3vw,24px)}
  158. .hero-title .ln{display:block;overflow:hidden}
  159. .hero-title .ln span{display:block;transform:translateY(110%);animation:sup .7s cubic-bezier(.16,1,.3,1) forwards}
  160. .hero-title .ln:nth-child(1) span{animation-delay:.2s}
  161. .hero-title .ln:nth-child(2) span{animation-delay:.34s}
  162. .hero-title .ln:nth-child(3) span{animation-delay:.48s}
  163. .hero-title em{color:var(--red);font-style:normal}
  164. @keyframes sup{to{transform:none}}
  165. .hero-sub{font-size:clamp(14px,2.5vw,17px);color:rgba(255,255,255,.55);
  166. max-width:480px;line-height:1.75;margin-bottom:clamp(24px,4vw,40px);
  167. opacity:0;animation:fin .6s .85s forwards}
  168. .hero-btns{display:flex;gap:10px;flex-wrap:wrap;opacity:0;animation:fin .6s 1s forwards;
  169. margin-bottom:clamp(36px,6vw,64px)}
  170. /* Двухколоночная grid-раскладка hero: контент + карточка подбора */
  171. .hero-layout{padding: clamp(48px, 8vw, 100px) 0;display:grid;grid-template-columns:1fr 380px;align-items:center;gap:48px;
  172. min-height:90vh}
  173. /* Карточка быстрого подбора (правая колонка) */
  174. .hero-search{
  175. background:rgba(255,255,255,.05);backdrop-filter:blur(10px);
  176. border:1px solid rgba(255,255,255,.1);border-radius:20px;
  177. padding:clamp(20px,3vw,32px);
  178. display:flex;flex-direction:column;gap:12px;
  179. }
  180. .hs-title{font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  181. color:rgba(255,255,255,.35);margin-bottom:4px}
  182. .hs-field{margin-bottom:0}
  183. .hs-field label,.hs-lbl{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  184. color:rgba(255,255,255,.35);display:block;margin-bottom:5px}
  185. .hs-field select,.hs-sel{width:100%;padding:11px 14px;background:#1e1e1e;
  186. border:1.5px solid rgba(255,255,255,.08);border-radius:10px;
  187. color:#fff;-webkit-text-fill-color:#fff;color-scheme:dark;
  188. font-family:var(--fb);font-size:14px;
  189. outline:none;appearance:none;cursor:pointer;transition:border-color .2s}
  190. .hs-field select:focus,.hs-sel:focus{border-color:var(--orange)}
  191. .hs-field select option,.hs-sel option{background:#1e1e1e;color:#fff}
  192. .hs-btn-full{width:100%;padding:14px 20px;margin-top:4px;font-size:15px;font-weight:700;
  193. justify-content:center;border-radius:10px}
  194. .hero-stats{display:flex;flex-wrap:wrap;gap:0;border-top:1px solid rgba(255,255,255,.1);
  195. padding-top:clamp(20px,4vw,36px);opacity:0;animation:fin .5s 1.15s forwards}
  196. .hstat{padding-right:clamp(16px,3vw,44px);margin-right:clamp(16px,3vw,44px);
  197. border-right:1px solid rgba(255,255,255,.1)}
  198. .hstat:last-child{border-right:none;margin-right:0;padding-right:0}
  199. .hstat-n{font-family:var(--fh);font-size:clamp(24px,5vw,40px);font-weight:700;color:#fff;line-height:1}
  200. .hstat-n em{color:var(--red);font-style:normal}
  201. .hstat-l{font-size:clamp(10px,1.5vw,12px);color:rgba(255,255,255,.4);text-transform:uppercase;
  202. letter-spacing:.08em;margin-top:4px}
  203. /* ===== BRANDS — точная копия avadge ===== */
  204. .brands-section{background:var(--dark2);padding:clamp(40px,6vw,72px) 0;overflow:hidden}
  205. .brands-label{font-family:var(--fb);font-size:12px;font-weight:700;letter-spacing:.16em;
  206. text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:clamp(16px,3vw,28px)}
  207. .brands-grid{
  208. display:grid;
  209. grid-template-columns:repeat(6,1fr);
  210. gap:8px;
  211. }
  212. .brand-tile{
  213. background:var(--dark2);
  214. border-radius:8px;
  215. padding:clamp(16px,2.5vw,24px) clamp(8px,1.5vw,14px);
  216. display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  217. cursor:pointer;min-height:clamp(90px,10vw,120px);
  218. position:relative;
  219. transition:background var(--tr),color var(--tr),border-color var(--tr);
  220. text-decoration:none;
  221. border:1px solid transparent;
  222. overflow:hidden;
  223. isolation:isolate;
  224. }
  225. .brand-tile::before{
  226. content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  227. background:linear-gradient(135deg,transparent 30%,rgba(242,133,0,.13) 50%,transparent 70%);
  228. transform:translate(-110%);
  229. transition:transform .65s cubic-bezier(.25,.46,.45,.94);
  230. }
  231. .brand-tile:hover::before{transform:translate(110%)}
  232. .brand-tile::after{
  233. content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  234. background:var(--orange);transform:scaleX(0);
  235. transition:transform .25s ease;
  236. transform-origin:left;
  237. }
  238. .brand-tile:hover{background:#222;border-color:rgba(242,133,0,.35)}
  239. .brand-tile:hover::after{transform:scaleX(1)}
  240. .brand-logo{
  241. height:clamp(40px,4.5vw,56px);width:auto;max-width:75%;
  242. display:flex;align-items:center;justify-content:center;
  243. position:relative;z-index:1;
  244. }
  245. .brand-logo-letter{
  246. font-family:var(--fb);font-size:clamp(14px,2vw,20px);font-weight:700;
  247. color:rgba(255,255,255,.55);
  248. transition:color var(--tr);
  249. }
  250. .brand-tile:hover .brand-logo-letter{color:var(--orange)}
  251. .brand-name{
  252. font-family:var(--fb);font-size:clamp(9px,1.2vw,11px);font-weight:600;
  253. letter-spacing:.04em;text-transform:uppercase;
  254. color:rgba(255,255,255,.38);
  255. transition:color var(--tr);
  256. text-align:center;
  257. line-height:1.2;
  258. position:relative;z-index:1;
  259. }
  260. .brand-tile:hover .brand-name{color:var(--orange)}
  261. .brand-logo-img{width:auto;height:100%;max-width:80%;object-fit:contain;
  262. filter:grayscale(1) brightness(.9);opacity:.55;
  263. transition:opacity var(--tr),filter var(--tr),transform var(--tr)}
  264. .brand-tile:hover .brand-logo-img{opacity:1;
  265. filter:grayscale(0) brightness(1.08) contrast(1.04);
  266. transform:scale(1.06)}
  267. /* ===== CAR CARDS ===== */
  268. .cars-section{padding:clamp(48px,8vw,88px) 0;background:var(--bg)}
  269. .cars-scroll{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:20px}
  270. .car-card{background:var(--w);border-radius:var(--r);overflow:hidden;
  271. transition:all var(--tr);border:1px solid var(--line);display:flex;flex-direction:column;cursor:pointer}
  272. .car-card:hover{box-shadow:var(--sh2);transform:translateY(-4px);border-color:rgba(209,38,38,.2)}
  273. .car-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--bg2);flex-shrink:0}
  274. .car-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
  275. .car-card:hover .car-img img{transform:scale(1.04)}
  276. .car-img-badges{position:absolute;top:10px;left:10px;display:flex;gap:5px;flex-wrap:wrap}
  277. .car-img-fav{position:absolute;top:10px;right:10px;width:32px;height:32px;
  278. background:rgba(255,255,255,.92);border-radius:50%;display:flex;align-items:center;
  279. justify-content:center;font-size:14px;cursor:pointer;transition:all var(--tr)}
  280. .car-img-fav:hover{background:#fff;transform:scale(1.1)}
  281. .car-body{padding:clamp(14px,2vw,20px) clamp(14px,2vw,22px);flex:1;display:flex;flex-direction:column}
  282. .car-origin{font-size:12px;color:var(--light);font-weight:500;margin-bottom:4px;
  283. display:flex;align-items:center;gap:5px}
  284. .car-name{font-family:var(--fh);font-size:clamp(14px,2vw,17px);font-weight:700;
  285. letter-spacing:-.01em;color:var(--text);margin-bottom:12px;line-height:1.2}
  286. .car-specs-row{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:14px}
  287. .car-spec-box{background:var(--bg);border-radius:var(--r-sm);padding:8px 10px}
  288. .car-spec-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  289. color:var(--light);margin-bottom:2px}
  290. .car-spec-val{font-size:clamp(11px,1.5vw,13px);font-weight:700;color:var(--text)}
  291. .car-footer{display:flex;align-items:flex-end;justify-content:space-between;
  292. margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
  293. .car-price-label{font-size:11px;color:var(--light);font-weight:500;margin-bottom:2px}
  294. .car-price{font-family:var(--fh);font-size:clamp(16px,3vw,22px);font-weight:700;
  295. color:var(--text);letter-spacing:-.01em;line-height:1}
  296. .car-price em{font-size:13px;font-style:normal;color:var(--muted);font-weight:500;margin-left:2px}
  297. .car-go{width:38px;height:38px;background:var(--dark);border-radius:var(--r-sm);
  298. display:flex;align-items:center;justify-content:center;
  299. color:#fff;font-size:16px;transition:all var(--tr);flex-shrink:0}
  300. .car-go:hover{background:var(--red);transform:scale(1.05)}
  301. /* ===== STEPS — точная копия avadge ===== */
  302. /*
  303. avadge: каждый шаг — flex строка.
  304. Левая часть: номер (большой оранжевый при ховере).
  305. Правая часть: заголовок + текст (широкий).
  306. Внизу каждого шага — полноширокое фото.
  307. Разделитель — горизонтальная линия между шагами.
  308. Фон секции белый, при ховере строка не подсвечивается — только номер меняет цвет.
  309. */
  310. .steps-section{padding:clamp(48px,8vw,88px) 0;background:var(--w)}
  311. .steps-list{display:flex;flex-direction:column;margin-top:clamp(28px,5vw,52px)}
  312. .step-item{
  313. border-bottom:1px solid var(--line);
  314. padding:clamp(20px,4vw,36px) 0;
  315. cursor:default;
  316. }
  317. .step-item:first-child{border-top:1px solid var(--line)}
  318. /* Верхняя часть шага: номер + контент */
  319. .step-top{
  320. display:grid;
  321. grid-template-columns:clamp(48px,6vw,80px) 1fr;
  322. gap:clamp(16px,3vw,32px);
  323. align-items:start;
  324. margin-bottom:clamp(16px,3vw,28px);
  325. }
  326. .step-num{
  327. font-family:var(--fh);
  328. font-size:clamp(36px,5vw,56px);
  329. font-weight:900;
  330. color:var(--line);
  331. line-height:1;
  332. transition:color .25s ease;
  333. padding-top:4px;
  334. }
  335. .step-item:hover .step-num{color:var(--orange)}
  336. .step-text h3{
  337. font-family:var(--fh);
  338. font-size:clamp(14px,2.5vw,20px);
  339. font-weight:700;
  340. letter-spacing:-.01em;
  341. margin-bottom:10px;
  342. line-height:1.2;
  343. }
  344. .step-text p{
  345. color:var(--muted);
  346. font-size:clamp(13px,1.8vw,14px);
  347. line-height:1.75;
  348. }
  349. /* Нижняя часть: фото */
  350. .step-photo{
  351. border-radius:var(--r);
  352. overflow:hidden;
  353. aspect-ratio:16/6;
  354. background:var(--bg2);
  355. }
  356. .step-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
  357. .step-item:hover .step-photo img{transform:scale(1.02)}
  358. /* ===== REVIEWS ===== */
  359. .reviews-section{padding:clamp(48px,8vw,88px) 0;background:var(--bg)}
  360. .reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(320px,100%),1fr));
  361. gap:16px;margin-top:clamp(28px,5vw,52px)}
  362. .review-card{background:var(--w);border:1px solid var(--line);border-radius:var(--r);
  363. padding:clamp(20px,3vw,32px);position:relative;transition:all var(--tr)}
  364. .review-card:hover{box-shadow:var(--sh);transform:translateY(-2px)}
  365. .review-card::before{content:'\201C';position:absolute;top:20px;right:20px;
  366. font-family:var(--fh);font-size:80px;color:var(--red);opacity:.07;line-height:1;font-style:italic}
  367. .review-stars{display:flex;gap:3px;margin-bottom:12px}
  368. .review-stars span{color:#f59e0b;font-size:15px}
  369. .review-car{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  370. color:var(--red);margin-bottom:14px;padding:5px 12px;background:var(--red-lt);
  371. border-radius:99px;display:inline-block}
  372. .review-text{font-size:14px;color:var(--muted);line-height:1.8;margin-bottom:20px}
  373. .review-author{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:1px solid var(--line)}
  374. .review-av{width:40px;height:40px;border-radius:50%;background:var(--dark);
  375. display:flex;align-items:center;justify-content:center;
  376. font-family:var(--fh);font-size:13px;font-weight:700;color:#fff;flex-shrink:0}
  377. .review-name{font-weight:700;font-size:14px}
  378. .review-date{font-size:12px;color:var(--light);margin-top:2px}
  379. /* ===== CTA STRIP ===== */
  380. .cta-strip{background:var(--dark);padding:clamp(48px,8vw,80px) 0;position:relative;overflow:hidden}
  381. .cta-strip::after{content:'ISHIYAMA';position:absolute;right:-40px;top:50%;transform:translateY(-50%);
  382. font-family:var(--fh);font-size:clamp(60px,14vw,180px);font-weight:900;
  383. color:rgba(255,255,255,.025);line-height:1;pointer-events:none;white-space:nowrap}
  384. .cta-inner{display:flex;align-items:center;justify-content:space-between;
  385. gap:clamp(24px,4vw,48px);flex-wrap:nowrap;position:relative}
  386. .cta-text{flex:1 1 0;min-width:0}
  387. .cta-title{font-family:var(--fh);font-size:clamp(24px,4vw,52px);font-weight:700;
  388. color:#fff;line-height:1.05;letter-spacing:-.02em}
  389. .cta-sub{color:rgba(255,255,255,.4);font-size:clamp(13px,2vw,15px);margin-top:8px}
  390. .cta-actions{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0;align-items:center}
  391. /* ===== FOOTER ===== */
  392. .footer{background:var(--dark2);padding:clamp(40px,6vw,64px) 0 0;border-top:3px solid var(--red)}
  393. .footer-grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);
  394. gap:clamp(24px,4vw,48px);padding-bottom:clamp(32px,5vw,48px);
  395. border-bottom:1px solid rgba(255,255,255,.06)}
  396. .footer-logo{margin-bottom:14px}
  397. .footer-logo-img{height:40px;width:auto;display:block}
  398. .footer-brand p{color:rgba(255,255,255,.35);font-size:13px;line-height:1.75;max-width:260px}
  399. .footer-soc{display:flex;gap:8px;margin-top:18px}
  400. .footer-soc a{width:32px;height:32px;border:1px solid rgba(255,255,255,.1);border-radius:50%;
  401. display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.35);
  402. font-size:12px;transition:all var(--tr)}
  403. .footer-soc a:hover{border-color:var(--orange);color:var(--orange)}
  404. .footer-col h5{font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:.14em;
  405. text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:16px}
  406. .footer-col ul{display:flex;flex-direction:column;gap:9px}
  407. .footer-col ul a{color:rgba(255,255,255,.38);font-size:13px;transition:all var(--tr)}
  408. .footer-col ul a:hover{color:#fff;padding-left:4px}
  409. .footer-bottom{padding:16px 0;display:flex;align-items:center;justify-content:space-between;
  410. gap:14px;flex-wrap:wrap}
  411. .footer-bottom p{font-size:12px;color:rgba(255,255,255,.28)}
  412. /* ===== PAGE HEADER ===== */
  413. .page-hdr{padding:clamp(40px,6vw,72px) 0 clamp(32px,5vw,52px);background:var(--w);
  414. border-bottom:1px solid var(--line);position:relative}
  415. .page-hdr::after{content:'';position:absolute;bottom:0;left:clamp(16px,4vw,32px);
  416. width:80px;height:3px;background:var(--red);border-radius:2px}
  417. .page-hdr h1{font-family:var(--fh);font-size:clamp(32px,7vw,76px);font-weight:900;
  418. line-height:1;letter-spacing:-.02em;margin-bottom:14px}
  419. .breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--light)}
  420. .breadcrumb a:hover{color:var(--red)}
  421. .breadcrumb span{color:var(--red)}
  422. /* ===== CATALOG FILTERS ===== */
  423. .catalog-layout{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start}
  424. .filters{background:var(--w);border:1px solid var(--line);border-radius:var(--r);
  425. padding:20px;position:sticky;top:80px}
  426. .filter-hdr{font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:.14em;
  427. text-transform:uppercase;color:var(--text);margin-bottom:18px;padding-bottom:14px;
  428. border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
  429. .filter-reset{font-family:var(--fb);font-size:12px;font-weight:600;color:var(--red);
  430. cursor:pointer;text-transform:none;letter-spacing:0}
  431. .filter-group{margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--line)}
  432. .filter-group:last-child{border-bottom:none;margin:0;padding:0}
  433. .filter-group>label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  434. color:var(--light);display:block;margin-bottom:9px}
  435. .f-sel{width:100%;padding:9px 12px;background:var(--bg);border:1.5px solid var(--line);
  436. border-radius:var(--r-sm);font-family:var(--fb);font-size:14px;color:var(--text);
  437. outline:none;appearance:none;cursor:pointer;transition:border-color var(--tr)}
  438. .f-sel:focus{border-color:var(--red)}
  439. .f-checks{display:flex;flex-direction:column;gap:8px}
  440. .f-check{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--muted);
  441. cursor:pointer;transition:color var(--tr)}
  442. .f-check input{width:14px;height:14px;accent-color:var(--red);cursor:pointer;flex-shrink:0}
  443. .f-check:hover{color:var(--text)}
  444. .f-range{width:100%;accent-color:var(--red);cursor:pointer;margin-bottom:6px}
  445. .f-range-row{font-size:12px;color:var(--muted);display:flex;justify-content:space-between}
  446. .f-range-row strong{color:var(--text);font-weight:700}
  447. .cat-top{display:flex;align-items:center;justify-content:space-between;
  448. margin-bottom:18px;gap:10px;flex-wrap:wrap}
  449. .cat-count{font-size:14px;color:var(--muted)}
  450. .cat-count strong{color:var(--text)}
  451. .cat-sort{display:flex;align-items:center;gap:8px}
  452. .cat-sort select{padding:7px 11px;background:var(--w);border:1.5px solid var(--line);
  453. border-radius:var(--r-sm);font-size:13px;font-family:var(--fb);outline:none;cursor:pointer}
  454. .view-btns{display:flex;gap:4px}
  455. .vbtn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  456. border:1.5px solid var(--line);border-radius:var(--r-sm);cursor:pointer;
  457. background:var(--w);color:var(--muted);font-size:13px;transition:all var(--tr)}
  458. .vbtn.active,.vbtn:hover{border-color:var(--red);color:var(--red)}
  459. .active-tags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}
  460. .atag{display:flex;align-items:center;gap:5px;padding:3px 10px;
  461. background:var(--red-lt);border:1px solid rgba(209,38,38,.2);border-radius:99px;
  462. font-size:12px;font-weight:600;color:var(--red)}
  463. .atag button{background:none;border:none;cursor:pointer;color:var(--red);font-size:13px;line-height:1;padding:0}
  464. .cars-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:18px}
  465. .cars-grid.list-view{grid-template-columns:1fr}
  466. .cars-grid.list-view .car-card{flex-direction:row;min-height:170px}
  467. .cars-grid.list-view .car-img{width:220px;aspect-ratio:auto;height:auto;flex-shrink:0;align-self:stretch}
  468. .pagination{display:flex;align-items:center;justify-content:center;gap:5px;margin-top:36px}
  469. .pag{width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  470. border:1.5px solid var(--line);border-radius:var(--r-sm);font-family:var(--fh);
  471. font-size:13px;font-weight:600;cursor:pointer;background:var(--w);color:var(--muted);
  472. transition:all var(--tr)}
  473. .pag.active,.pag:hover{background:var(--red);border-color:var(--red);color:#fff}
  474. .no-results{grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--muted)}
  475. .no-results .nr-i{font-size:48px;margin-bottom:14px}
  476. .no-results h3{font-family:var(--fh);font-size:20px;font-weight:700;margin-bottom:8px;color:var(--text)}
  477. /* ===== CAR DETAIL ===== */
  478. .car-detail-grid{display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:start}
  479. .gallery{border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
  480. .gallery-main{aspect-ratio:16/10;background:var(--bg2);overflow:hidden;position:relative}
  481. .gallery-main img{width:100%;height:100%;object-fit:cover}
  482. .gallery-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--line)}
  483. .thumb{aspect-ratio:16/9;overflow:hidden;cursor:pointer;opacity:.6;transition:opacity var(--tr);
  484. display:flex;align-items:center;justify-content:center;font-size:22px;background:var(--bg2)}
  485. .thumb:hover,.thumb.active{opacity:1}
  486. .thumb img{width:100%;height:100%;object-fit:cover}
  487. .car-info-panel{background:var(--w);border:1px solid var(--line);border-radius:var(--r);
  488. padding:clamp(20px,3vw,28px);position:sticky;top:84px}
  489. .cip-price{font-family:var(--fh);font-size:clamp(26px,4vw,36px);font-weight:900;
  490. color:var(--text);letter-spacing:-.02em;line-height:1;margin-bottom:4px}
  491. .cip-sub{font-size:12px;color:var(--light);margin-bottom:20px}
  492. .cip-specs{display:grid;grid-template-columns:1fr 1fr;gap:2px;
  493. background:var(--line);border-radius:var(--r-sm);overflow:hidden;margin-bottom:18px}
  494. .cip-spec{background:var(--bg);padding:10px 12px}
  495. .cip-spec-l{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  496. color:var(--light);margin-bottom:2px}
  497. .cip-spec-v{font-size:13px;font-weight:700;color:var(--text)}
  498. .cip-note{background:var(--red-lt);border:1px solid rgba(209,38,38,.15);border-radius:var(--r-sm);
  499. padding:12px 14px;font-size:13px;color:var(--muted);line-height:1.6;margin-top:12px}
  500. .cip-note strong{color:var(--red)}
  501. .tab-nav{display:flex;gap:0;border-bottom:1.5px solid var(--line);margin-bottom:24px;
  502. overflow-x:auto;-webkit-overflow-scrolling:touch}
  503. .tab-btn{padding:10px 16px;font-family:var(--fh);font-size:11px;font-weight:700;
  504. letter-spacing:.08em;text-transform:uppercase;color:var(--muted);cursor:pointer;
  505. border-bottom:2px solid transparent;margin-bottom:-1.5px;transition:all var(--tr);
  506. white-space:nowrap;flex-shrink:0}
  507. .tab-btn:hover,.tab-btn.active{color:var(--red);border-color:var(--red)}
  508. .tab-pane{display:none}
  509. .tab-pane.active{display:block}
  510. .car-desc-text{font-size:15px;color:var(--muted);line-height:1.8;margin-bottom:20px}
  511. .opts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(180px,100%),1fr));gap:7px}
  512. .opt{padding:9px 12px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);
  513. font-size:13px;color:var(--text);display:flex;align-items:center;gap:7px}
  514. .opt::before{content:'✓';color:var(--red);font-weight:800;flex-shrink:0}
  515. /* ===== SERVICES ===== */
  516. .svc-grid{display:flex;flex-direction:column;gap:2px;margin-top:clamp(28px,5vw,52px)}
  517. .svc-item{display:grid;grid-template-columns:clamp(52px,6vw,72px) 1fr;
  518. border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  519. background:var(--w);transition:all var(--tr);
  520. text-decoration:none;color:inherit}
  521. .svc-item:hover{box-shadow:var(--sh);border-color:rgba(209,38,38,.25)}
  522. .svc-n{background:var(--bg);display:flex;align-items:center;justify-content:center;
  523. font-family:var(--fh);font-size:clamp(20px,3vw,28px);font-weight:900;color:var(--red);
  524. opacity:.4;border-right:1px solid var(--line);transition:opacity var(--tr)}
  525. .svc-item:hover .svc-n{opacity:.8}
  526. .svc-body{padding:clamp(18px,3vw,28px) clamp(16px,3vw,36px)}
  527. .svc-body h3{font-family:var(--fh);font-size:clamp(14px,2vw,20px);font-weight:700;
  528. letter-spacing:-.01em;margin-bottom:8px}
  529. .svc-body p{color:var(--muted);font-size:14px;line-height:1.8;margin-bottom:12px}
  530. .svc-tags{display:flex;flex-wrap:wrap;gap:6px}
  531. .svc-tag{padding:4px 11px;background:var(--bg);border:1px solid var(--line);border-radius:99px;
  532. font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
  533. /* Детальная страница услуги */
  534. .svc-detail-lead{font-size:clamp(16px,2vw,20px);color:var(--muted);line-height:1.75;
  535. margin-bottom:clamp(20px,3vw,32px);max-width:760px}
  536. .svc-detail-body{max-width:860px;font-size:15px;line-height:1.85;color:var(--text)}
  537. .svc-detail-body h2,.svc-detail-body h3{font-family:var(--fh);font-weight:700;
  538. margin-top:clamp(24px,4vw,40px);margin-bottom:12px}
  539. .svc-detail-body p{margin-bottom:16px;color:var(--muted)}
  540. .svc-detail-body ul,.svc-detail-body ol{padding-left:24px;margin-bottom:16px}
  541. .svc-detail-body li{margin-bottom:6px;color:var(--muted)}
  542. .why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(200px,100%),1fr));
  543. gap:14px;margin-top:clamp(28px,5vw,50px)}
  544. .why-card{background:var(--w);border:1px solid var(--line);border-radius:var(--r);
  545. padding:clamp(20px,3vw,28px) clamp(16px,2vw,24px);transition:all var(--tr)}
  546. .why-card:hover{box-shadow:var(--sh);transform:translateY(-2px);border-color:rgba(209,38,38,.2)}
  547. .why-icon{font-size:26px;margin-bottom:14px}
  548. .why-card h4{font-family:var(--fh);font-size:clamp(13px,1.8vw,15px);font-weight:700;
  549. letter-spacing:-.01em;margin-bottom:7px}
  550. .why-card p{color:var(--muted);font-size:13px;line-height:1.75}
  551. /* ===== CONTACT ===== */
  552. .contact-layout{display:grid;grid-template-columns:1fr 340px;gap:clamp(28px,5vw,52px);align-items:start}
  553. .form-group{margin-bottom:14px}
  554. .form-group label{display:block;font-size:11px;font-weight:700;letter-spacing:.12em;
  555. text-transform:uppercase;color:var(--light);margin-bottom:6px}
  556. .form-group input,.form-group textarea,.form-group select{width:100%;
  557. padding:12px 14px;background:var(--w);border:1.5px solid var(--line);
  558. border-radius:var(--r-sm);color:var(--text);font-family:var(--fb);font-size:15px;
  559. outline:none;transition:border-color var(--tr);resize:none}
  560. .form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--red)}
  561. .form-group textarea{min-height:120px}
  562. .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  563. .ci-card{background:var(--w);border:1px solid var(--line);border-radius:var(--r);
  564. padding:clamp(20px,3vw,28px);position:sticky;top:84px}
  565. .ci-card h3{font-family:var(--fh);font-size:12px;font-weight:700;letter-spacing:.14em;
  566. text-transform:uppercase;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--line)}
  567. .ci{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;
  568. padding-bottom:14px;border-bottom:1px solid var(--line)}
  569. .ci:last-of-type{border-bottom:none;margin:0;padding:0}
  570. .ci-icon{width:34px;height:34px;background:var(--red-lt);border:1px solid rgba(209,38,38,.15);
  571. border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;
  572. font-size:14px;flex-shrink:0;color:var(--red)}
  573. .ci-l{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  574. color:var(--light);margin-bottom:3px}
  575. .ci-v{font-size:14px;font-weight:600}
  576. .ci-v a:hover{color:var(--red)}
  577. /* ===== 404 ===== */
  578. .err-section{min-height:80vh;display:flex;align-items:center;justify-content:center;
  579. padding:clamp(40px,8vw,80px) 24px}
  580. .err-big{font-family:var(--fh);font-size:clamp(110px,22vw,240px);font-weight:900;
  581. line-height:1;color:var(--bg2);position:relative;letter-spacing:-.04em}
  582. .err-big::after{content:attr(data-n);position:absolute;inset:0;
  583. background:linear-gradient(150deg,var(--red) 40%,var(--dark));
  584. -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  585. clip-path:polygon(0 0,100% 0,100% 46%,0 46%)}
  586. .err-h{font-family:var(--fh);font-size:clamp(20px,3.5vw,40px);font-weight:800;
  587. margin:20px 0 12px;letter-spacing:-.01em}
  588. .err-p{color:var(--muted);margin-bottom:32px;max-width:380px;margin-inline:auto;line-height:1.7;
  589. font-size:clamp(14px,2vw,16px)}
  590. /* ===== FLOAT TG ===== */
  591. .float-tg{position:fixed;bottom:24px;right:24px;z-index:300;width:52px;height:52px;
  592. border-radius:50%;background:var(--tg);display:flex;align-items:center;justify-content:center;
  593. box-shadow:0 4px 20px rgba(34,158,217,.4);transition:all var(--tr)}
  594. .float-tg:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(34,158,217,.5)}
  595. .float-tg svg{width:22px;height:22px;fill:#fff}
  596. /* ===== MISC ===== */
  597. .section{padding:clamp(48px,8vw,88px) 0}
  598. .sec-white{background:var(--w)}
  599. .sec-alt{background:var(--bg)}
  600. /* ======================================================
  601. RESPONSIVE — от 1024 до 360px
  602. ====================================================== */
  603. @media(max-width:1100px){
  604. .brands-grid{grid-template-columns:repeat(4,1fr)}
  605. .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  606. }
  607. @media(max-width:900px){
  608. .catalog-layout{grid-template-columns:1fr}
  609. .filters{position:static;display:none}
  610. .filters.open{display:block}
  611. .car-detail-grid{grid-template-columns:1fr}
  612. .car-info-panel{position:static}
  613. .contact-layout{grid-template-columns:1fr}
  614. .ci-card{position:static}
  615. }
  616. @media(max-width:1024px){
  617. /* Hero — одна колонка, карточка подбора скрыта */
  618. .hero-layout{grid-template-columns:1fr}
  619. .hero-search{display:none}
  620. }
  621. @media(max-width:768px){
  622. .topbar{display:none}
  623. .nav-links{display:none}
  624. .burger{display:flex}
  625. .brands-grid{grid-template-columns:repeat(3,1fr)}
  626. .hero-btns .btn{flex:1 1 auto;text-align:center}
  627. .form-row{grid-template-columns:1fr}
  628. .footer-grid{grid-template-columns:1fr}
  629. .cta-inner{flex-direction:column;align-items:flex-start;flex-wrap:wrap}
  630. .cta-text{flex:none;width:100%}
  631. .sh-row{flex-direction:column;align-items:flex-start}
  632. /* steps: убираем широкий макет */
  633. .step-photo{aspect-ratio:16/7}
  634. }
  635. @media(max-width:560px){
  636. .cars-grid.list-view .car-img{width:140px}
  637. .reviews-grid{grid-template-columns:1fr}
  638. .hstat{padding-right:clamp(12px,3vw,20px);margin-right:clamp(12px,3vw,20px)}
  639. .car-specs-row{grid-template-columns:repeat(2,1fr)}
  640. .step-photo{aspect-ratio:16/8}
  641. }
  642. @media(max-width:480px){
  643. .brand-name{font-size:9px}
  644. .cars-grid.list-view{grid-template-columns:1fr}
  645. .cars-grid.list-view .car-card{flex-direction:column;max-height:none}
  646. .cars-grid.list-view .car-img{width:100%;aspect-ratio:16/10;height:auto}
  647. .step-top{grid-template-columns:clamp(40px,10vw,56px) 1fr;gap:12px}
  648. }
  649. /* ===== CRITICAL: 360px fix ===== */
  650. @media(max-width:400px){
  651. /* navbar — иконки-кнопки влезают на любом экране, скрывать не нужно */
  652. /* hero stats — в 2 колонки */
  653. .hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  654. .hstat{border-right:none;padding-right:0;margin-right:0;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:12px}
  655. .hstat:nth-child(odd){border-right:1px solid rgba(255,255,255,.1);padding-right:12px}
  656. .hstat:last-child{border-bottom:none;padding-bottom:0}
  657. /* step photo shorter */
  658. .step-photo{aspect-ratio:16/10}
  659. /* cards list mode off on tiny screens */
  660. .cars-grid.list-view{grid-template-columns:1fr}
  661. .cars-grid.list-view .car-card{flex-direction:column;max-height:none}
  662. .cars-grid.list-view .car-img{width:100%;aspect-ratio:16/10;height:auto}
  663. /* cta buttons stack */
  664. .cta-actions{flex-direction:column;width:100%}
  665. .cta-actions .btn{width:100%}
  666. /* hero buttons stack */
  667. .hero-btns{flex-direction:column}
  668. .hero-btns .btn{width:100%}
  669. /* footer bottom */
  670. .footer-bottom{flex-direction:column;text-align:center}
  671. }
  672. @media(max-width:360px){
  673. .container{padding:0 12px}
  674. .brand-logo{height:16px}
  675. .brand-name{font-size:8px;letter-spacing:0}
  676. .brand-tile{padding:12px 6px;gap:6px;min-height:60px}
  677. /* step top even tighter */
  678. .step-top{grid-template-columns:40px 1fr;gap:10px}
  679. .step-num{font-size:32px}
  680. .step-text h3{font-size:14px}
  681. }
  682. /* ═══════════════════════════════════════════════════════
  683. STEPS SECTION — точно как avadge.com скрин 3
  684. Тёмный фон, горизонтальный степпер + контент
  685. ═══════════════════════════════════════════════════════ */
  686. .steps-section{background:#0d0d0d;padding:clamp(48px,8vw,88px) 0;color:#fff}
  687. .steps-section .sh-label{color:#F28500}
  688. .steps-section .sh h2{color:#fff}
  689. .steps-section .sh p{color:rgba(255,255,255,.5)}
  690. /* Горизонтальный степпер с кружками */
  691. .stepper{
  692. display:flex;align-items:center;
  693. margin:clamp(28px,4vw,48px) 0 clamp(32px,5vw,52px);
  694. overflow-x:auto;padding-bottom:2px;
  695. -webkit-overflow-scrolling:touch;
  696. scrollbar-width:none;
  697. }
  698. .stepper::-webkit-scrollbar{display:none}
  699. .stepper-item{display:flex;align-items:center;flex-shrink:0}
  700. /* Кружок-номер — квадратный с radius как у avadge */
  701. .stepper-dot{
  702. width:clamp(38px,4.5vw,52px);height:clamp(38px,4.5vw,52px);
  703. border-radius:10px;
  704. background:#1e1e1e;
  705. border:none;outline:none;
  706. display:flex;align-items:center;justify-content:center;
  707. font-family:var(--fh);font-size:clamp(14px,1.8vw,20px);font-weight:700;
  708. color:#fff;cursor:pointer;
  709. transition:background .2s,transform .15s;
  710. position:relative;flex-shrink:0;
  711. }
  712. .stepper-dot:hover{background:#2a2a2a;transform:scale(1.06)}
  713. .stepper-dot.active{background:#F28500;color:#fff}
  714. /* Соединительная линия между кружками */
  715. .stepper-line{
  716. flex:1;min-width:clamp(14px,2.5vw,48px);height:1px;
  717. background:rgba(255,255,255,.15);
  718. margin:0 3px;
  719. }
  720. .stepper-line.done{background:#F28500}
  721. /* Контент шага: текст слева, фото справа */
  722. .step-content{
  723. display:grid;
  724. grid-template-columns:1fr 1fr;
  725. gap:clamp(24px,5vw,72px);
  726. align-items:start;
  727. }
  728. /* Бейдж с номером шага */
  729. .step-badge{
  730. display:inline-flex;align-items:center;justify-content:center;
  731. width:clamp(38px,4vw,52px);height:clamp(38px,4vw,52px);
  732. background:#1e1e1e;border-radius:10px;
  733. font-family:var(--fh);font-size:clamp(14px,2vw,20px);font-weight:700;color:#fff;
  734. margin-bottom:clamp(16px,2.5vw,28px);flex-shrink:0;
  735. }
  736. /* Заголовок шага — крупный как у avadge */
  737. .step-title{
  738. font-family:var(--fh);
  739. font-size:clamp(24px,4vw,46px);
  740. font-weight:700;color:#fff;
  741. line-height:1.1;letter-spacing:-.01em;
  742. margin-bottom:clamp(14px,2vw,22px);
  743. }
  744. .step-desc{
  745. color:rgba(255,255,255,.55);
  746. font-size:clamp(14px,1.6vw,17px);
  747. line-height:1.8;
  748. }
  749. /* Фото правой колонки */
  750. .step-right{
  751. border-radius:16px;overflow:hidden;
  752. aspect-ratio:4/3;background:#1a1a1a;
  753. }
  754. .step-right img{
  755. width:100%;height:100%;object-fit:cover;display:block;
  756. transition:transform .4s ease;
  757. }
  758. .step-right:hover img{transform:scale(1.02)}
  759. @media(max-width:768px){
  760. .step-content{grid-template-columns:1fr}
  761. .step-right{aspect-ratio:16/9}
  762. }
  763. @media(max-width:480px){
  764. .stepper-dot{width:32px;height:32px;font-size:13px;border-radius:7px}
  765. .stepper-line{min-width:10px}
  766. }
  767. @media(max-width:360px){
  768. .stepper-dot{width:28px;height:28px;font-size:12px}
  769. .step-title{font-size:22px}
  770. }
  771. /* ── Избранное ── */
  772. .car-img-fav.fav-active{background:var(--red);color:#fff}
  773. .car-img-fav.fav-active:hover{background:var(--red2)}
  774. /* #favNavCount перенесён в .nav-fav-count выше */
  775. /* ===== NO-ANIMATIONS: отключение всех эффектов появления ===== */
  776. /* Применяется когда в настройках включён переключатель «Отключить анимации» */
  777. body.no-animations .reveal,
  778. body.no-animations .reveal-up,
  779. body.no-animations .stagger>*{
  780. opacity:1!important;transform:none!important;
  781. animation:none!important;transition:none!important}
  782. /* Hero: CSS-анимации на @keyframes fin / sup */
  783. body.no-animations .hero-eyebrow,
  784. body.no-animations .hero-sub,
  785. body.no-animations .hero-btns,
  786. body.no-animations .hero-stats{
  787. opacity:1!important;animation:none!important}
  788. body.no-animations .hero-title .ln span{
  789. transform:none!important;animation:none!important}