
    :root {
      --bg: #270444;
      --panel: #200049;
      --muted: #94a3b8;
      --text: #e2e8f0;
      --primary: #0D1838;
      --primary-2: #7C3AED;
      --accent: #a78bfa;
      --ok: #22c55e;
      --danger: #ef4444;
      --radius: 16px;
      --shadow: 0 10px 30px rgba(2, 8, 23, .45);
      --scrollF1: 0px;
      --scrollF2: 0px;
      --navH: 96px;
    }

    * {
      box-sizing: border-box
    }


    nav::after {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      height: 2px;
      background: linear-gradient(90deg, var(--primary-2), #0ea5e9);
      opacity: .55;
    }

    .nav-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      min-height: var(--navH);
      gap: 14px;
    }

    .logo-img {
      width: 180px;
      height: 54px;
      object-fit: contain;
      filter: drop-shadow(0 6px 14px rgba(124, 58, 237, .35));
    }

    .nav-links {
      display: flex;
      align-items: center;
      gap: 22px
    }

    .nav-links a {
      position: relative;
      color: #0b1220;
      opacity: .85;
      font-weight: 500;
      letter-spacing: .02em;
      padding: 10px 6px;
    }

    .nav-links a:hover {
      opacity: 1
    }

    .nav-links a::after {
      content: "";
      position: absolute;
      left: 6px;
      right: 6px;
      bottom: -8px;
      height: 2px;
      border-radius: 2px;
      background: linear-gradient(90deg, var(--primary-2), var(--accent));
      transform: scaleX(0);
      transform-origin: left;
      transition: transform .25s ease;
    }

    .nav-links a:hover::after {
      transform: scaleX(1)
    }

    .nav-cta {
      display: flex;
      align-items: center;
      gap: 10px
    }

    /* Buttons */
    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      padding: 10px 14px;
      border-radius: 12px;
      border: 1px solid rgba(148, 163, 184, .2);
      background: transparent;
      cursor: pointer;
      transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
      user-select: none;
    }

    .btn:hover {
      transform: translateY(-1px);
      background: rgba(148, 163, 184, .10);
    }

    /* Primary (para hero / formularios) */
    .btn-primary {
      border: 0;
      color: #fff;
      font-weight: 600;
      background: linear-gradient(135deg, var(--primary), var(--primary-2));
      background-size: 200% 200%;
      box-shadow: 0 6px 20px rgba(124, 58, 237, .45);
      text-shadow: 0 1px 2px rgba(0, 0, 0, .35);
    }

    .btn-primary:hover {
      background-position: 100% 0;
      box-shadow: 0 0 18px rgba(124, 58, 237, .45), 0 10px 26px rgba(2, 8, 23, .35);
    }

    /* CTA “premium” (Cotiza tu proyecto) */
    .btn-cta {
      border: 0;
      color: #fff;
      font-weight: 600;
      padding: 12px 20px;
      border-radius: 999px;
      background: linear-gradient(135deg, var(--primary), var(--primary-2));
      background-size: 200% 200%;
      box-shadow: 0 0 0 rgba(124, 58, 237, 0), 0 8px 22px rgba(2, 8, 23, .35);
      text-shadow: 0 1px 2px rgba(0, 0, 0, .35);
    }

    .btn-cta:hover {
      background-position: 100% 0;
      transform: translateY(-1px) scale(1.01);
      box-shadow: 0 0 18px rgba(124, 58, 237, .45), 0 12px 28px rgba(2, 8, 23, .45);
    }

    /* Fix hover raro “blanqueado” en móvil:
forzamos que el hover aplique bien al <a> y no quede “lavado” */
    .nav-cta a.btn-cta,
    .nav-cta a.btn-primary {
      filter: none;
      opacity: 1
    }

    .nav-cta a.btn-cta:hover,
    .nav-cta a.btn-primary:hover {
      opacity: 1
    }

    /* Mobile toggle */
    .menu-toggle {
      display: none
    }

    /* Mobile menu */
    .menu-backdrop {
      position: fixed;
      inset: 0;
      z-index: 58;
      background: rgba(11, 18, 32, .55);
      backdrop-filter: blur(4px);
      display: none;
    }

    .mobile-menu {
      position: fixed;
      left: 50%;
      transform: translateX(-50%);
      top: calc(var(--navH) + 12px);
      width: calc(100% - 24px);
      max-width: 520px;
      z-index: 59;
      background: linear-gradient(180deg, rgba(15, 23, 42, .98), rgba(15, 23, 42, .92));
      border-radius: 16px;
      border: 1px solid rgba(148, 163, 184, .18);
      box-shadow: 0 30px 60px rgba(2, 8, 23, .65);
      padding: 18px;
      display: none;
      flex-direction: column;
      gap: 10px;
    }

    .mobile-menu .btn {
      width: 100%;
      justify-content: flex-start;
      background: rgba(148, 163, 184, .06);
      border: 1px solid rgba(148, 163, 184, .16);
      color: #e2e8f0;
      font-weight: 500;
      padding: 14px 16px;
    }

    .mobile-menu .btn:hover {
      background: rgba(148, 163, 184, .12)
    }

    .mobile-menu .sep {
      height: 1px;
      border: 0;
      background: rgba(148, 163, 184, .18);
      margin: 6px 0
    }

    /* se abrirá con una clase en el nav desde JS */
    nav.open~.menu-backdrop {
      display: block
    }

    nav.open~.menu-backdrop+.mobile-menu {
      display: flex
    }

    /* animación entrada */
    @keyframes navIn {
      from {
        opacity: 0;
        transform: translateY(-12px);
      }

      to {
        opacity: 1;
        transform: none;
      }
    }

    html,
    body {
      margin: 0
    }

    body {
      font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, sans-serif;
      /* background: linear-gradient(180deg, #0b1220, #0b1120 35%, #0a1020 100%); */
      color: var(--text);
      line-height: 1.6;
    }

    a {
      color: inherit;
      text-decoration: none
    }

    img {
      max-width: 100%;
      display: block;
      height: auto;
    }

    .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 20px;
      width: 100%;
    }

    /* ====== FIX IMPORTANTE: BACKGROUNDS SIN Z-INDEX NEGATIVO ====== */
    .bg-tech {
      position: fixed;
      inset: 0;
      z-index: 0;
      /* <-- antes estaba negativo */
      pointer-events: none;
      will-change: background-position, transform;
      background: radial-gradient(1200px 600px at calc(10% + var(--scrollF1)) calc(10% + var(--scrollF1)), rgba(14, 165, 233, .18), transparent 60%), radial-gradient(900px 500px at calc(80% + var(--scrollF2)) calc(40% + var(--scrollF2)), rgba(167, 139, 250, .12), transparent 60%), linear-gradient(180deg, #26133b 0%, #0a1020 100%);
      background-attachment: fixed, fixed, scroll;
      filter: saturate(115%);
    }

    .bg-tech::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image: radial-gradient(rgba(148, 163, 184, .14) 1px, transparent 1px);
      background-size: 28px 28px;
      opacity: .22;
    }

    .bg-tech::after {
      content: '';
      position: absolute;
      inset: -10% -10%;
      background-image: linear-gradient(115deg, rgba(14, 165, 233, .14) 0 1px, transparent 1px), linear-gradient(245deg, rgba(167, 139, 250, .10) 0 1px, transparent 1px);
      background-size: 360px 360px, 420px 420px;
      mix-blend-mode: overlay;
      opacity: .35;
      transform: translate3d(calc(var(--scrollF2)), calc(var(--scrollF1)), 0);
    }

    .bg-shapes {
      position: fixed;
      inset: 0;
      z-index: 1;
      /* <-- visible, encima del bg-tech */
      pointer-events: none;
      opacity: .58;
    }

    .bg-code {
      position: fixed;
      inset: auto 0 8% 0;
      z-index: 1;
      color: #cbd5e1;
      font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
      font-size: 12px;
      line-height: 1.6;
      white-space: pre;
      opacity: .06;
      mix-blend-mode: soft-light;
      pointer-events: none;
      transform: translate3d(calc(var(--scrollF1)*0.2), 0, 0);
    }

    /* Contenido SIEMPRE arriba */
    .page {
      position: relative;
      z-index: 2;
    }

    /* NAV */
    nav {
      position: sticky;
      top: 0;
      z-index: 50;
      background: rgba(255, 255, 255, .78);
      backdrop-filter: blur(14px) saturate(140%);
      -webkit-backdrop-filter: blur(14px) saturate(140%);
      border-bottom: 1px solid rgba(124, 58, 237, .18);
      box-shadow: 0 8px 26px rgba(2, 8, 23, .10);
    }

    .nav-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      min-height: 96px;
      padding: 0 20px;
      transition: transform .25s ease;
      gap: 12px;
    }

    .logo-img {
      width: 180px;
      height: 54px;
      object-fit: contain;
      flex-shrink: 0;
    }

    .nav-links {
      display: flex;
      align-items: center;
      gap: 24px;
      flex: 1;
      justify-content: center;
    }

    .nav-cta {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      justify-content: flex-end;
    }

    .btn {
      padding: 10px 14px;
      border-radius: 12px;
      border: 1px solid rgba(148, 163, 184, .2);
      transition: .2s background, .2s transform;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      background: transparent;
      cursor: pointer;
      font-size: 14px;
      font-weight: 500;
    }

    .btn:hover {
      transform: translateY(-1px);
      background: rgba(148, 163, 184, .08);
    }

    .btn-primary {
      background: linear-gradient(135deg, var(--primary), var(--primary-2));
      border: 0;
      color: #fff;
      box-shadow: 0 6px 20px rgba(14, 165, 233, .35);
      background-size: 200% 200%;
      transition: transform .2s ease, background-position .4s ease;
    }

    .btn-primary:hover {
      transform: translateY(-1px) scale(1.01);
      background-position: 100% 0;
    }

    .menu-toggle {
      display: none
    }

    nav a {
      color: #0b1220
    }

    .nav-links a {
      position: relative;
      padding: 8px 10px;
      border: 0;
      font-size: 14px;
    }

    .nav-links a::after {
      content: "";
      position: absolute;
      left: 10px;
      right: 10px;
      bottom: -8px;
      height: 2px;
      background: linear-gradient(90deg, var(--primary), var(--accent));
      transform: scaleX(0);
      transform-origin: left;
      transition: transform .25s ease;
    }

    .nav-links a:hover::after {
      transform: scaleX(1)
    }

    nav.scrolled .nav-inner {
      transform: scale(0.98)
    }

    /* Animations & microinteractions */
    .reveal {
      opacity: 0;
      transform: translateY(12px);
      transition: opacity .7s ease, transform .7s ease;
    }

    .reveal.in {
      opacity: 1;
      transform: none
    }

    @keyframes floaty {

      0%,
      100% {
        transform: translateY(0)
      }

      50% {
        transform: translateY(-8px)
      }
    }

    .hero .card {
      animation: floaty 8s ease-in-out infinite
    }

    .service:hover,
    .work .item:hover,
    .step:hover,
    .quote:hover {
      transform: translateY(-3px);
      box-shadow: 0 12px 30px rgba(2, 8, 23, .45);
    }

    /* HERO */
    .hero {
      padding: 220px 0 80px;
      position: relative;
      overflow: hidden;
    }

    .hero-grid {
      display: grid;
      grid-template-columns: 1.1fr .9fr;
      gap: 40px;
      align-items: center;
    }

    @media (max-width: 768px) {
      .hero-grid {
        grid-template-columns: 1fr;
        gap: 30px;
      }
    }

    .eyebrow {
      display: inline-block;
      padding: 6px 10px;
      border: 1px solid rgba(148, 163, 184, .25);
      border-radius: 999px;
      color: var(--muted);
      font-size: 12px;
      background: rgba(148, 163, 184, .06);
    }

    h1 {
      font-size: clamp(24px, 5vw, 56px);
      line-height: 1.1;
      margin: 14px 0 12px;
      word-break: break-word;
    }

    .lead {
      color: #cbd5e1;
      font-size: clamp(14px, 1.2vw, 18px);
      line-height: 1.65;
    }

    .hero-cta {
      display: flex;
      gap: 12px;
      margin-top: 22px;
      flex-wrap: wrap;
    }

    .card {
      background: linear-gradient(180deg, rgba(255, 255, 255, .02), rgba(255, 255, 255, .01));
      border: 1px solid rgba(148, 163, 184, .16);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
    }

    .stats {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
      margin-top: 24px;
    }

    .stat {
      padding: 14px;
      border-radius: 12px;
      background: rgba(148, 163, 184, .06);
      border: 1px solid rgba(148, 163, 184, .12);
      text-align: center;
    }

    .stat b {
      font-size: 20px
    }

    section {
      padding: 64px 0
    }

    .section-title {
      font-size: clamp(20px, 5vw, 28px);
      margin: 0 0 14px;
      line-height: 1.2;
    }

    .muted {
      color: var(--muted)
    }

    .grid {
      display: grid;
      gap: 20px
    }

    .grid-3 {
      grid-template-columns: repeat(3, 1fr)
    }

    .grid-2 {
      grid-template-columns: repeat(2, 1fr)
    }

    .service {
      padding: 18px;
      border-radius: 16px;
      background: linear-gradient(180deg, rgba(15, 23, 42, .8), rgba(15, 23, 42, .6));
      border: 1px solid rgba(148, 163, 184, .14);
      transition: .2s transform;
      display: flex;
      flex-direction: column;
      height: 100%;
    }

    .service h3 {
      margin: 10px 0 8px;
      font-size: clamp(16px, 2vw, 20px);
    }

    .service p {
      color: #cbd5e1;
      margin: 0;
      flex-grow: 1;
    }

    .work {
      display: grid;
      grid-template-columns: repeat(12, 1fr);
      gap: 16px;
    }

    .work .item {
      grid-column: span 4;
      padding: 12px;
      border-radius: 16px;
      background: linear-gradient(180deg, rgba(15, 23, 42, .8), rgba(15, 23, 42, .6));
      border: 1px solid rgba(148, 163, 184, .12);
      transition: .2s transform;
    }

    .tags {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 10px
    }

    .tag {
      font-size: 12px;
      padding: 6px 10px;
      border-radius: 999px;
      background: rgba(148, 163, 184, .08);
      border: 1px solid rgba(148, 163, 184, .18);
    }

    .steps {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 16px;
    }

    .step {
      padding: 18px;
      border-radius: 16px;
      background: linear-gradient(180deg, rgba(15, 23, 42, .8), rgba(15, 23, 42, .6));
      border: 1px solid rgba(148, 163, 184, .14);
      transition: .2s transform;
    }

    .step .num {
      width: 34px;
      height: 34px;
      border-radius: 10px;
      background: linear-gradient(135deg, var(--primary), var(--accent));
      display: grid;
      place-items: center;
      font-weight: 700;
      margin-bottom: 8px;
    }

    .quotes {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
    }

    .quote {
      padding: 18px;
      border-radius: 16px;
      background: linear-gradient(180deg, rgba(15, 23, 42, .8), rgba(15, 23, 42, .6));
      border: 1px solid rgba(148, 163, 184, .14);
      transition: .2s transform;
    }

    .quote .who {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-top: 10px;
      color: #cbd5e1
    }

    .avatar {
      width: 36px;
      height: 36px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--primary), var(--primary-2))
    }

    /* ========================= CTA PREMIUM UNIFICADO ========================= */
    .btn-cta {
      background: linear-gradient(135deg, var(--primary), var(--primary-2));
      color: #ffffff;
      border: 0;
      font-weight: 600;
      padding: 12px 20px;
      border-radius: 999px;
      background-size: 200% 200%;
      transition: transform .2s ease, box-shadow .2s ease, background-position .4s ease;
      box-shadow: 0 0 0 rgba(124, 58, 237, 0), 0 8px 22px rgba(2, 8, 23, .35);
      text-shadow: 0 1px 2px rgba(0, 0, 0, .35);
      white-space: nowrap;
    }

    .btn-cta:hover {
      background-color: #270444;
      background-position: 100% 0;
      transform: translateY(-1px) scale(1.01);
      box-shadow: 0 0 18px rgba(124, 58, 237, .45), 0 12px 28px rgba(2, 8, 23, .45);
      text-shadow: 0 1px 3px rgba(0, 0, 0, .45);
    }

    .btn-cta:active {
      transform: translateY(0) scale(.98);
      box-shadow: 0 0 12px rgba(124, 58, 237, .35), 0 6px 18px rgba(2, 8, 23, .45);
    }

    .contact {
      display: grid;
      grid-template-columns: 1.1fr .9fr;
      gap: 24px
    }

    form.card {
      padding: 18px
    }

    .input {
      width: 100%;
      padding: 12px 14px;
      border-radius: 12px;
      border: 1px solid rgba(148, 163, 184, .18);
      background: #0b1220;
      color: var(--text);
    }

    .input::placeholder {
      color: #94a3b8
    }

    textarea.input {
      min-height: 140px;
      resize: vertical
    }

    footer {
      padding: 48px 0;
      border-top: 1px solid rgba(2, 8, 23, .06);
      background: #ffffff;
      color: #0b1220;
    }

    footer a {
      color: #0b1220
    }

    .footer-grid {
      display: grid;
      grid-template-columns: 2fr 1fr 1fr 1fr;
      gap: 20px;
      align-items: flex-start;
    }

    .footer-title {
      font-weight: 700;
      font-size: 14px;
      text-transform: uppercase;
      letter-spacing: .04em;
    }

    .socials {
      display: flex;
      gap: 10px;
      margin-top: 12px
    }

    .socials a {
      width: 38px;
      height: 38px;
      border-radius: 10px;
      border: 1px solid rgba(2, 8, 23, .08);
      display: grid;
      place-items: center;
      transition: .2s transform, .2s background;
    }

    .socials a:hover {
      transform: translateY(-2px);
      background: rgba(2, 8, 23, .04)
    }

    .newsletter {
      margin-top: 12px;
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
    }

    .newsletter input {
      flex: 1;
      padding: 10px 12px;
      border-radius: 10px;
      border: 1px solid rgba(2, 8, 23, .12)
    }

    .newsletter button {
      padding: 10px 14px;
      border-radius: 10px;
      border: 0;
      background: linear-gradient(135deg, var(--primary), var(--primary-2));
      color: #fff
    }

    .small {
      font-size: 13px
    }

    .copyright {
      margin-top: 18px;
      color: var(--muted);
      font-size: 12px
    }

    /* ========================= MOBILE MENU (NAV REAL) ========================= */
    .menu-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(11, 18, 32, .55);
      backdrop-filter: blur(4px);
      -webkit-backdrop-filter: blur(4px);
      display: none;
      z-index: 58;
    }

    .mobile-menu {
      position: fixed;
      left: 0;
      right: 0;
      top: var(--navH);
      width: 100%;
      max-height: calc(100vh - var(--navH));
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
      background: linear-gradient(180deg, rgba(15, 23, 42, .98), rgba(15, 23, 42, .92));
      border-bottom: 1px solid rgba(148, 163, 184, .18);
      box-shadow: 0 10px 40px rgba(2, 8, 23, .65);
      padding: 12px;
      display: none;
      flex-direction: column;
      gap: 8px;
      z-index: 59;
    }

    /* items del menú */
    .mobile-menu .btn {
      justify-content: flex-start;
      background: rgba(148, 163, 184, .06);
      border: 1px solid rgba(148, 163, 184, .16);
      color: #e2e8f0;
      font-weight: 500;
      padding: 14px 16px;
    }

    /* hover */
    .mobile-menu .btn:hover {
      background: rgba(148, 163, 184, .12);
    }

    /* separador */
    .mobile-menu .sep {
      height: 1px;
      background: rgba(148, 163, 184, .18);
      margin: 6px 0;
    }

    /* CTA final */
    .mobile-menu .btn-primary {
      justify-content: center;
      font-weight: 600;
      margin-top: 8px;
      padding: 14px 16px;
      background: linear-gradient(135deg, var(--primary), var(--primary-2));
      box-shadow: 0 0 0 rgba(124, 58, 237, 0), 0 10px 28px rgba(124, 58, 237, .55);
    }

    /* animación entrada */
    nav.open+.menu-backdrop+.mobile-menu {
      display: flex;
      animation: mobileDrop .25s ease-out;
    }

    /* ========================= CTA FIX LEGIBILIDAD ========================= */
    .btn-primary {
      color: #ffffff;
      text-shadow: 0 1px 2px rgba(0, 0, 0, .35);
    }

    /* hover refinado */
    .btn-primary:hover {
      background-position: 100% 0;
      transform: translateY(-1px) scale(1.01);
      /* glow controlado */
      box-shadow: 0 0 18px rgba(124, 58, 237, .45), 0 10px 26px rgba(2, 8, 23, .35);
      /* refuerzo visual */
      text-shadow: 0 1px 3px rgba(0, 0, 0, .45);
    }

    @keyframes mobileDrop {
      from {
        opacity: 0;
        transform: translateX(-50%) translateY(-10px);
      }

      to {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
      }
    }

    @keyframes drop {
      from {
        opacity: 0;
        transform: translateY(-8px)
      }

      to {
        opacity: 1;
        transform: none
      }
    }

    @media (max-width: 980px) {
      .nav-links {
        display: none
      }

      .menu-toggle {
        display: inline-flex
      }

      .logo-img {
        width: 140px;
        height: 42px;
      }

      .hero {
        padding-top: 140px;
        padding-bottom: 60px;
      }

      .nav-cta .btn {
        padding: 8px 12px;
        font-size: 13px;
      }

      .nav-cta .btn:not(.btn-cta) {
        display: none;
      }

      .hero-grid,
      .contact {
        grid-template-columns: 1fr
      }

      .grid-3 {
        grid-template-columns: repeat(2, 1fr)
      }

      .grid-2,
      .steps,
      .quotes {
        grid-template-columns: 1fr
      }

      .work .item {
        grid-column: span 6
      }

      .footer-grid {
        grid-template-columns: 1fr 1fr
      }
    }

    @media (max-width: 768px) {
      .hero-grid {
        grid-template-columns: 1fr;
        gap: 30px;
      }

      .contact {
        grid-template-columns: 1fr;
        gap: 18px;
      }

      .grid-3 {
        grid-template-columns: repeat(2, 1fr)
      }

      .steps {
        grid-template-columns: repeat(2, 1fr)
      }

      .quotes {
        grid-template-columns: repeat(2, 1fr)
      }

      .footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: 16px;
      }

      .hero {
        padding-top: 120px;
      }

      .logo-img {
        width: 120px;
        height: 36px;
      }

      .card {
        padding: 14px;
      }

      form.card {
        padding: 14px;
      }

      .input {
        padding: 10px 12px;
        font-size: 14px;
      }

      textarea.input {
        min-height: 120px;
      }

      section {
        padding: 48px 0;
      }
    }

    @media (max-width: 640px) {
      .nav-inner {
        min-height: 80px;
        padding: 0 16px;
        gap: 8px;
      }

      .logo-img {
        width: 100px;
        height: 30px;
      }

      .menu-toggle {
        padding: 8px 10px;
      }

      .hero {
        padding-top: 100px;
        padding-bottom: 40px;
      }

      .grid-3 {
        grid-template-columns: 1fr
      }

      .grid-2 {
        grid-template-columns: 1fr
      }

      .work .item {
        grid-column: span 12
      }

      .footer-grid {
        grid-template-columns: 1fr
      }

      .steps {
        grid-template-columns: 1fr
      }

      .quotes {
        grid-template-columns: 1fr
      }

      .stat {
        padding: 12px;
      }

      .stat b {
        font-size: 18px;
      }

      .stats {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
      }

      .stats .stat:last-child {
        grid-column: span 2;
      }

      .card {
        padding: 12px;
      }

      form.card {
        padding: 12px;
      }

      .input {
        padding: 10px 12px;
        font-size: 14px;
        border-radius: 8px;
      }

      textarea.input {
        min-height: 100px;
      }

      .service,
      .step,
      .quote {
        padding: 14px;
      }

      .step .num {
        width: 30px;
        height: 30px;
        font-size: 14px;
      }

      footer {
        padding: 32px 0;
      }

      .footer-title {
        font-size: 12px;
      }

      .socials {
        gap: 8px;
      }

      .socials a {
        width: 36px;
        height: 36px;
      }

      .newsletter {
        margin-top: 16px;
        flex-direction: column;
        gap: 8px;
      }

      .newsletter input,
      .newsletter button {
        width: 100%;
        padding: 10px 12px;
        font-size: 13px;
      }

      section {
        padding: 36px 0;
      }
    }

    @media (max-width: 480px) {
      .nav-inner {
        min-height: 72px;
        padding: 0 12px;
      }

      .logo-img {
        width: 90px;
        height: 27px;
      }

      h1 {
        font-size: clamp(18px, 4vw, 28px);
      }

      .section-title {
        font-size: clamp(18px, 4vw, 24px);
      }

      .lead {
        font-size: 13px;
      }

      .small {
        font-size: 12px;
      }

      .hero {
        padding-top: 90px;
        padding-bottom: 30px;
      }

      .hero-cta {
        gap: 8px;
        flex-direction: column;
      }

      .hero-cta .btn {
        padding: 10px 12px;
        font-size: 13px;
        width: 100%;
      }

      .container {
        padding: 0 16px;
      }

      .eyebrow {
        font-size: 11px;
      }

      .stat {
        padding: 10px;
      }

      .stat b {
        font-size: 16px;
      }

      .tag {
        font-size: 11px;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      .hero .card {
        animation: none
      }

      .reveal {
        transition: none
      }
    }
