/* ============================================================
   ГК «ГОГОЛЬ» — DESIGN TOKENS (источник правды)
   Семантические токены ссылаются на палитру. Маппинг 1:1 в
   Tailwind v4 theme (--color-*, --radius-*, --shadow-*).
   ============================================================ */
:root{
  /* — Палитра — */
  --brand-teal:#1FA0A8;
  --brand-teal-hover:#1B8C93;     /* base −10% */
  --brand-teal-active:#17787E;    /* base −18% */
  --brand-teal-soft:#E3F2F2;
  --navy:#16335E;
  --navy-hover:#122C53;
  --crimson:#E63E5C;
  --crimson-hover:#D63250;        /* −10% */
  --crimson-active:#C32A46;       /* −18% */
  --ink:#0F0F0F;
  --ink-hover:#000000;

  --white:#FFFFFF;
  --surface:#FFFFFF;
  --surface-muted:#F6F8FA;
  --text:#1C2533;
  --text-muted:#5B6675;
  --border:#E4E8EE;

  /* — Семантика — */
  --color-text:var(--text);
  --color-text-muted:var(--text-muted);
  --color-text-on-dark:#FFFFFF;
  --color-text-on-dark-muted:#A9B7CC;
  --color-surface:var(--surface);
  --color-surface-muted:var(--surface-muted);
  --color-surface-alt:var(--brand-teal-soft);
  --color-surface-dark:var(--navy);
  --color-border:var(--border);
  --color-border-strong:#C9D2DE;
  --color-action:var(--crimson);
  --color-action-secondary:var(--ink);
  --color-accent:var(--brand-teal);

  /* — Типографика — */
  --font-display:'Onest', system-ui, sans-serif;
  --font-text:'Inter', system-ui, sans-serif;

  /* — Spacing (4px base) — */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px;
  --sp-6:24px; --sp-8:32px; --sp-12:48px; --sp-16:64px; --sp-24:96px;

  /* — Радиусы — */
  --radius-sm:8px;
  --radius-md:12px;
  --radius-lg:16px;
  --radius-pill:999px;

  /* — Тени — */
  --shadow-card:0 4px 20px -6px rgba(22,51,94,.14);
  --shadow-pop:0 18px 48px -12px rgba(15,15,15,.28);

  /* — Слой — */
  --container:1200px;
  --section-y:96px;
  --diagonal:2.5deg;
}

*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--font-text);
  color:var(--color-text);
  background:var(--surface-muted);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;}
button{font-family:inherit;}

/* ============================================================
   BRAND TYPE SCALE
   desktop: H1 52 / H2 38 / H3 26 / body-lg 18 / body 16 / caption 13
   mobile: H1/H2 −~30%
   ============================================================ */
.h1{font-family:var(--font-display);font-weight:800;font-size:52px;line-height:1.08;letter-spacing:-.02em;color:var(--navy);margin:0;}
.h2{font-family:var(--font-display);font-weight:700;font-size:38px;line-height:1.12;letter-spacing:-.01em;color:var(--navy);margin:0;}
.h3{font-family:var(--font-display);font-weight:700;font-size:26px;line-height:1.2;color:var(--navy);margin:0;}
.body-lg{font-size:18px;line-height:1.6;}
.body{font-size:16px;line-height:1.6;}
.caption{font-size:13px;line-height:1.5;color:var(--text-muted);}
@media(max-width:768px){
  .h1{font-size:34px;}
  .h2{font-size:27px;}
  .h3{font-size:22px;}
  :root{--section-y:60px;}
}

/* ============================================================
   COMPONENT LIBRARY — реальные классы дизайн-системы
   ============================================================ */

/* — Контейнер — */
.gg-container{max-width:var(--container);margin-inline:auto;padding-inline:40px;}
@media(max-width:768px){.gg-container{padding-inline:22px;}}

/* — Кнопки — */
.btn{
  --btn-bg:var(--crimson);--btn-bg-h:var(--crimson-hover);--btn-bg-a:var(--crimson-active);--btn-fg:#fff;--btn-bd:transparent;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-text);font-weight:600;font-size:16px;line-height:1;
  padding:0 26px;height:54px;border-radius:var(--radius-md);
  background:var(--btn-bg);color:var(--btn-fg);border:1.5px solid var(--btn-bd);
  cursor:pointer;text-decoration:none;white-space:nowrap;
  transition:background .16s ease, color .16s ease, border-color .16s ease, transform .04s ease, box-shadow .16s ease;
}
.btn:hover{background:var(--btn-bg-h);border-color:var(--btn-bg-h);}
.btn:active{background:var(--btn-bg-a);border-color:var(--btn-bg-a);transform:translateY(1px);}
.btn:focus-visible{outline:3px solid color-mix(in srgb,var(--brand-teal) 55%,transparent);outline-offset:2px;}
.btn:disabled,.btn[aria-disabled="true"]{background:#E7EAEF;color:#A6AFBD;border-color:#E7EAEF;cursor:not-allowed;transform:none;}
.btn--md{height:46px;font-size:15px;padding:0 20px;}
.btn--secondary{--btn-bg:var(--ink);--btn-bg-h:#1d1d1d;--btn-bg-a:#000;--btn-fg:#fff;justify-content:space-between;}
.btn--ghost{--btn-bg:transparent;--btn-bg-h:var(--brand-teal-soft);--btn-bg-a:#d2eaea;--btn-fg:var(--brand-teal);--btn-bd:var(--brand-teal);}
.btn--ghost:hover{color:var(--brand-teal-active);border-color:var(--brand-teal);}
.btn--block{display:flex;width:100%;}
.btn__chev{font-size:20px;line-height:1;opacity:.9;}
.btn__spin{width:18px;height:18px;border-radius:50%;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;animation:gg-spin .7s linear infinite;}
@keyframes gg-spin{to{transform:rotate(360deg);}}
.ic{width:20px;height:20px;display:inline-block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none;}

/* — Поля ввода — */
.field{display:flex;flex-direction:column;gap:7px;}
.field__label{font-size:13px;font-weight:600;color:var(--text-muted);letter-spacing:.01em;}
.input{
  width:100%;height:56px;padding:0 18px;
  font-family:var(--font-text);font-size:16px;color:var(--text);
  background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);
  transition:border-color .15s ease, box-shadow .15s ease;
}
.input::placeholder{color:#9aa4b2;}
.input:hover{border-color:var(--color-border-strong);}
.input:focus{outline:none;border-color:var(--brand-teal);box-shadow:0 0 0 4px color-mix(in srgb,var(--brand-teal) 16%,transparent);}
textarea.input{height:auto;min-height:130px;padding:14px 18px;resize:vertical;line-height:1.55;}
.input--filled{border-color:var(--color-border-strong);}
.input--error{border-color:var(--crimson);box-shadow:0 0 0 4px color-mix(in srgb,var(--crimson) 14%,transparent);}
.field__error{font-size:13px;color:var(--crimson);font-weight:500;}

/* phone input + флаг-селектор */
.phone{display:flex;align-items:center;height:56px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);padding-left:6px;transition:border-color .15s ease,box-shadow .15s ease;}
.phone:focus-within{border-color:var(--brand-teal);box-shadow:0 0 0 4px color-mix(in srgb,var(--brand-teal) 16%,transparent);}
.flag-select{display:inline-flex;align-items:center;gap:6px;height:40px;padding:0 8px 0 6px;border:none;background:transparent;border-radius:var(--radius-pill);cursor:pointer;color:var(--text-muted);}
.flag-select:hover{background:var(--surface-muted);}
.flag{width:22px;height:15px;border-radius:3px;overflow:hidden;flex:none;border:1px solid rgba(0,0,0,.08);}
.flag i{display:block;height:5px;}
.flag .f-w{background:#fff;}.flag .f-b{background:#0039A6;}.flag .f-r{background:#D52B1E;}
.flag-select .c8{font-size:10px;opacity:.7;}
.phone input{flex:1;border:none;outline:none;background:transparent;height:100%;font-family:var(--font-text);font-size:16px;color:var(--text);padding:0 16px 0 10px;border-left:1.5px solid var(--border);margin-left:4px;}
.phone input::placeholder{color:#9aa4b2;}

/* — Форма-блок — */
.formblock{display:flex;flex-direction:column;gap:14px;}
.form-privacy{font-size:13px;line-height:1.5;color:var(--text-muted);text-align:center;}
.form-privacy a{color:var(--brand-teal);text-underline-offset:2px;}

/* — Section header — */
.sec-head{margin-bottom:var(--sp-12);}
.sec-head--center{text-align:center;}
.sec-head__sub{font-size:15px;font-weight:600;color:var(--brand-teal);text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px;}
.sec-head--center .sec-head__sub{justify-content:center;}

/* — Списки характеристик — */
.gg-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px;max-width:760px;}
.gg-list li{position:relative;padding-left:30px;font-size:17px;line-height:1.55;color:var(--text);}
.gg-list--bullet li::before{content:"";position:absolute;left:6px;top:11px;width:7px;height:7px;border-radius:50%;background:var(--brand-teal);}
.gg-list--check li{padding-left:36px;}
.gg-list--check li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:6px;background:var(--brand-teal-soft);}
.gg-list--check li::after{content:"";position:absolute;left:7px;top:7px;width:9px;height:6px;border:2.4px solid var(--brand-teal);border-top:none;border-right:none;transform:rotate(-45deg);}

/* — About (двухколоночный) — */
.about{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.15fr);gap:64px;align-items:start;}
.about__lead{font-size:18px;line-height:1.65;color:var(--text);}
@media(max-width:768px){.about{grid-template-columns:1fr;gap:20px;}}

/* — Спек-иллюстрация (линейная графика, без сложного SVG) — */
.spec-illu{background:var(--brand-teal-soft);border-radius:var(--radius-lg);padding:40px;display:flex;justify-content:center;}
.garage{width:260px;}
.garage__floor2{display:flex;gap:14px;justify-content:center;margin-bottom:10px;}
.garage__win{width:54px;height:42px;border:2px solid var(--brand-teal);border-radius:4px;opacity:.6;}
.garage__portal{border:2px solid var(--brand-teal);border-bottom:none;border-radius:8px 8px 0 0;height:120px;display:flex;align-items:flex-end;justify-content:center;padding:14px;}
.garage__car{width:100%;height:54px;border-radius:6px 6px 3px 3px;background:repeating-linear-gradient(135deg,#cfe6e6 0 7px,#e3f2f2 7px 14px);border:1px dashed var(--brand-teal);display:flex;align-items:center;justify-content:center;font-family:ui-monospace,monospace;font-size:11px;color:var(--brand-teal-active);letter-spacing:.04em;}

/* — Image placeholder (под реальное фото) — */
.ph{position:relative;background:
  repeating-linear-gradient(135deg,#e9edf2 0 12px,#eef2f6 12px 24px);
  border:1px solid var(--border);border-radius:var(--radius-md);
  display:flex;align-items:center;justify-content:center;overflow:hidden;color:#8a95a4;}
.ph span{font-family:ui-monospace,monospace;font-size:12px;letter-spacing:.04em;background:rgba(255,255,255,.78);padding:5px 11px;border-radius:var(--radius-pill);}

/* — Оверлей-градиент для фото — */
.photo-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,18,38,.78) 0%,rgba(8,18,38,.45) 45%,rgba(8,18,38,.12) 100%);}

/* — Header / навигация — */
.gg-header{position:relative;display:flex;align-items:center;justify-content:space-between;height:78px;border-radius:var(--radius-md);padding-inline:24px;transition:background .25s ease,box-shadow .25s ease;}
.gg-header--onphoto{background:transparent;}
.gg-header--scrolled{background:#fff;box-shadow:var(--shadow-card);}
.gg-header .logo{height:34px;width:auto;}
.gg-nav{display:flex;gap:30px;align-items:center;}
.gg-nav a{font-weight:500;font-size:15px;text-decoration:none;opacity:.92;transition:color .15s;}
.gg-nav a:hover{color:var(--brand-teal);opacity:1;}
.gg-header--onphoto .gg-nav a{color:#fff;}
.gg-header--scrolled .gg-nav a{color:var(--text);}
.burger{display:none;width:46px;height:46px;border-radius:50%;background:var(--crimson);border:none;cursor:pointer;align-items:center;justify-content:center;flex:none;box-shadow:0 6px 16px -4px rgba(230,62,92,.55);}
.burger span{display:block;width:18px;height:2px;background:#fff;position:relative;}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:#fff;}
.burger span::before{top:-5px;}.burger span::after{top:5px;}
@media(max-width:768px){.gg-nav{display:none;}.burger{display:inline-flex;}}

/* — Hero — */
.hero{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:520px;display:flex;align-items:flex-end;color:#fff;}
.hero .ph{position:absolute;inset:0;border-radius:0;border:none;}
.hero__inner{position:relative;padding:48px;max-width:680px;}
.hero h1{font-family:var(--font-display);font-weight:800;font-size:48px;line-height:1.08;color:#fff;margin:0 0 28px;letter-spacing:-.02em;text-wrap:balance;}
.hero__form{display:flex;gap:12px;max-width:540px;}
.hero__form .phone{flex:1;background:rgba(255,255,255,.96);}
.hero__privacy{margin-top:14px;font-size:12px;color:rgba(255,255,255,.72);max-width:430px;}
@media(max-width:768px){
  .hero{min-height:440px;}
  .hero__inner{padding:26px;}
  .hero h1{font-size:30px;}
  .hero__form{flex-direction:column;}
}

/* — Slider / карусель — */
.slider{position:relative;}
.slider__viewport{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);}
.slider__track{display:flex;transition:transform .45s cubic-bezier(.4,0,.15,1);}
.slider__slide{min-width:100%;}
.slider__slide .ph{border-radius:0;border:none;height:380px;}
.slider__arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;background:var(--brand-teal);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px -4px rgba(31,160,168,.5);transition:background .15s;z-index:2;}
.slider__arrow:hover{background:var(--brand-teal-hover);}
.slider__arrow--prev{left:-23px;}
.slider__arrow--next{right:-23px;}
.slider__dots{display:flex;gap:9px;justify-content:center;margin-top:20px;}
.slider__dots button{width:9px;height:9px;border-radius:50%;border:none;background:#cfd7e1;cursor:pointer;padding:0;transition:background .15s,width .2s;}
.slider__dots button[aria-current="true"]{background:var(--crimson);width:26px;border-radius:var(--radius-pill);}
.tabs{display:flex;gap:10px;justify-content:center;margin-top:26px;}
.tab{padding:9px 20px;border-radius:var(--radius-pill);border:1.5px solid var(--border);background:#fff;font-weight:600;font-size:14px;color:var(--text-muted);cursor:pointer;transition:all .15s;}
.tab[aria-selected="true"]{background:var(--navy);border-color:var(--navy);color:#fff;}
.empty-state{margin-top:18px;border:1.5px dashed var(--border);border-radius:var(--radius-lg);min-height:160px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:15px;}
@media(max-width:768px){
  .slider__slide .ph{height:240px;}
  .slider__arrow--prev{left:8px;}.slider__arrow--next{right:8px;}
}

/* — Карта — */
.map-wrap{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);height:380px;}
.map-wrap .ph{border-radius:0;border:none;height:100%;}
@media(max-width:768px){.map-wrap{height:280px;}}

/* — FAQ-аккордеон — */
.faq{max-width:820px;margin-inline:auto;}
.faq__item{border-top:1px solid var(--border);}
.faq__item:last-child{border-bottom:1px solid var(--border);}
.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:20px;background:none;border:none;cursor:pointer;text-align:left;padding:24px 4px;font-family:var(--font-display);font-weight:600;font-size:19px;color:var(--navy);}
.faq__icon{position:relative;width:24px;height:24px;flex:none;}
.faq__icon::before,.faq__icon::after{content:"";position:absolute;background:var(--brand-teal);border-radius:2px;transition:transform .25s ease,opacity .25s ease;}
.faq__icon::before{top:11px;left:2px;width:20px;height:2.5px;}
.faq__icon::after{top:2px;left:11px;width:2.5px;height:20px;}
.faq__item.open .faq__icon::after{transform:rotate(90deg);opacity:0;}
.faq__a{overflow:hidden;max-height:0;transition:max-height .3s ease;}
.faq__a-inner{padding:0 4px 24px;color:var(--text-muted);font-size:16px;line-height:1.65;max-width:680px;}

/* — CTA-баннер — */
.cta-banner{background:var(--surface-muted);border-radius:var(--radius-lg);padding:56px 40px;text-align:center;}
.cta-banner__sub{color:var(--text-muted);margin:12px 0 28px;font-size:17px;}
.cta-banner__form{max-width:440px;margin-inline:auto;display:flex;flex-direction:column;gap:14px;}

/* — Контакты — */
.contacts{display:grid;grid-template-columns:1fr 1.3fr;gap:48px;align-items:start;}
.contacts dt{font-weight:700;color:var(--navy);}
.contacts__row{margin-bottom:14px;}
.contacts__row span{color:var(--text-muted);}
.contacts a{color:var(--text);text-decoration:none;}
.contacts a:hover{color:var(--brand-teal);}
@media(max-width:768px){.contacts{grid-template-columns:1fr;gap:24px;}}

/* — Footer — */
.gg-footer{background:var(--navy);color:#fff;border-radius:var(--radius-lg);padding:56px 48px 40px;}
.gg-footer__top{display:grid;grid-template-columns:auto 1fr 1fr;gap:48px;align-items:start;}
.gg-footer .logo{height:34px;margin-bottom:20px;}
.gg-footer__cols{display:flex;flex-direction:column;gap:12px;}
.gg-footer__cols a{color:#fff;text-decoration:none;opacity:.85;font-size:15px;}
.gg-footer__cols a:hover{opacity:1;color:var(--brand-teal);}
.gg-footer__phone{font-family:var(--font-display);font-weight:600;font-size:20px;}
.vk{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;font-weight:700;font-size:13px;letter-spacing:.02em;transition:background .15s;}
.vk:hover{background:var(--brand-teal);}
.gg-footer__legal{margin-top:36px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);font-size:12px;line-height:1.55;color:var(--color-text-on-dark-muted);}
.gg-footer__copy{font-size:13px;color:var(--color-text-on-dark-muted);margin-top:18px;}
@media(max-width:768px){.gg-footer{padding:40px 24px;}.gg-footer__top{grid-template-columns:1fr;gap:28px;}}

/* — Утилиты: badge / chip, разделитель, плавающая кнопка — */
.chip{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 14px;border-radius:var(--radius-pill);background:var(--brand-teal-soft);color:var(--brand-teal-active);font-size:13px;font-weight:600;}
.chip--navy{background:var(--navy);color:#fff;}
.chip--ghost{background:transparent;border:1.5px solid var(--border);color:var(--text-muted);}
.fab{width:58px;height:58px;border-radius:50%;background:var(--brand-teal);color:#fff;border:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-pop);}
.fab:hover{background:var(--brand-teal-hover);}

/* Сигнатурный диагональный срез секции (угол ~2.5°) */
.diagonal{clip-path:polygon(0 var(--cut,2.6%),100% 0,100% 100%,0 100%);}
.diagonal-both{clip-path:polygon(0 var(--cut,2.6%),100% 0,100% calc(100% - var(--cut,2.6%)),0 100%);}

/* ============================================================
   NEW COMPONENT A — Промо-лента «Скидки и акции»
   ============================================================ */
.promos{display:flex;flex-direction:column;gap:20px;}
.promo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;}
@media(max-width:880px){.promo-grid{grid-template-columns:1fr;}}

.promo{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px;display:flex;flex-direction:column;gap:12px;transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease;}
.promo:hover{box-shadow:var(--shadow-card);transform:translateY(-3px);border-color:var(--brand-teal);}
.promo__badge{align-self:flex-start;display:inline-flex;align-items:center;font-family:var(--font-display);font-weight:700;font-size:14px;letter-spacing:.01em;padding:6px 14px;border-radius:var(--radius-pill);background:var(--brand-teal);color:#fff;white-space:nowrap;}
.promo__badge--crimson{background:var(--crimson);}
.promo__title{font-family:var(--font-display);font-weight:700;font-size:19px;line-height:1.25;color:var(--navy);margin:0;}
.promo__text{font-size:15px;line-height:1.55;color:var(--text-muted);margin:0;}
.promo__meta{font-family:ui-monospace,monospace;font-size:12px;letter-spacing:.03em;color:var(--text-muted);}
.promo__link{margin-top:auto;display:inline-flex;align-items:center;gap:8px;color:var(--brand-teal-active);font-weight:600;font-size:15px;text-decoration:none;transition:gap .15s ease;}
.promo__link:hover{gap:13px;}
.promo__link .ic{width:18px;height:18px;}

/* фичер-карточка — крупнее, на всю ширину */
.promo--feature{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:36px;padding:34px 40px;background:var(--brand-teal-soft);border-color:transparent;gap:36px;}
.promo--feature:hover{transform:none;border-color:transparent;box-shadow:var(--shadow-card);}
.promo__pct{font-family:var(--font-display);font-weight:800;font-size:64px;line-height:.9;color:var(--crimson);letter-spacing:-.03em;}
.promo--feature .promo__body{display:flex;flex-direction:column;gap:10px;}
.promo--feature .promo__title{font-size:24px;}
.promo--feature .promo__text{font-size:16px;max-width:540px;}
.promo--feature .btn{white-space:nowrap;}
@media(max-width:880px){
  .promo--feature{grid-template-columns:1fr;gap:18px;padding:28px 24px;text-align:left;}
  .promo__pct{font-size:52px;}
  .promo--feature .btn{width:100%;}
}

/* ============================================================
   NEW COMPONENT B — Карточки «Гараж под увлечение»
   ============================================================ */
.hobby-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;}
@media(max-width:980px){.hobby-grid{grid-template-columns:1fr;}}

.hobby{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;}
.hobby:hover{transform:translateY(-5px);box-shadow:var(--shadow-card);border-color:var(--brand-teal);}

/* единый «коробка-гараж» рендер, 4:3, разное наполнение */
.hobby__render{aspect-ratio:4/3;background:repeating-linear-gradient(135deg,#e9edf2 0 12px,#eef2f6 12px 24px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;padding:26px;}
.garage-box{position:relative;width:74%;height:78%;border:2px solid var(--brand-teal);border-radius:7px;background:rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;padding:14px;}
.garage-box::before{content:"";position:absolute;top:13%;left:20%;right:20%;height:20%;border:2px solid var(--brand-teal);opacity:.45;border-radius:4px;}
.garage-box span{font-family:ui-monospace,monospace;font-size:11px;line-height:1.4;color:var(--brand-teal-active);background:rgba(255,255,255,.86);padding:6px 12px;border-radius:var(--radius-pill);text-align:center;}

.hobby__body{display:flex;flex-direction:column;gap:12px;padding:22px 22px 24px;}
.hobby__head{display:flex;align-items:center;gap:12px;}
.hobby__mark{width:28px;height:34px;flex:none;background:var(--brand-teal);clip-path:polygon(0 0,100% 0,100% 100%,50% 76%,0 100%);border-radius:0 0 3px 3px;}
.hobby__name{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--navy);margin:0;}
.hobby__text{font-size:14.5px;line-height:1.55;color:var(--text-muted);margin:0;}
.hobby__chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px;}
.hobby__chips .chip{background:var(--brand-teal-soft);color:var(--navy);white-space:nowrap;}

/* ============================================================
   PAGE INTEGRATION — шапка/подвал/слайдер-фото/карта/cookie/согласие
   Дополнение к библиотеке системы для боевой сборки страниц.
   ============================================================ */

/* — Sticky header dock + расширения шапки (из header.html) — */
.header-dock{position:fixed;top:0;left:0;right:0;z-index:60;padding-top:14px;}
@media(max-width:768px){.header-dock{padding-top:10px;}}
.gg-header .logo-dark{display:none;}
.gg-header--scrolled .logo-light{display:none;}
.gg-header--scrolled .logo-dark{display:block;}
.gg-end{display:flex;align-items:center;gap:26px;}
.gg-phone{display:inline-flex;align-items:center;gap:9px;height:46px;padding:0 4px;font-family:var(--font-display);font-weight:600;font-size:17px;letter-spacing:.005em;text-decoration:none;white-space:nowrap;transition:color .25s ease,opacity .25s ease;}
.gg-phone .ic{width:18px;height:18px;display:inline-block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none;opacity:.85;}
.gg-header--onphoto .gg-phone{color:#fff;}
.gg-header--onphoto .gg-phone:hover{color:#fff;opacity:.82;}
.gg-header--scrolled .gg-phone{color:var(--navy);}
.gg-header--scrolled .gg-phone:hover{color:var(--brand-teal);}
.burger:hover{background:var(--crimson-hover);}
.burger:focus-visible{outline:3px solid color-mix(in srgb,var(--brand-teal) 55%,transparent);outline-offset:2px;}
@media(max-width:768px){
  .gg-nav,.gg-end .gg-phone,.gg-end .btn{display:none;}
  .gg-end{gap:0;}
}

/* — Мобильное меню — */
.mobile-overlay{position:fixed;inset:0;z-index:70;background:rgba(11,22,44,.46);opacity:0;visibility:hidden;transition:opacity .28s ease,visibility .28s ease;}
.mobile-overlay.open{opacity:1;visibility:visible;}
.mobile-panel{position:fixed;top:0;right:0;z-index:80;width:min(86vw,360px);height:100%;background:#fff;box-shadow:var(--shadow-pop);display:flex;flex-direction:column;padding:18px 22px calc(22px + env(safe-area-inset-bottom));transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.15,1);overflow-y:auto;}
.mobile-panel.open{transform:translateX(0);}
.mobile-panel__head{display:flex;align-items:center;justify-content:space-between;height:54px;margin-bottom:8px;}
.mobile-panel__head .logo{height:30px;width:auto;}
.mobile-close{width:46px;height:46px;flex:none;border:none;cursor:pointer;background:var(--surface-muted);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--navy);transition:background .16s ease,color .16s ease;}
.mobile-close:hover{background:var(--brand-teal-soft);color:var(--brand-teal-active);}
.mobile-close svg{width:20px;height:20px;stroke:currentColor;stroke-width:2;stroke-linecap:round;fill:none;}
.mobile-nav{display:flex;flex-direction:column;gap:2px;margin-top:8px;}
.mobile-nav a{display:flex;align-items:center;min-height:52px;padding:0 14px;border-radius:var(--radius-sm);text-decoration:none;font-family:var(--font-display);font-weight:600;font-size:19px;color:var(--navy);transition:background .15s ease,color .15s ease;}
.mobile-nav a:hover{background:var(--surface-muted);color:var(--brand-teal-active);}
.mobile-panel__foot{margin-top:auto;padding-top:22px;display:flex;flex-direction:column;gap:14px;}
.mobile-phone{display:inline-flex;align-items:center;gap:11px;min-height:48px;font-family:var(--font-display);font-weight:600;font-size:21px;color:var(--navy);text-decoration:none;}
.mobile-phone .ic{width:20px;height:20px;fill:none;stroke:var(--brand-teal);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none;}
.mobile-phone:hover{color:var(--brand-teal-active);}

/* — Подвал full-bleed (страница, а не карточка) — */
.site-footer{border-radius:0;padding:56px 0 40px;}
@media(max-width:768px){.site-footer{padding:40px 0;}}
.gg-footer__addr{color:var(--color-text-on-dark-muted);font-size:14px;line-height:1.5;margin-top:4px;}
.gg-footer__label{color:var(--color-text-on-dark-muted);font-size:13px;}
.gg-footer__phone{color:#fff;text-decoration:none;}
.gg-footer__phone:hover{color:var(--brand-teal);}

/* — Реальные фото в слайдере и карта (iframe) — */
.slider__slide img{display:block;width:100%;height:440px;object-fit:cover;}
@media(max-width:768px){.slider__slide img{height:240px;}}
.map-wrap iframe{display:block;width:100%;height:100%;border:0;}

/* — Чекбокс согласия (.gg-check) для форм (152-ФЗ) — */
.consent{display:flex;align-items:flex-start;gap:12px;cursor:pointer;text-align:left;}
.consent__text{font-size:13px;line-height:1.5;color:var(--text-muted);user-select:none;padding-top:1px;}
.consent a{color:var(--brand-teal);text-decoration:underline;text-underline-offset:2px;}
.consent a:hover{color:var(--brand-teal-hover);}
.gg-check{display:inline-flex;align-items:center;justify-content:center;position:relative;flex:none;width:20px;height:20px;border:1.5px solid var(--border);border-radius:4px;background:var(--surface);cursor:pointer;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease;}
.gg-check input{position:absolute;inset:0;margin:0;width:100%;height:100%;opacity:0;cursor:pointer;}
.gg-check__tick{width:10px;height:6px;border:2px solid #fff;border-top:none;border-right:none;transform:rotate(-45deg) translateY(-1px);opacity:0;transition:opacity .2s ease;}
.gg-check:hover{border-color:var(--color-border-strong);}
.gg-check[data-checked="true"]{background:var(--brand-teal);border-color:var(--brand-teal);}
.gg-check[data-checked="true"] .gg-check__tick{opacity:1;}
.gg-check[data-checked="true"]:hover{background:var(--brand-teal-hover);border-color:var(--brand-teal-hover);}
.gg-check:has(input:focus-visible){outline:none;box-shadow:0 0 0 4px color-mix(in srgb,var(--brand-teal) 16%,transparent);border-color:var(--brand-teal);}

/* ============================================================
   COOKIE CONSENT — изолированный нижний бар (префикс ck-)
   Не конфликтует с .btn / фикс-шапкой проекта.
   ============================================================ */
.ck-bar{position:fixed;left:16px;right:16px;bottom:16px;z-index:90;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-pop);display:flex;align-items:center;gap:20px;padding:16px 20px;}
.ck-bar[hidden]{display:none;}
.ck-bar__info{display:flex;align-items:center;gap:12px;flex:1 1 auto;min-width:0;}
.ck-bar__icon{flex:0 0 auto;width:32px;height:32px;border-radius:var(--radius-pill);border:none;background:var(--brand-teal-soft);color:var(--brand-teal);font-family:var(--font-display);font-weight:700;font-size:17px;font-style:italic;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .15s ease;}
.ck-bar__icon:hover{background:var(--brand-teal);color:#fff;}
.ck-bar__text{font-size:14px;line-height:1.5;color:var(--text-muted);}
.ck-bar__text a{color:var(--brand-teal);text-decoration:underline;text-underline-offset:2px;}
.ck-bar__actions{flex:0 0 auto;display:flex;align-items:center;gap:12px;}
.ck-btn{font-family:var(--font-text);font-size:14px;font-weight:600;line-height:1;border-radius:var(--radius-pill);border:1px solid transparent;padding:11px 20px;cursor:pointer;white-space:nowrap;transition:background .15s ease,color .15s ease,border-color .15s ease;}
.ck-btn:focus-visible{outline:2px solid var(--brand-teal);outline-offset:2px;}
.ck-btn--action{background:var(--crimson);color:#fff;}
.ck-btn--action:hover{background:var(--crimson-hover);}
.ck-btn--action:active{background:var(--crimson-active);}
.ck-btn--ghost{background:transparent;color:var(--text);border-color:var(--border);}
.ck-btn--ghost:hover{background:var(--surface-muted);border-color:var(--text-muted);}
.ck-manage{font-family:var(--font-text);font-size:14px;font-weight:500;color:var(--text-muted);background:none;border:none;padding:0 8px;cursor:pointer;text-decoration:underline;text-underline-offset:3px;}
.ck-manage:hover{color:var(--text);}
.ck-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(22,51,94,.38);}
.ck-modal[hidden]{display:none;}
.ck-dialog{width:100%;max-width:520px;max-height:calc(100vh - 40px);overflow:auto;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-pop);padding:24px;}
.ck-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:8px;}
.ck-title{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-.01em;margin:0;color:var(--navy);}
.ck-close{flex:0 0 auto;width:32px;height:32px;border:none;background:var(--surface-muted);border-radius:var(--radius-pill);color:var(--text-muted);font-size:18px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;}
.ck-close:hover{background:var(--border);color:var(--text);}
.ck-lead{color:var(--text-muted);font-size:14px;line-height:1.6;margin:0 0 20px;}
.ck-cat{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px 0;border-top:1px solid var(--border);}
.ck-cat__name{font-family:var(--font-display);font-weight:600;font-size:15px;margin:0 0 4px;color:var(--navy);}
.ck-cat__desc{color:var(--text-muted);font-size:13px;line-height:1.5;margin:0;}
.ck-toggle{position:relative;flex:0 0 auto;width:44px;height:26px;margin-top:2px;}
.ck-toggle input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;}
.ck-track{display:block;width:44px;height:26px;border-radius:var(--radius-pill);background:var(--border);transition:background .18s ease;}
.ck-track::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:var(--radius-pill);background:var(--surface);box-shadow:0 1px 3px rgba(22,51,94,.25);transition:transform .18s ease;}
.ck-toggle input:checked + .ck-track{background:var(--brand-teal);}
.ck-toggle input:checked + .ck-track::after{transform:translateX(18px);}
.ck-toggle input:disabled + .ck-track{background:var(--brand-teal-active);opacity:.55;}
.ck-foot{margin-top:24px;display:flex;justify-content:flex-end;}
.ck-foot .ck-btn--action{width:100%;}
@media(max-width:699px){
  .ck-bar{flex-direction:column;align-items:stretch;gap:14px;}
  .ck-bar__actions{flex-direction:column;align-items:stretch;gap:10px;}
  .ck-btn--action{order:1;width:100%;}
  .ck-btn--ghost{order:2;width:100%;}
  .ck-manage{order:3;align-self:center;}
}

/* — Реальные рендеры в карточках «Гараж под увлечение» — */
.hobby__render--photo{padding:0;background:none;}
.hobby__render--photo img{display:block;width:100%;height:100%;object-fit:cover;}
