    /* ==========================================================
      1) [STYLE] ГЛОБАЛЬНЫЕ ТОКЕНЫ + BASE + ОБЩИЕ КОМПОНЕНТЫ
      Относится ко всему сайту: переменные, базовые правила,
      контейнеры/секции, кнопки, поля, карточки, модалки, уведомления.
    ========================================================== */
    :root{
      --bg:#FFFFFF;
      --bg-soft:#F6F7FA;
      --card:#FFFFFF;
      --line:#E6E8EE;
      --text:#111827;
      --muted:#6B7280;
      --brand:#CC0000;
      --brand-dark:#9B1F1F;
      --brand-soft:#FCE8E8;
      --cta:#29CE90;
      --cta-hover:#23B67E;
      --cta-soft:#E9FBF3;
      --info:#3483CA;
      --slate:#384B60;

      --gradient-cta: linear-gradient(135deg, var(--cta), #1da1f2);
      --gradient-slate: linear-gradient(135deg, var(--slate), #2a3d52);

      --shadow: 0 8px 24px rgba(17,24,39,0.06);
      --shadow-soft: 0 4px 12px rgba(17,24,39,0.04);
      --shadow-neo: 0 8px 24px rgba(17,24,39,0.06), inset 0 1px 0 rgba(255,255,255,0.1);
      --r-card: 16px;
      --r-btn: 14px;
      --r-input: 12px;

      --container: 1240px;
      --pad-m: 5px;
      --pad-d: 32px;

      --section-m: 40px;
      --section-d: 64px;

      --tap: 44px;

      --transition-smooth: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }

    /* Base */
    *{box-sizing:border-box}
    html,body{height:100%}
    body{
      margin:0;
      font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", sans-serif;
      color:var(--text);
      background:var(--bg);
      line-height:1.6;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
    }
    img{max-width:100%; height:auto; display:block}
    a{color:inherit; text-decoration: none}
    :focus-visible{outline:3px solid rgba(52,131,202,.55); outline-offset:3px}

    .container{
      max-width: var(--container);
      margin: 0 auto;
      padding: 0 var(--pad-m);
    }

    .section{
      padding: var(--section-m) 0;
    }

    /* Breakpoints (mobile-first) */
    @media (min-width: 480px){
      .container{padding: 0 20px}
    }
    @media (min-width: 768px){
      .section{padding: 50px 0}
    }
    @media (min-width: 1024px){
      .container{padding: 0 var(--pad-d)}
      .section{padding: var(--section-d) 0}
    }
    @media (min-width: 1280px){
      .container{padding: 0 40px}
    }

    /* Buttons */
    .btn{
      appearance:none;
      border:1px solid transparent;
      min-height:48px;
      padding: 12px 24px;
      border-radius: var(--r-btn);
      font-weight: 700;
      cursor:pointer;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      line-height:1.1;
      text-decoration:none;
      user-select:none;
      transition: var(--transition-smooth);
      box-shadow: none;
      position: relative;
      overflow: hidden;
    }
    .btn:active{transform: translateY(1px)}
    .btn[disabled]{opacity:.6; cursor:not-allowed}
    .btn::after {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: rgba(255,255,255,0.1);
      opacity: 0;
      transition: opacity 0.3s ease;
    }
    .btn:hover::after {
      opacity: 1;
	  color: #384b60;
    }

    .btn--primary{
      background: var(--gradient-cta);
      color:#fff;
      box-shadow: 0 4px 12px rgba(41,206,144,0.25);
    }
    .btn--primary:hover{
      box-shadow: 0 6px 20px rgba(41,206,144,0.35);
      transform: translateY(-2px);
    }
    .btn--secondary{
      background:var(--bg);
      color:var(--slate);
      border:1px solid var(--line);
      box-shadow: var(--shadow-soft);
    }
    .btn--secondary:hover{
      background:var(--bg-soft);
      box-shadow: var(--shadow);
      transform: translateY(-2px);
    }
    .btn--ghost{
      background:transparent;
      color:var(--slate);
      border-color:transparent
    }
    .btn--ghost:hover{
      background:rgba(17,24,39,0.04);
      border-color:rgba(17,24,39,0.04)
    }
    .btn--icon{padding: 12px 14px}

    /* Inputs */
    .field{display:flex; flex-direction:column; margin-bottom:10px; gap:6px}
    .field__label{font-size:14px; color:var(--muted); font-weight: 500}
    .field__input, .field__textarea{
      width:100%;
      min-height:52px;
      padding: 14px 16px;
      border:2px solid var(--line);
      border-radius: var(--r-input);
      background: var(--bg);
      color: var(--text);
      font-size:16px;
      transition: var(--transition-smooth);
    }
    .field__textarea{min-height:100px; resize: vertical}
    .field__input:focus, .field__textarea:focus{
      border-color: var(--cta);
      box-shadow: 0 0 0 4px rgba(41,206,144,.15);
      outline:none;
      transform: translateY(-1px);
    }
    .field__input--invalid, .field__textarea--invalid{
      border-color: rgba(204,0,0,.55);
      box-shadow: 0 0 0 4px rgba(204,0,0,.10);
      background: #fff7f7;
    }
    .field__error{
      display:none;
      font-size:12px;
      color: var(--brand);
    }
    .field__error--show{display:block}

    /* Card */
    .card{
      background: var(--card);
      border: 1px solid var(--line);
      border-radius: var(--r-card);
      box-shadow: var(--shadow-neo);
      transition: var(--transition-smooth);
    }
    .card:hover {
      box-shadow: 0 12px 32px rgba(17,24,39,0.1);
    }

    /* Modal (A11y: aria, esc, outside click, focus trap) */
    .modal{
      position: fixed;
      inset: 0;
      z-index: 1000;
      display: none;
      align-items: center;
      justify-content: center;
      padding: 16px;
      background: rgba(17,24,39,.85);
      backdrop-filter: blur(6px);
    }
    .modal--open{display:flex}
    .modal__dialog{
      width: min(640px, 100%);
      max-height: min(80vh, 720px);
      overflow:auto;
      background: var(--card);
      border-radius: var(--r-card);
      border: 1px solid rgba(255,255,255,.08);
      box-shadow: 0 24px 64px rgba(0,0,0,.25);
      position: relative;
      animation: modalSlideIn 0.4s ease;
    }
    @keyframes modalSlideIn {
      from { opacity: 0; transform: translateY(20px); }
      to { opacity: 1; transform: translateY(0); }
    }
    .modal__header{
      padding: 20px 24px 0;
      display:flex;
      align-items:flex-start;
      justify-content:space-between;
      gap: 12px;
    }
    .modal__title{
      margin:0;
      font-size: 22px;
      line-height:1.2;
      color: var(--slate);
    }
    .modal__close{
      flex: 0 0 auto;
      width: 44px;
      height: 44px;
      border-radius: 12px;
      border: 1px solid var(--line);
      background: var(--bg);
      cursor:pointer;
      display:grid;
      place-items:center;
      transition: var(--transition-smooth);
    }
    .modal__close:hover{
      background: var(--bg-soft);
      transform: rotate(90deg);
    }
    .modal__body{padding: 18px 24px 24px}
    .modal__text{margin: 8px 0 18px; color: var(--muted); font-size: 18px; font-weight: 500; line-height: 1.5}
	.modal__text_n{margin: 8px 0 0px; color: #29ce90; font-size: 16px; line-height: 1.5}

    .loader{
      display:none;
      width:18px; height:18px;
      border:3px solid rgba(255,255,255,0.35);
      border-top-color:#fff;
      border-radius:50%;
      animation: spin 1s linear infinite;
    }
    @keyframes spin{to{transform:rotate(360deg)}}

    .notice{
      display:none;
      margin-top: 16px;
      padding: 12px 16px;
      border-radius: 12px;
      font-size: 14px;
      background: var(--cta-soft);
      color: #0f5132;
      border: 1px solid rgba(41,206,144,.25);
      animation: fadeIn 0.5s ease;
    }
    @keyframes fadeIn {
      from { opacity: 0; transform: translateY(10px); }
      to { opacity: 1; transform: translateY(0); }
    }
    .notice--show{display:block}

    .privacy{
      margin-top: 5px;
      font-size: 14px;
      color: var(--muted);
      line-height: 1.2;
    }
    .privacy a{color: var(--info); text-decoration: underline}
    .privacy a:hover{text-decoration: none}

    /* ==========================================================
      2) [STYLE] МОДУЛЬ: HERO (Banner / Header)
      Всё что начинается с .hero__ относится к баннеру в <header>.
    ========================================================== */
    .hero{
      padding: padding: 0 0 40px;;
      position: relative;
    }
    .hero__grid{
      display:grid;
      gap: 16px;
    }
    .hero__banner{
      border-radius: var(--r-card);
      overflow:hidden;
      position:relative;
      min-height: 380px;
      background:
        linear-gradient(90deg, rgba(17,24,39,.75), rgba(17,24,39,.15)),
        url("/images/banners/2024/foto_7.webp");
      background-size: cover;
      background-position: center;
      border: 1px solid rgba(255,255,255,.10);
      box-shadow: var(--shadow);
    }
    .hero__content{
      padding: 24px;
      display:flex;
      flex-direction:column;
      color:#fff;
      max-width: 1240px;
      position: relative;
      z-index: 2;
    }
    .hero__title{
      margin:0;
      font-size: 28px;
      line-height:1.2;
      letter-spacing: .02em;
      text-transform: uppercase;
      font-weight: 800;
      text-shadow: 0 2px 4px rgba(0,0,0,0.3);
    }
    .hero__subtitle{
      margin:0;
      color: rgba(255,255,255,.92);
      font-size: 20px;
      font-weight: 800;
    }
    .hero__subtitle strong{
      color: var(--cta);
      font-weight:800;
      background: linear-gradient(90deg, var(--cta), #1da1f2);
      -webkit-background-clip: text;
      background-clip: text;
      color: transparent;
    }
    .hero__media{
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 8px;
    justify-content: space-between;
}
	  .hero__badge{
    display: inline-flex;
    gap: 10px;
    padding: 12px 14px;
    background: rgba(255, 255, 255, .12);
    border: 2px solid rgba(255, 255, 255, .18);
    border-radius: 14px;
    backdrop-filter: blur(8px);
    transition: var(--transition-smooth);
    flex-direction: column;
}
    .hero__badge:hover {
      transform: translateY(-2px);
      background: rgba(255,255,255,.18);
    }
    .hero__badge img{width: 400px; height:auto}
    .hero__badge_o{
    display: inline-flex;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 14px;
    transition: var(--transition-smooth);
}
    .hero__badge_o:hover {
      transform: translateY(-2px);
      background: rgba(255,255,255,.18);
    }
    .hero__badge_o img{width: 300px; height:auto}
	@media (max-width: 1024px){
  .hero__badge_o{
    display: none !important;
  }
}
    .hero__actions{
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 24px;
    justify-content: flex-start;
}
.hero__deadline {
margin: 5px 0 0;
    font-size: 16px;
    color: rgba(255, 255, 255, .9);
    display: inline-block;
    line-height: 1.2;
    text-align: center;
}
.hero__deadline1 {
    margin: 16px 0 0;
    font-size: 16px;
    color: rgba(255, 255, 255, .9);
    padding: 10px 14px;
    border-radius: 12px;
    display: inline-block;
    border: 2px solid rgba(255, 255, 255, .12);
    line-height: 1.2;
    text-align: center;
}
    .hero__features{
      margin-top: 48px;
      display:grid;
      grid-template-columns: 1fr;
      gap: 12px;
      max-width: 520px;
    }
    .hero__feature{
      display:flex;
      gap: 14px;
      align-items:center;
      padding: 14px 16px;
      background: rgba(255,255,255,.12);
      border: 2px solid rgba(255,255,255,.18);
      border-radius: 14px;
      transition: var(--transition-smooth);
    }
    .hero__feature:hover {
      transform: translateY(-2px);
      background: rgba(255,255,255,.18);
    }
@media (max-width: 768px){
  .hero__features{ display:none !important; }
}
    .hero__icon{
      width: 48px;
      height: 48px;
      display:grid;
      place-items:center;
      border-radius: 12px;
      background: rgba(255,255,255,.15);
      border: 1px solid rgba(255,255,255,.2);
      flex: 0 0 auto;
      transition: var(--transition-smooth);
    }
    .hero__icon img{width: 28px; height: 28px}
    .hero__feature-text{
      margin:0;
      font-size: 15px;
      line-height:1.3;
      color: rgba(255,255,255,.95);
      font-weight: 500;
    }

    /* Desktop hero enhancements */
    @media (min-width: 768px){
      .hero__banner{min-height: 560px}
      .hero__content{padding: 40px}
      .hero__title{font-size: 60px}
      .hero__subtitle{font-size: 40px}
      .hero__features{grid-template-columns: repeat(3, 1fr); max-width: 100%}
      .hero__feature-text{font-size: 16px}
    }

    /* ==========================================================
      3) [STYLE] МОДУЛЬ: CALCULATOR (калькулятор в main)
      Всё что начинается с .calc__ / .stepper относится к калькулятору.
    ========================================================== */
    .calc__grid{
      display:grid;
      gap: 20px;
    }
    .calc__left, .calc__right{padding: 24px}
    .calc__right{display:flex; flex-direction:column; gap: 16px}
    .calc__title{
      margin:0 0 8px;
      font-size: 24px;
      color: var(--slate);
      font-weight: 800;
    }
    .calc__hint{
      margin:0;
      font-size: 14px;
      color: var(--muted);
      line-height: 1.5;
    }
    .calc__range{
      margin-top: 20px;
      padding: 20px;
      border: 1px solid var(--line);
      border-radius: var(--r-card);
      background: var(--bg-soft);
      transition: var(--transition-smooth);
    }
    .calc__range:hover {
      box-shadow: var(--shadow-soft);
    }
    .calc__range-top{
      display:flex;
      align-items:baseline;
      justify-content:space-between;
      gap: 12px;
      flex-wrap: wrap;
    }
    .calc__range-label{font-weight: 800; color: var(--slate); font-size: 16px}
    .calc__range-value{font-weight: 900; font-size: 28px; color: var(--cta)}
    .calc__slider{
      width:100%;
      margin-top: 16px;
      appearance:none;
      height: 10px;
      border-radius: 999px;
      background: #dde2ea;
      outline:none;
      transition: var(--transition-smooth);
    }
    .calc__slider:hover {
      background: #d0d6e0;
    }
    .calc__slider::-webkit-slider-thumb{
      appearance:none;
      width: 24px; height: 24px;
      border-radius: 50%;
      background: var(--gradient-cta);
      border: 4px solid #fff;
      box-shadow: 0 6px 16px rgba(17,24,39,.2);
      cursor:pointer;
      transition: var(--transition-smooth);
    }
    .calc__slider::-webkit-slider-thumb:hover {
      transform: scale(1.1);
      box-shadow: 0 8px 20px rgba(17,24,39,.25);
    }
    .calc__slider::-moz-range-thumb{
      width: 24px; height: 24px;
      border-radius: 50%;
      background: var(--gradient-cta);
      border: 4px solid #fff;
      box-shadow: 0 6px 16px rgba(17,24,39,.2);
      cursor:pointer;
      transition: var(--transition-smooth);
    }
    .calc__slider::-moz-range-thumb:hover {
      transform: scale(1.1);
    }
    .calc__scale{
      display:flex;
      justify-content:space-between;
      font-size: 13px;
      color: var(--muted);
      margin-top: 8px;
    }

    .calc__options{
      margin-top: 20px;
      display:grid;
      grid-template-columns: 1fr;
      gap: 16px;
    }
    .calc__option{
      padding: 20px;
      border: 1px solid var(--line);
      border-radius: var(--r-card);
      background: var(--bg);
      transition: var(--transition-smooth);
    }
    .calc__option:hover {
      box-shadow: var(--shadow-soft);
      transform: translateY(-2px);
    }
    .calc__option-title{
      margin:0 0 12px;
      font-weight: 800;
      color: var(--slate);
      font-size: 16px;
    }
    .stepper{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap: 12px;
    }
    .stepper__btn{
      width: 48px; height: 48px;
      border-radius: 14px;
      border: 1px solid var(--line);
      background: var(--bg-soft);
      color: var(--slate);
      font-size: 26px;
      line-height: 1;
      cursor:pointer;
      transition: var(--transition-smooth);
    }
    .stepper__btn:hover{
      background: var(--bg);
      transform: scale(1.05);
    }
    .stepper__btn:active{transform: scale(0.96)}
    .stepper__value{
      min-width: 60px;
      text-align:center;
      font-weight: 900;
      font-size: 28px;
      color: var(--slate);
    }

    .calc__total{
      display:flex;
      flex-direction:column;
      gap: 8px;
      padding: 20px;
      border: 1px solid var(--line);
      border-radius: var(--r-card);
      background: var(--gradient-slate);
      color: white;
      transition: var(--transition-smooth);
    }
    .calc__total:hover {
      transform: translateY(-2px);
      box-shadow: 0 12px 32px rgba(56,75,96,0.15);
    }
    .calc__total-label{font-size: 14px; color: rgba(255,255,255,.8)}
    .calc__total-value{
      font-size: 36px;
      font-weight: 900;
      letter-spacing: .01em;
    }
    .calc__note{
      display:none;
      font-size: 14px;
      color: var(--muted);
      margin: 0;
      line-height: 1.5;
    }

    @media (min-width: 768px){
      .calc__grid{
        grid-template-columns: 1.2fr .8fr;
        align-items:start;
      }
      .calc__options{grid-template-columns: repeat(2, 1fr)}
      .calc__note{display:block}
    }

    /* ==========================================================
      4) [STYLE] МОДУЛЬ: ZAMER (выгода бесплатного замера)
      Всё что начинается с .zamer__ относится к блоку замера.
    ========================================================== */
    .zamer__wrap{
      display:grid;
      gap: 20px;
      align-items: stretch;
    }
    .zamer__card{
      padding: 32px 24px;
      background: var(--gradient-slate);
      color: #fff;
      border-radius: var(--r-card);
      border: 1px solid rgba(255,255,255,.15);
      box-shadow: 0 16px 48px rgba(56,75,96,0.2);
      position: relative;
      overflow:hidden;
    }
    .zamer__card::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      height: 4px;
      background: var(--gradient-cta);
    }
    @keyframes pulse {
      0% { box-shadow: 0 4px 12px rgba(41,206,144,0.3); }
      50% { box-shadow: 0 4px 20px rgba(41,206,144,0.5); }
      100% { box-shadow: 0 4px 12px rgba(41,206,144,0.3); }
    }
    .zamer__title{
      font-size: 32px;
      line-height:1.15;
      letter-spacing: .02em;
      font-weight: 800;
      max-width: 600px;
    }
    .zamer__title strong{
      color: var(--cta);
      background: linear-gradient(90deg, var(--cta), #1da1f2);
      -webkit-background-clip: text;
      background-clip: text;
      color: transparent;
    }
    .zamer__list{
      margin: 0 0 24px;
      padding: 0;
      list-style:none;
      display:grid;
      color: rgba(255,255,255,.95);
    }
    .zamer__list li{
      display:flex;
      gap:14px;
      align-items:center;
      padding: 10px 0;
      font-size: 16px;
      border-bottom: 1px solid rgba(255,255,255,.1);
    }
    .zamer__list li:last-child {
      border-bottom: none;
    }
    .zamer__list li span {
      font-size: 20px;
      background: rgba(255,255,255,.1);
      width: 36px;
      height: 36px;
      border-radius: 10px;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .zamer__row{
      display:grid;
      gap: 16px;
      grid-template-columns: 1fr;
      align-items: start;
      margin-top: 24px;
    }
    .zamer__consent{
      display:flex;
      gap: 12px;
      align-items:flex-start;
      margin-top: 20px;
      font-size: 14px;
    color: rgb(255 255 255 / 70%);
    line-height: 1.2;
}
    .zamer__consent input{
      width: 20px; height: 20px;
      margin-top: 4px;
      flex: 0 0 auto;
      border-radius: 4px;
    }
    .zamer__consent a{
      color:#fff;
      text-decoration: underline;
    }
    .zamer__consent a:hover{
      text-decoration: none;
    }

    @media (min-width: 768px){
      .zamer__title{font-size: 38px}
      .zamer__row{grid-template-columns: 1fr auto}
      .zamer__list{grid-template-columns: repeat(2, 1fr); gap: 16px}
      .zamer__list li{border-bottom: none; padding: 12px 0}
    }

    /* ==========================================================
      5) [STYLE] МОДУЛЬ: FOOTER (подвал)
      Всё что начинается с .footer__ относится к подвалу.
    ========================================================== */
    .footer{
    padding: 40px 0 20px;
	margin-top: 20px;
    border-top: 1px solid var(--line);
    background: #e3edf6;
    position: relative;
    border-radius: 16px;
}
    .footer__grid{
      display:grid;
      gap: 24px;
      text-align:center;
      justify-items:center;
    }
    .footer__logo img{
      width: min(300px, 80vw);
    }
    .footer__phone1{
      font-size: 24px;
      font-weight: 900;
      color: var(--slate);
      text-decoration:none;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      min-height: var(--tap);
      padding: 10px 20px;
      border-radius: 12px;
      background: var(--bg-soft);
      transition: var(--transition-smooth);
    }
    .footer__phone1:hover{
      color: var(--info);
      background: var(--bg);
      box-shadow: var(--shadow-soft);
      transform: translateY(-2px);
    }
    .footer__reviews{
      width: min(320px, 100%);
      display:grid;
      gap: 14px;
      justify-items:center;
      padding: 24px;
      border-radius: var(--r-card);
      border: 1px solid var(--line);
      background: var(--bg-soft);
      transition: var(--transition-smooth);
    }
    .footer__reviews:hover {
      transform: translateY(-2px);
      box-shadow: var(--shadow);
    }
    .footer__stars{
      color: #f59e0b;
      letter-spacing: 2px;
      font-size: 18px;
    }
    .footer__cta{
      width: min(320px, 100%);
      display:grid;
      gap: 16px;
    }
/* Anti-spam honeypot (только для формы отзывов) */
.hp-field{
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}
/* ==========================================================
  6) [STYLE] МОДУЛЬ: FLOATING MENU (плавающее меню)
========================================================== */
.floating-menu{
  --fm-size: 68px;
  --fm-gap: 10px;
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 999;
}
.floating-menu__main-btn{
  width: var(--fm-size);
  height: var(--fm-size);
  border-radius: 16px;
  background: var(--gradient-cta);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
  right: 10px;
}
.floating-menu__main-btn:hover{
  transform: scale(1.06);
  box-shadow: 0 12px 32px rgba(41,206,144,0.35);
}
.floating-menu__main-btn::after{
  content:'';
  position:absolute;
  inset:0;
  background: rgba(255,255,255,0.10);
  opacity:0;
  transition: opacity .25s ease;
}
.floating-menu__main-btn:hover::after{ opacity:1; }
.floating-menu__icon{
  width: 60px;
  height: 60px;
  display:block;
  transition: opacity .18s ease, transform .18s ease;
}
.floating-menu__main-btn.is-open{
  background: transparent;
  box-shadow: none;
}
.floating-menu__main-btn.is-open::after{ opacity:0; }
.floating-menu__main-btn.is-open .floating-menu__icon{
  opacity: 0;
  transform: scale(0.8);
}
.floating-menu__items {
    position: fixed;
    bottom: 20px;
    height: var(--fm-size);
    display: flex;
    gap: 12px;
    padding-right: calc(var(--fm-size) + 12px);
    opacity: 0;
    transform: translateY(6px) scale(0.98);
    pointer-events: none;
    transition: opacity .16s ease, transform .16s ease;
    align-items: flex-end;
    flex-direction: column;
    justify-content: flex-end;
}
@keyframes fmSpringIn {
  0%   { opacity: 0; transform: translateY(8px) scale(0.96); }
  60%  { opacity: 1; transform: translateY(-1px) scale(1.03); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes fmItemSpringIn {
  0%   { opacity: 0; transform: translateY(6px) scale(0.95); }
  65%  { opacity: 1; transform: translateY(-1px) scale(1.04); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}
/* Открытие: spring */
.floating-menu__items--visible{
  pointer-events: auto;
  animation: fmSpringIn .32s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.floating-menu__item{
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: transparent;
  border: none;
  box-shadow: none;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition: transform .2s ease, background .2s ease;
  -webkit-tap-highlight-color: transparent;
}
.floating-menu__items--visible .floating-menu__item{
  animation: fmItemSpringIn .34s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.floating-menu__item:hover{
  transform: translateY(-1px) scale(1.03);
  background: rgba(255,255,255,0.10);
}
.floating-menu__item:focus-visible{
  outline: 2px solid rgba(41,206,144,0.55);
  outline-offset: 3px;
}
.floating-menu__item-icon{
  width: 54px;
  height: 54px;
  display:block;
}
@media (min-width: 1024px){
  .floating-menu{
    right: 16%;
  }
}
    /* ==========================================================
      7) [STYLE] МОДУЛЬ: QUIZ (квиз внутри модалки)
      Всё что начинается с .quiz__ относится к квизу.
    ========================================================== */
    .quiz__progress{
      width:100%;
      height: 8px;
      border-radius: 999px;
      background: #e5e7eb;
      overflow:hidden;
      position: relative;
    }
    .quiz__progress-bar{
      height:100%;
      width:0%;
      background: var(--gradient-cta);
      border-radius: 999px;
      transition: width .4s cubic-bezier(0.4, 0, 0.2, 1);
    }
    .quiz__progress-text{
      margin: 2px 0 0;
      font-size: 12px;
      color: var(--muted);
      text-align:center;
    }
    .quiz__slide{display:none; animation: fadeIn 0.5s ease}
    .quiz__slide--active{display:block}
    .quiz__h1{
      margin: 0 0 16px;
      font-size: 20px;
      color: var(--slate);
      line-height:1.2;
      font-weight: 700;
    }
    .quiz__h2{
      margin: 0 0 0px;
      font-size: 20px;
      color: var(--slate);
      line-height:1.2;
      font-weight: 700;
    }
    .quiz__p{margin:0 0 16px; color: var(--muted); font-size: 14px; line-height: 1.2}
    
    .quiz__options{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
      margin-top: 16px;
    }
    @media (min-width: 480px){
      .quiz__options{grid-template-columns: repeat(2, 2fr)}
    }
    .quiz__option{
      border: 2px solid var(--line);
      border-radius: var(--r-card);
      overflow:hidden;
      background: var(--bg);
      cursor:pointer;
      transition: var(--transition-smooth);
      min-height: 44px;
      display: flex;
      flex-direction: column;
    }
    .quiz__option:hover{
      transform: translateY(-4px);
      box-shadow: var(--shadow);
      border-color: var(--cta);
    }
    .quiz__option[aria-pressed="true"]{
      border-color: var(--cta);
      box-shadow: 0 0 0 4px rgba(41,206,144,.12);
      background: var(--cta-soft);
      transform: translateY(-2px);
    }
.quiz__option-img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    transition: transform 0.3s ease;
    border-radius: 8px;
    margin-top: 5px;
}
    .quiz__option:hover .quiz__option-img {
      transform: scale(1.05);
    }
    .quiz__option-title{
      margin: 0;
      padding: 4px 12px;
      font-size: 16px;
      font-weight: 600;
      color: var(--slate);
      text-align:center;
      flex: 1;
      display: flex;
      align-items: center;
      justify-content: center;
	  line-height: 1.2;
    }
.quiz__nav {
    display: flex;
    gap: 12px;
    justify-content: center;
    margin-top: 24px;
    flex-wrap: wrap;
}
    .quiz__timer{
      font-size: 14px;
      color: var(--muted);
      padding: 8px 16px;
      background: var(--bg-soft);
      border-radius: 12px;
      border: 1px solid var(--line);
    }
    .quiz__timer strong{color: var(--cta)}
.quiz__range {
    padding: 0px 16px 16px;
    border-radius: var(--r-card);
    border: 1px solid var(--line);
    background: var(--bg-soft);
    transition: var(--transition-smooth);
}
    .quiz__range:hover {
      box-shadow: var(--shadow-soft);
    }
    .quiz__range-value{
      font-weight: 900;
      color: var(--cta);
      text-align:center;
      font-size: 24px;
      margin: 8px 0 8px;
    }
    .quiz__range input[type="range"]{
      width:100%;
      height: 10px;
      border-radius: 5px;
      background: #dde2ea;
      outline: none;
      -webkit-appearance: none;
    }
    .quiz__range input[type="range"]::-webkit-slider-thumb {
      -webkit-appearance: none;
      width: 24px;
      height: 24px;
      border-radius: 50%;
      background: var(--gradient-cta);
      border: 4px solid white;
      box-shadow: 0 4px 12px rgba(0,0,0,0.2);
      cursor: pointer;
    }
.quiz__messengers {
    display: flex;
    gap: 30px;
    margin: 10px 0 6px;
    justify-content: center;
}

.quiz__messenger{
  width:56px;
  height:56px;
  border-radius: 14px;
  border: 2px solid var(--line);
  background: var(--bg);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition: var(--transition-smooth);
  box-shadow: none;
  padding: 0;
}

.quiz__messenger:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-soft);
  border-color: var(--cta);
}

.quiz__messenger[aria-pressed="true"]{
  border-color: var(--cta);
  box-shadow: 0 0 0 4px rgba(41,206,144,.12);
  background: var(--cta-soft);
  transform: translateY(-1px);
}

.quiz__messenger img{
  width:42px;
  height:42px;
  display:block;
}

.quiz__gift-picked {
    font-size: 24px;
    line-height: 1.15;
    letter-spacing: .02em;
    font-weight: 800;
    max-width: 600px;
    color: var(--cta);
    background: linear-gradient(90deg, var(--cta), #1da1f2);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin-bottom: 24px;
    text-align: center;
}
    /* ==========================================================
      8) [STYLE] МЕДИА-ПРАВКИ (мелкие экраны + safe-area)
      Эти правила влияют на несколько модулей одновременно.
    ========================================================== */
    @media (max-width: 360px) {
      .hero__title { font-size: 26px; }
      .zamer__title { font-size: 24px; }
      .calc__title { font-size: 22px; }
       .floating-menu{
    right: 12px;
    bottom: 12px;
	bottom: 12px;
    padding-right: calc(var(--fm-size) + 10px);
    --fm-size: 56px;
  }
  .floating-menu__item{
    width: 52px;
    height: 52px;
  }
}

    @supports (padding: max(0px)){
  .floating-menu{
    bottom: max(10px, env(safe-area-inset-bottom));
  }
}

/* Уважение к настройке "уменьшить анимацию" */
@media (prefers-reduced-motion: reduce){
  .floating-menu__main-btn,
  .floating-menu__icon,
  .floating-menu__items,
  .floating-menu__item{
    transition: none !important;
  }
  .floating-menu__items--visible,
  .floating-menu__items--visible .floating-menu__item{
    animation: none !important;
  }
}

  /* =========================================================
     [00] DESIGN TOKENS (переменные проекта)
     ========================================================= */
  :root{
    --bg_1:#FFFFFF;
    --bg-soft_1:#F6F7FA;
    --card_1:#FFFFFF;
    --line_1:#E6E8EE;
    --text_1:#111827;
    --muted_1:#6B7280;

    --brand_1:#CC0000;
    --brand-dark_1:#9B1F1F;
    --brand-soft_1:#FCE8E8;

    --cta_1:#29CE90;
    --cta-hover_1:#23B67E;
    --cta-soft_1:#E9FBF3;

    --info_1:#3483CA;
    --slate_1:#384B60;

    --gradient-cta_1: linear-gradient(135deg, var(--cta_1), #1da1f2);
    --gradient-slate_1: linear-gradient(135deg, var(--slate_1), #2a3d52);

    --shadow_1: 0 8px 24px rgba(17,24,39,0.06);
    --shadow-soft_1: 0 4px 12px rgba(17,24,39,0.04);
    --shadow-neo_1: 0 8px 24px rgba(17,24,39,0.06), inset 0 1px 0 rgba(255,255,255,0.1);

    --r-card_1: 16px;
    --r-btn_1: 14px;
    --r-input_1: 12px;

    --container_1: 1240px;
    --pad-m_1: 5px;
    --pad-d_1: 32px;

    --section-m_1: 40px;
    --section-d_1: 64px;

    --tap_1: 44px;

    --transition-smooth_1: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }

  /* =========================================================
     [00] Base / A11y
     ========================================================= */
 
  @supports not (overflow: clip){
    body{ overflow-x:hidden; }
  }

  /* =========================================================
     [00] Layout
     ========================================================= */
  .container_1{ max-width:var(--container_1); margin:0 auto; padding:0 var(--pad-m_1); }
  .section_1{ padding:var(--section-m_1) 0; }
  .section--soft_1{ 
  background:var(--bg-soft_1);
  border-radius: 16px;
  }

  @media (min-width: 480px){
    .container_1{ padding:0 20px; }
  }
  @media (min-width: 768px){
    .section_1{ padding:50px 0; }
  }
  @media (min-width: 1024px){
    .container_1{ padding:0 var(--pad-d_1); }
    .section_1{ padding:var(--section-d_1) 0; }
  }
  @media (min-width: 1280px){
    .container_1{ padding:0 40px; }
  }
  @media (max-width: 360px){
    .section_1{ padding:32px 0; }
  }

  .section__title_1{
    margin: 0 0 8px;
    font-size: 24px;
    color: var(--slate);
    font-weight: 800;
}
  .section__lead_1{
    font-size: 16px;
    color: var(--muted);
    line-height: 1.5;
	max-width: 60ch;
}

  /* =========================================================
     [00] UI-KIT: Buttons
     ========================================================= */
  .btn_1{
    position:relative;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-height:48px;
    padding:10px 14px;
    border-radius:var(--r-btn_1);
    border:2px solid transparent;
    cursor:pointer;
    text-decoration:none;
    font-weight:700;
    letter-spacing:.2px;
    user-select:none;
    -webkit-tap-highlight-color: transparent;
    transition:var(--transition-smooth_1);
    transform:translateY(0);
    overflow:hidden;
    min-width:var(--tap_1);
  }
  .btn_1::after{
    content:"";
    position:absolute;
    inset:0;
    background:rgba(255,255,255,0);
    transition:var(--transition-smooth_1);
    pointer-events:none;
  }
  .btn_1:hover::after{ background:rgba(255,255,255,.10); }
  .btn_1:active{ transform:translateY(1px); }

  .btn--primary_1{
    background:var(--gradient-cta_1);
    color:var(--bg_1);
    box-shadow:0 4px 12px rgba(41,206,144,0.25);
  }
  .btn--primary_1:hover{
    transform:translateY(-2px);
    box-shadow:0 10px 22px rgba(41,206,144,0.32);
  }

  .btn--secondary_1{
    background:var(--bg_1);
    color:var(--slate_1);
    border:2px solid var(--line_1);
  }
  .btn--secondary_1:hover{
    background:var(--bg-soft_1);
    box-shadow:var(--shadow-soft_1);
    transform:translateY(-2px);
  }

  .btn--ghost_1{
    background:transparent;
    color:var(--slate_1);
    border:2px solid var(--line_1);
  }
  .btn--ghost_1:hover{
    background:rgba(17,24,39,.04);
    box-shadow:var(--shadow-soft_1);
    transform:translateY(-2px);
  }

  .btn--icon_1{
    padding:12px 14px;
    min-width:48px;
    width:48px;
  }

  /* Контексты на тёмном/фото: ghost-вид (ВАЖНО: reviews__nav исключили) */
  .btn--ghost_1,
  .btn--ghost_1,
  .article-card_1 .btn--ghost_1{
    color:var(--bg_1);
    border-color:rgba(255,255,255,.55);
    background:rgba(255,255,255,.06);
  }
  .btn--ghost_1:hover,
  .btn--ghost_1:hover,
  .article-card_1 .btn--ghost_1:hover{
    background:rgba(255,255,255,.10);
    transform:translateY(-2px);
    box-shadow:var(--shadow-soft_1);
  }

  /* =========================================================
     [00] UI-KIT: Fields
     ========================================================= */
  .field_1{ min-width:0; }
  .field__label_1{ display:block; font-size:14px; color:var(--muted_1); margin:0 0 6px; }
  .field__input_1,
  .field__textarea_1{
    width:100%;
    border:2px solid var(--line_1);
    border-radius:var(--r-input_1);
    padding:14px 16px;
    font-size:16px;
    min-height:52px;
    background:var(--bg_1);
    color:var(--text_1);
    transition:var(--transition-smooth_1);
    appearance:none;
  }
  .field__textarea_1{ min-height:120px; resize:vertical; }
  .field__input_1:focus,
  .field__textarea_1:focus{
    outline:none;
    border-color:var(--cta_1);
    box-shadow:0 0 0 4px rgba(41,206,144,.15);
    transform:translateY(-1px);
  }
  .field__input--invalid_1,
  .field__textarea--invalid_1{
    border-color:rgba(204,0,0,.55);
    background:rgba(204,0,0,.04);
  }
  .field__error_1{
    margin:8px 0 0;
    font-size:12px;
    color:var(--brand_1);
    display:none;
  }
  .field__error--show_1{ display:block; }

  /* =========================================================
     [00] UI-KIT: Cards
     ========================================================= */
  .card_1{
    background:var(--card_1);
    border:1px solid var(--line_1);
    border-radius:var(--r-card_1);
    box-shadow:var(--shadow-neo_1);
    transition:var(--transition-smooth_1);
  }
  .card_1:hover{ box-shadow:0 12px 28px rgba(17,24,39,0.10), inset 0 1px 0 rgba(255,255,255,0.12); transform:translateY(-2px); }

  /* =========================================================
     [00] UI-KIT: Modal
     ========================================================= */
  .modal_1{
    position:fixed; inset:0;
    display:none;
    align-items:center;
    justify-content:center;
    padding:16px;
    background:rgba(17,24,39,.85);
    backdrop-filter: blur(6px);
    z-index:2000;
  }
  .modal_1[aria-hidden="false"]{ display:flex; }
  .modal__dialog_1{
    width:min(640px, 100%);
    max-height:min(80vh, 720px);
    overflow:hidden;
    border-radius:var(--r-card_1);
    background:var(--card_1);
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-neo_1);
    position:relative;
    transform:translateY(10px);
    opacity:0;
    animation: modalIn_1 .28s cubic-bezier(0.4,0,0.2,1) forwards;
  }
  @keyframes modalIn_1{
    to{ transform:translateY(0); opacity:1; }
  }
  .modal__header_1{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:12px 12px 10px;
    border-bottom:1px solid var(--line_1);
    gap:12px;
    background:var(--bg_1);
  }
  .modal__title_1{ margin:0; font-size:16px; color:var(--slate_1); font-weight:800; }
  .modal__close_1{
    width:var(--tap_1);
    height:var(--tap_1);
    min-width:var(--tap_1);
    min-height:var(--tap_1);
    border-radius:var(--r-btn_1);
    border:1px solid var(--line_1);
    background:var(--bg_1);
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    transition:var(--transition-smooth_1);
  }
  .modal__close_1:hover{ transform:rotate(90deg); box-shadow:var(--shadow-soft_1); }
  .modal__body_1{ padding:12px; }

/* =========================================================
   [01] Types gallery (unified)
   ========================================================= */
.types-grid_1{ display:block; }

.types-grid__lead--desk_1{ display:none; }
.types-grid__lead--mob_1{ display:inline; }
@media (min-width:1024px){
  .types-grid__lead--desk_1{ display:inline; }
  .types-grid__lead--mob_1{ display:none; }
}
.types-grid__tools_1{
  display:block;
  margin-top:12px;
  margin-bottom:14px;
}
.types-grid__filters_1{
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
}
.types-grid__chip_1{
    appearance: none;
    border: 2px solid var(--line_1);
    background: var(--card_1);
    color: var(--slate_1);
    border-radius: 16px;
    padding: 10px 14px;
    min-height: 40px;
    line-height: 1;
    font-weight: 900;
    cursor: pointer;
    transition: var(--transition-smooth_1);
}
.types-grid__chip_1:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(17,24,39,.06);
}
.types-grid__chip_1.is-active{
  border-color: rgba(41,206,144,.45);
  box-shadow: 0 10px 20px rgba(41,206,144,.12);
}
.types-grid__metaLine_1{
  margin: 6px 0 10px;
  color: var(--muted_1);
  font-size: 14px;
}
.types-grid__grid_1{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:10px;
}
.types-grid__item--small_1{ aspect-ratio: 1 / 1; }
.types-grid__item--large_1{
  grid-column: span 2;
  aspect-ratio: 2 / 1;
}
.types-grid__item_1{ order: var(--order-mob, 0); }
@media (max-width:1023px){
  .types-grid__grid_1{
    grid-template-columns: 1fr;
  }
  .types-grid__item--large_1{
    grid-column: auto;
  }
  .types-grid__item--small_1,
  .types-grid__item--large_1{
    aspect-ratio: 16 / 9;
  }
}
@media (min-width:1024px){
  .types-grid__grid_1{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap:12px;
  }
  .types-grid__item_1{ order: var(--order-desk, 0); }
}
.types-grid__item_1{
  position:relative;
  overflow:hidden;
  border-radius:var(--r-card_1);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:var(--shadow-neo_1);
  isolation:isolate;
  background:rgba(17,24,39,1);
  transition:var(--transition-smooth_1);
  cursor:pointer;
}
.types-grid__item_1:focus-visible{
  outline: 2px solid var(--cta_1);
  outline-offset: 3px;
}
.types-grid__item_1:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(17,24,39,0.10), inset 0 1px 0 rgba(255,255,255,0.12);
}
.types-grid__img_1{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:var(--transition-smooth_1);
  filter:brightness(.95);
}
.types-grid__overlay_1{
  position:absolute; inset:0;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:14px;
  background:linear-gradient(180deg, rgba(17,24,39,.18), rgba(17,24,39,.62));
  transition:var(--transition-smooth_1);
}
@media (min-width:768px){
  .types-grid__overlay_1{ padding:18px; }
}
.types-grid__badge_1{
    align-self: flex-start;
    color: var(--bg_1);
    font-weight: 800;
    font-size: clamp(18px, 2.7vw, 24px);
}
.types-grid__desc_1{
  color: rgba(255,255,255,.92);
  font-size: 16px;
  line-height: 1.25;
  max-width: 32ch;
}
.types-grid__bottom_1{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:10px;
}
.types-grid__price_1{
  margin-top:auto;
  font-size:clamp(18px, 4vw, 22px);
  font-weight:900;
  color:var(--bg_1);
  text-shadow:0 10px 18px rgba(17,24,39,.35);
  opacity:1;
  transform:none;
}
.types-grid__cta_1{
  opacity:1;
  transition:var(--transition-smooth_1);
  position:relative;
  z-index:2;
}
@media (hover: hover) and (pointer: fine){
  .types-grid__item_1:hover .types-grid__img_1{
    transform:scale(1.06);
    filter:brightness(.75);
  }
  .types-grid__item_1:hover .types-grid__overlay_1{
    background:linear-gradient(180deg, rgba(246,247,250,.20), rgba(246,247,250,.62));
  }
  .types-grid__item_1:hover .types-grid__price_1{
    color: var(--slate_1);
    text-shadow:none;
  }
}
@media (prefers-reduced-motion: reduce){
  .types-grid_1 *{ scroll-behavior:auto !important; }
  .types-grid_1 .types-grid__img_1{ transition:none !important; }
  .types-grid_1 .types-grid__overlay_1{ transition:none !important; }
  .types-grid_1 .types-grid__cta_1{ transition:none !important; }
  .types-grid_1 .types-grid__item_1{ transition:none !important; }
}

  /* =========================================================
     [02] Photo gallery + buttons + lightbox
     ========================================================= */
  .work-gallery__tabs_1{
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 0 0 18px;
    overflow: auto;
    padding: 4px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    justify-content: center;
}
  .work-gallery__tabs_1::-webkit-scrollbar{ display:none; }

  .work-gallery__tab_1{
    flex:0 0 auto;
    min-height:40px;
    padding:10px 14px;
    border-radius:16px;
    border:2px solid var(--line_1);
    background:var(--bg_1);
    color:var(--slate_1);
    font-weight:900;
    cursor:pointer;
    transition:var(--transition-smooth_1);
    white-space:nowrap;
  }
  .work-gallery__tab_1:hover{
    transform:translateY(-2px);
    background:var(--bg-soft_1);
    box-shadow:var(--shadow-soft_1);
  }
  .work-gallery__tab_1.is-active_1{
    border-color:rgba(41,206,144,.45);
    background:var(--cta-soft_1);
    box-shadow:0 10px 22px rgba(41,206,144,0.14);
  }

  .work-gallery__grid_1{
    display:grid;
    grid-template-columns: repeat(2, 1fr);
    gap:10px;
    margin:0 0 16px;
  }
  .work-gallery__item_1{
    position:relative;
    overflow:hidden;
    border-radius:var(--r-card_1);
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-neo_1);
    background:var(--card_1);
    cursor:pointer;
    min-height:120px;
    transition:var(--transition-smooth_1);
  }
  .work-gallery__item_1:hover{ transform:translateY(-2px); box-shadow:0 12px 28px rgba(17,24,39,0.10), inset 0 1px 0 rgba(255,255,255,0.12); }
  .work-gallery__img_1{
    width:100%;
    height:100%;
    aspect-ratio: 4/3;
    object-fit:cover;
    transition:var(--transition-smooth_1);
  }
  .work-gallery__item_1:hover .work-gallery__img_1{ transform:scale(1.03); }
  .work-gallery__empty_1{
    grid-column: 1 / -1;
    padding:16px;
    color:var(--muted_1);
    text-align:center;
    border:1px dashed var(--line_1);
    border-radius:var(--r-card_1);
    background:var(--bg-soft_1);
  }
  .work-gallery__more_1{ width:100%; }

  .lightbox__frame_1{
    position:relative;
    border-radius:14px;
    overflow:hidden;
    background:var(--bg-soft_1);
    border:1px solid var(--line_1);
  }
  .lightbox__img_1{
    width:100%;
    height:auto;
    max-height:70vh;
    object-fit:contain;
    background:rgba(17,24,39,1);
  }
  .lightbox__nav_1{
    position:absolute; inset:0;
    pointer-events:none;
    display:flex;
    justify-content:space-between;
    align-items:center;
  }
  .lightbox__btn_1{
    pointer-events:auto;
    margin:10px;
    width:var(--tap_1);
    height:var(--tap_1);
    min-width:var(--tap_1);
    min-height:var(--tap_1);
    border-radius:16px;
    border:1px solid rgba(255,255,255,.55);
    background:rgba(17,24,39,.45);
    color:var(--bg_1);
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    backdrop-filter: blur(6px);
    transition:var(--transition-smooth_1);
  }
  .lightbox__btn_1:hover{ background:rgba(17,24,39,.62); transform:translateY(-2px); }

  /* =========================================================
     [03] Articles (исправлено: 4 в ряд на десктопе)
     ========================================================= */
  .articles__grid_1{
    display:grid;
    grid-template-columns: 1fr;
    gap:10px;
  }
  .articles__row_1{ display:none; gap:10px; }
  .articles__row_1.is-visible_1{ display:grid; }

  /* ВАЖНО: именно rows задаём колонки (раньше было 1 колонка всегда) */
  .articles__row_1{ grid-template-columns: 1fr; }
  @media (min-width:768px){
    .articles__row_1{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  }
  @media (min-width:1024px){
    .articles__row_1{ grid-template-columns: repeat(4, minmax(0,1fr)); }
  }

  .article-card_1{
    position:relative;
    overflow:hidden;
    border-radius:var(--r-card_1);
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-neo_1);
    background:rgba(17,24,39,1);
    min-height:220px;
    transition:var(--transition-smooth_1);
  }
  .article-card_1:hover{ transform:translateY(-2px); box-shadow:0 12px 28px rgba(17,24,39,0.10), inset 0 1px 0 rgba(255,255,255,0.12); }
  .article-card__img_1{
    width:100%;
    height:100%;
    object-fit:cover;
    aspect-ratio: 16/10;
    filter:brightness(.9);
    transition:var(--transition-smooth_1);
  }
  .article-card__overlay_1{
    position:absolute; inset:0;
    background:rgba(56,75,96,.62);
    transition:var(--transition-smooth_1);
  }
  .article-card__content_1{
    position:absolute; inset:0;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    padding:14px;
    color:var(--bg_1);
  }
  .article-card__title_1{
    margin:0;
    font-size:18px;
    line-height:1.2;
    font-weight:900;
  }
  .article-card__desc_1{
    margin:8px 0 0;
    font-size:14px;
    color:rgba(255,255,255,.88);
    max-width:54ch;
  }
  .article-card__link_1{ align-self:flex-start; margin-top:12px; }
  .article-card_1:hover .article-card__img_1{ transform:scale(1.03); filter:brightness(.75); }
  .article-card_1:hover .article-card__overlay_1{ background:rgba(17,24,39,.68); }
  .articles__more_1{ margin-top:16px; width:100%; }

  /* =========================================================
     [04] FAQ
     ========================================================= */
  .faq__list_1{ display:grid; gap:10px; }
  .faq__item_1{
    border-radius:var(--r-card_1);
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-neo_1);
    background:var(--card_1);
    overflow:hidden;
    transition:var(--transition-smooth_1);
  }
  .faq__item_1:hover{ box-shadow:0 12px 28px rgba(17,24,39,0.10), inset 0 1px 0 rgba(255,255,255,0.12); transform:translateY(-2px); }

  .faq__q_1{
    width:100%;
    text-align:left;
    padding:14px 14px;
    background:var(--bg-soft_1);
    border:0;
    cursor:pointer;
    font-size:16px;
    font-weight:800;
    color:var(--slate_1);
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    min-height:48px;
  }
  .faq__q_1:hover{ background:rgba(41,206,144,.10); }
  .faq__icon_1{
    flex:0 0 auto;
    width:36px; height:36px;
    border-radius:6px;
    border:2px solid var(--line_1);
    display:grid;
    place-items:center;
    background:var(--bg_1);
    color:var(--slate_1);
    transition:var(--transition-smooth_1);
  }
  .faq__a_1{ padding:0 14px 14px; color:var(--slate_1); display:none; }
  .faq__a_1 p{ margin:10px 0 0; color:var(--slate_1); }
  .faq__item_1.is-open_1 .faq__a_1{ display:block; }
  .faq__item_1.is-open_1 .faq__icon_1{ border-color:rgba(41,206,144,.35); background:var(--cta-soft_1); }

  /* =========================================================
     [05] Reviews slider (исправлено: кнопки видны на десктопе)
     ========================================================= */
  .reviews__wrap_1{ position:relative; }
  .reviews__track_1{
    display:flex;
    gap:10px;
    overflow:auto;
    scroll-snap-type: x mandatory;
    scroll-behavior:smooth;
    padding:4px;
    scrollbar-width:none;
  }
  .reviews__track_1::-webkit-scrollbar{ display:none; }

  .reviews__card_1{
    flex:0 0 78%;
    scroll-snap-align:start;
    border-radius:var(--r-card_1);
    overflow:hidden;
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-neo_1);
    background:var(--card_1);
    transition:var(--transition-smooth_1);
  }
  .reviews__card_1:hover{ transform:translateY(-2px); box-shadow:0 12px 28px rgba(17,24,39,0.10), inset 0 1px 0 rgba(255,255,255,0.12); }
  .reviews__card_1 img{ width:100%; aspect-ratio: 4/3; object-fit:cover; }

  .reviews__nav_1{
    position:absolute;
    inset:0;
    pointer-events:none;
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:0 6px;
  }
  .reviews__nav_1 .btn_1{
    pointer-events:auto;
    border-radius:16px;
    width:var(--tap_1);
    height:var(--tap_1);
    min-width:var(--tap_1);
    min-height:var(--tap_1);
    padding:0;
  }

  /* НОВОЕ: правильный стиль кнопок на светлом фоне */
  .reviews__nav_1 .btn--ghost_1{
    color:var(--slate_1);
    border-color:rgba(230,232,238,.95);
    background:rgba(17,24,39,.04);
    box-shadow:var(--shadow-soft_1);
    backdrop-filter: blur(6px);
  }
  .reviews__nav_1 .btn--ghost_1:hover{
    background:rgba(17,24,39,.08);
    transform:translateY(-2px);
  }
@media (max-width: 1024px){
  .reviews__nav_1{
    display: none !important;
  }
}
  /* =========================================================
     [06/11] About
     ========================================================= */
  .about__grid_1{
    display:grid;
    grid-template-columns: 1fr;
    gap:10px;
  }
  .about-card_1{
    position:relative;
    border-radius:var(--r-card_1);
    overflow:hidden;
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-neo_1);
    padding:18px;
    min-height:200px;
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
    color:var(--bg_1);
    transition:var(--transition-smooth_1);
  }
  .about-card_1:hover{ transform:translateY(-2px); box-shadow:0 12px 28px rgba(17,24,39,0.10), inset 0 1px 0 rgba(255,255,255,0.12); }

  .about-card--white_1{
    background: var(--info_1);
    justify-content: flex-start;
  }
  .about-card--blue_1{ background:var(--muted_1); }
  .about-card--slate_1{ background:var(--slate_1); }
  .about-card--image_1{ background-size:cover; background-position:center; }

.about-card__title_1 {
    margin: 0;
    font-size: clamp(24px, 4.5vw, 28px);
    line-height: 1.1;
    letter-spacing: .2px;
    font-weight: 900;
}
  .about-card--white_1 .about-card__title_1{ color:#ffffff; }
  .about-card__text_1{
margin: 5px 0 0;
    color: rgba(255, 255, 255, .92);
    font-size: 18px;
    max-width: 32ch;
    font-weight: 400;
    line-height: 1.35;
}
  .about-card--white_1 .about-card__text_1{ color:#ffffff; }

  .about__num_1{ font-variant-numeric: tabular-nums; }

  /* =========================================================
     [07/12] Manufacturers + Accordion (generic)
     ========================================================= */
  .manufacturers__grid_1{
    display:none;
    grid-template-columns: 1fr;
    gap:10px;
  }
  .m-card_1{
    position:relative;
    padding:18px;
    border-radius:var(--r-card_1);
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-neo_1);
    background:var(--card_1);
    overflow:hidden;
    transition:var(--transition-smooth_1);
  }
  .m-card_1:hover{ transform:translateY(-2px); box-shadow:0 12px 28px rgba(17,24,39,0.10), inset 0 1px 0 rgba(255,255,255,0.12); }

  .m-card__brand_1{
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap:12px;
    margin-bottom:12px;
  }
  .m-card__logo_1{ width:220px; height:auto; }
  .m-card__badge_1{
    position:absolute;
    top:18px; right:18px;
    width:92px; height:92px;
    border-radius:999px;
    background:var(--bg_1);
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-soft_1);
    display:grid;
    place-items:center;
    padding:10px;
  }
  .m-card__badge_1 img{ width:100%; height:100%; object-fit:contain; }
  .m-card__subtitle_1{ color:var(--muted_1); margin:0 0 10px; }
  .m-card__price_1{ margin:0 0 10px; font-size:26px; font-weight:900; color:var(--slate_1); }
  .m-card__meta-title_1{ margin:0 0 6px; font-weight:900; color:var(--slate_1); }
  .m-card__meta_1{ margin:0; color:var(--muted_1); font-size:14px; line-height:1.45; }
  .m-card__cta_1{ position:absolute; right:18px; bottom:18px; }

  /* Accordion (generic) */
  .acc_1{ display:grid; gap:10px; }
  .acc__item_1{
    border-radius:var(--r-card_1);
    overflow:hidden;
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-neo_1);
    background:var(--card_1);
    transition:var(--transition-smooth_1);
  }
  .acc__item_1:hover{ box-shadow:0 12px 28px rgba(17,24,39,0.10), inset 0 1px 0 rgba(255,255,255,0.12); transform:translateY(-2px); }

  .acc__btn_1{
    width:100%;
    border:0;
    background:var(--card_1);
    cursor:pointer;
    padding-top: 28px;
    padding-right: 14px;
    padding-bottom: 28px;
    padding-left: 14px;
    min-height:48px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    text-align:left;
  }
  .acc__btn_1:hover{ background:var(--bg-soft_1); }
  .acc__head_1{ display:flex; align-items:center; gap:12px; min-width:0; }
  .acc__head_1 img{ width:190px; height:auto; flex:0 0 auto; }
  .acc__price_1{ margin-left:auto; color:var(--slate_1); font-weight:900; }
  .acc__chev_1{
    width:36px; height:36px;
    border-radius:6px;
    border:2px solid var(--line_1);
    display:grid;
    place-items:center;
    color:var(--slate_1);
    flex:0 0 auto;
    background:var(--bg_1);
    transition:var(--transition-smooth_1);
	font-size: 20px;
  }
  .acc__item_1.is-open_1 .acc__chev_1{ border-color:rgba(41,206,144,.35); background:var(--cta-soft_1); }

  .acc__panel_1{ display:none; padding:0 14px 14px; }
  .acc__item_1.is-open_1 .acc__panel_1{ display:block; }
  .acc__panel_1 p{ margin:10px 0 0; color:var(--muted_1); }
  .acc__panel_1 .btn_1{ margin-top:12px; }

  /* =========================================================
     [08] QR
     ========================================================= */
  .qr__grid_1{
    display:grid;
    grid-template-columns: 1fr;
    gap:14px;
    align-items:start;
  }
  .qr__item_1{
    border-radius:var(--r-card_1);
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-neo_1);
    background:var(--card_1);
    padding:14px;
    text-align:center;
    transition:var(--transition-smooth_1);
  }
  .qr__item_1:hover{ transform:translateY(-2px); box-shadow:0 12px 28px rgba(17,24,39,0.10), inset 0 1px 0 rgba(255,255,255,0.12); }
  .qr__item_1 a{ color:var(--info_1); text-decoration:none; font-weight:800; }
  .qr__item_1 a:hover{ color:var(--cta_1); }
  .qr__img_1{ width:100%; max-width:320px; margin:0 auto 10px; }

  /* =========================================================
     [09] Hero slider
     ========================================================= */
  .hero__wrap_1{
    position:relative;
    overflow:hidden;
    border-radius:var(--r-card_1);
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-neo_1);
    background:var(--bg-soft_1);
  }
  .hero__track_1{
    display:flex;
    transition:var(--transition-smooth_1);
    touch-action: pan-y pinch-zoom;
  }
  .hero__slide_1{ flex:0 0 100%; position:relative; min-height:320px; }
  .hero__img_1{
    width:100%;
    height:100%;
    min-height:320px;
    object-fit:cover;
  }
  .hero__content_1{
    position:absolute;
    inset:0;
    padding:16px;
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    gap:10px;
  }
  .hero__kicker_1{ color:var(--info_1); font-weight:900; font-size:20px; }
  .hero__kicker--cta_1{ color:var(--cta_1); }

  .hero__title_1{
    margin:0;
    color:var(--slate_1);
    font-weight:1000;
    font-size:clamp(22px, 5vw, 34px);
    line-height:1.1;
    text-shadow:0 10px 20px rgba(255,255,255,.35);
  }
  .hero__price_1{
    align-self:flex-start;
    margin-top:6px;
    font-weight:1000;
    color:var(--slate_1);
    background:rgba(255,255,255,.72);
    border:2px solid rgba(204,0,0,.55);
    padding:8px 10px;
    border-radius:14px;
    transform: rotate(-1deg);
  }
  .hero__note_1{
    margin-top:auto;
    color:rgba(56,75,96,.92);
    background:rgba(255,255,255,.78);
    border:1px solid rgba(230,232,238,.9);
    padding:10px 12px;
    border-radius:14px;
    max-width:70ch;
  }
  .hero__note_1 b{ color:var(--cta_1); }

  .hero__metrics_1{ display:grid; gap:10px; margin-top:6px; max-width:520px; }
  .hero-metric_1{ display:flex; align-items:center; gap:12px; }
  .hero-metric__icon_1{ width:40px; height:40px; }
  .hero-metric__text_1{ display:flex; flex-direction:column; }
  .hero-metric__text_1 span{ color:var(--slate_1); font-size:14px; }
  .hero-metric__text_1 strong{ color:var(--slate_1); font-size:18px; }

  .hero__dots_1{
    position:absolute;
    left:50%;
    bottom:14px;
    transform:translateX(-50%);
    display:flex;
    gap:8px;
    z-index:2;
  }
  .hero__dot_1{
    width:var(--tap_1);
    height:var(--tap_1);
    min-width:var(--tap_1);
    min-height:var(--tap_1);
    border-radius:16px;
    border:8px solid rgba(230,232,238,.8);
    background:rgba(246,247,250,.85);
    cursor:pointer;
    display:grid;
    place-items:center;
    transition:var(--transition-smooth_1);
  }

  .hero__dot_1.is-active_1{ border-color:rgba(204,0,0,.35); }


  @media (max-width: 360px){
    .hero__content_1{ padding:14px; }
    .hero__kicker_1{ font-size:18px; }
    .hero-metric__icon_1{ width:36px; height:36px; }
    .hero-metric__text_1 strong{ font-size:16px; }
  }

  /* =========================================================
     [13] How we work (reveal)
     ========================================================= */
  .howwork__grid_1{
    display:grid;
    grid-template-columns: 1fr;
    gap:10px;
  }
  .howwork__item_1{
    border-radius:var(--r-card_1);
    border:1px solid var(--line_1);
    box-shadow:var(--shadow-neo_1);
    background:var(--card_1);
    padding:16px;
    opacity:0;
    transform: translateY(14px);
    transition:var(--transition-smooth_1);
  }
  .howwork__item_1.is-visible_1{ opacity:1; transform:translateY(0); }
  .howwork__item_1 h3{
    margin:0 0 8px;
    color:var(--brand_1);
    font-size:18px;
    font-weight:1000;
  }
  .howwork__item_1 p{ margin:0; color:var(--slate_1); }

  /* =========================================================
     [00] Responsive
     ========================================================= */
  @media (min-width:480px){
    .work-gallery__grid_1{ grid-template-columns: repeat(3, 1fr); }
    .qr__grid_1{ grid-template-columns: 1fr 1fr; }
  }

  @media (min-width:768px){
    .work-gallery__grid_1{ grid-template-columns: repeat(4, 1fr); }
    .about__grid_1{ grid-template-columns: repeat(2, 1fr); }
    .reviews__card_1{ flex-basis: 44%; }
    .hero__content_1{ padding:18px; }
    .hero__slide_1{ min-height:420px; }
    .hero__img_1{ min-height:420px; }
    .howwork__grid_1{ grid-template-columns: repeat(2, 1fr); }
  }

  @media (min-width:1024px){
    .manufacturers__grid_1{ display:grid; grid-template-columns: repeat(3, 1fr); }
    .manufacturers__acc_1{ display:none; }

    .about__grid_1{ grid-template-columns: repeat(3, 1fr); }
    .reviews__card_1{ flex-basis: 32%; }
  }

  @media (min-width:1280px){
    .hero__slide_1{ min-height:520px; }
    .hero__img_1{ min-height:520px; }
  }

  /* =========================================================
     [00] Reduced motion
     ========================================================= */
  @media (prefers-reduced-motion: reduce){
    *{ scroll-behavior:auto !important; }
    .work-gallery__img_1,.article-card__img_1{ transition:none !important; }
    .howwork__item_1{ transition:none !important; }
    .hero__track_1{ transition:none !important; }
    .btn_1, .card_1, .m-card_1, .about-card_1, .faq__item_1, .reviews__card_1, .work-gallery__item_1{ transition:none !important; }
    .modal__dialog_1{ animation:none !important; opacity:1 !important; transform:none !important; }
  }
  @media (max-width: 1024px){
  .section_1 section--soft_1 qr_1{
    display: none !important;
  }
}
  .menus {
    display: flex;
    margin: 0 auto;
    padding: 10px;
    flex-direction: column-reverse;
}
.menu-section {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    margin-bottom: 20px;
}
.menu-section h2 {
  font-size: 18px;
  font-weight: bold;
  color: #f6f7fa;
  margin-bottom: 10px;
}
.menu-section ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
  flex-grow: 1; 
}
.menu-section ul li {
  margin-bottom: 2px;
}
.menu-section ul li a {
  text-decoration: none;
  color: #5C5C5C;
  font-size: 14px;
  transition: color 0.3s;
}
.menu-section ul li a:hover {
  color: #3483ca;
}

</style>

<!-- FAQ Schema (модуль 4) — актуальная микроразметка сохраняется (ключи Schema.org НЕ МЕНЯЕМ) -->
<script type="application/ld+json">
{
  "@context": "https://schema.org",
  "@type": "FAQPage",
  "mainEntity": [
    {
      "@type": "Question",
      "name": "Какие тренды в дизайне натяжных потолков в 2025 году?",
      "acceptedAnswer": {
        "@type": "Answer",
        "text": "В 2025 популярны трековое освещение, световые линии, интеграция с «умным домом» и скрытые карнизы для эффекта «парящего» потолка."
      }
    },
    {
      "@type": "Question",
      "name": "Что сначала - потолок или обои?",
      "acceptedAnswer": {
        "@type": "Answer",
        "text": "Рекомендуем сначала устанавливать потолок, а затем клеить обои."
      }
    },
    {
      "@type": "Question",
      "name": "На сколько опустится потолок?",
      "acceptedAnswer": {
        "@type": "Answer",
        "text": "Потолок обычно опускается на 4-6 см в зависимости от особенностей конструкции."
      }
    },
    {
      "@type": "Question",
      "name": "Вредны ли натяжные потолки?",
      "acceptedAnswer": {
        "@type": "Answer",
        "text": "Мы используем только качественные полотна, которые абсолютно безвредны в жилых помещениях."
      }
    },
    {
      "@type": "Question",
      "name": "Сколько длится установка?",
      "acceptedAnswer": {
        "@type": "Answer",
        "text": "В среднем установка занимает 2-4 часа для одного помещения."
      }
    }
  ]
}