    *,
    *::before,
    *::after {
      margin: 0;
      padding: 0;
      box-sizing: border-box
    }

    html {
      scroll-behavior: smooth;
      -webkit-text-size-adjust: 100%;
      cursor: none
    }

    :root {
      --bg: #ffffff;
      --bg2: #f8fafc;
      --surface: #f1f5f9;
      --border: rgba(0, 0, 0, 0.1);
      --accent: #10b981;
      --accent2: #3b82f6;
      --text: #0f172a;
      --text-2: #334155;
      --text-3: #64748b;
      --ff-display: "Bricolage Grotesque", sans-serif;
      --ff-body: "Instrument Sans", sans-serif;
      --text-xs: 0.75rem;
      --text-sm: 0.875rem;
      --text-base: 1rem;
      --text-md: 1.125rem;
      --text-lg: 1.25rem;
      --text-xl: clamp(1.4rem, 3vw, 2rem);
      --text-2xl: clamp(1.75rem, 4vw, 3rem);
      --text-3xl: clamp(2.2rem, 5vw, 4rem);
      --text-hero: clamp(2.6rem, 7.5vw, 6rem);
      --lh-tight: 1.05;
      --lh-snug: 1.2;
      --lh-normal: 1.5;
      --lh-relaxed: 1.72;
      --lh-loose: 1.85;
      --max-w: 1200px;
      --gutter: clamp(1.25rem, 5vw, 4rem);
      --section-py: clamp(4rem, 10vw, 8rem)
    }

    /* ── Custom Cursor ── */
    .c-cursor {
      position: fixed;
      top: 0;
      left: 0;
      width: 8px;
      height: 8px;
      background: var(--accent);
      border-radius: 50%;
      pointer-events: none;
      z-index: 99999;
      transform: translate(-50%, -50%);
      transition: width .3s, height .3s, background-color .3s, opacity .3s
    }

    .c-cursor-follower {
      position: fixed;
      top: 0;
      left: 0;
      width: 36px;
      height: 36px;
      border: 1px solid var(--accent);
      border-radius: 50%;
      pointer-events: none;
      z-index: 99998;
      transform: translate(-50%, -50%);
      transition: width .3s, height .3s, border-color .3s, background-color .3s, opacity .3s
    }

    .c-cursor.hover {
      width: 12px;
      height: 12px;
      background-color: var(--accent2)
    }

    .c-cursor-follower.hover {
      width: 56px;
      height: 56px;
      border-color: var(--accent2);
      background-color: rgba(59, 130, 246, .1)
    }

    .c-cursor.hidden,
    .c-cursor-follower.hidden {
      opacity: 0
    }

    a,
    button,
    input,
    textarea,
    select,
    .service-card,
    .process-step,
    .logo,
    .why-point,
    .tech-card-rolling,
    .contact-method {
      cursor: none
    }

    /* ── Global ── */
    body {
      background: var(--bg);
      color: var(--text);
      font-family: var(--ff-body);
      font-size: var(--text-base);
      line-height: var(--lh-relaxed);
      overflow-x: hidden;
      -webkit-font-smoothing: antialiased
    }

    body::before {
      content: "";
      position: fixed;
      inset: 0;
      background: radial-gradient(ellipse 80% 80% at 50% 20%, rgba(16, 185, 129, .05) 0%, rgba(59, 130, 246, .025) 40%, transparent 70%);
      pointer-events: none;
      z-index: 1
    }

    body::after {
      content: "";
      position: fixed;
      inset: 0;
      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='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
      opacity: .02;
      pointer-events: none;
      z-index: 9999
    }

    .container {
      width: 100%;
      max-width: var(--max-w);
      margin-inline: auto;
      padding-inline: var(--gutter)
    }

    .section-py {
      padding-block: var(--section-py)
    }

    .t-label {
      font-family: var(--ff-body);
      font-size: var(--text-xs);
      font-weight: 700;
      letter-spacing: .14em;
      text-transform: uppercase;
      color: var(--accent);
      display: inline-block;
      background: rgba(16, 185, 129, .08);
      padding: .4rem .8rem;
      border-radius: 8px;
      border: 1px solid rgba(16, 185, 129, .2)
    }

    .t-gradient {
      background: linear-gradient(135deg, var(--accent) 0%, var(--accent2) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text
    }

    .section-header {
      margin-bottom: clamp(2.5rem, 5vw, 4rem)
    }

    .section-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: .75rem;
      margin-bottom: 1.25rem
    }

    .section-eyebrow::before {
      content: "";
      display: block;
      width: 24px;
      height: 2.5px;
      background: linear-gradient(90deg, var(--accent), transparent);
      border-radius: 2px;
      flex-shrink: 0
    }

    .section-title {
      font-family: var(--ff-display);
      font-size: var(--text-3xl);
      font-weight: 800;
      line-height: 1.2;
      letter-spacing: -.025em;
      background: linear-gradient(135deg, var(--text) 0%, var(--accent) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text
    }

    .section-lead {
      font-size: var(--text-md);
      line-height: 1.85;
      color: var(--text-2);
      max-width: 52ch;
      margin-top: 1rem
    }

    /* ── Buttons ── */
    .btn {
      display: inline-flex;
      align-items: center;
      gap: .5rem;
      font-family: var(--ff-display);
      font-weight: 700;
      font-size: var(--text-base);
      border-radius: 100px;
      padding: .75rem 1.75rem;
      text-decoration: none;
      border: none;
      transition: transform .2s, box-shadow .2s
    }

    .btn-primary {
      background: linear-gradient(135deg, var(--accent), #059669);
      color: #fff;
      font-weight: 800
    }

    .btn-primary:hover {
      transform: translateY(-4px);
      box-shadow: 0 16px 48px rgba(16, 185, 129, .45)
    }

    .btn-ghost {
      color: var(--text);
      border: 1.5px solid rgba(16, 185, 129, .3);
      background: rgba(16, 185, 129, .04);
      backdrop-filter: blur(8px)
    }

    .btn-ghost:hover {
      border-color: rgba(16, 185, 129, .6);
      background: rgba(16, 185, 129, .08);
      box-shadow: 0 8px 32px -8px rgba(16, 185, 129, .25)
    }

    /* ── Scroll Reveal ── */
    /* Default: visible. JS adds .js-ready to hide+animate on scroll. */
    .reveal {
      opacity: 1;
      transform: translateY(0);
      transition: opacity .75s cubic-bezier(.165, .84, .44, 1), transform .75s cubic-bezier(.165, .84, .44, 1)
    }

    .js-ready .reveal {
      opacity: 0;
      transform: translateY(30px)
    }

    .reveal.visible {
      opacity: 1;
      transform: translateY(0)
    }

    /* ── Keyframes ── */
    @keyframes drift {
      from {
        transform: translate(0, 0) scale(1)
      }

      to {
        transform: translate(40px, 28px) scale(1.08)
      }
    }

    @keyframes pulse {

      0%,
      100% {
        opacity: 1
      }

      50% {
        opacity: .3
      }
    }

    @keyframes floatA {

      0%,
      100% {
        transform: translateY(0)
      }

      50% {
        transform: translateY(-14px)
      }
    }

    @keyframes floatB {

      0%,
      100% {
        transform: translateY(0)
      }

      50% {
        transform: translateY(10px)
      }
    }

    @keyframes scrollDown {
      0% {
        transform: scaleY(0);
        transform-origin: top
      }

      50% {
        transform: scaleY(1);
        transform-origin: top
      }

      51% {
        transform-origin: bottom
      }

      100% {
        transform: scaleY(0);
        transform-origin: bottom
      }
    }

    @keyframes scrollLeft {
      from {
        transform: translateX(0)
      }

      to {
        transform: translateX(-50%)
      }
    }

    @keyframes scrollRight {
      from {
        transform: translateX(-50%)
      }

      to {
        transform: translateX(0)
      }
    }

    /* ── Nav ── */
    nav {
      position: fixed;
      top: 0;
      inset-inline: 0;
      z-index: 200;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding-block: 1rem;
      padding-inline: var(--gutter);
      background: rgba(255, 255, 255, .85);
      backdrop-filter: blur(24px) saturate(1.2);
      border-bottom: 1px solid rgba(16, 185, 129, .08)
    }

    .logo {
      font-family: var(--ff-display);
      font-size: 1.3rem;
      font-weight: 800;
      letter-spacing: -.035em;
      color: var(--text);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: .5rem
    }

    .logo img {
      width: 40px;
      height: 40px;
      object-fit: contain;
      display: block
    }

    .logo .dot,
    .footer-logo .dot {
      color: var(--accent)
    }

    .nav-links {
      display: flex;
      gap: 2rem;
      list-style: none
    }

    .nav-links a {
      font-size: var(--text-sm);
      font-weight: 500;
      color: var(--text-3);
      text-decoration: none;
      letter-spacing: .03em;
      transition: color .22s
    }

    .nav-links a:hover {
      color: var(--text)
    }

    .nav-toggle {
      display: none;
      flex-direction: column;
      gap: 5px;
      background: none;
      border: none;
      padding: .5rem
    }

    .nav-toggle span {
      display: block;
      width: 22px;
      height: 2px;
      background: var(--text);
      border-radius: 2px;
      transition: transform .3s, opacity .3s
    }

    .nav-toggle.open span:nth-child(1) {
      transform: translateY(7px) rotate(45deg)
    }

    .nav-toggle.open span:nth-child(2) {
      opacity: 0
    }

    .nav-toggle.open span:nth-child(3) {
      transform: translateY(-7px) rotate(-45deg)
    }

    .nav-drawer {
      display: none;
      position: fixed;
      inset: 0;
      z-index: 190;
      background: rgba(255, 255, 255, .97);
      backdrop-filter: blur(24px);
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 2rem
    }

    .nav-drawer.open {
      display: flex
    }

    .nav-drawer a {
      font-family: var(--ff-display);
      font-size: var(--text-2xl);
      font-weight: 700;
      color: var(--text);
      text-decoration: none;
      letter-spacing: -.025em;
      transition: color .2s
    }

    .nav-drawer a:hover {
      color: var(--accent)
    }

    /* ── Hero ── */
    .hero {
      min-height: 100svh;
      display: grid;
      place-items: center;
      padding-block: clamp(6rem, 15vw, 10rem) clamp(4rem, 8vw, 6rem);
      padding-inline: var(--gutter);
      position: relative;
      overflow: hidden;
      text-align: center
    }

    .orb {
      position: absolute;
      border-radius: 50%;
      filter: blur(100px);
      opacity: .13;
      animation: drift 16s ease-in-out infinite alternate
    }

    .orb-1 {
      width: clamp(300px, 55vw, 700px);
      height: clamp(300px, 55vw, 700px);
      background: linear-gradient(135deg, var(--accent), var(--accent2));
      top: -15%;
      right: -10%
    }

    .orb-2 {
      width: clamp(260px, 45vw, 600px);
      height: clamp(260px, 45vw, 600px);
      background: linear-gradient(225deg, var(--accent2), var(--accent));
      bottom: -10%;
      left: -8%;
      animation-delay: -5s
    }

    .orb-3 {
      width: clamp(140px, 25vw, 320px);
      height: clamp(140px, 25vw, 320px);
      background: #a855f7;
      top: 40%;
      left: 28%;
      animation-delay: -10s
    }

    .hero-inner {
      position: relative;
      z-index: 2;
      max-width: 860px;
      width: 100%;
      margin-inline: auto
    }

    .hero-badge {
      display: inline-flex;
      align-items: center;
      gap: .5rem;
      background: rgba(16, 185, 129, .1);
      border: 1px solid rgba(16, 185, 129, .3);
      border-radius: 100px;
      padding: .5rem 1.25rem;
      font-size: var(--text-xs);
      font-weight: 700;
      color: var(--accent);
      letter-spacing: .14em;
      text-transform: uppercase;
      margin-bottom: 2rem;
      backdrop-filter: blur(12px);
      box-shadow: 0 4px 16px -4px rgba(16, 185, 129, .15)
    }

    .hero-badge .dot {
      font-size: .45rem;
      animation: pulse 2s ease-in-out infinite
    }

    .hero h1 {
      font-family: var(--ff-display);
      font-size: var(--text-hero);
      font-weight: 800;
      line-height: 1.05;
      letter-spacing: -.04em;
      margin-bottom: 1.5rem;
      background: linear-gradient(135deg, var(--accent) 0%, var(--text) 50%, var(--accent2) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text
    }

    .hero-sub {
      font-size: clamp(1rem, 2.2vw, 1.2rem);
      line-height: 1.85;
      color: var(--text-2);
      max-width: 54ch;
      margin-inline: auto;
      margin-bottom: 2.5rem
    }

    .hero-actions {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 1rem;
      flex-wrap: wrap
    }

    .hero-scroll {
      position: absolute;
      bottom: 2rem;
      left: 50%;
      transform: translateX(-50%);
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: .5rem;
      color: var(--text-3);
      font-size: var(--text-xs);
      letter-spacing: .14em;
      text-transform: uppercase;
      z-index: 2
    }

    .scroll-line {
      width: 1px;
      height: 36px;
      background: linear-gradient(to bottom, var(--text-3), transparent);
      animation: scrollDown 2s ease-in-out infinite
    }

    /* ── Stats ── */
    .stats {
      border-block: 1px solid rgba(16, 185, 129, .1);
      background: linear-gradient(135deg, rgba(241, 245, 249, .8), rgba(226, 232, 240, .5));
      padding-block: 2rem;
      padding-inline: var(--gutter);
      backdrop-filter: blur(16px)
    }

    .stats-inner {
      max-width: var(--max-w);
      margin-inline: auto;
      display: grid;
      grid-template-columns: repeat(4, 1fr)
    }

    .stat {
      text-align: center;
      padding: 1.5rem;
      border-right: 1px solid rgba(16, 185, 129, .1)
    }

    .stat:last-child {
      border-right: none
    }

    .stat-num {
      font-family: var(--ff-display);
      font-size: clamp(1.8rem, 3.5vw, 2.5rem);
      font-weight: 800;
      background: linear-gradient(135deg, var(--accent), var(--accent2));
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      letter-spacing: -.025em;
      line-height: 1
    }

    .stat-label {
      font-size: var(--text-xs);
      color: var(--text-3);
      letter-spacing: .08em;
      text-transform: uppercase;
      margin-top: .4rem
    }

    /* ── Services ── */
    .services {
      background: var(--bg)
    }

    .services-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1.5px;
      background: rgba(16, 185, 129, .05);
      border: 1px solid rgba(16, 185, 129, .1);
      border-radius: 24px;
      overflow: hidden;
      box-shadow: inset 0 0 60px -30px rgba(16, 185, 129, .08)
    }

    .service-card {
      background: rgba(241, 245, 249, .6);
      backdrop-filter: blur(12px);
      padding: clamp(1.75rem, 3vw, 2.75rem) clamp(1.5rem, 2.5vw, 2.25rem);
      position: relative;
      transition: all .4s cubic-bezier(.22, 1, .36, 1);
      overflow: hidden;
      border: 1px solid rgba(16, 185, 129, .1)
    }

    .service-card::before {
      content: "";
      position: absolute;
      top: 0;
      inset-inline: 0;
      height: 2px;
      background: linear-gradient(90deg, var(--accent), var(--accent2));
      transform: scaleX(0);
      transform-origin: center;
      transition: transform .4s cubic-bezier(.22, 1, .36, 1)
    }

    .service-card:hover {
      background: rgba(255, 255, 255, .95);
      border-color: rgba(16, 185, 129, .35);
      transform: translateY(-8px);
      box-shadow: 0 20px 60px -20px rgba(16, 185, 129, .25)
    }

    .service-card:hover::before {
      transform: scaleX(1)
    }

    .service-icon {
      width: 56px;
      height: 56px;
      background: linear-gradient(135deg, rgba(16, 185, 129, .12), rgba(59, 130, 246, .08));
      border: 1px solid rgba(16, 185, 129, .2);
      border-radius: 14px;
      display: grid;
      place-items: center;
      font-size: 1.6rem;
      margin-bottom: 1.5rem;
      transition: all .4s cubic-bezier(.22, 1, .36, 1)
    }

    .service-card:hover .service-icon {
      transform: scale(1.15) rotate(-8deg);
      background: linear-gradient(135deg, rgba(16, 185, 129, .2), rgba(59, 130, 246, .15));
      box-shadow: 0 12px 32px -6px rgba(16, 185, 129, .2)
    }

    .service-card h3 {
      font-family: var(--ff-display);
      font-size: var(--text-md);
      font-weight: 700;
      letter-spacing: -.01em;
      line-height: 1.2;
      margin-bottom: .6rem;
      background: linear-gradient(135deg, var(--text), var(--accent));
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text
    }

    .service-card p {
      font-size: var(--text-sm);
      line-height: 1.72;
      color: var(--text-3)
    }

    .service-num {
      position: absolute;
      bottom: 1rem;
      right: 1.5rem;
      font-family: var(--ff-display);
      font-size: 3.5rem;
      font-weight: 800;
      color: rgba(0, 0, 0, .05);
      line-height: 1;
      pointer-events: none;
      user-select: none
    }

    /* ── Process ── */
    .process {
      background: var(--bg2);
      position: relative;
      overflow: hidden
    }

    .process-steps {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 1.5rem;
      position: relative
    }

    .process-step {
      position: relative;
      z-index: 1;
      text-align: left;
      background: linear-gradient(135deg, rgba(241, 245, 249, .8), rgba(226, 232, 240, .5));
      backdrop-filter: blur(16px);
      border: 1px solid rgba(16, 185, 129, .12);
      border-radius: 24px;
      padding: 2rem;
      transition: all .5s cubic-bezier(.22, 1, .36, 1)
    }

    .process-step.is-glowing {
      border-color: rgba(16, 185, 129, .5);
      background: linear-gradient(135deg, rgba(16, 185, 129, .08), rgba(59, 130, 246, .04));
      box-shadow: inset 0 0 40px rgba(16, 185, 129, .08), 0 0 50px -12px rgba(16, 185, 129, .18)
    }

    .process-step.is-glowing .step-icon-box {
      border-color: var(--accent);
      color: var(--accent)
    }

    .process-step:hover {
      background: linear-gradient(135deg, rgba(255, 255, 255, .95), rgba(241, 245, 249, .8));
      border-color: rgba(16, 185, 129, .3);
      transform: translateY(-8px);
      box-shadow: 0 20px 60px -20px rgba(16, 185, 129, .18)
    }

    .step-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 2rem
    }

    .step-icon-box {
      width: 64px;
      height: 64px;
      border-radius: 16px;
      background: linear-gradient(135deg, rgba(16, 185, 129, .12), rgba(59, 130, 246, .08));
      border: 1px solid rgba(16, 185, 129, .2);
      display: grid;
      place-items: center;
      color: var(--accent);
      font-size: 1.4rem;
      transition: all .4s ease
    }

    .process-step:hover .step-icon-box {
      transform: scale(1.1) translateY(-4px);
      box-shadow: 0 8px 24px -6px rgba(16, 185, 129, .25)
    }

    .step-icon-box svg {
      width: 28px;
      height: 28px;
      stroke: currentColor;
      fill: none;
      stroke-width: 1.5
    }

    .step-badge {
      font-family: var(--ff-display);
      font-size: .7rem;
      font-weight: 800;
      color: var(--accent);
      text-transform: uppercase;
      letter-spacing: .12em
    }

    .process-step h4 {
      font-family: var(--ff-display);
      font-size: var(--text-lg);
      font-weight: 700;
      margin-bottom: .75rem;
      background: linear-gradient(135deg, var(--text), var(--accent));
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text
    }

    .process-step p {
      font-size: var(--text-sm);
      line-height: 1.6;
      color: var(--text-3);
      transition: color .3s
    }

    .process-step:hover p {
      color: var(--text-2)
    }

    /* ── Why Us ── */
    .why {
      background: var(--bg);
      position: relative
    }

    .why-grid {
      display: grid;
      grid-template-columns: 1.1fr 0.9fr;
      gap: clamp(3rem, 8vw, 8rem);
      align-items: center
    }

    .why-visual-composition {
      position: relative;
      height: 520px;
      display: grid;
      place-items: center
    }

    .why-center-hub {
      width: 320px;
      height: 320px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(16, 185, 129, .08), transparent);
      border: 2px solid rgba(16, 185, 129, .25);
      display: grid;
      place-items: center;
      position: relative;
      box-shadow: inset 0 0 60px rgba(16, 185, 129, .06), 0 0 80px -20px rgba(16, 185, 129, .1)
    }

    .why-center-hub::after {
      content: "";
      position: absolute;
      inset: -40px;
      border-radius: 50%;
      border: 2px dashed rgba(16, 185, 129, .15);
      animation: drift 20s linear infinite
    }

    .why-center-hub .logo-mark {
      font-family: var(--ff-display);
      font-size: 3.5rem;
      font-weight: 900;
      background: linear-gradient(135deg, var(--accent), var(--accent2));
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      filter: drop-shadow(0 0 20px rgba(16, 185, 129, .3))
    }

    .ui-element {
      position: absolute;
      background: linear-gradient(135deg, rgba(255, 255, 255, .9), rgba(241, 245, 249, .8));
      backdrop-filter: blur(16px);
      border: 1px solid rgba(16, 185, 129, .15);
      border-radius: 24px;
      padding: 1.5rem;
      z-index: 2;
      box-shadow: 0 16px 40px -10px rgba(0, 0, 0, .08);
      transition: transform .2s cubic-bezier(.22, 1, .36, 1)
    }

    .ui-1 {
      top: 12%;
      right: -60px;
      width: 240px;
      animation: floatA 6s ease-in-out infinite
    }

    .ui-2 {
      bottom: 12%;
      left: -60px;
      width: 240px;
      animation: floatB 8s ease-in-out infinite 1s
    }

    .ui-3 {
      top: 50%;
      right: -60px;
      width: 220px;
      animation: floatA 7s ease-in-out infinite .5s
    }

    .ui-header {
      display: flex;
      align-items: center;
      gap: .75rem;
      margin-bottom: .5rem
    }

    .ui-dot {
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: var(--accent)
    }

    .ui-label {
      font-size: .7rem;
      font-weight: 700;
      color: var(--text-3);
      text-transform: uppercase;
      letter-spacing: .1em
    }

    .ui-val {
      font-family: var(--ff-display);
      font-size: 1.25rem;
      font-weight: 800;
      color: var(--text)
    }

    .ui-bar {
      height: 4px;
      background: rgba(0, 0, 0, .08);
      border-radius: 2px;
      overflow: hidden;
      margin-top: .75rem
    }

    .ui-bar-fill {
      height: 100%;
      background: var(--accent);
      border-radius: 2px
    }

    .why-points {
      display: flex;
      flex-direction: column;
      gap: .5rem;
      margin-top: 1rem
    }

    .why-point {
      display: flex;
      gap: 1.25rem;
      align-items: flex-start;
      padding: 1.5rem;
      border-radius: 20px;
      border: 1px solid rgba(16, 185, 129, .12);
      background: rgba(241, 245, 249, .5);
      transition: all .4s cubic-bezier(.22, 1, .36, 1);
      backdrop-filter: blur(8px)
    }

    .why-point:hover {
      background: rgba(255, 255, 255, .9);
      border-color: rgba(16, 185, 129, .3);
      transform: translateX(8px);
      box-shadow: 0 8px 32px -8px rgba(16, 185, 129, .15)
    }

    .why-point:hover .wp-check {
      background: linear-gradient(135deg, var(--accent), #059669);
      color: #fff;
      border-color: var(--accent);
      box-shadow: 0 0 20px rgba(16, 185, 129, .4)
    }

    .wp-check {
      width: 36px;
      height: 36px;
      flex-shrink: 0;
      background: rgba(16, 185, 129, .1);
      border: 1.5px solid rgba(16, 185, 129, .25);
      border-radius: 10px;
      display: grid;
      place-items: center;
      color: var(--accent);
      font-size: .9rem;
      font-weight: 700;
      margin-top: 2px;
      transition: all .4s cubic-bezier(.22, 1, .36, 1)
    }

    .wp-content h4 {
      font-family: var(--ff-display);
      font-size: var(--text-md);
      font-weight: 700;
      margin-bottom: .4rem;
      color: var(--text)
    }

    .wp-content p {
      font-size: var(--text-sm);
      color: var(--text-3);
      line-height: 1.6
    }

    /* ── Tech (Rolling) ── */
    .tech {
      background: var(--bg2);
      position: relative;
      overflow: hidden
    }

    .tech-track-container {
      display: flex;
      flex-direction: column;
      gap: 2rem;
      margin-top: 3rem
    }

    .tech-track-wrap {
      overflow: hidden;
      position: relative;
      width: 100%
    }

    .tech-track-wrap::before,
    .tech-track-wrap::after {
      content: "";
      position: absolute;
      top: 0;
      bottom: 0;
      width: 150px;
      z-index: 2;
      pointer-events: none
    }

    .tech-track-wrap::before {
      left: 0;
      background: linear-gradient(to right, var(--bg2), transparent)
    }

    .tech-track-wrap::after {
      right: 0;
      background: linear-gradient(to left, var(--bg2), transparent)
    }

    .tech-track {
      display: flex;
      gap: 1.5rem;
      width: max-content;
      animation: scrollLeft 40s linear infinite
    }

    .tech-track.reverse {
      animation: scrollRight 40s linear infinite
    }

    .tech-track:hover {
      animation-play-state: paused
    }

    .tech-card-rolling {
      display: flex;
      align-items: center;
      gap: 1rem;
      background: rgba(255, 255, 255, .7);
      border: 1px solid rgba(16, 185, 129, .15);
      border-radius: 16px;
      padding: 1rem 1.5rem;
      backdrop-filter: blur(12px);
      transition: all .4s cubic-bezier(.22, 1, .36, 1)
    }

    .tech-card-rolling:hover {
      border-color: var(--accent);
      background: rgba(16, 185, 129, .06);
      transform: translateY(-6px) scale(1.02);
      box-shadow: 0 16px 40px -8px rgba(16, 185, 129, .2)
    }

    .tech-card-icon-mini {
      width: 32px;
      height: 32px;
      display: grid;
      place-items: center;
      color: var(--accent)
    }

    .tech-card-icon-mini svg {
      width: 100%;
      height: 100%
    }

    .tech-card-name {
      font-family: var(--ff-display);
      font-size: var(--text-base);
      font-weight: 700;
      color: var(--text);
      white-space: nowrap
    }

    /* ── Contact ── */
    .contact {
      background: var(--bg);
      position: relative
    }

    .contact::after {
      content: "";
      position: absolute;
      bottom: 0;
      right: 0;
      width: 30%;
      height: 50%;
      background: radial-gradient(circle, rgba(59, 130, 246, .04) 0%, transparent 70%);
      pointer-events: none;
      z-index: 0
    }

    .contact-grid {
      display: grid;
      grid-template-columns: 1fr 1.5fr;
      gap: clamp(2rem, 5vw, 4rem);
      align-items: flex-start
    }

    .contact-info {
      padding-top: 1rem
    }

    .contact-info h2 {
      font-family: var(--ff-display);
      font-size: var(--text-3xl);
      font-weight: 800;
      line-height: 1.1;
      margin-bottom: 1.5rem;
      color: var(--text)
    }

    .contact-info p {
      color: var(--text-2);
      max-width: 35ch;
      margin-bottom: 2.5rem;
      line-height: 1.6
    }

    .contact-methods {
      display: flex;
      flex-direction: column;
      gap: 1.5rem
    }

    .contact-method {
      display: flex;
      align-items: center;
      gap: 1.25rem;
      padding: 1.5rem;
      background: rgba(241, 245, 249, .6);
      border: 1px solid rgba(16, 185, 129, .12);
      border-radius: 18px;
      text-decoration: none;
      transition: all .4s cubic-bezier(.22, 1, .36, 1);
      backdrop-filter: blur(8px)
    }

    .contact-method:hover {
      background: rgba(255, 255, 255, .9);
      border-color: var(--accent2);
      transform: translateX(12px);
      box-shadow: 0 12px 36px -10px rgba(59, 130, 246, .15)
    }

    .cm-icon {
      width: 48px;
      height: 48px;
      border-radius: 12px;
      background: linear-gradient(135deg, rgba(59, 130, 246, .12), rgba(16, 185, 129, .06));
      border: 1px solid rgba(59, 130, 246, .2);
      display: grid;
      place-items: center;
      font-size: 1.2rem
    }

    .cm-details span {
      display: block
    }

    .cm-label {
      font-size: .7rem;
      font-weight: 700;
      color: var(--text-3);
      text-transform: uppercase;
      letter-spacing: .1em;
      margin-bottom: 2px
    }

    .cm-value {
      font-size: var(--text-sm);
      font-weight: 600;
      color: var(--text)
    }

    .contact-form-card {
      background: linear-gradient(135deg, rgba(255, 255, 255, .8), rgba(241, 245, 249, .6));
      backdrop-filter: blur(24px);
      border: 1px solid rgba(16, 185, 129, .15);
      border-radius: 32px;
      padding: clamp(2rem, 4vw, 3.5rem);
      position: relative;
      z-index: 1;
      box-shadow: 0 8px 40px -10px rgba(16, 185, 129, .1)
    }

    .contact-form {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 1.5rem
    }

    .form-full {
      grid-column: span 2
    }

    .form-group {
      display: flex;
      flex-direction: column;
      gap: .6rem;
      position: relative
    }

    .form-group label {
      font-size: var(--text-xs);
      font-weight: 700;
      color: var(--text-3);
      text-transform: uppercase;
      letter-spacing: .1em;
      transition: color .3s ease
    }

    .form-group input,
    .form-group textarea,
    .form-group select {
      background: rgba(248, 250, 252, .9);
      border: 1px solid rgba(16, 185, 129, .15);
      border-radius: 14px;
      padding: 1rem 1.25rem;
      color: var(--text);
      font-family: var(--ff-body);
      font-size: var(--text-base);
      outline: none;
      transition: all .3s ease;
      width: 100%;
      cursor: none
    }

    .form-group textarea {
      min-height: 120px;
      resize: vertical
    }

    .form-group select {
      appearance: none;
      padding-right: 2.5rem;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2310b981' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 1rem center;
      background-color: rgba(248, 250, 252, .9);
      cursor: pointer
    }

    .form-group input:focus,
    .form-group textarea:focus,
    .form-group select:focus {
      border-color: var(--accent);
      background: rgba(16, 185, 129, .04);
      box-shadow: 0 0 24px -6px rgba(16, 185, 129, .15)
    }

    .btn-submit {
      grid-column: span 2;
      margin-top: 1.5rem;
      background: linear-gradient(135deg, var(--accent) 0%, #059669 50%, var(--accent2) 100%);
      color: #fff;
      padding: 1.35rem 2rem;
      border-radius: 16px;
      font-family: var(--ff-display);
      font-weight: 800;
      font-size: 1.05rem;
      border: none;
      cursor: none;
      transition: all .5s cubic-bezier(.22, 1, .36, 1);
      display: flex;
      align-items: center;
      justify-content: center;
      gap: .85rem;
      box-shadow: 0 10px 32px -6px rgba(16, 185, 129, .35);
      position: relative;
      overflow: hidden
    }

    .btn-submit::before {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, transparent 0%, rgba(255, 255, 255, .12) 50%, transparent 100%);
      transform: translateX(-100%);
      transition: transform .6s ease
    }

    .btn-submit:hover::before {
      transform: translateX(100%)
    }

    .btn-submit:hover {
      transform: translateY(-6px);
      box-shadow: 0 20px 60px -8px rgba(16, 185, 129, .45)
    }

    .btn-submit:active {
      transform: translateY(-2px)
    }

    .btn-submit span {
      position: relative;
      z-index: 1;
      letter-spacing: .02em
    }

    .btn-submit svg {
      width: 20px;
      height: 20px;
      transition: all .5s cubic-bezier(.22, 1, .36, 1);
      position: relative;
      z-index: 1
    }

    .btn-submit:hover svg {
      transform: translateX(6px) rotate(-20deg)
    }

    /* ── Footer ── */
    footer {
      background: linear-gradient(135deg, var(--bg2), rgba(226, 232, 240, .6));
      border-top: 1px solid rgba(16, 185, 129, .1);
      padding-block: 2.5rem;
      padding-inline: var(--gutter)
    }

    .footer-inner {
      max-width: var(--max-w);
      margin-inline: auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      flex-wrap: wrap;
      gap: 1.5rem
    }

    .footer-logo {
      font-family: var(--ff-display);
      font-size: var(--text-md);
      font-weight: 800;
      letter-spacing: -.025em;
      color: var(--text)
    }

    .footer-links {
      display: flex;
      gap: 1.5rem;
      list-style: none;
      flex-wrap: wrap
    }

    .footer-links a {
      font-size: var(--text-sm);
      color: var(--text-3);
      text-decoration: none;
      transition: color .2s;
      cursor: none
    }

    .footer-links a:hover {
      color: var(--text)
    }

    .footer-copy {
      font-size: var(--text-xs);
      color: var(--text-3);
      letter-spacing: .03em
    }

    /* ── Sidebar Panel ── */
    .sidebar-overlay {
      position: fixed;
      inset: 0;
      background: rgba(15, 23, 42, .45);
      backdrop-filter: blur(6px);
      z-index: 500;
      opacity: 0;
      pointer-events: none;
      transition: opacity .4s cubic-bezier(.22, 1, .36, 1)
    }

    .sidebar-overlay.open {
      opacity: 1;
      pointer-events: auto
    }

    .sidebar-panel {
      position: fixed;
      top: 0;
      right: 0;
      bottom: 0;
      width: min(680px, 92vw);
      background: rgba(248, 250, 252, .97);
      backdrop-filter: blur(32px) saturate(1.4);
      z-index: 510;
      transform: translateX(100%);
      transition: transform .5s cubic-bezier(.22, 1, .36, 1);
      overflow-y: auto;
      overflow-x: hidden;
      box-shadow: -20px 0 80px -20px rgba(0, 0, 0, .15);
      border-left: 1px solid rgba(16, 185, 129, .12)
    }

    .sidebar-panel.open {
      transform: translateX(0)
    }

    .sidebar-panel::-webkit-scrollbar {
      width: 4px
    }

    .sidebar-panel::-webkit-scrollbar-track {
      background: transparent
    }

    .sidebar-panel::-webkit-scrollbar-thumb {
      background: rgba(16, 185, 129, .2);
      border-radius: 2px
    }

    .sidebar-close {
      position: sticky;
      top: 0;
      z-index: 10;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 1.25rem 2rem;
      background: rgba(248, 250, 252, .92);
      backdrop-filter: blur(16px);
      border-bottom: 1px solid rgba(16, 185, 129, .1)
    }

    .sidebar-close-title {
      font-family: var(--ff-display);
      font-size: var(--text-md);
      font-weight: 700;
      background: linear-gradient(135deg, var(--accent), var(--accent2));
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text
    }

    .sidebar-close-btn {
      width: 40px;
      height: 40px;
      border-radius: 12px;
      background: rgba(16, 185, 129, .08);
      border: 1px solid rgba(16, 185, 129, .15);
      display: grid;
      place-items: center;
      color: var(--text);
      font-size: 1.25rem;
      transition: all .3s ease;
      cursor: pointer
    }

    .sidebar-close-btn:hover {
      background: rgba(16, 185, 129, .15);
      border-color: rgba(16, 185, 129, .3);
      transform: rotate(90deg)
    }

    .sidebar-content {
      padding: 2rem
    }

    .sidebar-content .section-header {
      margin-bottom: 2rem
    }

    .sidebar-content .section-title {
      font-size: clamp(1.5rem, 3vw, 2rem)
    }

    .sidebar-content .section-lead {
      font-size: var(--text-sm)
    }

    /* Sidebar Process Steps */
    .sidebar-content .process-steps {
      grid-template-columns: 1fr;
      gap: 1rem
    }

    .sidebar-content .process-step {
      padding: 1.5rem;
      border-radius: 18px
    }

    .sidebar-content .step-header {
      margin-bottom: 1rem
    }

    .sidebar-content .step-icon-box {
      width: 48px;
      height: 48px;
      border-radius: 12px;
      font-size: 1.1rem
    }

    .sidebar-content .step-icon-box svg {
      width: 22px;
      height: 22px
    }

    .sidebar-content .process-step h4 {
      font-size: var(--text-base)
    }

    .sidebar-content .process-step p {
      font-size: var(--text-xs)
    }

    /* Sidebar Tech Section */
    .sidebar-tech {
      margin-top: 2.5rem;
      padding-top: 2rem;
      border-top: 1px solid rgba(16, 185, 129, .12)
    }

    .sidebar-tech-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
      gap: .75rem;
      margin-top: 1.5rem
    }

    .sidebar-tech-card {
      display: flex;
      align-items: center;
      gap: .75rem;
      background: rgba(255, 255, 255, .7);
      border: 1px solid rgba(16, 185, 129, .12);
      border-radius: 14px;
      padding: .75rem 1rem;
      backdrop-filter: blur(8px);
      transition: all .35s cubic-bezier(.22, 1, .36, 1)
    }

    .sidebar-tech-card:hover {
      border-color: var(--accent);
      background: rgba(16, 185, 129, .06);
      transform: translateY(-3px);
      box-shadow: 0 8px 24px -6px rgba(16, 185, 129, .15)
    }

    .sidebar-tech-card .tech-card-icon-mini {
      width: 24px;
      height: 24px;
      flex-shrink: 0
    }

    .sidebar-tech-card .tech-card-name {
      font-size: var(--text-sm);
      font-weight: 600
    }

    /* Sidebar CTA */
    .sidebar-cta {
      margin-top: 2.5rem;
      padding: 2rem;
      background: linear-gradient(135deg, rgba(16, 185, 129, .08), rgba(59, 130, 246, .06));
      border: 1px solid rgba(16, 185, 129, .2);
      border-radius: 24px;
      text-align: center
    }

    .sidebar-cta h3 {
      font-family: var(--ff-display);
      font-size: var(--text-lg);
      font-weight: 700;
      margin-bottom: .75rem;
      background: linear-gradient(135deg, var(--text), var(--accent));
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text
    }

    .sidebar-cta p {
      font-size: var(--text-sm);
      color: var(--text-3);
      margin-bottom: 1.5rem;
      line-height: 1.6
    }

    .sidebar-cta .btn-primary {
      width: 100%;
      justify-content: center;
      padding: 1rem 2rem;
      font-size: var(--text-base);
      border-radius: 14px
    }

    /* Sidebar open animation for children */
    .sidebar-panel .sidebar-content > * {
      opacity: 0;
      transform: translateY(16px);
      transition: all .4s cubic-bezier(.22, 1, .36, 1)
    }

    .sidebar-panel.open .sidebar-content > *:nth-child(1) { opacity: 1; transform: translateY(0); transition-delay: .15s }
    .sidebar-panel.open .sidebar-content > *:nth-child(2) { opacity: 1; transform: translateY(0); transition-delay: .25s }
    .sidebar-panel.open .sidebar-content > *:nth-child(3) { opacity: 1; transform: translateY(0); transition-delay: .35s }
    .sidebar-panel.open .sidebar-content > *:nth-child(4) { opacity: 1; transform: translateY(0); transition-delay: .45s }

    body.sidebar-open {
      overflow: hidden
    }

    /* ── Responsive ── */
    @media(max-width:1024px) {

      .c-cursor,
      .c-cursor-follower {
        display: none !important
      }

      html {
        cursor: auto !important
      }

      a,
      button,
      input,
      textarea,
      select,
      .service-card,
      .process-step,
      .logo,
      .why-point,
      .tech-card-rolling,
      .contact-method {
        cursor: pointer !important
      }

      .nav-links,
      .nav-cta-desk {
        display: none
      }

      .nav-toggle {
        display: flex
      }

      .stats-inner {
        grid-template-columns: repeat(2, 1fr)
      }

      .services-grid {
        grid-template-columns: repeat(2, 1fr)
      }

      .process-steps {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem
      }

      .why-grid {
        grid-template-columns: 1fr
      }

      .why-visual-composition {
        display: none
      }

      .contact-grid {
        grid-template-columns: 1fr
      }
    }

    @media(max-width:640px) {
      .hero-scroll {
        display: none
      }

      .stats-inner {
        grid-template-columns: repeat(2, 1fr);
        gap: 0
      }

      .services-grid {
        grid-template-columns: 1fr;
        border-radius: 14px
      }

      .process-steps {
        grid-template-columns: 1fr
      }

      .contact-form {
        grid-template-columns: 1fr
      }

      .form-full,
      .btn-submit {
        grid-column: span 1
      }

      .hero-actions {
        flex-direction: column;
        align-items: stretch
      }

      .hero-actions .btn {
        justify-content: center
      }
    }
