    *,
    *::before,
    *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0
    }

    :root {
      --bg: #f8f9fc;
      --bg2: #eef0f7;
      --panel: rgba(255,255,255,.55);
      --panel-solid: #ffffff;
      --panel2: #f3f4fa;
      --text: #0f172a;
      --text2: #334155;
      --muted: #64748b;
      --dim: #cbd5e1;
      --border: rgba(255,255,255,.45);
      --border2: rgba(255,255,255,.65);
      --border-out: rgba(15,23,42,.06);
      --accent: #6366f1;
      --accent-l: #818cf8;
      --accent-s: #eef2ff;
      --gold: #f59e0b;
      --gold-l: #fbbf24;
      --gold-s: #fffbeb;
      --green: #10b981;
      --green-s: #ecfdf5;
      --nav-bg: rgba(255,255,255,.45);
      --card-bg: rgba(255,255,255,.5);
      --sh: 0 2px 16px rgba(15, 23, 42, .06), 0 1px 3px rgba(15, 23, 42, .04);
      --sh-lg: 0 12px 40px rgba(15, 23, 42, .1), 0 4px 10px rgba(15, 23, 42, .06);
      --sh-xl: 0 24px 64px rgba(15, 23, 42, .14), 0 8px 20px rgba(15, 23, 42, .07);
      --serif: 'Cormorant Garamond', Georgia, serif;
      --sans: 'DM Sans', -apple-system, sans-serif;
      --r: 16px;
      --r-lg: 22px;
      --glass-blur: blur(20px) saturate(1.8);
      --glass-blur-lg: blur(40px) saturate(1.8);
      --ease: cubic-bezier(.4,0,.2,1);
      --ease-spring: cubic-bezier(.34,1.56,.64,1);
      --ease-out: cubic-bezier(0,0,.2,1);
    }

    [data-theme="dark"] {
      --bg: #0c0f1a;
      --bg2: #131827;
      --panel: rgba(22,28,52,.55);
      --panel-solid: #1a1f35;
      --panel2: #1f2640;
      --text: #f1f5f9;
      --text2: #cbd5e1;
      --muted: #94a3b8;
      --dim: #334155;
      --border: rgba(248,250,252,.1);
      --border2: rgba(248,250,252,.18);
      --border-out: rgba(0,0,0,.2);
      --accent-s: #1e1b4b;
      --gold-s: #1c1505;
      --green-s: #052e16;
      --nav-bg: rgba(10,13,24,.55);
      --card-bg: rgba(22,28,52,.5);
      --sh: 0 2px 16px rgba(0, 0, 0, .45), 0 1px 3px rgba(0, 0, 0, .35);
      --sh-lg: 0 12px 40px rgba(0, 0, 0, .55), 0 4px 10px rgba(0, 0, 0, .35);
      --sh-xl: 0 24px 64px rgba(0, 0, 0, .65), 0 8px 20px rgba(0, 0, 0, .45);
    }

    html {
      font-size: 15px;
      scroll-behavior: smooth
    }

    body {
      font-family: var(--sans);
      background: var(--bg);
      background-image: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(99,102,241,.07) 0%, transparent 70%),
                         radial-gradient(ellipse 60% 50% at 80% 100%, rgba(245,158,11,.04) 0%, transparent 60%);
      color: var(--text);
      min-height: 100vh;
      overflow-x: hidden;
      transition: background .45s var(--ease), color .45s var(--ease)
    }

    /* grain */
    body::after {
      content: '';
      position: fixed;
      inset: 0;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23g)' opacity='.035'/%3E%3C/svg%3E");
      pointer-events: none;
      z-index: 9999;
      opacity: 1
    }

    /* animated grid lines */
    .grid-bg {
      position: fixed;
      inset: 0;
      pointer-events: none;
      z-index: 0;
      opacity: .55
    }

    [data-theme="dark"] .grid-bg {
      opacity: .18
    }

    .grid-bg::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image: linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);
      background-size: 64px 64px;
      mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black, transparent);
      animation: gridMove 22s linear infinite
    }

    @keyframes gridMove {
      0% {
        background-position: 0 0
      }

      100% {
        background-position: 64px 64px
      }
    }

    /* floating shapes */
    .shape {
      position: fixed;
      pointer-events: none;
      z-index: 0;
      border-radius: 50%;
      filter: blur(72px);
      animation: shapeFloat 20s ease-in-out infinite
    }

    .shape-1 {
      width: 520px;
      height: 520px;
      background: radial-gradient(circle, rgba(99, 102, 241, .16), transparent 70%);
      top: -180px;
      left: -160px;
      animation-duration: 22s
    }

    .shape-2 {
      width: 440px;
      height: 440px;
      background: radial-gradient(circle, rgba(245, 158, 11, .13), transparent 70%);
      bottom: -120px;
      right: -100px;
      animation-duration: 26s;
      animation-delay: -9s
    }

    .shape-3 {
      width: 360px;
      height: 360px;
      background: radial-gradient(circle, rgba(16, 185, 129, .1), transparent 70%);
      top: 50%;
      left: 55%;
      animation-duration: 30s;
      animation-delay: -15s
    }

    @keyframes shapeFloat {

      0%,
      100% {
        transform: translate(0, 0) scale(1)
      }

      33% {
        transform: translate(24px, -18px) scale(1.04)
      }

      66% {
        transform: translate(-16px, 22px) scale(.97)
      }
    }

    /* ─ NAV ─ */
    nav {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 200;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0 44px;
      height: 60px;
      background: var(--nav-bg);
      backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      border-bottom: 1px solid var(--border);
      transition: background .45s var(--ease), box-shadow .45s var(--ease)
    }

    nav.scrolled {
      box-shadow: var(--sh)
    }

    .nav-logo {
      display: flex;
      align-items: center;
      gap: 10px;
      text-decoration: none
    }

    .nav-mark {
      width: 32px;
      height: 32px;
      background: #0f172a;
      border-radius: 8px;
      display: flex;
      align-items: center;
      justify-content: center;
      box-shadow: 0 3px 10px rgba(15, 23, 42, .35);
      flex-shrink: 0;
      transition: transform .22s, box-shadow .22s
    }

    [data-theme="dark"] .nav-mark {
      background: #fbbf24;
      box-shadow: 0 3px 10px rgba(251, 191, 36, .35)
    }

    [data-theme="dark"] .nav-mark svg path:first-child {
      stroke: #0f172a
    }

    [data-theme="dark"] .nav-mark svg path:nth-child(3) {
      stroke: #0f172a
    }

    .nav-logo:hover .nav-mark {
      transform: rotate(-7deg) scale(1.1);
      box-shadow: 0 6px 18px rgba(15, 23, 42, .48)
    }

    [data-theme="dark"] .nav-logo:hover .nav-mark {
      box-shadow: 0 6px 18px rgba(251, 191, 36, .48)
    }

    .nav-wm {
      font-family: var(--serif);
      font-size: 1.18rem;
      font-weight: 700;
      color: var(--text);
      letter-spacing: -.01em;
      line-height: 1
    }

    .nav-wm span {
      color: var(--gold)
    }

    .nav-r {
      display: flex;
      align-items: center;
      gap: 8px
    }

    .nav-a {
      padding: 7px 14px;
      border-radius: 7px;
      font-size: .79rem;
      font-weight: 500;
      color: var(--muted);
      text-decoration: none;
      border: none;
      background: none;
      cursor: pointer;
      font-family: var(--sans);
      transition: all .18s;
      letter-spacing: .01em
    }

    .nav-a:hover {
      color: var(--text);
      background: var(--border)
    }

    /* ── ANIMATED THEME TOGGLE ── */
    .theme-switch{--ts:1;position:relative;display:inline-block;width:calc(var(--ts)*60px);height:calc(var(--ts)*34px);flex-shrink:0;vertical-align:middle}
    .theme-switch input{opacity:0;width:0;height:0;position:absolute}
    .ts-slider{position:absolute;cursor:pointer;inset:0;background:var(--accent);transition:.4s;overflow:hidden}
    .ts-slider.round{border-radius:calc(var(--ts)*34px)}
    .ts-knob{position:absolute;height:calc(var(--ts)*26px);width:calc(var(--ts)*26px);left:calc(var(--ts)*4px);bottom:calc(var(--ts)*4px);background-color:#fbbf24;transition:.4s}
    .ts-slider.round .ts-knob{border-radius:50%}
    .theme-switch input:checked+.ts-slider{background:#0b1220}
    .theme-switch input:checked+.ts-slider .ts-knob{transform:translateX(calc(var(--ts)*26px));background:#e0e0e0}
    .ts-dot{opacity:0;transition:.4s;fill:#999;position:absolute;z-index:4}
    .theme-switch input:checked+.ts-slider .ts-dot{opacity:1}
    #tmd1{left:calc(var(--ts)*10px);top:calc(var(--ts)*3px);width:calc(var(--ts)*6px);height:calc(var(--ts)*6px)}
    #tmd2{left:calc(var(--ts)*2px);top:calc(var(--ts)*10px);width:calc(var(--ts)*10px);height:calc(var(--ts)*10px)}
    #tmd3{left:calc(var(--ts)*16px);top:calc(var(--ts)*18px);width:calc(var(--ts)*3px);height:calc(var(--ts)*3px)}
    .ts-ray{position:absolute;z-index:-1;fill:white;opacity:.1}
    #tr1{left:calc(var(--ts)*-8px);top:calc(var(--ts)*-8px);width:calc(var(--ts)*43px);height:calc(var(--ts)*43px)}
    #tr2{left:-50%;top:-50%;width:calc(var(--ts)*55px);height:calc(var(--ts)*55px)}
    #tr3{left:calc(var(--ts)*-18px);top:calc(var(--ts)*-18px);width:calc(var(--ts)*60px);height:calc(var(--ts)*60px)}
    .ts-cld{position:absolute;animation:ts-cloud 6s infinite}
    .ts-cl{fill:#eee}
    .ts-cd{fill:#ccc;animation-delay:1s}
    #tc1{left:calc(var(--ts)*30px);top:calc(var(--ts)*15px);width:calc(var(--ts)*40px)}
    #tc2{left:calc(var(--ts)*44px);top:calc(var(--ts)*10px);width:calc(var(--ts)*20px)}
    #tc3{left:calc(var(--ts)*18px);top:calc(var(--ts)*24px);width:calc(var(--ts)*30px)}
    #tc4{left:calc(var(--ts)*36px);top:calc(var(--ts)*18px);width:calc(var(--ts)*40px)}
    #tc5{left:calc(var(--ts)*48px);top:calc(var(--ts)*14px);width:calc(var(--ts)*20px)}
    #tc6{left:calc(var(--ts)*22px);top:calc(var(--ts)*26px);width:calc(var(--ts)*30px)}
    @keyframes ts-cloud{0%{transform:translateX(0)}40%{transform:translateX(4px)}80%{transform:translateX(-4px)}100%{transform:translateX(0)}}
    .ts-stars{transform:translateY(calc(var(--ts)*-32px));opacity:0;transition:.4s}
    .theme-switch input:checked+.ts-slider .ts-stars{transform:translateY(0);opacity:1}
    .ts-star{fill:white;position:absolute;animation:ts-twinkle 2s infinite}
    #ts1{width:calc(var(--ts)*20px);top:calc(var(--ts)*2px);left:calc(var(--ts)*3px);animation-delay:.3s}
    #ts2{width:calc(var(--ts)*6px);top:calc(var(--ts)*16px);left:calc(var(--ts)*3px)}
    #ts3{width:calc(var(--ts)*12px);top:calc(var(--ts)*20px);left:calc(var(--ts)*10px);animation-delay:.6s}
    #ts4{width:calc(var(--ts)*18px);top:calc(var(--ts)*0);left:calc(var(--ts)*18px);animation-delay:1.3s}
    @keyframes ts-twinkle{0%{transform:scale(1)}40%{transform:scale(1.2)}80%{transform:scale(.8)}100%{transform:scale(1)}}

    .nav-cta {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: linear-gradient(135deg, var(--accent), var(--accent-l));
      color: #fff;
      padding: 8px 18px;
      border-radius: 10px;
      font-size: .81rem;
      font-weight: 600;
      text-decoration: none;
      border: none;
      cursor: pointer;
      font-family: var(--sans);
      letter-spacing: .01em;
      box-shadow: 0 2px 10px rgba(99, 102, 241, .34), inset 0 1px 0 rgba(255,255,255,.2);
      transition: all .35s var(--ease)
    }

    .nav-cta:hover {
      transform: translateY(-1px) scale(1.03);
      box-shadow: 0 4px 16px rgba(99, 102, 241, .5), inset 0 1px 0 rgba(255,255,255,.2)
    }

    /* ─ HERO ─ */
    .hero {
      position: relative;
      z-index: 1;
      min-height: 100vh;
      display: grid;
      grid-template-columns: 1fr 1fr;
      align-items: center;
      gap: 64px;
      max-width: 1160px;
      margin: 0 auto;
      padding: 120px 44px 80px;
      overflow: hidden;
    }

    .hero::before {
      content: '';
      position: absolute;
      top: -30%;
      right: -15%;
      width: 700px;
      height: 700px;
      background: radial-gradient(circle, rgba(99, 102, 241, 0.12), transparent);
      border-radius: 50%;
      filter: blur(100px);
      z-index: 0;
      pointer-events: none;
      animation: floatX 20s ease-in-out infinite;
    }

    .hero::after {
      content: '';
      position: absolute;
      bottom: -25%;
      left: -10%;
      width: 600px;
      height: 600px;
      background: radial-gradient(circle, rgba(245, 158, 11, 0.1), transparent);
      border-radius: 50%;
      filter: blur(100px);
      z-index: 0;
      pointer-events: none;
      animation: floatY 25s ease-in-out infinite;
    }

    @keyframes floatX {
      0%, 100% { transform: translateX(0px) translateY(0px); }
      50% { transform: translateX(40px) translateY(-20px); }
    }

    @keyframes floatY {
      0%, 100% { transform: translateX(0px) translateY(0px); }
      50% { transform: translateX(-30px) translateY(30px); }
    }

    .hero-left {
      display: flex;
      flex-direction: column;
      align-items: flex-start
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: linear-gradient(135deg, rgba(99, 102, 241, 0.12), rgba(245, 158, 11, 0.08));
      border: 1.5px solid rgba(99, 102, 241, 0.2);
      color: var(--accent);
      padding: 9px 18px;
      border-radius: 24px;
      font-size: .71rem;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
      margin-bottom: 26px;
      opacity: 0;
      animation: rUp .6s .08s ease forwards;
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      box-shadow: 0 2px 12px rgba(99, 102, 241, 0.08), inset 0 1px 1px rgba(255, 255, 255, 0.3);
      position: relative;
      z-index: 1;
    }

    .ew-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--gold-l);
      animation: ePulse 2.2s ease-in-out infinite
    }

    @keyframes ePulse {

      0%,
      100% {
        opacity: 1;
        transform: scale(1)
      }

      50% {
        opacity: .35;
        transform: scale(.72)
      }
    }

    .hero-h1 {
      font-family: var(--serif);
      font-size: clamp(2.8rem, 5.2vw, 4.2rem);
      font-weight: 700;
      line-height: 1.07;
      letter-spacing: -.022em;
      color: var(--text);
      margin-bottom: 22px;
      opacity: 0;
      animation: rUp .66s .16s ease forwards;
      position: relative;
      z-index: 1;
      background: linear-gradient(135deg, var(--text) 0%, var(--text2) 50%, var(--text) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }

    .hero-h1 em {
      font-style: italic;
      color: var(--accent)
    }

    [data-theme="dark"] .hero-h1 em {
      color: var(--gold-l)
    }

    .hero-p {
      font-size: 1.04rem;
      color: var(--muted);
      line-height: 1.72;
      max-width: 450px;
      margin-bottom: 34px;
      opacity: 0;
      animation: rUp .7s .24s ease forwards;
      position: relative;
      z-index: 1;
      text-shadow: 0 1px 2px rgba(255, 255, 255, 0.4);
    }

    .hero-btns {
      display: flex;
      align-items: center;
      gap: 11px;
      flex-wrap: wrap;
      margin-bottom: 42px;
      opacity: 0;
      animation: rUp .72s .32s ease forwards;
      position: relative;
      z-index: 1;
    }

    .btn-p {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 13px 26px;
      border-radius: 12px;
      font-family: var(--sans);
      font-size: .9rem;
      font-weight: 700;
      text-decoration: none;
      cursor: pointer;
      transition: all .35s var(--ease-spring);
      letter-spacing: .01em;
      border: none;
      position: relative;
      overflow: hidden;
    }

    .btn-p::before {
      content: '';
      position: absolute;
      top: 0;
      left: -100%;
      width: 100%;
      height: 100%;
      background: rgba(255, 255, 255, 0.15);
      transition: left 0.35s ease;
      z-index: -1;
    }

    .btn-p:hover::before {
      left: 100%;
    }

    .btn-primary {
      background: linear-gradient(135deg, var(--accent), var(--accent-l));
      color: #fff;
      box-shadow: 0 4px 18px rgba(99, 102, 241, .42), inset 0 1px 0 rgba(255,255,255,.2);
    }

    .btn-primary:hover {
      transform: translateY(-3px) scale(1.02);
      box-shadow: 0 8px 32px rgba(99, 102, 241, .56), inset 0 1px 0 rgba(255,255,255,.2);
    }

    .btn-outline {
      background: rgba(99, 102, 241, 0.06);
      backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      color: var(--accent);
      border: 2px solid var(--accent);
      box-shadow: inset 0 0 12px rgba(99, 102, 241, 0.05);
    }

    .btn-outline:hover {
      background: var(--accent-s);
      border-color: var(--accent-l);
      color: var(--accent-l);
      transform: translateY(-3px) scale(1.02);
      box-shadow: 0 6px 24px rgba(99, 102, 241, 0.22), inset 0 0 12px rgba(99, 102, 241, 0.08);
    }

    .proof {
      display: flex;
      align-items: center;
      gap: 10px;
      opacity: 0;
      animation: rUp .74s .4s ease forwards;
      position: relative;
      z-index: 1;
      padding: 10px 20px;
      background: rgba(255, 255, 255, 0.4);
      backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      border-radius: 12px;
      border: 1px solid rgba(99, 102, 241, 0.08);
      box-shadow: 0 4px 14px rgba(0, 0, 0, 0.05);
      width: fit-content;
    }

    .proof-stars {
      color: #f59e0b;
      font-size: .82rem;
      letter-spacing: 2px;
      font-weight: 700;
      text-shadow: 0 1px 4px rgba(245, 158, 11, 0.25);
      line-height: 1;
    }

    .proof-label {
      font-size: .76rem;
      color: var(--text2);
      font-weight: 600;
    }

    .proof-label strong {
      color: var(--accent);
      font-weight: 700;
    }

    /* ─ MOCKUP ─ */
    .hero-right {
      position: relative;
      opacity: 0;
      animation: rRight .82s .28s cubic-bezier(.2, .8, .3, 1) forwards
    }

    .mock-wrap {
      position: relative;
      perspective: 1100px
    }

    .mock-doc {
      background: var(--card-bg);
      backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      border-radius: 16px;
      box-shadow: var(--sh-xl);
      border: 1px solid var(--border);
      padding: 26px;
      transform: rotateY(-9deg) rotateX(3deg);
      transform-origin: left center;
      animation: docBob 6s ease-in-out infinite;
      position: relative;
      z-index: 2
    }

    @keyframes docBob {

      0%,
      100% {
        transform: rotateY(-9deg) rotateX(3deg) translateY(0)
      }

      50% {
        transform: rotateY(-7deg) rotateX(2deg) translateY(-8px)
      }
    }

    .m-hdr {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      margin-bottom: 14px;
      padding-bottom: 12px;
      border-bottom: 2.5px solid var(--accent)
    }

    .m-co {
      font-family: var(--serif);
      font-size: .9rem;
      font-weight: 700;
      color: var(--text)
    }

    .m-co-sub {
      font-size: .58rem;
      color: var(--muted);
      margin-top: 2px
    }

    .m-type {
      font-family: var(--serif);
      font-size: .95rem;
      font-weight: 700;
      color: var(--accent);
      text-align: right
    }

    .m-no {
      font-size: .58rem;
      color: var(--muted);
      margin-top: 2px;
      text-align: right
    }

    .m-pts {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 10px;
      margin-bottom: 13px;
      padding: 9px;
      background: var(--panel2);
      border-radius: 7px;
      border: 1px solid var(--border)
    }

    .m-pl {
      font-size: .54rem;
      color: var(--dim);
      text-transform: uppercase;
      letter-spacing: .08em;
      margin-bottom: 2px
    }

    .m-pn {
      font-size: .72rem;
      font-weight: 700;
      color: var(--text)
    }

    .m-pd {
      font-size: .59rem;
      color: var(--muted);
      margin-top: 1px
    }

    .m-tbl {
      width: 100%;
      border-collapse: collapse;
      margin-bottom: 9px
    }

    .m-tbl thead tr {
      background: var(--accent)
    }

    .m-tbl th {
      padding: 5px 7px;
      font-size: .56rem;
      font-weight: 700;
      color: #fff;
      text-align: left;
      text-transform: uppercase;
      letter-spacing: .06em
    }

    .m-tbl th:last-child {
      text-align: right
    }

    .m-tbl td {
      padding: 5px 7px;
      font-size: .65rem;
      border-bottom: 1px solid var(--border);
      color: var(--text2)
    }

    .m-tbl td:last-child {
      text-align: right;
      font-weight: 600
    }

    .m-tbl tr:nth-child(even) td {
      background: var(--panel2)
    }

    .m-tots {
      display: flex;
      justify-content: flex-end
    }

    .m-tot-in {
      width: 48%
    }

    .m-trow {
      display: flex;
      justify-content: space-between;
      padding: 3px 7px;
      font-size: .63rem;
      color: var(--muted);
      border-bottom: 1px solid var(--border)
    }

    .m-grand {
      display: flex;
      justify-content: space-between;
      padding: 5px 7px;
      font-size: .7rem;
      font-weight: 700;
      background: var(--accent);
      color: #fff;
      border-radius: 0 0 5px 5px
    }

    .m-cursor {
      position: absolute;
      width: 9px;
      height: 13px;
      background: var(--accent);
      border-radius: 1px;
      bottom: 58px;
      right: 30px;
      animation: mBlink 1.1s step-start infinite;
      z-index: 5
    }

    @keyframes mBlink {

      0%,
      49% {
        opacity: 1
      }

      50%,
      100% {
        opacity: 0
      }
    }

    /* floating badges */
    .mbadge {
      position: absolute;
      background: var(--panel);
      backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      border-radius: 12px;
      padding: 7px 12px;
      box-shadow: var(--sh-lg);
      border: 1px solid var(--border);
      font-size: .7rem;
      font-weight: 600;
      color: var(--text2);
      display: flex;
      align-items: center;
      gap: 7px;
      white-space: nowrap;
      animation: bPop .5s var(--ease-spring) both;
      z-index: 10
    }

    .mb1 {
      top: -16px;
      right: -8px;
      animation-delay: .85s
    }

    .mb2 {
      bottom: 28px;
      left: -22px;
      animation-delay: 1.05s
    }

    .mb3 {
      top: 44%;
      right: -30px;
      animation-delay: 1.25s
    }

    @keyframes bPop {
      from {
        opacity: 0;
        transform: scale(.55)
      }

      to {
        opacity: 1;
        transform: scale(1)
      }
    }

    .ok-text {
      color: #10b981;
      font-weight: 700
    }

    /* ─ TICKER ─ */
    .ticker-wrap {
      position: relative;
      z-index: 1;
      overflow: hidden;
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      background: var(--nav-bg);
      backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      padding: 14px 0;
      margin-bottom: 96px;
      mask-image: linear-gradient(to right, transparent, black 15%, black 85%, transparent);
      -webkit-mask-image: linear-gradient(to right, transparent, black 15%, black 85%, transparent);
    }

    .ticker {
      display: flex;
      animation: tickScroll 40s linear infinite;
      width: max-content
    }

    .ticker:hover {
      animation-play-state: paused
    }

    .tick-item {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      padding: 0 36px;
      font-size: .8rem;
      font-weight: 500;
      color: var(--muted);
      white-space: nowrap;
      letter-spacing: 0.01em;
    }

    .tick-hi {
      color: var(--accent);
      font-weight: 700
    }

    [data-theme="dark"] .tick-hi {
      color: var(--gold-l)
    }

    @keyframes tickScroll {
      from {
        transform: translateX(0)
      }

      to {
        transform: translateX(-50%)
      }
    }

    /* ─ SECTION LABELS ─ */
    .s-eye {
      display: inline-block;
      font-size: .67rem;
      font-weight: 700;
      letter-spacing: .14em;
      text-transform: uppercase;
      color: var(--accent);
      margin-bottom: 13px
    }

    [data-theme="dark"] .s-eye {
      color: var(--gold-l)
    }

    .s-title {
      font-family: var(--serif);
      font-size: clamp(1.8rem, 3.5vw, 2.55rem);
      font-weight: 700;
      line-height: 1.1;
      letter-spacing: -.02em;
      color: var(--text);
      margin-bottom: 13px
    }

    .s-sub {
      font-size: .98rem;
      color: var(--muted);
      line-height: 1.65;
      max-width: 500px
    }

    /* ─ CARDS ─ */
    .tools-sec {
      position: relative;
      z-index: 1;
      max-width: 1160px;
      margin: 0 auto;
      padding: 0 44px 100px
    }

    .tools-hd {
      text-align: center;
      margin-bottom: 52px
    }

    .tools-hd .s-sub {
      margin: 0 auto
    }

    .cards-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 22px
    }

    .tc {
      position: relative;
      background: var(--card-bg);
      backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      border: 1px solid var(--border);
      border-radius: var(--r);
      padding: 34px 30px;
      text-decoration: none;
      color: var(--text);
      overflow: hidden;
      cursor: pointer;
      transition: box-shadow .4s var(--ease), border-color .3s var(--ease), transform .4s var(--ease);
      transform-style: preserve-3d;
      --rx: 0;
      --ry: 0;
      display: flex;
      flex-direction: column
    }

    .tc:hover {
      box-shadow: var(--sh-xl);
      transform: perspective(1000px) rotateX(calc(var(--rx)*1deg)) rotateY(calc(var(--ry)*1deg)) translateY(-6px);
      border-color: var(--border2)
    }

    /* shine */
    .tc::after {
      content: '';
      position: absolute;
      top: 0;
      left: -100%;
      width: 60%;
      height: 100%;
      background: linear-gradient(105deg, transparent, rgba(255, 255, 255, .11), transparent);
      transform: skewX(-20deg);
      transition: left .58s cubic-bezier(.19, 1, .22, 1);
      pointer-events: none
    }

    .tc:hover::after {
      left: 140%
    }

    /* corner */
    .tc-corner {
      position: absolute;
      top: 0;
      right: 0;
      width: 96px;
      height: 96px;
      border-radius: 0 var(--r) 0 96px;
      opacity: .08;
      transition: opacity .25s
    }

    .tc:hover .tc-corner {
      opacity: .16
    }

    .tc-blue .tc-corner {
      background: var(--accent)
    }

    .tc-gold .tc-corner {
      background: var(--gold)
    }

    .tc-green .tc-corner {
      background: var(--green)
    }

    /* icon */
    .tc-ico {
      width: 52px;
      height: 52px;
      border-radius: 13px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.4rem;
      margin-bottom: 20px;
      position: relative;
      z-index: 1;
      transition: transform .25s cubic-bezier(.34, 1.56, .64, 1)
    }

    .tc:hover .tc-ico {
      transform: scale(1.12) rotate(-5deg)
    }

    .tc-blue .tc-ico {
      background: var(--accent-s);
      border: 1px solid rgba(99, 102, 241, .16)
    }

    .tc-gold .tc-ico {
      background: var(--gold-s);
      border: 1px solid rgba(245, 158, 11, .18)
    }

    .tc-green .tc-ico {
      background: var(--green-s);
      border: 1px solid rgba(16, 185, 129, .16)
    }

    .tc-name {
      font-family: var(--serif);
      font-size: 1.2rem;
      font-weight: 700;
      color: var(--text);
      margin-bottom: 9px;
      position: relative;
      z-index: 1;
      letter-spacing: -.01em
    }

    .tc-desc {
      font-size: .83rem;
      color: var(--muted);
      line-height: 1.64;
      position: relative;
      z-index: 1;
      margin-bottom: 19px;
      flex: 1
    }

    .tc-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      position: relative;
      z-index: 1;
      margin-bottom: 20px
    }

    .tag {
      font-size: .65rem;
      font-weight: 600;
      padding: 3px 9px;
      border-radius: 20px;
      letter-spacing: .04em;
      border: 1px solid var(--border);
      background: var(--panel2);
      color: var(--muted)
    }

    .tc-blue .tag {
      background: var(--accent-s);
      border-color: rgba(99, 102, 241, .14);
      color: var(--accent)
    }

    .tc-gold .tag {
      background: var(--gold-s);
      border-color: rgba(245, 158, 11, .17);
      color: var(--gold)
    }

    .tc-green .tag {
      background: var(--green-s);
      border-color: rgba(16, 185, 129, .15);
      color: var(--green)
    }

    .tc-link {
      display: flex;
      align-items: center;
      gap: 7px;
      font-size: .81rem;
      font-weight: 700;
      position: relative;
      z-index: 1;
      transition: gap .18s
    }

    .tc:hover .tc-link {
      gap: 11px
    }

    .tc-blue .tc-link {
      color: var(--accent)
    }

    .tc-gold .tc-link {
      color: var(--gold)
    }

    .tc-green .tc-link {
      color: var(--green)
    }

    /* ─ FEATURES ─ */
    .feats-sec {
      position: relative;
      z-index: 1;
      background: var(--panel2);
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      padding: 96px 44px;
      margin-bottom: 96px
    }

    .feats-in {
      max-width: 1160px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center
    }

    .feats-right {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px
    }

    .fc {
      background: var(--panel);
      backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      border: 1px solid var(--border);
      border-radius: 14px;
      padding: 22px 20px;
      transition: all .4s var(--ease);
      cursor: default
    }

    .fc:hover {
      border-color: var(--accent);
      transform: translateY(-4px);
      box-shadow: var(--sh-lg)
    }

    .fc-ico {
      font-size: 1.35rem;
      margin-bottom: 10px
    }

    .fc-name {
      font-size: .85rem;
      font-weight: 700;
      color: var(--text);
      margin-bottom: 5px
    }

    .fc-desc {
      font-size: .74rem;
      color: var(--muted);
      line-height: 1.5
    }

    .fc:nth-child(even) {
      margin-top: 20px
    }

    /* ─ HOW ─ */
    .how-sec {
      position: relative;
      z-index: 1;
      max-width: 1160px;
      margin: 0 auto;
      padding: 0 44px 100px
    }

    .how-hd {
      text-align: center;
      margin-bottom: 58px
    }

    .how-hd .s-sub {
      margin: 0 auto
    }

    .steps {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      position: relative
    }

    .steps::before {
      content: '';
      position: absolute;
      top: 21px;
      left: 12%;
      right: 12%;
      height: 1.5px;
      background: linear-gradient(90deg, transparent, var(--border2), var(--border2), transparent);
      z-index: 0
    }

    .sc {
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      padding: 0 14px;
      position: relative;
      z-index: 1
    }

    .sc-n {
      width: 44px;
      height: 44px;
      border-radius: 50%;
      background: var(--panel);
      backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      border: 2px solid var(--border2);
      display: flex;
      align-items: center;
      justify-content: center;
      font-family: var(--serif);
      font-size: 1rem;
      font-weight: 700;
      color: var(--accent);
      margin-bottom: 18px;
      transition: all .4s var(--ease-spring);
      box-shadow: var(--sh)
    }

    .sc:hover .sc-n {
      background: linear-gradient(135deg, var(--accent), var(--accent-l));
      color: #fff;
      border-color: var(--accent);
      transform: scale(1.14);
      box-shadow: 0 6px 20px rgba(99, 102, 241, .38)
    }

    .sc-name {
      font-size: .88rem;
      font-weight: 700;
      color: var(--text);
      margin-bottom: 7px
    }

    .sc-desc {
      font-size: .74rem;
      color: var(--muted);
      line-height: 1.55
    }

    /* ─ FOOTER ─ */
    .main-footer {
      background: linear-gradient(180deg, var(--panel), var(--panel2));
      backdrop-filter: var(--glass-blur-lg);
      -webkit-backdrop-filter: var(--glass-blur-lg);
      border-top: 1px solid var(--border);
      padding: 80px 44px 40px;
      position: relative;
      z-index: 10;
      overflow: hidden;
    }

    .main-footer::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      height: 1px;
      background: linear-gradient(90deg, transparent, var(--accent), var(--gold), transparent);
      opacity: 0.4;
    }

    .footer-grid {
      max-width: 1160px;
      margin: 0 auto 60px;
      display: grid;
      grid-template-columns: 2fr 1fr 1fr 1fr;
      gap: 60px;
    }

    .footer-brand-col {
      display: flex;
      flex-direction: column;
      gap: 20px;
    }

    .footer-logo {
      display: flex;
      align-items: center;
      gap: 12px;
      font-family: var(--serif);
      font-size: 1.4rem;
      font-weight: 700;
      color: var(--text);
      text-decoration: none;
      transition: transform 0.2s;
    }

    .footer-logo:hover {
      transform: translateX(4px);
    }

    .footer-logo span {
      color: var(--gold-l);
    }

    .footer-logo-box {
      width: 32px;
      height: 32px;
      background: #0f172a;
      border-radius: 9px;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      box-shadow: 0 4px 12px rgba(15, 23, 42, 0.35);
    }

    [data-theme="dark"] .footer-logo-box {
      background: #fbbf24;
      box-shadow: 0 4px 12px rgba(251, 191, 36, 0.35);
    }

    [data-theme="dark"] .footer-logo-box svg path:nth-child(2) {
      stroke: #0f172a;
    }

    .footer-tagline {
      font-size: 0.95rem;
      color: var(--muted);
      line-height: 1.7;
      max-width: 340px;
    }

    .footer-title {
      font-size: 0.8rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--text);
      margin-bottom: 24px;
      position: relative;
      display: inline-block;
    }

    .footer-title::after {
      content: '';
      position: absolute;
      bottom: -6px;
      left: 0;
      width: 20px;
      height: 2px;
      background: var(--gold-l);
      border-radius: 2px;
    }

    .footer-col a {
      display: block;
      font-size: 0.9rem;
      color: var(--muted);
      text-decoration: none;
      padding: 8px 0;
      transition: all .3s var(--ease);
    }

    .footer-col a:hover {
      color: var(--accent);
      transform: translateX(6px);
    }

    .footer-bottom {
      max-width: 1160px;
      margin: 0 auto;
      padding-top: 32px;
      border-top: 1px solid var(--border);
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
      gap: 20px;
    }

    .footer-copyright {
      font-size: 0.82rem;
      color: var(--muted);
      font-weight: 500;
    }

    .footer-meta {
      display: flex;
      gap: 16px;
      font-size: 0.82rem;
      color: var(--dim);
      font-weight: 600;
      letter-spacing: 0.02em;
    }

    .footer-socials {
      display: flex;
      gap: 12px;
      align-items: center;
    }

    .footer-socials a {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 34px;
      height: 34px;
      border-radius: 10px;
      background: var(--panel);
      backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      color: var(--muted);
      transition: all .35s var(--ease);
      border: 1px solid var(--border);
    }

    .footer-socials a:hover {
      background: linear-gradient(135deg, var(--accent), var(--accent-l));
      color: #fff;
      border-color: var(--accent);
      transform: translateY(-2px) scale(1.08);
      box-shadow: 0 4px 16px rgba(99,102,241,.35);
    }

    /* ─ SCROLL REVEAL ─ */
    .reveal {
      opacity: 0;
      transform: translateY(24px);
      transition: opacity .7s var(--ease-out), transform .7s var(--ease-out)
    }

    .reveal.in {
      opacity: 1;
      transform: translateY(0)
    }

    .rd1 {
      transition-delay: .07s
    }

    .rd2 {
      transition-delay: .14s
    }

    .rd3 {
      transition-delay: .21s
    }

    .rd4 {
      transition-delay: .28s
    }

    /* ─ KEYFRAMES ─ */
    @keyframes rUp {
      from {
        opacity: 0;
        transform: translateY(14px)
      }

      to {
        opacity: 1;
        transform: translateY(0)
      }
    }

    @keyframes rRight {
      from {
        opacity: 0;
        transform: translateX(22px)
      }

      to {
        opacity: 1;
        transform: translateX(0)
      }
    }

    /* ─ MOBILE HAMBURGER ─ */
    .nav-hamburger {
      display: none;
      width: 36px;
      height: 36px;
      border-radius: 8px;
      border: 1px solid var(--border2);
      background: var(--panel);
      align-items: center;
      justify-content: center;
      cursor: pointer;
      font-size: 1.1rem;
      color: var(--muted);
      transition: all .18s
    }

    .nav-hamburger:hover {
      background: var(--panel2);
      color: var(--text)
    }

    .mobile-nav {
      display: none;
      position: fixed;
      top: 60px;
      left: 0;
      right: 0;
      z-index: 199;
      background: var(--panel);
      border-bottom: 1px solid var(--border);
      box-shadow: var(--sh-lg);
      padding: 12px 20px;
      flex-direction: column;
      gap: 4px
    }

    .mobile-nav.open {
      display: flex;
      animation: rUp .2s ease
    }

    .mobile-nav a {
      display: block;
      padding: 11px 16px;
      border-radius: 8px;
      font-size: .88rem;
      font-weight: 500;
      color: var(--text2);
      text-decoration: none;
      transition: background .12s
    }

    .mobile-nav a:hover,
    .mobile-nav a.active {
      background: var(--accent-s);
      color: var(--accent)
    }

    /* ─ RESPONSIVE ─ */
    /* ─ TABLET ─ */
    @media(max-width:920px) {
      nav {
        padding: 0 18px;
        height: 56px
      }

      .hero {
        grid-template-columns: 1fr;
        gap: 32px;
        padding: 96px 20px 56px;
        min-height: auto
      }

      .hero-right {
        display: none
      }

      .hero-left {
        align-items: center;
        text-align: center
      }

      .hero-p {
        max-width: 100%
      }

      .proof {
        justify-content: center
      }

      .cards-grid {
        grid-template-columns: 1fr 1fr;
        gap: 14px
      }

      .feats-in {
        grid-template-columns: 1fr;
        gap: 40px
      }

      .steps {
        grid-template-columns: 1fr 1fr;
        gap: 24px
      }

      .steps::before {
        display: none
      }

      .tools-sec,
      .how-sec {
        padding-left: 20px;
        padding-right: 20px;
        padding-bottom: 72px
      }

      .feats-sec {
        padding: 72px 20px
      }

      .feats-right {
        grid-template-columns: 1fr 1fr
      }

      .ticker-wrap {
        margin-bottom: 72px
      }

      .footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: 36px 40px
      }

      .main-footer {
        padding: 60px 28px 32px
      }
    }

    /* ─ MOBILE NAV (<680px) ─ */
    @media(max-width:680px) {
      .nav-a {
        display: none
      }

      .nav-hamburger {
        display: flex
      }

      .mobile-nav {
        top: 56px
      }
    }

    /* ─ MOBILE (<520px) ─ */
    @media(max-width:520px) {
      html {
        font-size: 15px
      }

      nav {
        padding: 0 16px;
        height: 52px
      }

      .nav-cta {
        padding: 7px 14px;
        font-size: .78rem
      }

      .theme-switch {
        --ts: .85
      }

      .mobile-nav {
        top: 52px
      }

      /* hero */
      .hero {
        padding: 84px 16px 48px;
        gap: 24px
      }

      .hero-h1 {
        font-size: 2.5rem;
        letter-spacing: -.02em
      }

      .hero-p {
        font-size: .94rem
      }

      .eyebrow {
        font-size: .67rem;
        padding: 5px 11px
      }

      .hero-btns {
        flex-direction: column;
        width: 100%;
        gap: 9px
      }

      .btn-p {
        justify-content: center;
        padding: 13px 20px;
        font-size: .88rem;
        width: 100%
      }

      .proof {
        flex-direction: column;
        align-items: center;
        gap: 8px;
        text-align: center
      }

      /* cards — single column on phone */
      .cards-grid {
        grid-template-columns: 1fr;
        gap: 14px;
        max-width: 100%
      }

      .tc {
        padding: 26px 22px
      }

      /* features */
      .feats-right {
        grid-template-columns: 1fr;
        gap: 12px
      }

      .fc:nth-child(even) {
        margin-top: 0
      }

      .feats-sec {
        padding: 56px 16px
      }

      /* steps */
      .steps {
        grid-template-columns: 1fr;
        gap: 20px
      }

      .steps::before {
        display: none
      }

      /* how */
      .how-sec {
        padding-left: 16px;
        padding-right: 16px;
        padding-bottom: 56px
      }

      .how-hd {
        margin-bottom: 36px
      }

      /* tools */
      .tools-sec {
        padding-left: 16px;
        padding-right: 16px;
        padding-bottom: 64px
      }

      .tools-hd {
        margin-bottom: 36px
      }

      /* ticker */
      .ticker-wrap {
        margin-bottom: 56px
      }

      .tick-item {
        padding: 0 20px;
        font-size: .74rem
      }

      /* footer */
      footer {
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: 22px 16px;
        gap: 12px
      }

      .footer-grid {
        grid-template-columns: 1fr;
        gap: 28px
      }

      .main-footer {
        padding: 48px 20px 28px
      }

      .footer-bottom {
        flex-direction: column;
        align-items: center;
        text-align: center
      }

      .ft-links {
        justify-content: center;
        flex-wrap: wrap
      }

      /* section text */
      .s-title {
        font-size: 1.65rem
      }

      .s-sub {
        font-size: .9rem
      }
    }

    /* ─ TINY PHONES (<360px) ─ */
    @media(max-width:360px) {
      .hero-h1 {
        font-size: 2.1rem
      }

      .tc {
        padding: 22px 18px
      }

      nav {
        padding: 0 12px
      }
    }

    /* ─ NEWSLETTER SIGNUP WIDGET ─ */
    .nl-signup { margin-top: 18px; }
    .nl-title { font-size: .85rem; font-weight: 700; margin: 0 0 4px; color: var(--text); }
    .nl-desc { font-size: .78rem; color: var(--muted); margin: 0 0 10px; }
    .nl-row { display: flex; gap: 6px; }
    .nl-input {
      flex: 1; padding: 8px 12px; border: 1px solid var(--border); border-radius: 10px;
      font-size: .82rem; background: var(--card-bg); backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur); color: var(--text); min-width: 0;
    }
    .nl-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(99,102,241,.1); }
    .nl-btn {
      padding: 8px 16px; background: linear-gradient(135deg, var(--accent), var(--accent-l)); color: #fff; border: none;
      border-radius: 10px; font-size: .82rem; font-weight: 700; cursor: pointer; white-space: nowrap;
      box-shadow: 0 2px 10px rgba(99,102,241,.25); transition: all .35s var(--ease);
    }
    .nl-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(99,102,241,.4); }
    .nl-btn:disabled { opacity: .5; cursor: default; transform: none; }
    .nl-msg { font-size: .78rem; margin-top: 6px; }

    /* ═══════════════════════════════════════
       ANNOUNCEMENT BAR
       ═══════════════════════════════════════ */
    .announce-bar {
      position: fixed; top: 0; left: 0; right: 0; z-index: 1001;
      background: linear-gradient(90deg, var(--accent), #a855f7, var(--gold));
      color: #fff; text-align: center; font-size: .78rem; font-weight: 600;
      padding: 7px 40px 7px 16px; letter-spacing: .01em;
      animation: shimmer 3s ease infinite;
      background-size: 200% 100%;
    }
    .announce-bar a { color: #fff; text-decoration: underline; text-underline-offset: 2px; }
    .announce-bar .ab-close {
      position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
      background: none; border: none; color: #fff; font-size: 1.1rem; cursor: pointer;
      opacity: .7; transition: opacity .2s;
    }
    .announce-bar .ab-close:hover { opacity: 1; }
    @keyframes shimmer { 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }
    .has-announce nav { top: 32px; }
    .has-announce .mobile-nav { top: 92px; }

    /* ═══════════════════════════════════════
       TRUST BADGES
       ═══════════════════════════════════════ */
    .trust-row {
      display: flex; justify-content: center; flex-wrap: wrap; gap: 12px 24px;
      max-width: 900px; margin: -20px auto 0; padding: 0 20px 48px;
      position: relative; z-index: 2;
    }
    .trust-badge {
      display: flex; align-items: center; gap: 8px;
      background: var(--panel); border: 1px solid var(--border);
      backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur);
      padding: 10px 18px; border-radius: 50px; font-size: .8rem; font-weight: 600;
      color: var(--text2); transition: all .35s var(--ease);
      box-shadow: 0 2px 12px rgba(0,0,0,.04);
    }
    .trust-badge:hover { transform: translateY(-2px); box-shadow: var(--sh); border-color: var(--accent); }
    .trust-badge svg { flex-shrink: 0; }

    /* ═══════════════════════════════════════
       ANIMATED STATS COUNTER
       ═══════════════════════════════════════ */
    .stats-sec {
      padding: 64px 20px; position: relative; overflow: hidden;
    }
    .stats-grid {
      display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
      max-width: 960px; margin: 0 auto;
    }
    .stat-card {
      text-align: center; padding: 32px 16px;
      background: var(--panel); border: 1px solid var(--border);
      border-radius: var(--r-lg); backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      transition: all .4s var(--ease); position: relative; overflow: hidden;
    }
    .stat-card::before {
      content: ''; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
      width: 50px; height: 3px; border-radius: 0 0 3px 3px;
      background: linear-gradient(90deg, var(--accent), var(--accent-l));
    }
    .stat-card:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); }
    .stat-num {
      font-family: var(--serif); font-size: 2.8rem; font-weight: 700;
      background: linear-gradient(135deg, var(--accent), var(--gold));
      -webkit-background-clip: text; -webkit-text-fill-color: transparent;
      background-clip: text; line-height: 1.1; margin-bottom: 4px;
    }
    .stat-label { font-size: .82rem; color: var(--muted); font-weight: 500; }

    /* ═══════════════════════════════════════
       TESTIMONIAL CARDS
       ═══════════════════════════════════════ */
    .test-sec {
      padding: 80px 20px 64px; position: relative;
    }
    .test-grid {
      display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
      max-width: 1060px; margin: 0 auto;
    }
    .test-card {
      background: var(--panel); border: 1px solid var(--border);
      border-radius: var(--r-lg); padding: 28px 24px;
      backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur);
      transition: all .4s var(--ease); position: relative;
    }
    .test-card:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); border-color: var(--accent); }
    .test-card:nth-child(2) { transform: translateY(-12px); }
    .test-card:nth-child(2):hover { transform: translateY(-16px); }
    .test-stars { color: var(--gold); font-size: .95rem; margin-bottom: 12px; letter-spacing: 1px; }
    .test-quote {
      font-size: .92rem; line-height: 1.65; color: var(--text2); margin-bottom: 18px;
      font-style: italic; position: relative; padding-left: 20px;
    }
    .test-quote::before {
      content: '\201C'; position: absolute; left: 0; top: -6px;
      font-size: 2rem; font-family: var(--serif); color: var(--accent); opacity: .5;
    }
    .test-author { display: flex; align-items: center; gap: 12px; }
    .test-avatar {
      width: 40px; height: 40px; border-radius: 50%;
      background: linear-gradient(135deg, var(--accent), var(--gold));
      display: flex; align-items: center; justify-content: center;
      color: #fff; font-weight: 700; font-size: .85rem;
    }
    .test-name { font-size: .85rem; font-weight: 700; color: var(--text); }
    .test-role { font-size: .75rem; color: var(--muted); }

    /* ═══════════════════════════════════════
       LOGO CLOUD
       ═══════════════════════════════════════ */
    .logo-cloud {
      padding: 32px 20px 48px; text-align: center;
    }
    .logo-cloud-label {
      font-size: .78rem; color: var(--muted); font-weight: 600;
      text-transform: uppercase; letter-spacing: .08em; margin-bottom: 24px;
    }
    .logo-cloud-row {
      display: flex; justify-content: center; flex-wrap: wrap;
      gap: 32px 48px; align-items: center; max-width: 800px; margin: 0 auto;
      opacity: .45; transition: opacity .4s var(--ease);
    }
    .logo-cloud-row:hover { opacity: .65; }
    .lc-logo {
      font-size: 1.05rem; font-weight: 700; color: var(--text);
      letter-spacing: -.01em; display: flex; align-items: center; gap: 6px;
    }
    .lc-logo svg { opacity: .6; }

    /* ═══════════════════════════════════════
       BENTO GRID (replaces plain feature cards)
       ═══════════════════════════════════════ */
    .bento-sec {
      padding: 80px 20px 64px; position: relative;
    }
    .bento-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      grid-template-rows: auto auto;
      gap: 16px; max-width: 1060px; margin: 0 auto;
    }
    .bento-card {
      background: var(--panel); border: 1px solid var(--border);
      border-radius: var(--r-lg); padding: 32px 28px;
      backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur);
      transition: all .45s var(--ease); position: relative; overflow: hidden;
    }
    .bento-card:hover { transform: translateY(-3px); box-shadow: var(--sh-lg); border-color: var(--accent); }
    .bento-card.bento-wide { grid-column: span 2; }
    .bento-card.bento-tall { grid-row: span 2; display: flex; flex-direction: column; justify-content: center; }
    .bento-ico {
      width: 44px; height: 44px; border-radius: 12px;
      display: flex; align-items: center; justify-content: center;
      margin-bottom: 16px; font-size: 1.3rem;
    }
    .bento-ico.bi-purple { background: rgba(99,102,241,.1); color: var(--accent); }
    .bento-ico.bi-gold { background: rgba(245,158,11,.1); color: var(--gold); }
    .bento-ico.bi-green { background: rgba(16,185,129,.1); color: var(--green); }
    .bento-ico.bi-pink { background: rgba(236,72,153,.1); color: #ec4899; }
    .bento-name { font-family: var(--serif); font-size: 1.15rem; font-weight: 700; margin-bottom: 6px; color: var(--text); }
    .bento-desc { font-size: .85rem; color: var(--muted); line-height: 1.6; }
    .bento-card .bento-visual {
      margin-top: 18px; padding: 16px; border-radius: 12px;
      background: var(--panel2); border: 1px solid var(--border);
      font-family: 'SF Mono', 'Fira Code', monospace; font-size: .72rem;
      color: var(--muted); line-height: 1.7; overflow: hidden;
    }

    /* ═══════════════════════════════════════
       FAQ ACCORDION
       ═══════════════════════════════════════ */
    .faq-sec {
      padding: 80px 20px 64px; position: relative;
    }
    .faq-list {
      max-width: 720px; margin: 0 auto;
      display: flex; flex-direction: column; gap: 10px;
    }
    .faq-item {
      background: var(--panel); border: 1px solid var(--border);
      border-radius: var(--r); backdrop-filter: var(--glass-blur);
      -webkit-backdrop-filter: var(--glass-blur);
      overflow: hidden; transition: all .35s var(--ease);
    }
    .faq-item:hover { border-color: rgba(99,102,241,.25); }
    .faq-q {
      display: flex; align-items: center; justify-content: space-between;
      padding: 18px 22px; cursor: pointer; font-size: .9rem; font-weight: 600;
      color: var(--text); gap: 12px; user-select: none;
    }
    .faq-q svg {
      flex-shrink: 0; transition: transform .3s var(--ease); color: var(--muted);
    }
    .faq-item.open .faq-q svg { transform: rotate(180deg); color: var(--accent); }
    .faq-a {
      max-height: 0; overflow: hidden; transition: max-height .4s var(--ease), padding .3s var(--ease);
      padding: 0 22px; font-size: .85rem; color: var(--text2); line-height: 1.7;
    }
    .faq-item.open .faq-a { max-height: 300px; padding: 0 22px 20px; }

    /* ═══════════════════════════════════════
       BLOG PREVIEW
       ═══════════════════════════════════════ */
    .blog-sec {
      padding: 64px 20px 48px; position: relative;
    }
    .blog-grid {
      display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
      max-width: 1060px; margin: 0 auto;
    }
    .blog-card {
      background: var(--panel); border: 1px solid var(--border);
      border-radius: var(--r-lg); padding: 24px 22px;
      backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur);
      transition: all .4s var(--ease); text-decoration: none; color: inherit;
      display: flex; flex-direction: column;
    }
    .blog-card:hover { transform: translateY(-3px); box-shadow: var(--sh-lg); border-color: var(--accent); }
    .blog-tag {
      display: inline-block; font-size: .68rem; font-weight: 700; text-transform: uppercase;
      letter-spacing: .06em; color: var(--accent); background: var(--accent-s);
      padding: 4px 10px; border-radius: 6px; margin-bottom: 12px; width: fit-content;
    }
    .blog-title {
      font-family: var(--serif); font-size: 1.1rem; font-weight: 700;
      color: var(--text); margin-bottom: 8px; line-height: 1.35;
    }
    .blog-excerpt { font-size: .82rem; color: var(--muted); line-height: 1.6; flex: 1; }
    .blog-read {
      font-size: .8rem; font-weight: 600; color: var(--accent); margin-top: 14px;
      display: flex; align-items: center; gap: 4px;
    }

    /* ═══════════════════════════════════════
       FLOATING MOBILE CTA
       ═══════════════════════════════════════ */
    .float-cta {
      position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%) translateY(80px);
      z-index: 998; display: none;
      background: linear-gradient(135deg, var(--accent), #a855f7);
      color: #fff; padding: 14px 28px; border-radius: 50px; border: none;
      font-size: .88rem; font-weight: 700; cursor: pointer;
      box-shadow: 0 8px 32px rgba(99,102,241,.4), 0 0 0 1px rgba(255,255,255,.1) inset;
      text-decoration: none; white-space: nowrap;
      transition: all .4s var(--ease-spring);
    }
    .float-cta.visible { transform: translateX(-50%) translateY(0); }
    .float-cta:hover { box-shadow: 0 12px 40px rgba(99,102,241,.55); }
    .float-cta svg { vertical-align: middle; margin-left: 6px; }

    /* ═══════════════════════════════════════
       BOLDER AURORA MESH GRADIENTS
       ═══════════════════════════════════════ */
    .aurora-mesh {
      position: fixed; top: 0; left: 0; width: 100%; height: 100%;
      pointer-events: none; z-index: -1; overflow: hidden;
    }
    .aurora-orb {
      position: absolute; border-radius: 50%; filter: blur(100px); opacity: .12;
      animation: auroraFloat 20s ease-in-out infinite alternate;
    }
    .aurora-orb:nth-child(1) {
      width: 600px; height: 600px; top: -10%; left: -5%;
      background: radial-gradient(circle, #6366f1, transparent 70%);
    }
    .aurora-orb:nth-child(2) {
      width: 500px; height: 500px; top: 30%; right: -10%;
      background: radial-gradient(circle, #a855f7, transparent 70%);
      animation-delay: -7s; animation-duration: 25s;
    }
    .aurora-orb:nth-child(3) {
      width: 450px; height: 450px; bottom: 10%; left: 20%;
      background: radial-gradient(circle, #f59e0b, transparent 70%);
      animation-delay: -12s; animation-duration: 22s; opacity: .08;
    }
    .aurora-orb:nth-child(4) {
      width: 350px; height: 350px; top: 60%; right: 25%;
      background: radial-gradient(circle, #10b981, transparent 70%);
      animation-delay: -5s; animation-duration: 28s; opacity: .06;
    }
    @keyframes auroraFloat {
      0% { transform: translate(0, 0) scale(1); }
      33% { transform: translate(30px, -40px) scale(1.1); }
      66% { transform: translate(-20px, 30px) scale(.95); }
      100% { transform: translate(10px, -20px) scale(1.05); }
    }
    [data-theme="dark"] .aurora-orb { opacity: .18; }
    [data-theme="dark"] .aurora-orb:nth-child(3) { opacity: .12; }
    [data-theme="dark"] .aurora-orb:nth-child(4) { opacity: .1; }

    /* ═══════════════════════════════════════
       CTA BANNER (before footer)
       ═══════════════════════════════════════ */
    .cta-banner {
      max-width: 1060px; margin: 0 auto; padding: 0 20px 64px;
    }
    .cta-inner {
      background: linear-gradient(135deg, var(--accent), #7c3aed, #a855f7);
      border-radius: var(--r-lg); padding: 56px 40px; text-align: center;
      position: relative; overflow: hidden;
    }
    .cta-inner::before {
      content: ''; position: absolute; top: -50%; right: -20%;
      width: 400px; height: 400px; border-radius: 50%;
      background: rgba(255,255,255,.08); pointer-events: none;
    }
    .cta-inner::after {
      content: ''; position: absolute; bottom: -40%; left: -10%;
      width: 300px; height: 300px; border-radius: 50%;
      background: rgba(255,255,255,.05); pointer-events: none;
    }
    .cta-inner h2 {
      font-family: var(--serif); font-size: 2.2rem; color: #fff;
      margin-bottom: 12px; position: relative;
    }
    .cta-inner p {
      font-size: 1rem; color: rgba(255,255,255,.8); margin-bottom: 28px;
      max-width: 500px; margin-left: auto; margin-right: auto; position: relative;
    }
    .cta-inner .cta-btn {
      display: inline-flex; align-items: center; gap: 8px;
      background: #fff; color: var(--accent); padding: 14px 32px;
      border-radius: 50px; font-size: .95rem; font-weight: 700;
      text-decoration: none; transition: all .35s var(--ease);
      box-shadow: 0 4px 20px rgba(0,0,0,.15); position: relative;
    }
    .cta-inner .cta-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,0,0,.2); }

    /* ═══════════════════════════════════════
       RESPONSIVE: NEW SECTIONS
       ═══════════════════════════════════════ */
    @media(max-width:900px) {
      .stats-grid { grid-template-columns: repeat(2, 1fr); }
      .test-grid { grid-template-columns: 1fr; max-width: 500px; }
      .test-card:nth-child(2) { transform: none; }
      .test-card:nth-child(2):hover { transform: translateY(-4px); }
      .bento-grid { grid-template-columns: 1fr 1fr; }
      .bento-card.bento-wide { grid-column: span 2; }
      .bento-card.bento-tall { grid-row: span 1; }
      .blog-grid { grid-template-columns: 1fr; max-width: 500px; }
    }
    @media(max-width:520px) {
      .trust-row { gap: 8px 12px; padding-bottom: 32px; }
      .trust-badge { padding: 8px 14px; font-size: .73rem; }
      .stats-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
      .stat-card { padding: 24px 12px; }
      .stat-num { font-size: 2rem; }
      .bento-grid { grid-template-columns: 1fr; }
      .bento-card.bento-wide { grid-column: span 1; }
      .cta-inner { padding: 40px 24px; }
      .cta-inner h2 { font-size: 1.7rem; }
      .announce-bar { font-size: .7rem; padding: 6px 36px 6px 12px; }
      .float-cta { display: block; font-size: .82rem; padding: 12px 24px; }
      .faq-q { padding: 15px 18px; font-size: .85rem; }
    }
    @media(min-width:521px) {
      .float-cta { display: none !important; }
    }

    /* ── PWA Install button ── */
    .nav-install {
      display: inline-flex; align-items: center; gap: 6px;
      padding: 7px 12px; border-radius: 8px;
      background: var(--accent-s); color: var(--accent);
      border: 1px solid rgba(99,102,241,.18);
      font-family: var(--sans); font-size: .78rem; font-weight: 600;
      cursor: pointer; transition: all .2s var(--ease);
    }
    .nav-install:hover {
      background: var(--accent); color: #fff;
      border-color: var(--accent);
      transform: translateY(-1px);
      box-shadow: 0 3px 12px rgba(99,102,241,.32);
    }
    .nav-install[hidden] { display: none !important; }
    @media(max-width:680px){
      .nav-install { display: none !important; }
    }

    /* ── iOS install guide modal ── */
    .pq-ios-guide {
      position: fixed; inset: 0; z-index: 9999;
      background: rgba(8,12,28,.62);
      backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
      display: flex; align-items: center; justify-content: center;
      padding: 20px; animation: pqFadeIn .2s ease;
    }
    .pq-ios-guide[hidden] { display: none !important; }
    @keyframes pqFadeIn { from{opacity:0} to{opacity:1} }
    .pq-ios-card {
      background: var(--panel-solid); color: var(--text);
      max-width: 380px; width: 100%;
      border-radius: 18px; padding: 28px 26px 22px;
      box-shadow: 0 24px 60px rgba(0,0,0,.35);
      position: relative;
      animation: pqPop .25s cubic-bezier(.34,1.56,.64,1);
    }
    @keyframes pqPop { from{opacity:0;transform:scale(.92) translateY(12px)} to{opacity:1;transform:scale(1) translateY(0)} }
    .pq-ios-x {
      position: absolute; top: 10px; right: 12px;
      width: 32px; height: 32px; border: none; background: transparent;
      font-size: 1.6rem; line-height: 1; cursor: pointer; color: var(--muted);
      border-radius: 50%; transition: background .15s;
    }
    .pq-ios-x:hover { background: var(--panel2); color: var(--text); }
    .pq-ios-icon { font-size: 2.4rem; margin-bottom: 8px; }
    .pq-ios-card h3 {
      font-family: var(--serif); font-size: 1.35rem; font-weight: 700;
      color: var(--text); margin-bottom: 8px;
    }
    .pq-ios-card p {
      font-size: .88rem; color: var(--muted); line-height: 1.55; margin-bottom: 16px;
    }
    .pq-ios-card ol {
      margin: 0 0 18px 18px; padding: 0;
      font-size: .87rem; color: var(--text2); line-height: 1.7;
    }
    .pq-ios-card ol li { margin-bottom: 6px; }
    .pq-ios-card strong { color: var(--text); }
    .pq-ios-share {
      display: inline-block; padding: 1px 6px;
      background: var(--accent-s); border-radius: 4px;
      font-size: .82rem;
    }
    .pq-ios-ok {
      display: block; width: 100%;
      padding: 11px 18px; border-radius: 10px;
      background: linear-gradient(135deg, var(--accent), var(--accent-l));
      color: #fff; border: none; cursor: pointer;
      font-family: var(--sans); font-size: .88rem; font-weight: 700;
      box-shadow: 0 3px 14px rgba(99,102,241,.34);
      transition: transform .18s, box-shadow .18s;
    }
    .pq-ios-ok:hover { transform: translateY(-1px); box-shadow: 0 6px 22px rgba(99,102,241,.46); }

    /* mobile-nav install link */
    #pq-install-mobile[hidden] { display: none !important; }

    /* ── Skip painting below-the-fold sections until they scroll near viewport ── */
    .tools-sec,
    .test-sec,
    .bento-sec,
    .how-sec,
    .faq-sec,
    .blog-sec,
    .main-footer {
      content-visibility: auto;
      contain-intrinsic-size: 1px 800px;
    }
    /* Footer is shorter — give a tighter size hint to avoid scrollbar jump */
    .main-footer { contain-intrinsic-size: 1px 480px; }
