  @import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap');

  :root {
      --accent: #7b2eda;
      --accent-2: #9b59b6;
      --bg-dark: #0a0a0a;
      --bg-darker: #050505;
      --surface: #1a1a1a;
      --surface-dark: #0f0f0f;
      --surface-step: #1f1f1f;
      --surface-step-dark: #181818;
      --text: #eee;
      --text-soft: #aaa;

      --radius-sm: 0.3rem;
      --radius-md: 0.45rem;
      --radius-lg: 0.5rem;

      --border-purple: 1px solid rgba(123, 46, 218, 0.2);
      --border-purple-soft: 1px solid rgba(123, 46, 218, 0.15);

      --gradient-purple: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
      --gradient-surface: linear-gradient(145deg, var(--surface) 0%, var(--surface-dark) 100%);
      --gradient-step: linear-gradient(145deg, var(--surface-step) 0%, var(--surface-step-dark) 100%);

      --shadow-purple:
          0 18px 45px rgba(0, 0, 0, 0.55),
          0 0 0 1px rgba(137, 39, 213, 0.25),
          0 0 18px rgba(137, 39, 213, 0.35);

      --shadow-hover:
          0 20px 40px -12px rgba(0, 0, 0, 0.6),
          0 0 0 1px rgba(123, 46, 218, 0.2),
          0 8px 32px rgba(123, 46, 218, 0.15);

      --transition-fast: all 0.2s ease;
      --transition-main: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }

  * {
      box-sizing: border-box;
  }

  html {
      scroll-behavior: smooth;
  }

  body {
      font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
      background: linear-gradient(145deg, var(--bg-dark) 0%, var(--bg-darker) 100%);
      color: var(--text);
      margin: 0;
  }

  a {
      color: var(--accent) !important;
      text-decoration: underline;
      transition: var(--transition-fast);
  }

  a:hover {
      color: var(--accent-2) !important;
      text-shadow: 0 0 8px rgba(123, 46, 218, 0.5);
  }

  .accent {
      color: var(--accent);
      background: var(--gradient-purple);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
  }

  .CornerBox,
  .card,
  .step-card,
  .social-btn {
      position: relative;
      overflow: visible;
      box-shadow: var(--shadow-purple);
  }

  .CornerBox::before,
  .card::before,
  .step-card::before,
  .social-btn::before {
      content: "";
      position: absolute;
      inset: -2px;
      pointer-events: none;
      background-repeat: no-repeat;
      background-image:
          linear-gradient(var(--accent), var(--accent)),
          linear-gradient(var(--accent), var(--accent)),
          linear-gradient(var(--accent), var(--accent)),
          linear-gradient(var(--accent), var(--accent)),
          linear-gradient(var(--accent), var(--accent)),
          linear-gradient(var(--accent), var(--accent)),
          linear-gradient(var(--accent), var(--accent)),
          linear-gradient(var(--accent), var(--accent));
      background-size:
          14px 3px,
          3px 14px,
          14px 3px,
          3px 14px,
          14px 3px,
          3px 14px,
          14px 3px,
          3px 14px;
      background-position:
          left top,
          left top,
          right top,
          right top,
          left bottom,
          left bottom,
          right bottom,
          right bottom;
  }

  .card,
  .skeleton-card {
      width: 95%;
      max-width: 1200px;
      margin: auto;
  }

  .card {
      background: var(--gradient-surface);
      border: var(--border-purple);
      transition:
          transform 0.3s cubic-bezier(0.4, 0, 0.2, 1),
          box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }

  .card:hover,
  .step-card:hover {
      transform: translateY(-4px);
      box-shadow: var(--shadow-hover);
  }

  .card:hover {
      box-shadow:
          0 20px 40px -12px rgba(0, 0, 0, 0.6),
          0 0 0 1px rgba(123, 46, 218, 0.2),
          0 8px 32px rgba(123, 46, 218, 0.15);
  }

  .card-header {
      position: relative;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 2rem 2rem 1rem;
      height: 200px;
      background-size: cover;
      background-position: center;
  }

  .card-header::before {
      content: "";
      position: absolute;
      inset: 0;
      background: rgba(0, 0, 0, 0.75);
      z-index: 0;
  }

  .card-header h2 {
      position: relative;
      z-index: 1;
      font-size: 2rem;
      font-weight: 700;
      color: #fff;
  }

  .card-desc-teaser {
      position: relative;
      z-index: 1;
      font-size: 0.85rem;
      color: rgba(220, 220, 220, 0.75);
      margin-top: 0.35rem;
      font-weight: 400;
      max-width: 70%;
      line-height: 1.4;
  }

  .expand-hint {
      font-size: 0.75rem;
      color: rgba(123, 46, 218, 0.7);
      letter-spacing: 0.05em;
      position: relative;
      z-index: 1;
      display: flex;
      align-items: center;
      gap: 0.4rem;
      font-weight: 500;
  }

  .arrow {
      border: solid var(--accent);
      border-width: 0 3px 3px 0;
      display: inline-block;
      padding: 5px;
      transform: rotate(45deg);
      transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
      position: relative;
      z-index: 1;
      filter: drop-shadow(0 0 8px rgba(123, 46, 218, 0.5));
  }

  .arrow.open {
      transform: rotate(-135deg);
  }

  .btn-category,
  .social-btn {
      cursor: pointer;
      transition: var(--transition-main);
      border: var(--border-purple);
      background: var(--gradient-surface);
      color: var(--text);
      position: relative;
      overflow: hidden;
      font-weight: 600;
  }

  .btn-category {
      padding: 0.5rem 1rem;
      border-radius: var(--radius-sm);
  }

  .btn-category::after {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(circle at 50% 0%, rgba(123, 46, 218, 0.05) 0%, transparent 70%);
      opacity: 0;
      transition: opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
      pointer-events: none;
  }

  .btn-category:hover {
      border-color: rgba(123, 46, 218, 0.3);
      box-shadow: 0 8px 32px rgba(123, 46, 218, 0.15);
      transform: translateY(-2px);
  }

  .btn-category:hover::after {
      opacity: 1;
  }

  .btn-category.active {
      background: var(--gradient-purple);
      color: #141414;
      border-color: rgba(123, 46, 218, 0.4);
      box-shadow: 0 0 20px rgba(123, 46, 218, 0.4);
  }

  .cat-badge {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: rgba(123, 46, 218, 0.18);
      color: #b07aef;
      border-radius: 999px;
      font-size: 0.7rem;
      font-weight: 700;
      min-width: 1.35rem;
      height: 1.35rem;
      padding: 0 0.35rem;
      margin-left: 0.4rem;
      line-height: 1;
  }

  .btn-category.active .cat-badge {
      background: rgba(0, 0, 0, 0.2);
      color: #1a1a1a;
  }

  .fade-enter-active,
  .fade-leave-active {
      transition: all 0.4s ease;
  }

  .fade-enter-from,
  .fade-leave-to {
      opacity: 0;
      transform: translateY(20px);
  }

  .step-content {
      padding: 3rem;
      display: flex;
      flex-direction: column;
      gap: 1.5rem;
      max-height: 70vh;
      overflow-y: auto;
      scroll-behavior: auto;
  }

  .step-card {
      background: var(--gradient-step);
      padding: 1.5rem;
      border: var(--border-purple-soft);
      transition: var(--transition-main);
      cursor: pointer;
  }

  .step-card::after {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      height: 2px;
      background: linear-gradient(90deg, transparent 0%, var(--accent) 50%, transparent 100%);
      opacity: 0;
      transition: opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
      z-index: 1;
  }

  .step-card:hover {
      border-color: rgba(123, 46, 218, 0.3);
  }

  .step-card:hover::after {
      opacity: 1;
  }

  img.step-image {
      display: block;
      width: auto;
      max-width: min(100%, 800px);
      max-height: 370px;
      height: auto;
      object-fit: contain;
      margin-left: auto;
      margin-right: auto;
      border-radius: var(--radius-sm);
      box-shadow: var(--shadow-purple);
      transition:
          transform 0.3s cubic-bezier(0.4, 0, 0.2, 1),
          box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
      cursor: pointer;
      border: var(--border-purple);
  }

  img.step-image:hover {
      transform: scale(1.02);
      box-shadow: var(--shadow-hover);
  }

  .modal-bg {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, 0.9);
      display: flex;
      justify-content: center;
      align-items: center;
      z-index: 1000;
      backdrop-filter: blur(10px);
  }

  .modal-content {
      position: relative;
      width: 95%;
      max-width: 1400px;
  }

  .modal-img {
      width: 100%;
      max-height: 90vh;
      border-radius: var(--radius-sm);
      box-shadow: var(--shadow-purple);
      object-fit: contain;
      border: var(--border-purple);
  }

  .modal-close {
      position: absolute;
      top: -20px;
      right: -20px;
      background: var(--gradient-purple);
      color: #fff;
      border-radius: var(--radius-sm);
      width: 40px;
      height: 40px;
      display: flex;
      justify-content: center;
      align-items: center;
      font-size: 1.5rem;
      cursor: pointer;
      box-shadow: var(--shadow-purple);
      z-index: 1010;
      border: var(--border-purple);
      transition: var(--transition-fast);
  }

  .modal-close:hover {
      transform: scale(1.05);
      box-shadow: var(--shadow-hover);
  }

  .modal-close:active {
      transform: scale(0.95);
  }

  .social-btn {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      padding: 0.75rem 1.5rem;
      border-radius: var(--radius-sm);
      color: var(--text) !important;
      text-decoration: none !important;
  }

  .social-btn::before {
      transition: var(--transition-main);
  }

  .discord-btn:hover,
  .fivem-btn:hover {
      transform: translateY(-2px);
  }

  .discord-btn:hover {
      background: linear-gradient(145deg, #5865F2 0%, #4752c4 100%);
      border-color: rgba(88, 101, 242, 0.4);
      box-shadow: 0 8px 32px rgba(88, 101, 242, 0.4), 0 0 20px rgba(88, 101, 242, 0.3);
      color: #0d0f1a !important;
  }

  .discord-btn:hover::before {
      background-image:
          linear-gradient(#5865F2, #5865F2),
          linear-gradient(#5865F2, #5865F2),
          linear-gradient(#5865F2, #5865F2),
          linear-gradient(#5865F2, #5865F2),
          linear-gradient(#5865F2, #5865F2),
          linear-gradient(#5865F2, #5865F2),
          linear-gradient(#5865F2, #5865F2),
          linear-gradient(#5865F2, #5865F2);
  }

  .fivem-btn:hover {
      background: linear-gradient(145deg, #fe6f00 0%, #fe6f00 100%);
      border-color: rgba(244, 5, 82, 0.4);
      box-shadow: 0 8px 32px rgba(244, 5, 82, 0.4), 0 0 20px rgba(244, 5, 82, 0.3);
      color: #1a0800 !important;
  }

  .fivem-btn:hover::before {
      background-image:
          linear-gradient(#ffa600, #ffa600),
          linear-gradient(#ffa600, #ffa600),
          linear-gradient(#ffa600, #ffa600),
          linear-gradient(#ffa600, #ffa600),
          linear-gradient(#ffa600, #ffa600),
          linear-gradient(#ffa600, #ffa600),
          linear-gradient(#ffa600, #ffa600),
          linear-gradient(#ffa600, #ffa600);
  }

  .discord-btn img,
  .fivem-btn img {
      transition: filter 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }

  .discord-btn:hover img,
  .fivem-btn:hover img {
      filter: invert(1) brightness(0.2);
  }

  .logo {
      width: 320px;
      height: auto;
      transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
      filter: drop-shadow(0 8px 24px rgba(123, 46, 218, 0.3));
  }

  .logo:hover {
      transform: scale(1.02);
      filter: drop-shadow(0 12px 32px rgba(123, 46, 218, 0.4));
  }

  .scroll-top-btn {
      position: fixed;
      bottom: 2rem;
      right: 2rem;
      width: 48px;
      height: 48px;
      border-radius: 50%;
      background: var(--gradient-purple);
      border: 1px solid rgba(123, 46, 218, 0.4);
      box-shadow: 0 8px 32px rgba(123, 46, 218, 0.45), 0 0 0 1px rgba(137, 39, 213, 0.25);
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      z-index: 999;
      transition: var(--transition-main);
      opacity: 0;
      pointer-events: none;
      transform: translateY(12px);
  }

  .scroll-top-btn.visible {
      opacity: 1;
      pointer-events: all;
      transform: translateY(0);
  }

  .scroll-top-btn:hover {
      transform: translateY(-3px) scale(1.08);
      box-shadow: 0 12px 40px rgba(123, 46, 218, 0.6), 0 0 0 1px rgba(137, 39, 213, 0.4);
  }

  .scroll-top-btn:active {
      transform: scale(0.95);
  }

  .scroll-top-btn svg {
      width: 22px;
      height: 22px;
      stroke: #fff;
      stroke-width: 2.5;
      fill: none;
      stroke-linecap: round;
      stroke-linejoin: round;
  }

  .skeleton-card {
      background: var(--gradient-surface);
      border: var(--border-purple-soft);
      border-radius: var(--radius-sm);
      overflow: hidden;
      height: 200px;
      position: relative;
  }

  .skeleton-card::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, transparent 0%, rgba(123, 46, 218, 0.06) 50%, transparent 100%);
      animation: shimmer 1.6s infinite;
  }

  @keyframes shimmer {
      0% {
          transform: translateX(-100%);
      }

      100% {
          transform: translateX(100%);
      }
  }

  .empty-state {
      text-align: center;
      padding: 4rem 2rem;
      color: #555;
  }

  .empty-state svg {
      width: 56px;
      height: 56px;
      margin: 0 auto 1rem;
      opacity: 0.3;
      stroke: var(--accent);
      fill: none;
      stroke-width: 1.5;
  }

  .empty-state p {
      font-size: 1.1rem;
      color: #666;
  }

  .hero-strip {
      background: linear-gradient(135deg, rgba(123, 46, 218, 0.08) 0%, rgba(155, 89, 182, 0.04) 100%);
      border: var(--border-purple-soft);
      border-radius: var(--radius-lg);
      padding: 1rem 1.5rem;
      margin-bottom: 0.5rem;
      font-size: 0.95rem;
      color: var(--text-soft);
      line-height: 1.6;
  }

  .site-footer {
      margin-top: 4rem;
      padding: 2rem;
      text-align: center;
      border-top: var(--border-purple-soft);
      color: #444;
      font-size: 0.85rem;
      width: 100%;
      max-width: 1200px;
  }

  .site-footer a {
      font-size: 0.85rem;
  }

  .site-footer span {
      color: var(--accent);
  }

  .progress-bar-container {
      position: relative;
      z-index: 2;
  }

  .progress-fill {
      transition: width 0.1s linear;
  }

  .error-state {
      text-align: center;
      padding: 3rem 1rem;
      background: var(--gradient-surface);
      border-radius: var(--radius-lg);
      border: 1px solid rgba(255, 70, 70, 0.3);
  }

  .error-state svg {
      width: 48px;
      height: 48px;
      stroke: #ff6b6b;
      margin-bottom: 1rem;
  }

  .page-loader {
      position: fixed;
      inset: 0;
      z-index: 9999;
      background:
          radial-gradient(circle at center, rgba(123, 46, 218, 0.16) 0%, transparent 35%),
          linear-gradient(145deg, #0a0a0a 0%, #050505 100%);
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 1rem;
      backdrop-filter: blur(10px);
  }

  .loader-ring {
      width: 72px;
      height: 72px;
      border-radius: 50%;
      border: 4px solid rgba(123, 46, 218, 0.18);
      border-top-color: #7b2eda;
      border-right-color: #9b59b6;
      box-shadow:
          0 0 25px rgba(123, 46, 218, 0.45),
          inset 0 0 18px rgba(123, 46, 218, 0.18);
      animation: loader-spin 0.85s linear infinite;
  }

  .page-loader p {
      color: rgba(238, 238, 238, 0.8);
      font-size: 0.95rem;
      font-weight: 600;
      letter-spacing: 0.04em;
  }

  @keyframes loader-spin {
      to {
          transform: rotate(360deg);
      }
  }

  .loader-fade-enter-active,
  .loader-fade-leave-active {
      transition: opacity 0.35s ease;
  }

  .loader-fade-enter-from,
  .loader-fade-leave-to {
      opacity: 0;
  }

  @media (max-width: 1024px) {
      .card-header {
          height: 160px;
          padding: 1.5rem;
      }
  }

  @media (max-height: 800px) and (min-width: 769px) {
      .step-content {
          max-height: 65vh;
      }

      img.step-image {
          max-height: 340px;
      }
  }

  @media (max-width: 768px) {
      body {
          overflow-x: hidden;
      }

      .logo {
          width: min(240px, 80vw);
      }

      .hero-strip {
          padding: 0.9rem 1rem;
          font-size: 0.85rem;
          line-height: 1.55;
          margin: 0 0.75rem 0.75rem;
      }

      .card,
      .skeleton-card {
          width: calc(100% - 1rem);
          max-width: none;
          border-radius: var(--radius-md);
      }

      .card {
          scroll-margin-top: 12px;
      }

      .card-header {
          height: auto;
          min-height: 115px;
          padding: 1rem;
          gap: 0.75rem;
          align-items: flex-end;
      }

      .card-header h2 {
          font-size: clamp(1.2rem, 6vw, 1.55rem);
          line-height: 1.15;
          margin: 0;
      }

      .card-desc-teaser {
          max-width: 100%;
          font-size: 0.8rem;
          line-height: 1.4;
          margin-top: 0.3rem;
      }

      .expand-hint {
          font-size: 0.65rem;
          white-space: nowrap;
      }

      .arrow {
          padding: 4px;
          border-width: 0 2px 2px 0;
      }

      .step-content {
          padding: 1rem 1rem 1.25rem;
          gap: 1rem;
          max-height: 60vh;
          overflow-y: auto;
          -webkit-overflow-scrolling: touch;
      }

      .step-card {
          padding: 1rem;
          border-radius: var(--radius-md);
      }

      .step-card:hover,
      .card:hover,
      img.step-image:hover {
          transform: none;
      }

      img.step-image {
          width: 100%;
          max-width: 100%;
          max-height: 260px;
          object-fit: contain;
          border-radius: var(--radius-md);
      }

      .btn-category {
          padding: 0.65rem 0.85rem;
          font-size: 0.85rem;
          border-radius: var(--radius-md);
          flex: 1 1 auto;
          min-height: 42px;
      }

      .cat-badge {
          font-size: 0.65rem;
          min-width: 1.2rem;
          height: 1.2rem;
      }

      .social-buttons-row {
          display: flex;
          flex-direction: column;
          gap: 0.75rem;
          width: 100%;
      }

      .social-btn {
          width: 100%;
          min-height: 46px;
          padding: 0.8rem 1rem;
          justify-content: center;
          font-size: 0.9rem;
          border-radius: var(--radius-md);
          flex: 1;
      }

      .modal-bg {
          padding: 1rem;
          align-items: center;
      }

      .modal-content {
          width: 100%;
          max-width: 100%;
      }

      .modal-img {
          max-height: 82vh;
          border-radius: var(--radius-md);
      }

      .modal-close {
          top: 0.5rem;
          right: 0.5rem;
          width: 38px;
          height: 38px;
          font-size: 1.35rem;
          border-radius: var(--radius-md);
      }

      .scroll-top-btn {
          width: 44px;
          height: 44px;
          bottom: 0.9rem;
          right: 0.9rem;
      }

      .site-footer {
          margin-top: 2.5rem;
          padding: 1.5rem 1rem;
          font-size: 0.75rem;
      }

      .empty-state {
          padding: 3rem 1rem;
      }

      .empty-state p {
          font-size: 0.95rem;
      }
  }

  @media (max-width: 480px) {
      .card-header {
          min-height: 105px;
          padding: 0.85rem;
      }

      .card-header h2 {
          font-size: 1.15rem;
      }

      .card-desc-teaser,
      .expand-hint {
          display: none;
      }

      .step-content {
          padding: 0.85rem;
          max-height: 60vh;
      }

      .step-card {
          padding: 0.85rem;
      }

      .btn-category {
          width: 100%;
          justify-content: center;
      }

      img.step-image {
          max-height: 220px;
      }

      .CornerBox::before,
      .card::before,
      .step-card::before,
      .social-btn::before {
          background-size:
              10px 2px,
              2px 10px,
              10px 2px,
              2px 10px,
              10px 2px,
              2px 10px,
              10px 2px,
              2px 10px;
      }
  }

  @media (hover: none) {

      .card:hover,
      .step-card:hover,
      .btn-category:hover,
      .social-btn:hover,
      img.step-image:hover,
      .logo:hover,
      .scroll-top-btn:hover {
          transform: none;
      }
  }

  @media (prefers-reduced-motion: reduce) {

      *,
      *::before,
      *::after {
          animation-duration: 0.01ms !important;
          animation-iteration-count: 1 !important;
          scroll-behavior: auto !important;
          transition-duration: 0.01ms !important;
      }
  }