:root{
      --primary:#001F3F;
      --secondary:#B8860B;
      --accent:#4682B4;
      --white:#FFFFFF;
      --bg:#F8F9FA;
      --line:#E9ECEF;
      --text:#343A40;
      --muted:#6C757D;
      --shadow:0 18px 50px rgba(0,31,63,.12);
      --radius:20px;
      --radius-sm:14px;
      --container:1200px;
    }
    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      margin:0;
      font-family:'Inter',sans-serif;
      color:var(--text);
      background:var(--white);
      line-height:1.65;
      -webkit-font-smoothing:antialiased;
      text-rendering:optimizeLegibility;
    }
    img{max-width:100%;display:block}
    a{text-decoration:none;color:inherit}
    button,input,textarea{font:inherit}
    .container{
      width:min(var(--container),calc(100% - 40px));
      margin:0 auto;
    }
    .section{
      padding:96px 0;
      position:relative;
    }
    .section.alt{background:var(--bg)}
    .eyebrow{
      display:inline-flex;
      align-items:center;
      gap:10px;
      color:var(--secondary);
      text-transform:uppercase;
      letter-spacing:.14em;
      font-size:.78rem;
      font-weight:700;
      margin-bottom:16px;
    }
    .eyebrow::before{
      content:'';
      width:34px;
      height:2px;
      background:var(--secondary);
      border-radius:999px;
    }
    .section-title{
      font-size:clamp(2rem,3vw,3rem);
      line-height:1.1;
      margin:0 0 16px;
      color:var(--primary);
      letter-spacing:-.03em;
    }
    .section-lead{
      max-width:760px;
      margin:0 auto 44px;
      color:var(--muted);
      font-size:1.05rem;
    }
    .grid{
      display:grid;
      gap:24px;
    }
    .btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      padding:16px 24px;
      border-radius:999px;
      font-weight:700;
      transition:.25s ease;
      border:1px solid transparent;
      cursor:pointer;
      white-space:nowrap;
    }
    .btn-primary{
      background:var(--secondary);
      color:var(--white);
      box-shadow:0 10px 25px rgba(184,134,11,.25);
    }
    .btn-primary:hover{transform:translateY(-2px);filter:brightness(.97)}
    .btn-secondary{
      background:transparent;
      color:var(--white);
      border-color:rgba(255,255,255,.75);
      backdrop-filter:blur(8px);
    }
    .btn-secondary:hover{
      background:var(--white);
      color:var(--primary);
      border-color:var(--white);
      transform:translateY(-2px);
    }
    .btn-dark{
      background:var(--primary);
      color:var(--white);
    }
    .btn-dark:hover{transform:translateY(-2px);opacity:.96}
    .card{
      background:var(--white);
      border:1px solid var(--line);
      border-radius:var(--radius);
      box-shadow:0 10px 40px rgba(0,0,0,.04);
    }

    /* Header */
    .header{
      position:fixed;
      top:0;
      left:0;
      right:0;
      z-index:1000;
      background:rgba(0,31,63,.88);
      backdrop-filter:blur(14px);
      border-bottom:1px solid rgba(255,255,255,.08);
    }
    .nav{
      min-height:84px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:18px;
    }
    .brand{
      display:flex;
      align-items:center;
      gap:14px;
      min-width:0;
    }
    .brand img{
      height:48px;
      width:auto;
      object-fit:contain;
    }
    .brand-text{
      color:rgba(255,255,255,.92);
      font-weight:700;
      letter-spacing:.02em;
      font-size:.95rem;
      display:none;
    }
    .menu{
      display:flex;
      align-items:center;
      gap:28px;
      list-style:none;
      margin:0;
      padding:0;
    }
    .menu a{
      color:rgba(255,255,255,.9);
      font-weight:600;
      font-size:.96rem;
      position:relative;
      padding:8px 0;
    }
    .menu a::after{
      content:'';
      position:absolute;
      left:0;
      bottom:0;
      width:0;
      height:2px;
      background:var(--secondary);
      transition:.25s ease;
      border-radius:999px;
    }
    .menu a:hover::after,.menu a.active::after{width:100%}
    .nav-actions{
      display:flex;
      align-items:center;
      gap:12px;
    }
    .nav-cta{
      padding:12px 18px;
      border-radius:999px;
      background:var(--secondary);
      color:#fff;
      font-weight:700;
      font-size:.92rem;
      box-shadow:0 10px 24px rgba(184,134,11,.22);
    }
    .burger{
      display:none;
      width:46px;
      height:46px;
      border-radius:14px;
      border:1px solid rgba(255,255,255,.15);
      background:rgba(255,255,255,.06);
      color:#fff;
      align-items:center;
      justify-content:center;
      cursor:pointer;
    }
    .burger i{font-size:1.1rem}

    /* Hero */
    .hero{
      padding-top:120px;
      padding-bottom:52px;
      background:
        radial-gradient(circle at top left, rgba(70,130,180,.22), transparent 35%),
        radial-gradient(circle at 85% 20%, rgba(184,134,11,.18), transparent 28%),
        linear-gradient(135deg, #001F3F 0%, #0B2E57 55%, #0E3A6A 100%);
      color:#fff;
      overflow:hidden;
      position:relative;
    }
    .hero::before,
    .hero::after{
      content:'';
      position:absolute;
      border-radius:999px;
      pointer-events:none;
      opacity:.3;
    }
    .hero::before{
      width:340px;
      height:340px;
      border:1px solid rgba(255,255,255,.18);
      right:-110px;
      top:120px;
      transform:rotate(18deg);
    }
    .hero::after{
      width:240px;
      height:240px;
      border:1px dashed rgba(255,255,255,.16);
      right:110px;
      top:54px;
    }
    .hero-grid{
      display:grid;
      grid-template-columns:1.1fr .9fr;
      gap:44px;
      align-items:center;
      min-height:calc(100vh - 120px);
    }
    .hero-copy h1{
      font-size:clamp(2.5rem,5vw,4.6rem);
      line-height:1.03;
      margin:0 0 20px;
      letter-spacing:-.05em;
      max-width:12ch;
    }
    .hero-copy p{
      font-size:1.12rem;
      color:rgba(255,255,255,.86);
      max-width:60ch;
      margin:0 0 30px;
    }
    .hero-actions{
      display:flex;
      flex-wrap:wrap;
      gap:14px;
      margin-bottom:30px;
    }
    .hero-points{
      display:flex;
      flex-wrap:wrap;
      gap:14px;
      margin-top:22px;
    }
    .pill{
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding:12px 16px;
      border-radius:999px;
      background:rgba(255,255,255,.08);
      border:1px solid rgba(255,255,255,.12);
      color:rgba(255,255,255,.92);
      font-size:.92rem;
    }
    .hero-visual{
      position:relative;
      min-height:540px;
      display:flex;
      align-items:center;
      justify-content:center;
    }
    .visual-card{
      width:min(100%,520px);
      aspect-ratio:1/1;
      border-radius:34px;
      background:
        radial-gradient(circle at 30% 30%, rgba(255,255,255,.18), transparent 28%),
        radial-gradient(circle at 70% 65%, rgba(184,134,11,.16), transparent 26%),
        linear-gradient(145deg, rgba(255,255,255,.09), rgba(255,255,255,.03));
      border:1px solid rgba(255,255,255,.14);
      box-shadow:0 30px 80px rgba(0,0,0,.22);
      backdrop-filter:blur(12px);
      position:relative;
      overflow:hidden;
    }
    .visual-card::before,
    .visual-card::after{
      content:'';
      position:absolute;
      border-radius:24px;
      border:1px solid rgba(255,255,255,.14);
    }
    .visual-card::before{
      width:72%;
      height:72%;
      top:14%;
      left:14%;
      transform:rotate(10deg);
    }
    .visual-card::after{
      width:52%;
      height:52%;
      top:24%;
      left:24%;
      transform:rotate(-12deg);
    }
    .orbit{
      position:absolute;
      inset:0;
      display:grid;
      place-items:center;
    }
    .orbit .dot{
      position:absolute;
      width:14px;
      height:14px;
      border-radius:50%;
      background:var(--secondary);
      box-shadow:0 0 0 10px rgba(184,134,11,.12);
    }
    .orbit .dot.dot1{top:18%;left:18%}
    .orbit .dot.dot2{top:78%;left:20%;background:#84B6E6}
    .orbit .dot.dot3{top:72%;right:18%;background:#fff}
    .orbit .dot.dot4{top:22%;right:24%;background:#84B6E6}
    .network{
      position:absolute;
      inset:0;
      background:
        linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px),
        linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px);
      background-size:52px 52px;
      mask-image:radial-gradient(circle at center, black 30%, transparent 75%);
      opacity:.7;
    }
    .network-lines{
      position:absolute;
      inset:0;
      overflow:hidden;
    }
    .network-lines span{
      position:absolute;
      display:block;
      background:linear-gradient(90deg, transparent, rgba(255,255,255,.36), transparent);
      height:1px;
      width:78%;
      left:11%;
    }
    .network-lines span:nth-child(1){top:28%;transform:rotate(26deg)}
    .network-lines span:nth-child(2){top:42%;transform:rotate(-18deg);width:62%;left:20%}
    .network-lines span:nth-child(3){top:58%;transform:rotate(22deg);width:72%;left:14%}
    .network-lines span:nth-child(4){top:70%;transform:rotate(-12deg);width:58%;left:24%}
    .hero-note{
      position:absolute;
      left:24px;
      bottom:24px;
      right:24px;
      padding:16px 18px;
      border-radius:20px;
      background:rgba(0,31,63,.42);
      border:1px solid rgba(255,255,255,.12);
      color:rgba(255,255,255,.9);
      backdrop-filter:blur(10px);
      font-size:.95rem;
    }

    /* What we do */
    .services-grid{
      grid-template-columns:repeat(4,1fr);
    }
    .service-item{
      padding:30px;
      transition:.25s ease;
      min-height:100%;
    }
    .service-item:hover{
      transform:translateY(-6px);
      box-shadow:var(--shadow);
      border-color:rgba(70,130,180,.22);
    }
    .service-icon{
      width:58px;
      height:58px;
      border-radius:18px;
      display:grid;
      place-items:center;
      background:linear-gradient(135deg, rgba(70,130,180,.12), rgba(184,134,11,.12));
      color:var(--primary);
      font-size:1.35rem;
      margin-bottom:18px;
    }
    .service-item h3{
      margin:0 0 12px;
      color:var(--primary);
      font-size:1.08rem;
      line-height:1.3;
    }
    .service-item p{margin:0;color:var(--muted)}
    .section-footer{
      display:flex;
      justify-content:center;
      margin-top:28px;
    }
    .link-arrow{
      display:inline-flex;
      align-items:center;
      gap:10px;
      color:var(--primary);
      font-weight:700;
    }

    /* Process */
    .process{
      display:grid;
      grid-template-columns:repeat(4,1fr);
      gap:16px;
      margin-top:12px;
    }
    .step{
      padding:26px 22px;
      position:relative;
      background:var(--white);
    }
    .step .num{
      width:42px;
      height:42px;
      border-radius:14px;
      display:grid;
      place-items:center;
      background:rgba(184,134,11,.11);
      color:var(--secondary);
      font-weight:800;
      margin-bottom:16px;
    }
    .step h3{margin:0 0 10px;color:var(--primary)}
    .step p{margin:0;color:var(--muted)}
    .step:not(:last-child)::after{
      content:'';
      position:absolute;
      right:-8px;
      top:50%;
      width:16px;
      height:2px;
      background:var(--line);
      transform:translateY(-50%);
    }

    /* Social proof */
    .stats-grid{
      grid-template-columns:repeat(4,1fr);
    }
    .stat{
      padding:28px 24px;
      text-align:center;
    }
    .stat strong{
      display:block;
      font-size:2.3rem;
      line-height:1;
      color:var(--primary);
      margin-bottom:10px;
    }
    .stat span{color:var(--muted);font-weight:500}
    .logos{
      display:grid;
      grid-template-columns:repeat(5,1fr);
      gap:18px;
      margin-top:24px;
    }
    .logo-chip{
      padding:16px;
      border-radius:16px;
      background:linear-gradient(180deg, #fff, #fafbfc);
      border:1px solid var(--line);
      text-align:center;
      color:#94A3B8;
      font-weight:700;
      letter-spacing:.02em;
    }

    /* Sectors */
    .sector-grid{
      grid-template-columns:repeat(5,1fr);
    }
    .sector{
      padding:26px 22px;
      text-align:center;
      transition:.25s ease;
    }
    .sector:hover{
      transform:translateY(-5px);
      box-shadow:var(--shadow);
      border-color:rgba(70,130,180,.2);
    }
    .sector .service-icon{
      margin:0 auto 16px;
    }
    .sector h3{margin:0 0 10px;color:var(--primary)}
    .sector p{margin:0;color:var(--muted);font-size:.96rem}

    /* CTA */
    .cta-band{
      background:
        radial-gradient(circle at left top, rgba(184,134,11,.14), transparent 25%),
        linear-gradient(135deg, var(--primary), #0A315D 100%);
      color:#fff;
      border-radius:36px;
      padding:46px;
      overflow:hidden;
      position:relative;
    }
    .cta-band::after{
      content:'';
      position:absolute;
      inset:auto -120px -120px auto;
      width:280px;
      height:280px;
      border-radius:50%;
      border:1px solid rgba(255,255,255,.12);
    }
    .cta-band h2{
      margin:0 0 14px;
      font-size:clamp(1.8rem,3vw,2.7rem);
      line-height:1.12;
      max-width:16ch;
    }
    .cta-band p{
      margin:0 0 24px;
      color:rgba(255,255,255,.84);
      max-width:64ch;
    }
    .cta-band .btn-secondary{border-color:rgba(255,255,255,.8)}
    .cta-band .btn-secondary:hover{border-color:#fff}

    /* About */
    .about-grid{
      grid-template-columns:1.1fr .9fr;
      align-items:start;
    }
    .about-box{
      padding:34px;
    }
    .about-box p{color:var(--muted);margin:0 0 18px}
    .feature-list{
      display:grid;
      gap:14px;
      margin-top:18px;
    }
    .feature{
      display:flex;
      gap:14px;
      align-items:flex-start;
      padding:16px 0;
      border-top:1px solid var(--line);
    }
    .feature:first-child{border-top:none;padding-top:0}
    .feature i{
      color:var(--secondary);
      margin-top:4px;
      font-size:1.1rem;
    }
    .feature strong{
      display:block;
      color:var(--primary);
      margin-bottom:4px;
    }
    .feature span{color:var(--muted)}
    .about-visual{
      padding:24px;
      position:relative;
      min-height:480px;
      overflow:hidden;
      background:
        radial-gradient(circle at 20% 20%, rgba(70,130,180,.12), transparent 22%),
        radial-gradient(circle at 80% 80%, rgba(184,134,11,.14), transparent 22%),
        linear-gradient(180deg, #fff, #f7f9fc);
    }
    .about-visual .tile{
      position:absolute;
      border-radius:26px;
      border:1px solid var(--line);
      box-shadow:0 16px 40px rgba(0,0,0,.04);
      background:rgba(255,255,255,.92);
      backdrop-filter:blur(8px);
    }
    .about-visual .tile.t1{width:68%;height:36%;left:8%;top:8%}
    .about-visual .tile.t2{width:48%;height:28%;right:7%;top:26%}
    .about-visual .tile.t3{width:58%;height:26%;left:18%;bottom:12%}
    .about-visual .tile::before{
      content:'';
      position:absolute;
      inset:18px;
      border-radius:18px;
      background:
        linear-gradient(90deg, rgba(0,31,63,.92), rgba(70,130,180,.78));
      opacity:.92;
    }
    .about-visual .tile.t2::before{
      background:linear-gradient(135deg, rgba(184,134,11,.92), rgba(0,31,63,.88));
    }
    .about-visual .tile.t3::before{
      background:linear-gradient(135deg, rgba(70,130,180,.88), rgba(0,31,63,.94));
    }
    .about-visual .floating{
      position:absolute;
      right:24px;
      top:24px;
      width:120px;
      height:120px;
      border-radius:32px;
      background:linear-gradient(135deg, rgba(184,134,11,.95), rgba(70,130,180,.95));
      box-shadow:0 18px 40px rgba(0,0,0,.12);
      transform:rotate(12deg);
    }

    /* Services detail */
    .service-details{
      display:grid;
      gap:18px;
      margin-top:26px;
    }
    .accordion{
      border:1px solid var(--line);
      border-radius:var(--radius);
      overflow:hidden;
      background:var(--white);
    }
    .accordion-item + .accordion-item{border-top:1px solid var(--line)}
    .accordion-header{
      width:100%;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:16px;
      padding:22px 22px;
      background:transparent;
      border:none;
      cursor:pointer;
      color:var(--primary);
      font-weight:800;
      text-align:left;
    }
    .accordion-header i{
      color:var(--secondary);
      transition:.25s ease;
    }
    .accordion-item.active .accordion-header i{transform:rotate(180deg)}
    .accordion-content{
      max-height:0;
      overflow:hidden;
      transition:max-height .3s ease;
      padding:0 22px;
      color:var(--muted);
    }
    .accordion-content .inner{
      padding:0 0 22px;
    }
    .tech-tags{
      display:flex;
      flex-wrap:wrap;
      gap:10px;
      margin-top:18px;
    }
    .tag{
      padding:9px 12px;
      border-radius:999px;
      background:#F3F6FA;
      border:1px solid var(--line);
      color:var(--primary);
      font-weight:600;
      font-size:.88rem;
    }

    /* Cases */
    .case-grid{
      grid-template-columns:repeat(3,1fr);
    }
    .case{
      overflow:hidden;
    }
    .case-cover{
      padding:24px;
      min-height:160px;
      background:
        radial-gradient(circle at 25% 20%, rgba(255,255,255,.22), transparent 24%),
        linear-gradient(135deg, #001F3F, #0F4C81 55%, #2B6EA8);
      color:#fff;
    }
    .case-cover.secondary{
      background:linear-gradient(135deg, #0A315D, #B8860B);
    }
    .case-cover.accent{
      background:linear-gradient(135deg, #0E3A6A, #4682B4);
    }
    .case-body{padding:24px}
    .case-body h3{margin:0 0 10px;color:var(--primary)}
    .case-body p{margin:0 0 16px;color:var(--muted)}
    .case-list{
      padding:0;
      margin:0;
      list-style:none;
      display:grid;
      gap:10px;
    }
    .case-list li{
      display:flex;
      gap:10px;
      align-items:flex-start;
      color:var(--text);
    }
    .case-list i{color:var(--secondary);margin-top:4px}

    /* Blog */
    .blog-grid{
      grid-template-columns:repeat(4,1fr);
    }
    .post{
      overflow:hidden;
    }
    .post-thumb{
      height:180px;
      background:
        radial-gradient(circle at 20% 20%, rgba(255,255,255,.2), transparent 20%),
        linear-gradient(135deg, rgba(0,31,63,.95), rgba(70,130,180,.9));
      position:relative;
    }
    .post-thumb::after{
      content:'';
      position:absolute;
      inset:22px;
      border-radius:18px;
      border:1px solid rgba(255,255,255,.16);
    }
    .post-body{padding:22px}
    .post-meta{
      display:flex;
      gap:12px;
      color:var(--muted);
      font-size:.88rem;
      margin-bottom:10px;
    }
    .post-body h3{
      margin:0 0 10px;
      color:var(--primary);
      font-size:1.05rem;
    }
    .post-body p{margin:0 0 16px;color:var(--muted)}
    .read-more{
      display:inline-flex;
      align-items:center;
      gap:8px;
      color:var(--primary);
      font-weight:700;
    }

    /* Contact */
    .contact-grid{
      grid-template-columns:.95fr 1.05fr;
      align-items:start;
    }
    .contact-info{
      padding:34px;
      background:
        radial-gradient(circle at top right, rgba(184,134,11,.08), transparent 22%),
        linear-gradient(180deg, #fff, #f9fbfd);
    }
    .contact-info h3{
      color:var(--primary);
      margin:0 0 14px;
      font-size:1.5rem;
    }
    .contact-info p{color:var(--muted);margin:0 0 18px}
    .contact-list{
      display:grid;
      gap:14px;
      margin-top:22px;
    }
    .contact-row{
      display:flex;
      gap:14px;
      align-items:flex-start;
      padding:16px 0;
      border-top:1px solid var(--line);
    }
    .contact-row:first-child{border-top:none;padding-top:0}
    .contact-row i{
      width:42px;height:42px;border-radius:14px;
      display:grid;place-items:center;
      background:rgba(184,134,11,.11);
      color:var(--secondary);
      flex:0 0 auto;
    }
    .contact-row strong{display:block;color:var(--primary);margin-bottom:4px}
    .contact-row span{color:var(--muted)}
    .contact-form{
      padding:34px;
    }
    .form-grid{
      display:grid;
      grid-template-columns:repeat(2,1fr);
      gap:16px;
    }
    .field{display:grid;gap:8px}
    .field.full{grid-column:1 / -1}
    .field label{
      font-size:.92rem;
      font-weight:700;
      color:var(--primary);
    }
    .field input,.field textarea, .field select{
      width:100%;
      border:1px solid var(--line);
      border-radius:14px;
      padding:15px 16px;
      outline:none;
      background:#fff;
      color:var(--text);
      transition:.2s ease;
    }
    .field input:focus,.field textarea:focus,.field select:focus{
      border-color:rgba(70,130,180,.55);
      box-shadow:0 0 0 4px rgba(70,130,180,.08);
    }
    .field textarea{min-height:150px;resize:vertical}
    .form-actions{
      display:flex;
      gap:14px;
      flex-wrap:wrap;
      margin-top:20px;
    }

    /* Footer */
    .footer{
      padding:34px 0;
      background:var(--primary);
      color:rgba(255,255,255,.86);
      border-top:1px solid rgba(255,255,255,.08);
    }
    .footer-grid{
      display:grid;
      grid-template-columns:1.2fr .8fr .8fr;
      gap:28px;
      align-items:start;
    }
    .footer-brand img{height:52px;margin-bottom:16px}
    .footer h4{
      margin:0 0 14px;
      color:#fff;
      font-size:1rem;
    }
    .footer p{margin:0;color:rgba(255,255,255,.72)}
    .footer-links{
      display:grid;
      gap:10px;
    }
    .footer-links a{
      color:rgba(255,255,255,.78);
    }
    .footer-links a:hover{color:#fff}
    .socials{
      display:flex;
      gap:12px;
      flex-wrap:wrap;
    }
    .socials a{
      width:42px;height:42px;border-radius:14px;
      display:grid;place-items:center;
      background:rgba(255,255,255,.08);
      color:#fff;
    }
    .socials a:hover{background:rgba(255,255,255,.16)}
    .footer-bottom{
      margin-top:28px;
      padding-top:18px;
      border-top:1px solid rgba(255,255,255,.08);
      display:flex;
      justify-content:space-between;
      gap:16px;
      flex-wrap:wrap;
      color:rgba(255,255,255,.64);
      font-size:.92rem;
    }

    /* Floating WhatsApp */
    .whatsapp{
      position:fixed;
      right:22px;
      bottom:22px;
      z-index:1001;
      width:62px;
      height:62px;
      border-radius:18px;
      display:grid;
      place-items:center;
      background:#25D366;
      color:#fff;
      box-shadow:0 20px 35px rgba(37,211,102,.32);
    }
    .whatsapp i{font-size:1.5rem}

    /* Reveal */
    .reveal{
      opacity:0;
      transform:translateY(20px);
      transition:opacity .7s ease, transform .7s ease;
    }
    .reveal.visible{
      opacity:1;
      transform:none;
    }

    /* Responsive */
    @media (max-width: 1100px){
      .hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr}
      .hero-visual{min-height:460px}
      .services-grid,.process,.stats-grid,.sector-grid,.case-grid,.blog-grid,.logos{grid-template-columns:repeat(2,1fr)}
      .footer-grid{grid-template-columns:1fr 1fr}
    }
    @media (max-width: 780px){
      .section{padding:76px 0}
      .nav{min-height:76px}
      .brand-text{display:none}
      .menu{
        position:fixed;
        top:84px;
        left:16px;
        right:16px;
        padding:16px;
        background:rgba(0,31,63,.98);
        border:1px solid rgba(255,255,255,.08);
        border-radius:22px;
        flex-direction:column;
        align-items:stretch;
        gap:8px;
        box-shadow:var(--shadow);
        transform:translateY(-18px);
        opacity:0;
        pointer-events:none;
        transition:.25s ease;
      }
      .menu.open{
        opacity:1;
        transform:translateY(0);
        pointer-events:auto;
      }
      .menu a{
        display:block;
        padding:14px 12px;
        border-radius:14px;
      }
      .menu a:hover{background:rgba(255,255,255,.06)}
      .burger{display:inline-flex}
      .nav-cta{display:none}
      .hero{padding-top:112px}
      .hero-grid{min-height:auto;padding:20px 0 44px}
      .hero-copy h1{max-width:none}
      .hero-actions,.hero-points{justify-content:flex-start}
      .btn{width:100%}
      .btn-secondary,.btn-primary,.btn-dark{width:100%}
      .services-grid,.process,.stats-grid,.sector-grid,.case-grid,.blog-grid,.logos{grid-template-columns:1fr}
      .step:not(:last-child)::after{display:none}
      .form-grid{grid-template-columns:1fr}
      .footer-grid{grid-template-columns:1fr}
      .footer-bottom{flex-direction:column}
      .hero-visual{min-height:380px}
      .visual-card{border-radius:28px}
    }
