:root{
    --blue:#0e9bd6;
    --blue-dark:#0a78ac;
    --blue-soft:#d4ecf8;
    --ink:#0c2333;
    --ink-soft:#4d6679;
    --sky:#f1f9fd;
    --aqua:#dcf0f9;
    --aqua-deep:#bce3f3;
    --teal:#34d3e0;
    --teal-deep:#13a7c4;
    --shell:#ffffff;
    --line:rgba(12,35,51,.08);
    --radius-xl:34px;
    --radius-lg:26px;
    --radius-md:18px;
    --shadow-soft:0 30px 60px -30px rgba(16,76,112,.35);
    --shadow-card:0 24px 50px -24px rgba(16,76,112,.28);
    --maxw:1240px;
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:"Hanken Grotesk",system-ui,sans-serif;
    color:var(--ink);
    background:#eceae7;
    -webkit-font-smoothing:antialiased;
    line-height:1.5;
  }
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  ::selection{background:var(--blue);color:#fff}

  /* ---------- Announcement bar ---------- */
  .announce{
    background:var(--blue);
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:14px;
    padding:16px 64px;
    position:relative;
    font-weight:500;
    font-size:15px;
    letter-spacing:.2px;
    flex-wrap:wrap;
  }
  .announce a{font-weight:700;text-decoration:underline;text-underline-offset:3px}
  .announce .close{
    position:absolute;right:26px;top:50%;transform:translateY(-50%);
    width:30px;height:30px;border-radius:50%;
    display:grid;place-items:center;cursor:pointer;
    border:1.5px solid rgba(255,255,255,.5);font-size:15px;line-height:1;
    transition:background .2s,transform .2s;
  }
  .announce .close:hover{background:rgba(255,255,255,.18);transform:translateY(-50%) rotate(90deg)}

  /* ---------- Shell ---------- */
  .shell{
    background:
      radial-gradient(120% 90% at 78% 8%, var(--aqua) 0%, var(--sky) 42%, var(--sky) 100%);
    border-radius:var(--radius-xl) var(--radius-xl) 0 0;
    margin-top:-22px;
    position:relative;
    overflow:hidden;
  }
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}

  /* ---------- Header ---------- */
  header{padding-top:30px}
  .topbar{
    display:flex;align-items:center;gap:26px;
    padding:14px 26px;
  }
  .brand{display:flex;align-items:center;gap:11px}
  .logo-mark{
    width:46px;height:46px;border-radius:13px;
    background:#fff;overflow:hidden;
    display:grid;place-items:center;
    box-shadow:0 8px 18px -6px rgba(16,76,112,.45);
  }
  .logo-mark img{width:100%;height:100%;object-fit:contain}
  .brand-name{font-size:24px;font-weight:800;letter-spacing:-.5px}
  .brand-tag{
    font-size:15px;color:var(--ink-soft);font-weight:500;
    padding-left:24px;margin-left:8px;border-left:1px solid var(--line);
  }
  .topbar .cta-quote{margin-left:auto}
  .btn{
    display:inline-flex;align-items:center;gap:9px;
    font-weight:700;font-size:15px;border:none;cursor:pointer;
    border-radius:40px;padding:14px 26px;transition:transform .2s,box-shadow .2s,background .2s;
    white-space:nowrap;
  }
  .btn-dark{background:var(--ink);color:#fff}
  .btn-dark:hover{transform:translateY(-2px);box-shadow:0 14px 26px -12px rgba(0,0,0,.6)}
  .btn-blue{background:var(--blue);color:#fff;box-shadow:0 14px 26px -12px rgba(14,155,214,.7)}
  .btn-blue:hover{background:var(--blue-dark);transform:translateY(-2px)}
  .btn-ghost{background:transparent;color:var(--ink);border:1.5px solid rgba(12,35,51,.22)}
  .btn-ghost:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}

  /* nav row */
  .navbar{
    display:flex;align-items:center;gap:6px;
    margin-top:14px;padding:10px 16px;
    background:rgba(255,255,255,.55);
    border:1px solid rgba(255,255,255,.7);
    border-radius:40px;
    backdrop-filter:blur(8px);
    box-shadow:0 10px 30px -22px rgba(16,76,112,.5);
  }
  .navbar a{
    padding:11px 20px;border-radius:30px;font-weight:600;font-size:15px;color:var(--ink-soft);
    transition:color .2s,background .2s;
  }
  .navbar a:hover{color:var(--ink)}
  .navbar a.active{background:var(--blue-soft);color:var(--blue-dark)}
  .navbar .lang{margin-left:auto;display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px;color:var(--ink-soft);padding-right:8px}

  /* ---------- Hero ---------- */
  .hero{padding:54px 0 70px;position:relative}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:start}
  h1.hero-title{
    font-size:clamp(46px,6vw,92px);
    line-height:.98;font-weight:800;letter-spacing:-2.5px;
    max-width:680px;
  }
  h1.hero-title .accent{color:var(--blue)}

  .hero-lower{display:flex;gap:24px;align-items:flex-start;margin-top:42px;max-width:640px}
  .hero-thumb{
    width:118px;height:138px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0;
    box-shadow:var(--shadow-card);
  }
  .hero-lead{font-size:18px;color:var(--ink-soft);line-height:1.55;max-width:430px}
  .hero-lower .btn{margin-top:22px}

  .stats{display:flex;gap:46px;margin-top:54px}
  .stat{display:flex;align-items:center;gap:16px}
  .stat-ico{
    width:62px;height:62px;border-radius:16px;background:#fff;
    display:grid;place-items:center;box-shadow:var(--shadow-card);
  }
  .stat-ico svg{width:28px;height:28px}
  .stat-num{font-size:34px;font-weight:800;letter-spacing:-1px;line-height:1}
  .stat-label{font-size:15px;color:var(--ink-soft);font-weight:500;margin-top:4px}

  /* hero visual */
  .hero-visual{position:relative;min-height:520px}
  .hero-photo{
    width:100%;border-radius:var(--radius-lg);
    object-fit:cover;aspect-ratio:5/4;
    -webkit-mask-image:radial-gradient(120% 120% at 30% 30%,#000 70%,transparent 100%);
  }
  .sparkle{position:absolute;font-size:30px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15));animation:twinkle 3s ease-in-out infinite}
  .sparkle.s1{top:6%;right:16%;font-size:40px}
  .sparkle.s2{top:20%;right:6%;font-size:24px;animation-delay:.8s}
  @keyframes twinkle{0%,100%{transform:scale(1) rotate(0);opacity:.85}50%{transform:scale(1.25) rotate(12deg);opacity:1}}

  /* 3D ocean bars */
  .bars{position:absolute;right:2%;bottom:14%;display:flex;align-items:flex-end;gap:14px;perspective:600px}
  .bar{
    width:46px;border-radius:8px 8px 4px 4px;
    background:linear-gradient(180deg,rgba(52,211,224,.92),rgba(19,167,196,.88));
    box-shadow:0 18px 40px -14px rgba(19,167,196,.7), inset 0 0 0 1px rgba(255,255,255,.45);
    transform:rotateY(-18deg) rotateX(6deg);
    transform-origin:bottom;
  }
  .bar.b1{height:90px}
  .bar.b2{height:140px}
  .bar.b3{height:200px}

  /* glass card */
  .glass{
    position:absolute;left:-6%;bottom:-4%;
    width:380px;max-width:62%;
    background:rgba(255,255,255,.55);
    border:1px solid rgba(255,255,255,.75);
    backdrop-filter:blur(18px);
    border-radius:var(--radius-lg);
    padding:30px 30px 28px;
    box-shadow:var(--shadow-soft);
  }
  .glass h3{font-size:23px;font-weight:800;letter-spacing:-.6px;line-height:1.15}
  .glass p{font-size:15px;color:var(--ink-soft);margin:14px 0 20px;line-height:1.5}

  /* ---------- Section base ---------- */
  section.block{padding:84px 0}
  .eyebrow{
    display:inline-flex;align-items:center;gap:8px;
    font-size:13px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;
    color:var(--blue-dark);background:var(--blue-soft);
    padding:8px 16px;border-radius:30px;
  }
  .sec-head{max-width:640px;margin-bottom:46px}
  .sec-head h2{font-size:clamp(32px,4vw,48px);font-weight:800;letter-spacing:-1.4px;line-height:1.05;margin-top:18px}
  .sec-head p{font-size:18px;color:var(--ink-soft);margin-top:16px;line-height:1.55}
  .center{text-align:center;margin-left:auto;margin-right:auto}

  /* services */
  .cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .svc{
    background:#fff;border-radius:var(--radius-lg);padding:34px 30px 32px;
    box-shadow:var(--shadow-card);position:relative;overflow:hidden;
    transition:transform .3s,box-shadow .3s;
    border:1px solid rgba(255,255,255,.6);
  }
  .svc:hover{transform:translateY(-8px);box-shadow:0 38px 60px -28px rgba(16,76,112,.4)}
  .svc::after{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--blue),#7fd0ef)}
  .svc-ico{
    width:64px;height:64px;border-radius:18px;display:grid;place-items:center;margin-bottom:22px;
    background:linear-gradient(135deg,var(--aqua),var(--blue-soft));
  }
  .svc-ico svg{width:30px;height:30px;color:var(--blue-dark)}
  .svc h3{font-size:22px;font-weight:800;letter-spacing:-.5px}
  .svc p{font-size:16px;color:var(--ink-soft);margin-top:12px;line-height:1.55}
  .svc .more{display:inline-flex;align-items:center;gap:7px;margin-top:20px;font-weight:700;color:var(--blue-dark);font-size:15px}
  .svc .more svg{width:16px;height:16px;transition:transform .25s}
  .svc:hover .more svg{transform:translateX(5px)}

  /* process */
  .process{background:var(--ink);border-radius:var(--radius-xl);color:#fff;padding:70px 56px;position:relative;overflow:hidden}
  .process .glow{position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(14,155,214,.45),transparent 70%);top:-160px;right:-120px;filter:blur(20px)}
  .process .sec-head h2{color:#fff}
  .process .sec-head p{color:rgba(255,255,255,.7)}
  .process .eyebrow{background:rgba(14,155,214,.2);color:#f9b483}
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;position:relative;z-index:1}
  .step{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:32px 28px;transition:transform .3s,background .3s}
  .step:hover{transform:translateY(-6px);background:rgba(255,255,255,.1)}
  .step-num{font-size:15px;font-weight:800;color:var(--blue);letter-spacing:1px}
  .step h3{font-size:22px;font-weight:800;margin:14px 0 10px;letter-spacing:-.5px}
  .step p{font-size:15px;color:rgba(255,255,255,.66);line-height:1.55}

  /* mission band */
  .mission{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
  .mission-quote{font-size:clamp(28px,3.6vw,44px);font-weight:800;letter-spacing:-1.4px;line-height:1.12}
  .mission-quote .accent{color:var(--blue)}
  .mission-sub{font-size:18px;color:var(--ink-soft);margin-top:22px;line-height:1.6;max-width:440px}
  .logos{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
  .logo-chip{background:#fff;border-radius:14px;padding:14px 22px;font-weight:700;color:var(--ink-soft);box-shadow:var(--shadow-card);font-size:15px}
  .mission-photo{border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);object-fit:cover;aspect-ratio:4/5;width:100%}

  /* final CTA */
  .cta-final{
    background:
      radial-gradient(120% 130% at 80% 10%, var(--aqua-deep), var(--blue-soft) 55%, var(--sky));
    border-radius:var(--radius-xl);
    padding:74px 56px;text-align:center;position:relative;overflow:hidden;
    border:1px solid rgba(255,255,255,.6);
  }
  .cta-final h2{font-size:clamp(34px,4.4vw,56px);font-weight:800;letter-spacing:-1.8px;line-height:1.04;max-width:760px;margin:18px auto 0}
  .cta-final p{font-size:19px;color:var(--ink-soft);margin:18px auto 0;max-width:520px}
  .cta-final .actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:34px}
  .cta-final .loc{margin-top:30px;font-size:15px;color:var(--ink-soft);font-weight:500}

  /* footer */
  footer{background:var(--ink);color:rgba(255,255,255,.62);padding:54px 0 34px}
  .foot-grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:flex-start}
  footer .brand-name{color:#fff}
  footer .foot-tag{margin-top:14px;max-width:300px;font-size:15px;line-height:1.6}
  .foot-col h4{color:#fff;font-size:14px;letter-spacing:1px;text-transform:uppercase;margin-bottom:16px}
  .foot-col a{display:block;margin-bottom:10px;font-size:15px;transition:color .2s}
  .foot-col a:hover{color:var(--blue)}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:42px;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:14px}

  /* reveal animation */
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}
  [data-delay="1"]{transition-delay:.08s}
  [data-delay="2"]{transition-delay:.16s}
  [data-delay="3"]{transition-delay:.24s}
  [data-delay="4"]{transition-delay:.32s}

  /* logo wall */
  .logo-wall{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:16px}
  .logo-tile{background:#fff;border-radius:14px;padding:14px 24px;box-shadow:var(--shadow-card);display:grid;place-items:center;height:76px;min-width:158px;transition:transform .25s}
  .logo-tile:hover{transform:translateY(-4px)}
  .logo-tile img{max-height:36px;width:auto;object-fit:contain}
  .wall-cap{text-align:center;font-size:15px;color:var(--ink-soft);font-weight:600;letter-spacing:.3px;margin-bottom:28px}
  .wall-cap b{color:var(--ink)}

  /* cadence sub-list inside dark steps */
  .step ul{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:9px}
  .step ul li{display:flex;gap:9px;align-items:flex-start;font-size:14.5px;color:rgba(255,255,255,.72);line-height:1.4}
  .step ul li::before{content:"";flex-shrink:0;width:7px;height:7px;border-radius:50%;background:var(--teal);margin-top:6px}

  /* ---------- Responsive ---------- */
  @media(max-width:980px){
    .hero-grid{grid-template-columns:1fr;gap:60px}
    .hero-visual{min-height:420px;margin-bottom:40px}
    .mission{grid-template-columns:1fr}
    .mission-photo{max-width:420px}
    .brand-tag{display:none}
    .navbar{flex-wrap:wrap;border-radius:24px}
    .navbar .lang{margin-left:0}
  }
  @media(max-width:680px){
    .wrap{padding:0 20px}
    .announce{padding:14px 44px;font-size:14px}
    .topbar{flex-wrap:wrap;gap:14px}
    .cards3,.steps{grid-template-columns:1fr}
    .stats{flex-direction:column;gap:20px}
    .hero-lower{flex-direction:column}
    .process,.cta-final,.process{padding:48px 24px}
    .glass{position:static;width:100%;max-width:100%;margin-top:24px}
    h1.hero-title{letter-spacing:-1.5px}
  }
