
  :root{
    /* Brand palette from logo */
    --ink-900:#152330;        /* deep navy (logo dark) */
    --ink-800:#1d2f3f;
    --ink-700:#2a3f52;
    --ink-500:#5a6c7e;
    --ink-400:#8694a3;
    --ink-300:#b9c3cd;
    --ink-200:#dde3ea;
    --ink-100:#eef2f6;
    --paper:#f7f5f0;          /* warm off-white */
    --paper-2:#efeae0;        /* deeper paper for bands */
    --white:#ffffff;

    --teal-700:#1f5a4f;
    --teal-600:#2a7466;
    --teal-500:#358a7a;       /* logo green */
    --teal-400:#5aa89a;
    --teal-200:#bfdbd3;
    --teal-100:#e4efeb;

    --radius:18px;
    --radius-lg:26px;
    --shadow-sm: 0 1px 2px rgba(21,35,48,.06), 0 4px 14px rgba(21,35,48,.05);
    --shadow:    0 2px 4px rgba(21,35,48,.06), 0 18px 38px -10px rgba(21,35,48,.18);
    --t: 360ms cubic-bezier(.22,.61,.36,1);
  }

  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  body{
    background:var(--paper);
    color:var(--ink-900);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
    font-feature-settings:"ss01","cv11";
    -webkit-font-smoothing:antialiased;
    line-height:1.55;
  }
  a{color:inherit}
  img{display:block;max-width:100%}

  /* ---------- NAV ---------- */
  .nav{
    position:sticky; top:0; z-index:50;
    backdrop-filter: saturate(140%) blur(14px);
    -webkit-backdrop-filter: saturate(140%) blur(14px);
    background: color-mix(in srgb, var(--paper) 78%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--ink-900) 8%, transparent);
  }
  .nav__in{
    max-width: 1280px; margin:0 auto;
    display:flex; align-items:center; justify-content:space-between;
    padding: 16px 28px;
  }
  .logo{display:flex; align-items:center; gap:10px; font-family:'Fraunces'; font-weight:600; font-size:22px; letter-spacing:-.02em; color:var(--ink-900); text-decoration:none}
  .logo svg{width:30px;height:30px}
  .nav__links{display:none; gap:30px; font-size:14px; font-weight:500; color:var(--ink-700)}
  .nav__links a{text-decoration:none; transition:color var(--t)}
  .nav__links a:hover{color:var(--teal-600)}
  @media (min-width: 880px){ .nav__links{display:flex} }
  .nav__cta{
    display:inline-flex; align-items:center; gap:8px;
    padding:10px 16px; border-radius:999px;
    background:var(--ink-900); color:var(--white);
    font-size:13px; font-weight:600; text-decoration:none;
    transition: transform var(--t), background var(--t);
  }
  .nav__cta:hover{ background:var(--teal-600); transform:translateY(-1px) }
  .nav__cta .dot{width:6px;height:6px;border-radius:50%;background:var(--teal-400); box-shadow:0 0 0 4px rgba(90,168,154,.25)}

  /* ---------- TYPE ---------- */
  .display{
    font-family:'Fraunces';
    font-weight:500;
    font-variation-settings: "opsz" 144, "SOFT" 0;
    letter-spacing:-.025em;
    line-height:1.02;
    color:var(--ink-900);
  }
  .display em{ font-style:italic; color:var(--teal-600); font-weight:500 }
  .eyebrow{
    font-family:'JetBrains Mono', ui-monospace, Menlo, monospace;
    font-size:12px; text-transform:uppercase; letter-spacing:.18em;
    color:var(--teal-700);
    display:inline-flex; align-items:center; gap:10px;
  }
  .eyebrow::before{
    content:""; width:22px; height:1px; background:var(--teal-500);
  }
  .lead{ color:var(--ink-700); font-size:18px; line-height:1.6 }
  .h2{ font-family:'Fraunces'; font-weight:500; font-size:clamp(34px, 4.4vw, 58px); letter-spacing:-.025em; line-height:1.04; margin:0 }
  .h3{ font-family:'Fraunces'; font-weight:500; font-size:26px; letter-spacing:-.02em; margin:0 }
  p{margin:0}

  /* ---------- LAYOUT ---------- */
  .shell{ max-width: 1280px; margin: 0 auto; padding: 0 28px }
  section{ padding: 96px 0; position:relative }
  @media (max-width: 720px){
    section{padding: 64px 0}
  }
  .sec-head{ max-width: 760px; margin: 0 auto 56px; text-align:center; display:grid; gap:18px; justify-items:center }

  /* ---------- BUTTONS ---------- */
  .btn{
    display:inline-flex; align-items:center; gap:10px;
    padding:14px 22px; border-radius:999px;
    font-weight:600; font-size:15px; text-decoration:none;
    transition: transform var(--t), background var(--t), color var(--t), box-shadow var(--t), border-color var(--t);
    border:1px solid transparent; cursor:pointer;
  }
  .btn--primary{ background:var(--ink-900); color:var(--white); box-shadow: 0 8px 24px -8px rgba(21,35,48,.4) }
  .btn--primary:hover{ background:var(--teal-600); transform:translateY(-2px); box-shadow: 0 14px 34px -10px rgba(53,138,122,.5) }
  .btn--ghost{ background:transparent; color:var(--ink-900); border-color:color-mix(in srgb, var(--ink-900) 18%, transparent) }
  .btn--ghost:hover{ background:var(--ink-900); color:var(--white); transform:translateY(-2px) }
  .btn--teal{ background:var(--teal-600); color:var(--white) }
  .btn--teal:hover{ background:var(--teal-700); transform:translateY(-2px) }
  .btn .arr{transition: transform var(--t)}
  .btn:hover .arr{ transform: translateX(4px) }

  /* ---------- HERO ---------- */
  .hero{ padding: 56px 0 80px; overflow:hidden }
  body{ overflow-x: hidden }
  .hero__grid{
    display:grid; gap: 48px;
    grid-template-columns: 1fr;
    align-items:center;
  }
  @media (min-width: 980px){
    .hero__grid{ grid-template-columns: 1.05fr .95fr; gap:64px }
  }
  .hero h1{
    font-size: clamp(44px, 6.6vw, 92px);
    margin: 18px 0 22px;
  }
  .hero .lead{ max-width: 52ch; font-size: 19px }
  .hero__cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:32px }
  .hero__meta{
    display:flex; flex-wrap:wrap; gap:26px; margin-top:36px;
    padding-top:26px; border-top:1px solid color-mix(in srgb, var(--ink-900) 10%, transparent);
  }
  .hero__meta-it{ display:flex; flex-direction:column; gap:2px }
  .hero__meta-num{ font-family:'Fraunces'; font-size:30px; color:var(--ink-900); letter-spacing:-.02em; line-height:1 }
  .hero__meta-lbl{ font-size:13px; color:var(--ink-500) }

  /* Hero media — editorial split frame */
  .hero__media{ position:relative; aspect-ratio: 5/6; max-width:560px; margin-left:auto; width:100% }
  .hero__plate{
    position:absolute; inset:0;
    border-radius: var(--radius-lg);
    overflow:hidden;
    background:
      linear-gradient(135deg, var(--ink-800), var(--teal-700));
    box-shadow: var(--shadow);
  }
  .hero__plate::before{
    content:""; position:absolute; inset:0;
    background:
      radial-gradient(circle at 30% 20%, rgba(90,168,154,.35), transparent 50%),
      radial-gradient(circle at 80% 70%, rgba(21,35,48,.5), transparent 60%);
  }
  .hero__plate-img{
    position:absolute; inset:0;
    background-size:cover; background-position:center;
    background-image:
      linear-gradient(180deg, rgba(21,35,48,0) 50%, rgba(21,35,48,.45) 100%),
      url('https://images.unsplash.com/photo-1517248135467-4c7edcad34c4?w=900&q=80');
    background-blend-mode: normal;
  }
  .hero__badge{
    position:absolute; bottom:24px; left:24px; right:24px;
    background: color-mix(in srgb, var(--paper) 92%, transparent);
    backdrop-filter: blur(12px);
    border-radius: 16px;
    padding: 16px 18px;
    display:flex; align-items:center; gap:14px;
    border:1px solid color-mix(in srgb, var(--ink-900) 8%, transparent);
  }
  .hero__badge-mark{
    width:42px;height:42px;border-radius:12px;
    background: var(--teal-500);
    display:grid; place-items:center;
    color:var(--white); font-family:'Fraunces'; font-size:22px; font-weight:600;
  }
  .hero__badge-t{ font-weight:600; font-size:14px; line-height:1.2 }
  .hero__badge-s{ font-size:12px; color:var(--ink-500); margin-top:2px }
  .hero__tag{
    position:absolute; top:24px; left:24px;
    padding:8px 14px; border-radius:999px;
    background: color-mix(in srgb, var(--paper) 90%, transparent);
    backdrop-filter: blur(12px);
    font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase;
    color:var(--ink-900);
    border:1px solid color-mix(in srgb, var(--ink-900) 8%, transparent);
  }
  /* floating accent shape */
  .hero__accent{
    position:absolute; right:-28px; top:-28px;
    width:120px; height:120px; border-radius:50%;
    background: var(--teal-500);
    z-index:-1;
  }
  .hero__accent--2{
    position:absolute; left:-32px; bottom:-32px;
    width:160px; height:160px; border-radius:50%;
    background: var(--ink-900);
    z-index:-1;
    top:auto; right:auto;
  }

  /* ---------- LOGO STRIP ---------- */
  .marquee{
    padding: 22px 0;
    border-top:1px solid color-mix(in srgb, var(--ink-900) 9%, transparent);
    border-bottom:1px solid color-mix(in srgb, var(--ink-900) 9%, transparent);
    overflow:hidden;
    background: color-mix(in srgb, var(--paper-2) 50%, transparent);
  }
  .marquee__lbl{
    font-family:'JetBrains Mono', monospace;
    font-size:11px; letter-spacing:.18em; text-transform:uppercase;
    color:var(--ink-500); text-align:center; margin-bottom:14px;
  }
  .marquee__track{
    display:flex; gap:60px; width:max-content;
    animation: scroll 38s linear infinite;
  }
  .marquee__item{
    font-family:'Fraunces'; font-style:italic; font-weight:500;
    font-size:22px; color:var(--ink-500);
    white-space:nowrap;
    display:flex; align-items:center; gap:60px;
  }
  .marquee__item::after{
    content:""; width:6px; height:6px; border-radius:50%; background:var(--teal-500); opacity:.7;
  }
  @keyframes scroll{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

  /* ---------- PROBLEM/SOLUTION ---------- */
  .problem{
    background: var(--paper);
  }
  .problem__grid{
    display:grid; gap:24px;
    grid-template-columns: 1fr;
  }
  @media (min-width: 880px){ .problem__grid{ grid-template-columns: 1fr 1fr } }
  .ps-card{
    border-radius: var(--radius-lg);
    padding: 36px 32px;
    position:relative; overflow:hidden;
    border:1px solid color-mix(in srgb, var(--ink-900) 10%, transparent);
  }
  .ps-card--bad{ background:var(--white) }
  .ps-card--good{
    background:var(--ink-900); color:var(--paper);
    border-color:var(--ink-900);
  }
  .ps-card--good .ps-card__k{ color:var(--teal-400) }
  .ps-card__k{
    font-family:'JetBrains Mono', monospace;
    font-size:12px; letter-spacing:.16em; text-transform:uppercase;
    color:var(--ink-500); margin-bottom:18px;
    display:flex; align-items:center; gap:10px;
  }
  .ps-card__k::before{
    content:""; width:8px; height:8px; border-radius:50%;
    background: currentColor;
  }
  .ps-card h3{ font-family:'Fraunces'; font-size:30px; font-weight:500; letter-spacing:-.02em; margin:0 0 22px; line-height:1.1 }
  .ps-list{ list-style:none; padding:0; margin:0; display:grid; gap:14px }
  .ps-list li{
    padding-left:32px; position:relative;
    font-size:16px; line-height:1.5;
  }
  .ps-list li::before{
    content:""; position:absolute; left:0; top:8px;
    width:18px; height:2px; background:var(--ink-300);
  }
  .ps-card--good .ps-list li::before{ background:var(--teal-400); height:2px; width:18px }
  .ps-card--good .ps-list li{ color: color-mix(in srgb, var(--paper) 90%, transparent) }
  .ps-card--bad .ps-list li::before{
    width:18px; height:2px;
    background: linear-gradient(90deg, transparent, var(--ink-400));
  }

  /* ---------- METHOD ---------- */
  .method{ background: linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%); }
  .method__intro{ display:grid; grid-template-columns:1fr; gap:32px; align-items:end; margin-bottom:60px }
  @media (min-width: 980px){ .method__intro{ grid-template-columns: 1.2fr .8fr; gap:60px } }
  .method__intro .lead{ max-width:48ch }
  .method__grid{
    display:grid; gap:20px;
    grid-template-columns: 1fr;
  }
  @media (min-width: 720px){ .method__grid{ grid-template-columns: 1fr 1fr } }
  @media (min-width: 1080px){ .method__grid{ grid-template-columns: repeat(4, 1fr); gap:16px } }
  .step{
    background:var(--white);
    border:1px solid color-mix(in srgb, var(--ink-900) 9%, transparent);
    border-radius: var(--radius-lg);
    padding: 28px 24px;
    display:flex; flex-direction:column; gap:18px;
    transition: transform var(--t), box-shadow var(--t), border-color var(--t);
    cursor:pointer; position:relative; overflow:hidden;
  }
  .step:hover{ transform:translateY(-4px); box-shadow: var(--shadow); border-color:var(--teal-400) }
  .step__num{
    font-family:'JetBrains Mono', monospace;
    font-size:11px; color:var(--ink-400); letter-spacing:.12em;
  }
  .step__letter{
    font-family:'Fraunces'; font-weight:500;
    font-size:84px; line-height:1; letter-spacing:-.04em;
    color:var(--ink-900);
    display:flex; align-items:baseline; gap:6px;
  }
  .step__letter span{
    font-size:24px; color:var(--teal-500); letter-spacing:0;
  }
  .step__name{
    font-family:'JetBrains Mono', monospace;
    font-size:11px; text-transform:uppercase; letter-spacing:.18em;
    color:var(--teal-700);
  }
  .step h3{
    font-family:'Fraunces'; font-weight:500;
    font-size:24px; letter-spacing:-.02em; line-height:1.1;
    margin:0;
  }
  .step__p{ font-size:14.5px; color:var(--ink-500); line-height:1.55; flex:1 }
  .step__chips{ display:flex; flex-wrap:wrap; gap:6px; padding-top:14px; border-top:1px dashed color-mix(in srgb, var(--ink-900) 14%, transparent) }
  .chip{
    font-size:11.5px; font-weight:500;
    padding:5px 10px; border-radius:999px;
    background: var(--teal-100); color:var(--teal-700);
  }

  /* ---------- GALLERY ---------- */
  .gallery{ background:var(--paper) }
  .gallery__rail{
    overflow:hidden; mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
    margin: 0 -28px;
  }
  .gallery__track{
    display:flex; gap:18px; width:max-content;
    animation: scroll 50s linear infinite;
    padding: 8px 0;
  }
  .gallery__track:hover{ animation-play-state:paused }
  .gallery__item{
    width:280px; height:320px;
    border-radius: var(--radius);
    overflow:hidden;
    flex:0 0 auto;
    background: var(--ink-200);
    position:relative;
    box-shadow: var(--shadow-sm);
  }
  .gallery__item img{ width:100%; height:100%; object-fit:cover; transition: transform 800ms ease }
  .gallery__item:hover img{ transform:scale(1.06) }
  .gallery__item-tag{
    position:absolute; left:14px; bottom:14px;
    background: color-mix(in srgb, var(--paper) 90%, transparent);
    backdrop-filter: blur(8px);
    padding:6px 10px; border-radius: 999px;
    font-family:'JetBrains Mono', monospace; font-size:10px; letter-spacing:.1em; text-transform:uppercase;
    color:var(--ink-900);
  }

  /* ---------- SILOS / TILES ---------- */
  .silos{ background: linear-gradient(180deg, var(--paper-2) 0%, var(--paper) 100%) }
  .tiles{
    display:grid; gap:16px;
    grid-template-columns: 1fr;
  }
  @media (min-width: 720px){ .tiles{ grid-template-columns: 1fr 1fr } }
  @media (min-width: 1080px){ .tiles{ grid-template-columns: repeat(4, 1fr) } }
  .tile{
    position:relative;
    border-radius: var(--radius-lg);
    padding: 32px 28px;
    background: var(--white);
    border:1px solid color-mix(in srgb, var(--ink-900) 9%, transparent);
    text-decoration:none; color:inherit;
    display:flex; flex-direction:column; gap:14px;
    transition: transform var(--t), background var(--t), color var(--t), border-color var(--t);
    overflow:hidden;
    min-height:280px;
  }
  .tile::after{
    content:""; position:absolute; bottom:0; left:0; right:0; height:3px;
    background: linear-gradient(90deg, var(--teal-500), var(--ink-900));
    transform: scaleX(0); transform-origin:left;
    transition: transform 500ms cubic-bezier(.22,.61,.36,1);
  }
  .tile:hover{ transform: translateY(-6px); border-color:var(--teal-400); box-shadow: var(--shadow) }
  .tile:hover::after{ transform:scaleX(1) }
  .tile__icon{
    width:54px; height:54px; border-radius: 16px;
    display:grid; place-items:center;
    background: var(--teal-100); color: var(--teal-700);
    margin-bottom:6px;
  }
  .tile h3{ font-family:'Fraunces'; font-weight:500; font-size:22px; letter-spacing:-.02em; line-height:1.15; margin:0 }
  .tile__p{ color:var(--ink-500); font-size:14.5px; line-height:1.55; flex:1 }
  .tile__cta{ display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600; color:var(--teal-700) }
  .tile__cta .arr{ transition: transform var(--t) }
  .tile:hover .tile__cta .arr{ transform: translateX(4px) }

  /* ---------- SERVICES ---------- */
  .services{ background:var(--paper) }
  .svc-grid{
    display:grid; gap: 1px;
    background: color-mix(in srgb, var(--ink-900) 12%, transparent);
    border-radius: var(--radius-lg);
    overflow:hidden;
    border:1px solid color-mix(in srgb, var(--ink-900) 12%, transparent);
    grid-template-columns: 1fr;
  }
  @media (min-width: 720px){ .svc-grid{ grid-template-columns: 1fr 1fr } }
  @media (min-width: 1080px){ .svc-grid{ grid-template-columns: repeat(3, 1fr) } }
  .svc{
    background: var(--paper);
    padding: 36px 32px;
    display:flex; flex-direction:column; gap:14px;
    text-decoration:none; color:inherit;
    transition: background var(--t);
    min-height:240px;
    position:relative;
  }
  .svc:hover{ background: var(--white) }
  .svc__num{ font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--ink-400); letter-spacing:.12em }
  .svc h3{ font-family:'Fraunces'; font-weight:500; font-size:24px; letter-spacing:-.02em; line-height:1.15; margin:0; max-width:18ch }
  .svc p{ color:var(--ink-500); font-size:14.5px; flex:1 }
  .svc__cta{
    display:inline-flex; align-items:center; gap:6px;
    font-size:13px; font-weight:600; color:var(--teal-700);
  }
  .svc__cta .arr{transition:transform var(--t)}
  .svc:hover .svc__cta .arr{ transform: translateX(4px) }
  .services__cta{ display:flex; justify-content:center; gap:12px; margin-top:48px; flex-wrap:wrap }

  /* ---------- TRUST ---------- */
  .trust{
    background: var(--ink-900);
    color: var(--paper);
  }
  .trust .h2, .trust .display{ color: var(--paper) }
  .trust .lead{ color: color-mix(in srgb, var(--paper) 70%, transparent) }
  .trust .eyebrow{ color: var(--teal-400) }
  .trust .eyebrow::before{ background:var(--teal-400) }
  .trust__grid{
    display:grid; gap:32px;
    grid-template-columns: 1fr;
    margin-top: 60px;
  }
  @media (min-width: 980px){ .trust__grid{ grid-template-columns: 1.2fr .8fr; gap:48px; align-items:start } }
  .trust__list{ display:grid; gap:0; list-style:none; padding:0; margin:0 }
  .trust__list li{
    padding: 22px 0;
    border-top: 1px solid color-mix(in srgb, var(--paper) 14%, transparent);
    display:grid; grid-template-columns: 60px 1fr; gap:24px; align-items:start;
  }
  .trust__list li:last-child{ border-bottom: 1px solid color-mix(in srgb, var(--paper) 14%, transparent) }
  .trust__list-n{ font-family:'JetBrains Mono', monospace; font-size:13px; color:var(--teal-400); padding-top:4px }
  .trust__list-t{ font-family:'Fraunces'; font-size:22px; font-weight:500; letter-spacing:-.015em; line-height:1.2 }
  .trust__list-s{ font-size:14px; color: color-mix(in srgb, var(--paper) 65%, transparent); margin-top:6px }

  .trust__card{
    background: color-mix(in srgb, var(--paper) 6%, transparent);
    border: 1px solid color-mix(in srgb, var(--paper) 14%, transparent);
    border-radius: var(--radius-lg);
    padding: 32px;
    display:flex; flex-direction:column; gap:18px;
  }
  .trust__card-k{
    font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase;
    color: var(--teal-400);
  }
  .trust__card h3{ font-family:'Fraunces'; font-weight:500; font-size:28px; letter-spacing:-.02em; line-height:1.15; margin:0 }
  .trust__card p{ font-size:15px; color: color-mix(in srgb, var(--paper) 70%, transparent) }
  .trust__card .btn--primary{ background:var(--teal-500); color:var(--white) }
  .trust__card .btn--primary:hover{ background:var(--teal-400) }

  /* ---------- FAQ ---------- */
  .faq{ background:var(--paper) }
  .faq__list{
    max-width: 880px; margin: 0 auto;
    display:grid; gap: 0;
  }
  .qa{
    border-top: 1px solid color-mix(in srgb, var(--ink-900) 10%, transparent);
  }
  .qa:last-child{ border-bottom: 1px solid color-mix(in srgb, var(--ink-900) 10%, transparent) }
  .qa__q{
    width:100%; background:transparent; border:none; cursor:pointer;
    padding: 26px 0;
    display:flex; align-items:center; justify-content:space-between; gap:24px;
    font-family:'Fraunces'; font-weight:500; font-size:21px; letter-spacing:-.015em;
    text-align:left; color:var(--ink-900); line-height:1.3;
  }
  .qa__i{
    width:36px; height:36px; border-radius:50%; flex-shrink:0;
    border: 1px solid color-mix(in srgb, var(--ink-900) 16%, transparent);
    display:grid; place-items:center;
    transition: transform var(--t), background var(--t), border-color var(--t);
    position:relative;
  }
  .qa__i::before, .qa__i::after{
    content:""; position:absolute; background: var(--ink-900); border-radius:1px;
    transition: transform var(--t), background var(--t);
  }
  .qa__i::before{ width:12px; height:1.5px }
  .qa__i::after{ width:1.5px; height:12px }
  .qa[data-open="true"] .qa__i{ background: var(--ink-900); border-color: var(--ink-900) }
  .qa[data-open="true"] .qa__i::before{ background: var(--paper) }
  .qa[data-open="true"] .qa__i::after{ background: var(--paper); transform: rotate(90deg) }
  .qa__a{
    max-height:0; overflow:hidden; transition: max-height 500ms cubic-bezier(.22,.61,.36,1);
  }
  .qa[data-open="true"] .qa__a{ max-height: 400px }
  .qa__a-in{ padding: 0 0 26px; font-size:16px; color:var(--ink-500); line-height:1.65; max-width:62ch }

  /* ---------- CONTACT ---------- */
  .contact{ background: linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%) }
  .contact__grid{
    display:grid; gap:32px; margin-top:60px;
    grid-template-columns: 1fr;
  }
  @media (min-width: 980px){ .contact__grid{ grid-template-columns: 1.15fr .85fr; gap:32px; align-items:start } }
  .form{
    background: var(--white);
    border:1px solid color-mix(in srgb, var(--ink-900) 10%, transparent);
    border-radius: var(--radius-lg);
    padding: 36px;
    display:flex; flex-direction:column; gap:18px;
    box-shadow: var(--shadow-sm);
  }
  .form__row{
    display:grid; gap:18px;
    grid-template-columns: 1fr;
  }
  @media (min-width: 640px){ .form__row{ grid-template-columns: 1fr 1fr } }
  .field{ display:flex; flex-direction:column; gap:6px }
  .label{
    font-size:12px; font-weight:600;
    color:var(--ink-700);
    font-family:'JetBrains Mono', monospace;
    letter-spacing:.06em; text-transform:uppercase;
  }
  .input{
    padding: 14px 16px;
    border:1px solid color-mix(in srgb, var(--ink-900) 14%, transparent);
    border-radius: 12px;
    background: var(--paper);
    font: inherit; font-size:15px; color: var(--ink-900);
    transition: border-color var(--t), background var(--t), box-shadow var(--t);
  }
  .input::placeholder{ color: var(--ink-400) }
  .input:focus{
    outline:none; background:var(--white);
    border-color: var(--teal-500);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--teal-500) 18%, transparent);
  }
  .check{ display:flex; gap:10px; align-items:flex-start; font-size:13.5px; color:var(--ink-500); cursor:pointer }
  .check input{ accent-color: var(--teal-600); margin-top:3px }
  .check a{ color: var(--teal-700); font-weight:500 }
  .form__note{ font-size:12px; color:var(--ink-400); text-align:center }

  .contact-aside{
    display:flex; flex-direction:column; gap:18px;
  }
  .contact-card{
    background: var(--ink-900); color: var(--paper);
    border-radius: var(--radius-lg);
    padding: 32px;
    display:flex; flex-direction:column; gap:14px;
    position:relative; overflow:hidden;
  }
  .contact-card::before{
    content:""; position:absolute; top:-40px; right:-40px;
    width:160px; height:160px; border-radius:50%;
    background: color-mix(in srgb, var(--teal-500) 40%, transparent);
    filter: blur(60px);
  }
  .contact-card__k{ font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--teal-400); position:relative; z-index:1 }
  .contact-card h3{ font-family:'Fraunces'; font-weight:500; font-size:28px; letter-spacing:-.02em; line-height:1.15; margin:0; position:relative; z-index:1 }
  .contact-card p{ color: color-mix(in srgb, var(--paper) 70%, transparent); font-size:15px; position:relative; z-index:1 }
  .contact-card .btn{ position:relative; z-index:1 }

  .quick{
    border:1px solid color-mix(in srgb, var(--ink-900) 10%, transparent);
    border-radius: var(--radius-lg);
    padding: 28px;
    background: var(--white);
    display:grid; gap:10px;
  }
  .quick__t{ font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-500); margin-bottom:6px }
  .quick a{
    display:flex; align-items:center; justify-content:space-between;
    padding: 12px 14px;
    border-radius: 12px;
    text-decoration:none; color: var(--ink-900); font-weight:500; font-size:14.5px;
    transition: background var(--t), color var(--t);
  }
  .quick a:hover{ background: var(--teal-100); color:var(--teal-700) }

  /* ---------- FOOTER ---------- */
  .footer{
    background: var(--ink-900); color: color-mix(in srgb, var(--paper) 70%, transparent);
    padding: 60px 0 30px;
  }
  .footer__grid{
    display:grid; gap: 36px; margin-bottom: 40px;
    grid-template-columns: 1fr;
  }
  @media (min-width: 720px){ .footer__grid{ grid-template-columns: 2fr 1fr 1fr 1fr } }
  .footer h4{
    font-family:'JetBrains Mono', monospace;
    font-size:11px; letter-spacing:.16em; text-transform:uppercase;
    color:var(--teal-400); margin: 0 0 16px;
  }
  .footer__col a{
    display:block; padding: 4px 0;
    color: color-mix(in srgb, var(--paper) 70%, transparent);
    text-decoration:none; font-size:14px;
    transition: color var(--t);
  }
  .footer__col a:hover{ color: var(--paper) }
  .footer__brand p{ font-size:14px; max-width: 32ch; margin-top:14px }
  .footer__bottom{
    padding-top: 24px;
    border-top: 1px solid color-mix(in srgb, var(--paper) 14%, transparent);
    display:flex; justify-content:space-between; flex-wrap:wrap; gap: 14px;
    font-size: 12px; color: color-mix(in srgb, var(--paper) 50%, transparent);
  }

  /* ---------- Reveal anim ---------- */
  [data-reveal]{
    opacity:0; transform: translateY(20px);
    transition: opacity 800ms cubic-bezier(.22,.61,.36,1), transform 800ms cubic-bezier(.22,.61,.36,1);
    transition-delay: var(--d, 0ms);
  }
  [data-reveal].in{ opacity:1; transform: none }
  @media (prefers-reduced-motion: reduce){
    [data-reveal]{ opacity:1; transform:none; transition: none }
    .marquee__track, .gallery__track{ animation: none }
  }

  /* selection */
  ::selection{ background: var(--teal-500); color: var(--white) }

  /* ---------- MEGA MENU ---------- */
  .nav__wrap{ position:relative }
  .nav__links{ position:relative }
  .nav__links > li{ list-style:none; position:relative }
  .nav__links ul{ list-style:none; padding:0; margin:0 }
  .nav__item{
    background:transparent; border:none; cursor:pointer;
    font: inherit; font-size:14px; font-weight:500; color:var(--ink-700);
    padding: 10px 4px; display:flex; align-items:center; gap:6px;
    transition: color var(--t);
  }
  .nav__item:hover, .nav__item[aria-expanded="true"]{ color: var(--teal-700) }
  .nav__item svg{ transition: transform var(--t) }
  .nav__item[aria-expanded="true"] svg{ transform: rotate(180deg) }

  .mega{
    position:absolute; top: calc(100% + 14px); left: 50%; transform: translateX(-50%) translateY(6px);
    width: min(880px, 92vw);
    background: var(--paper);
    border: 1px solid color-mix(in srgb, var(--ink-900) 10%, transparent);
    border-radius: var(--radius-lg);
    box-shadow: 0 30px 60px -20px rgba(21,35,48,.25);
    padding: 28px;
    opacity:0; pointer-events:none;
    transition: opacity 240ms ease, transform 240ms ease;
    z-index: 60;
  }
  .mega.is-open{ opacity:1; pointer-events:auto; transform: translateX(-50%) translateY(0) }
  .mega--right{ left:auto; right: 0; transform: translateY(6px) }
  .mega--right.is-open{ transform: translateY(0) }
  .mega__grid{
    display:grid; gap: 8px 22px;
    grid-template-columns: 1fr 1fr;
  }
  .mega__col h5{
    margin: 0 0 12px;
    font-family:'JetBrains Mono', monospace;
    font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--teal-700);
    display:flex; align-items:center; gap:8px;
  }
  .mega__col h5::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--teal-500) }
  .mega__link{
    display:flex; align-items:flex-start; gap:12px;
    padding: 10px 12px; border-radius: 12px;
    text-decoration:none; color: var(--ink-900);
    transition: background var(--t), color var(--t);
  }
  .mega__link:hover{ background: color-mix(in srgb, var(--teal-100) 70%, transparent) }
  .mega__link-ic{
    width:34px; height:34px; flex-shrink:0;
    border-radius:10px; background: var(--white);
    border: 1px solid color-mix(in srgb, var(--ink-900) 10%, transparent);
    display:grid; place-items:center; color:var(--teal-700);
  }
  .mega__link-t{ font-size:14px; font-weight:600; line-height:1.2 }
  .mega__link-s{ font-size:12.5px; color:var(--ink-500); margin-top:2px; line-height:1.45 }
  .mega__foot{
    margin-top:18px; padding-top:18px;
    border-top:1px dashed color-mix(in srgb, var(--ink-900) 14%, transparent);
    display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap;
    font-size:13px;
  }
  .mega__foot a{ color:var(--teal-700); font-weight:600; text-decoration:none; display:inline-flex; gap:6px; align-items:center }
  .mega__foot-meta{ color:var(--ink-500); font-size:12px }

  /* mobile menu */
  .nav__burger{
    display:inline-grid; place-items:center;
    width:40px; height:40px; border-radius:10px;
    background: var(--white); border:1px solid color-mix(in srgb, var(--ink-900) 12%, transparent);
    cursor:pointer;
  }
  @media (min-width: 880px){ .nav__burger{ display:none } }
  .mobileMenu{
    position:fixed; inset:0; z-index:100;
    background: var(--paper);
    transform: translateY(-100%);
    transition: transform 400ms cubic-bezier(.22,.61,.36,1);
    overflow-y:auto;
  }
  .mobileMenu.is-open{ transform: translateY(0) }
  .mobileMenu__head{
    display:flex; align-items:center; justify-content:space-between;
    padding: 20px 28px;
    border-bottom: 1px solid color-mix(in srgb, var(--ink-900) 9%, transparent);
  }
  .mobileMenu__body{ padding: 28px }
  .mobileMenu h5{
    margin: 24px 0 10px;
    font-family:'JetBrains Mono', monospace;
    font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--teal-700);
  }
  .mobileMenu a{
    display:block; padding: 12px 0;
    text-decoration:none; color: var(--ink-900);
    font-size:17px; font-weight:500;
    border-top: 1px solid color-mix(in srgb, var(--ink-900) 8%, transparent);
  }

  /* ---------- BREADCRUMBS ---------- */
  .crumbs{
    display:flex; gap:8px; align-items:center; flex-wrap:wrap;
    font-family:'JetBrains Mono', monospace; font-size:11px;
    letter-spacing:.1em; text-transform:uppercase; color:var(--ink-500);
    padding: 20px 0 0;
  }
  .crumbs a{ color:var(--ink-700); text-decoration:none; transition: color var(--t) }
  .crumbs a:hover{ color: var(--teal-700) }
  .crumbs span.sep{ color: var(--ink-300) }
  .crumbs span.cur{ color: var(--teal-700) }

  /* ---------- RELATED LINKS WIDGET ---------- */
  .related{
    margin-top: 60px;
    background: var(--white);
    border: 1px solid color-mix(in srgb, var(--ink-900) 10%, transparent);
    border-radius: var(--radius-lg);
    padding: 32px;
  }
  .related__head{
    display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap;
    margin-bottom: 22px; padding-bottom: 18px;
    border-bottom: 1px dashed color-mix(in srgb, var(--ink-900) 14%, transparent);
  }
  .related__k{ font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--teal-700) }
  .related__t{ font-family:'Fraunces'; font-size:22px; font-weight:500; letter-spacing:-.015em }
  .related__grid{
    display:grid; gap:14px;
    grid-template-columns: 1fr;
  }
  @media (min-width:720px){ .related__grid{ grid-template-columns: 1fr 1fr 1fr } }
  .related__link{
    display:flex; flex-direction:column; gap:6px;
    padding: 18px;
    text-decoration:none; color:inherit;
    border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--ink-900) 8%, transparent);
    transition: background var(--t), border-color var(--t), transform var(--t);
  }
  .related__link:hover{ background:var(--paper-2); border-color: var(--teal-400); transform: translateY(-2px) }
  .related__link-k{ font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color: var(--ink-500) }
  .related__link-t{ font-family:'Fraunces'; font-size:18px; font-weight:500; letter-spacing:-.015em; line-height:1.25 }
  .related__link-c{ font-size:13px; color:var(--ink-500); margin-top:auto; padding-top:8px }
  .related__link-cta{ font-size:12.5px; color:var(--teal-700); font-weight:600; margin-top:8px; display:inline-flex; align-items:center; gap:6px }

  /* ---------- STICKY CTA BAR ---------- */
  .stickyBar{
    position:fixed; bottom: 18px; left:50%; transform: translateX(-50%) translateY(120%);
    z-index:80;
    background: var(--ink-900); color: var(--paper);
    border-radius: 999px;
    padding: 8px 10px 8px 22px;
    display:flex; align-items:center; gap:14px;
    box-shadow: 0 20px 50px -10px rgba(21,35,48,.4);
    transition: transform 500ms cubic-bezier(.22,.61,.36,1);
    max-width: 92vw;
  }
  .stickyBar.is-on{ transform: translateX(-50%) translateY(0) }
  .stickyBar__t{ font-size:13.5px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
  .stickyBar__t b{ color: var(--teal-400); font-weight:600 }
  .stickyBar__cta{
    display:inline-flex; align-items:center; gap:6px;
    padding: 9px 16px; border-radius:999px;
    background: var(--teal-500); color: var(--white);
    text-decoration:none; font-size:13px; font-weight:600;
    transition: background var(--t);
  }
  .stickyBar__cta:hover{ background: var(--teal-400) }
  @media (max-width: 540px){ .stickyBar__t{ display:none } .stickyBar{ padding: 8px } }

  /* ---------- FOOTER SITEMAP UPGRADE ---------- */
  .footer__grid{ grid-template-columns: 1fr !important }
  @media (min-width: 720px){ .footer__grid{ grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr !important } }

  /* === NEW SECTIONS v1.5 === */
  .cases{ background: var(--paper) }
  .cases__grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:28px; margin-top:52px }
  @media (max-width:960px){ .cases__grid{ grid-template-columns:1fr; gap:36px } }
  .case{ background:var(--white); border:1px solid color-mix(in srgb,var(--ink-900) 9%,transparent); border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column; transition:transform .35s ease,box-shadow .35s ease }
  .case:hover{ transform:translateY(-4px); box-shadow:0 24px 50px -22px rgba(21,35,48,.25) }
  .case__media{ position:relative; aspect-ratio:4/3; overflow:hidden; background:linear-gradient(135deg,var(--ink-800),var(--teal-700)) }
  .case__media img{ width:100%; height:100%; object-fit:cover; display:block }
  .case__tag{ position:absolute; top:14px; left:14px; background:color-mix(in srgb,var(--paper) 92%,transparent); backdrop-filter:blur(10px); padding:6px 12px; border-radius:999px; font-family:'JetBrains Mono',monospace; font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-900) }
  .case__body{ padding:26px 24px 28px; display:flex; flex-direction:column; gap:14px; flex:1 }
  .case__name{ font-family:'Fraunces'; font-weight:500; font-size:26px; letter-spacing:-.02em; margin:0; color:var(--ink-900) }
  .case__sub{ color:var(--ink-500); font-size:13.5px; margin:-10px 0 0 }
  .case__kpi{ list-style:none; padding:16px 0; margin:0; display:grid; grid-template-columns:repeat(3,1fr); gap:8px; border-top:1px dashed color-mix(in srgb,var(--ink-900) 14%,transparent); border-bottom:1px dashed color-mix(in srgb,var(--ink-900) 14%,transparent) }
  .case__kpi li{ display:flex; flex-direction:column; gap:2px }
  .case__kpi-n{ font-family:'Fraunces'; font-size:26px; letter-spacing:-.02em; color:var(--teal-700); line-height:1 }
  .case__kpi-l{ font-size:11.5px; color:var(--ink-500); line-height:1.35 }
  .case__quote{ font-family:'Fraunces'; font-style:italic; font-weight:500; font-size:17px; line-height:1.45; color:var(--ink-800); margin:0; padding:0; border:none }
  .case__author{ font-size:12.5px; color:var(--ink-500); font-weight:500 }
  .cases__cta{ text-align:center; margin-top:44px }

  .vtest{ background:var(--paper-2) }
  .sec-head--center{ text-align:center; max-width:720px; margin-left:auto; margin-right:auto }
  .vtest__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px }
  @media (max-width:960px){ .vtest__grid{ grid-template-columns:1fr; gap:32px } }
  .vtest__card{ margin:0; display:flex; flex-direction:column; gap:14px }
  .vtest__media{ position:relative; aspect-ratio:9/12; overflow:hidden; border-radius:var(--radius-lg); background:linear-gradient(135deg,var(--ink-800),var(--teal-700)); cursor:pointer }
  .vtest__poster{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .6s ease }
  .vtest__media:hover .vtest__poster{ transform:scale(1.04) }
  .vtest__play{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:72px; height:72px; border-radius:50%; background:rgba(247,245,240,.95); border:none; cursor:pointer; display:grid; place-items:center; color:var(--ink-900); box-shadow:0 18px 40px -10px rgba(0,0,0,.4); transition:transform .35s ease,background .35s ease }
  .vtest__play svg{ width:26px; height:26px; margin-left:4px }
  .vtest__media:hover .vtest__play{ background:var(--teal-500); color:var(--white); transform:translate(-50%,-50%) scale(1.08) }
  .vtest__time{ position:absolute; bottom:14px; right:14px; background:rgba(21,35,48,.78); color:var(--paper); padding:4px 10px; border-radius:999px; font-family:'JetBrains Mono',monospace; font-size:11px; backdrop-filter:blur(8px) }
  .vtest__card figcaption{ display:flex; flex-direction:column; gap:2px; padding:0 4px }
  .vtest__card figcaption strong{ font-family:'Fraunces'; font-weight:500; font-size:19px; color:var(--ink-900); letter-spacing:-.01em }
  .vtest__card figcaption span{ font-size:13px; color:var(--ink-500) }

  .vbox{ border:none; padding:0; background:transparent; max-width:min(90vw,480px); width:100% }
  .vbox::backdrop{ background:rgba(15,24,32,.88); backdrop-filter:blur(8px) }
  .vbox__video{ width:100%; aspect-ratio:9/16; background:black; border-radius:var(--radius-lg); display:block }
  .vbox__close{ position:absolute; top:-44px; right:0; background:transparent; border:1px solid rgba(247,245,240,.3); color:var(--paper); border-radius:50%; width:36px; height:36px; cursor:pointer; display:grid; place-items:center }

  .bts{ background:var(--paper) }
  .bts__mosaic{ display:grid; gap:14px; margin-top:48px; grid-template-columns:repeat(4,1fr); grid-template-rows:220px 220px; grid-template-areas:"a a b c" "a a d e" }
  @media (max-width:880px){ .bts__mosaic{ grid-template-columns:1fr 1fr; grid-template-rows:repeat(3,200px); grid-template-areas:"a a" "b c" "d e" } }
  @media (max-width:540px){ .bts__mosaic{ grid-template-columns:1fr; grid-template-rows:repeat(5,220px); grid-template-areas:"a" "b" "c" "d" "e" } }
  .bts__tile{ position:relative; margin:0; overflow:hidden; border-radius:var(--radius-md); background:linear-gradient(135deg,var(--ink-800),var(--teal-700)) }
  .bts__tile:nth-child(1){ grid-area:a } .bts__tile:nth-child(2){ grid-area:b } .bts__tile:nth-child(3){ grid-area:c } .bts__tile:nth-child(4){ grid-area:d } .bts__tile:nth-child(5){ grid-area:e }
  .bts__tile img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .6s ease }
  .bts__tile:hover img{ transform:scale(1.06) }
  .bts__tile figcaption{ position:absolute; left:14px; bottom:14px; background:color-mix(in srgb,var(--paper) 92%,transparent); backdrop-filter:blur(10px); padding:6px 12px; border-radius:999px; font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.08em; color:var(--ink-900); text-transform:uppercase }

  .promise{ background:var(--paper-2) }
  .promise__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; margin-top:48px; background:color-mix(in srgb,var(--ink-900) 10%,transparent); border:1px solid color-mix(in srgb,var(--ink-900) 10%,transparent); border-radius:var(--radius-lg); overflow:hidden }
  @media (max-width:880px){ .promise__grid{ grid-template-columns:repeat(2,1fr) } }
  @media (max-width:540px){ .promise__grid{ grid-template-columns:1fr } }
  .promise__it{ background:var(--paper); padding:32px 28px; display:flex; flex-direction:column; gap:10px }
  .promise__n{ font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.12em; color:var(--ink-400) }
  /* === WRITTEN TESTIMONIAL === */
  .wtest{ background:var(--paper-2) }
  .wtest__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:52px }
  @media (max-width:960px){ .wtest__grid{ grid-template-columns:1fr; gap:20px } }
  .wtest__card{ margin:0; padding:30px 28px; background:var(--paper); border:1px solid color-mix(in srgb,var(--ink-900) 9%,transparent); border-radius:var(--radius-lg); display:flex; flex-direction:column; gap:18px; position:relative; transition:transform .35s ease,box-shadow .35s ease }
  .wtest__card:hover{ transform:translateY(-3px); box-shadow:0 22px 44px -22px rgba(21,35,48,.2) }
  .wtest__card::before{ content:"\201C"; position:absolute; top:-14px; left:22px; font-family:'Fraunces'; font-size:92px; line-height:1; color:var(--teal-500); opacity:.35; pointer-events:none }
  .wtest__stars{ display:flex; gap:3px; color:#f5b400 }
  .wtest__stars svg{ width:18px; height:18px }
  .wtest__quote{ font-family:'Fraunces'; font-weight:400; font-style:italic; font-size:17.5px; line-height:1.55; color:var(--ink-800); margin:0; padding:0; border:none; flex:1 }
  .wtest__author{ display:flex; align-items:center; gap:14px; padding-top:18px; border-top:1px dashed color-mix(in srgb,var(--ink-900) 14%,transparent) }
  .wtest__avatar{ width:48px; height:48px; border-radius:50%; overflow:hidden; flex-shrink:0; background:linear-gradient(135deg,var(--ink-800),var(--teal-700)); display:grid; place-items:center }
  .wtest__avatar img{ width:100%; height:100%; object-fit:cover; display:block }
  .wtest__avatar-ph{ color:var(--paper); font-family:'Fraunces'; font-weight:500; font-size:16px }
  .wtest__meta{ display:flex; flex-direction:column; gap:1px }
  .wtest__meta strong{ font-weight:600; font-size:14.5px; color:var(--ink-900) }
  .wtest__meta span{ font-size:12.5px; color:var(--ink-500) }
