/** Shopify CDN: Minification failed

Line 331:2 Unexpected "@property"

**/

  .ogc-teams-page {
    --bg: #FFFFFF;
    --bg-alt: #F4F6FB;
    --bg-dark: #0B0F1A;
    --ink: #111418;
    --ink-soft: #2B2F38;
    --muted: #5C6373;
    --line: #E5E8EF;
    --line-soft: #EEF1F6;
    --brand: #005AD1;
    --brand-ink: #00307A;
    --brand-soft: #E6EEFB;
    --mint: #88DBB7;
    --orange: #FE5D02;
    --sans: "GT Walsheim", "GT Walsheim Pro", "Manrope", -apple-system, BlinkMacSystemFont, sans-serif;
    --container: 1320px;
    --gutter: 24px;
  }

    .ogc-teams-page * { box-sizing: border-box; }
    .ogc-teams-page { -webkit-text-size-adjust: 100%; }
    .ogc-teams-page {
    margin: 0;
    min-height: 100vh;
    background-color: #0B0F1A;
    background-image:
        radial-gradient(1400px 760px at 50% -2%, rgba(0, 90, 209, .55) 0%, rgba(0, 90, 209, 0) 70%),
        radial-gradient(900px 600px at 92% 10%, rgba(100, 180, 255, .14) 0%, rgba(100, 180, 255, 0) 75%),
        radial-gradient(1500px 1100px at 12% 50%, rgba(0, 90, 209, .14) 0%, rgba(0, 90, 209, 0) 75%),
        radial-gradient(1500px 1100px at 88% 78%, rgba(124, 77, 255, .10) 0%, rgba(124, 77, 255, 0) 75%),
        linear-gradient(to bottom, #07090F 0%, #090C16 44%, #0A0D18 84%, #0B0F1A 100%);
    background-repeat: no-repeat;
    background-size: 100% 100%;
    color: var(--ink);
    font-family: var(--sans);
    font-size: 17px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
  }
  .ogc-teams-page img, .ogc-teams-page svg { max-width: 100%; display: block; }
  .ogc-teams-page a { color: inherit; }

  .ogc-teams-page .container { max-width: var(--container); margin: 0 auto; padding-left: var(--gutter); padding-right: var(--gutter); }
  .ogc-teams-page .container.nav { padding-left: 48px; padding-right: 48px; }
  .ogc-teams-page .section { padding: 26px 0; }
  @media (max-width: 700px) { .ogc-teams-page .section { padding: 12px 0; } }
  .ogc-teams-page .section.alt { background: var(--bg-alt); }

  .ogc-teams-page /* ── SCROLL REVEAL ── fade + rise as each element enters the viewport.
     JS adds .is-visible via IntersectionObserver; --reveal-delay staggers
     elements within a section. */
  [data-reveal] {
    opacity: 0;
    transform: translateY(26px);
    transition: opacity .7s cubic-bezier(.22,.61,.36,1), transform .7s cubic-bezier(.22,.61,.36,1);
    transition-delay: var(--reveal-delay, 0ms);
  }
  .ogc-teams-page [data-reveal].is-visible { opacity: 1; transform: none; }

  .ogc-teams-page /* Cascade the cards inside the "And more" grid instead of fading as one block */
  .feature-grid[data-reveal] { opacity: 1; transform: none; transition: none; }
  .ogc-teams-page .feature-grid .feature-tile {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .6s ease, transform .6s cubic-bezier(.22,.61,.36,1);
  }
  .ogc-teams-page .feature-grid.is-visible .feature-tile { opacity: 1; transform: none; }
  .ogc-teams-page .feature-grid.is-visible .feature-tile:nth-child(1) { transition-delay: .04s; }
  .ogc-teams-page .feature-grid.is-visible .feature-tile:nth-child(2) { transition-delay: .10s; }
  .ogc-teams-page .feature-grid.is-visible .feature-tile:nth-child(3) { transition-delay: .16s; }
  .ogc-teams-page .feature-grid.is-visible .feature-tile:nth-child(4) { transition-delay: .22s; }
  .ogc-teams-page .feature-grid.is-visible .feature-tile:nth-child(5) { transition-delay: .28s; }
  .ogc-teams-page .feature-grid.is-visible .feature-tile:nth-child(6) { transition-delay: .34s; }

  .ogc-teams-page .feature-grid.is-visible .feature-tile h3 {font-size: 24px !important}
  .ogc-teams-page .feature-grid.is-visible .feature-tile p {font-size: 15.5px !important}

  @media (prefers-reduced-motion: reduce) {
    .ogc-teams-page [data-reveal], .ogc-teams-page .feature-grid .feature-tile {
      transition: opacity .3s ease !important;
      transform: none !important;
    }
  }

  .ogc-teams-page h1, .ogc-teams-page h2, .ogc-teams-page h3 { margin: 0; font-weight: 500; letter-spacing: -0.02em; color: var(--ink); }
  .ogc-teams-page h1 { font-size: clamp(38px, 5vw, 64px); line-height: 1.05; letter-spacing: -0.025em; }
  .ogc-teams-page h2 { font-size: clamp(30px, 4.2vw, 50px); line-height: 1.06; letter-spacing: -0.022em; font-weight: 500; }
  .ogc-teams-page h3 { font-size: 20px; font-weight: 600; letter-spacing: -0.01em; }
  .ogc-teams-page .eyebrow { font-size: 12px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brand); margin: 0 0 18px; }
  .ogc-teams-page .lede { font-size: clamp(19px, 1.6vw, 23px); line-height: 1.5; color: var(--ink-soft); max-width: 56ch; font-weight: 400; margin: 0; }

  .ogc-teams-page .btn { display: inline-flex; align-items: center; gap: 8px; padding: 15px 26px; border-radius: 999px; font-family: var(--sans); font-size: 16px; font-weight: 600; line-height: 1; text-decoration: none; border: 1px solid transparent; cursor: pointer; white-space: nowrap; letter-spacing: -0.005em; transition: background .2s ease, color .2s ease, border-color .2s ease; }
  .ogc-teams-page .btn-primary { background: var(--brand); color: #fff; }
  .ogc-teams-page .btn-primary:hover { background: var(--brand-ink); }
  .ogc-teams-page .btn-ghost { background: transparent; color: var(--brand); border-color: var(--brand); border-width: 1.5px; }
  .ogc-teams-page .btn-ghost:hover { background: var(--brand-soft); }

  .ogc-teams-page /* Site nav styles live in site-nav.css */
  /* ── HERO ── */
  .hero { padding: 48px 0 56px; text-align: center; background: transparent; }
  .ogc-teams-page .hero-inner { max-width: 820px; margin: 0 auto; padding-top:130px }
  .ogc-teams-page .hero .eyebrow { color: #7CB0F0; }
  .ogc-teams-page .hero h1 { margin-bottom: 24px; color: #fff; }
  .ogc-teams-page .hero .lede { max-width: 52ch; margin: 0 auto 36px; color: #fff; }
  .ogc-teams-page .hero-cta { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; align-items: center; margin-bottom: 50px; }
  .ogc-teams-page .hero-cta .btn svg { width: 18px; height: 18px; stroke: currentColor; fill: none; }
  .ogc-teams-page .hero .btn-ghost { color: #fff; border-color: rgba(255,255,255,.55); }
  .ogc-teams-page .hero .btn-ghost:hover { background: rgba(255,255,255,.12); border-color: #fff; }

  .ogc-teams-page /* ── TEAM DASHBOARD HERO MOCKUP (layered stack) ── */
  .td-stack {
    position: relative;
    max-width: 1100px;
    margin: 0 auto;
  }
  .ogc-teams-page /* Base dashboard — always visible, .ogc-teams-page defines the stack height */
  .td-base {
    display: block;
    width: 90%;
    margin-left: 2%;
    border-radius: 14px;
    box-shadow: 0 24px 60px -24px rgba(11,15,26,.30), 0 4px 14px -4px rgba(11,15,26,.10);
  }
  .ogc-teams-page /* Floating overlays — hidden until the user scrolls (see .is-visible).
     No CSS shadow/radius: the PNGs already include their own soft shadow
     on a transparent background. */
  .td-fly {
    position: absolute;
    display: block;
    height: auto;
    opacity: 0;
    transition: opacity .7s ease, transform .8s cubic-bezier(.22,.61,.36,1);
  }
  .ogc-teams-page /* Profile — vertically centred on the dashboard, .ogc-teams-page enters from the right */
  .td-fly.profile { top: 50%; right: 0; width: 25%; z-index: 3; transform: translate(90px, calc(-50% - 16px)) scale(.93); }
  .ogc-teams-page /* Analytics — pushed further into the bottom-left, .ogc-teams-page slightly past the edge */
  .td-fly.analytics { bottom: -5%; left: -5%; width: 27%; z-index: 2; transform: translateX(-90px) translateY(28px) scale(.93); transition-delay: .14s; }

  .ogc-teams-page /* Scroll trigger flies the overlays into place (profile keeps its centring) */
  .td-stack.is-visible .td-fly { opacity: 1; }
  .ogc-teams-page .td-stack.is-visible .td-fly.profile { transform: translateY(-50%); }
  .ogc-teams-page .td-stack.is-visible .td-fly.analytics { transform: none; }

    @media (min-width: 750px) {
        .ogc-teams-page .hero .lede {
            margin-top: 35px;
            color: rgba(255, 255, 255, 0.90);
        }
    }

    @media (max-width: 700px) {
        .lede {
            font-size: 16px !important;
            line-height: 1.5;
        }

        .ogc-teams-page .hero-cta {
            margin-top: -5px;
            margin-bottom: 45px;
        }

        .ogc-teams-page .hero-inner { padding-top:110px }
    }

  @media (prefers-reduced-motion: reduce) {
    .ogc-teams-page .td-fly { transition: opacity .4s ease; }
    .ogc-teams-page .td-fly.profile { transform: translateY(-50%); }
    .ogc-teams-page .td-fly.analytics { transform: none; }
  }
  @media (max-width: 720px) {
    .ogc-teams-page .td-base { width: 100%; margin-left: 0; }
    .ogc-teams-page .td-fly.profile { width: 32%; right: -2%; }
    .ogc-teams-page .td-fly.analytics { width: 36%; left: 0; }
  }

  .ogc-teams-page /* ── FEATURE GRID ── */
  .feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; margin-top: 40px; border-radius: 20px; overflow: hidden; border: 1px solid var(--line); }
  @media (max-width: 1024px) { .ogc-teams-page .feature-grid { grid-template-columns: 1fr 1fr; } }
  @media (max-width: 700px) { .ogc-teams-page .feature-grid { grid-template-columns: 1fr; } }
  .ogc-teams-page .feature-tile { background: #fff; padding: 36px 32px; display: flex; flex-direction: column; gap: 8px; }
  .ogc-teams-page .feature-tile-icon { width: 44px; height: 44px; border-radius: 12px; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; }
  .ogc-teams-page .feature-tile-icon svg { width: 22px; height: 22px; stroke: var(--brand); fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
  .ogc-teams-page .feature-tile h3 { font-size: 18px; margin: 12px 0 0; }
  .ogc-teams-page .feature-tile p { color: var(--ink); font-size: 17px; margin: 0; line-height: 1.55; }

  .ogc-teams-page /* ── SPLIT LAYOUT ── */
  .teams-split { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; margin-top: 56px; }
  @media (max-width: 900px) {
    .ogc-teams-page .teams-split { grid-template-columns: 1fr; gap: 26px; }
    .ogc-teams-page /* Flatten the copy column so its header + feature list can be ordered
       around the image: eyebrow/header → image → sub-features. */
    .teams-split > div { display: contents; }
    .ogc-teams-page .teams-split .split-head { order: 1; }
    .ogc-teams-page .teams-split > img { order: 2; }
    .ogc-teams-page /* The mockups wrapped in a positioned container (for animated overlays)
       must stay real boxes rather than collapsing to display:contents. */
    .teams-split > .bulk-mockup, .ogc-teams-page .teams-split > .brand-mockup, .ogc-teams-page .teams-split > .ta-mockup, .ogc-teams-page .teams-split > .sv-mockup { display: block; order: 2; margin-top: 0; margin-bottom: 10px; }
    .ogc-teams-page .teams-split .teams-feature-list { order: 3; margin-top: 0; }
    .ogc-teams-page .teams-feature p { font-size: 15px !important; color: rgba(229, 232, 239, 0.72);}
    .ogc-teams-page .teams-feature h3 { font-size: 22px; margin: 0 0 4px !important; }
  }
  @media (min-width: 901px) { .ogc-teams-page .teams-split.rev > :first-child { order: 2; } }
  .ogc-teams-page /* Reset the UA default h2 margins so split-head spacing is driven only by the
     eyebrow's margin-bottom above and the feature list's margin-top below. */
  .split-head h2 { margin: 0; }
  .ogc-teams-page .teams-feature-list { display: flex; flex-direction: column; gap: 28px; margin-top: 32px; }
  .ogc-teams-page .teams-feature { display: flex; gap: 16px; align-items: flex-start; }
  .ogc-teams-page .teams-feature-icon { width: 40px; height: 40px; border-radius: 10px; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
  .ogc-teams-page .teams-feature-icon svg { width: 20px; height: 20px; stroke: var(--brand); fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
  .ogc-teams-page .teams-feature h3 { font-size: 17px; margin: 0 0 6px; }
  .ogc-teams-page .teams-feature p { font-size: 16px; color: var(--ink); margin: 0; line-height: 1.5; }

  .ogc-teams-page /* ── MOCKUP IMAGES (split-section screenshots) ── */
  .bulk-mockup-img, .ogc-teams-page .brand-mockup-img, .ogc-teams-page .sv-mockup-img, .ogc-teams-page .ta-mockup-img { display: block; width: 100%; height: auto; border-radius: 20px; box-shadow: 0 8px 32px -8px rgba(11,15,26,.12); }

  .ogc-teams-page /* ── BULK EDITING: live "type the name" overlay ──
     The mockup is a flat PNG with "Max" baked into a focused Name cell.
     We wrap it in a container-query context and lay a real text element
     exactly over that cell (positions are % of the image so they scale
     with it; type scales via cqw). The white box masks the baked text, .ogc-teams-page then we type/erase the name on a loop with a blinking caret. */
  .bulk-mockup { position: relative; container-type: inline-size; }
  .ogc-teams-page .bulk-type {
    position: absolute;
    left: 43.7%; top: 40.0%;
    width: 32.1%; height: 13.1%;
    background: #fff;
    display: flex; align-items: center;
    padding-left: 1.55cqw;
    overflow: hidden;
    pointer-events: none;
  }
  .ogc-teams-page .bulk-type-text {
    font-family: var(--sans);
    font-size: 3.2cqw;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: #1F2A37;
    white-space: nowrap;
    overflow: hidden;
    width: 0;
    border-right: 0.24cqw solid #005AD1;
    animation: bulkType 3.4s steps(3, end) infinite, bulkCaret .7s step-end infinite;
  }
  @keyframes bulkType {
    0%   { width: 0; }
    22%  { width: 6.5cqw; }  /* typed: M-a-x (full word, with room so it never clips) */
    60%  { width: 6.5cqw; }  /* hold */
    82%  { width: 0; }       /* erased */
    100% { width: 0; }       /* pause */
  }
  @keyframes bulkCaret {
    0%, 100% { border-right-color: #005AD1; }
    50%      { border-right-color: transparent; }
  }
  @media (prefers-reduced-motion: reduce) {
    .ogc-teams-page .bulk-type-text { width: 6.5cqw; animation: none; border-right-color: transparent; }
  }

  .ogc-teams-page /* ── BRAND STANDARDISATION: live "Restrict Editing" pill ──
     The mockup bakes the pill in its final state (toggle ON, lock red).
     We lay a rebuilt pill exactly over it (positions are % of the image,
     sizes scale via cqw) and loop: toggle off→on, .ogc-teams-page lock black→red. */
  .brand-mockup { position: relative; container-type: inline-size; }
  .ogc-teams-page .brand-pill {
    position: absolute;
    left: 57.3%; top: 12.4%;
    width: 33.8%; height: 8.4%;
    display: flex; align-items: center;
    gap: 1.2cqw;
    padding: 0 1.7cqw;
    background: #fff;
    border-radius: 1.4cqw;
    box-shadow: none;
    pointer-events: none;
  }
  .ogc-teams-page .brand-lock {
    width: 3.2cqw; height: 3.2cqw; flex: none;
    color: #111418;
    animation: brandLock 3.4s ease infinite;
  }
  .ogc-teams-page .brand-pill-label {
    font-family: var(--sans);
    font-size: 2.8cqw; font-weight: 500;
    letter-spacing: -0.01em; color: #111418;
    white-space: nowrap;
  }
  .ogc-teams-page .brand-switch {
    position: relative; margin-left: auto; flex: none;
    width: 5.6cqw; height: 2.9cqw;
    border-radius: 999px; background: #C7CDD9;
    animation: brandTrack 3.4s ease infinite;
  }
  .ogc-teams-page .brand-switch::after {
    content: ""; position: absolute; top: 50%; left: 0.35cqw;
    width: 2.2cqw; height: 2.2cqw; border-radius: 50%;
    background: #fff; box-shadow: 0 0.15cqw 0.4cqw rgba(0,0,0,.3);
    transform: translateY(-50%);
    animation: brandKnob 3.4s cubic-bezier(.4,0,.2,1) infinite;
  }
  @keyframes brandTrack {
    0%, 26%   { background: #C7CDD9; }
    42%, 80%  { background: #005AD1; }
    94%, 100% { background: #C7CDD9; }
  }
  @keyframes brandKnob {
    0%, 26%   { transform: translateY(-50%) translateX(0); }
    42%, 80%  { transform: translateY(-50%) translateX(2.7cqw); }
    94%, 100% { transform: translateY(-50%) translateX(0); }
  }
  @keyframes brandLock {
    0%, 30%   { color: #111418; }
    44%, 82%  { color: #E5362C; }
    95%, 100% { color: #111418; }
  }
  @media (prefers-reduced-motion: reduce) {
    .ogc-teams-page .brand-lock { color: #E5362C; animation: none; }
    .ogc-teams-page .brand-switch { background: #005AD1; animation: none; }
    .ogc-teams-page .brand-switch::after { transform: translateY(-50%) translateX(2.7cqw); animation: none; }
  }

  .ogc-teams-page /* ── TEAM ANALYTICS: count up Max's profile views ──
     The mockup bakes Max's leaderboard count (443). We mask it and run a
     pure-CSS count-up (animated @property integer) that ticks from 0 to 443
     when the section scrolls into view. Positions are % of the image. */
  @property --ta-num { syntax: "<integer>"; inherits: false; initial-value: 443; }
  .ogc-teams-page .ta-mockup { position: relative; container-type: inline-size; }
  .ogc-teams-page .ta-count {
    position: absolute;
    left: 68.7%;
    width: 10%; height: 5.6%;
    background: #fff;
    display: flex; align-items: center;
    font-family: var(--sans);
    font-size: 3.2cqw; font-weight: 500;
    letter-spacing: -0.01em; color: #111418;
    counter-reset: ta-num var(--ta-num);
    pointer-events: none;
  }
  .ogc-teams-page .ta-count::after { content: counter(ta-num); }
  .ogc-teams-page /* One row per leaderboard entry; each holds its own final value so the
     numbers are correct even before the count-up runs (or with JS off). */
  .ta-count.r1 { top: 34.00%; --ta-num: 443; }
  .ogc-teams-page .ta-count.r2 { top: 47.45%; --ta-num: 212; }
  .ogc-teams-page .ta-count.r3 { top: 60.95%; --ta-num: 164; }
  .ogc-teams-page .ta-count.r4 { top: 74.30%; --ta-num: 98;  }
  .ogc-teams-page .teams-split.is-visible .ta-count.r1 { animation: taCount1 2.4s cubic-bezier(.2,.6,.2,1) infinite; }
  .ogc-teams-page .teams-split.is-visible .ta-count.r2 { animation: taCount2 2.4s cubic-bezier(.2,.6,.2,1) infinite; }
  .ogc-teams-page .teams-split.is-visible .ta-count.r3 { animation: taCount3 2.4s cubic-bezier(.2,.6,.2,1) infinite; }
  .ogc-teams-page .teams-split.is-visible .ta-count.r4 { animation: taCount4 2.4s cubic-bezier(.2,.6,.2,1) infinite; }
  @keyframes taCount1 { 0% { --ta-num: 400; } 60% { --ta-num: 443; } 100% { --ta-num: 443; } }
  @keyframes taCount2 { 0% { --ta-num: 188; } 60% { --ta-num: 212; } 100% { --ta-num: 212; } }
  @keyframes taCount3 { 0% { --ta-num: 140; } 60% { --ta-num: 164; } 100% { --ta-num: 164; } }
  @keyframes taCount4 { 0% { --ta-num: 78;  } 60% { --ta-num: 98;  } 100% { --ta-num: 98;  } }
  @media (prefers-reduced-motion: reduce) {
    .ogc-teams-page .teams-split.is-visible .ta-count { animation: none; }
  }

  .ogc-teams-page /* ── SERIAL VAULT: activation sequence ──
     A looping mini-story over the baked control bar: serial number types in →
     a user is selected → the Activate button pulses → the card confirms.
     Positions are % of the image; text scales with cqw. */
  .sv-mockup { position: relative; container-type: inline-size; }
  .ogc-teams-page .sv-field {
    position: absolute; background: #fff;
    display: flex; align-items: center; overflow: hidden;
    font-family: var(--sans); font-size: 2.3cqw; font-weight: 500;
    letter-spacing: -0.01em; color: #111418; white-space: nowrap;
    pointer-events: none;
  }
  .ogc-teams-page /* 1 — serial number types into the field */
  .sv-serial { left: 24.4%; top: 8.0%; width: 25%; height: 5.7%; padding-left: 0.9cqw; }
  .ogc-teams-page .sv-serial .sv-serial-text { overflow: hidden; white-space: nowrap; width: 0; border-right: 0.18cqw solid #005AD1; }
  .ogc-teams-page .teams-split.is-visible .sv-serial .sv-serial-text {
    animation: svType 6s steps(10, end) infinite, svCaret .7s step-end infinite;
  }
  @keyframes svType { 0% { width: 0; } 18% { width: 13cqw; } 88% { width: 13cqw; } 92% { width: 0; } 100% { width: 0; } }
  @keyframes svCaret { 0%, 100% { border-right-color: #005AD1; } 50% { border-right-color: transparent; } }
  .ogc-teams-page /* 2a — the user dropdown opens first */
  .sv-menu {
    position: absolute; left: 56.6%; top: 14.7%; width: 21.8%;
    background: #fff; border: 1px solid rgba(17,20,24,.08); border-radius: 1.4cqw;
    box-shadow: 0 2cqw 4.5cqw -1.2cqw rgba(11,15,26,.28);
    padding: 0.7cqw; opacity: 0; transform: translateY(-0.6cqw) scaleY(.96); transform-origin: top center;
    z-index: 4; pointer-events: none;
  }
  .ogc-teams-page .sv-menu .sv-opt {
    display: flex; align-items: center; justify-content: space-between; gap: 0.8cqw;
    padding: 0.7cqw 0.9cqw; border-radius: 0.9cqw;
    font-family: var(--sans); font-size: 2.05cqw; font-weight: 500; color: #3A3F4A; white-space: nowrap;
  }
  .ogc-teams-page .sv-menu .sv-opt.sel { background: #E6EEFB; color: #111418; font-weight: 600; }
  .ogc-teams-page .sv-menu .sv-opt .sv-tick { width: 2cqw; height: 2cqw; stroke: #005AD1; stroke-width: 3; fill: none; stroke-linecap: round; stroke-linejoin: round; opacity: 0; flex: none; }
  .ogc-teams-page .sv-menu .sv-opt.sel .sv-tick { opacity: 1; }
  .ogc-teams-page .teams-split.is-visible .sv-menu { animation: svMenu 6s ease infinite; }
  @keyframes svMenu {
    0%, 20% { opacity: 0; transform: translateY(-0.6cqw) scaleY(.96); }
    25%, 33% { opacity: 1; transform: none; }
    38%, 100% { opacity: 0; transform: translateY(-0.6cqw) scaleY(.96); }
  }
  .ogc-teams-page /* 2b — then the selected name fills the field (covers the baked placeholder) */
  .sv-user { left: 56.6%; top: 8.0%; width: 17.8%; height: 5.7%; padding-left: 0.9cqw; opacity: 0; }
  .ogc-teams-page .teams-split.is-visible .sv-user { animation: svUser 6s ease infinite; }
  @keyframes svUser { 0%, 33% { opacity: 0; } 39%, 88% { opacity: 1; } 93%, 100% { opacity: 0; } }
  .ogc-teams-page /* 3 — Activate button: press darken + ripple, .ogc-teams-page both clipped to the button */
  .sv-btn { position: absolute; left: 80.5%; top: 6.8%; width: 14.2%; height: 7.8%; border-radius: 1.2cqw; overflow: hidden; pointer-events: none; }
  .ogc-teams-page .sv-btn::before { content: ""; position: absolute; inset: 0; background: #00256B; opacity: 0; }
  .ogc-teams-page .sv-btn::after {
    content: ""; position: absolute; left: 50%; top: 50%;
    width: 30cqw; height: 30cqw; margin: -15cqw 0 0 -15cqw;
    border-radius: 50%; background: rgba(255,255,255,.4); opacity: 0; transform: scale(0);
  }
  .ogc-teams-page .teams-split.is-visible .sv-btn::before { animation: svPress 6s ease infinite; }
  .ogc-teams-page .teams-split.is-visible .sv-btn::after { animation: svRipple 6s ease-out infinite; }
  @keyframes svPress { 0%, 46% { opacity: 0; } 49% { opacity: .22; } 56% { opacity: 0; } 100% { opacity: 0; } }
  @keyframes svRipple { 0%, 47% { opacity: 0; transform: scale(0); } 50% { opacity: .5; transform: scale(.18); } 63% { opacity: 0; transform: scale(1); } 100% { opacity: 0; transform: scale(1); } }
  .ogc-teams-page /* 4 — card confirms with a check badge */
  .sv-check {
    position: absolute; left: 50%; top: 53.3%; width: 9cqw; height: 9cqw; margin: -4.5cqw 0 0 -4.5cqw;
    border-radius: 50%; background: #22A565; display: flex; align-items: center; justify-content: center;
    opacity: 0; transform: scale(.4); box-shadow: 0 1cqw 2.4cqw -0.6cqw rgba(34,165,101,.6); pointer-events: none;
  }
  .ogc-teams-page .sv-check svg { width: 54%; height: 54%; stroke: #fff; stroke-width: 3; fill: none; stroke-linecap: round; stroke-linejoin: round; }
  .ogc-teams-page .teams-split.is-visible .sv-check { animation: svCheck 6s cubic-bezier(.2,.8,.2,1) infinite; }
  @keyframes svCheck {
    0%, 54% { opacity: 0; transform: scale(.4); }
    60% { opacity: 1; transform: scale(1.08); }
    66% { transform: scale(1); }
    88% { opacity: 1; transform: scale(1); }
    94%, 100% { opacity: 0; transform: scale(.7); }
  }
  @media (prefers-reduced-motion: reduce) {
    .ogc-teams-page .teams-split.is-visible .sv-serial .sv-serial-text, .ogc-teams-page .teams-split.is-visible .sv-menu, .ogc-teams-page .teams-split.is-visible .sv-user, .ogc-teams-page .teams-split.is-visible .sv-btn::before, .ogc-teams-page .teams-split.is-visible .sv-btn::after, .ogc-teams-page .teams-split.is-visible .sv-check { animation: none; }
    .ogc-teams-page .sv-serial .sv-serial-text { width: 13cqw; border-right-color: transparent; }
    .ogc-teams-page .sv-user { opacity: 1; }
    .ogc-teams-page .sv-check { opacity: 1; transform: scale(1); }
  }

  .ogc-teams-page /* ── FAQ ── */
  .faq-card { background: #0A3A75; border-radius: 28px; padding: 56px 64px; display: grid; grid-template-columns: 200px 1fr; gap: 64px; align-items: start; }
  @media (max-width: 900px) { .ogc-teams-page .faq-card { grid-template-columns: 1fr; gap: 36px; padding: 40px 32px; } }
  .ogc-teams-page .faq-label { color: #fff; }
  .ogc-teams-page .faq-label h2 { font-size: clamp(36px, 4vw, 52px); font-weight: 700; color: #fff; letter-spacing: -0.03em; line-height: 1; margin-bottom: 20px; }
  .ogc-teams-page .faq-label a { color: rgba(255,255,255,.75); font-size: 18px; font-weight: 600; text-decoration: none; display: inline-flex; align-items: center; gap: 5px; transition: color .15s; }
  .ogc-teams-page .faq-label a:hover { color: #fff; }
  .ogc-teams-page .faq-list { display: flex; flex-direction: column; }
  .ogc-teams-page .faq-item { border-top: 1px solid rgba(255,255,255,.2); padding: 20px 0; }
  .ogc-teams-page .faq-item:last-child { border-bottom: 1px solid rgba(255,255,255,.2); }
  .ogc-teams-page .faq-item summary { list-style: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 24px; font-size: 19px; font-weight: 600; letter-spacing: -0.01em; color: #fff; user-select: none; }
  .ogc-teams-page .faq-item summary::-webkit-details-marker { display: none; }
  .ogc-teams-page .faq-item summary .plus { width: 22px; height: 22px; flex: 0 0 auto; position: relative; flex-shrink: 0; }
  .ogc-teams-page .faq-item summary .plus::before, .ogc-teams-page .faq-item summary .plus::after { content: ""; position: absolute; inset: 0; margin: auto; background: rgba(255,255,255,.8); transition: transform .25s ease, background .15s; }
  .ogc-teams-page .faq-item summary .plus::before { width: 13px; height: 1.5px; }
  .ogc-teams-page .faq-item summary .plus::after { width: 1.5px; height: 13px; transition: transform .25s ease; }
  .ogc-teams-page .faq-item[open] summary .plus::after { transform: rotate(90deg); }
  .ogc-teams-page .faq-item[open] summary { color: #fff; }
  .ogc-teams-page .faq-item[open] summary .plus::before, .ogc-teams-page .faq-item[open] summary .plus::after { background: #fff; }
  .ogc-teams-page .faq-item .answer { padding-top: 12px; color: #fff; font-size: 17px; line-height: 1.65; font-weight: 400; }
  .ogc-teams-page .faq-item .answer a { color: #fff; text-decoration: underline; }

  .ogc-teams-page /* ── FINAL CTA ── */
  .final-cta { padding: 56px 0 60px; text-align: center; background: var(--bg-dark); color: #fff; position: relative; overflow: hidden; border-radius: 30px 30px 0 0; }
  .ogc-teams-page .final-cta .container { position: relative; z-index: 1; }
  .ogc-teams-page .cta-btn-row { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 12px; }
  .ogc-teams-page .final-cta h2 { color: #fff; font-size: clamp(32px, 4vw, 52px); margin-bottom: 16px; }
  .ogc-teams-page .final-cta .lede { color: rgba(255,255,255,.65); margin: 0 auto 36px; }
  .ogc-teams-page .final-cta .btn-primary { background: #fff; color: var(--ink); }
  .ogc-teams-page .final-cta .btn-ghost { color: #fff; border-color: rgba(255,255,255,.5); border-width: 2px; }
  .ogc-teams-page .final-cta .btn-ghost:hover { background: rgba(255,255,255,.1); }

  .ogc-teams-page /* ── TRUSTED BY (logo wall) ── */
  .trusted-strip { text-align: center; }
  .ogc-teams-page .trusted-eyebrow { font-size: 13px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); margin: 0 0 32px; }
  .ogc-teams-page .trusted-logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 32px; max-width: 1100px; margin: 0 auto; }
  .ogc-teams-page .trusted-logos img { height: 52px; width: auto; max-width: 100%; object-fit: contain; opacity: 0.55; filter: grayscale(100%); flex: 0 1 auto; min-width: 0; }
  @media (max-width: 900px) {
    .ogc-teams-page .trusted-logos { justify-content: center; gap: 24px 36px; }
    .ogc-teams-page .trusted-logos img { height: 38px; }
  }

  .ogc-teams-page /* ── PROFILE SHOWCASE (example digital business cards) ── */
  .profiles-row {
    display: flex;
    gap: 20px;
    justify-content: flex-start;
    align-items: flex-start;
    overflow-x: auto;
    padding-top: 20px;
    padding-bottom: 4px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
  }
  .ogc-teams-page .profiles-row::-webkit-scrollbar { display: none; }
  .ogc-teams-page .profile-card {
    flex: 0 0 270px;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 24px 60px -24px rgba(0,0,0,.55), 0 6px 18px -8px rgba(0,0,0,.35);
    transition: transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s ease;
  }
  .ogc-teams-page .profile-card:hover {
    transform: translateY(-12px);
    box-shadow: 0 36px 80px -24px rgba(0,0,0,.6), 0 10px 24px -8px rgba(0,0,0,.4);
  }
  @media (prefers-reduced-motion: reduce) {
    .ogc-teams-page .profile-card { transition: none; }
    .ogc-teams-page .profile-card:hover { transform: none; }
  }
  .ogc-teams-page .profile-card img { width: 100%; height: auto; display: block; }
  @media (max-width: 1180px) {
    .ogc-teams-page .profiles-row { justify-content: flex-start; padding-left: var(--gutter); padding-right: var(--gutter); }
  }
  @media (max-width: 700px) {
    .ogc-teams-page .profile-card { flex: 0 0 230px; }
  }
  .ogc-teams-page /* Carousel wrapper + scroll buttons for the profile showcase */
  .profiles-carousel { position: relative; }
  .ogc-teams-page .pcard-nav {
    position: absolute; top: 50%; transform: translateY(-50%); z-index: 3;
    width: 48px; height: 48px; border-radius: 50%;
    border: 1px solid rgba(255,255,255,.14); background: rgba(17,21,31,.85); color: #E5E8EF;
    display: flex; align-items: center; justify-content: center; cursor: pointer;
    box-shadow: 0 4px 16px rgba(0,0,0,0.35);
    -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
    transition: background .15s ease, transform .15s ease, opacity .2s ease;
  }
  .ogc-teams-page .pcard-nav:hover { background: rgba(0,90,209,.9); border-color: rgba(124,176,240,.6); }
  .ogc-teams-page .pcard-nav:active { transform: translateY(-50%) scale(0.94); }
  .ogc-teams-page .pcard-nav svg { width: 20px; height: 20px; display: block; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
  .ogc-teams-page .pcard-nav.prev { left: -8px; }
  .ogc-teams-page .pcard-nav.next { right: -8px; }
  .ogc-teams-page .pcard-nav[disabled] { opacity: 0; pointer-events: none; }
  @media (max-width: 700px) { .ogc-teams-page .pcard-nav { display: none; } }

  .ogc-teams-page /* ── CASE STUDIES CAROUSEL ── */
  .testimonial-scroll {
    display: flex;
    gap: 20px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    margin-top: 40px;
    padding-top: 12px;
    padding-bottom: 40px;
    scrollbar-width: none;
  }
  .ogc-teams-page .testimonial-scroll::-webkit-scrollbar { display: none; }
  .ogc-teams-page .cs-card {
    background: #fff;
    border-radius: 16px;
    padding: 14px;
    display: flex; flex-direction: column;
    flex: 0 0 308px;
    scroll-snap-align: start;
    text-decoration: none;
    box-shadow: 0 18px 44px -22px rgba(0,0,0,.45);
    transition: transform .15s ease, box-shadow .15s ease;
  }
  .ogc-teams-page .cs-card:hover { transform: translateY(-3px); box-shadow: 0 26px 56px -24px rgba(0,0,0,.55); }
  @media (max-width: 700px) { .ogc-teams-page .cs-card { flex: 0 0 62vw; } }
  .ogc-teams-page .cs-img { width: 100%; aspect-ratio: 16 / 11; object-fit: cover; border-radius: 10px; display: block; background: var(--bg-alt); }
  .ogc-teams-page .cs-body { padding: 16px 8px 6px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
  .ogc-teams-page .cs-title { font-size: 22px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; margin: 0; }
  .ogc-teams-page .cs-desc { font-size: 14px; line-height: 1.45; color: var(--muted); margin: 0; min-height: 2.9em; }
  .ogc-teams-page .cs-link { font-size: 15px; font-weight: 600; color: var(--brand); display: inline-flex; align-items: center; gap: 6px; margin-top: 10px; transition: gap .15s ease; }
  .ogc-teams-page .cs-card:hover .cs-link { gap: 10px; }
  .ogc-teams-page /* Carousel wrapper + scroll buttons */
  .testimonial-carousel { position: relative; }
  .ogc-teams-page .tcard-nav {
    position: absolute; top: 50%; transform: translateY(-50%); z-index: 3;
    width: 48px; height: 48px; border-radius: 50%;
    border: 1px solid var(--line); background: #fff; color: var(--ink);
    display: flex; align-items: center; justify-content: center; cursor: pointer;
    box-shadow: 0 4px 16px rgba(0,0,0,0.08);
    transition: background 0.15s ease, transform 0.15s ease, opacity 0.2s ease;
  }
  .ogc-teams-page .tcard-nav:hover { background: var(--bg-alt); }
  .ogc-teams-page .tcard-nav:active { transform: translateY(-50%) scale(0.94); }
  .ogc-teams-page .tcard-nav svg { width: 20px; height: 20px; display: block; }
  .ogc-teams-page .tcard-nav.prev { left: -12px; }
  .ogc-teams-page .tcard-nav.next { right: -12px; }
  .ogc-teams-page .tcard-nav[disabled] { opacity: 0; pointer-events: none; }
  @media (max-width: 900px) { .ogc-teams-page .tcard-nav { display: none; } }

  .ogc-teams-page /* Site footer styles live in site-footer.css */

  /* ============================================================
     DARK THEME (teams page)
     Page chrome flips to dark; inline UI mockups stay light as
     "in-app screenshots" — common dark-mode pattern (Stripe, Vercel).
     ============================================================ */

  .ogc-teams-page /* Subtle final blend strip — sits just above the footer so any
     residual contrast against the dark footer disappears. */
  .site-footer {
    position: relative;
  }
  .ogc-teams-page .site-footer::before {
    content: "";
    position: absolute;
    left: 0; right: 0; top: -120px;
    height: 120px;
    pointer-events: none;
    background: linear-gradient(to bottom, rgba(11, 15, 26, 0) 0%, rgba(11, 15, 26, .6) 60%, #0B0F1A 100%);
  }

  .ogc-teams-page /* Type tokens flipped */
  h1, .ogc-teams-page h2, .ogc-teams-page h3 { color: #F4F6FB; }
  .ogc-teams-page .eyebrow { color: #7CB0F0; }
  .ogc-teams-page .lede { color: rgba(229, 232, 239, .72); }
  .ogc-teams-page a { color: inherit; }
  .ogc-teams-page p { color: #CFD3DC; }

  .ogc-teams-page /* Sections: fully transparent so the body gradients flow through */
  .section { background: transparent; }
  .ogc-teams-page .section.alt { background: transparent; border-top: none; border-bottom: none; }

  .ogc-teams-page /* Nav pill: dark glass (neutral accents, no blue) */
  .nav {
    background: rgba(11, 15, 26, .65);
    border-color: rgba(255, 255, 255, .08);
    box-shadow: 0 4px 28px -6px rgba(0, 0, 0, .55), 0 1px 4px -1px rgba(0, 0, 0, .35);
  }
  .ogc-teams-page .nav-item > a { color: #E5E8EF; }
  .ogc-teams-page .nav-item > a:hover { background: rgba(255, 255, 255, .06); color: #fff; }
  .ogc-teams-page .nav-icon-btn { color: #E5E8EF; }
  .ogc-teams-page .nav-icon-btn:hover { background: rgba(255, 255, 255, .06); }
  .ogc-teams-page .brand-logo { filter: brightness(0) invert(1); }
  .ogc-teams-page .nav-cta .btn-ghost { color: #E5E8EF; border-color: rgba(255, 255, 255, .35); }
  .ogc-teams-page .nav-cta .btn-ghost:hover { background: rgba(255, 255, 255, .08); border-color: rgba(255, 255, 255, .55); }

  .ogc-teams-page /* Mega-menu dropdown — keep light interior for legibility */
  .nav-dropdown { background: #11151F; border-color: rgba(255, 255, 255, .08); }
  .ogc-teams-page .dropdown-item { color: #E5E8EF; }
  .ogc-teams-page .dropdown-item:hover { background: rgba(255, 255, 255, .05); }
  .ogc-teams-page .dropdown-item .di-title { color: #F4F6FB; }
  .ogc-teams-page .dropdown-item .di-desc { color: rgba(229, 232, 239, .55); }
  .ogc-teams-page .dropdown-label { color: rgba(229, 232, 239, .55); }
  .ogc-teams-page .dropdown-col + .dropdown-col { border-left-color: rgba(255, 255, 255, .08); }

  .ogc-teams-page /* Cards on dark canvas */
  .feature-tile {
    background: rgba(255, 255, 255, .04);
    border-color: rgba(255, 255, 255, .08);
    color: #E5E8EF;
  }
  .ogc-teams-page .feature-tile h3 { color: #F4F6FB; }
  .ogc-teams-page .feature-tile p, .ogc-teams-page .teams-feature p, .ogc-teams-page .teams-feature h3 { color: #CFD3DC; }
  .ogc-teams-page .teams-feature h3 { color: #F4F6FB; }
  .ogc-teams-page .feature-tile-icon, .ogc-teams-page .teams-feature-icon {
    background: rgba(0, 90, 209, .18);
  }
  .ogc-teams-page .feature-tile-icon svg, .ogc-teams-page .teams-feature-icon svg {
    stroke: #7CB0F0;
  }

  .ogc-teams-page /* Feature grid: tiles share a translucent surface so the 2px gaps
     don't show as dark slashes — give the grid itself a darker base. */
  .feature-grid {
    border-color: rgba(255, 255, 255, .08);
    background: rgba(255, 255, 255, .02);
  }

  .ogc-teams-page .trusted-eyebrow { color: rgba(229, 232, 239, .55); }
  .ogc-teams-page .trusted-logos img { filter: grayscale(100%) brightness(0) invert(1); opacity: .55; }

  .ogc-teams-page /* Final CTA: let the body gradient show through so the band has no
     hard edge against the section above or the footer below. The radial
     ::before pseudo-element still provides the brand-glow depth. */
  .final-cta { background: transparent; border-radius: 30px 30px 0 0; }
  .ogc-teams-page /* Bottom mask: resolve the section's lower half to the exact footer
     colour so the glow fades out and the section melts into the footer
     with no visible seam. Sits above ::before, below .container (z:1). */
  .final-cta::after {
    content: "";
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 60%;
    pointer-events: none;
    background: linear-gradient(to bottom, rgba(11, 15, 26, 0) 0%, rgba(11, 15, 26, .65) 55%, var(--bg-dark) 100%);
  }

  .ogc-teams-page /* FAQ card already uses brand colour — keep, .ogc-teams-page but lift contrast on dark page */
  .faq-card { box-shadow: 0 24px 64px -28px rgba(0, 0, 0, .65); }

    .ogc-teams-page .demo-modal {
        position: fixed;
        inset: 0;
        z-index: 1000000;
        display: none;
        align-items: flex-start;
        justify-content: center;
        padding: 88px 24px 24px;
        background: rgba(7, 9, 15, .72);
        backdrop-filter: blur(6px);
        -webkit-backdrop-filter: blur(6px);
        opacity: 0;
        transition: opacity .25s ease;
    }

    @media (max-width: 760px) {
        .ogc-teams-page .demo-modal {
            padding: 72px 16px 20px;
        }
    }

  .ogc-teams-page .demo-modal.is-open { display: flex; opacity: 1; }
  .ogc-teams-page .demo-dialog {
    margin: 0 auto;
    position: relative;
    width: 100%;
    max-width: 920px;
    background: #11151F;
    border: 1px solid rgba(255, 255, 255, .10);
    border-radius: 22px;
    box-shadow: 0 40px 100px -30px rgba(0, 0, 0, .8);
    overflow: hidden;
    transform: translateY(16px) scale(.98);
    transition: transform .3s cubic-bezier(.22,.61,.36,1);
  }
  .ogc-teams-page .demo-modal.is-open .demo-dialog { transform: none; }
  .ogc-teams-page .demo-close {
    position: absolute;
    top: 14px; right: 14px;
    z-index: 5;
    width: 38px; height: 38px;
    border-radius: 0;
    border: 0;
    background: transparent;
    color: rgba(229, 232, 239, .7);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: color .15s ease;
  }
  .ogc-teams-page .demo-close:hover { color: #fff; }
  .ogc-teams-page .demo-close svg { width: 18px; height: 18px; }

  .ogc-teams-page /* Two-column lead-gen layout: pitch on the left, .ogc-teams-page form on the right */
  .demo-grid { display: grid; grid-template-columns: 1fr 1fr; }
  @media (max-width: 760px) { .ogc-teams-page .demo-grid { grid-template-columns: 1fr; } }

  .ogc-teams-page .demo-aside {
    padding: 44px 38px;
    background:
      radial-gradient(520px 360px at 0% 0%, rgba(0, 90, 209, .14) 0%, rgba(0, 90, 209, 0) 72%),
      linear-gradient(160deg, #141A26 0%, #0C111B 100%);
    border-right: 1px solid rgba(255, 255, 255, .06);
    display: flex;
    flex-direction: column;
    gap: 18px;
  }
  .ogc-teams-page .demo-aside .eyebrow { color: #7CB0F0; margin: 0; }
  .ogc-teams-page .demo-aside h2 { color: #fff; font-size: 28px; line-height: 1.1; }
  .ogc-teams-page .demo-aside p { color: rgba(229, 232, 239, .78); font-size: 16px; margin: 0; }
  .ogc-teams-page .demo-points { list-style: none; padding: 0; margin: 6px 0 0; display: flex; flex-direction: column; gap: 12px; }
  .ogc-teams-page .demo-points li { display: flex; gap: 10px; align-items: flex-start; color: #E5E8EF; font-size: 15px; }
  .ogc-teams-page .demo-points svg { width: 18px; height: 18px; stroke: #7CB0F0; fill: none; stroke-width: 2; flex-shrink: 0; margin-top: 2px; }
  @media (max-width: 760px) { .ogc-teams-page .demo-aside { display: none; } }

  .ogc-teams-page .demo-form-wrap { padding: 44px 38px; }
  .ogc-teams-page .demo-form-wrap h3 { color: #F4F6FB; font-size: 22px; margin: 0 0 6px; }
  .ogc-teams-page .demo-form-wrap .demo-sub { color: rgba(229, 232, 239, .6); font-size: 14px; margin: 0 0 24px; }
  .ogc-teams-page .demo-field { margin-bottom: 16px; }
  .ogc-teams-page .demo-field label { display: block; font-size: 13px; font-weight: 600; color: #CFD3DC; margin-bottom: 6px; }
  .ogc-teams-page .demo-field input, .ogc-teams-page .demo-field select {
    width: 100%;
    padding: 12px 14px;
    font-family: var(--sans);
    font-size: 15px;
    color: #F4F6FB;
    background: rgba(255, 255, 255, .04);
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: 10px;
    outline: none;
    transition: border-color .15s ease, background .15s ease;
    -webkit-appearance: none;
    appearance: none;
  }
  .ogc-teams-page .demo-field input::placeholder { color: rgba(229, 232, 239, .4); }
  .ogc-teams-page .demo-field input:focus, .ogc-teams-page .demo-field select:focus { border-color: #7CB0F0; background: rgba(255, 255, 255, .07); }
  .ogc-teams-page .demo-field select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237CB0F0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 38px; }
  .ogc-teams-page .demo-field select option { color: #111418; }
  .ogc-teams-page .demo-form-wrap .btn-primary { width: 100%; justify-content: center; margin-top: 6px; }
  .ogc-teams-page .demo-privacy { font-size: 12px; color: rgba(229, 232, 239, .5); margin: 14px 0 0; text-align: center; }
  .ogc-teams-page .demo-privacy a { color: #7CB0F0; }

  .ogc-teams-page /* Video state — full-width 16:9 player replaces the grid after submit */
  .demo-video { display: none; }
  .ogc-teams-page .demo-dialog.show-video .demo-grid { display: none; }
  .ogc-teams-page .demo-dialog.show-video .demo-video { display: block; }
  .ogc-teams-page .demo-video .demo-video-frame { position: relative; width: 100%; aspect-ratio: 16 / 9; background: #000; }
  .ogc-teams-page .demo-video iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
  .ogc-teams-page .final-trust {
    list-style: none; padding: 0; margin: 48px auto 0;
    display: flex; flex-wrap: wrap; justify-content: center;
    gap: 8px 40px;
  }
  .ogc-teams-page .final-trust li {
    display: flex; align-items: center; gap: 7px;
    font-size: 14px; color: rgba(255,255,255,.6);
    font-weight: 500;
  }
  .ogc-teams-page .final-trust [data-lucide] { width: 14px; height: 14px; stroke-width: 2; vertical-align: -2px; margin-right: 2px; }


/* Shopify theme containment */
.ogc-teams-page {
  min-height: 100vh;
  margin-top: -1px;
  background-color: #0B0F1A;
}
.ogc-teams-page .btn { min-height: initial; }

body.demo-modal-open .site-header {
    filter: blur(10px);
    opacity: .45;
    transition: all .25s ease;
}

.hero-highlight {
  position: relative;
  display: inline-block;
}

.hero-highlight svg {
  position: absolute;
  left: -2%;
  bottom: -0.28em;
  width: 104%;
  height: 18px;
  overflow: visible;
}

.hero-highlight path {
  fill: none;
  stroke: rgba(124, 176, 240, 0.55);
  stroke-width: 5;
  stroke-linecap: round;

  stroke-dasharray: 300;
  stroke-dashoffset: 300;

  animation: drawUnderline 1s ease .6s forwards;
}

@keyframes drawUnderline {
  to {
    stroke-dashoffset: 0;
  }
}

.desktop-break {
  display: inline;
}

@media (max-width: 749px) {
  .desktop-break {
    display: none;
  }
}

.answer a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1.5px;
}

.answer a:hover {
    opacity: 0.8;
}

@media (min-width: 750px) {
  .trusted-logos img:nth-last-child(-n+2) {
    display: none;
  }
}

@media (max-width: 759px) {
    .ogc-teams-page #team-analytics,
    .ogc-teams-page #card-administration,
    .ogc-teams-page #brand-standardisation {
        margin-top: -15px;
    }
}

@media (max-width: 750px) {
    .faq-item .answer,
    .faq-item .answer p {
        padding-top: 10px !important;
        font-size: 15px !important;
        line-height: 1.55 !important;
        font-weight: 400 !important;
        color: rgba(255,255,255,.90);
    }

    .faq-item summary {
        font-size: 17px !important;
        line-height: 1.4 !important;
    }

    .faq-label h2 {
        margin-bottom: 6px !important;
    }

    .faq-label {
        margin-bottom: -12px !important;
    }

    .faq-card { grid-template-columns: 1fr; gap: 36px !important; padding: 32px 26px !important;}
}

.demo-field-error {
  margin: 6px 0 0;
  font-size: 13px;
  color: #ffb4b4;
  line-height: 1.35;
}