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

    :root {
      --black: #111418;
      --grey: #7A7A7A;
      --white: #ffffff;
      --accent: #B9C896;
      --accent-dark: #6a7f44;
      --accent-dim: rgba(185,200,150,0.12);
      --cell: 72px;
    }

    html { scroll-behavior: smooth; overflow-x: hidden; }
    body { font-family: 'DM Sans', sans-serif; background: var(--black); color: var(--white); overflow-x: hidden; cursor: none; }

    /* ── Cursor */
    .cursor { position:fixed; width:10px; height:10px; background:var(--accent); border-radius:50%; pointer-events:none; z-index:99999; transition:transform .15s ease; transform:translate(-50%,-50%); }
    .cursor-ring { position:fixed; width:36px; height:36px; border:1px solid rgba(185,200,150,.5); border-radius:50%; pointer-events:none; z-index:99998; transition:width .3s,height .3s,border-color .3s; transform:translate(-50%,-50%); }

    /* ── Nav */
    nav { position:fixed; top:0; left:0; right:0; z-index:1000; display:flex; align-items:center; justify-content:space-between; padding:14px 56px; background:rgba(17,20,24,.88); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid rgba(255,255,255,.05); }
    nav a.logo img { height:60px; display:block; }

    .btn { display:inline-block; font-family:'DM Sans',sans-serif; font-size:15px; font-weight:600; border-radius:30px; padding:12px 28px; border:none; cursor:none; transition:opacity .2s,transform .2s; text-decoration:none; letter-spacing:.01em; line-height:1; }
    .btn:hover { opacity:.88; transform:translateY(-1px); }
    .btn-accent { background:var(--accent); color:var(--black); }
    .btn-outline { background:transparent; color:var(--white); border:1px solid rgba(255,255,255,.22); transition:opacity .2s,transform .2s,border-color .25s,color .25s; }
    .btn-outline:hover { border-color:var(--accent); color:var(--accent); opacity:1; transform:translateY(-1px); }

    /* ══════════════════════════════════
       HERO
    ══════════════════════════════════ */
    #hero { min-height:100vh; display:flex; flex-direction:column; align-items:center; justify-content:center; position:relative; overflow:hidden; padding:160px 56px 120px; text-align:center; }

    .hero-grid-bg {
      position:absolute; inset:0; z-index:0;
      background-image:
        linear-gradient(rgba(185,200,150,0.15) 1px, transparent 1px),
        linear-gradient(90deg, rgba(185,200,150,0.15) 1px, transparent 1px);
      background-size: var(--cell) var(--cell);
    }
    .hero-vignette { position:absolute; inset:0; z-index:1; background:radial-gradient(ellipse 80% 70% at 50% 50%, transparent 25%, var(--black) 100%); }
    .hero-dots { position:absolute; inset:0; z-index:2; pointer-events:none; overflow:hidden; }
    .hdot { position:absolute; border-radius:50%; background:var(--accent); transform:translate(-50%,-50%); }
    @keyframes dotPulse { 0%,100%{opacity:.18;box-shadow:0 0 0 0 rgba(185,200,150,0)} 50%{opacity:.6;box-shadow:0 0 8px 3px rgba(185,200,150,.25)} }

    .hero-eyebrow { font-size:13px; letter-spacing:.28em; text-transform:uppercase; color:var(--accent); margin-bottom:24px; position:relative; z-index:3; }
    .hero-h1 { font-size:clamp(44px,7.5vw,100px); font-weight:700; text-transform:uppercase; line-height:.95; letter-spacing:2px; color:var(--white); margin-bottom:28px; position:relative; z-index:3; max-width:1000px; }
    .hero-h1 em { font-style:normal; color:var(--accent); }
    .hero-sub { font-size:19px; color:var(--grey); margin-bottom:44px; font-weight:300; position:relative; z-index:3; }
    .hero-btns { display:flex; gap:14px; justify-content:center; align-items:center; flex-wrap:wrap; position:relative; z-index:3; }
    .scroll-hint { position:absolute; bottom:40px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; opacity:.35; z-index:3; }
    .scroll-hint span { font-size:9px; letter-spacing:.25em; text-transform:uppercase; }
    .scroll-line { width:1px; height:40px; background:linear-gradient(to bottom,var(--white),transparent); animation:scrollPulse 2s ease infinite; }
    @keyframes scrollPulse { 0%,100%{opacity:.4} 50%{opacity:1} }
    .ha { opacity:0; transform:translateY(30px); animation:haReveal .8s cubic-bezier(.25,.46,.45,.94) forwards; }
    .ha-1{animation-delay:.1s} .ha-2{animation-delay:.25s} .ha-3{animation-delay:.4s} .ha-4{animation-delay:.55s}
    @keyframes haReveal { to{opacity:1;transform:translateY(0)} }

    /* ══════════════════════════════════
       SHARED
    ══════════════════════════════════ */
    section { padding:100px 56px; position:relative; }
    .container { max-width:1200px; margin:0 auto; }
    .section-label { font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--accent); margin-bottom:14px; display:flex; align-items:center; gap:12px; }
    .section-label::after { content:''; display:block; width:28px; height:1px; background:var(--accent); opacity:.5; }
    .section-h2 { font-size:clamp(30px,4vw,54px); font-weight:700; text-transform:uppercase; line-height:1.0; letter-spacing:2px; }
    .reveal { opacity:0; transform:translateY(26px); transition:opacity .7s ease,transform .7s cubic-bezier(.25,.46,.45,.94); }
    .reveal.visible { opacity:1; transform:translateY(0); }
    .rd1{transition-delay:.1s} .rd2{transition-delay:.2s} .rd3{transition-delay:.3s} .rd4{transition-delay:.4s}

    /* ══════════════════════════════════
       WHO WE ARE — light section
    ══════════════════════════════════ */
    #whoweare {
      position: relative;
      overflow: hidden;
      background-image: url('https://atticsaltadvt.com/wp-content/uploads/2025/09/Banner-2-1.webp');
      background-size: cover; background-position: center;
    }
    #whoweare .container { position: relative; z-index: 1; }
    .wwa-layout { display:grid; grid-template-columns:1fr 1.6fr; gap:80px; align-items:center; }
    .wwa-left {}
    .wwa-stats { display:flex; flex-direction:column; gap:32px; margin-top:40px; }
    .wwa-stat-item {}
    .wwa-stat-num { font-size:clamp(48px,5vw,80px); font-weight:700; color:#111418; line-height:1; letter-spacing:-0.02em; }
    .wwa-stat-label { font-size:13px; color:#444; letter-spacing:.08em; text-transform:uppercase; margin-top:6px; }
    .wwa-logo { margin-top:40px; }
    .wwa-logo img { max-width:200px; height:auto; display:block; }
    .wwa-right { padding-top:4px; }
    .wwa-body { font-size:16px; color:rgba(17,20,24,.7); line-height:1.85; }
    .wwa-body p+p { margin-top:20px; }
    .wwa-body strong { color:#111418; font-weight:600; }
    #whoweare .section-label { color:#111418; }
    #whoweare .section-label::after { background:#111418; opacity:.5; }

    /* ══════════════════════════════════
       OBJECTIONS
    ══════════════════════════════════ */
    #objections { border-top:1px solid rgba(255,255,255,.06); }
    .speech-stage { position:relative; min-height:380px; margin-bottom:72px; }
    .speech-bubble {
      position:absolute; opacity:0;
      background:#b9c896; border-radius:22px; padding:20px 28px;
      font-size:clamp(15px,1.5vw,19px); font-weight:500; font-style:italic; color:#111418; line-height:1.45;
      filter:drop-shadow(0 6px 24px rgba(0,0,0,.45));
      transition:filter .35s ease, transform .35s cubic-bezier(.25,.46,.45,.94);
      will-change:transform,filter;
    }
    .speech-bubble .sb-tail { position:absolute; width:0; height:0; border-left:14px solid transparent; border-right:0 solid transparent; border-top:20px solid #b9c896; bottom:-19px; left:32px; }
    .speech-bubble:hover { filter:drop-shadow(0 10px 40px rgba(185,200,150,.18)); }
    .sb-q { font-style:normal; font-weight:700; color:var(--white); opacity:.55; margin-right:2px; }
    .sb-pulse { position:absolute; inset:-3px; border-radius:25px; border:1.5px solid var(--accent); opacity:0; pointer-events:none; }
    @keyframes pulseOut { 0%{opacity:.55;transform:scale(1)} 100%{opacity:0;transform:scale(1.06)} }
    .do-pulse { animation:pulseOut .9s ease-out forwards; }
    .sb-1 { left:0; top:0; max-width:360px; }
    .sb-2 { right:0; top:24px; max-width:400px; }
    .sb-2 .sb-tail { right:40px; left:auto; }
    .sb-3 { left:16%; top:138px; max-width:380px; }
    .sb-4 { right:2%; top:158px; max-width:340px; }
    .sb-4 .sb-tail { right:36px; left:auto; }
    .sb-5 { left:50%; top:286px; max-width:460px; transform:translateX(-50%); }
    @keyframes floatUp     { 0%,100%{transform:translateY(0)}            50%{transform:translateY(-8px)} }
    @keyframes floatUpB    { 0%,100%{transform:translateY(0)}            50%{transform:translateY(-6px)} }
    @keyframes floatCentre { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(-7px)} }
    .objections-header { margin-bottom:56px; }
    .objection-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
    .objection-card { background:rgba(255,255,255,.02); border:1px solid rgba(255,255,255,.06); padding:36px 36px 52px; position:relative; overflow:hidden; transition:border-color .3s; }
    .objection-card::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,var(--accent-dim),transparent 60%); opacity:0; transition:opacity .4s; }
    .objection-card:hover { border-color:rgba(185,200,150,.2); }
    .objection-card:hover::before { opacity:1; }
    .card-num-label { font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--accent); margin-bottom:16px; opacity:.7; }
    .card-rebuttal { font-size:17px; font-weight:600; color:var(--white); line-height:1.6; position:relative; z-index:1; }
    .card-highlight { color:var(--accent); text-decoration:underline; text-decoration-color:rgba(185,200,150,.35); text-underline-offset:4px; text-decoration-thickness:1.5px; }
    .objection-num { position:absolute; bottom:18px; right:22px; font-size:80px; font-weight:700; color:rgba(255,255,255,.025); line-height:1; }

    /* ══════════════════════════════════
       WORK
    ══════════════════════════════════ */
    #work { border-top:1px solid rgba(255,255,255,.06); padding-bottom:0; }
    .work-head { margin-bottom:48px; display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:20px; }
    .work-scroll-container { overflow-x:auto; margin:0 -56px; padding:0 56px 80px; scrollbar-width:none; }
    .work-scroll-container::-webkit-scrollbar { display:none; }
    .work-track { display:flex; gap:20px; width:max-content; padding-right:56px; }
    .work-card { width:380px; flex-shrink:0; border:1px solid rgba(255,255,255,.07); border-radius:16px; overflow:hidden; background:rgba(255,255,255,.02); transition:transform .4s,border-color .4s; cursor:none; }
    .work-card:hover { transform:translateY(-6px); border-color:rgba(185,200,150,.22); }
    .browser-link { display:block; text-decoration:none; cursor:none; }
    .browser-frame { height:240px; background:#0a0c0e; position:relative; overflow:hidden; display:flex; flex-direction:column; }
    .browser-bar { background:#1a1e23; padding:9px 14px; display:flex; align-items:center; gap:6px; flex-shrink:0; border-bottom:1px solid rgba(255,255,255,.05); }
    .b-dot { width:9px; height:9px; border-radius:50%; }
    .b-dot-r{background:#ff5f57} .b-dot-y{background:#febc2e} .b-dot-g{background:#28c840}
    .b-url { flex:1; margin-left:8px; background:#23272d; border-radius:4px; padding:3px 10px; font-size:11px; color:var(--grey); font-family:monospace; }
    .site-screenshot { flex:1; width:100%; object-fit:cover; object-position:top center; display:block; transition:transform 6s ease; }
    .work-card:hover .site-screenshot { transform:translateY(-8%); }
    .work-card-info { padding:22px 28px; }
    .work-type { font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--accent); margin-bottom:6px; }
    .work-name { font-size:18px; font-weight:700; text-transform:uppercase; color:var(--white); margin-bottom:6px; }
    .work-outcome { font-size:13px; color:var(--grey); line-height:1.5; }
    .work-card-cta { width:320px; display:flex; flex-direction:column; justify-content:center; align-items:flex-start; padding:48px 36px; background:var(--accent-dim); border-color:rgba(185,200,150,.15) !important; }

    /* ══════════════════════════════════
       TESTIMONIALS — light section, 2-card layout
    ══════════════════════════════════ */
    #testimonials {
      padding: 0;
      position: relative;
      overflow: hidden;
      border-top: 1px solid rgba(255,255,255,.06);
      background: url('https://atticsaltadvt.com/wp-content/uploads/2025/09/Banner-2-1.webp') center center / cover no-repeat;
    }
    #testimonials::before {
      content: '';
      position: absolute; inset: 0; z-index: 0;
      background: rgba(255,255,255,0.88);
    }
    #testimonials > .container { position: relative; z-index: 1; padding-top: 0; padding-bottom: 80px; }
    #testimonials .section-label { color: #111418; }
    #testimonials .section-label::after { background: #111418; opacity: .25; }
    #testimonials .section-h2 { color: #111418; }

    /* Marquee — flush to top, full bleed, no bg */
    .marquee-outer {
      margin: 0 -56px;
      padding: 28px 0;
      border-bottom: 1px solid rgba(0,0,0,.08);
      margin-bottom: 72px;
    }
    .marquee-wrap {
      overflow: hidden;
      mask-image: linear-gradient(to right, transparent 0%, black 5%, black 95%, transparent 100%);
      -webkit-mask-image: linear-gradient(to right, transparent 0%, black 5%, black 95%, transparent 100%);
    }
    .marquee-track {
      display: flex;
      align-items: center;
      gap: 64px;
      width: max-content;
      animation: marqueeScroll 36s linear infinite;
      padding: 0 32px;
    }
    .marquee-track:hover { animation-play-state: paused; }
    @keyframes marqueeScroll {
      0%   { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }
    .marquee-logo {
      height: 60px; width: auto;
      flex-shrink: 0;
      opacity: 1;
      filter: none;
      transition: opacity .3s;
    }
    .marquee-logo:hover { opacity: 0.65; }

    /* Section header */
    .testi-header { padding: 0 56px; margin-bottom: 48px; }

    /* 2-card layout */
    .testi-stage {
      position: relative;
      margin-bottom: 32px;
      min-height: 450px;
    }
    /* Non-active pairs: hidden, absolutely positioned so they don't affect height */
    .testi-pair {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
      opacity: 0;
      position: absolute;
      top: 0; left: 0; right: 0;
      transform: translateY(16px);
      height: 100%;
      transition: opacity .5s ease, transform .5s cubic-bezier(.25,.46,.45,.94);
      pointer-events: none;
      visibility: hidden;
    }
    /* Active pair: in normal flow, sets the stage height */
    .testi-pair.active {
      opacity: 1;
      transform: translateY(0);
      position: relative;
      top: auto; left: auto; right: auto;
      pointer-events: all;
      visibility: visible;
    }

    /* Individual card */
    .testi-card {
      background: rgba(255,255,255,0.6);
      border: 1px solid rgba(0,0,0,.08);
      padding: 40px 40px 44px;
      display: flex;
      flex-direction: column;
      backdrop-filter: blur(8px);
      transition: border-color .3s, background .3s;
      height: 450px;
    }
    .testi-card:hover { border-color: rgba(0,0,0,.18); background: rgba(255,255,255,0.8); }

    /* CTA card (last slot) */
    .testi-card-cta {
      background: rgba(185,200,150,0.15);
      border-color: rgba(106,127,68,.2);
      justify-content: center;
    }
    .testi-card-cta:hover { background: rgba(185,200,150,0.25); }
    .testi-cta-label { font-size:10px; letter-spacing:.22em; text-transform:uppercase; color: var(--accent-dark); margin-bottom: 14px; display:flex; align-items:center; gap:10px; }
    .testi-cta-label::after { content:''; display:block; width:20px; height:1px; background:var(--accent-dark); opacity:.5; }
    .testi-cta-h { font-size:26px; font-weight:700; text-transform:uppercase; color:#111418; line-height:1.1; margin-bottom:24px; letter-spacing:1px; }

    /* Card content */
    .testi-highlight {
      font-size: clamp(18px, 2vw, 26px);
      font-weight: 700;
      color: #111418;
      line-height: 1.25;
      margin-bottom: 18px;
      letter-spacing: -.01em;
    }
    .testi-highlight::before { content: '\201C'; color: var(--accent-dark); opacity: .7; margin-right: 2px; }
    .testi-highlight::after  { content: '\201D'; color: var(--accent-dark); opacity: .7; margin-left: 2px; }
    .testi-quote {
      font-size: 14px;
      color: rgba(0,0,0,.55);
      line-height: 1.8;
      flex: 1;
      margin-bottom: 32px;
    }
    .testi-footer {
      display: flex;
      align-items: center;
      gap: 18px;
      border-top: 1px solid rgba(0,0,0,.08);
      padding-top: 22px;
      margin-top: auto;
    }
    .testi-logo-img {
      height: 52px; width: auto;
      opacity: 0.85;
      filter: none;
      flex-shrink: 0;
    }
    .testi-meta { display: flex; flex-direction: column; gap: 2px; }
    .testi-name { font-size: 14px; font-weight: 700; color: #111418; }
    .testi-company { font-size: 11px; color: var(--accent-dark); letter-spacing: .08em; text-transform: uppercase; font-weight: 600; }
    .testi-context { font-size: 11px; color: rgba(0,0,0,.4); margin-top: 2px; }

    /* Controls */
    .testi-controls {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 20px;
      padding-top: 32px;
    }
    .testi-dots {
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .testi-dot {
      width: 7px; height: 7px;
      border-radius: 50%;
      background: rgba(0,0,0,.18);
      border: none;
      cursor: none;
      padding: 0;
      transition: background .3s, width .3s, border-radius .3s;
      position: relative;
      overflow: hidden;
    }
    .testi-dot.active {
      width: 24px;
      border-radius: 4px;
      background: var(--accent-dark);
    }
    .testi-dot.active::after {
      content: '';
      position: absolute;
      left: 0; top: 0; bottom: 0;
      background: rgba(255,255,255,.35);
      animation: dotProgress 7s linear forwards;
    }
    @keyframes dotProgress { from { width: 0% } to { width: 100% } }
    .testi-arrows { display: flex; gap: 10px; }
    .testi-arrow {
      width: 42px; height: 42px;
      border-radius: 50%;
      border: 1px solid rgba(0,0,0,.15);
      background: rgba(255,255,255,.8);
      display: flex; align-items: center; justify-content: center;
      cursor: none;
      transition: border-color .25s, background .25s, transform .2s;
      flex-shrink: 0;
    }
    .testi-arrow:hover { border-color: rgba(0,0,0,.35); background: #fff; transform: scale(1.08); }
    .testi-arrow svg { width: 17px; height: 17px; stroke: #111418; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

    /* ══════════════════════════════════
       TIMELINE
    ══════════════════════════════════ */
    #timeline {
      border-top:1px solid rgba(255,255,255,.06);
      background-image:
        linear-gradient(rgba(185,200,150,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(185,200,150,0.06) 1px, transparent 1px);
      background-size: var(--cell) var(--cell);
      position: relative;
    }
    #timeline::before {
      content:''; position:absolute; inset:0; z-index:1;
      background:rgba(0,0,0,0.14);
      pointer-events:none;
    }
    .timeline-dots { position:absolute; inset:0; z-index:2; pointer-events:none; overflow:hidden; }
    #timeline .container { position:relative; z-index:3; }
    .timeline-head { margin-bottom:72px; }
    .timeline-track { display:flex; position:relative; gap:48px; }
    .timeline-track::before {
      content:''; position:absolute;
      top:6px; left:7px; right:calc(20% - 45px);
      height:1px; background:rgba(255,255,255,.07);
    }
    /* Scroll-driven fill bar — sits on top of the faint track line */
    .timeline-fill {
      position: absolute;
      top: 6px; left: 7px;
      width: 0; height: 1px;
      background: linear-gradient(to right, var(--accent), rgba(185,200,150,.5));
      box-shadow: 0 0 7px rgba(185,200,150,.4);
      pointer-events: none;
      z-index: 2;
    }
    .timeline-step { flex:1; position:relative; padding-top:40px; padding-right:12px; }
    .timeline-dot { position:absolute; top:0; left:0; width:14px; height:14px; border-radius:50%; background:var(--black); border:2px solid rgba(185,200,150,.45); z-index:1; transition:background .3s,border-color .3s; }
    .timeline-step:hover .timeline-dot, .timeline-step.active .timeline-dot { background:var(--accent); border-color:var(--accent); }
    .timeline-icon { width:40px; height:40px; border-radius:10px; background:rgba(185,200,150,.07); border:1px solid rgba(185,200,150,.15); display:flex; align-items:center; justify-content:center; margin-bottom:14px; transition:background .3s,border-color .3s; }
    .timeline-step:hover .timeline-icon,
    .timeline-step.active .timeline-icon { background:rgba(185,200,150,.13); border-color:rgba(185,200,150,.3); }
    .timeline-icon svg { width:18px; height:18px; stroke:var(--accent); fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
    .timeline-day { font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:6px; }
    .timeline-label { font-size:15px; font-weight:600; text-transform:uppercase; color:var(--white); letter-spacing:.01em; }

    /* ══════════════════════════════════
       CTA
    ══════════════════════════════════ */
    #cta { border-top:1px solid rgba(255,255,255,.06); padding:0; }
    .cta-layout { display:grid; grid-template-columns:1fr 1fr; min-height:640px; }
    .cta-left { padding:100px 64px 100px 56px; display:flex; flex-direction:column; justify-content:center; border-right:1px solid rgba(255,255,255,.06); position:relative; }
    .cta-left::before { content:''; position:absolute; width:500px; height:500px; background:radial-gradient(circle,rgba(185,200,150,.05),transparent 65%); top:50%; left:0; transform:translateY(-50%); pointer-events:none; }
    .cta-h2 { font-size:clamp(40px,5vw,76px); font-weight:700; text-transform:uppercase; line-height:.92; letter-spacing:2px; margin-bottom:32px; position:relative; z-index:1; }
    .cta-h2 span { color:var(--accent); }
    .cta-body { font-size:15px; color:var(--grey); line-height:1.8; margin-bottom:28px; position:relative; z-index:1; max-width:440px; }
    .cta-body p+p { margin-top:14px; }
    .cta-qualifier { font-size:15px; color:var(--grey); font-style:italic; line-height:1.8; border-top:1px solid rgba(255,255,255,.07); padding-top:20px; max-width:440px; position:relative; z-index:1; }
    .cta-right { padding:100px 56px 100px 64px; display:flex; flex-direction:column; justify-content:center; background:rgba(255,255,255,.015); }
    .cta-form-label { font-size:11px; letter-spacing:.25em; text-transform:uppercase; color:var(--accent); margin-bottom:28px; }
    .form-group { margin-bottom:18px; }
    .form-group label { display:block; font-size:11px; letter-spacing:.15em; text-transform:uppercase; color:#F7F7F7; margin-bottom:8px; }
    .form-group input { width:100%; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:8px; padding:14px 16px; font-family:'DM Sans',sans-serif; font-size:15px; color:var(--white); outline:none; transition:border-color .25s; }
    .form-group input::placeholder { color:rgba(255,255,255,.2); }
    .form-group input:focus { border-color:rgba(185,200,150,.4); }
    .form-submit-full { width:100%; margin-top:6px; font-size:15px; padding:15px; text-align:center; }
    .cta-form-note { font-size:12px; color:rgba(255,255,255,.22); text-align:center; margin-top:16px; line-height:1.65; }

    /* ══════════════════════════════════
       MODAL
    ══════════════════════════════════ */
    .modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.83); backdrop-filter:blur(10px); z-index:9000; display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .3s; }
    .modal-overlay.active { opacity:1; pointer-events:all; }
    .modal { background:#161b1f; border:1px solid rgba(255,255,255,.08); border-radius:20px; padding:52px 48px; width:90%; max-width:480px; position:relative; transform:translateY(22px); transition:transform .38s cubic-bezier(.34,1.56,.64,1); }
    .modal-overlay.active .modal { transform:translateY(0); }
    .modal-close { position:absolute; top:20px; right:22px; background:none; border:none; color:var(--grey); font-size:26px; cursor:none; line-height:1; transition:color .2s; }
    .modal-close:hover { color:var(--white); }
    .modal-eyebrow { font-size:10px; letter-spacing:.25em; text-transform:uppercase; color:var(--accent); margin-bottom:10px; }
    .modal-h { font-size:30px; font-weight:700; text-transform:uppercase; color:var(--white); margin-bottom:6px; }
    .modal-sub { font-size:14px; color:var(--grey); margin-bottom:32px; line-height:1.6; }
    .modal-submit { width:100%; margin-top:6px; font-size:15px; padding:15px; text-align:center; }
    .modal-note { font-size:12px; color:rgba(255,255,255,.22); text-align:center; margin-top:16px; line-height:1.65; }

    /* ══════════════════════════════════
       FOOTER
    ══════════════════════════════════ */
    footer { border-top:1px solid rgba(255,255,255,.06); padding:32px 56px; display:flex; justify-content:flex-end; align-items:center; flex-wrap:wrap; gap:16px; }
    .footer-right { font-size:12px; color:rgba(255,255,255,.25); }
    .footer-right a { color:rgba(255,255,255,.3); text-decoration:none; transition:color .2s; }
    .footer-right a:hover { color:var(--accent); }

    /* ══════════════════════════════════
       RESPONSIVE
    ══════════════════════════════════ */
    @media (max-width:960px) {
        nav { padding: 12px 16px; justify-content: space-between; max-width: 100vw; box-sizing: border-box; }
        nav a.logo img { height: 40px; }
        nav .btn { font-size: 12px; padding: 8px 12px; white-space: nowrap; flex-shrink: 0; }
      section { padding:72px 24px; }
      .cursor, .cursor-ring { display: none; }
      body { cursor: auto; }
      #hero { padding:130px 24px 100px; }
      .wwa-layout { grid-template-columns:1fr; gap:40px; }
      .wwa-stats { flex-direction:row; gap:24px; flex-wrap:wrap; }
      .wwa-stat-num { font-size:clamp(40px,9vw,64px); }
      .speech-stage { position:static; min-height:unset; display:flex; flex-direction:column; gap:16px; margin-bottom:40px; }
      .speech-bubble { position:static !important; left:auto !important; right:auto !important; top:auto !important; transform:none !important; max-width:100% !important; width:100%; opacity:1; }
      .sb-tail { display:none; }
      .objection-cards { grid-template-columns:1fr; }
      .cta-layout { grid-template-columns:1fr; }
      .cta-left { padding:72px 24px 48px; border-right:none; border-bottom:1px solid rgba(255,255,255,.06); }
      .cta-right { padding:48px 24px 72px; }
        .timeline-track { flex-direction: column; gap: 0; }
        .timeline-track::before { display: none; }
        .timeline-step {
          display: grid;
          grid-template-columns: 40px 48px 1fr;
          grid-template-rows: auto auto;
          column-gap: 16px;
          padding: 0 0 36px 0;
          position: relative;
          align-items: start;
        }
        .timeline-step:last-child { padding-bottom: 0; }
        .timeline-dot {
          grid-column: 1; grid-row: 1;
          margin-top: 4px;
          position: relative; top: auto; left: auto;
        }
        .timeline-step::before {
          content: '';
          position: absolute;
          left: 6px; top: 14px; bottom: 0;
          width: 1px;
          background: rgba(255,255,255,.07);
        }
        .timeline-step:last-child::before { display: none; }
        /* Vertical fill bar on mobile */
        .timeline-fill {
          top: 0; /* overridden by JS */
          left: 6px;
          width: 1px;
          height: 0;
          background: linear-gradient(to bottom, var(--accent), rgba(185,200,150,.5));
          box-shadow: 1px 0 7px rgba(185,200,150,.4);
        }
        .timeline-icon {
          grid-column: 2; grid-row: 1 / 3;
          margin: 0;
          align-self: start;
        }
        .timeline-day {
          grid-column: 3; grid-row: 1;
          margin: 0;
        }
        .timeline-label {
          grid-column: 3; grid-row: 2;
        }
      .work-scroll-container { margin:0 -24px; padding:0 24px 60px; }
      .work-track { padding-right:24px; }
      footer { padding:28px 24px; justify-content:flex-start; }
      .modal { padding:40px 28px; }
      /* Testimonials mobile — one card at a time */
      .marquee-outer { margin: 0 -24px; }
      .testi-header { padding: 0 24px; }
      .testi-stage { padding: 0 24px; min-height: unset; }
      /* Override 2-col grid so the single visible card fills full width */
      .testi-pair.active {
        display: block;
        position: relative;
        inset: auto;
      }
      /* Both cards in the active pair are hidden by default on mobile */
      .testi-pair.active .testi-card { display: none; }
      /* Only the JS-marked card is shown — fixed height prevents jitter */
      .testi-pair.active .testi-card.mc-active {
        display: flex;
        height: 400px;
        min-height: unset;
        overflow: hidden;
      }
      /* Clamp quote text so it never pushes beyond the fixed height */
      .testi-pair.active .testi-card.mc-active .testi-quote {
        display: -webkit-box;
        -webkit-line-clamp: 5;
        -webkit-box-orient: vertical;
        overflow: hidden;
        flex: unset;
        margin-bottom: 16px;
      }
      /* CTA card: centre its content vertically */
      .testi-pair.active .testi-card-cta.mc-active {
        justify-content: center;
        overflow: visible;
      }
      /* Reduce card side padding on mobile */
      .testi-card { padding: 28px 24px 28px; }
      .testi-controls { padding: 10px 24px 0; }
    }
