/* Reveal-on-scroll */
  
  
  

  /* ---------- NAV ---------- */
  
  
  
  
  
  
  
  
  
  
  .dd-menu{position:absolute;top:100%;left:-14px;min-width:180px;padding:8px;margin-top:14px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 40px rgba(12,55,77,.10),0 4px 12px rgba(12,55,77,.06);opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .22s ease, transform .22s ease, visibility .22s;z-index:60;list-style:none;display:block;gap:0}
  .has-dd:hover .dd-menu,.has-dd:focus-within .dd-menu{opacity:1;visibility:visible;transform:translateY(0)}
  
  
  .dd-menu a{display:block;padding:9px 14px;border-radius:8px;color:var(--ink) !important;font-size:14px;font-weight:500;transition:background .18s ease}
  
  
  .btn{padding:11px 22px;border-radius:999px;font-weight:600;font-size:14px;transition:all .2s;display:inline-flex;align-items:center;gap:8px;text-decoration:none}
  
  
  
  
  

  /* ---------- COMMON ---------- */
  .section{max-width:1320px;margin:0 auto;padding:64px 32px;position:relative}
  .kicker{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);font-weight:700;margin-bottom:18px;display:inline-block}
  h2{font-size:clamp(30px,3.4vw,46px);letter-spacing:-.025em;line-height:1.08;font-weight:700;color:var(--ink)}
  h2 em{font-style:normal;color:var(--teal);font-weight:inherit}

  /* ---------- HERO ---------- */
  .pt-hero{position:relative;width:100%;padding:160px 32px 48px;text-align:center;background:linear-gradient(180deg,#fff 0%,var(--bg) 100%);overflow:hidden}
  .pt-hero::after{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);width:1100px;height:540px;background:radial-gradient(ellipse at center,rgba(79,166,192,.14) 0%,transparent 60%);pointer-events:none;z-index:0}
  .pt-hero-inner{position:relative;z-index:1;max-width:880px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:22px}
  .pt-h1{font-size:clamp(44px,5.4vw,76px);line-height:1.02;letter-spacing:-.03em;font-weight:700;color:var(--ink)}
  .pt-lede{font-size:18px;line-height:1.55;color:var(--muted);max-width:620px;font-weight:400}

  /* ---------- PARTNER SECTION ---------- */
  .pt-section{max-width:1320px;margin:0 auto;padding:56px 32px;scroll-margin-top:96px}
  .pt-section-head{display:grid;grid-template-columns:1fr 1.6fr;gap:48px;align-items:end;margin-bottom:32px}
  .pt-section-head h2{font-size:clamp(28px,3.2vw,40px);font-weight:700;letter-spacing:-.02em;color:var(--ink)}
  .pt-section-head .lede{color:var(--muted);font-size:15px;line-height:1.6;max-width:560px}

  /* ---------- PARTNER GRID ---------- */
  .partner-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
  .partner-card{
    background:#fff;border:1px solid var(--line-soft);border-radius:16px;
    height:120px;display:flex;align-items:center;justify-content:center;
    padding:20px 18px;
    transition:all .2s ease;
    overflow:hidden;
  }
  .partner-card:hover{
    border-color:rgba(79,166,192,.55);
    transform:translateY(-2px);
    box-shadow:0 14px 30px -16px rgba(12,55,77,.10);
  }
  .partner-card img{
    max-width:100%;max-height:64px;width:auto;height:auto;
    object-fit:contain;
    filter:grayscale(1) opacity(.78);
    transition:filter .25s ease, transform .25s ease;
  }
  /* Per-logo size variants, some marks read too small or too big at the
     default 64px. Tune these here rather than per-card inline style. */
  .partner-card img.logo-xl{max-height:120px;max-width:92%}
  .partner-card img.logo-lg{max-height:96px;max-width:88%}
  .partner-card img.logo-sm{max-height:44px;max-width:78%}
  .partner-card img.logo-xs{max-height:34px;max-width:70%}
  /* Logos that ship with a white (or checkered-transparency) background,
     multiply blend mode drops the light pixels into the white card so the
     mark sits cleanly on the surface. */
  .partner-card img.logo-clean{mix-blend-mode:multiply}
  .partner-card:hover img{filter:grayscale(0) opacity(1);transform:scale(1.05)}
  /* Logo cards that link through to a partner integration guide */
  a.partner-card{text-decoration:none;color:inherit;cursor:pointer}
  a.partner-card:focus-visible{outline:2px solid var(--teal);outline-offset:2px}

  /* Text-based logos (when no image asset is available) */
  .partner-text{
    font-size:17px;font-weight:800;letter-spacing:-.015em;
    color:var(--ink);text-align:center;line-height:1.15;
    transition:color .2s ease;
  }
  .partner-text small{display:block;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;margin-top:4px}
  .partner-card:hover .partner-text{color:var(--teal-ink)}

  /* ---------- DEVELOPER FORUM ---------- */
  .forum{
    max-width:1320px;margin:0 auto;padding:48px 32px;
  }
  .forum-card{
    background:linear-gradient(180deg,#fff 0%,var(--bg) 100%);
    border:1px solid var(--line-soft);border-radius:24px;
    padding:48px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
    box-shadow:0 20px 50px -24px rgba(12,55,77,.08);position:relative;overflow:hidden;
  }
  .forum-card::before{content:"";position:absolute;right:-200px;top:-100px;width:600px;height:600px;background:radial-gradient(circle at center,rgba(79,166,192,.10) 0%,transparent 60%);pointer-events:none}
  .forum-card h3{font-size:clamp(26px,2.8vw,36px);font-weight:700;color:var(--ink);letter-spacing:-.02em;line-height:1.15;margin-bottom:14px;position:relative;z-index:1}
  .forum-card h3 em{font-style:normal;color:var(--teal)}
  .forum-card p{color:var(--muted);font-size:15px;line-height:1.6;margin-bottom:24px;position:relative;z-index:1}
  .forum-card .btn{position:relative;z-index:1}
  .forum-visual{position:relative;z-index:1;display:flex;align-items:center;justify-content:center}
  .forum-visual svg{width:80%;max-width:300px;height:auto}

  /* ---------- FINAL CTA ---------- */
  .final-cta{
    background:linear-gradient(180deg,#fff 0%,var(--bg) 100%);
    border:1px solid var(--line-soft);border-radius:32px;
    padding:80px 56px;text-align:center;position:relative;overflow:hidden;
    box-shadow:0 30px 60px -20px rgba(12,55,77,.08);
  }
  .final-cta::before{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);width:900px;height:500px;background:radial-gradient(ellipse at center,rgba(79,166,192,.12) 0%,transparent 60%);pointer-events:none}
  .final-cta h2{position:relative;z-index:2;margin-bottom:20px}
  .final-cta p{position:relative;z-index:2;color:var(--muted);font-size:18px;line-height:1.55;max-width:560px;margin:0 auto 32px}
  .final-cta .btns{position:relative;z-index:2;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

  /* ---------- FOOTER ---------- */
  footer{background:#fff;border-top:1px solid var(--line-soft);padding:72px 32px 36px}
  
  
  
  
  
  
  
  
  
  

  /* ---------- RESPONSIVE ---------- */
  @media (max-width:1100px){
    .partner-grid{grid-template-columns:repeat(4,1fr)}
    .pt-section-head{grid-template-columns:1fr;gap:14px}
  }
  @media (max-width:768px){
    nav ul{display:none}
    .nav-inner{padding:14px 20px}
    .pt-hero{padding:120px 20px 40px}
    .pt-section{padding:64px 20px}
    .partner-grid{grid-template-columns:repeat(2,1fr);gap:10px}
    .partner-card{height:100px;padding:14px}
    .forum-card{grid-template-columns:1fr;gap:24px;padding:32px 24px}
    .forum-visual{display:none}
    .final-cta{padding:48px 24px;border-radius:24px}
    .foot-grid{grid-template-columns:1fr;gap:32px}
  }
