@font-face {
  font-family: 'Instrument Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/instrument-serif-400.219af963408c.ttf") format('truetype');
}

@font-face {
  font-family: 'Instrument Serif';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/instrument-serif-400i.8c71a7596220.ttf") format('truetype');
}

:root{
    --bg:#f5f8ff;
    --paper:#ffffff;
    --ink:#0d1424;
    --text:#25304a;
    --muted:#7a859c;
    --line:#dfe7f4;
    --line-soft:#edf2fa;
    --blue:#2868e8;
    --blue-2:#1747ad;
    --blue-soft:#eaf1ff;
    --green:#11a35c;
    --green-soft:#e8f7ef;
    --amber:#d88b19;
    --amber-soft:#fff3dc;
    --rose:#d84a67;
    --rose-soft:#fff0f3;
    --shadow:0 28px 70px rgba(22,44,84,.14),0 8px 18px rgba(22,44,84,.07);
    --shadow-sm:0 12px 32px rgba(22,44,84,.09),0 2px 8px rgba(22,44,84,.06);
    --serif:"Instrument Serif",Georgia,"Times New Roman",serif;
    --sans:"Instrument Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    --mono:"Space Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  }

  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  html,body{overflow-x:clip}
  body{
    margin:0;
    color:var(--ink);
    background:
      radial-gradient(900px 520px at 82% 7%, #e5eeff 0%, rgba(229,238,255,0) 64%),
      radial-gradient(800px 520px at 5% 96%, #eef4ff 0%, rgba(238,244,255,0) 62%),
      linear-gradient(180deg,#fff 0%,var(--bg) 100%);
    font-family:var(--sans);
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
  }

  a{text-decoration:none;color:inherit}
  button{font:inherit}

  .wrap{
    width:min(1180px,calc(100% - 48px));
    margin:0 auto;
  }

  .wrap.nav,
  .wrap.hero,
  .wrap.story-intro,
  .wrap.scroll-story{
    width:min(1348px,calc(100% - 56px));
  }

  .wrap.hero{
    width:min(1460px,calc(100% - 48px));
  }

  .nav{
    position:relative;
    z-index:50;
    min-height:76px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
    border-bottom:1px solid rgba(223,231,244,0);
    background:rgba(248,251,255,0);
    transition:background .28s ease,border-color .28s ease,box-shadow .28s ease,backdrop-filter .28s ease,-webkit-backdrop-filter .28s ease;
  }

  .nav.nav-scrolled{
    background:rgba(255,255,255,.92);
    border-bottom-color:rgba(223,231,244,.84);
    box-shadow:0 10px 30px rgba(22,44,84,.08);
    -webkit-backdrop-filter:blur(18px);
    backdrop-filter:blur(18px);
  }

  .brand{
    display:inline-flex;
    align-items:baseline;
    color:var(--ink);
    font-family:"Mogra",var(--sans);
    font-size:22px;
    font-weight:400;
    letter-spacing:0;
    line-height:1;
    white-space:nowrap;
  }

  .brand-wordmark{
    display:inline-flex;
    align-items:baseline;
    gap:.18em;
  }

  .brand-wordmark-ai{color:var(--ink)}
  .brand-wordmark-accent{color:var(--blue)}

  .mark{
    display:none;
  }

  .links{
    display:flex;
    align-items:center;
    gap:28px;
    color:#26304a;
    font-size:14.5px;
    font-weight:560;
  }

  .links a:not(.nav-cta){
    position:relative;
    display:inline-flex;
    align-items:center;
    min-height:36px;
  }

  .links .back-link{
    margin-right:10px;
    color:#66718a;
    font-weight:700;
  }

  .links .back-link:hover,
  .links .back-link:focus-visible{
    color:var(--blue-2);
  }

  .links .back-link::before{
    content:"";
    position:absolute;
    right:-20px;
    top:50%;
    width:1px;
    height:18px;
    background:var(--line);
    transform:translateY(-50%);
  }

  .links a:not(.nav-cta)::after{
    content:"";
    position:absolute;
    left:0;
    right:0;
    bottom:-5px;
    height:2px;
    border-radius:999px;
    background:var(--blue);
    transform:scaleX(0);
    transform-origin:left;
    transition:transform .18s ease;
  }

  .links a:not(.nav-cta):hover::after,
  .links a:not(.nav-cta):focus-visible::after,
  .links a[aria-current="page"]::after{
    transform:scaleX(1);
  }

  .nav-cta{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:36px;
    padding:0 15px;
    border:1px solid var(--line);
    border-radius:10px;
    background:#fff;
    color:var(--blue-2);
    font-weight:700;
    box-shadow:0 6px 18px rgba(22,44,84,.08);
  }

  .burger{
    display:none;
    width:44px;
    height:44px;
    align-items:center;
    justify-content:center;
    flex-direction:column;
    gap:5px;
    border:1px solid var(--line);
    border-radius:12px;
    background:#fff;
    color:var(--ink);
    cursor:pointer;
    box-shadow:0 8px 20px rgba(22,44,84,.07);
  }

  .burger span{
    display:block;
    width:18px;
    height:2px;
    border-radius:999px;
    background:currentColor;
    transition:opacity .18s ease, transform .18s ease;
  }

  .burger.active span:first-child{
    transform:rotate(45deg) translate(5px,5px);
  }

  .burger.active span:nth-child(2){
    opacity:0;
  }

  .burger.active span:nth-child(3){
    transform:rotate(-45deg) translate(5px,-5px);
  }

  .mobile-overlay{
    position:fixed;
    z-index:49;
    inset:0;
    display:flex;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:10px;
    padding:calc(env(safe-area-inset-top) + 76px) 15px calc(env(safe-area-inset-bottom) + 22px);
    background:rgba(248,251,255,.98);
    border-top:1px solid rgba(223,231,244,.86);
    -webkit-backdrop-filter:blur(18px);
    backdrop-filter:blur(18px);
    opacity:0;
    pointer-events:none;
    transition:opacity .2s ease;
  }

  .mobile-overlay.open{
    opacity:1;
    pointer-events:auto;
  }

  .mobile-overlay-link{
    min-height:52px;
    display:flex;
    align-items:center;
    justify-content:center;
    border:1px solid var(--line);
    border-radius:14px;
    background:#fff;
    color:var(--ink);
    font-size:16px;
    font-weight:780;
    box-shadow:0 10px 24px rgba(22,44,84,.06);
  }

  .mobile-overlay-link:hover,
  .mobile-overlay-link:focus-visible{
    border-color:rgba(40,104,232,.30);
    color:var(--blue);
    outline:none;
  }

  .mobile-overlay-cta{
    border-color:var(--blue);
    background:var(--blue);
    color:#fff;
    box-shadow:0 18px 42px rgba(40,104,232,.24);
  }

  .mobile-overlay-cta:hover,
  .mobile-overlay-cta:focus-visible{
    border-color:var(--blue-2);
    background:var(--blue-2);
    color:#fff;
  }

  .hero{
    position:relative;
    isolation:isolate;
    min-height:calc(92vh - 76px);
    display:grid;
    grid-template-columns:minmax(640px,.92fr) minmax(0,1.08fr);
    align-items:center;
    gap:clamp(22px,3vw,44px);
    padding:4px 0 36px;
    overflow:visible;
  }

  .hero::before{
    content:"";
    position:absolute;
    z-index:-1;
    right:min(-12vw,-80px);
    top:4%;
    width:min(920px,68vw);
    height:80%;
    border-radius:999px;
    background:
      radial-gradient(closest-side at 56% 34%, rgba(40,104,232,.10), transparent 72%),
      radial-gradient(closest-side at 75% 70%, rgba(17,163,92,.08), transparent 76%);
    filter:blur(22px);
    opacity:.9;
    pointer-events:none;
  }

  .hero-copy h1{
    margin:0;
    font-family:var(--serif);
    font-weight:820;
    line-height:.84;
    letter-spacing:0;
    font-size:clamp(88px,9.2vw,140px);
  }

  .hero-copy{
    position:relative;
    z-index:2;
  }

  .hero-copy h1 em{
    color:var(--blue);
    font-style:italic;
    font-weight:820;
  }

  .lead{
    max-width:47ch;
    margin:32px 0 0;
    color:#33405d;
    font-size:22px;
    line-height:1.55;
  }

  .lead strong{
    color:var(--ink);
    font-weight:760;
  }

  .lead-mobile{
    display:none;
  }

  .cta-row{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:14px;
    margin-top:34px;
  }

  .btn{
    min-height:56px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:9px;
    padding:0 24px;
    border-radius:12px;
    font-size:16px;
    font-weight:780;
  }

  .btn-primary{
    color:#fff;
    background:var(--blue);
    box-shadow:0 14px 30px rgba(40,104,232,.28),0 2px 6px rgba(40,104,232,.18);
    transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  }

  .btn-secondary{
    border:1px solid var(--line);
    background:rgba(255,255,255,.82);
    color:var(--ink);
    transition:transform .18s ease, border-color .18s ease, background .18s ease;
  }

  .btn-primary:hover{
    transform:translateY(-2px);
    background:#1f5fe0;
    box-shadow:0 20px 38px rgba(40,104,232,.32),0 3px 8px rgba(40,104,232,.18);
  }

  .btn-secondary:hover{
    transform:translateY(-1px);
    border-color:#c6d5ee;
    background:#fff;
  }

  .mobile-sticky-cta{
    display:none;
  }

  .proof{
    display:flex;
    align-items:flex-start;
    gap:10px;
    margin-top:26px;
    max-width:44ch;
    color:var(--muted);
    font-size:14.5px;
    line-height:1.45;
  }

  .proof strong{
    color:var(--ink);
    font-weight:760;
  }

  .check{
    width:17px;
    height:17px;
    margin-top:1px;
    border-radius:999px;
    border:1.5px solid rgba(17,163,92,.35);
    display:grid;
    place-items:center;
    flex:0 0 auto;
    color:var(--green);
  }

  .hero-visual{
    position:relative;
    min-width:0;
    min-height:690px;
    isolation:isolate;
    overflow:hidden;
    border-radius:34px;
    background:
      linear-gradient(135deg, rgba(255,255,255,.68), rgba(242,247,255,.58)),
      radial-gradient(620px 380px at 76% 42%, rgba(40,104,232,.12), transparent 70%),
      radial-gradient(500px 340px at 96% 72%, rgba(17,163,92,.12), transparent 70%);
    perspective:none;
  }

  .hero-visual-image{
    min-height:660px;
    display:grid;
    align-items:center;
    justify-items:end;
    overflow:visible;
    border-radius:0;
    background:none;
  }

  .hero-visual-image::before,
  .hero-visual-image::after{
    display:none;
  }

  .hero-visual::before{
    content:"";
    position:absolute;
    z-index:0;
    inset:0;
    background-image:radial-gradient(circle at 1px 1px, rgba(40,104,232,.13) 1px, transparent 0);
    background-size:24px 24px;
    mask-image:radial-gradient(ellipse at 61% 47%, #000 0%, transparent 67%);
    opacity:.42;
    pointer-events:none;
  }

  .hero-visual::after{
    content:"";
    position:absolute;
    z-index:0;
    inset:10% 4% 3% 4%;
    border-radius:36px;
    background:
      conic-gradient(from 210deg at 52% 44%, transparent 0 18%, rgba(40,104,232,.20) 25%, transparent 34%, transparent 54%, rgba(17,163,92,.18) 66%, transparent 74%),
      radial-gradient(circle at 54% 48%, rgba(255,255,255,.92), transparent 28%);
    filter:blur(18px);
    opacity:.50;
    transform:rotate(-5deg);
    pointer-events:none;
  }

  .hero-showcase{
    position:relative;
    z-index:1;
    min-height:650px;
    padding:58px 28px 34px;
    transform-style:flat;
  }

  .showcase-halo{
    position:absolute;
    inset:0;
    border-radius:34px;
    background:
      linear-gradient(135deg, rgba(255,255,255,.82), rgba(241,247,255,.48)),
      radial-gradient(580px 340px at 80% 22%, rgba(40,104,232,.12), transparent 72%);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.78);
    opacity:.52;
  }

  .showcase-halo::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:inherit;
    background-image:
      linear-gradient(rgba(124,148,190,.10) 1px, transparent 1px),
      linear-gradient(90deg, rgba(124,148,190,.10) 1px, transparent 1px);
    background-size:34px 34px;
    mask-image:linear-gradient(130deg, rgba(0,0,0,.78), transparent 78%);
  }

  .pain-chip{
    position:absolute;
    z-index:7;
    display:inline-flex;
    align-items:center;
    gap:8px;
    min-height:38px;
    padding:0 13px;
    border-radius:999px;
    border:1px solid rgba(187,204,232,.82);
    background:rgba(255,255,255,.82);
    color:#25304a;
    box-shadow:0 16px 36px rgba(22,44,84,.10);
    backdrop-filter:blur(12px);
    font-size:12.5px;
    font-weight:760;
    animation:heroFloat 6s ease-in-out infinite;
  }

  .pain-chip::before{
    content:"";
    width:8px;
    height:8px;
    border-radius:999px;
    background:var(--blue);
    box-shadow:0 0 0 5px rgba(40,104,232,.10);
  }

  .pain-chip:nth-child(3)::before,
  .pain-chip:nth-child(4)::before{
    background:var(--green);
    box-shadow:0 0 0 5px rgba(17,163,92,.10);
  }

  .chip-a{left:2%;top:10%}
  .chip-b{right:10%;top:7%;animation-delay:-1.5s}
  .chip-c{left:3%;bottom:18%;animation-delay:-3s}
  .chip-d{right:9%;bottom:14%;animation-delay:-4.2s}

  .system-console{
    position:relative;
    z-index:5;
    left:auto;
    top:auto;
    width:100%;
    min-height:430px;
    border:1px solid rgba(155,181,222,.95);
    border-radius:28px;
    background:
      linear-gradient(180deg,rgba(255,255,255,.99),rgba(248,251,255,.96)),
      radial-gradient(520px 280px at 72% 18%, rgba(40,104,232,.12), transparent 66%);
    box-shadow:
      0 34px 90px rgba(22,44,84,.16),
      0 1px 0 rgba(255,255,255,.92) inset;
    overflow:hidden;
    transform:none;
    transform-origin:center;
  }

  .system-console::before{
    content:"";
    position:absolute;
    inset:0;
    background:
      linear-gradient(115deg, transparent 0 35%, rgba(255,255,255,.72) 45%, transparent 55% 100%);
    opacity:.36;
    transform:translateX(-68%);
    animation:heroSheen 9s ease-in-out infinite;
    pointer-events:none;
  }

  .console-top{
    position:relative;
    z-index:1;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    padding:14px 16px;
    border-bottom:1px solid rgba(205,218,239,.78);
    background:rgba(255,255,255,.68);
    font-size:12px;
    font-weight:780;
  }

  .console-brand{
    display:flex;
    align-items:center;
    gap:9px;
    min-width:0;
  }

  .console-dots{
    display:flex;
    gap:5px;
  }

  .console-dots span{
    width:8px;
    height:8px;
    border-radius:999px;
    background:#b9c7de;
  }

  .console-dots span:first-child{background:#ff8d8d}
  .console-dots span:nth-child(2){background:#ffd166}
  .console-dots span:nth-child(3){background:#63d992}

  .console-status{
    display:inline-flex;
    align-items:center;
    gap:7px;
    min-height:24px;
    padding:0 10px;
    border-radius:999px;
    background:var(--green-soft);
    color:var(--green);
    font-size:11px;
    white-space:nowrap;
  }

  .console-status::before{
    content:"";
    width:7px;
    height:7px;
    border-radius:999px;
    background:var(--green);
    box-shadow:0 0 0 5px rgba(17,163,92,.09);
  }

  .console-body{
    position:relative;
    z-index:1;
    display:grid;
    grid-template-columns:.95fr .78fr 1.12fr;
    gap:14px;
    padding:18px;
  }

  .intake-rail,
  .build-core,
  .output-rail{
    border:1px solid var(--line-soft);
    border-radius:18px;
    background:rgba(255,255,255,.88);
  }

  .intake-rail,
  .output-rail{
    padding:14px;
  }

  .rail-title,
  .output-head span,
  .core-badge{
    font-family:var(--mono);
    font-size:10.5px;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
  }

  .rail-title{
    color:#52627c;
    margin-bottom:12px;
  }

  .source-list{
    display:grid;
    gap:9px;
  }

  .source-item{
    display:grid;
    grid-template-columns:28px 1fr;
    gap:9px;
    align-items:center;
    padding:10px;
    border:1px solid rgba(206,218,239,.82);
    border-radius:13px;
    background:rgba(255,255,255,.92);
  }

  .source-icon{
    width:28px;
    height:28px;
    border-radius:10px;
    display:grid;
    place-items:center;
    background:#eef4ff;
    color:var(--blue);
    font-family:var(--mono);
    font-size:10px;
    font-weight:700;
  }

  .source-name{
    display:block;
    color:var(--ink);
    font-size:13px;
    font-weight:780;
    line-height:1.1;
  }

  .source-meta{
    display:block;
    margin-top:4px;
    color:#53617a;
    font-size:10.5px;
    font-weight:680;
  }

  .build-core{
    position:relative;
    overflow:hidden;
    min-height:100%;
    padding:16px;
    background:
      radial-gradient(180px 160px at 50% 44%, rgba(40,104,232,.18), transparent 72%),
      linear-gradient(180deg, rgba(238,245,255,.96), rgba(255,255,255,.86));
    text-align:center;
  }

  .build-core::before,
  .build-core::after{
    content:"";
    position:absolute;
    left:50%;
    width:2px;
    height:86px;
    background:linear-gradient(180deg, transparent, rgba(40,104,232,.46), transparent);
    transform:translateX(-50%);
  }

  .build-core::before{top:12px}
  .build-core::after{bottom:12px}

  .core-badge{
    display:inline-flex;
    color:var(--blue);
    padding:7px 10px;
    border-radius:999px;
    border:1px solid rgba(40,104,232,.20);
    background:rgba(255,255,255,.76);
  }

  .core-title{
    position:relative;
    z-index:1;
    margin:28px auto 22px;
    max-width:130px;
    color:var(--ink);
    font-size:22px;
    line-height:1.05;
    font-weight:780;
    letter-spacing:-.02em;
  }

  .core-pulse{
    position:relative;
    z-index:1;
    width:74px;
    height:74px;
    margin:0 auto 24px;
    border-radius:24px;
    display:grid;
    place-items:center;
    color:white;
    background:linear-gradient(135deg,var(--blue),#68a2ff);
    box-shadow:0 18px 42px rgba(40,104,232,.28),0 0 0 14px rgba(40,104,232,.08);
    animation:heroPulse 3.2s ease-in-out infinite;
  }

  .core-pulse svg{
    width:32px;
    height:32px;
  }

  .core-node{
    position:relative;
    z-index:1;
    display:inline-flex;
    align-items:center;
    gap:6px;
    margin:4px;
    padding:6px 8px;
    border-radius:999px;
    background:rgba(255,255,255,.82);
    border:1px solid rgba(206,218,239,.82);
    color:#52627c;
    font-size:10.5px;
    font-weight:760;
  }

  .output-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-bottom:12px;
  }

  .output-head strong{
    color:var(--ink);
    font-size:18px;
    letter-spacing:-.015em;
  }

  .output-head span{
    color:#079553;
  }

  .metric-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin-bottom:12px;
  }

  .metric-card{
    min-height:74px;
    padding:12px;
    border-radius:15px;
    border:1px solid rgba(206,218,239,.82);
    background:linear-gradient(180deg,rgba(248,251,255,.98),rgba(255,255,255,.9));
  }

  .metric-card strong{
    display:block;
    color:var(--ink);
    font-size:24px;
    line-height:1;
    letter-spacing:-.03em;
  }

  .metric-card span{
    display:block;
    margin-top:6px;
    color:#53617a;
    font-size:11px;
    line-height:1.25;
    font-weight:720;
  }

  .work-row{
    display:grid;
    grid-template-columns:9px 1fr auto;
    align-items:center;
    gap:9px;
    min-height:38px;
    margin-top:8px;
    padding:8px 9px;
    border-radius:12px;
    border:1px solid var(--line-soft);
    background:rgba(255,255,255,.92);
  }

  .work-row i{
    width:9px;
    height:9px;
    border-radius:999px;
    background:var(--green);
  }

  .work-row b{
    min-width:0;
    color:#25304a;
    font-size:12px;
    font-weight:760;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .work-row span{
    display:inline-flex;
    align-items:center;
    min-height:20px;
    padding:0 8px;
    border-radius:999px;
    background:var(--blue-soft);
    color:var(--blue-2);
    font-size:10px;
    font-weight:780;
    white-space:nowrap;
  }

  .hero-result-card{
    position:absolute;
    z-index:8;
    left:58px;
    bottom:22px;
    width:min(330px,48%);
    padding:18px;
    border-radius:22px;
    background:linear-gradient(135deg, #13213f, #2568e8);
    color:white;
    box-shadow:0 28px 70px rgba(40,104,232,.28);
    transform:rotate(-1.8deg);
  }

  .hero-result-card span{
    display:block;
    color:rgba(255,255,255,.68);
    font-family:var(--mono);
    font-size:10.5px;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
  }

  .hero-result-card strong{
    display:block;
    margin-top:10px;
    font-size:23px;
    line-height:1.08;
    letter-spacing:-.02em;
  }

  .hero-result-card p{
    margin:8px 0 0;
    color:rgba(255,255,255,.78);
    font-size:12.5px;
    line-height:1.45;
  }

  @keyframes heroFloat{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-9px)}
  }

  @keyframes heroPulse{
    0%,100%{transform:scale(1);box-shadow:0 18px 42px rgba(40,104,232,.28),0 0 0 14px rgba(40,104,232,.08)}
    50%{transform:scale(1.035);box-shadow:0 22px 52px rgba(40,104,232,.34),0 0 0 20px rgba(40,104,232,.06)}
  }

  @keyframes heroSheen{
    0%,52%,100%{transform:translateX(-72%)}
    72%{transform:translateX(72%)}
  }

  .journey-visual{
    position:relative;
    z-index:1;
    min-height:560px;
    padding:42px 36px 36px;
    display:grid;
    grid-template-columns:minmax(0,1fr) 112px minmax(0,1fr);
    gap:12px;
    align-items:center;
  }

  .journey-visual::before{
    content:"";
    position:absolute;
    z-index:0;
    left:13%;
    right:13%;
    top:50%;
    height:128px;
    border-radius:999px;
    background:linear-gradient(90deg, rgba(216,74,103,.10), rgba(40,104,232,.18), rgba(17,163,92,.15));
    filter:blur(18px);
    transform:translateY(-50%);
    pointer-events:none;
  }

  .journey-card{
    position:relative;
    z-index:1;
    min-height:424px;
    border-radius:32px;
    border:0;
    background:transparent;
    box-shadow:none;
    overflow:visible;
    backdrop-filter:none;
  }

  .journey-card::before{
    content:"";
    position:absolute;
    z-index:0;
    inset:64px 8px 0;
    border-radius:32px;
    background:rgba(255,255,255,.62);
    box-shadow:0 24px 70px rgba(22,44,84,.10);
    pointer-events:none;
  }

  .journey-card::after{
    content:"";
    position:absolute;
    z-index:0;
    inset:64px 8px 0;
    border-radius:32px;
    background-image:
      linear-gradient(rgba(124,148,190,.075) 1px, transparent 1px),
      linear-gradient(90deg, rgba(124,148,190,.075) 1px, transparent 1px);
    background-size:26px 26px;
    mask-image:linear-gradient(180deg,#000,rgba(0,0,0,.25));
    pointer-events:none;
  }

  .journey-card.problem::before{
    background:
      radial-gradient(230px 180px at 27% 20%, rgba(216,74,103,.13), transparent 70%),
      rgba(255,255,255,.72);
  }

  .journey-card.success::before{
    background:
      radial-gradient(230px 180px at 72% 18%, rgba(17,163,92,.14), transparent 70%),
      rgba(255,255,255,.76);
  }

  .journey-content{
    position:relative;
    z-index:1;
    height:100%;
    padding:22px;
    display:flex;
    flex-direction:column;
  }

  .journey-label{
    display:inline-flex;
    width:max-content;
    align-items:center;
    min-height:30px;
    padding:0 11px;
    border-radius:999px;
    font-family:var(--mono);
    font-size:10px;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
  }

  .problem .journey-label{
    color:var(--rose);
    background:var(--rose-soft);
  }

  .success .journey-label{
    color:var(--green);
    background:var(--green-soft);
  }

  .journey-card h3{
    margin:13px 0 0;
    color:var(--ink);
    font-size:clamp(34px,2.7vw,44px);
    line-height:.92;
    letter-spacing:-.025em;
  }

  .journey-summary{
    margin:10px 0 0;
    max-width:24ch;
    color:#5e6b84;
    font-size:13px;
    line-height:1.35;
    font-weight:720;
  }

  .problem-pile,
  .success-screen{
    position:relative;
    flex:1;
    margin-top:16px;
    min-height:282px;
  }

  .chaos-cloud{
    position:absolute;
    left:50%;
    top:53%;
    width:min(230px,94%);
    height:178px;
    border-radius:52% 48% 43% 57% / 50% 43% 57% 50%;
    background:
      radial-gradient(circle at 30% 34%, rgba(255,255,255,.98) 0 18%, transparent 19%),
      radial-gradient(circle at 67% 48%, rgba(255,255,255,.94) 0 19%, transparent 20%),
      linear-gradient(145deg, rgba(255,238,243,.96), rgba(255,255,255,.86));
    border:1px solid rgba(216,74,103,.16);
    box-shadow:0 24px 54px rgba(216,74,103,.12),0 18px 42px rgba(22,44,84,.08);
    transform:translate(-50%,-50%) rotate(-3deg);
  }

  .chaos-cloud::before,
  .chaos-cloud::after{
    content:"";
    position:absolute;
    inset:auto;
    border-radius:999px;
    border:7px solid rgba(216,74,103,.26);
    transform:rotate(-18deg);
  }

  .chaos-cloud::before{
    left:20px;
    right:42px;
    top:52px;
    height:58px;
    border-left-color:transparent;
    border-bottom-color:transparent;
  }

  .chaos-cloud::after{
    left:64px;
    right:22px;
    top:88px;
    height:48px;
    border-top-color:transparent;
    border-right-color:transparent;
    transform:rotate(14deg);
  }

  .paper-note{
    position:absolute;
    z-index:2;
    width:152px;
    min-height:82px;
    padding:13px;
    border-radius:18px;
    border:1px solid rgba(216,74,103,.18);
    background:#fff;
    box-shadow:0 16px 34px rgba(22,44,84,.09);
  }

  .paper-note strong,
  .clean-window strong{
    display:block;
    color:var(--ink);
    font-size:15px;
    line-height:1.1;
  }

  .paper-note span,
  .clean-window span{
    display:block;
    margin-top:7px;
    color:#66748e;
    font-size:11px;
    line-height:1.3;
    font-weight:700;
  }

  .paper-note.excel{
    left:2%;
    top:38%;
    transform:rotate(-8deg);
  }

  .paper-note.mail{
    right:0;
    top:52%;
    transform:rotate(7deg);
  }

  .paper-note.phone{
    left:22%;
    top:4%;
    transform:rotate(-3deg);
  }

  .scribble-line{
    position:absolute;
    z-index:1;
    left:16%;
    top:38%;
    width:min(185px,72%);
    height:92px;
    color:var(--rose);
    opacity:.42;
  }

  .warning-bubble{
    position:absolute;
    z-index:3;
    right:12%;
    top:28%;
    width:62px;
    height:62px;
    border-radius:23px;
    display:grid;
    place-items:center;
    color:#fff;
    background:linear-gradient(135deg,var(--rose),#ef8aa0);
    box-shadow:0 18px 38px rgba(216,74,103,.22);
    font-size:28px;
    font-weight:800;
  }

  .transform-step{
    position:relative;
    display:grid;
    place-items:center;
    min-height:424px;
  }

  .transform-line{
    position:absolute;
    left:50%;
    top:16%;
    bottom:16%;
    width:2px;
    transform:translateX(-50%);
    background:linear-gradient(180deg, rgba(40,104,232,0), rgba(40,104,232,.46), rgba(17,163,92,.42), rgba(17,163,92,0));
  }

  .transform-orb{
    position:relative;
    z-index:1;
    width:104px;
    height:104px;
    border-radius:32px;
    display:grid;
    place-items:center;
    color:white;
    background:linear-gradient(135deg,var(--blue),#63a0ff);
    box-shadow:0 24px 54px rgba(40,104,232,.28),0 0 0 18px rgba(40,104,232,.08);
  }

  .transform-orb svg{
    width:46px;
    height:46px;
  }

  .transform-copy{
    position:absolute;
    z-index:2;
    left:50%;
    bottom:54px;
    width:max-content;
    max-width:138px;
    transform:translateX(-50%);
    padding:10px 12px;
    border-radius:999px;
    border:1px solid rgba(40,104,232,.20);
    background:rgba(255,255,255,.82);
    color:var(--blue-2);
    box-shadow:0 16px 34px rgba(22,44,84,.08);
    font-size:12px;
    line-height:1.15;
    font-weight:800;
    text-align:center;
  }

  .journey-arrow{
    position:absolute;
    z-index:0;
    left:-22px;
    right:-22px;
    top:50%;
    height:3px;
    border-radius:999px;
    background:linear-gradient(90deg, rgba(216,74,103,.18), var(--blue), var(--green));
  }

  .journey-arrow::after{
    content:"";
    position:absolute;
    right:-3px;
    top:50%;
    width:15px;
    height:15px;
    border-top:3px solid var(--green);
    border-right:3px solid var(--green);
    transform:translateY(-50%) rotate(45deg);
  }

  .clean-window{
    position:relative;
    width:min(242px,100%);
    min-height:0;
    margin:0 auto;
    padding:72px 16px 16px;
    border-radius:26px;
    border:1px solid rgba(17,163,92,.20);
    background:#fff;
    box-shadow:0 18px 44px rgba(22,44,84,.09);
    overflow:hidden;
  }

  .clean-window::before{
    content:"";
    position:absolute;
    left:50%;
    top:16px;
    width:58px;
    height:58px;
    border-radius:20px;
    background:linear-gradient(135deg,var(--green-soft),#f8fffb);
    box-shadow:0 0 0 14px rgba(17,163,92,.08);
    transform:translateX(-50%);
  }

  .big-check{
    position:absolute;
    left:50%;
    top:31px;
    width:30px;
    height:30px;
    color:var(--green);
    transform:translateX(-50%);
  }

  .clean-row{
    display:grid;
    grid-template-columns:10px 1fr auto;
    gap:10px;
    align-items:center;
    min-height:38px;
    margin-top:10px;
    padding:8px 10px;
    border-radius:12px;
    background:#f7fbff;
    border:1px solid var(--line-soft);
    color:#26304a;
    font-size:12px;
    font-weight:760;
  }

  .clean-row i{
    width:9px;
    height:9px;
    border-radius:999px;
    background:var(--green);
  }

  .clean-row em{
    color:var(--blue-2);
    font-style:normal;
    font-size:10px;
    background:var(--blue-soft);
    padding:3px 7px;
    border-radius:999px;
  }

  .success-badges{
    position:relative;
    width:min(242px,100%);
    margin:12px auto 0;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
  }

  .success-badge{
    min-height:68px;
    padding:12px;
    border-radius:16px;
    background:rgba(255,255,255,.84);
    border:1px solid rgba(17,163,92,.16);
    box-shadow:0 12px 30px rgba(22,44,84,.06);
  }

  .success-badge strong{
    display:block;
    color:var(--ink);
    font-size:22px;
    line-height:1;
  }

  .success-badge span{
    display:block;
    margin-top:6px;
    color:#53617a;
    font-size:11px;
    line-height:1.25;
    font-weight:720;
  }

  .dual-path-visual{
    position:relative;
    z-index:1;
    min-height:560px;
    padding:42px 38px;
    display:grid;
    grid-template-columns:minmax(0,.94fr) 120px minmax(0,1.06fr);
    gap:16px;
    align-items:center;
  }

  .dual-path-visual::before{
    content:"";
    position:absolute;
    z-index:0;
    left:10%;
    right:8%;
    top:50%;
    height:210px;
    border-radius:999px;
    background:linear-gradient(90deg, rgba(216,74,103,.12), rgba(216,139,25,.12) 32%, rgba(40,104,232,.18) 58%, rgba(17,163,92,.16));
    filter:blur(28px);
    transform:translateY(-50%);
    pointer-events:none;
  }

  .path-inputs{
    position:relative;
    z-index:1;
    display:grid;
    gap:18px;
  }

  .path-card,
  .solution-card{
    position:relative;
    overflow:hidden;
    border:1px solid rgba(187,204,232,.76);
    background:rgba(255,255,255,.78);
    box-shadow:0 24px 70px rgba(22,44,84,.10);
    backdrop-filter:blur(14px);
  }

  .path-card{
    min-height:194px;
    border-radius:28px;
    padding:22px;
  }

  .path-card::before,
  .solution-card::before{
    content:"";
    position:absolute;
    inset:0;
    background-image:
      linear-gradient(rgba(124,148,190,.075) 1px, transparent 1px),
      linear-gradient(90deg, rgba(124,148,190,.075) 1px, transparent 1px);
    background-size:26px 26px;
    mask-image:linear-gradient(135deg,#000,transparent 78%);
    pointer-events:none;
  }

  .path-card.problem{
    border-color:rgba(216,74,103,.18);
    background:
      radial-gradient(230px 150px at 16% 12%, rgba(216,74,103,.13), transparent 72%),
      rgba(255,255,255,.80);
  }

  .path-card.idea{
    border-color:rgba(216,139,25,.20);
    background:
      radial-gradient(230px 150px at 18% 12%, rgba(216,139,25,.14), transparent 72%),
      rgba(255,255,255,.82);
  }

  .path-tag{
    position:relative;
    z-index:1;
    display:inline-flex;
    align-items:center;
    min-height:28px;
    padding:0 10px;
    border-radius:999px;
    font-family:var(--mono);
    font-size:10px;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
  }

  .problem .path-tag{
    color:var(--rose);
    background:var(--rose-soft);
  }

  .idea .path-tag{
    color:#a6630f;
    background:var(--amber-soft);
  }

  .solution-card .path-tag{
    color:var(--green);
    background:var(--green-soft);
  }

  .path-card h3,
  .solution-card h3{
    position:relative;
    z-index:1;
    margin:14px 0 0;
    color:var(--ink);
    letter-spacing:-.03em;
    line-height:.94;
  }

  .path-card h3{
    max-width:8ch;
    font-size:34px;
  }

  .solution-card h3{
    font-size:clamp(40px,3.7vw,54px);
  }

  .path-card p,
  .solution-card p{
    position:relative;
    z-index:1;
    margin:10px 0 0;
    color:#5e6b84;
    font-size:13px;
    line-height:1.36;
    font-weight:720;
  }

  .path-card p{
    max-width:22ch;
  }

  .path-icon{
    position:absolute;
    z-index:1;
    right:18px;
    top:20px;
    width:58px;
    height:58px;
    border-radius:20px;
    display:grid;
    place-items:center;
    font-size:28px;
    font-weight:850;
    box-shadow:0 16px 36px rgba(22,44,84,.10);
  }

  .problem .path-icon{
    color:#fff;
    background:linear-gradient(135deg,var(--rose),#ef8aa0);
  }

  .idea .path-icon{
    color:#9a5d0d;
    background:linear-gradient(135deg,#fff4d8,#ffffff);
  }

  .path-clues{
    position:relative;
    z-index:1;
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-top:16px;
  }

  .path-clue{
    display:inline-flex;
    align-items:center;
    min-height:28px;
    padding:0 10px;
    border-radius:999px;
    border:1px solid rgba(206,218,239,.82);
    background:rgba(255,255,255,.82);
    color:#34415d;
    font-size:11px;
    font-weight:800;
    box-shadow:0 8px 20px rgba(22,44,84,.06);
  }

  .path-merge{
    position:relative;
    z-index:1;
    min-height:430px;
    display:grid;
    place-items:center;
  }

  .merge-lines{
    position:absolute;
    inset:0 -34px;
    width:calc(100% + 68px);
    height:100%;
    overflow:visible;
  }

  .merge-lines path{
    fill:none;
    stroke-width:5.5;
    stroke-linecap:round;
    stroke-linejoin:round;
  }

  .merge-problem{
    stroke:rgba(216,74,103,.36);
  }

  .merge-idea{
    stroke:rgba(216,139,25,.36);
  }

  .merge-output{
    stroke:rgba(17,163,92,.70);
  }

  .merge-core{
    position:relative;
    z-index:2;
    width:104px;
    height:104px;
    border-radius:32px;
    display:grid;
    place-items:center;
    color:white;
    background:linear-gradient(135deg,var(--blue),#63a0ff);
    box-shadow:0 24px 54px rgba(40,104,232,.28),0 0 0 18px rgba(40,104,232,.08);
  }

  .merge-core svg{
    width:46px;
    height:46px;
  }

  .merge-caption{
    position:absolute;
    z-index:3;
    left:50%;
    bottom:50px;
    width:max-content;
    max-width:150px;
    transform:translateX(-50%);
    padding:10px 12px;
    border-radius:999px;
    border:1px solid rgba(40,104,232,.20);
    background:rgba(255,255,255,.86);
    color:var(--blue-2);
    box-shadow:0 16px 34px rgba(22,44,84,.08);
    font-size:12px;
    line-height:1.15;
    font-weight:800;
    text-align:center;
  }

  .solution-card{
    z-index:1;
    min-height:430px;
    border-radius:34px;
    padding:26px;
    border-color:rgba(17,163,92,.20);
    background:
      radial-gradient(280px 190px at 78% 14%, rgba(17,163,92,.14), transparent 72%),
      rgba(255,255,255,.82);
  }

  .solution-window{
    position:relative;
    z-index:1;
    margin-top:22px;
    padding:18px;
    border-radius:24px;
    border:1px solid rgba(17,163,92,.18);
    background:#fff;
    box-shadow:0 18px 44px rgba(22,44,84,.08);
  }

  .solution-check{
    width:66px;
    height:66px;
    margin:0 auto 14px;
    border-radius:24px;
    display:grid;
    place-items:center;
    color:var(--green);
    background:linear-gradient(135deg,var(--green-soft),#f8fffb);
    box-shadow:0 0 0 14px rgba(17,163,92,.08);
  }

  .solution-check svg{
    width:34px;
    height:34px;
  }

  .solution-window strong{
    display:block;
    color:var(--ink);
    font-size:18px;
    line-height:1.1;
    text-align:center;
  }

  .solution-window span{
    display:block;
    margin-top:7px;
    color:#66748e;
    font-size:11.5px;
    line-height:1.35;
    font-weight:760;
    text-align:center;
  }

  .solution-row{
    display:grid;
    grid-template-columns:10px 1fr auto;
    gap:10px;
    align-items:center;
    min-height:38px;
    margin-top:10px;
    padding:8px 10px;
    border-radius:12px;
    background:#f7fbff;
    border:1px solid var(--line-soft);
    color:#26304a;
    font-size:12px;
    font-weight:760;
  }

  .solution-row i{
    width:9px;
    height:9px;
    border-radius:999px;
    background:var(--green);
  }

  .solution-row em{
    color:var(--blue-2);
    font-style:normal;
    font-size:10px;
    background:var(--blue-soft);
    padding:3px 7px;
    border-radius:999px;
  }

  .solution-results{
    position:relative;
    z-index:1;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin-top:12px;
  }

  .solution-stat{
    min-height:66px;
    padding:12px;
    border-radius:16px;
    background:rgba(255,255,255,.84);
    border:1px solid rgba(17,163,92,.16);
    box-shadow:0 12px 30px rgba(22,44,84,.06);
  }

  .solution-stat strong{
    display:block;
    color:var(--ink);
    font-size:22px;
    line-height:1;
  }

  .solution-stat span{
    display:block;
    margin-top:6px;
    color:#53617a;
    font-size:11px;
    line-height:1.25;
    font-weight:720;
  }

  .illustration-visual{
    position:relative;
    z-index:1;
    min-height:560px;
    padding:28px;
    display:grid;
    place-items:center;
  }

  .hero-visual-image .illustration-visual{
    min-height:0;
    padding:0;
    width:100%;
    min-width:0;
  }

  .hero-visual-image .illustration-visual::before{
    display:none;
  }

  .illustration-visual::before{
    content:"";
    position:absolute;
    z-index:0;
    inset:6% 2% 5%;
    border-radius:44px;
    background:
      radial-gradient(360px 260px at 70% 20%, rgba(40,104,232,.12), transparent 72%),
      radial-gradient(360px 260px at 74% 78%, rgba(17,163,92,.12), transparent 72%),
      linear-gradient(135deg, rgba(255,255,255,.68), rgba(242,247,255,.34));
    box-shadow:inset 0 1px 0 rgba(255,255,255,.7);
    pointer-events:none;
  }

  .hero-asset-img{
    position:relative;
    z-index:1;
    display:block;
    width:min(122%,940px);
    max-width:none;
    height:auto;
    margin-left:auto;
    object-fit:contain;
    border-radius:0;
    transform:translateX(-18%) scale(1.02);
    transform-origin:center right;
    filter:drop-shadow(0 32px 68px rgba(40,104,232,.08));
    pointer-events:none;
  }

  .process-illustration{
    position:relative;
    z-index:1;
    width:100%;
    max-width:680px;
    height:auto;
    overflow:visible;
    display:none;
  }

  .illo-line{
    fill:none;
    stroke:#141b2b;
    stroke-width:3.2;
    stroke-linecap:round;
    stroke-linejoin:round;
  }

  .illo-thin{
    fill:none;
    stroke:#141b2b;
    stroke-width:2;
    stroke-linecap:round;
    stroke-linejoin:round;
  }

  .illo-dash{
    fill:none;
    stroke:#141b2b;
    stroke-width:2;
    stroke-linecap:round;
    stroke-dasharray:2 9;
    opacity:.52;
  }

  .illo-soft-blue{fill:#eaf1ff}
  .illo-soft-green{fill:#e8f7ef}
  .illo-soft-rose{fill:#fff0f3}
  .illo-soft-amber{fill:#fff3dc}
  .illo-blue{fill:var(--blue)}
  .illo-green{fill:var(--green)}
  .illo-yellow{fill:#ffd02f}
  .illo-white{fill:#fff}
  .illo-shadow{filter:drop-shadow(0 18px 24px rgba(22,44,84,.10))}

  .illo-label{
    font-family:var(--mono);
    font-size:12px;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
    fill:#50617e;
  }

  .illo-title{
    font-family:var(--sans);
    font-size:24px;
    font-weight:800;
    letter-spacing:-.03em;
    fill:var(--ink);
  }

  .illo-small{
    font-family:var(--sans);
    font-size:13px;
    font-weight:760;
    fill:#5c6b86;
  }

  .illo-tiny{
    font-family:var(--sans);
    font-size:11px;
    font-weight:800;
    fill:#34415d;
  }

  .sheet-grid{
    display:grid;
    grid-template-columns:34px 1fr 42px;
    border:1px solid var(--line-soft);
    border-radius:9px;
    overflow:hidden;
    font-family:var(--mono);
    font-size:9.5px;
    color:#4f5a70;
  }
  .sheet-grid span{padding:5px;border-right:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
  .sheet-grid span:nth-child(3n){border-right:0}
  .sheet-grid span:nth-last-child(-n+3){border-bottom:0}
  .bad{background:var(--rose-soft);color:var(--rose);font-weight:700}

  .story-intro{
    position:relative;
    padding:clamp(84px,9vw,132px) 0 clamp(28px,4vw,56px);
    isolation:isolate;
  }

  .story-intro::before{
    content:"";
    position:absolute;
    z-index:-1;
    left:50%;
    top:22px;
    width:100vw;
    height:calc(100% + 80px);
    transform:translateX(-50%);
    background:
      radial-gradient(820px 420px at 22% 16%, rgba(40,104,232,.08), transparent 68%),
      linear-gradient(180deg, rgba(255,255,255,0), rgba(246,250,255,.70) 54%, rgba(246,250,255,0));
    pointer-events:none;
  }

  .story-intro h2{
    max-width:1120px;
    margin:0;
    font-family:var(--serif);
    font-weight:400;
    font-size:clamp(74px,8.4vw,118px);
    line-height:.9;
    letter-spacing:0;
    text-wrap:balance;
  }

  .story-intro h2 em{
    color:var(--blue);
    font-style:italic;
  }

  .story-intro p{
    max-width:820px;
    margin:30px 0 0;
    color:#33405d;
    font-size:clamp(21px,2.1vw,28px);
    line-height:1.48;
  }

  .scroll-story{
    position:relative;
    padding:18px 0 74px;
    isolation:isolate;
  }

  .scroll-story::before{
    content:"";
    position:absolute;
    z-index:-1;
    top:-92px;
    bottom:18px;
    left:50%;
    width:100vw;
    transform:translateX(-50%);
    background:
      radial-gradient(880px 560px at 72% 38%, rgba(40,104,232,.10), transparent 70%),
      radial-gradient(720px 520px at 18% 76%, rgba(17,163,92,.07), transparent 68%),
      linear-gradient(180deg, rgba(255,255,255,0), rgba(245,248,255,.82) 31%, rgba(245,248,255,.2) 100%);
    pointer-events:none;
  }

  .process-step-layout{
    position:relative;
    display:grid;
    grid-template-columns:minmax(360px,.42fr) minmax(0,1fr);
    gap:clamp(48px,5vw,92px);
    align-items:center;
    min-height:clamp(520px,48vw,590px);
    isolation:isolate;
  }

  .process-step-layout + .process-step-layout{
    margin-top:clamp(8px,2vw,24px);
  }

  .process-step-layout--reverse{
    grid-template-columns:minmax(0,.98fr) minmax(360px,.46fr);
    gap:clamp(48px,5vw,84px);
  }

  .process-step-layout--reverse .process-step-copy{
    grid-column:2;
    justify-self:start;
    max-width:470px;
  }

  .process-step-layout--reverse .process-visual{
    grid-column:1;
    grid-row:1;
    margin-right:0;
    margin-left:0;
  }

  .process-step-layout--reverse .process-understanding-art{
    inset:50% auto auto 0;
    width:clamp(720px,58vw,960px);
  }

  .process-step-copy{
    position:relative;
    z-index:2;
    max-width:450px;
  }

  .process-step-copy::before{
    content:"";
    position:absolute;
    z-index:-1;
    inset:-54px -94px -58px -58px;
    background:
      radial-gradient(ellipse at 24% 44%, rgba(255,255,255,.98), rgba(255,255,255,.88) 44%, rgba(255,255,255,.54) 64%, rgba(255,255,255,0) 84%);
    filter:blur(10px);
    pointer-events:none;
  }

  .process-step-layout--reverse .process-step-copy::before{
    inset:-54px -58px -58px -94px;
    background:
      radial-gradient(ellipse at 74% 44%, rgba(255,255,255,.98), rgba(255,255,255,.88) 44%, rgba(255,255,255,.54) 64%, rgba(255,255,255,0) 84%);
  }

  .process-step-copy h3{
    margin:0;
    font-size:clamp(40px,4.3vw,58px);
    line-height:1;
    letter-spacing:-.02em;
  }

  .process-step-copy p{
    margin:18px 0 0;
    color:#33405d;
    font-size:18px;
    line-height:1.62;
  }

  .process-points{
    display:grid;
    gap:13px;
    margin:28px 0 0;
    padding:0;
    list-style:none;
  }

  .process-points li{
    position:relative;
    padding-left:28px;
    color:#3b4968;
    font-size:15.5px;
    line-height:1.48;
  }

  .process-points li::before{
    content:"";
    position:absolute;
    left:0;
    top:.45em;
    width:10px;
    height:10px;
    border-radius:999px;
    background:var(--blue);
    box-shadow:0 0 0 6px rgba(40,104,232,.10);
  }

  .process-support-note{
    margin-top:24px;
    padding:18px 20px;
    border:1px solid rgba(40,104,232,.16);
    border-radius:18px;
    background:linear-gradient(135deg,rgba(255,255,255,.86),rgba(238,244,255,.70));
    box-shadow:0 16px 38px rgba(22,44,84,.06);
  }

  .process-support-note strong{
    display:block;
    color:var(--ink);
    font-size:16px;
    line-height:1.2;
  }

  .process-support-note p{
    margin:7px 0 0;
    color:#3b4968;
    font-size:14.5px;
    line-height:1.48;
  }

  .support-section{
    position:relative;
    padding:18px 0 98px;
    isolation:isolate;
  }

  .support-section::before{
    content:"";
    position:absolute;
    z-index:-1;
    top:112px;
    bottom:30px;
    left:50%;
    width:100vw;
    transform:translateX(-50%);
    background:linear-gradient(180deg, rgba(247,250,255,.78), rgba(255,255,255,0));
    pointer-events:none;
  }

  .support-showcase{
    display:grid;
    gap:clamp(18px,2.8vw,34px);
    justify-items:center;
  }

  .support-copy-block{
    position:relative;
    z-index:2;
    max-width:820px;
    text-align:center;
  }

  .support-copy-block .section-heading{
    display:block;
    margin:0;
  }

  .support-copy-block .section-heading h2{
    max-width:760px;
    margin:0 auto;
    font-family:var(--sans);
    font-weight:820;
    font-size:clamp(44px,5.2vw,68px);
    line-height:.96;
    letter-spacing:-.03em;
  }

  .support-copy-block .section-heading h2 .text-accent{
    font-style:normal;
    font-weight:820;
  }

  .support-copy-block .section-heading p{
    max-width:680px;
    margin:20px auto 0;
    font-size:18px;
    line-height:1.58;
  }

  .support-visual{
    position:relative;
    width:100%;
    min-height:430px;
    margin:0;
    overflow:visible;
    opacity:.94;
  }

  .support-art{
    position:absolute;
    inset:50% auto auto 50%;
    width:clamp(840px,76vw,1120px);
    max-width:none;
    height:auto;
    transform:translate(-50%,-50%);
    overflow:visible;
    display:block;
  }

  .support-art image{
    pointer-events:none;
  }

  .step-number{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:42px;
    height:30px;
    border-radius:9px;
    background:var(--blue-soft);
    color:var(--blue-2);
    font-family:var(--mono);
    font-size:12px;
    font-weight:700;
    margin-bottom:16px;
  }

  .process-visual{
    position:relative;
    min-height:clamp(500px,46vw,570px);
    margin-right:0;
    overflow:visible;
    z-index:0;
  }

  .process-understanding-art{
    position:absolute;
    inset:50% 0 auto auto;
    width:clamp(720px,58vw,960px);
    max-width:none;
    height:auto;
    transform:translateY(-50%);
    display:block;
    overflow:visible;
    -webkit-mask-image:radial-gradient(ellipse at center, #000 0 62%, rgba(0,0,0,.82) 75%, rgba(0,0,0,.22) 88%, transparent 97%);
    mask-image:radial-gradient(ellipse at center, #000 0 62%, rgba(0,0,0,.82) 75%, rgba(0,0,0,.22) 88%, transparent 97%);
  }

  .process-understanding-art image{
    pointer-events:none;
  }

  .process-mobile-picture{
    display:none;
  }

  .process-mobile-art{
    display:block;
    width:100%;
    height:auto;
  }

  .section-heading{
    display:grid;
    grid-template-columns:minmax(300px,.74fr) minmax(420px,1fr);
    gap:60px;
    align-items:end;
    margin-bottom:32px;
  }

  .section-heading h2{
    margin:0;
    font-family:var(--serif);
    font-weight:400;
    font-size:clamp(42px,5vw,66px);
    line-height:1;
  }

  .section-heading p{
    margin:0;
    color:#33405d;
    font-size:18px;
    line-height:1.62;
  }

  .text-accent{
    color:var(--blue);
    font-style:italic;
  }

  .stack-section,
  .faq-section{
    position:relative;
    padding:34px 0 94px;
  }

  .faq-section::before,
  .contact-section::after{
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:0;
    height:2px;
    background:
      linear-gradient(90deg,rgba(40,104,232,.58),rgba(40,104,232,0)) left top / clamp(96px,12vw,162px) 2px no-repeat,
      linear-gradient(90deg,transparent,rgba(190,205,230,.88),rgba(190,205,230,.72),transparent) center top / 100% 1px no-repeat;
    pointer-events:none;
  }

  .contact-section::before{
    content:"";
    position:absolute;
    z-index:-1;
    left:50%;
    top:8px;
    bottom:20px;
    width:100vw;
    transform:translateX(-50%);
    background:
      radial-gradient(760px 480px at 17% 30%, rgba(40,104,232,.10), transparent 68%),
      radial-gradient(760px 520px at 78% 64%, rgba(17,163,92,.09), transparent 70%),
      linear-gradient(180deg,rgba(255,255,255,.45),rgba(238,244,255,.7));
  }

  .stack-section{
    padding-top:84px;
  }

  .stack-strip{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
  }

  .stack-panel{
    padding:28px;
    border-radius:20px;
    border:1px solid rgba(187,204,232,.72);
    background:rgba(255,255,255,.64);
    box-shadow:0 18px 46px rgba(22,44,84,.06);
  }

  .stack-panel h3{
    margin:0 0 18px;
    font-size:24px;
    line-height:1.1;
    letter-spacing:-.02em;
  }

  .stack-tags{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
  }

  .stack-tags span{
    display:inline-flex;
    align-items:center;
    min-height:34px;
    padding:0 12px;
    border-radius:10px;
    border:1px solid var(--line);
    background:#fff;
    color:#33405d;
    font-size:13px;
    font-weight:700;
  }

  .risk-list{
    display:grid;
    gap:12px;
  }

  .risk-item{
    display:grid;
    grid-template-columns:34px 1fr;
    gap:12px;
    align-items:start;
    color:#3b4968;
    font-size:14.5px;
    line-height:1.5;
  }

  .risk-item span:first-child{
    width:28px;
    height:28px;
    border-radius:999px;
    display:grid;
    place-items:center;
    background:var(--green-soft);
    color:var(--green);
    font-weight:800;
  }

  .projects-section{
    position:relative;
    padding:clamp(96px,9vw,136px) 0 104px;
    isolation:isolate;
  }

  .projects-section::before{
    content:"";
    position:absolute;
    z-index:-1;
    left:50%;
    top:12px;
    bottom:18px;
    width:100vw;
    transform:translateX(-50%);
    background:
      radial-gradient(720px 420px at 15% 16%, rgba(40,104,232,.10), transparent 68%),
      radial-gradient(620px 440px at 86% 70%, rgba(17,163,92,.08), transparent 70%),
      linear-gradient(180deg,rgba(255,255,255,.28),rgba(238,244,255,.54));
    pointer-events:none;
  }

  .projects-proof{
    display:grid;
    gap:0;
    border-top:1px solid rgba(187,204,232,.72);
    border-bottom:1px solid rgba(187,204,232,.54);
  }

  .project-feature,
  .project-row{
    position:relative;
    overflow:visible;
    border:0;
    background:transparent;
    box-shadow:none;
  }

  .project-feature::before,
  .project-row::before{
    content:"";
    position:absolute;
    left:0;
    top:-1px;
    width:76px;
    height:3px;
    border-radius:999px;
    background:linear-gradient(90deg,var(--blue),rgba(40,104,232,0));
    opacity:.86;
  }

  .project-row::before{
    background:linear-gradient(90deg,var(--green),rgba(17,163,92,0));
  }

  .project-feature--learning::before{
    background:linear-gradient(90deg,var(--green),rgba(17,163,92,0));
  }

  .project-feature{
    min-height:0;
    padding:48px 0 52px;
    display:grid;
    grid-template-columns:minmax(360px,.78fr) minmax(430px,.64fr);
    gap:56px;
    align-items:center;
  }

  .project-feature::after{
    content:"";
    position:absolute;
    right:-120px;
    bottom:10px;
    width:360px;
    height:360px;
    border-radius:50%;
    background:radial-gradient(circle,rgba(40,104,232,.10),rgba(40,104,232,0) 68%);
    pointer-events:none;
  }

  .project-copy,
  .project-row-copy{
    position:relative;
    z-index:2;
  }

  .project-copy{
    max-width:680px;
  }

  .project-status{
    display:inline-flex;
    align-items:center;
    width:max-content;
    min-height:30px;
    padding:0 12px;
    border:1px solid rgba(40,104,232,.18);
    border-radius:9px;
    background:rgba(40,104,232,.08);
    color:var(--blue-2);
    font-family:var(--mono);
    font-size:11px;
    font-weight:700;
    letter-spacing:0;
    margin-bottom:14px;
  }

  .project-status::before{
    content:none;
  }

  .project-row .project-status{
    color:var(--green);
  }

  .project-feature--learning .project-status{
    border-color:rgba(17,163,92,.18);
    background:rgba(17,163,92,.09);
    color:var(--green);
  }

  .project-copy h3,
  .project-row-copy h3{
    margin:0;
    font-weight:820;
    letter-spacing:0;
  }

  .project-copy h3{
    max-width:540px;
    font-size:clamp(44px,5.1vw,64px);
    line-height:.98;
  }

  .project-row-copy h3{
    font-size:clamp(34px,3.6vw,48px);
    line-height:1;
  }

  .project-copy p,
  .project-row-copy p{
    margin:20px 0 0;
    max-width:590px;
    color:#33405d;
    line-height:1.58;
  }

  .project-copy p{
    font-size:18px;
  }

  .project-row-copy p{
    font-size:16.5px;
  }

  .project-proof-points{
    display:grid;
    gap:10px;
    margin:24px 0 0;
    padding:0;
    list-style:none;
  }

  .project-proof-points li{
    display:grid;
    grid-template-columns:28px 1fr;
    gap:11px;
    align-items:start;
    color:#33405d;
    font-size:15px;
    line-height:1.45;
  }

  .project-proof-points li::before{
    content:"";
    width:22px;
    height:22px;
    margin-top:1px;
    border-radius:999px;
    background:
      radial-gradient(circle at center,var(--blue) 0 4px,transparent 4px),
      var(--blue-soft);
    box-shadow:0 0 0 4px rgba(40,104,232,.07);
  }

  .project-feature--learning .project-proof-points li::before{
    background:
      radial-gradient(circle at center,var(--green) 0 4px,transparent 4px),
      var(--green-soft);
    box-shadow:0 0 0 4px rgba(17,163,92,.07);
  }

  .project-preview{
    position:relative;
    z-index:2;
    min-height:360px;
    border:0;
    background:transparent;
    box-shadow:none;
    overflow:visible;
  }

  .project-preview::before{
    content:"";
    position:absolute;
    z-index:-1;
    inset:26px -8px 18px 38px;
    border-radius:30px;
    border:1px solid rgba(187,204,232,.58);
    background:
      radial-gradient(220px 160px at 20% 18%,rgba(40,104,232,.11),transparent 70%),
      radial-gradient(240px 170px at 82% 78%,rgba(17,163,92,.08),transparent 72%),
      linear-gradient(180deg,rgba(255,255,255,.72),rgba(238,244,255,.50));
  }

  .project-mentor-preview{
    position:relative;
    z-index:2;
    min-height:360px;
    overflow:hidden;
    border-radius:30px;
    border:1px solid rgba(187,204,232,.58);
    background:
      radial-gradient(260px 210px at 38% 28%,rgba(40,104,232,.12),transparent 72%),
      radial-gradient(260px 190px at 72% 76%,rgba(17,163,92,.10),transparent 72%),
      linear-gradient(180deg,rgba(255,255,255,.76),rgba(238,244,255,.48));
  }

  .project-mentor-preview::before{
    content:"";
    position:absolute;
    z-index:0;
    inset:0;
    background:
      radial-gradient(240px 170px at 56% 26%,rgba(255,255,255,.72),transparent 70%),
      radial-gradient(360px 240px at 50% 84%,rgba(40,104,232,.10),transparent 76%);
    pointer-events:none;
  }

  .projects-section > .section-heading{
    display:block;
    margin-bottom:clamp(46px,5vw,70px);
  }

  .projects-section > .section-heading h2{
    max-width:780px;
    font-size:clamp(74px,8vw,112px);
    line-height:.9;
    letter-spacing:0;
    text-wrap:balance;
  }

  .project-mentor-preview::after{
    content:"";
    position:absolute;
    z-index:1;
    inset:18px 28px 10px 28px;
    background-image:url("../img/ai-mentor-zacni-kodit-cutout.79500c568fc3.png");
    background-repeat:no-repeat;
    background-position:center bottom;
    background-size:contain;
    filter:drop-shadow(0 16px 28px rgba(22,44,84,.12));
    pointer-events:none;
  }

  .preview-browser{
    position:absolute;
    left:0;
    right:10px;
    top:8px;
    min-height:254px;
    border-radius:20px;
    border:1px solid rgba(187,204,232,.78);
    background:#fff;
    box-shadow:0 18px 38px rgba(22,44,84,.10);
    overflow:hidden;
  }

  .preview-topbar{
    display:flex;
    align-items:center;
    gap:8px;
    height:40px;
    padding:0 14px;
    border-bottom:1px solid rgba(187,204,232,.58);
    background:#f8fbff;
  }

  .preview-dot{
    width:8px;
    height:8px;
    border-radius:50%;
    background:#c6d2e5;
  }

  .preview-url{
    margin-left:8px;
    color:#53617c;
    font-family:var(--mono);
    font-size:11px;
    font-weight:700;
  }

  .preview-body{
    display:grid;
    grid-template-columns:1fr 170px;
    gap:16px;
    padding:20px;
  }

  .preview-website{
    display:grid;
    gap:12px;
  }

  .preview-hero-line{
    height:14px;
    border-radius:999px;
    background:#dbe6f8;
  }

  .preview-hero-line:nth-child(1){width:74%}
  .preview-hero-line:nth-child(2){width:54%}
  .preview-hero-line:nth-child(3){width:64%; background:#edf3fb}

  .preview-widget{
    display:grid;
    gap:10px;
    padding:14px;
    border-radius:18px;
    background:#0d1424;
    color:#fff;
    box-shadow:0 16px 30px rgba(13,20,36,.18);
  }

  .preview-widget-head{
    display:flex;
    align-items:center;
    gap:9px;
    font-size:12px;
    font-weight:820;
  }

  .preview-ai-mark{
    width:28px;
    height:28px;
    border-radius:10px;
    display:grid;
    place-items:center;
    background:var(--blue);
    font-family:var(--mono);
    font-size:10px;
    font-weight:900;
  }

  .preview-bubble{
    padding:10px 11px;
    border-radius:14px;
    background:rgba(255,255,255,.10);
    color:#e8efff;
    font-size:12px;
    line-height:1.36;
  }

  .preview-lead{
    position:absolute;
    left:28px;
    bottom:10px;
    width:252px;
    padding:16px;
    border-radius:19px;
    background:rgba(255,255,255,.92);
    border:1px solid rgba(187,204,232,.72);
    box-shadow:0 20px 40px rgba(22,44,84,.10);
  }

  .preview-lead strong{
    display:block;
    font-size:13px;
    line-height:1.25;
    margin-bottom:10px;
  }

  .preview-check{
    display:grid;
    grid-template-columns:18px 1fr;
    gap:8px;
    color:#53617c;
    font-size:12px;
    line-height:1.3;
  }

  .preview-check + .preview-check{
    margin-top:7px;
  }

  .preview-check::before{
    content:"";
    width:16px;
    height:16px;
    border-radius:50%;
    background:
      linear-gradient(135deg,transparent 45%,#fff 45% 58%,transparent 58%) center / 9px 9px no-repeat,
      var(--blue);
  }

  .preview-flow{
    position:absolute;
    right:10px;
    bottom:32px;
    display:flex;
    align-items:center;
    gap:9px;
  }

  .preview-flow span{
    width:46px;
    height:34px;
    border-radius:12px;
    border:1px solid rgba(187,204,232,.72);
    background:#fff;
    box-shadow:0 10px 22px rgba(22,44,84,.07);
  }

  .preview-flow i{
    width:24px;
    height:2px;
    background:rgba(40,104,232,.72);
    position:relative;
  }

  .preview-flow i::after{
    content:"";
    position:absolute;
    right:-1px;
    top:-4px;
    width:9px;
    height:9px;
    border-top:2px solid rgba(40,104,232,.72);
    border-right:2px solid rgba(40,104,232,.72);
    transform:rotate(45deg);
  }

  .project-row{
    min-height:0;
    padding:42px 0;
    border-top:1px solid rgba(187,204,232,.62);
    display:grid;
    grid-template-columns:minmax(0,.82fr) minmax(300px,.44fr);
    gap:54px;
    align-items:center;
  }

  .project-row::after{
    content:"";
    position:absolute;
    right:-90px;
    top:20px;
    width:280px;
    height:280px;
    border-radius:50%;
    background:radial-gradient(circle,rgba(17,163,92,.09),rgba(17,163,92,0) 70%);
    pointer-events:none;
  }

  .project-course-preview{
    position:relative;
    z-index:2;
    min-height:200px;
    border-radius:20px;
    border:1px solid rgba(187,204,232,.70);
    background:rgba(255,255,255,.86);
    box-shadow:0 16px 34px rgba(22,44,84,.07);
    overflow:hidden;
    padding:18px;
    display:grid;
    grid-template-columns:1fr 132px;
    gap:14px;
    align-items:stretch;
  }

  .course-editor{
    border-radius:16px;
    background:#0d1424;
    padding:14px;
    color:#dce8ff;
    font-family:var(--mono);
    font-size:11px;
    line-height:1.72;
  }

  .course-editor span{
    display:block;
  }

  .course-editor .code-blue{color:#7da5ff}
  .course-editor .code-green{color:#7ee2a6}

  .course-side{
    display:grid;
    gap:10px;
  }

  .course-lesson,
  .course-ai{
    border-radius:15px;
    border:1px solid rgba(187,204,232,.68);
    background:#fff;
    padding:12px;
  }

  .course-lesson strong,
  .course-ai strong{
    display:block;
    color:var(--ink);
    font-size:12px;
    line-height:1.2;
    margin-bottom:8px;
  }

  .course-line{
    height:7px;
    border-radius:999px;
    background:#dfe8f5;
  }

  .course-line + .course-line{
    margin-top:6px;
  }

  .course-ai{
    background:#eef7f1;
    border-color:rgba(17,163,92,.18);
  }

  .course-ai strong{
    color:#087844;
  }

  .project-tags{
    display:flex;
    flex-wrap:wrap;
    gap:9px;
    margin-top:22px;
  }

  .project-tags span{
    display:inline-flex;
    align-items:center;
    min-height:30px;
    padding:0 11px;
    border-radius:999px;
    border:1px solid rgba(17,163,92,.18);
    background:rgba(238,247,241,.62);
    color:#33405d;
    font-size:13px;
    font-weight:760;
  }

  .project-links{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    align-items:center;
    margin-top:28px;
    padding-top:0;
  }

  .project-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:9px;
    min-height:56px;
    padding:0 24px;
    border-radius:12px;
    border:0;
    font-size:16px;
    font-weight:780;
    transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
  }

  .project-link:hover{
    transform:translateY(-2px);
  }

  .project-link:disabled,
  .project-link[aria-disabled="true"]{
    cursor:not-allowed;
    opacity:.68;
  }

  .project-link:disabled:hover,
  .project-link[aria-disabled="true"]:hover{
    transform:none;
  }

  .project-link:not(.project-link--primary){
    border:1px solid var(--line);
    background:rgba(255,255,255,.82);
    color:var(--ink);
  }

  .project-link:not(.project-link--primary):hover{
    transform:translateY(-1px);
    border-color:#c6d5ee;
    background:#fff;
  }

  .project-link.project-link--secondary{
    border:1px solid var(--line);
    background:rgba(255,255,255,.82);
    color:var(--ink);
  }

  .project-link.project-link--secondary:hover{
    transform:translateY(-1px);
    border-color:#c6d5ee;
    background:#fff;
  }

  .project-link:not(.project-link--primary):disabled:hover,
  .project-link:not(.project-link--primary)[aria-disabled="true"]:hover{
    transform:none;
    border-color:var(--line);
    background:rgba(255,255,255,.82);
  }

  .project-link.project-link--secondary:disabled:hover,
  .project-link.project-link--secondary[aria-disabled="true"]:hover{
    transform:none;
    border-color:var(--line);
    background:rgba(255,255,255,.82);
  }

  .project-link--primary{
    background:var(--blue);
    color:#fff;
    box-shadow:0 14px 30px rgba(40,104,232,.28),0 2px 6px rgba(40,104,232,.18);
  }

  .project-link--primary:hover{
    background:#1f5fe0;
    box-shadow:0 20px 38px rgba(40,104,232,.32),0 3px 8px rgba(40,104,232,.18);
  }

  .faq-list{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
  }

  .faq-item{
    border:1px solid rgba(187,204,232,.72);
    border-radius:16px;
    background:rgba(255,255,255,.70);
    box-shadow:0 14px 38px rgba(22,44,84,.06);
    overflow:hidden;
  }

  .faq-item summary{
    cursor:pointer;
    position:relative;
    padding:20px 52px 20px 20px;
    list-style:none;
    font-size:17px;
    font-weight:760;
    line-height:1.25;
  }

  .faq-item summary::-webkit-details-marker{display:none}

  .faq-item summary::after{
    content:"+";
    position:absolute;
    top:18px;
    right:20px;
    width:24px;
    height:24px;
    border-radius:999px;
    display:grid;
    place-items:center;
    background:var(--blue-soft);
    color:var(--blue);
    font-weight:760;
  }

  .faq-item[open] summary::after{content:"-"}

  .faq-item p{
    margin:0;
    padding:0 20px 20px;
    color:#3b4968;
    font-size:15px;
    line-height:1.56;
  }

  .contact-section{
    position:relative;
    padding:96px 0 62px;
  }

  .contact-grid{
    display:grid;
    grid-template-columns:minmax(420px,.92fr) minmax(500px,1fr);
    gap:68px;
    align-items:center;
  }

  .contact-copy h2{
    margin:0;
    font-family:var(--serif);
    font-weight:400;
    font-size:clamp(48px,5.45vw,78px);
    line-height:.96;
  }

  .contact-copy p{
    margin:24px 0 0;
    color:#33405d;
    font-size:18px;
    line-height:1.68;
    max-width:590px;
  }

  .contact-guide{
    display:grid;
    gap:14px;
    margin-top:36px;
    max-width:590px;
  }

  .contact-guide-item{
    display:grid;
    grid-template-columns:42px 1fr;
    gap:16px;
    align-items:start;
    padding:18px 18px;
    border:1px solid rgba(187,204,232,.66);
    border-radius:16px;
    background:rgba(255,255,255,.76);
    box-shadow:0 14px 34px rgba(22,44,84,.04);
  }

  .contact-guide-step{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:36px;
    height:36px;
    border-radius:12px;
    background:rgba(40,104,232,.10);
    color:var(--blue);
    font-size:13px;
    font-weight:900;
  }

  .contact-guide-item strong{
    display:block;
    color:var(--ink);
    font-size:15px;
    line-height:1.25;
  }

  .contact-guide-item span:last-child{
    display:block;
    margin-top:3px;
    color:var(--muted);
    font-size:13.5px;
    line-height:1.48;
  }

  .contact-form{
    display:grid;
    gap:16px;
    padding:28px;
    border:1px solid rgba(187,204,232,.86);
    border-radius:28px;
    background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,251,255,.88));
    box-shadow:0 28px 85px rgba(22,44,84,.12),0 1px 0 rgba(255,255,255,.8) inset;
    backdrop-filter:blur(14px);
  }

  .contact-form-head{
    padding-bottom:4px;
  }

  .contact-form-head h3{
    margin:0;
    color:var(--ink);
    font-size:26px;
    line-height:1.08;
  }

  .contact-form-head p{
    margin:8px 0 0;
    color:var(--muted);
    font-size:14.5px;
    line-height:1.55;
  }

  .field{
    display:grid;
    gap:7px;
  }

  .field label{
    color:var(--ink);
    font-size:12.5px;
    font-weight:850;
  }

  .field input,
  .field textarea{
    width:100%;
    border:1px solid var(--line);
    border-radius:14px;
    background:#fff;
    color:var(--ink);
    padding:14px 15px;
    font:inherit;
    font-size:15px;
    outline:none;
    transition:border-color .18s ease, box-shadow .18s ease;
  }

  .field textarea{
    min-height:148px;
    resize:vertical;
  }

  .field-hint{
    color:var(--muted);
    font-size:12.5px;
    line-height:1.42;
  }

  .form-legal{
    display:flex;
    align-items:flex-start;
    gap:10px;
    color:var(--muted);
    font-size:12.5px;
    line-height:1.45;
  }

  .form-legal input{
    width:16px;
    height:16px;
    margin-top:2px;
    accent-color:var(--blue);
  }

  .form-legal a{
    color:var(--blue-2);
    font-weight:700;
  }

  .field input:focus,
  .field textarea:focus{
    border-color:rgba(40,104,232,.58);
    box-shadow:0 0 0 4px rgba(40,104,232,.10);
  }

  .form-foot{
    display:grid;
    gap:12px;
    margin-top:4px;
  }

  .form-foot .btn{
    width:100%;
    min-height:56px;
    font-size:16px;
  }

  .contact-form .btn-primary{
    border:1px solid var(--blue);
    background:var(--blue);
    box-shadow:none;
    transform:none;
  }

  .contact-form .btn-primary:hover,
  .contact-form .btn-primary:focus-visible{
    background:#1f5fe0;
    border-color:#1f5fe0;
    box-shadow:none;
    transform:none;
    outline:none;
  }

  .site-footer{
    padding:26px 0 40px;
    color:#71809a;
    font-size:13px;
  }

  .footer-line{
    border-top:1px solid rgba(190,205,230,.72);
    padding-top:20px;
    display:grid;
    gap:14px;
  }

  .footer-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
    flex-wrap:wrap;
    gap:12px 22px;
  }

  .footer-brand{
    color:var(--ink);
    font-weight:800;
  }

  .footer-company{
    display:grid;
    gap:8px;
  }

  .footer-company small{
    color:#8791a7;
    font-size:12px;
    line-height:1.5;
  }

  .footer-main,
  .footer-legal{
    display:flex;
    flex-wrap:wrap;
    justify-content:flex-end;
    gap:10px 16px;
  }

  .footer-main{
    color:#26304a;
    font-size:13px;
    font-weight:750;
  }

  .footer-legal{
    padding-top:10px;
    border-top:1px solid rgba(190,205,230,.72);
    font-size:12px;
    font-weight:700;
  }

  .footer-legal a{color:var(--blue-2)}
  .footer-main a:hover,
  .footer-legal a:hover{text-decoration:underline;text-underline-offset:4px}

  .final-cta{
    padding:78px 0 104px;
    text-align:center;
  }

  .final-cta h2{
    margin:0 auto;
    max-width:760px;
    font-family:var(--serif);
    font-weight:400;
    font-size:clamp(44px,5vw,68px);
    line-height:1;
  }

  .final-cta p{
    margin:20px auto 0;
    max-width:620px;
    color:#33405d;
    font-size:18px;
    line-height:1.6;
  }

  .final-cta .cta-row{justify-content:center}

  @media (max-width:1280px){
    .wrap.nav,
    .wrap.hero,
    .wrap.story-intro,
    .wrap.scroll-story{
      width:min(100% - 44px,1180px);
    }
    .hero,
    .story-grid,
    .section-heading,
    .contact-grid{
      grid-template-columns:1fr;
    }
    .stack-strip,
    .faq-list{
      grid-template-columns:1fr;
    }
    .project-feature,
    .project-row{
      grid-template-columns:1fr;
    }
    .projects-section > .section-heading{
      display:block;
      margin-bottom:44px;
    }
    .projects-section > .section-heading h2{
      max-width:860px;
      font-size:clamp(64px,10vw,96px);
    }
    .project-feature{
      min-height:0;
      padding:42px 0 46px;
    }
    .project-preview,
    .project-mentor-preview{
      min-height:360px;
      width:min(100%,720px);
    }
    .project-row{
      padding:40px 0;
    }
    .project-course-preview{
      width:min(100%,640px);
    }
    .support-showcase{
      gap:18px;
    }
    .support-copy-block{
      max-width:760px;
    }
    .support-visual{
      min-height:400px;
      margin:0 -46px;
      opacity:.9;
    }
    .support-art{
      width:min(920px,132%);
    }
    .story-grid{
      display:flex;
      flex-direction:column;
      gap:28px;
      align-items:stretch;
    }
    .hero{
      min-height:0;
      padding-top:26px;
      align-items:start;
      gap:22px;
    }
    .hero::before{
      display:none;
    }
    .hero-visual{
      min-height:0;
      padding-top:0;
      perspective:none;
      overflow:hidden;
      border-radius:28px;
    }
    .hero-visual-image{
      min-height:clamp(430px,54vw,620px);
    }
    .hero-visual::before{
      inset:-18% -8%;
      opacity:.34;
      mask-image:radial-gradient(ellipse at 58% 45%, #000 0%, transparent 72%);
    }
    .hero-visual::after{
      inset:16% 4% 4% 6%;
      opacity:.48;
      filter:blur(22px);
    }
    .hero-showcase{
      position:relative;
      display:grid;
      gap:16px;
      padding:18px 10px;
      min-height:0;
    }
    .journey-visual{
      min-height:0;
      padding:22px;
      grid-template-columns:1fr;
      gap:0;
    }
    .journey-card{
      min-height:350px;
    }
    .transform-step{
      min-height:118px;
    }
    .transform-line{
      left:50%;
      right:auto;
      top:0;
      bottom:0;
      width:2px;
      height:auto;
      transform:translateX(-50%);
      background:linear-gradient(180deg, rgba(216,74,103,.18), rgba(40,104,232,.46), rgba(17,163,92,.42));
    }
    .journey-arrow{
      left:50%;
      right:auto;
      top:8px;
      bottom:8px;
      width:3px;
      height:auto;
      transform:translateX(-50%);
      background:linear-gradient(180deg, rgba(216,74,103,.18), var(--blue), var(--green));
    }
    .journey-arrow::after{
      left:50%;
      right:auto;
      top:auto;
      bottom:-4px;
      transform:translateX(-50%) rotate(135deg);
    }
    .transform-orb{
      width:86px;
      height:86px;
      border-radius:26px;
    }
    .transform-copy{
      bottom:3px;
    }
    .dual-path-visual{
      min-height:0;
      padding:28px;
      grid-template-columns:minmax(0,1fr) 96px minmax(0,1.02fr);
      gap:10px;
    }
    .path-card{
      min-height:180px;
      padding:20px;
      border-radius:26px;
    }
    .path-card h3{
      font-size:32px;
    }
    .path-icon{
      width:54px;
      height:54px;
      border-radius:18px;
    }
    .path-merge,
    .solution-card{
      min-height:398px;
    }
    .merge-core{
      width:86px;
      height:86px;
      border-radius:26px;
    }
    .merge-caption{
      bottom:38px;
    }
    .solution-card{
      padding:22px;
      border-radius:30px;
    }
    .illustration-visual{
      min-height:0;
      padding:22px;
    }
    .hero-asset-img{
      width:min(116%,1080px);
      max-width:none;
      margin-left:0;
      border-radius:0;
      transform:translateX(4%) scale(1.02);
    }
    .process-illustration{
      max-width:760px;
    }
    .showcase-halo{
      inset:0;
      border-radius:28px;
    }
    .pain-orbits{
      display:none;
    }
    .system-console{
      position:relative;
      left:auto;
      top:auto;
      width:100%;
      min-height:0;
      transform:none;
    }
    .hero-result-card{
      position:relative;
      left:auto;
      bottom:auto;
      width:min(420px,100%);
      transform:none;
      order:-1;
    }
    .section-heading,
    .contact-grid{
      gap:24px;
    }
  }

  @media (max-width:980px){
    .lead-desktop{
      display:none;
    }
    .lead-mobile{
      display:inline;
    }
    .hero-asset-img{
      width:min(100%,760px);
      margin:0 auto;
      transform:none;
    }
    .process-step-layout{
      grid-template-columns:1fr;
      gap:18px;
      min-height:clamp(520px,72vw,640px);
      align-items:center;
      padding:42px 0;
    }
    .process-step-layout + .process-step-layout{
      margin-top:18px;
    }
    .process-step-copy{
      max-width:650px;
    }
    .process-visual{
      position:absolute;
      z-index:0;
      inset:64% 0 auto 0;
      display:block;
      min-height:0;
      height:min(440px,58vw);
      margin:0;
      transform:translateY(-50%);
      pointer-events:none;
    }
    .process-step-layout--reverse .process-step-copy,
    .process-step-layout--reverse .process-visual{
      grid-column:auto;
      grid-row:auto;
    }
    .process-step-layout--reverse .process-step-copy{
      justify-self:stretch;
    }
    .process-step-layout--reverse .process-visual{
      margin:0;
    }
    .process-understanding-art{
      display:none;
    }
    .process-mobile-picture{
      display:block;
      width:min(100%,680px);
      margin:0 auto;
      -webkit-mask-image:radial-gradient(ellipse at center, #000 0 60%, rgba(0,0,0,.82) 74%, rgba(0,0,0,.24) 88%, transparent 97%);
      mask-image:radial-gradient(ellipse at center, #000 0 60%, rgba(0,0,0,.82) 74%, rgba(0,0,0,.24) 88%, transparent 97%);
    }
    .process-mobile-art{
      aspect-ratio:3 / 2;
      object-fit:cover;
    }
    .support-visual{
      min-height:330px;
      margin:0;
    }
    .support-art{
      width:min(680px,100%);
    }
  }

  @media (max-width:680px){
    .wrap{width:min(100% - 28px,1180px)}
    .wrap.nav,
    .wrap.hero,
    .wrap.story-intro,
    .wrap.scroll-story{width:min(100% - 28px,1180px)}
    .links{display:none}
    .burger{display:inline-flex}
    .nav{min-height:60px}
    .hero{
      gap:16px;
      padding:6px 0 20px;
    }
    .hero-copy{
      padding-top:2px;
    }
    .hero-copy h1{
      font-size:clamp(53px,12.5vw,60px);
      line-height:.9;
      font-weight:820;
    }
    .lead{
      max-width:100%;
      margin-top:18px;
      font-size:16px;
      line-height:1.46;
      overflow-wrap:break-word;
    }
    .lead-desktop{
      display:none;
    }
    .lead-mobile{
      display:inline;
    }
    .cta-row{
      display:grid;
      grid-template-columns:1fr;
      gap:10px;
      margin-top:22px;
    }
    .btn{
      min-height:50px;
      padding:0 18px;
      border-radius:11px;
      font-size:15px;
    }
    .hero-visual{
      min-height:0;
      padding-top:0;
      border-radius:18px;
      perspective:none;
    }
    .hero-visual-image{
      min-height:clamp(250px,62vw,300px);
    }
    .hero-showcase{
      position:relative;
      display:grid;
      gap:14px;
      padding:0;
      min-height:0;
    }
    .journey-visual{
      padding:14px;
      gap:0;
    }
    .journey-card{
      border-radius:24px;
      min-height:330px;
    }
    .journey-content{
      padding:16px;
    }
    .journey-card h3{
      font-size:38px;
    }
    .journey-summary{
      font-size:12px;
      max-width:28ch;
    }
    .problem-pile,
    .success-screen{
      min-height:240px;
    }
    .paper-note{
      width:142px;
      min-height:74px;
      padding:11px;
      border-radius:14px;
    }
    .paper-note strong,
    .clean-window strong{
      font-size:14px;
    }
    .paper-note span,
    .clean-window span{
      font-size:10.5px;
    }
    .warning-bubble{
      width:54px;
      height:54px;
      border-radius:19px;
      font-size:25px;
    }
    .clean-window{
      width:min(240px,100%);
      padding:68px 14px 14px;
      border-radius:22px;
    }
    .success-badges{
      width:min(240px,100%);
      grid-template-columns:1fr 1fr;
      gap:8px;
      position:relative;
      margin-top:10px;
    }
    .success-badge{
      min-height:58px;
    }
    .dual-path-visual{
      padding:14px;
      grid-template-columns:1fr;
      gap:14px;
    }
    .path-inputs{
      gap:12px;
    }
    .path-card{
      min-height:168px;
      padding:18px;
      border-radius:22px;
    }
    .path-card h3{
      font-size:34px;
    }
    .path-card p,
    .solution-card p{
      font-size:12px;
      max-width:28ch;
    }
    .path-icon{
      width:50px;
      height:50px;
      border-radius:17px;
      font-size:25px;
    }
    .path-clues{
      gap:7px;
      margin-top:14px;
    }
    .path-clue{
      min-height:27px;
      padding:0 9px;
      font-size:10.5px;
    }
    .path-merge{
      min-height:126px;
    }
    .merge-lines{
      display:none;
    }
    .path-merge::before{
      content:"";
      position:absolute;
      top:-12px;
      bottom:-12px;
      left:50%;
      width:3px;
      border-radius:999px;
      background:linear-gradient(180deg, rgba(216,74,103,.24), rgba(216,139,25,.26), rgba(40,104,232,.48), rgba(17,163,92,.62));
      transform:translateX(-50%);
    }
    .merge-core{
      width:78px;
      height:78px;
      border-radius:24px;
      box-shadow:0 18px 42px rgba(40,104,232,.24),0 0 0 14px rgba(40,104,232,.08);
    }
    .merge-core svg{
      width:38px;
      height:38px;
    }
    .merge-caption{
      bottom:-2px;
      font-size:11px;
    }
    .solution-card{
      min-height:0;
      padding:20px;
      border-radius:24px;
    }
    .solution-card h3{
      font-size:42px;
    }
    .solution-window{
      padding:16px;
      border-radius:20px;
    }
    .solution-results{
      grid-template-columns:1fr 1fr;
      gap:8px;
    }
    .solution-stat{
      min-height:58px;
    }
    .illustration-visual{
      padding:4px 0 0;
    }
    .illustration-visual::before{
      inset:2% 0 3%;
      border-radius:24px;
    }
    .hero-asset-img{
      width:104%;
      max-width:none;
      margin-left:-2%;
      border-radius:0;
      transform:none;
      filter:none;
    }
    .process-illustration{
      width:100%;
      max-width:none;
    }
    .illo-title{
      font-size:25px;
    }
    .illo-small{
      font-size:12px;
    }
    .showcase-halo{
      inset:-10px -8px;
      border-radius:24px;
    }
    .pain-orbits{display:none}
    .system-console{
      position:relative;
      left:auto;
      top:auto;
      width:100%;
      min-height:0;
      border-radius:22px;
      transform:none;
    }
    .console-top{
      padding:13px;
    }
    .console-brand{
      min-width:0;
    }
    .console-brand strong{
      min-width:0;
      overflow:hidden;
      text-overflow:ellipsis;
      white-space:nowrap;
    }
    .console-body{
      grid-template-columns:1fr;
      padding:14px;
      gap:10px;
    }
    .intake-rail,
    .output-rail{
      padding:12px;
    }
    .source-list{
      gap:7px;
    }
    .source-item{
      padding:8px;
    }
    .source-meta{
      display:none;
    }
    .build-core{
      min-height:190px;
      padding:14px;
    }
    .core-title{
      max-width:210px;
      margin:16px auto 14px;
      font-size:20px;
    }
    .core-pulse{
      width:62px;
      height:62px;
      border-radius:20px;
      margin-bottom:14px;
    }
    .metric-card{
      min-height:62px;
    }
    .hero-result-card{
      position:relative;
      left:auto;
      bottom:auto;
      width:100%;
      transform:none;
      order:-1;
    }
    .story-intro{
      padding:46px 0 18px;
    }
    .story-intro h2{
      font-size:clamp(47px,12.5vw,56px);
      line-height:.94;
    }
    .story-intro p{
      max-width:100%;
      margin-top:16px;
      font-size:16px;
      line-height:1.48;
    }
    .scroll-story{
      padding:8px 0 46px;
    }
    .scroll-story::before{
      top:-48px;
      bottom:0;
    }
    .process-step-layout{
      gap:12px;
      min-height:clamp(500px,132vw,650px);
      padding:48px 0 52px;
    }
    .process-step-layout + .process-step-layout{
      margin-top:10px;
      padding-top:12px;
    }
    .step-number{
      min-width:36px;
      height:26px;
      margin-bottom:12px;
      border-radius:8px;
      font-size:11px;
    }
    .process-step-copy p,.final-cta p{
      margin-top:13px;
      font-size:15.5px;
      line-height:1.5;
    }
    .process-step-copy h3{
      font-size:clamp(31px,8.6vw,36px);
      line-height:1.02;
    }
    .process-points{
      gap:9px;
      margin-top:18px;
    }
    .process-points li{
      padding-left:24px;
      font-size:14.4px;
      line-height:1.42;
    }
    .process-points li::before{
      width:9px;
      height:9px;
      box-shadow:0 0 0 5px rgba(40,104,232,.10);
    }
    .process-visual,
    .process-step-layout--reverse .process-visual{
      position:absolute;
      inset:68% 0 auto 0;
      display:block;
      height:clamp(320px,86vw,430px);
      min-height:0;
      margin:0;
      transform:translateY(-50%);
    }
    .process-understanding-art{
      display:none;
    }
    .process-mobile-picture{
      display:block;
      width:100%;
      margin:0;
      -webkit-mask-image:radial-gradient(ellipse at center, #000 0 58%, rgba(0,0,0,.82) 73%, rgba(0,0,0,.24) 87%, transparent 97%);
      mask-image:radial-gradient(ellipse at center, #000 0 58%, rgba(0,0,0,.82) 73%, rgba(0,0,0,.24) 87%, transparent 97%);
    }
    .process-mobile-art{
      aspect-ratio:3 / 2;
      object-fit:cover;
    }
    .stack-section,
    .support-section,
    .projects-section,
    .faq-section{
      padding-bottom:52px;
    }
    .projects-section{
      padding-top:46px;
    }
    .projects-section > .section-heading{
      margin-bottom:32px;
    }
    .projects-section > .section-heading h2{
      font-size:clamp(48px,13vw,62px);
      line-height:.94;
    }
    .projects-proof{
      gap:0;
    }
    .project-feature,
    .project-row{
      padding:28px 0 34px;
      border-radius:0;
      gap:18px;
    }
    .project-feature::before,
    .project-row::before{
      width:54px;
      height:2px;
    }
    .project-row{
      padding-top:30px;
    }
    .project-status{
      min-height:28px;
      padding:0 10px;
      margin-bottom:10px;
      font-size:10.5px;
    }
    .project-copy h3{
      font-size:clamp(38px,11vw,48px);
      line-height:.96;
    }
    .project-row-copy h3{
      font-size:clamp(31px,8.8vw,39px);
      line-height:1;
    }
    .project-copy p,
    .project-row-copy p{
      margin-top:15px;
      font-size:15px;
      line-height:1.48;
    }
    .project-proof-points{
      gap:8px;
      margin-top:18px;
    }
    .project-proof-points li{
      grid-template-columns:24px 1fr;
      gap:9px;
      font-size:14px;
    }
    .project-proof-points li::before{
      width:18px;
      height:18px;
      background:
        radial-gradient(circle at center,var(--blue) 0 3px,transparent 3px),
        var(--blue-soft);
      box-shadow:0 0 0 3px rgba(40,104,232,.07);
    }
    .project-preview,
    .project-mentor-preview{
      min-height:202px;
      border-radius:0;
      width:100%;
    }
    .project-preview::before{
      inset:18px -4px 6px 22px;
      border-radius:22px;
    }
    .project-mentor-preview{
      min-height:260px;
      border-radius:22px;
    }
    .project-mentor-preview::before{
      inset:0;
    }
    .project-mentor-preview::after{
      inset:14px 20px 8px 20px;
      background-size:contain;
      background-position:center bottom;
    }
    .preview-browser{
      left:0;
      right:0;
      top:8px;
      min-height:166px;
      border-radius:16px;
    }
    .preview-topbar{
      height:34px;
      padding:0 12px;
    }
    .preview-url{
      font-size:10px;
    }
    .preview-body{
      grid-template-columns:minmax(0,1fr) 118px;
      gap:10px;
      padding:14px;
    }
    .preview-widget{
      padding:12px;
    }
    .preview-widget-head{
      font-size:11px;
    }
    .preview-ai-mark{
      width:24px;
      height:24px;
      border-radius:8px;
      font-size:9px;
    }
    .preview-bubble{
      padding:8px;
      border-radius:12px;
      font-size:10.5px;
    }
    .preview-lead{
      display:none;
    }
    .preview-flow{
      display:none;
    }
    .project-course-preview{
      min-height:0;
      padding:14px;
      border-radius:17px;
      grid-template-columns:1fr;
    }
    .course-side{
      grid-template-columns:1fr 1fr;
    }
    .project-tags{
      gap:8px;
      margin-top:16px;
    }
    .project-tags span{
      min-height:30px;
      padding:0 10px;
      font-size:12.5px;
    }
    .project-links{
      flex-direction:column;
      align-items:flex-start;
      gap:8px;
      margin-top:20px;
      padding-top:0;
    }
    .project-link{
      width:100%;
      min-height:50px;
      padding:0 18px;
      border-radius:11px;
      font-size:15px;
    }
    .project-link--primary{
      width:100%;
    }
    .project-link:not(.project-link--primary){
      min-height:50px;
      padding:0 18px;
    }
    .project-link.project-link--secondary{
      width:100%;
      min-height:50px;
      padding:0 18px;
    }
    .support-visual{
      min-height:220px;
      margin:0 -14px;
    }
    .support-art{
      width:min(450px,106%);
    }
    .support-section{
      padding-top:8px;
    }
    .support-section::before{
      top:52px;
      bottom:0;
    }
    .support-showcase{
      gap:12px;
    }
    .support-copy-block .section-heading h2{
      font-size:clamp(32px,9vw,40px);
      line-height:1;
    }
    .support-copy-block .section-heading p{
      margin-top:14px;
      font-size:15.5px;
      line-height:1.48;
    }
    .faq-section{
      padding-top:24px;
      padding-bottom:42px;
    }
    .faq-list{
      gap:10px;
    }
    .faq-item{
      border-radius:14px;
    }
    .faq-item summary{
      padding:16px 46px 16px 16px;
      font-size:15.5px;
    }
    .faq-item summary::after{
      top:14px;
      right:16px;
    }
    .faq-item p{
      padding:0 16px 16px;
      font-size:14.4px;
      line-height:1.5;
    }
    .section-heading h2,
    .contact-copy h2{
      font-size:clamp(34px,9.8vw,42px);
      line-height:1;
    }
    .section-heading p,
    .contact-copy p{
      font-size:15.8px;
      line-height:1.5;
    }
    .contact-section{
      padding:58px 0 40px;
    }
    .contact-grid{
      gap:22px;
    }
    .contact-copy p{
      margin-top:15px;
    }
    .contact-guide{
      gap:9px;
      margin-top:22px;
    }
    .contact-guide-item{
      grid-template-columns:34px 1fr;
      gap:10px;
      padding:12px;
      border-radius:14px;
    }
    .contact-guide-step{
      width:30px;
      height:30px;
      border-radius:10px;
      font-size:11px;
    }
    .contact-guide-item strong{
      font-size:14.2px;
    }
    .contact-guide-item span:last-child{
      font-size:12.8px;
      line-height:1.4;
    }
    .stack-panel,
    .contact-form{border-radius:18px}
    .contact-form{
      gap:13px;
      padding:18px;
      box-shadow:0 18px 44px rgba(22,44,84,.10),0 1px 0 rgba(255,255,255,.8) inset;
    }
    .contact-form-head h3{
      font-size:22px;
    }
    .contact-form-head p{
      font-size:13.5px;
      line-height:1.45;
    }
    .field{
      gap:6px;
    }
    .field input,
    .field textarea{
      padding:12px 13px;
      border-radius:12px;
      font-size:15px;
    }
    .field textarea{
      min-height:124px;
    }
    .field-hint{
      font-size:12px;
    }
    .form-foot{
      display:grid;
      gap:12px;
    }
    .form-foot .btn{
      width:100%;
      min-height:52px;
    }
    .footer-line{
      display:grid;
    }
    .footer-main,
    .footer-legal{
      justify-content:flex-start;
    }
    .site-footer{
      padding-bottom:86px;
    }
    .mobile-sticky-cta{
      position:fixed;
      z-index:50;
      left:14px;
      right:14px;
      bottom:calc(12px + env(safe-area-inset-bottom));
      min-height:52px;
      display:flex;
      align-items:center;
      justify-content:center;
      gap:8px;
      border-radius:14px;
      color:#fff;
      background:var(--blue);
      box-shadow:0 18px 42px rgba(40,104,232,.30),0 2px 8px rgba(22,44,84,.12);
      font-size:15px;
      font-weight:820;
      opacity:0;
      pointer-events:none;
      transform:translateY(calc(100% + 28px));
      transition:opacity .18s ease, transform .18s ease;
    }
    .mobile-sticky-cta:focus-visible{
      outline:3px solid rgba(40,104,232,.26);
      outline-offset:3px;
    }
    body.mobile-cta-visible .mobile-sticky-cta{
      opacity:1;
      pointer-events:auto;
      transform:translateY(0);
    }
  }

  .hero-visual.hero-visual-image{
    overflow:visible;
    border-radius:0;
    background:transparent;
    box-shadow:none;
  }

  .hero-visual.hero-visual-image::before,
  .hero-visual.hero-visual-image::after,
  .hero-visual.hero-visual-image .illustration-visual::before{
    content:none;
    display:none;
  }

  @media (max-width:1280px){
    .hero-visual.hero-visual-image{
      min-height:0;
      overflow:hidden;
      border-radius:0;
      background:transparent;
    }
  }

  @media (max-width:680px){
    .hero-visual.hero-visual-image{
      overflow:hidden;
    }
  }

  @media (prefers-reduced-motion:reduce){
    *,*::before,*::after{
      transition:none!important;
      animation:none!important;
      scroll-behavior:auto!important;
    }
  }

/* Django production integration */
.contact-form-success {
  align-self: stretch;
}

.contact-form-success[style*="display:none"],
.contact-form-success[style*="display: none"] {
  display: none !important;
}

.form-success-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.form-success-icon {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: var(--green-soft);
  color: var(--green);
  border: 1px solid rgba(17, 163, 92, .18);
  font-weight: 800;
}

.form-success-next {
  display: grid;
  gap: 9px;
  margin: 4px 0 2px;
}

.form-success-next span {
  position: relative;
  min-height: 40px;
  display: flex;
  align-items: center;
  padding: 9px 12px 9px 30px;
  border: 1px solid var(--line-soft);
  border-radius: 12px;
  background: #fff;
  color: var(--text);
  font-size: 14px;
  font-weight: 650;
}

.form-success-next span::before {
  content: "";
  position: absolute;
  left: 13px;
  top: 50%;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  transform: translateY(-50%);
}

.honeypot {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

.field input:focus,
.field textarea:focus {
  border-color: rgba(40, 104, 232, .5);
  box-shadow: 0 0 0 4px rgba(40, 104, 232, .11);
  outline: none;
}

.form-error {
  color: #d92d20;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.45;
}

.cookie-banner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 80;
  border-top: 1px solid var(--line);
  background: rgba(255, 255, 255, .96);
  color: var(--text);
  box-shadow: 0 -12px 42px rgba(22, 44, 84, .08);
  backdrop-filter: blur(16px);
}

.cookie-inner {
  min-height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  font-size: 14px;
}

.cookie-inner p {
  margin: 0;
}

.cookie-inner a {
  color: var(--blue);
  font-weight: 650;
}

.cookie-actions {
  display: flex;
  gap: 10px;
  flex: 0 0 auto;
}

.cookie-actions .btn {
  min-height: 38px;
  padding: 0 16px;
  border-radius: 9px;
  font-size: 13px;
}

@media (max-width: 680px) {
  .cookie-inner {
    align-items: stretch;
    flex-direction: column;
    padding-top: 14px;
    padding-bottom: 14px;
  }

  .cookie-inner p {
    font-size: 13px;
    line-height: 1.45;
    text-align: center;
    overflow-wrap: anywhere;
  }

  .cookie-actions,
  .cookie-actions .btn {
    width: 100%;
  }

  .cookie-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
