/* core.css — структурная вёрстка (общая для всех концепций) */
* {
      box-sizing: border-box;
      margin: 0;
      padding: 0
    }

    

    html {
      scroll-behavior: smooth
    }

    body {
      font-family: 'Inter', sans-serif;
      background: var(--dark);
      color: var(--w);
      overflow-x: hidden
    }

    @media(max-width:768px) {
      body {
        padding-bottom: 80px
      }
    }

    header {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 200;
      height: 68px;
      padding: 0 28px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      transition: .4s
    }

    header.s {
      background: rgba(var(--surface-rgb), .97);
      backdrop-filter: blur(24px);
      -webkit-backdrop-filter: blur(24px);
      border-bottom: 1px solid var(--bdr)
    }

    .logo {
      font-size: 18px;
      font-weight: 900;
      letter-spacing: -.5px
    }

    .logo b {
      color: var(--a)
    }

    nav {
      display: none
    }

    @media(min-width:960px) {
      nav {
        display: flex;
        align-items: center;
        gap: 2px
      }
    }

    nav a {
      color: var(--txt);
      text-decoration: none;
      font-size: 14px;
      font-weight: 500;
      padding: 8px 14px;
      border-radius: 8px;
      transition: .2s
    }

    nav a:hover {
      color: var(--w);
      background: rgba(var(--a-rgb), .05)
    }

    .hbtn {
      background: linear-gradient(135deg, var(--a2), var(--cta2));
      color: #fff;
      border: none;
      cursor: pointer;
      font: 700 14px/1 'Inter', sans-serif;
      padding: 10px 22px;
      border-radius: 10px;
      box-shadow: 0 4px 20px rgba(var(--a2-rgb), .35);
      transition: .2s
    }

    .hbtn:hover {
      transform: translateY(-1px);
      box-shadow: 0 6px 28px rgba(var(--a2-rgb), .5)
    }

    .hero {
      position: relative;
      min-height: 100vh;
      display: flex;
      align-items: center;
      overflow: hidden
    }

    .hbg {
      position: absolute;
      inset: 0;
      background: url('https://images.unsplash.com/photo-1595476108010-b4d1f102b1b1?w=1800&q=80&auto=format&fit=crop')center/cover;
      transition: transform 10s ease;
      transform: scale(1.07)
    }

    .hbg.go {
      transform: scale(1)
    }

    .hov {
      position: absolute;
      inset: 0;
      background: linear-gradient(150deg, rgba(var(--surface-rgb), .82) 0%, rgba(var(--surface-rgb), .45) 50%, rgba(var(--surface-rgb), .78) 100%)
    }

    .orb {
      position: absolute;
      border-radius: 50%;
      filter: blur(110px);
      pointer-events: none;
      will-change: transform
    }

    .o1 {
      width: 700px;
      height: 700px;
      background: radial-gradient(circle, rgba(var(--a-rgb), .42) 0%, transparent 70%);
      top: -200px;
      right: -200px;
      animation: fl1 14s ease-in-out infinite
    }

    .o2 {
      width: 500px;
      height: 500px;
      background: radial-gradient(circle, rgba(var(--a3-rgb), .32) 0%, transparent 70%);
      bottom: -150px;
      left: -100px;
      animation: fl1 11s ease-in-out infinite reverse;
      animation-delay: -5s
    }

    .o3 {
      width: 300px;
      height: 300px;
      background: radial-gradient(circle, rgba(var(--a3-rgb), .52) 0%, transparent 70%);
      top: 38%;
      right: 22%;
      animation: fl1 8s ease-in-out infinite;
      animation-delay: -3s
    }

    @keyframes fl1 {

      0%,
      100% {
        transform: translate(0, 0) scale(1)
      }

      33% {
        transform: translate(-30px, 25px) scale(1.06)
      }

      66% {
        transform: translate(25px, -20px) scale(.94)
      }
    }

    .hc {
      position: relative;
      z-index: 2;
      max-width: 1120px;
      margin: 0 auto;
      padding: 140px 24px 80px
    }

    .badge {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: rgba(var(--a-rgb), .12);
      border: 1px solid rgba(var(--a-rgb), .32);
      color: var(--a);
      font: 700 11px/1 'Inter', sans-serif;
      letter-spacing: .1em;
      text-transform: uppercase;
      padding: 8px 18px;
      border-radius: 100px;
      margin-bottom: 30px;
      animation: fdi 1s .1s both
    }

    .dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--a);
      animation: pd 2s infinite
    }

    @keyframes pd {

      0%,
      100% {
        opacity: 1;
        transform: scale(1)
      }

      50% {
        opacity: .35;
        transform: scale(1.6)
      }
    }

    h1 {
      font-size: clamp(42px, 7vw, 82px);
      font-weight: 900;
      line-height: 1.03;
      letter-spacing: -2.5px;
      margin-bottom: 26px
    }

    .hl {
      overflow: hidden;
      display: block
    }

    .hw {
      display: inline-block;
      animation: su .85s cubic-bezier(.16, 1, .3, 1) both;
      transform: translateY(110%);
      opacity: 0
    }

    .hl:nth-child(1) .hw {
      animation-delay: .2s
    }

    .hl:nth-child(2) .hw {
      animation-delay: .35s
    }

    .hl:nth-child(3) .hw {
      animation-delay: .5s
    }

    @keyframes su {
      to {
        transform: translateY(0);
        opacity: 1
      }
    }

    .gr {
      background: linear-gradient(90deg, var(--a), var(--a3), var(--a3));
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text
    }

    .hsub {
      font-size: clamp(16px, 2vw, 20px);
      color: rgba(var(--ink-rgb), .6);
      line-height: 1.72;
      max-width: 540px;
      margin-bottom: 42px;
      animation: fdi 1s .6s both
    }

    @keyframes fdi {
      from {
        opacity: 0;
        transform: translateY(12px)
      }

      to {
        opacity: 1;
        transform: none
      }
    }

    .btns {
      display: flex;
      gap: 14px;
      flex-wrap: wrap;
      animation: fdi 1s .75s both
    }

    .btp {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      background: linear-gradient(135deg, var(--a2), var(--cta2));
      color: #fff;
      font: 800 16px/1 'Inter', sans-serif;
      padding: 18px 36px;
      border-radius: 16px;
      border: none;
      cursor: pointer;
      animation: glow 3s ease-in-out infinite;
      transition: transform .2s
    }

    .btp:hover {
      transform: translateY(-3px)
    }

    @keyframes glow {

      0%,
      100% {
        box-shadow: 0 8px 32px rgba(var(--a2-rgb), .4)
      }

      50% {
        box-shadow: 0 8px 60px rgba(var(--a2-rgb), .65), 0 0 100px rgba(var(--a2-rgb), .12)
      }
    }

    .btg {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      background: rgba(var(--a-rgb), .07);
      color: rgb(var(--a2-rgb));
      font: 600 16px/1 'Inter', sans-serif;
      padding: 18px 36px;
      border-radius: 16px;
      border: 1px solid rgba(var(--a-rgb), .2);
      cursor: pointer;
      transition: .3s
    }

    .btg:hover {
      background: rgba(var(--a-rgb), .2);
      color: var(--w)
    }

    .sdown {
      position: absolute;
      bottom: 30px;
      left: 50%;
      transform: translateX(-50%);
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 7px;
      color: rgba(var(--ink-rgb), .35);
      font-size: 10px;
      letter-spacing: .14em;
      text-transform: uppercase;
      cursor: pointer;
      animation: bob 2.5s ease-in-out infinite
    }

    @keyframes bob {

      0%,
      100% {
        transform: translateX(-50%) translateY(0)
      }

      50% {
        transform: translateX(-50%) translateY(9px)
      }
    }

    .sdown-a {
      width: 18px;
      height: 18px;
      border-right: 2px solid rgba(var(--a-rgb), .5);
      border-bottom: 2px solid rgba(var(--a-rgb), .5);
      transform: rotate(45deg)
    }

    .stats {
      background: rgba(var(--surface-rgb), .9);
      backdrop-filter: blur(20px);
      border-top: 1px solid var(--bdr);
      border-bottom: 1px solid var(--bdr)
    }

    .sr {
      max-width: 1120px;
      margin: 0 auto;
      padding: 0 24px;
      display: grid;
      grid-template-columns: 1fr 1fr
    }

    @media(min-width:640px) {
      .sr {
        grid-template-columns: repeat(4, 1fr)
      }
    }

    .st {
      padding: 36px 20px;
      text-align: center;
      border-right: 1px solid var(--bdr)
    }

    .st:nth-child(2) {
      border-right: none
    }

    @media(min-width:640px) {
      .st:nth-child(2) {
        border-right: 1px solid var(--bdr)
      }

      .st:last-child {
        border-right: none
      }
    }

    .sn {
      font-size: 46px;
      font-weight: 900;
      letter-spacing: -2px;
      line-height: 1;
      background: linear-gradient(135deg, var(--a), var(--a3));
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text
    }

    .sl {
      font-size: 12px;
      color: var(--txt);
      margin-top: 8px;
      line-height: 1.55;
      font-weight: 500
    }

    .sec {
      padding: 100px 24px
    }

    .sr2 {
      max-width: 1120px;
      margin: 0 auto
    }

    .lbl {
      display: inline-block;
      font-size: 10px;
      font-weight: 800;
      letter-spacing: .14em;
      text-transform: uppercase;
      color: var(--a);
      background: rgba(var(--a-rgb), .1);
      border: 1px solid rgba(var(--a-rgb), .25);
      padding: 5px 16px;
      border-radius: 100px;
      margin-bottom: 20px
    }

    h2 {
      font-size: clamp(28px, 4vw, 50px);
      font-weight: 900;
      letter-spacing: -2px;
      line-height: 1.08;
      margin-bottom: 16px
    }

    .sub {
      color: var(--txt);
      font-size: 17px;
      line-height: 1.72;
      max-width: 580px
    }

    .pg {
      display: grid;
      grid-template-columns: 1fr;
      gap: 16px;
      margin-top: 52px
    }

    @media(min-width:640px) {
      .pg {
        grid-template-columns: 1fr 1fr
      }
    }

    .pc {
      background: var(--card);
      backdrop-filter: blur(20px);
      border: 1px solid var(--bdr);
      border-radius: 24px;
      padding: 32px;
      display: flex;
      gap: 22px;
      align-items: flex-start;
      transition: .35s;
      position: relative;
      overflow: hidden
    }

    .pc::before {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(var(--a-rgb), .04), transparent);
      opacity: 0;
      transition: .35s
    }

    .pc:hover {
      border-color: rgba(var(--a-rgb), .4);
      transform: translateY(-5px)
    }

    .pc:hover::before {
      opacity: 1
    }

    .pn {
      min-width: 46px;
      height: 46px;
      border-radius: 14px;
      background: linear-gradient(135deg, rgba(var(--a-rgb), .2), rgba(var(--a2-rgb), .08));
      color: var(--a);
      font-size: 18px;
      font-weight: 900;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      border: 1px solid rgba(var(--a-rgb), .22)
    }

    .pc p {
      color: var(--txt);
      font-size: 15px;
      line-height: 1.72;
      padding-top: 8px
    }

    .conbg {
      position: relative;
      overflow: hidden
    }

    .conbg::before {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(155deg, var(--d2), var(--dark));
      z-index: 0
    }

    .conbg::after {
      content: '';
      position: absolute;
      inset: 0;
      background: url('https://images.unsplash.com/photo-1522337660859-02fbefca4702?w=1400&q=20&auto=format&fit=crop')center/cover;
      opacity: .05;
      z-index: 0
    }

    .conbg .sr2 {
      position: relative;
      z-index: 1
    }

    .pls {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 16px;
      margin-top: 52px
    }

    @media(min-width:640px) {
      .pls {
        grid-template-columns: repeat(4, 1fr)
      }
    }

    .pi {
      background: var(--card);
      backdrop-filter: blur(20px);
      border: 1px solid rgba(var(--a-rgb), .07);
      border-radius: 26px;
      padding: 32px 22px;
      text-align: center;
      transition: .35s;
      cursor: default
    }

    .pi:hover {
      background: rgba(var(--a-rgb), .08);
      border-color: rgba(var(--a-rgb), .35);
      transform: translateY(-7px);
      box-shadow: 0 20px 50px rgba(var(--ink-rgb), .08), 0 0 40px rgba(var(--a-rgb), .1)
    }

    .pic {
      width: 58px;
      height: 58px;
      border-radius: 18px;
      background: linear-gradient(135deg, rgba(var(--a-rgb), .2), rgba(var(--a2-rgb), .08));
      border: 1px solid rgba(var(--a-rgb), .22);
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 auto 18px;
      color: var(--a)
    }

    .pi p {
      font-size: 14px;
      font-weight: 600;
      color: rgb(var(--ink-rgb));
      line-height: 1.5
    }

    .catg {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
      margin-top: 52px
    }

    @media(min-width:768px) {
      .catg {
        grid-template-columns: repeat(3, 1fr)
      }
    }

    @media(min-width:1024px) {
      .catg {
        grid-template-columns: repeat(4, 1fr)
      }
    }

    .cc {
      background: var(--card);
      backdrop-filter: blur(20px);
      border: 1px solid var(--bdr);
      border-radius: 22px;
      overflow: hidden;
      cursor: pointer;
      transition: .35s;
      transform-style: preserve-3d
    }

    .cc:hover {
      border-color: rgba(var(--a-rgb), .45);
      box-shadow: 0 24px 60px rgba(var(--ink-rgb), .12), 0 0 0 1px rgba(var(--a-rgb), .25)
    }

    .ci {
      height: 155px;
      background: center/cover no-repeat;
      position: relative
    }

    .ci::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(to top, rgba(var(--scrim-rgb), .9) 0%, rgba(var(--scrim-rgb), .4) 55%, transparent 100%)
    }

    .cb {
      padding: 18px
    }

    .ct {
      font-size: 14px;
      font-weight: 700;
      margin-bottom: 6px
    }

    .cd {
      font-size: 12px;
      color: var(--txt);
      line-height: 1.55
    }

    .clk {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      font-size: 12px;
      font-weight: 700;
      color: var(--a);
      margin-top: 12px
    }

    .clk svg {
      transition: transform .2s
    }

    .cc:hover .clk svg {
      transform: translateX(4px)
    }

    .bg2 {
      display: grid;
      grid-template-columns: 1fr;
      gap: 18px;
      margin-top: 52px
    }

    @media(min-width:640px) {
      .bg2 {
        grid-template-columns: 1fr 1fr
      }
    }

    @media(min-width:1024px) {
      .bg2 {
        grid-template-columns: repeat(3, 1fr)
      }
    }

    .bc {
      background: var(--card);
      backdrop-filter: blur(20px);
      border: 1px solid var(--bdr);
      border-radius: 26px;
      padding: 32px;
      transition: .35s
    }

    .bc:hover {
      border-color: rgba(var(--a-rgb), .4);
      transform: translateY(-5px);
      box-shadow: 0 24px 50px rgba(var(--ink-rgb), .08), 0 0 30px rgba(var(--a-rgb), .06)
    }

    .bi {
      width: 54px;
      height: 54px;
      border-radius: 18px;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 22px
    }

    .bt {
      font-size: 16px;
      font-weight: 700;
      margin-bottom: 10px
    }

    .bd {
      font-size: 14px;
      color: var(--txt);
      line-height: 1.72
    }

    .galg {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 14px;
      margin-top: 52px
    }

    @media(min-width:768px) {
      .galg {
        grid-template-columns: 2fr 1fr 1fr;
        grid-template-rows: 270px 270px
      }
    }

    .gi {
      border-radius: 22px;
      background: center/cover no-repeat;
      min-height: 190px;
      overflow: hidden;
      position: relative;
      cursor: pointer;
      transition: .4s
    }

    .gi::after {
      content: '';
      position: absolute;
      inset: 0;
      background: rgba(var(--scrim-rgb), .1);
      transition: .3s
    }

    .gi:hover {
      transform: scale(1.02)
    }

    .gi:hover::after {
      background: transparent
    }

    @media(min-width:768px) {
      .gi.big {
        grid-row: span 2
      }
    }

    .jss {
      display: flex;
      flex-direction: column;
      gap: 24px;
      margin-top: 52px;
      position: relative
    }

    @media(min-width:768px) {
      .jss {
        flex-direction: row;
        gap: 0
      }
    }

    .jline {
      display: none
    }

    @media(min-width:768px) {
      .jline {
        display: block;
        position: absolute;
        top: 26px;
        left: 30px;
        right: 30px;
        height: 2px;
        background: linear-gradient(90deg, var(--a), rgba(var(--a-rgb), .25));
        border-radius: 1px;
        z-index: 0
      }
    }

    .js {
      display: flex;
      gap: 18px;
      align-items: flex-start;
      flex: 1;
      position: relative;
      z-index: 1
    }

    @media(min-width:768px) {
      .js {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 16px;
        padding: 0 10px
      }
    }

    .jn {
      min-width: 52px;
      height: 52px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--a), var(--cta2));
      color: #fff;
      font-size: 18px;
      font-weight: 900;
      display: flex;
      align-items: center;
      justify-content: center;
      box-shadow: 0 0 0 8px rgba(var(--a-rgb), .12), 0 4px 20px rgba(var(--a-rgb), .35);
      flex-shrink: 0
    }

    .jt {
      font-size: 13px;
      color: var(--txt);
      line-height: 1.62;
      max-width: 155px;
      font-weight: 500;
      padding-top: 4px
    }

    @media(min-width:768px) {
      .jt {
        padding-top: 0
      }
    }

    .cond {
      background: var(--card);
      backdrop-filter: blur(20px);
      border: 1px solid var(--bdr);
      border-radius: 26px;
      overflow: hidden;
      max-width: 560px;
      margin-top: 44px
    }

    .cr {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 20px 28px;
      border-bottom: 1px solid var(--bdr)
    }

    .cr:last-child {
      border-bottom: none;
      background: rgba(var(--a-rgb), .04)
    }

    .ck {
      font-size: 14px;
      color: var(--txt)
    }

    .cv {
      font-size: 14px;
      font-weight: 600
    }

    .cbn {
      font-size: 13px;
      font-weight: 700;
      color: var(--a);
      background: none;
      border: none;
      cursor: pointer;
      display: flex;
      align-items: center;
      gap: 5px;
      font-family: inherit
    }

    .fl {
      display: flex;
      flex-direction: column;
      gap: 10px;
      margin: 52px auto 0;
      max-width: 820px
    }

    .fi {
      background: var(--card);
      backdrop-filter: blur(20px);
      border: 1px solid var(--bdr);
      border-radius: 20px;
      overflow: hidden;
      transition: .35s
    }

    .fi.on {
      border-color: rgba(var(--a-rgb), .4);
      box-shadow: 0 0 40px rgba(var(--a-rgb), .06)
    }

    .fq {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 24px 28px;
      cursor: pointer;
      gap: 18px;
      user-select: none
    }

    .fqt {
      font-size: 15px;
      font-weight: 600;
      line-height: 1.5
    }

    .fch {
      min-width: 32px;
      height: 32px;
      border-radius: 10px;
      background: rgba(var(--a-rgb), .07);
      display: flex;
      align-items: center;
      justify-content: center;
      transition: .35s;
      flex-shrink: 0
    }

    .fi.on .fch {
      background: rgba(var(--a-rgb), .18);
      transform: rotate(180deg);
      color: var(--a)
    }

    .fa {
      max-height: 0;
      overflow: hidden;
      transition: max-height .4s ease
    }

    .fa.on {
      max-height: 320px
    }

    .fai {
      padding: 0 28px 24px;
      font-size: 14px;
      color: var(--txt);
      line-height: 1.75
    }

    .ctbg {
      position: relative;
      overflow: hidden
    }

    .ctbg::before {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(155deg, var(--d2), var(--dark));
      z-index: 0
    }

    .ctbg::after {
      content: '';
      position: absolute;
      inset: 0;
      background: url('https://images.unsplash.com/photo-1595476108010-b4d1f102b1b1?w=1400&q=20&auto=format&fit=crop')center/cover;
      opacity: .04;
      z-index: 0
    }

    .ctbg .sr2 {
      position: relative;
      z-index: 1
    }

    .cg2 {
      display: grid;
      gap: 60px;
      grid-template-columns: 1fr
    }

    @media(min-width:920px) {
      .cg2 {
        grid-template-columns: 1fr 1fr;
        align-items: start
      }
    }

    .ci2 h2 {
      font-size: clamp(28px, 4vw, 46px);
      font-weight: 900;
      letter-spacing: -2px;
      margin-bottom: 16px
    }

    .ci2 p {
      color: var(--txt);
      font-size: 16px;
      line-height: 1.75;
      margin-bottom: 28px
    }

    .ctd {
      display: flex;
      align-items: center;
      gap: 16px;
      margin-bottom: 16px;
      color: rgba(var(--ink-rgb), .65);
      font-size: 15px;
      font-weight: 500
    }

    .ctd svg {
      color: var(--a);
      flex-shrink: 0
    }

    .fc2 {
      background: var(--card);
      backdrop-filter: blur(28px);
      border: 1px solid rgba(var(--a-rgb), .14);
      border-radius: 30px;
      padding: 40px
    }

    .ftabs {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 6px;
      background: rgba(var(--ink-rgb), .05);
      border-radius: 14px;
      padding: 6px;
      margin-bottom: 28px
    }

    .ftab {
      padding: 12px;
      text-align: center;
      font-size: 14px;
      font-weight: 600;
      border-radius: 10px;
      cursor: pointer;
      transition: .3s;
      color: rgba(var(--ink-rgb), .4);
      background: none;
      border: none;
      font-family: inherit
    }

    .ftab.on {
      background: linear-gradient(135deg, var(--a2), var(--cta2));
      color: #fff;
      box-shadow: 0 4px 18px rgba(var(--a2-rgb), .35)
    }

    .inp {
      width: 100%;
      background: rgba(var(--a-rgb), .05);
      border: 1px solid rgba(var(--a-rgb), .14);
      color: #fff;
      font: 500 15px/1 'Inter', sans-serif;
      padding: 18px 20px;
      border-radius: 16px;
      outline: none;
      transition: .3s;
      margin-bottom: 16px
    }

    .inp:focus {
      border-color: rgba(var(--a-rgb), .6);
      background: rgba(var(--a-rgb), .14);
      box-shadow: 0 0 0 4px rgba(var(--a-rgb), .1)
    }

    .inp::placeholder {
      color: rgba(var(--ink-rgb), .3)
    }

    .fcon {
      display: flex;
      align-items: flex-start;
      gap: 12px;
      margin-bottom: 20px;
      cursor: pointer
    }

    .fcon input {
      margin-top: 3px;
      accent-color: var(--a);
      width: 16px;
      height: 16px;
      flex-shrink: 0
    }

    .fcon span {
      font-size: 12px;
      color: rgba(var(--ink-rgb), .45);
      line-height: 1.65
    }

    .ferr {
      font-size: 13px;
      color: #f87171;
      margin-bottom: 12px;
      display: none
    }

    .fsub {
      width: 100%;
      padding: 18px;
      background: linear-gradient(135deg, var(--a2), var(--cta2));
      color: #fff;
      font: 800 16px/1 'Inter', sans-serif;
      border: none;
      border-radius: 16px;
      cursor: pointer;
      box-shadow: 0 8px 28px rgba(var(--a2-rgb), .35);
      transition: .3s;
      animation: glow 3s infinite
    }

    .fsub:hover {
      transform: translateY(-2px);
      box-shadow: 0 14px 40px rgba(var(--a2-rgb), .5)
    }

    .sbox {
      text-align: center;
      display: none;
      padding: 28px 0
    }

    .sbox h3 {
      font-size: 22px;
      font-weight: 700;
      margin-bottom: 10px
    }

    .sbox p {
      color: var(--txt);
      font-size: 14px;
      margin-bottom: 24px
    }

    .wb {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: #25d366;
      color: #fff;
      font-size: 14px;
      font-weight: 700;
      padding: 13px 26px;
      border-radius: 14px;
      text-decoration: none;
      transition: .2s
    }

    .wb:hover {
      transform: translateY(-1px)
    }

    .modal {
      position: fixed;
      inset: 0;
      z-index: 500;
      display: none;
      align-items: flex-end;
      justify-content: center
    }

    @media(min-width:640px) {
      .modal {
        align-items: center;
        padding: 24px
      }
    }

    .modal.on {
      display: flex
    }

    .mbg {
      position: absolute;
      inset: 0;
      background: rgba(var(--ink-rgb), .6);
      backdrop-filter: blur(10px)
    }

    .mc {
      position: relative;
      z-index: 1;
      width: 100%;
      max-width: 450px;
      background: var(--card);
      border: 1px solid rgba(180, 80, 220, .2);
      border-radius: 28px 28px 0 0;
      overflow: hidden
    }

    @media(min-width:640px) {
      .mc {
        border-radius: 28px;
        animation: pop .3s cubic-bezier(.16, 1, .3, 1)
      }
    }

    @keyframes pop {
      from {
        transform: scale(.93);
        opacity: 0
      }

      to {
        transform: scale(1);
        opacity: 1
      }
    }

    .mh {
      padding: 28px;
      border-bottom: 1px solid rgba(180, 80, 220, .15);
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      background: linear-gradient(135deg, rgba(var(--a-rgb), .1), transparent)
    }

    .mht {
      font-size: 20px;
      font-weight: 900;
      letter-spacing: -.5px
    }

    .mhs {
      font-size: 13px;
      color: var(--txt);
      margin-top: 4px
    }

    .mx {
      background: rgba(var(--a-rgb), .07);
      border: none;
      color: rgba(var(--ink-rgb), .4);
      width: 34px;
      height: 34px;
      border-radius: 10px;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: .2s;
      flex-shrink: 0
    }

    .mx:hover {
      background: rgba(var(--a-rgb), .14);
      color: var(--w)
    }

    .mb {
      padding: 28px
    }

    .flwa {
      position: fixed;
      bottom: 98px;
      right: 20px;
      z-index: 300;
      width: 56px;
      height: 56px;
      border-radius: 50%;
      background: #25d366;
      box-shadow: 0 4px 24px rgba(37, 211, 102, .5);
      display: flex;
      align-items: center;
      justify-content: center;
      text-decoration: none;
      transition: .3s;
      animation: wap 4s ease infinite
    }

    .flwa:hover {
      transform: scale(1.14)
    }

    @media(min-width:768px) {
      .flwa {
        bottom: 32px
      }
    }

    @keyframes wap {

      0%,
      100% {
        box-shadow: 0 4px 24px rgba(37, 211, 102, .5)
      }

      50% {
        box-shadow: 0 4px 44px rgba(37, 211, 102, .7), 0 0 0 10px rgba(37, 211, 102, .1)
      }
    }

    .stk {
      position: fixed;
      bottom: 0;
      left: 0;
      right: 0;
      z-index: 300;
      padding: 12px 16px 16px;
      background: rgba(var(--surface-rgb), .98);
      backdrop-filter: blur(20px);
      border-top: 1px solid var(--bdr);
      display: flex;
      gap: 10px
    }

    @media(min-width:768px) {
      .stk {
        display: none
      }
    }

    .rv {
      opacity: 0;
      transform: translateY(36px);
      transition: opacity .75s ease, transform .75s ease
    }

    .rv.vs {
      opacity: 1;
      transform: none
    }

    .rv.d1 {
      transition-delay: .12s
    }

    .rv.d2 {
      transition-delay: .24s
    }

    .rv.d3 {
      transition-delay: .36s
    }

    .rv.d4 {
      transition-delay: .48s
    }

    footer {
      background: rgba(var(--ink-rgb), .12);
      border-top: 1px solid var(--bdr);
      padding: 30px 24px;
      text-align: center;
      font-size: 13px;
      color: rgba(var(--ink-rgb), .35)
    }

    footer a {
      color: rgba(var(--ink-rgb), .5);
      text-decoration: none;
      margin-left: 18px
    }

    /* ═══════════════════════════════════════
       PREMIUM DESIGN LAYER — БЬЮТИЖАЙЛЫ
    ═══════════════════════════════════════ */

    h1,h2,.sn{font-family:'Unbounded','Inter',sans-serif}
    .logo{font-family:'Unbounded',sans-serif;letter-spacing:-1px}

    body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.028;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

    .sec:not(.conbg):not(.ctbg){position:relative}
    .sec:not(.conbg):not(.ctbg)::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(var(--ink-rgb),.03) 1px,transparent 1px),linear-gradient(90deg,rgba(var(--ink-rgb),.03) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0}
    .sec:not(.conbg):not(.ctbg) .sr2{position:relative;z-index:1}

    @media(min-width:1024px){
      .bg2{grid-template-columns:repeat(6,1fr);align-items:start}
      .bg2 .bc:nth-child(1){grid-column:span 4}
      .bg2 .bc:nth-child(2){grid-column:span 2}
      .bg2 .bc:nth-child(3){grid-column:span 2}
      .bg2 .bc:nth-child(4){grid-column:span 4}
      .bg2 .bc:nth-child(5){grid-column:span 3}
      .bg2 .bc:nth-child(6){grid-column:span 3}
    }

    .bc{transition:.4s cubic-bezier(.16,1,.3,1)}
    .bc:hover{transform:translateY(-9px);box-shadow:0 32px 64px rgba(var(--ink-rgb),.12),0 0 40px rgba(var(--a-rgb),.12)}

    .btp,.fsub,.hbtn{position:relative;overflow:hidden}
    .btp::after,.fsub::after,.hbtn::after{content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(var(--ink-rgb),.3),transparent);transform:skewX(-20deg);transition:.65s ease;pointer-events:none}
    .btp:hover::after,.fsub:hover::after,.hbtn:hover::after{left:160%}

    .gi::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(var(--scrim-rgb),.78) 0%,transparent 65%);opacity:0;transition:.38s;z-index:1;pointer-events:none}
    .gi:hover::before{opacity:1}

    .jss .js{opacity:0;transform:translateY(22px);transition:.62s cubic-bezier(.16,1,.3,1)}
    .jss .js.jlit{opacity:1;transform:none}

    footer{position:relative}
    footer::before{content:'';position:absolute;top:0;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,rgba(var(--a-rgb),.7),transparent)}

    nav a{position:relative}
    nav a::after{content:'';position:absolute;bottom:2px;left:50%;right:50%;height:1.5px;background:var(--a);transition:.28s cubic-bezier(.16,1,.3,1)}
    nav a:hover::after{left:14px;right:14px}

    .badge{box-shadow:0 0 28px rgba(var(--a-rgb),.14),inset 0 0 20px rgba(var(--a-rgb),.04)}

    @keyframes climit-glow{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.55)}50%{box-shadow:0 0 0 10px rgba(239,68,68,0)}}
    .climit{animation:climit-glow 2.2s ease-in-out infinite}

    .hov{background:linear-gradient(150deg,rgba(var(--surface-rgb),.85) 0%,rgba(var(--surface-rgb),.4) 45%,rgba(var(--surface-rgb),.8) 100%)}
    .o1{filter:blur(80px);opacity:.9}
    .o2{filter:blur(100px)}
    .o3{filter:blur(68px)}

    .cc{transition:.38s cubic-bezier(.16,1,.3,1)}
    .cc:hover{transform:translateY(-8px)}

    @media(prefers-reduced-motion:reduce){
      *,.rv,.hw,.orb,.dot,body::after{animation:none!important;transition-duration:.01ms!important}
      .rv,.hw{opacity:1;transform:none}
      .jss .js{opacity:1;transform:none}
    }

/* ── Batch 2 компоненты: мета в «Планах», блок карты ── */
.pmeta{display:block;margin-top:5px;font-size:12px;font-weight:500;opacity:.6}
.mapb{min-height:320px;border-radius:24px;border:1px solid var(--bdr);background:var(--card);display:flex;align-items:center;justify-content:center;overflow:hidden}
.mapb iframe{width:100%;height:100%;min-height:320px;border:0;display:block}
.mapb-ph{padding:32px;text-align:center;font-size:14px;line-height:1.6;color:var(--txt);max-width:340px}

/* ═══ Batch 5: a11y (фокус, skip-link) + lightbox ═══ */
/* Видимый фокус для клавиатуры (поля ввода сохраняют собственное кольцо) */
:focus-visible{outline:2px solid var(--a);outline-offset:3px}
.inp:focus-visible{outline:none}
/* Skip-link — первый таб для перехода к контенту */
.skip{position:fixed;top:-80px;left:12px;z-index:1000;background:var(--a2);color:#fff;font-weight:700;font-size:14px;padding:12px 20px;border-radius:12px;text-decoration:none;transition:top .2s;box-shadow:0 6px 24px rgba(var(--ink-rgb),.2)}
.skip:focus{top:12px}
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
/* FAQ-вопрос и плитка галереи теперь <button> — сбрасываем UA-стили */
.fq{width:100%;background:none;border:none;color:inherit;font-family:inherit;text-align:left}
.gi{border:0;padding:0;font:inherit}

/* Lightbox */
.lbx{position:fixed;inset:0;z-index:600;display:none;align-items:center;justify-content:center;gap:8px;padding:24px;background:rgba(var(--scrim-rgb),.94);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.lbx.on{display:flex}
.lbx-fig{margin:0;display:flex;flex-direction:column;align-items:center;gap:14px;max-width:92vw}
.lbx-img{max-width:88vw;max-height:80vh;border-radius:16px;box-shadow:0 30px 90px rgba(0,0,0,.55);object-fit:contain}
.lbx-cap{color:rgba(251,246,242,.82);font-size:14px;text-align:center;max-width:600px;line-height:1.5}
.lbx-x{position:absolute;top:18px;right:18px;width:44px;height:44px;border-radius:12px;border:none;cursor:pointer;background:rgba(251,246,242,.12);color:#fbf6f2;display:flex;align-items:center;justify-content:center;transition:.2s}
.lbx-x:hover{background:rgba(251,246,242,.24)}
.lbx-nav{width:48px;height:48px;min-width:48px;border-radius:50%;border:none;cursor:pointer;background:rgba(251,246,242,.12);color:#fbf6f2;display:flex;align-items:center;justify-content:center;transition:.2s;flex-shrink:0}
.lbx-nav:hover{background:rgba(251,246,242,.24)}
@media(max-width:640px){.lbx-nav{position:absolute;bottom:24px}.lbx-prev{left:26%}.lbx-next{right:26%}}
