@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@500;600;700;800;900&family=Oswald:wght@500;600;700&display=swap');

    .kxr-map{
      --neon:#d9f719;
      --red:#e43a22;
      --gold:#d8a246;
      font-family:'Montserrat',system-ui,sans-serif;
      background:
        radial-gradient(circle at 12% 18%, rgba(217,247,25,.08), transparent 25%),
        radial-gradient(circle at 88% 62%, rgba(228,58,34,.08), transparent 28%),
        linear-gradient(180deg,#000 0%,#050608 44%,#000 100%);
      color:#fff;
      padding:38px 14px 50px;
      overflow:hidden;
      position:relative;
    }

    .kxr-map *{ box-sizing:border-box; }
    .kxr-wrap{ width:min(1200px,100%); margin:0 auto; position:relative; z-index:2; }

    .kxr-title{
      font-family:'Oswald',sans-serif;
      text-align:center;
      text-transform:uppercase;
      font-size:clamp(34px,5vw,60px);
      line-height:.92;
      letter-spacing:.035em;
      margin:0 0 9px;
      text-shadow:0 0 24px rgba(217,247,25,.12);
      white-space:nowrap;
      position:relative;
      z-index:4;
      color:#fff;
    }

    .kxr-title-accent{ color:var(--neon); }
    .kxr-title-mobile{ display:none; }
    .kxr-title-desktop{ display:inline; }

    .kxr-subtitle{
      text-align:center;
      margin:0 auto 24px;
      color:rgba(255,255,255,.54);
      font-size:clamp(13px,1.5vw,16px);
      font-weight:650;
      line-height:1.35;
    }

    .kxr-track{ position:relative; height:430px; max-width:1160px; margin:auto 0; }
    @media(min-width:761px){ .kxr-track{ margin:70px auto 0; } }

    .kxr-path{
      position:absolute;
      inset:-70px 0 0;
      width:100%;
      height:calc(100% + 70px);
      z-index:0;
      pointer-events:none;
    }

    .kxr-path--mobile{ display:none; }

    .kxr-path .main-line{
      fill:none;
      stroke:rgba(255,255,255,.23);
      stroke-width:3;
      stroke-linecap:round;
      stroke-dasharray:9 13;
    }

    .kxr-path .glow-line{
      fill:none;
      stroke:rgba(217,247,25,.20);
      stroke-width:9;
      stroke-linecap:round;
      stroke-dasharray:1 18;
      filter:blur(3px);
      opacity:.72;
    }

    .kxr-card{
      position:absolute;
      width:350px;
      padding:14px 17px 14px;
      border-radius:21px;
      background:linear-gradient(135deg,rgba(255,255,255,.09),rgba(255,255,255,.025)), rgba(0,0,0,.61);
      border:1px solid var(--line);
      box-shadow:0 0 31px var(--soft), inset 0 0 20px rgba(255,255,255,.035);
      backdrop-filter:blur(10px);
      -webkit-backdrop-filter:blur(10px);
      z-index:2;
      overflow:hidden;
    }

    .kxr-card:after{
      content:"";
      position:absolute;
      right:-34px;
      top:50%;
      width:104px;
      height:104px;
      transform:translateY(-50%);
      border:1px solid var(--line);
      border-radius:50%;
      opacity:.18;
      pointer-events:none;
    }

    .kxr-card h3{
      font-family:'Oswald',sans-serif;
      text-transform:uppercase;
      font-size:25px;
      line-height:.98;
      letter-spacing:.04em;
      margin:0 0 6px;
      color:#fff;
      position:relative;
      z-index:2;
    }

    .kxr-card p{
      margin:0;
      color:rgba(255,255,255,.68);
      font-size:12.8px;
      line-height:1.24;
      font-weight:650;
      position:relative;
      z-index:2;
    }

    .kxr-solved{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      min-height:23px;
      margin-top:9px;
      padding:5px 10px;
      border-radius:999px;
      color:var(--accent);
      background:rgba(0,0,0,.48);
      border:1px solid var(--line);
      font-size:8px;
      line-height:1;
      font-weight:1000;
      letter-spacing:.13em;
      text-transform:uppercase;
      box-shadow:0 0 16px var(--soft);
      position:relative;
      z-index:2;
      white-space:nowrap;
    }

    .kxr-card--free{ --accent:#ffffff; --soft:rgba(255,255,255,.11); --line:rgba(255,255,255,.32); left:0; top:2px; }
    .kxr-card--build{ --accent:var(--neon); --soft:rgba(217,247,25,.22); --line:rgba(217,247,25,.62); right:300px; top:92px; }
    .kxr-card--perform{ --accent:var(--red); --soft:rgba(228,58,34,.22); --line:rgba(228,58,34,.62); right:96px; bottom:42px; }
    .kxr-card--coach{ --accent:var(--gold); --soft:rgba(216,162,70,.22); --line:rgba(216,162,70,.62); left:20px; bottom:-4px; }

    .kxr-roadmap-cta{ text-align:center; margin:44px auto 0; max-width:1040px; }
    .kxr-roadmap-cta > p{ margin:0 0 16px; color:rgba(255,255,255,.72); font-size:18px; line-height:1.4; font-weight:750; }

    .kxr-btn{
      appearance:none;
      border:1px solid rgba(217,247,25,.72);
      background:var(--neon);
      color:#050608;
      border-radius:999px;
      padding:18px 38px;
      font-size:15px;
      font-weight:950;
      letter-spacing:.09em;
      text-transform:uppercase;
      cursor:pointer;
      box-shadow:0 0 26px rgba(217,247,25,.25);
      transition:transform .18s ease, box-shadow .18s ease;
      text-align:center;
    }

    .kxr-btn:hover{ transform:translateY(-1px); box-shadow:0 0 38px rgba(217,247,25,.35); }

    .kxr-receive{
      width:min(980px,100%);
      margin:58px auto 0;
      text-align:center;
    }

    .kxr-receive h3,
    .kxr-faq h3{
      font-family:'Oswald',sans-serif;
      text-transform:uppercase;
      font-size:28px;
      line-height:1;
      letter-spacing:.04em;
      margin:0 0 14px;
      color:var(--neon);
      text-align:center;
    }

    .kxr-receive ul{
      list-style:none;
      display:grid;
      grid-template-columns:repeat(6,1fr);
      gap:14px;
      margin:0;
      padding:0;
    }

    .kxr-receive li{
      min-height:88px;
      display:flex;
      align-items:center;
      justify-content:center;
      color:rgba(255,255,255,.88);
      font-size:14px;
      line-height:1.32;
      font-weight:900;
      padding:18px 18px 18px 44px;
      position:relative;
      border-radius:18px;
      border:1px solid rgba(217,247,25,.34);
      background:linear-gradient(135deg,rgba(255,255,255,.095),rgba(255,255,255,.026)),rgba(12,14,14,.62);
      box-shadow:0 16px 34px rgba(0,0,0,.34), 0 0 24px rgba(217,247,25,.13), inset 0 0 24px rgba(255,255,255,.035);
      text-align:center;
      text-shadow:0 0 13px rgba(217,247,25,.13), 0 2px 8px rgba(0,0,0,.62);
    }

    .kxr-receive li:before{
      content:"";
      position:absolute;
      left:20px;
      top:50%;
      width:8px;
      height:14px;
      border-right:2px solid var(--neon);
      border-bottom:2px solid var(--neon);
      transform:translateY(-56%) rotate(45deg);
      filter:drop-shadow(0 0 7px rgba(217,247,25,.5));
    }

    .kxr-receive li:nth-child(-n+3){ grid-column:span 2; }
    .kxr-receive li:nth-child(n+4){ grid-column:span 3; }

    .kxr-form{
      display:none;
      width:min(760px,100%);
      margin:48px auto 0;
      padding:20px;
      border-radius:24px;
      background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.04)),rgba(18,20,20,.9);
      border:1px solid rgba(217,247,25,.34);
      box-shadow:0 24px 60px rgba(0,0,0,.42), 0 0 34px rgba(217,247,25,.14), inset 0 0 24px rgba(255,255,255,.04);
      text-align:left;
    }

    .kxr-form.is-open{ display:block; }

    .kxr-faq{
      width:min(720px,100%);
      margin:64px auto 0;
      text-align:left;
    }

    .kxr-faq-list{
      display:grid;
      gap:11px;
    }

    .kxr-faq-item{
      border-radius:18px;
      border:1px solid rgba(217,247,25,.46);
      background:linear-gradient(135deg,rgba(255,255,255,.07),rgba(255,255,255,.025)),rgba(0,0,0,.44);
      box-shadow:0 0 20px rgba(217,247,25,.10), inset 0 0 18px rgba(255,255,255,.03);
      overflow:hidden;
    }

    .kxr-faq-question{
      appearance:none;
      width:100%;
      border:0;
      background:transparent;
      color:#fff;
      font-family:'Oswald',sans-serif;
      text-transform:uppercase;
      font-size:21px;
      line-height:1.05;
      letter-spacing:.035em;
      text-align:left;
      padding:16px 42px 16px 18px;
      cursor:pointer;
      position:relative;
    }

    .kxr-faq-question:after{
      content:"+";
      position:absolute;
      right:18px;
      top:50%;
      transform:translateY(-50%);
      color:var(--neon);
      font-family:'Montserrat',system-ui,sans-serif;
      font-size:24px;
      line-height:1;
      font-weight:900;
    }

    .kxr-faq-item.is-open .kxr-faq-question:after{
      content:"-";
    }

    .kxr-faq-answer{
      display:none;
      color:rgba(255,255,255,.62);
      font-size:13.5px;
      line-height:1.48;
      font-weight:650;
      padding:0 18px 16px;
    }

    .kxr-faq-item.is-open .kxr-faq-answer{
      display:block;
    }

    .kxr-bottom-cta{
      margin-top:58px;
    }

    .kxr-map .kx-form-intro{ text-align:center; margin:0 auto 18px; }
    .kxr-map .kx-form-intro p{
      margin:0;
      color:rgba(255,255,255,.58);
      font-size:13px;
      line-height:1.4;
      font-weight:750;
      letter-spacing:.02em;
    }

    .kxr-map .kx-progress{ height:7px; background:rgba(255,255,255,.09); border-radius:999px; overflow:hidden; margin-bottom:22px; }
    .kxr-map .kx-progress-bar{ height:100%; width:0%; background:var(--neon); border-radius:999px; box-shadow:0 0 18px rgba(217,247,25,.32); transition:width .25s ease; }

    .kxr-map .kx-step{ display:none; animation:kxFade .22s ease; }
    .kxr-map .kx-step.is-active{ display:block; }
    @keyframes kxFade{ from{opacity:0; transform:translateY(6px);} to{opacity:1; transform:translateY(0);} }

    .kxr-map .kx-step-count{ color:rgba(255,255,255,.42); font-size:11px; font-weight:900; letter-spacing:.12em; text-transform:uppercase; margin-bottom:12px; }
    .kxr-map .kx-step h3{ font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:30px; line-height:1; margin:0 0 18px; letter-spacing:.035em; color:#fff; }
    .kxr-map .kx-helper{ margin:-8px 0 16px; color:rgba(255,255,255,.48); font-size:13px; font-weight:650; }

    .kxr-map .kx-options{ display:grid; gap:10px; }

    .kxr-map .kx-option{
      display:flex;
      align-items:center;
      gap:12px;
      min-height:56px;
      padding:13px 15px;
      border-radius:17px;
      border:1px solid rgba(255,255,255,.13);
      background:rgba(255,255,255,.045);
      color:rgba(255,255,255,.78);
      font-size:15px;
      font-weight:800;
      cursor:pointer;
      transition:border-color .18s ease, background .18s ease, transform .18s ease;
    }

    .kxr-map .kx-option:hover{ transform:translateY(-1px); border-color:rgba(217,247,25,.42); background:rgba(217,247,25,.055); }
    .kxr-map .kx-option input{ position:absolute; opacity:0; pointer-events:none; }
    .kxr-map .kx-option-text{ flex:1; }

    .kxr-map .kx-radio-dot{
      width:20px;
      height:20px;
      border-radius:50%;
      border:2px solid rgba(255,255,255,.32);
      flex:0 0 auto;
      position:relative;
    }

    .kxr-map .kx-option input:checked + .kx-radio-dot{ border-color:var(--neon); box-shadow:0 0 18px rgba(217,247,25,.24); }
    .kxr-map .kx-option input:checked + .kx-radio-dot:after{ content:""; position:absolute; inset:4px; border-radius:50%; background:var(--neon); }
    .kxr-map .kx-option:has(input:checked){ border-color:rgba(217,247,25,.58); background:rgba(217,247,25,.08); color:#fff; }

    .kxr-map .kx-field{ display:block; margin-bottom:14px; color:rgba(255,255,255,.72); font-size:13px; font-weight:850; letter-spacing:.02em; }

    .kxr-map .kx-field input,
    .kxr-map .kx-field select{
      width:100%;
      min-height:54px;
      padding:14px 15px;
      border-radius:16px;
      border:1px solid rgba(255,255,255,.13);
      background:rgba(255,255,255,.07);
      color:#fff;
      font-size:16px;
      font-weight:700;
      margin-top:8px;
      outline:none;
    }

    .kxr-map .kx-field input::placeholder{ color:rgba(255,255,255,.34); }
    .kxr-map .kx-field input:focus, .kxr-map .kx-field select:focus{ border-color:rgba(217,247,25,.62); box-shadow:0 0 0 3px rgba(217,247,25,.10); }
    .kxr-map .kx-field select option{ color:#000; }

    .kxr-map .kx-nav{ display:flex; justify-content:center; align-items:center; gap:12px; margin-top:24px; }

    .kxr-map .kx-nav .kx-btn-form{
      appearance:none;
      border-radius:999px;
      padding:13px 22px;
      font-size:11px;
      font-weight:950;
      letter-spacing:.09em;
      text-transform:uppercase;
      cursor:pointer;
      transition:transform .18s ease, opacity .18s ease, box-shadow .18s ease;
      min-width:118px;
      width:auto;
      text-align:center;
      display:inline-flex;
      justify-content:center;
      align-items:center;
    }

    .kxr-map .kx-btn-form:hover{ transform:translateY(-1px); }
    .kxr-map .kx-btn-next, .kxr-map .kx-btn-submit{ border:1px solid rgba(217,247,25,.72); background:var(--neon); color:#050608; box-shadow:0 0 22px rgba(217,247,25,.22); }
    .kxr-map .kx-btn-back{ background:rgba(255,255,255,.08); color:rgba(255,255,255,.72); border:1px solid rgba(255,255,255,.14); }
    .kxr-map .kx-error{ display:none; margin-top:14px; color:#ff796d; font-size:13px; font-weight:750; text-align:center; }

    @media(max-width:760px){
      .kxr-map{ padding:42px 8px 70px; }
      .kxr-title{ font-size:31px; margin-bottom:8px; white-space:nowrap; }
      .kxr-title-desktop{ display:none; }
      .kxr-title-mobile{ display:inline; }
      .kxr-subtitle{ font-size:12.5px; margin-bottom:34px; }
      .kxr-track{ width:360px; max-width:100%; height:470px; }
      .kxr-path{ inset:0; height:100%; }
      .kxr-path--desktop{ display:none; }
      .kxr-path--mobile{ display:block; }
      .kxr-path .main-line{ stroke-width:2.2; stroke-dasharray:7 10; opacity:.76; }
      .kxr-path .glow-line{ stroke-width:6; opacity:.5; }
      .kxr-card{ width:202px; border-radius:16px; padding:9px 10px 9px; }
      .kxr-card:after{ width:70px; height:70px; right:-28px; opacity:.16; }
      .kxr-card h3{ font-size:16.5px; margin-bottom:4px; }
      .kxr-card p{ font-size:9.7px; line-height:1.18; }
      .kxr-solved{ min-height:18px; margin-top:6px; padding:4px 7px; font-size:6.2px; }
      .kxr-card--free{ left:0; top:0; }
      .kxr-card--build{ right:0; top:116px; }
      .kxr-card--perform{ left:0; bottom:auto; top:238px; }
      .kxr-card--coach{ right:0; bottom:auto; left:auto; top:360px; }
      .kxr-roadmap-cta{ margin-top:48px; padding:0 8px; }
      .kxr-roadmap-cta > p{ font-size:14px; margin-bottom:32px; }
      .kxr-btn{ padding:15px 28px; font-size:13px; }
      .kxr-receive{ margin-top:112px; }
      .kxr-receive h3,
      .kxr-faq h3{ font-size:25px; }
      .kxr-receive ul{ grid-template-columns:1fr; gap:12px; }
      .kxr-receive li{
        grid-column:1 / -1 !important;
        min-height:64px;
        justify-content:flex-start;
        text-align:left;
        font-size:13.5px;
        padding:15px 16px 15px 42px;
      }
      .kxr-receive li:before{ left:18px; }
      .kxr-form{ margin-top:74px; padding:14px; border-radius:18px; }
      .kxr-faq{ margin-top:104px; }
      .kxr-faq-list{ gap:22px; }
      .kxr-faq-question{ font-size:18px; padding:14px 40px 14px 15px; }
      .kxr-faq-answer{ font-size:13px; padding:0 15px 15px; }
      .kxr-map .kx-step h3{ font-size:24px; }
      .kxr-map .kx-option{ min-height:54px; font-size:14px; }
      .kxr-map .kx-nav{ flex-direction:row; justify-content:center; }
      .kxr-map .kx-nav .kx-btn-form{ width:auto; min-width:112px; padding:12px 18px; }
      .kxr-bottom-cta{ margin-top:96px; }
    }

    @media(max-width:380px){
      .kxr-track{ width:340px; height:462px; }
      .kxr-card{ width:196px; }
      .kxr-map .kx-nav .kx-btn-form{ min-width:104px; padding:12px 15px; }
    }
