    /* ==========================================================
      1) [STYLE] ГЛОБАЛЬНЫЕ ТОКЕНЫ + BASE + ОБЩИЕ КОМПОНЕНТЫ
      Относится ко всему сайту: переменные, базовые правила,
      контейнеры/секции, кнопки, поля, карточки, модалки, уведомления.
    ========================================================== */
    :root{
      --bg:#FFFFFF;
      --bg-soft:#F6F7FA;
      --card:#FFFFFF;
      --line:#E6E8EE;
      --text:#384B60;
      --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;
    }

    @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: 1302;
      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(500px, 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: center;
    justify-content: space-between;
    gap: 12px;
}
    .modal__title{
    margin: 0;
    font-size: 24px;
    line-height: 1.2;
    color: var(--slate);
    font-weight: 900;
}
    .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, .hero *{ box-sizing:border-box; }
  .hero img{ max-width:100%; display:block; }
  .hero a{ color:inherit; text-decoration:none; }

  /* Фокус делаем в CTA-цвете, без синего второго акцента */
  .hero :focus-visible{ outline:3px solid rgba(41,206,144,.55); outline-offset:3px; }

  .hero .container{
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--pad-m);
  }
  @media (min-width: 1024px){ .hero .container{padding: 0 var(--pad-d)} }
  @media (min-width: 1280px){ .hero .container{padding: 0 40px} }

  /* Buttons (scoped) */
  .hero .btn{
    appearance:none;
    border:1px solid transparent;
    min-height:48px;
    padding: 12px 18px;
    border-radius: var(--r-btn);
    font-weight: 800;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    line-height:1.15;
    user-select:none;
    transition: var(--transition-smooth);
    position: relative;
    overflow: hidden;

    /* ВАЖНО: не ломаем 360px и увеличенный шрифт */
    white-space: normal;
    text-align: center;
    overflow-wrap: anywhere;
  }
  @media (min-width: 520px){
    /* На широких можно вернуть одну строку */
    .hero .btn{ white-space: nowrap; overflow-wrap: normal; }
  }

  .hero .btn:active{ transform: translateY(1px); }
  .hero .btn[disabled]{ opacity:.6; cursor:not-allowed; }

  .hero .btn::after{
    content:'';
    position:absolute;
    inset:0;
    background: rgba(255,255,255,0.10);
    opacity:0;
    transition: opacity 0.25s ease;
  }
  .hero .btn:hover::after{ opacity:1; }

  .hero .btn--primary{
    background: var(--gradient-cta);
    color:#fff;
    box-shadow: 0 8px 22px rgba(41,206,144,0.26);
    min-height: 54px;
    padding: 14px 18px;
    font-size: 16px;
    font-weight: 900;
  }
  .hero .btn--primary:hover{
    box-shadow: 0 12px 30px rgba(41,206,144,0.34);
    transform: translateY(-1px);
  }

  /* Вторичный CTA намеренно тише, чтобы не отбирать клики у квиза */
  .hero .btn--secondary{
    background: rgba(255,255,255,0.06);
    color: rgba(255,255,255,.94);
    border:2px solid rgba(255,255,255,.22);
    box-shadow: none;
    font-weight: 800;
  }
  .hero .btn--secondary:hover{
    background: rgba(255,255,255,0.10);
    transform: translateY(-1px);
  }

  .hero .sr-only{
    position:absolute !important;
    width:1px !important;
    height:1px !important;
    padding:0 !important;
    margin:-1px !important;
    overflow:hidden !important;
    clip:rect(0,0,0,0) !important;
    white-space:nowrap !important;
    border:0 !important;
  }

  /* ==========================================================
    HERO
  ========================================================== */
  .hero__grid{
    display:grid;
    gap: 16px;
  }

  .hero__banner{
    border-radius: var(--r-card);
    overflow:hidden;
    position:relative;
    min-height: 360px;
    background-color: #111827;
    border: 1px solid rgba(255,255,255,.10);
    box-shadow: var(--shadow);
  }

  /* LCP background image */
  .hero__bg{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit: cover;
    object-position: center;
    z-index: 0;
  }

  .hero__banner::before{
    content:'';
    position:absolute;
    inset:0;
    background: linear-gradient(
      90deg,
      rgba(17,24,39,.90) 0%,
      rgba(17,24,39,.58) 45%,
      rgba(17,24,39,.24) 100%
    );
    z-index: 1;
  }

  .hero__content{
    padding: 20px;
    display:flex;
    flex-direction:column;
    color:#fff;
    position: relative;
    z-index: 2;
    gap: 12px;
  }

  .hero__title{
    margin:0;
    font-size: clamp(26px, 4.6vw, 56px);
    line-height: 1.2;
    letter-spacing: .01em;
    font-weight: 900;
    text-shadow: 0 2px 4px rgba(0,0,0,0.30);
    max-width: 20ch;
  }

  .hero__subtitle{
    margin: 0;
    color: rgba(255, 255, 255, .94);
    font-size: clamp(16px, 2.6vw, 28px);
    font-weight: 850;
    max-width: 46ch;
	margin-top: -10px;
  }
  .hero__subtitle strong{
    font-weight:900;
    color: #fff;
  }

  .hero__price{
    margin: 0;
    color: rgba(255,255,255,.94);
    font-size: 14px;
    line-height: 1.35;
    max-width: 68ch;
  }
  .hero__price strong{
    font-weight: 900;
    color: #fff;
  }
  .hero__price em{
    font-style: normal;
    color: rgba(255,255,255,.86);
  }

  /* CTA максимально рано и компактно */
  .hero__actions{
    display:flex;
    flex-direction: column;
    gap: 10px;
    align-items: stretch;
    margin-top: 4px;
  }
  .hero__actions .btn{ width: 100%; }

  @media (min-width: 520px){
    .hero__actions{
      flex-direction: row;
      align-items: center;
      justify-content: flex-start;
    }
    .hero__actions .btn{ width: auto; }
  }



  /* ==========================================================
    Акции как вход в квиз (кликабельные чипсы)
  ========================================================== */
  .hero__chips{
    margin: 4px 0 0;
    padding: 0;
    list-style: none;
    display:flex;
    flex-wrap: wrap;
    gap: 10px;
    max-width: 980px;
  }
  .hero__chip-item{ margin:0; padding:0; }

  .hero__chip-btn{
    appearance: none;
    border: 1px solid rgba(255, 255, 255, .18);
    background: rgba(255, 255, 255, .10);
    color: rgba(255, 255, 255, .95);
	border-top-left-radius: 60px;
    border-top-right-radius: 16px;
    border-bottom-right-radius: 16px;
    border-bottom-left-radius: 60px;
    padding: 10px 24px 10px 12px;
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    transition: var(--transition-smooth);
    min-height: 44px;
    text-align: left;
}
  .hero__chip-btn:hover{
    background: rgba(255,255,255,.14);
    transform: translateY(-1px);
  }

  .hero__chip-text{
    margin: 0;
    font-size: 16px;
    line-height: 1.5;
    font-weight: 800;
    white-space: normal;
  }
  @media (min-width: 768px){
    .hero__chip-text{ font-size: 14px; }
  }

  .hero__chip-btn strong{
    font-weight: 900;
    color: #fff;
  }

  .hero__chip-icon{
    width: 60px;
    height: 60px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .16);
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    overflow: hidden;
}

  /* ==========================================================
    Компактные преимущества (меньше "стекла", меньше высота)
  ========================================================== */
  .hero__features{
    margin-top: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px 2px;
    max-width: 1240px;
    justify-content: space-between;
}

  .hero__feature{
    display: flex;
    gap: 5px;
    align-items: center;
    border: 0;
    background: rgba(255, 255, 255, .10);
    border-radius: 10px;
    padding: 0 10px 0 0;
}

  .hero__icon{
    width: 36px;
    height: 36px;
    display:grid;
    place-items:center;
    border-radius: 10px;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.16);
    flex: 0 0 auto;
  }
  .hero__icon img{ width: 22px; height: 22px; }

  .hero__feature-text{
    margin:0;
    font-size: 12px;
    line-height:1.25;
    color: rgba(255,255,255,.94);
    font-weight: 600;
  }

  @media (min-width: 768px){
    .hero__banner{ min-height: 560px; }
    .hero__content{ padding: 38px; gap: 14px; }
    .hero__price{ font-size: 15px; }
    .hero__feature-text{ font-size: 16px; }
    .hero__icon{ width: 40px; height: 40px; }
  }

  @media (prefers-reduced-motion: reduce){
    .hero .btn,
    .hero__chip-btn{
      transition: none !important;
    }
    .hero .btn:hover,
    .hero__chip-btn:hover{
      transform: none !important;
    }
  }

    /* ==========================================================
      3) [STYLE] МОДУЛЬ: CALCULATOR (калькулятор в main)
      Всё что начинается с .calc__ / .stepper относится к калькулятору.
    ========================================================== */
    .calc__grid{
      display:grid;
      gap: 20px;
    }
    .calc__left, .calc__right{padding: 0px}
    .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: 950px){
      .calc__left, .calc__right {
        padding: 24px;
      }
	  .calc__grid{
        grid-template-columns: 1.2fr .8fr;
        align-items:end;
      }
      .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: 1301;
}
.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;
}
.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 32px;
    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: 50px;
	--section-m_2: 20px;
    --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 {
    margin: var(--section-m_1) 0;
    padding: var(--section-m_2) 0;
}
  .section--soft_1{ 
  background:var(--bg-soft_1);
  border-radius: 16px;
  }

  @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:#29ce90;
  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: #ffffff;
    border:0;
    cursor:pointer;
    font-size:16px;
    font-weight:700;
    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; font-size: 16px; }
  .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); font-size: 16px; }
  .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); }
  }

  @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;
}
  .footer-address{
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    font-size: 14px;
    line-height: 1.4;
    color: inherit;
    opacity: .9;
    justify-content: center;
}
  .footer-address__label{ color: #ffffff; opacity:.8; }
  .footer-address__value{ color: #ffffff; font-weight:600; }
  .sp-copyright{ color: #e3edf6; font-size: 14px; }
  
    /* =========================================================
     МОДУЛЬ: Примеры сметы - стили
     ========================================================= */

  .estimate-examples_1{
    --ee-line: var(--line_1, #E6E8EE);
    --ee-bg: var(--bg_1, #ffffff);
    --ee-bg-soft: var(--bg-soft_1, #F6F7FA);
    --ee-text: var(--text_1, #111827);
    --ee-muted: var(--muted_1, #6B7280);
    --ee-slate: var(--slate_1, #384B60);
    --ee-cta: var(--cta_1, #29CE90);
    --ee-cta-soft: var(--cta-soft_1, #E9FBF3);
    --ee-info: var(--info_1, #3483CA);
    color: var(--ee-text);
  }

  .estimate-examples_1 .estimate-examples__headRow_1{
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    align-items: start;
  }

  .estimate-examples_1 .estimate-examples__noscript_1{
    margin-top: 12px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid rgba(0,0,0,.08);
    background: rgba(255,255,255,.75);
    color: var(--ee-muted);
    font-size: 14px;
    line-height: 1.45;
  }

  .estimate-examples_1 .estimate-examples__grid_1{
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 14px;
    align-items: start;
  }

  .estimate-examples_1 .estimate-card_1{
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-self: start;
  }

  .estimate-examples_1 .estimate-card__media_1{
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid var(--ee-line);
    background: var(--ee-bg-soft);
    aspect-ratio: 16 / 10;
  }

  .estimate-examples_1 .estimate-card__media_1 img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .estimate-examples_1 .estimate-card__top_1{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
  }

  .estimate-examples_1 .estimate-card__titlewrap_1{
    min-width: 0;
    flex: 1 1 180px;
  }

  .estimate-examples_1 .estimate-card__title_1{
    margin: 0;
    color: var(--ee-slate);
    font-weight: 1000;
    font-size: 18px;
    line-height: 1.15;
  }

  .estimate-examples_1 .estimate-card__meta_1{
    margin: 6px 0 0;
    color: var(--ee-muted);
    font-size: 15px;
    line-height: 1.35;
  }

  .estimate-examples_1 .estimate-card__priceWrap_1{
    flex: 0 0 auto;
    text-align: center;
  }

  .estimate-examples_1 .estimate-card__price_1{
    font-weight: 1000;
    color: var(--ee-slate);
    background: rgba(255,255,255,.72);
    border: 2px solid rgba(41,206,144,.35);
    padding: 8px 10px;
    border-radius: 14px;
    white-space: nowrap;
    font-size: 24px;
  }

  .estimate-examples_1 .estimate-card__subprice_1{
    color: var(--ee-muted);
    font-size: 12px;
    line-height: 1.25;
  }

  .estimate-examples_1 .estimate-card__priceval_1{
    font-variant-numeric: tabular-nums;
  }

  .estimate-examples_1 .estimate-card__actions_1{
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 2px;
  }

  .estimate-examples_1 .estimate-card__details_1{
    border-top: 1px solid var(--ee-line);
    padding-top: 12px;
    overflow: hidden;
    scroll-margin-top: 120px;
  }
  .estimate-examples_1 .estimate-card__details_1[hidden]{ display:none; }

  @media (prefers-reduced-motion: no-preference){
    .estimate-examples_1 .estimate-card__details_1{
      animation: estimateFadeIn_1 .18s ease-out;
    }
    @keyframes estimateFadeIn_1{
      from{ opacity: 0; transform: translateY(-2px); }
      to { opacity: 1; transform: translateY(0); }
    }
  }

  .estimate-examples_1 .estimate-card__split_1{
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .estimate-examples_1 .estimate-card__subtitle_1{
    margin: 0 0 8px;
    color: var(--ee-slate);
    font-weight: 900;
    font-size: 14px;
  }

  .estimate-examples_1 .estimate-card__lines_1{
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 8px;
    color: var(--ee-slate);
    font-size: 15px;
  }

  .estimate-examples_1 .estimate-card__lines_1 li{
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
    border: 1px solid var(--ee-line);
    background: var(--ee-bg-soft);
    border-radius: 12px;
    padding: 10px 12px;
  }

  .estimate-examples_1 .estimate-card__lines_1 b{
    font-weight: 1000;
    color: var(--ee-slate);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
  }

  .estimate-examples_1 .estimate-card__notes_1{
    margin: 0;
    padding-left: 18px;
    color: var(--ee-muted);
    font-size: 15px;
    line-height: 1.45;
  }

  .estimate-examples_1 .estimate-card__hint_1{
    margin: 10px 0 0;
    color: var(--ee-muted);
    font-size: 15px;
    line-height: 1.45;
    background: var(--ee-cta-soft);
    border: 1px solid rgba(41,206,144,.25);
    padding: 10px 12px;
    border-radius: 12px;
  }

  .estimate-examples_1 .btn:focus-visible,
  .estimate-examples_1 .btn_1:focus-visible,
  .estimate-examples_1 [data-toggle-details]:focus-visible{
    outline: 3px solid rgba(52,131,202,.45);
    outline-offset: 2px;
    border-radius: 14px;
  }

  @media (min-width: 768px){
    .estimate-examples_1 .estimate-examples__head_1{ text-align: left; }

    .estimate-examples_1 .estimate-examples__grid_1{
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
    }

    .estimate-examples_1 .estimate-card__actions_1{
      grid-template-columns: 1fr;
      align-items: center;
    }

    .estimate-examples_1 .estimate-card__split_1{
      grid-template-columns: 1fr 1fr;
    }
  }

  @media (min-width: 1024px){
    .estimate-examples_1 .estimate-examples__grid_1{
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (max-width: 360px){
    .estimate-examples_1 .estimate-card_1{ padding: 14px; }
    .estimate-examples_1 .estimate-card__price_1{ font-size: 15px; }
  }
/* 1) Жёстко запрещаем горизонтальную прокрутку именно в этом модуле */
.estimate-examples_1{
  overflow-x: clip;
}
@supports not (overflow: clip){
  .estimate-examples_1{ overflow-x: hidden; }
}

/* 2) Снимаем дефолтные margin у figure (бывает источником overflow) */
.estimate-examples_1 .estimate-card__media_1{
  margin: 0;
}

/* 3) Grid items должны уметь сжиматься (иначе выталкивают вьюпорт) */
.estimate-examples_1 .estimate-examples__grid_1 > *,
.estimate-examples_1 .estimate-card_1{
  min-width: 0;
}

/* 4) Детерминируем верх карточки через grid (без “иногда переносится, иногда нет”) */
.estimate-examples_1 .estimate-card__top_1{
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  align-items: start;
}
.estimate-examples_1 .estimate-card__titlewrap_1{
  width: 100%;
  min-width: 0;
}
.estimate-examples_1 .estimate-card__priceWrap_1{
  width: 100%;
  text-align: left;
}
.estimate-examples_1 .estimate-card__price_1{
  display: inline-block;
  max-width: 100%;
}

/* 5) Кнопки внутри actions не должны расширять карточку */
.estimate-examples_1 .estimate-card__actions_1 .btn,
.estimate-examples_1 .estimate-card__actions_1 .btn_1{
  width: 100%;
  max-width: 100%;
}

/* На планшете/десктопе можно вернуть “цена справа” */
@media (min-width: 768px){
  .estimate-examples_1 .estimate-card__top_1{
    grid-template-columns: 1fr auto;
    gap: 12px;
  }
  .estimate-examples_1 .estimate-card__priceWrap_1{
    width: auto;
    text-align: center;
  }
}
    /* =========================================================
     Adress
     ========================================================= */
 .snNap_1, .snNap_1 *{ box-sizing:border-box; }

  .snNap_1{
    --bg:#ffffff;
    --bgSoft:#F6F7FA;
    --line:#E6E8EE;
    --text:#111827;
    --muted:#6B7280;
    --brand:#CC0000;
    --slate:#384B60;
    --radius:12px;
    --shadow: 0 10px 25px rgba(17,24,39,.08);
    --tap: 36px;
    padding: 5px;
    color:var(--text);
    font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }
@media (min-width: 1024px) {
    .snNap_1 {
        padding: 0px 32px;
    }
}
  .snNap_1__details{
    background: var(--bgSoft);
    /* border: 2px solid var(--line); */
    border-radius: calc(var(--radius) + 4px);
    overflow: hidden;
}

  .snNap_1__summary{
    list-style: none;
    cursor: pointer;
    user-select: none;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 12px;
    padding: 6px 14px;
    -webkit-tap-highlight-color: transparent;
  }
  .snNap_1__summary::-webkit-details-marker{ display:none; }
  .snNap_1__summary::marker{ content:""; }

  .snNap_1__titleBox{
    display:flex;
    align-items:center;
    gap: 10px;
    min-width: 0;
  }

  .snNap_1__badge{
    width: 36px;
    height: 36px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid rgba(41, 206, 144, .35);
    flex: 0 0 auto;
}
  .snNap_1__t{ min-width: 0; display:flex; flex-direction:column; gap: 2px; }
  .snNap_1__title{ font-weight: 800; font-size: 14px; color: var(--slate); line-height: 1.2; }
  .snNap_1__sub{ color: var(--muted); font-size: 12.2px; line-height: 1.25; }

  .snNap_1__chev{
    width: var(--tap);
    height: var(--tap);
    border-radius: 14px;
    border: 2px solid rgba(17,24,39,.08);
    background: #fff;
    display:flex;
    align-items:center;
    justify-content:center;
    flex: 0 0 auto;
  }
  .snNap_1__chevChar{
  font-size: 24px;
  line-height: 1;
  color: var(--slate);
  opacity: .95;
  transform: translateY(-1px);
  transition: transform .18s ease;
}

  .snNap_1__details[open] .snNap_1__summary{
    background: #fff;
  }
  .snNap_1__details[open] .snNap_1__chevChar{
  transform: translateY(-1px) rotate(180deg);
}

  .snNap_1__card{
    background: #fff;
    padding: 10px 0px 14px;
  }

  .snNap_1__row{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
  }

  .snNap_1__cell{
    border: 2px solid rgba(17,24,39,.06);
    border-radius: 16px;
    padding: 9px 11px;
    background: #fff;
  }

  .snNap_1__k{
    font-size: 11.3px;
    color: var(--muted);
    margin-bottom: 3px;
    font-weight: 700;
    letter-spacing: .2px;
  }

  .snNap_1__v{
    font-size: 13.2px;
    line-height: 1.32;
    color: var(--text);
    word-break: break-word;
  }

  .snNap_1__chips{
    display:flex;
    flex-wrap:wrap;
    gap: 6px;
  }

  .snNap_1__chip{
    display:inline-flex;
    align-items:center;
    padding: 6px 9px;
    border-radius: 8px;
    background: #fff;
    border: 2px solid var(--line);
    font-size: 11.4px;
    color: var(--slate);
    font-weight: 900;
    white-space: nowrap;
  }

  .snNap_1__chipLink{
    text-decoration: none;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background-color .18s ease, color .18s ease;
    will-change: transform;
  }
@media (max-width: 899.98px){
  .snNap_1__row > .snNap_1__cell:nth-child(1),
  .snNap_1__row > .snNap_1__cell:nth-child(4){
    grid-column: 1 / -1; /* занять 2 колонки */
  }
}
  @media (hover:hover){
    .snNap_1__chipLink:hover{
      transform: translateY(-1px);
      box-shadow: 0 8px 18px rgba(17,24,39,.10);
      border-color: rgba(41,206,144,.45);
      background: #fff;
      color: var(--text);
    }
    .snNap_1__chipLink:active{
      transform: translateY(0);
      box-shadow: 0 4px 10px rgba(17,24,39,.08);
    }
  }
  @media (min-width: 900px){
    .snNap_1__summary{ display:none !important; }

    .snNap_1__details{ background:#fff; }
    .snNap_1__card{ padding: 6px 0px 6px; }

    .snNap_1__row{
      grid-template-columns: 1.6fr 0.7fr 0.8fr 3.1fr;
      gap: 8px;
      align-items: stretch;
    }

    .snNap_1__cell{
      padding: 6px 12px;
      min-height: 64px;
      display:flex;
      flex-direction:column;
      justify-content:flex-start;
    }

    .snNap_1__chips{ gap: 6px; }
    .snNap_1__chip{ padding: 6px 10px; font-size: 11.5px; }
  }

  @media (min-width: 1240px){
    .snNap_1{ padding: 0 40px; }
    .snNap_1__row{
      grid-template-columns: 1.6fr 0.6fr 1fr 3fr;
    }
  }

  @media (prefers-reduced-motion: reduce){
    .snNap_1__chipLink{ transition: none; }
  }
 
 
     /* =========================================================
     Work
     ========================================================= */
 .sn-work { padding: 0 var(--pad-m_1); }
    .sn-work *{ box-sizing: border-box; }
    .sn-work :where(h2,h3,p,ol,li){ margin:0; padding:0; }
    .sn-work :where(ol){ list-style:none; }

    .sn-work__head{
      display:grid;
      gap: 8px;
      margin-bottom: 14px;
    }
    .sn-work__kicker{
      font-size: 13px;
      line-height: 1.3;
      color: var(--muted);
      font-weight: 600;
    }
    .sn-work__title{
      font-size: 22px;
      line-height: 1.15;
      letter-spacing: .01em;
      text-transform: uppercase;
      font-weight: 900;
      color: var(--slate);
    }
    .sn-work__subtitle{
      font-size: 14px;
      color: var(--muted);
      max-width: 70ch;
    }

    .sn-work__grid{
      counter-reset: snStep;
      display:grid;
      grid-template-columns: 1fr;
      gap: 12px;
      margin-top: 14px;
    }

    .sn-work__card{
      counter-increment: snStep;
      position: relative;
      border-radius: var(--r-card);
      overflow: hidden;
      min-width: 0;
      box-shadow: var(--shadow-neo);
      transform: translateZ(0);
      transition: var(--t);
background: linear-gradient(12deg, #495057, rgba(17, 24, 39, .18)), var(--sn-img);
      background-size: cover;
      background-position: center;
      border: 1px solid rgba(255,255,255,.10);
      min-height: 220px;

      display: grid;
      align-items: end;
    }

    .sn-work__card::after{
      content:"";
      position:absolute;
      inset:0;
      pointer-events:none;
    }

    .sn-work__card:hover{
      transform: translateY(-2px);
      box-shadow: 0 12px 32px rgba(17,24,39,0.10), inset 0 1px 0 rgba(255,255,255,0.12);
    }

    .sn-work__inner{
      position: relative;
      z-index: 2;
      padding: 14px;
      display: grid;
      gap: 8px;
      color: #fff;
    }
    .sn-work__chip{
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 10px 12px;
    border-radius: var(--r-btn_1);
    background: #384b60ab;
    width: fit-content;
    transition: var(--t);
    user-select: none;
}
    .sn-work__chip-num{
    width: 32px;
    height: 32px;
    border-radius: 8px;
    display: grid;
    place-items: center;
    background: rgba(255, 255, 255, .14);
    border: 2px solid rgba(41, 206, 144, .45);
    font-weight: 900;
    font-size: 18px;
    line-height: 1;
    color: #ffffff;
}
    .sn-work__chip-num::before{ content: counter(snStep); }

    .sn-work__chip-text{
    font-weight: 800;
    font-size: 13px;
    line-height: 1.1;
    letter-spacing: .01em;
    text-transform: uppercase;
    opacity: .95;
    color: #ffffff;
}

    .sn-work__h3{
      font-size: 20px;
      line-height: 1.2;
      font-weight: 800;
      margin-top: 34px;
    }

    .sn-work__desc{
    font-size: 16px;
    line-height: 1.3;
    color: rgba(255, 255, 255, .92);
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.22);
    max-width: 42ch;
}

    .sn-work :focus-visible{
      outline: 3px solid rgba(52,131,202,.55);
      outline-offset: 3px;
      border-radius: 12px;
    }

    @media (min-width: 768px){
      .sn-work{ padding: var(--section-d_1) 0; }
      .sn-work__grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
      .sn-work__card{ min-height: 240px; }
      .sn-work__h3{ margin-top: 36px; }
    }
@media (min-width: 1280px) {
    .sn-work { padding: 40px; }
}

    @media (prefers-reduced-motion: reduce){
      .sn-work, .sn-work *{ transition: none !important; }
      .sn-work__card:hover{ transform: none; }
    }
     /* =========================================================
     Work
     ========================================================= */
	   .snCookie[hidden]{display:none!important}
  .snCookie{position:fixed;inset:0;z-index:9999;display:block}
  .snCookie__backdrop{
	position: absolute;
    inset: 0;
    background: rgb(0 0 0 / 50%);
    backdrop-filter: saturate(180%) blur(4px);
}
  .snCookie__panel{
    position:absolute;left:50%;bottom:50%;transform:translateX(-50%);
    width:min(680px,calc(100% - 24px));
    background:#fff;border-radius:16px;box-shadow:0 16px 40px rgba(0,0,0,.20);
    padding:16px;display:flex;align-items:center;flex-direction: column;
    align-items: center;gap:20px
  }
  .snCookie__text{flex:1 1 auto;color:var(--slate);font-size:14px;text-align: center;line-height:1.35}
  .snCookie__link{color:#3483ca;text-decoration:underline;margin-left:6px;white-space:nowrap}
  .snCookie__btn{
    flex:0 0 auto;border:0;border-radius:14px;padding:12px 18px;
    font-weight:700;font-size:14px;cursor:pointer;background:var(--slate);color:#fff;min-width:88px
  }
  .snCookie__btn:focus{outline:3px solid rgba(52,131,202,.35);outline-offset:2px}
  @media (max-width:420px){
    .snCookie__panel{padding:14px;gap:10px}
    .snCookie__btn{padding:12px 14px;min-width:72px}
  }

