/* ============================================================
   WEBNOVA — Service detail pages (template: includes/sections/service/page.php)
   Sections: hero crumb · intro · capabilities · approach (dark) · faq
   Relies on page.css for hero, section heads, prose, and FAQ accordion.
   ============================================================ */

/* ─── Hero breadcrumb ───────────────────────────────────── */
.wn-svcpage-crumb { color: rgba(247, 246, 242, 0.6); transition: color var(--wn-t-fast) var(--wn-ease); }
.wn-svcpage-crumb:hover { color: var(--wn-ink-inv); }
.wn-svcpage-crumb-sep { color: rgba(247, 246, 242, 0.35); }

/* ─── Intro (two-column) ────────────────────────────────── */
.wn-svcpage-intro-grid {
    display: grid;
    grid-template-columns: 5fr 8fr;
    gap: clamp(2.5rem, 5vw, 5rem);
    align-items: start;
}
/* Let the intro prose use the wider column, and never orphan a last word */
.wn-svcpage-intro-grid .wn-prose { max-width: 70ch; text-wrap: pretty; }
.wn-svcpage-intro-aside { position: sticky; top: 7rem; }
.wn-svcpage-intro-aside .wn-section-eyebrow { margin-bottom: 1.4rem; }
.wn-svcpage-intro-lead {
    font-size: clamp(1.5rem, 2.4vw, 2.1rem);
    font-weight: 300;
    line-height: 1.2;
    letter-spacing: -0.025em;
    color: var(--wn-ink);
    margin: 0;
    max-width: 18ch;
}

/* ─── Capabilities grid ─────────────────────────────────── */
.wn-svcpage-caps-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.2rem;
}
.wn-svcpage-cap {
    padding: 2.2rem 1.8rem;
    background: var(--wn-bg);
    border: 1px solid var(--wn-line);
    border-radius: var(--wn-r-lg);
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    transition: transform var(--wn-t-med) var(--wn-ease), box-shadow var(--wn-t-med) var(--wn-ease);
}
.wn-svcpage-cap:hover { transform: translateY(-3px); box-shadow: var(--wn-glass-shadow); }
.wn-svcpage-cap-icon {
    width: 46px; height: 46px;
    border-radius: 50%;
    background: var(--wn-accent-tint);
    color: var(--wn-accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.wn-svcpage-cap-icon svg { width: 22px; height: 22px; }
.wn-svcpage-cap-title {
    font-size: 1.1rem;
    font-weight: 600;
    letter-spacing: -0.015em;
    color: var(--wn-ink);
    margin: 0;
}
.wn-svcpage-cap-copy {
    font-size: 0.92rem;
    font-weight: 300;
    line-height: 1.6;
    color: var(--wn-ink-2);
    margin: 0;
}

/* ─── Approach steps (dark band) ────────────────────────── */
.wn-svcpage-steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--wn-line-inv);
    border-top: 1px solid var(--wn-line-inv);
    border-bottom: 1px solid var(--wn-line-inv);
}
.wn-svcpage-step {
    background: #0a0d14;
    padding: 2.4rem 1.8rem;
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
}
.wn-svcpage-step-num {
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.22em;
    color: var(--wn-accent);
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 0.4rem;
}
.wn-svcpage-step-num::before { content: ''; width: 22px; height: 1px; background: var(--wn-accent); }
.wn-svcpage-step-title {
    font-size: 1.2rem;
    font-weight: 500;
    letter-spacing: -0.02em;
    color: var(--wn-ink-inv);
    margin: 0;
}
.wn-svcpage-step-copy {
    font-size: 0.92rem;
    font-weight: 300;
    line-height: 1.6;
    color: var(--wn-ink-inv-muted);
    margin: 0;
}

/* ─── Responsive ────────────────────────────────────────── */
@media (max-width: 1024px) {
    .wn-svcpage-intro-grid { grid-template-columns: 1fr; gap: 2rem; }
    .wn-svcpage-intro-aside { position: static; }
    .wn-svcpage-intro-lead { max-width: none; }
    .wn-svcpage-caps-grid { grid-template-columns: repeat(2, 1fr); }
    .wn-svcpage-steps { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
    .wn-svcpage-caps-grid { grid-template-columns: 1fr; }
    .wn-svcpage-steps { grid-template-columns: 1fr; }
}

/* ============================================================
   SERVICE-PAGE UPGRADE LIBRARY
   Shared mini-sales-page sections: proof-strip · stat-inline ·
   signature-visual · cta-mid · testimonial-single · offer-anchor.
   Per-service accent is a DECORATIVE ambient hue only (aurora glows
   + signature) — UI chrome stays on the brand --wn-accent.
   ============================================================ */

/* Service-page accent — bound to the brand UI accent (--wn-accent #02d9ff).
   Kept as a single variable so every component references one source. */
.page-service { --svc-accent: var(--wn-accent); --svc-accent-rgb: 2, 217, 255; }

/* Retint the hero aurora with the service accent (scoped to service hero
   so the about/contact heroes are untouched) */
.wn-svchero .wn-page-hero-glow.is-1 {
    background: radial-gradient(circle, rgba(var(--svc-accent-rgb), 0.16) 0%, transparent 70%);
}

/* ─── Proof strip ───────────────────────────────────────── */
.wn-proof-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1.5rem 2.5rem;
    flex-wrap: wrap;
    margin-bottom: 2.8rem;
}
.wn-proof-line {
    font-size: 1.05rem;
    font-weight: 300;
    color: var(--wn-ink-muted);
    margin: 0.9rem 0 0;
}
.wn-proof-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--wn-ink);
    white-space: nowrap;
    padding-bottom: 0.3rem;
    border-bottom: 1px solid var(--wn-ink);
}
.wn-proof-link svg { transition: transform var(--wn-t-fast) var(--wn-ease); }
.wn-proof-link:hover svg { transform: translateX(4px); }
/* Two-up, matching the home portfolio (is-half) — room to show each tile well */
.wn-proof-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.2rem;
}

/* ─── Typography tidy — no orphaned tails ───────────────── */
/* Give the capabilities intro room so the final "yes." stays on its line */
.wn-svcpage-caps .wn-section-head { max-width: 74rem; }
.wn-svcpage-caps .wn-section-copy { max-width: 72ch; text-wrap: pretty; }
/* Keep the process heading on one line where it fits; balance, never orphan */
.wn-svcpage-approach .wn-section-title { max-width: none; text-wrap: balance; }
/* Proof title reads on one line (no tail) */
.wn-proof .wn-section-title { max-width: none; text-wrap: balance; }

/* ─── Inline stat strip (slim, dark) ────────────────────── */
.wn-statline {
    background: #0a0d14;
    color: var(--wn-ink-inv);
    padding: clamp(2.2rem, 4vw, 3.2rem) 0;
    border-top: 1px solid var(--wn-line-inv);
    border-bottom: 1px solid var(--wn-line-inv);
}
.wn-statline-row {
    display: flex;
    justify-content: space-around;
    align-items: flex-start;
    gap: 1.5rem 2rem;
    flex-wrap: wrap;
    text-align: center;
}
.wn-statline-item { display: flex; flex-direction: column; gap: 0.45rem; }
.wn-statline-num {
    font-family: var(--font-display);
    font-size: clamp(2.4rem, 4.4vw, 3.6rem);
    font-weight: 300;
    letter-spacing: -0.04em;
    line-height: 1;
    color: var(--wn-ink-inv);
    font-variant-numeric: tabular-nums;
}
.wn-statline-num sup {
    font-size: 0.36em;
    font-weight: 400;
    vertical-align: top;
    position: relative;
    top: 0.7em;
    margin-left: 2px;
    color: var(--svc-accent);
}
.wn-statline-label {
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--wn-ink-inv-muted);
}

/* ─── Signature visual band ─────────────────────────────── */
.wn-sig { position: relative; overflow: hidden; }
.wn-sig-glow { position: absolute; border-radius: 50%; filter: blur(70px); pointer-events: none; z-index: 0; }
.wn-sig-glow.is-1 {
    top: -130px; right: -60px; width: 480px; height: 480px;
    background: radial-gradient(circle, rgba(var(--svc-accent-rgb), 0.20) 0%, transparent 70%);
}
.wn-sig-glow.is-2 {
    bottom: -150px; left: -90px; width: 400px; height: 400px;
    background: radial-gradient(circle, rgba(123, 97, 255, 0.14) 0%, transparent 70%);
}
.wn-sig .wn-container { position: relative; z-index: 1; }
.wn-sig-grid {
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: clamp(2.5rem, 5vw, 4.5rem);
    align-items: center;
}
.wn-sig-copy .wn-section-title { max-width: 16ch; }
.wn-sig-stage { position: relative; min-height: 420px; }
/* Short visuals (e.g. the pipeline) centre against the copy instead of
   sitting at the top of the tall fragment stage */
.wn-sig-stage--ai-pipeline { min-height: 0; display: flex; align-items: center; }

/* ─── Interface fragment (Custom Software signature) ────── */
.wn-frag { position: relative; height: 100%; min-height: 420px; }
.wn-frag-panel {
    position: absolute;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.10);
    background: rgba(20, 25, 34, 0.72);
    backdrop-filter: blur(14px) saturate(1.4);
    box-shadow: 0 30px 60px -28px rgba(0, 0, 0, 0.72);
    overflow: hidden;
}
@media (prefers-reduced-transparency: reduce) {
    .wn-frag-panel { background: rgba(16, 20, 28, 0.96); backdrop-filter: none; }
}
.wn-frag-code  { top: 6%;  left: 0;    width: 60%; z-index: 2; }
.wn-frag-table { bottom: 4%; right: 0; width: 56%; z-index: 3; padding: 0.9rem 1rem 0.4rem; }
.wn-frag-cards { top: 0; right: 1%;    width: 30%; z-index: 4; background: transparent; border: 0; box-shadow: none; backdrop-filter: none; display: flex; flex-direction: column; gap: 0.7rem; overflow: visible; }

.wn-frag-bar { display: flex; align-items: center; gap: 6px; padding: 0.65rem 0.85rem; border-bottom: 1px solid rgba(255, 255, 255, 0.08); }
.wn-frag-dot { width: 10px; height: 10px; border-radius: 50%; background: rgba(255, 255, 255, 0.16); }
.wn-frag-bar-name { margin-left: 8px; font-size: 0.7rem; letter-spacing: 0.04em; color: rgba(247, 246, 242, 0.4); }
.wn-frag-pre {
    margin: 0;
    padding: 0.95rem 1.1rem 1.1rem;
    font-family: ui-monospace, "SF Mono", "SFMono-Regular", Menlo, Consolas, monospace;
    font-size: 0.78rem;
    line-height: 1.75;
    color: rgba(247, 246, 242, 0.82);
    white-space: pre;
    overflow: hidden;
}
.wn-frag-pre .t-c  { color: rgba(247, 246, 242, 0.34); font-style: italic; }
.wn-frag-pre .t-k  { color: #7b61ff; }
.wn-frag-pre .t-f  { color: var(--svc-accent); }
.wn-frag-pre .t-v  { color: var(--wn-accent-soft); }
.wn-frag-pre .t-vr { color: var(--wn-ink-inv); }
.wn-frag-pre .t-s  { color: #19c27a; }

.wn-frag-table-head,
.wn-frag-row {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr;
    gap: 0.6rem;
    align-items: center;
    font-size: 0.74rem;
}
.wn-frag-table-head {
    color: rgba(247, 246, 242, 0.4);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: 0.62rem;
    padding-bottom: 0.6rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.wn-frag-row { padding: 0.55rem 0; border-bottom: 1px solid rgba(255, 255, 255, 0.05); color: rgba(247, 246, 242, 0.78); }
.wn-frag-row:last-child { border-bottom: 0; }
.wn-frag-table .ta-r { text-align: right; font-variant-numeric: tabular-nums; }
.wn-frag-pill { justify-self: start; font-size: 0.6rem; padding: 0.18rem 0.5rem; border-radius: var(--wn-r-pill); letter-spacing: 0.03em; }
.wn-frag-pill.is-ok   { background: rgba(25, 194, 122, 0.16); color: #19c27a; }
.wn-frag-pill.is-wait { background: rgba(var(--svc-accent-rgb), 0.16); color: var(--svc-accent); }

.wn-frag-metric {
    background: rgba(20, 25, 34, 0.85);
    border: 1px solid rgba(255, 255, 255, 0.10);
    border-radius: 12px;
    padding: 0.75rem 0.9rem;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    backdrop-filter: blur(14px);
    box-shadow: 0 20px 40px -24px rgba(0, 0, 0, 0.7);
}
.wn-frag-metric-label { font-size: 0.64rem; letter-spacing: 0.04em; color: rgba(247, 246, 242, 0.4); }
.wn-frag-metric-num { font-family: var(--font-display); font-size: 1.5rem; font-weight: 300; line-height: 1; color: var(--svc-accent); }
.wn-frag-spark { height: 3px; border-radius: 2px; background: linear-gradient(90deg, transparent, var(--svc-accent)); opacity: 0.7; }
.wn-frag-spark.is-2 { background: linear-gradient(90deg, transparent, #7b61ff); opacity: 0.55; }

/* ─── Fragment motion — "code builds the UI" ─────────────
   Each code line is its own inline-block so it can fade in (the literal
   newlines in the <pre> still provide the line breaks). Everything below is
   gated behind .is-armed, which software-fragment.js adds ONLY when motion is
   allowed — so with JS off or reduced-motion on, the panel stays fully visible
   exactly as the static fragment did. opacity-hidden lines keep their layout
   box, so the code panel never changes height while typing. */
.wn-frag-line { display: inline-block; }

.wn-frag.is-armed .wn-frag-row,
.wn-frag.is-armed .wn-frag-metric-num { opacity: 0; }
.wn-frag.is-armed .wn-frag-row    { transform: translateX(10px); }
.wn-frag.is-armed .wn-frag-metric-num { transform: translateY(4px); }
.wn-frag.is-armed .wn-frag-spark  { transform: scaleX(0); transform-origin: left center; }

/* Code is typed out one character at a time (JS wraps each char in .t-ch).
   The line spans stay in flow, so the panel never changes height — only the
   characters appear. */
.wn-frag.is-armed .t-ch { display: none; }
.wn-frag.is-armed .t-ch.is-typed { display: inline; }
/* Blinking caret on the line currently being typed */
.wn-frag.is-armed .wn-frag-line.is-active::after {
    content: ''; display: inline-block;
    width: 7px; height: 0.95em; margin-left: 3px; vertical-align: -1px;
    background: var(--svc-accent);
    animation: wn-frag-caret 0.9s steps(1, end) infinite;
}
@keyframes wn-frag-caret { 50% { opacity: 0; } }

/* Table rows assemble once the reconcile() line lands */
.wn-frag.is-armed .wn-frag-table.is-built .wn-frag-row {
    opacity: 1; transform: none;
    transition: opacity 320ms var(--wn-ease), transform 320ms var(--wn-ease);
}
.wn-frag.is-armed .wn-frag-table.is-built .wn-frag-row:nth-child(3) { transition-delay: 90ms; }
.wn-frag.is-armed .wn-frag-table.is-built .wn-frag-row:nth-child(4) { transition-delay: 180ms; }

/* Metric numbers + sparklines draw once export('pdf') lands */
.wn-frag.is-armed .wn-frag-cards.is-built .wn-frag-metric-num {
    opacity: 1; transform: none;
    transition: opacity 400ms var(--wn-ease) 60ms, transform 400ms var(--wn-ease) 60ms;
}
.wn-frag.is-armed .wn-frag-cards.is-built .wn-frag-spark {
    transform: scaleX(1);
    transition: transform 550ms var(--wn-ease-out);
}
.wn-frag.is-armed .wn-frag-cards.is-built .wn-frag-spark.is-2 { transition-delay: 120ms; }

/* Defensive: if armed under reduced motion, show the finished state, no caret */
@media (prefers-reduced-motion: reduce) {
    .wn-frag.is-armed .t-ch { display: inline; }
    .wn-frag.is-armed .wn-frag-row,
    .wn-frag.is-armed .wn-frag-metric-num { opacity: 1; transform: none; }
    .wn-frag.is-armed .wn-frag-spark { transform: scaleX(1); }
    .wn-frag.is-armed .wn-frag-line.is-active::after { display: none; }
}

/* ─── Design canvas (Website Design signature) — wireframe → finished ───
   A browser frame holding a light mock page that assembles itself. State is
   driven by design-canvas.js stacking classes on .wn-canvas:
     is-armed   → hide the lay-in blocks, greyscale the page, clip the headline
     is-laid    → blocks fade up into place (staggered by inline --d)
     is-coloured→ greyscale lifts, brand colour resolves
     is-typed   → headline wipes in (staggered by inline --w)
   Everything that hides is gated behind .is-armed, so JS-off / reduced-motion
   shows the finished page as-is. */
.wn-canvas { position: relative; height: 100%; min-height: 420px; display: flex; align-items: center; }
.wn-canvas-frame {
    width: 100%;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: #fff;
    box-shadow: 0 40px 80px -30px rgba(0, 0, 0, 0.7);
}
.wn-canvas-chrome {
    display: flex; align-items: center; gap: 6px;
    padding: 0.6rem 0.85rem;
    background: #0f131b;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.wn-canvas-url {
    margin-left: 10px;
    font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
    font-size: 0.64rem; letter-spacing: 0.04em;
    color: rgba(247, 246, 242, 0.45);
    background: rgba(255, 255, 255, 0.06);
    padding: 0.2rem 0.7rem; border-radius: var(--wn-r-pill);
}
.wn-canvas-page {
    position: relative;
    background: #fff;
    padding: clamp(1rem, 2.2vw, 1.6rem);
    display: flex; flex-direction: column;
    gap: clamp(0.9rem, 2vw, 1.4rem);
    transition: filter 1500ms var(--wn-ease);
}
.wn-canvas.is-armed .wn-canvas-page { filter: grayscale(1) contrast(0.92); }
.wn-canvas.is-coloured .wn-canvas-page { filter: none; }

/* Lay-in for the structural blocks */
.wn-canvas.is-armed .wn-canvas-anim { opacity: 0; transform: translateY(16px); }
.wn-canvas.is-laid .wn-canvas-anim {
    opacity: 1; transform: none;
    transition: opacity 1000ms var(--wn-ease-out) var(--d), transform 1000ms var(--wn-ease-out) var(--d);
}

/* Top nav */
.wn-canvas-nav { display: flex; align-items: center; gap: 0.8rem; }
.wn-canvas-logo { width: 56px; height: 14px; border-radius: 5px; background: var(--wn-gradient); }
.wn-canvas-navlinks { display: flex; gap: 0.7rem; margin-left: auto; }
.wn-canvas-navlinks i { width: 34px; height: 7px; border-radius: 4px; background: rgba(14, 16, 20, 0.14); }
.wn-canvas-navbtn { width: 64px; height: 22px; border-radius: var(--wn-r-pill); background: var(--wn-ink); }

/* Hero */
.wn-canvas-hero { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(1rem, 2.5vw, 2rem); align-items: center; }
.wn-canvas-hero-copy { display: flex; flex-direction: column; gap: 0.7rem; }
.wn-canvas-eyebrow { width: 70px; height: 8px; border-radius: 4px; background: var(--wn-accent); }
.wn-canvas-h {
    margin: 0.2rem 0 0.3rem;
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 3.4vw, 2.4rem);
    font-weight: 700; line-height: 1.04; letter-spacing: -0.03em;
    color: var(--wn-ink);
    display: flex; flex-direction: column;
}
/* Headline is typed out character-by-character (design-canvas.js wraps each char
   in .t-ch). The gradient sits on the inner span so the whole word shares one
   gradient as the letters appear. clip-path is NOT used — it conflicts with
   background-clip:text and renders the text invisible in Chromium. min-height
   reserves each line so nothing shifts while it types. */
.wn-canvas-h-line { display: block; position: relative; min-height: 1.05em; }
.wn-canvas-h-line > span { display: inline; }
.wn-canvas-h-line.is-grad > span {
    background: var(--wn-gradient);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; color: transparent;
}
.wn-canvas.is-armed .wn-canvas-h .t-ch { display: none; }
.wn-canvas .wn-canvas-h .t-ch.is-typed { display: inline; }
/* Caret on the line currently typing — accent so it shows on the gradient line */
.wn-canvas.is-armed .wn-canvas-h-line.is-typing::after {
    content: ''; display: inline-block;
    width: 2px; height: 0.92em; margin-left: 0.05em; vertical-align: -0.08em;
    background: var(--wn-accent);
    animation: wn-frag-caret 0.9s steps(1, end) infinite;
}
.wn-canvas-txt { height: 8px; border-radius: 4px; background: rgba(14, 16, 20, 0.12); }
.wn-canvas-txt.is-1 { width: 92%; }
.wn-canvas-txt.is-2 { width: 68%; }
.wn-canvas-cta { display: flex; gap: 0.6rem; margin-top: 0.5rem; }
.wn-canvas-btn { height: 30px; border-radius: var(--wn-r-pill); }
.wn-canvas-btn.is-primary { width: 110px; background: var(--wn-gradient); }
.wn-canvas-btn.is-ghost { width: 84px; border: 1px solid var(--wn-line-strong); }
.wn-canvas-hero-media {
    height: clamp(120px, 18vw, 180px);
    border-radius: 12px;
    background:
        radial-gradient(circle at 30% 28%, rgba(0, 212, 255, 0.55), transparent 60%),
        linear-gradient(135deg, var(--wn-cyan), var(--wn-purple));
    box-shadow: 0 20px 40px -22px rgba(123, 97, 255, 0.5);
}

/* Feature row */
.wn-canvas-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.8rem; }
.wn-canvas-card {
    border: 1px solid var(--wn-line);
    border-radius: 10px;
    padding: 0.85rem;
    display: flex; flex-direction: column; gap: 0.5rem;
    background: var(--wn-bg-warm);
}
.wn-canvas-card-dot { width: 22px; height: 22px; border-radius: 50%; background: var(--wn-accent-tint); border: 1px solid rgba(2, 217, 255, 0.4); }
.wn-canvas-card i { height: 7px; border-radius: 4px; background: rgba(14, 16, 20, 0.12); }
.wn-canvas-card i:first-of-type { width: 82%; }
.wn-canvas-card i:last-of-type  { width: 54%; }

@media (max-width: 600px) {
    .wn-canvas-hero { grid-template-columns: 1fr; }
    .wn-canvas-cards { grid-template-columns: 1fr 1fr; }
}
@media (prefers-reduced-motion: reduce) {
    .wn-canvas.is-armed .wn-canvas-anim { opacity: 1; transform: none; }
    .wn-canvas.is-armed .wn-canvas-h .t-ch { display: inline; }
    .wn-canvas.is-armed .wn-canvas-page { filter: none; }
}

/* ─── AEO chat window (Answer Engine Optimisation signature) ─────────────
   A mock AI chat that types a question, "thinks", then streams a recommendation
   with Webnova picked out. aeo-chat.js stacks classes:
     is-armed                     → hide messages + every .t-ch character
     .wn-chat-msg.is-shown        → a message fades/scales in
     .wn-chat-thinking.is-active  → the thinking dots show
     .t-ch.is-typed               → a character appears (typed)
   Gated behind .is-armed so JS-off / reduced-motion show the finished
   conversation (no thinking dots). */
.wn-chat { position: relative; width: 100%; }
.wn-chat-window {
    display: flex; flex-direction: column;
    min-height: 460px;
    border-radius: var(--wn-r-lg);
    border: 1px solid rgba(255, 255, 255, 0.10);
    background: rgba(16, 20, 28, 0.72);
    backdrop-filter: blur(18px) saturate(1.3);
    box-shadow: 0 40px 80px -32px rgba(0, 0, 0, 0.75);
    overflow: hidden;
}
@media (prefers-reduced-transparency: reduce) {
    .wn-chat-window { background: rgba(16, 20, 28, 0.96); backdrop-filter: none; }
}

.wn-chat-head {
    display: flex; align-items: center; gap: 0.7rem;
    padding: 0.85rem 1.1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}
.wn-chat-avatar {
    flex: none; width: 34px; height: 34px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--wn-accent);
    background: rgba(2, 217, 255, 0.12);
    border: 1px solid rgba(2, 217, 255, 0.28);
}
.wn-chat-avatar svg { width: 18px; height: 18px; }
.wn-chat-avatar.is-sm { width: 28px; height: 28px; align-self: flex-start; }
.wn-chat-avatar.is-sm svg { width: 15px; height: 15px; }
.wn-chat-head-text { display: flex; flex-direction: column; line-height: 1.2; }
.wn-chat-head-name { font-size: 0.82rem; font-weight: 600; color: var(--wn-ink-inv); }
.wn-chat-head-status { font-size: 0.66rem; color: rgba(247, 246, 242, 0.45); display: inline-flex; align-items: center; gap: 0.35rem; }
.wn-chat-head-status::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: #19c27a; box-shadow: 0 0 0 2px rgba(25, 194, 122, 0.18);
}

.wn-chat-thread { flex: 1; display: flex; flex-direction: column; gap: 0.9rem; padding: 1.2rem 1.1rem; }
.wn-chat-msg { display: flex; gap: 0.6rem; max-width: 88%; }
.wn-chat-msg--user { align-self: flex-end; }
.wn-chat-msg--ai { align-self: flex-start; }
.wn-chat-bubble { font-size: 0.86rem; line-height: 1.5; padding: 0.7rem 0.95rem; border-radius: 16px; }
.wn-chat-msg--user .wn-chat-bubble {
    background: rgba(2, 217, 255, 0.14);
    border: 1px solid rgba(2, 217, 255, 0.22);
    color: var(--wn-ink-inv);
    border-bottom-right-radius: 5px;
}
.wn-chat-msg--ai .wn-chat-bubble {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: rgba(247, 246, 242, 0.82);
    border-bottom-left-radius: 5px;
}
.wn-chat-line { margin: 0; }
.wn-chat-line + .wn-chat-line { margin-top: 0.34rem; }
.wn-chat-line strong { font-weight: 600; color: var(--wn-ink-inv); }
.wn-chat-rank {
    display: inline-flex; align-items: center; justify-content: center;
    width: 1.15rem; height: 1.15rem; margin-right: 0.45rem;
    border-radius: 50%; font-size: 0.64rem; font-weight: 600;
    color: rgba(247, 246, 242, 0.6); background: rgba(255, 255, 255, 0.08);
    vertical-align: -0.2rem;
}
/* The pick — Webnova, in accent */
.wn-chat-line.is-pick {
    margin-left: -0.55rem; padding: 0.2rem 0.55rem;
    border-left: 2px solid var(--wn-accent);
    background: rgba(2, 217, 255, 0.08);
    border-radius: 0 8px 8px 0;
    color: var(--wn-ink-inv);
}
.wn-chat-line.is-pick strong { color: var(--wn-accent); }
.wn-chat-line.is-pick .wn-chat-rank { background: rgba(2, 217, 255, 0.2); color: var(--wn-accent); }

.wn-chat-thinking { display: none; }
.wn-chat-dots { display: inline-flex; align-items: center; gap: 5px; }
.wn-chat-dots i { width: 7px; height: 7px; border-radius: 50%; background: rgba(247, 246, 242, 0.5); animation: wn-chat-bounce 1.2s var(--wn-ease) infinite; }
.wn-chat-dots i:nth-child(2) { animation-delay: 0.15s; }
.wn-chat-dots i:nth-child(3) { animation-delay: 0.3s; }
@keyframes wn-chat-bounce { 0%, 60%, 100% { transform: translateY(0); opacity: 0.5; } 30% { transform: translateY(-4px); opacity: 1; } }

.wn-chat-input {
    display: flex; align-items: center; gap: 0.6rem;
    padding: 0.55rem 0.6rem; margin: 0 0.7rem 0.7rem;
    border-radius: var(--wn-r-pill);
    border: 1px solid rgba(255, 255, 255, 0.10);
    background: rgba(255, 255, 255, 0.04);
}
.wn-chat-input-field { flex: 1; font-size: 0.8rem; color: rgba(247, 246, 242, 0.4); padding-left: 0.5rem; }
.wn-chat-send {
    flex: none; width: 32px; height: 32px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--wn-accent); color: #06222b;
}
.wn-chat-send svg { width: 16px; height: 16px; }

/* Motion */
.wn-chat.is-armed .wn-chat-msg { opacity: 0; transform: translateY(10px) scale(0.98); }
.wn-chat.is-armed .wn-chat-msg.is-shown,
.wn-chat.is-armed .wn-chat-thinking.is-active {
    opacity: 1; transform: none;
    transition: opacity 380ms var(--wn-ease-out), transform 380ms var(--wn-ease-out);
}
.wn-chat.is-armed .wn-chat-thinking.is-active { display: flex; }
.wn-chat.is-armed .wn-chat-line .t-ch { display: none; }
.wn-chat .wn-chat-line .t-ch.is-typed { display: inline; }
.wn-chat.is-armed .wn-chat-line.is-typing::after {
    content: ''; display: inline-block;
    width: 2px; height: 0.95em; margin-left: 0.06em; vertical-align: -0.12em;
    background: var(--wn-accent);
    animation: wn-frag-caret 0.9s steps(1, end) infinite;
}

@media (prefers-reduced-motion: reduce) {
    .wn-chat.is-armed .wn-chat-msg { opacity: 1; transform: none; }
    .wn-chat.is-armed .wn-chat-line .t-ch { display: inline; }
    .wn-chat.is-armed .wn-chat-thinking { display: none; }
    .wn-chat.is-armed .wn-chat-line.is-typing::after { display: none; }
}

/* ─── Search-results climb (SEO signature) ───────────────────────────────
   A light mock search page: the query types in, results appear, then
   "Your Business" climbs from the bottom to #1 (rows are absolutely positioned;
   top = --row × --rowh, so changing --row animates the climb). serp-climb.js
   sets the pre-climb order, types the query, then restores the final --row and
   adds .is-top to the winning row. The highlight + meta are visible by DEFAULT
   (so JS-off / reduced-motion show the finished #1 state); .is-armed strips them
   for the pre-climb state and .is-top restores them on arrival. */
.wn-serp { position: relative; width: 100%; }
.wn-serp-card {
    background: #fff;
    border-radius: var(--wn-r-lg);
    border: 1px solid rgba(255, 255, 255, 0.10);
    box-shadow: 0 40px 80px -32px rgba(0, 0, 0, 0.75);
    padding: clamp(1.1rem, 2.4vw, 1.7rem);
}
.wn-serp-bar {
    display: flex; align-items: center; gap: 0.7rem;
    padding: 0.7rem 1rem;
    border-radius: var(--wn-r-pill);
    border: 1px solid var(--wn-line-strong);
    background: #fff;
    box-shadow: 0 1px 3px rgba(14, 16, 20, 0.06);
}
.wn-serp-bar-ic { color: var(--wn-accent); display: inline-flex; }
.wn-serp-bar-ic svg { width: 18px; height: 18px; }
.wn-serp-query { font-size: 0.95rem; color: var(--wn-ink); }
.wn-serp-stats { font-size: 0.72rem; color: var(--wn-ink-faint); margin: 0.9rem 0 0.5rem; }

.wn-serp-results { --rowh: 4.8rem; position: relative; height: calc(5 * var(--rowh)); }
.wn-serp-row {
    position: absolute; left: 0; right: 0;
    top: calc(var(--row) * var(--rowh));
    height: 4.3rem; overflow: hidden;
    display: flex; gap: 0.8rem; align-items: flex-start;
    padding: 0.5rem 0.6rem; border-radius: 12px;
}
.wn-serp-fav {
    flex: none; width: 24px; height: 24px; border-radius: 50%; margin-top: 0.15rem;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 0.7rem; font-weight: 600;
    background: rgba(14, 16, 20, 0.06); color: var(--wn-ink-muted);
}
.wn-serp-fav.is-you { background: var(--wn-accent); color: #06222b; }
.wn-serp-main { min-width: 0; flex: 1; display: flex; flex-direction: column; gap: 0.1rem; }
.wn-serp-url,
.wn-serp-title,
.wn-serp-desc { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wn-serp-url { font-size: 0.74rem; color: var(--wn-ink-muted); }
.wn-serp-title { font-size: 0.98rem; font-weight: 500; color: #1a56db; letter-spacing: -0.01em; }
.wn-serp-desc { font-size: 0.8rem; line-height: 1.4; color: var(--wn-ink-muted); }

.wn-serp-meta { flex: none; display: flex; flex-direction: column; align-items: flex-end; gap: 0.3rem; }
.wn-serp-pos { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; color: var(--wn-accent); line-height: 1; }
.wn-serp-gain {
    font-size: 0.66rem; font-weight: 600; color: #19c27a;
    background: rgba(25, 194, 122, 0.12); border-radius: var(--wn-r-pill); padding: 0.12rem 0.42rem;
}

/* Winning row highlight — visible by default (no-JS shows the finished state) */
.wn-serp-row.is-you { background: rgba(2, 217, 255, 0.07); box-shadow: inset 3px 0 0 var(--wn-accent); }

/* Motion */
.wn-serp.is-armed .wn-serp-row { opacity: 0; }
.wn-serp.is-armed .wn-serp-row.is-you { background: transparent; box-shadow: none; }
.wn-serp.is-armed .wn-serp-meta { opacity: 0; }
.wn-serp.is-shown .wn-serp-row {
    opacity: 1;
    transition: opacity 420ms var(--wn-ease) var(--d),
                top 600ms var(--wn-ease-out),
                background 500ms var(--wn-ease),
                box-shadow 500ms var(--wn-ease);
}
/* Highlight marks "Your Business" the moment it starts climbing, so it's easy to
   follow; the #1 / ▲4 meta only appears once it actually lands on top. */
.wn-serp.is-armed .wn-serp-row.is-you.is-climbing { background: rgba(2, 217, 255, 0.07); box-shadow: inset 3px 0 0 var(--wn-accent); }
.wn-serp.is-armed .wn-serp-row.is-you.is-top .wn-serp-meta { opacity: 1; transition: opacity 500ms var(--wn-ease) 200ms; }

.wn-serp.is-armed .wn-serp-q-text .t-ch { display: none; }
.wn-serp .wn-serp-q-text .t-ch.is-typed { display: inline; }
.wn-serp.is-armed .wn-serp-q-text.is-typing::after {
    content: ''; display: inline-block;
    width: 2px; height: 1em; margin-left: 1px; vertical-align: -0.15em;
    background: var(--wn-accent);
    animation: wn-frag-caret 0.9s steps(1, end) infinite;
}

@media (prefers-reduced-motion: reduce) {
    .wn-serp.is-armed .wn-serp-row { opacity: 1; }
    .wn-serp.is-armed .wn-serp-row.is-you { background: rgba(2, 217, 255, 0.07); box-shadow: inset 3px 0 0 var(--wn-accent); }
    .wn-serp.is-armed .wn-serp-meta { opacity: 1; }
    .wn-serp.is-armed .wn-serp-q-text .t-ch { display: inline; }
    .wn-serp.is-armed .wn-serp-q-text.is-typing::after { display: none; }
}

/* ─── Google Ads — paid result drops in on top (Google Ads signature) ─────
   Reuses the search-card visuals (.wn-serp-*) with a separate motion root
   (.wn-ads): the query types in, organic results appear, then the "Sponsored"
   ad for Your Business slides in from the top and pushes the organic results
   down — exactly how paid search works. ads-serp.js handles the timing. The
   finished ad-on-top state renders by default for JS-off / reduced-motion. */
.wn-ads { position: relative; width: 100%; }
.wn-ad-tag { font-weight: 700; color: var(--wn-ink); margin-right: 0.5rem; }

.wn-ads.is-armed .wn-serp-row { opacity: 0; }
.wn-ads.is-shown .wn-serp-row {
    opacity: 1;
    transition: opacity 480ms var(--wn-ease) var(--d), top 950ms var(--wn-ease-out);
}
/* The ad waits above, hidden, until it's "served" — then slides down into slot 0 */
.wn-ads.is-armed .wn-ad { opacity: 0; transform: translateY(-115%); }
.wn-ads.is-served .wn-ad {
    opacity: 1; transform: translateY(0);
    transition: opacity 720ms var(--wn-ease), transform 1100ms var(--wn-ease-out);
}

.wn-ads.is-armed .wn-serp-q-text .t-ch { display: none; }
.wn-ads .wn-serp-q-text .t-ch.is-typed { display: inline; }
.wn-ads.is-armed .wn-serp-q-text.is-typing::after {
    content: ''; display: inline-block;
    width: 2px; height: 1em; margin-left: 1px; vertical-align: -0.15em;
    background: var(--wn-accent);
    animation: wn-frag-caret 0.9s steps(1, end) infinite;
}

@media (prefers-reduced-motion: reduce) {
    .wn-ads.is-armed .wn-serp-row { opacity: 1; }
    .wn-ads.is-armed .wn-ad { opacity: 1; transform: none; }
    .wn-ads.is-armed .wn-serp-q-text .t-ch { display: inline; }
    .wn-ads.is-armed .wn-serp-q-text.is-typing::after { display: none; }
}

/* ─── Brand feed (Brand & Social signature) — consistency → recognition ────
   Varied posts cascade in mismatched (dull --off colour, askew), then snap into
   one identity (final --on colour, aligned, the same mark stamped on each), and
   a "Recognised" badge lands. brand-grid.js stages it: is-shown → is-branded →
   is-recognised. Final (branded) styles are the DEFAULT so JS-off / reduced-
   motion render the finished, consistent feed; .is-armed reverts to the
   mismatched pre-brand state. */
.wn-brand { position: relative; width: 100%; }
.wn-brand-card {
    background: #fff;
    border-radius: var(--wn-r-lg);
    border: 1px solid rgba(255, 255, 255, 0.10);
    box-shadow: 0 40px 80px -32px rgba(0, 0, 0, 0.75);
    padding: clamp(1.2rem, 2.6vw, 1.8rem);
}

/* Header — the constant brand avatar (the "remembered image") */
.wn-brand-head { display: flex; align-items: center; gap: 0.8rem; margin-bottom: 1.2rem; }
.wn-brand-avatar {
    flex: none; width: 44px; height: 44px; border-radius: 13px;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--wn-gradient); color: #fff;
}
.wn-brand-avatar svg { width: 22px; height: 22px; }
.wn-brand-id { display: flex; flex-direction: column; line-height: 1.25; }
.wn-brand-handle { font-size: 0.95rem; font-weight: 600; color: var(--wn-ink); }
.wn-brand-sub { font-size: 0.74rem; color: var(--wn-ink-muted); }
.wn-brand-badge {
    margin-left: auto;
    display: inline-flex; align-items: center; gap: 0.35rem;
    font-size: 0.72rem; font-weight: 600;
    color: var(--wn-accent);
    background: rgba(2, 217, 255, 0.10);
    border: 1px solid rgba(2, 217, 255, 0.25);
    padding: 0.28rem 0.6rem; border-radius: var(--wn-r-pill);
}
.wn-brand-badge svg { width: 13px; height: 13px; }

/* Grid of posts */
.wn-brand-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.7rem; }
.wn-brand-post {
    position: relative; aspect-ratio: 1 / 1;
    border-radius: 14px; overflow: hidden;
    display: flex; align-items: center; justify-content: center;
    background-color: var(--on); color: #fff;
    box-shadow: 0 10px 24px -16px rgba(14, 16, 20, 0.5);
}
.wn-brand-post-ic { display: inline-flex; opacity: 0.95; }
.wn-brand-post-ic svg { width: 38px; height: 38px; }
.wn-brand-post-logo {
    position: absolute; bottom: 8px; right: 8px;
    width: 19px; height: 19px; border-radius: 50%;
    background: #fff; color: var(--wn-accent);
    display: inline-flex; align-items: center; justify-content: center;
    box-shadow: 0 2px 6px rgba(14, 16, 20, 0.25);
}
.wn-brand-post-logo svg { width: 11px; height: 11px; }

/* ── Motion ── */
/* Pre-brand: dull mismatched colour, askew, no mark */
.wn-brand.is-armed .wn-brand-post { opacity: 0; background-color: var(--off); transform: translateY(12px) rotate(var(--jit)); }
.wn-brand.is-armed .wn-brand-post-logo { opacity: 0; transform: scale(0.4); }
.wn-brand.is-armed .wn-brand-badge { opacity: 0; transform: translateY(-4px); }

/* Cascade in (still mismatched) */
.wn-brand.is-shown .wn-brand-post {
    opacity: 1; transform: translateY(0) rotate(var(--jit));
    transition: opacity 1840ms var(--wn-ease) var(--d), transform 1840ms var(--wn-ease-out) var(--d);
}
/* Snap into one identity — unified colour, aligned, mark stamped (wave via --bd) */
.wn-brand.is-branded .wn-brand-post {
    background-color: var(--on); transform: translateY(0) rotate(0deg);
    transition: background-color 3040ms var(--wn-ease) var(--bd), transform 2560ms var(--wn-ease-out) var(--bd);
}
.wn-brand.is-branded .wn-brand-post-logo {
    opacity: 1; transform: scale(1);
    transition: opacity 1520ms var(--wn-ease) calc(var(--bd) + 0.88s), transform 1680ms var(--wn-ease-out) calc(var(--bd) + 0.88s);
}
/* Recognised — badge lands, avatar gets a soft ring */
.wn-brand.is-recognised .wn-brand-badge { opacity: 1; transform: none; transition: opacity 1680ms var(--wn-ease), transform 1680ms var(--wn-ease-out); }
.wn-brand.is-recognised .wn-brand-avatar { box-shadow: 0 0 0 4px rgba(2, 217, 255, 0.18); transition: box-shadow 2400ms var(--wn-ease); }

@media (prefers-reduced-motion: reduce) {
    .wn-brand.is-armed .wn-brand-post { opacity: 1; background-color: var(--on); transform: none; }
    .wn-brand.is-armed .wn-brand-post-logo { opacity: 1; transform: none; }
    .wn-brand.is-armed .wn-brand-badge { opacity: 1; transform: none; }
}

/* ─── Hosting hub (Web & Application Hosting signature) — always-on radial ──
   A server core with dotted spokes to six service nodes; packets pulse outward
   and each node lights as its packet arrives, while the core emits heartbeat
   rings. Pure CSS, loops forever (hosting never stops). Geometry: SVG viewBox
   0..400 lines up with HTML nodes positioned by % of the same square box.
   The reduced-motion query hides the packets/rings for a clean static diagram. */
.wn-hub { position: relative; width: 100%; max-width: 440px; margin-inline: auto; aspect-ratio: 1 / 1; }
.wn-hub-wires { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.wn-hub-spoke { stroke: rgba(247, 246, 242, 0.16); stroke-width: 1.4; stroke-dasharray: 1.5 7; stroke-linecap: round; }
.wn-hub-packet {
    fill: var(--wn-accent);
    filter: drop-shadow(0 0 4px var(--wn-accent));
    animation: wn-hub-packet 2.4s linear infinite;
    animation-delay: calc(var(--i) * 0.4s);
}
@keyframes wn-hub-packet {
    0%   { transform: translate(0, 0); opacity: 0; }
    12%  { opacity: 1; }
    80%  { opacity: 1; }
    100% { transform: translate(var(--tx), var(--ty)); opacity: 0; }
}

/* Core */
.wn-hub-core {
    position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
    z-index: 3; display: flex; flex-direction: column; align-items: center; gap: 0.55rem;
}
.wn-hub-core-box {
    position: relative; width: 74px; height: 74px; border-radius: 18px;
    display: flex; align-items: center; justify-content: center; color: #fff;
    background: linear-gradient(135deg, rgba(0, 212, 255, 0.20), rgba(123, 97, 255, 0.20));
    border: 1px solid rgba(255, 255, 255, 0.18);
    box-shadow: 0 0 34px -6px rgba(0, 212, 255, 0.45);
    backdrop-filter: blur(6px);
}
.wn-hub-core-box svg { position: relative; z-index: 1; width: 34px; height: 34px; }
.wn-hub-core-box::after {
    content: ''; position: absolute; top: 9px; right: 9px;
    width: 8px; height: 8px; border-radius: 50%; background: #19c27a; z-index: 2;
    box-shadow: 0 0 0 3px rgba(25, 194, 122, 0.22);
    animation: wn-hub-blink 2s ease-out infinite;
}
@keyframes wn-hub-blink {
    0%   { box-shadow: 0 0 0 0 rgba(25, 194, 122, 0.45); }
    70%  { box-shadow: 0 0 0 6px rgba(25, 194, 122, 0); }
    100% { box-shadow: 0 0 0 0 rgba(25, 194, 122, 0); }
}
.wn-hub-ring {
    position: absolute; left: 50%; top: 50%; width: 74px; height: 74px;
    border-radius: 50%; border: 1px solid var(--wn-accent);
    transform: translate(-50%, -50%) scale(0.55); opacity: 0;
    animation: wn-hub-ring 3.3s ease-out infinite;
}
.wn-hub-ring:nth-child(2) { animation-delay: 1.1s; }
.wn-hub-ring:nth-child(3) { animation-delay: 2.2s; }
@keyframes wn-hub-ring {
    0%   { transform: translate(-50%, -50%) scale(0.55); opacity: 0.5; }
    100% { transform: translate(-50%, -50%) scale(2.5); opacity: 0; }
}
.wn-hub-status {
    display: inline-flex; align-items: center; gap: 0.4rem;
    font-size: 0.64rem; letter-spacing: 0.12em; text-transform: uppercase;
    color: rgba(247, 246, 242, 0.55); white-space: nowrap;
}
.wn-hub-status-dot { width: 6px; height: 6px; border-radius: 50%; background: #19c27a; }

/* Nodes */
.wn-hub-node {
    position: absolute; transform: translate(-50%, -50%); z-index: 2;
    display: flex; flex-direction: column; align-items: center; gap: 0.45rem;
}
.wn-hub-node-ic {
    width: 48px; height: 48px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    background: rgba(20, 25, 34, 0.6); border: 1px solid rgba(247, 246, 242, 0.14);
    color: var(--wn-accent-soft); backdrop-filter: blur(6px);
    animation: wn-hub-node 2.4s ease-in-out infinite;
    animation-delay: calc(var(--i) * 0.4s);
}
.wn-hub-node-ic svg { width: 22px; height: 22px; }
.wn-hub-node-label { font-size: 0.72rem; font-weight: 500; color: rgba(247, 246, 242, 0.72); white-space: nowrap; }
@keyframes wn-hub-node {
    0%, 84%, 100% { border-color: rgba(247, 246, 242, 0.14); color: var(--wn-accent-soft); box-shadow: none; transform: scale(1); }
    94%           { border-color: var(--wn-accent); color: #fff; box-shadow: 0 0 18px -2px rgba(0, 212, 255, 0.6); transform: scale(1.07); }
}

@media (prefers-reduced-motion: reduce) {
    .wn-hub-packet, .wn-hub-ring { display: none; }
    .wn-hub-node-ic { border-color: rgba(0, 212, 255, 0.4); color: var(--wn-accent-soft); }
}

/* ─── Mid-page CTA band — accent-tinted band, frosted glass box ─── */
.wn-ctamid {
    padding: clamp(6rem, 12vw, 10rem) 0;
    background:
        radial-gradient(ellipse at 12% 18%, rgba(var(--svc-accent-rgb), 0.20), transparent 58%),
        radial-gradient(ellipse at 88% 84%, rgba(123, 97, 255, 0.18), transparent 58%),
        linear-gradient(135deg, rgba(var(--svc-accent-rgb), 0.12), rgba(123, 97, 255, 0.12));
}
.wn-ctamid-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem 2.5rem;
    flex-wrap: wrap;
    padding: clamp(2rem, 4vw, 2.8rem) clamp(2rem, 4vw, 3.2rem);
    border-radius: var(--wn-r-lg);
    border: 1px solid var(--wn-glass-border);
    background: var(--wn-glass-bg);
    -webkit-backdrop-filter: blur(22px) saturate(1.6);
    backdrop-filter: blur(22px) saturate(1.6);
    box-shadow: var(--wn-glass-shadow);
}
@media (prefers-reduced-transparency: reduce) {
    .wn-ctamid-inner { background: var(--wn-glass-bg-strong); -webkit-backdrop-filter: none; backdrop-filter: none; }
}
.wn-ctamid-text {
    font-size: clamp(1.3rem, 2.2vw, 1.9rem);
    font-weight: 300;
    letter-spacing: -0.025em;
    line-height: 1.25;
    color: var(--wn-ink);
    margin: 0;
    max-width: 32ch;
}
.wn-ctamid-btn { flex-shrink: 0; }

/* ─── Single testimonial (pull-quote) ───────────────────── */
.wn-svcquote-inner { max-width: 56rem; margin: 0 auto; text-align: center; }
.wn-svcquote-mark { width: 38px; height: 38px; display: block; margin: 0 auto 1.4rem; color: var(--svc-accent); opacity: 0.55; }
.wn-svcquote-text {
    font-size: clamp(1.45rem, 2.8vw, 2.25rem);
    font-weight: 300;
    line-height: 1.4;
    letter-spacing: -0.02em;
    color: var(--wn-ink);
    margin: 0 0 1.8rem;
}
.wn-svcquote-cite { display: flex; flex-direction: column; gap: 0.2rem; }
.wn-svcquote-name { font-weight: 600; color: var(--wn-ink); }
.wn-svcquote-role { font-size: 0.9rem; color: var(--wn-ink-muted); }

/* ─── Offer anchor — dark accent-aurora band, dark-glass card ─── */
.wn-offer {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(ellipse at 16% 14%, rgba(var(--svc-accent-rgb), 0.18), transparent 55%),
        radial-gradient(ellipse at 84% 86%, rgba(123, 97, 255, 0.16), transparent 55%),
        linear-gradient(180deg, var(--wn-bg-dark) 0%, #0a0d14 100%);
}
.wn-offer-card {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem 3rem;
    flex-wrap: wrap;
    padding: clamp(2.4rem, 4vw, 3.4rem);
    border-radius: var(--wn-r-xl);
    background: var(--wn-glass-bg-dark);
    color: var(--wn-ink-inv);
    border: 1px solid var(--wn-glass-border-dark);
    -webkit-backdrop-filter: blur(22px) saturate(1.4);
    backdrop-filter: blur(22px) saturate(1.4);
    box-shadow: var(--wn-glass-shadow-dark);
}
@media (prefers-reduced-transparency: reduce) {
    .wn-offer-card { background: rgba(16, 20, 28, 0.96); -webkit-backdrop-filter: none; backdrop-filter: none; }
}
.wn-offer-glow {
    position: absolute;
    top: -40%; right: -10%;
    width: 420px; height: 420px;
    border-radius: 50%;
    filter: blur(70px);
    background: radial-gradient(circle, rgba(var(--svc-accent-rgb), 0.22) 0%, transparent 70%);
    pointer-events: none;
}
.wn-offer-body { position: relative; z-index: 1; }
.wn-offer-eyebrow {
    font-size: var(--wn-t-label);
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--svc-accent);
    margin: 0;
}
.wn-offer-title {
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    font-weight: 300;
    letter-spacing: -0.03em;
    line-height: 1.1;
    color: var(--wn-ink-inv);
    margin: 0.7rem 0 0;
    max-width: 22ch;
}
.wn-offer-line { font-size: var(--wn-t-lead); font-weight: 300; color: var(--wn-ink-inv-muted); margin: 0.9rem 0 0; max-width: 44ch; }
.wn-offer-action { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: flex-start; gap: 0.7rem; }
.wn-offer-card .wn-btn-primary { background: var(--wn-ink-inv); color: var(--wn-ink); }
.wn-offer-card .wn-btn-primary:hover { filter: brightness(1.05); }
.wn-offer-note { font-size: 0.82rem; color: rgba(247, 246, 242, 0.4); margin: 0; }
.wn-offer-note a { color: var(--wn-ink-inv-muted); border-bottom: 1px solid var(--wn-line-inv); padding-bottom: 1px; }
.wn-offer-note a:hover { color: var(--wn-ink-inv); }

/* ─── Responsive (library) ──────────────────────────────── */
@media (max-width: 1024px) {
    .wn-sig-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .wn-sig-stage { min-height: 380px; }
    .wn-frag { min-height: 380px; }
}
@media (max-width: 720px) {
    /* Stack the interface fragment into clean, non-overlapping panels */
    .wn-frag { display: flex; flex-direction: column; gap: 0.9rem; min-height: 0; height: auto; }
    .wn-frag-panel { position: static; width: 100%; }
    .wn-frag-cards { flex-direction: row; }
    .wn-frag-metric { flex: 1; }
    .wn-sig-stage { min-height: 0; }

    .wn-proof-grid { grid-template-columns: 1fr; }

    .wn-ctamid-inner { flex-direction: column; align-items: flex-start; }
    .wn-offer-card { flex-direction: column; align-items: flex-start; }
    .wn-offer-action { width: 100%; }
}

/* ============================================================
   SIGNATURE — AI & Automation pipeline (includes/.../signatures/ai-pipeline.php)
   "Tasks doing themselves": email → classified → drafted → approved.
   Nodes light in sequence, a packet travels the connectors. Pure CSS loop;
   reduced-motion shows every node finished (static).
   ============================================================ */
.wn-pipe {
    display: flex;
    align-items: stretch;
    gap: 0;
    width: 100%;
}
.wn-pipe-node {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.6rem;
    padding: 1.1rem 0.6rem;
    border-radius: var(--wn-r-md);
    border: 1px solid rgba(255, 255, 255, 0.10);
    background: rgba(255, 255, 255, 0.03);
    transition: border-color var(--wn-t-med) var(--wn-ease), background var(--wn-t-med) var(--wn-ease);
    animation: wn-pipe-node 6.4s calc(var(--i) * 1.6s) infinite;
}
.wn-pipe-ic {
    width: 44px; height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: rgba(247, 246, 242, 0.55);
    background: rgba(255, 255, 255, 0.03);
    transition: color var(--wn-t-med) var(--wn-ease), border-color var(--wn-t-med) var(--wn-ease), box-shadow var(--wn-t-med) var(--wn-ease);
}
.wn-pipe-ic svg { width: 22px; height: 22px; }
.wn-pipe-text { display: flex; flex-direction: column; gap: 0.15rem; }
.wn-pipe-label { font-family: var(--font-display), sans-serif; font-size: 0.92rem; font-weight: 500; color: var(--wn-ink-inv); letter-spacing: -0.01em; }
.wn-pipe-sub { font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(247, 246, 242, 0.4); }
.wn-pipe-tick {
    position: relative;
    width: 7px; height: 7px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.16);
    transition: background var(--wn-t-med) var(--wn-ease), box-shadow var(--wn-t-med) var(--wn-ease);
}

/* connector + travelling packet */
.wn-pipe-link {
    position: relative;
    flex: 0 0 clamp(1.5rem, 4vw, 3.5rem);
    align-self: center;
    height: 2px;
    margin: 0 0.2rem;
    background: rgba(255, 255, 255, 0.12);
    border-radius: 2px;
}
.wn-pipe-packet {
    position: absolute;
    top: 50%;
    left: 0;
    width: 8px; height: 8px;
    margin-top: -4px;
    border-radius: 50%;
    background: var(--svc-accent);
    box-shadow: 0 0 10px 1px rgba(var(--svc-accent-rgb), 0.7);
    opacity: 0;
    animation: wn-pipe-packet 6.4s calc(var(--i) * 1.6s + 1.05s) infinite;
}
.wn-pipe-caption {
    margin: 1.8rem 0 0;
    font-size: 0.92rem;
    font-weight: 300;
    line-height: 1.5;
    color: var(--wn-ink-inv-muted);
    max-width: 46ch;
}

/* active node (its slice of the cycle) */
@keyframes wn-pipe-node {
    0%, 100% { border-color: rgba(255, 255, 255, 0.10); background: rgba(255, 255, 255, 0.03); }
    3%       { border-color: var(--svc-accent); background: rgba(var(--svc-accent-rgb), 0.08); }
    22%      { border-color: var(--svc-accent); background: rgba(var(--svc-accent-rgb), 0.08); }
    28%      { border-color: rgba(255, 255, 255, 0.10); background: rgba(255, 255, 255, 0.03); }
}
.wn-pipe-node { animation-name: wn-pipe-node; }
/* drive the icon + tick from the same cadence */
.wn-pipe-node .wn-pipe-ic { animation: wn-pipe-ic 6.4s calc(var(--i) * 1.6s) infinite; }
@keyframes wn-pipe-ic {
    0%, 100% { color: rgba(247, 246, 242, 0.55); border-color: rgba(255, 255, 255, 0.12); box-shadow: none; }
    3%, 22%  { color: var(--svc-accent); border-color: var(--svc-accent); box-shadow: 0 0 18px -2px rgba(var(--svc-accent-rgb), 0.55); }
    28%      { color: rgba(247, 246, 242, 0.55); border-color: rgba(255, 255, 255, 0.12); box-shadow: none; }
}
.wn-pipe-node .wn-pipe-tick { animation: wn-pipe-tick 6.4s calc(var(--i) * 1.6s) infinite; }
@keyframes wn-pipe-tick {
    0%, 100% { background: rgba(255, 255, 255, 0.16); box-shadow: none; }
    3%, 22%  { background: var(--svc-accent); box-shadow: 0 0 8px 0 rgba(var(--svc-accent-rgb), 0.7); }
    28%      { background: rgba(255, 255, 255, 0.16); box-shadow: none; }
}
/* the final node resolves to green (done/sent) */
.wn-pipe-node.is-done .wn-pipe-ic { animation-name: wn-pipe-ic-done; }
.wn-pipe-node.is-done .wn-pipe-tick { animation-name: wn-pipe-tick-done; }
@keyframes wn-pipe-ic-done {
    0%, 100% { color: rgba(247, 246, 242, 0.55); border-color: rgba(255, 255, 255, 0.12); box-shadow: none; }
    3%, 22%  { color: #19c27a; border-color: #19c27a; box-shadow: 0 0 18px -2px rgba(25, 194, 122, 0.55); }
    28%      { color: rgba(247, 246, 242, 0.55); border-color: rgba(255, 255, 255, 0.12); box-shadow: none; }
}
@keyframes wn-pipe-tick-done {
    0%, 100% { background: rgba(255, 255, 255, 0.16); box-shadow: none; }
    3%, 22%  { background: #19c27a; box-shadow: 0 0 8px 0 rgba(25, 194, 122, 0.7); }
    28%      { background: rgba(255, 255, 255, 0.16); box-shadow: none; }
}
@keyframes wn-pipe-packet {
    0%, 100% { opacity: 0; left: 0; }
    1%       { opacity: 1; left: 0; }
    11%      { opacity: 1; left: 100%; }
    13%      { opacity: 0; left: 100%; }
}

/* Static fallback — no JS-free issue (CSS only), but stop the loop for
   reduced motion and present the whole pipeline as finished. */
@media (prefers-reduced-motion: reduce) {
    .wn-pipe-node, .wn-pipe-node .wn-pipe-ic, .wn-pipe-node .wn-pipe-tick, .wn-pipe-packet { animation: none !important; }
    .wn-pipe-node { border-color: var(--svc-accent); background: rgba(var(--svc-accent-rgb), 0.07); }
    .wn-pipe-ic { color: var(--svc-accent); border-color: var(--svc-accent); }
    .wn-pipe-tick { background: var(--svc-accent); }
    .wn-pipe-node.is-done .wn-pipe-ic { color: #19c27a; border-color: #19c27a; }
    .wn-pipe-node.is-done .wn-pipe-tick { background: #19c27a; }
}

@media (max-width: 760px) {
    .wn-pipe { flex-direction: column; align-items: stretch; }
    .wn-pipe-node { flex-direction: row; justify-content: flex-start; text-align: left; gap: 0.9rem; padding: 0.9rem 1rem; }
    .wn-pipe-text { align-items: flex-start; }
    .wn-pipe-tick { margin-left: auto; }
    .wn-pipe-link { flex: 0 0 1.6rem; width: 2px; height: 1.6rem; align-self: center; margin: 0.1rem 0; }
    .wn-pipe-packet { left: 50%; top: 0; margin: 0 0 0 -4px; animation-name: wn-pipe-packet-v; }
    @keyframes wn-pipe-packet-v {
        0%, 100% { opacity: 0; top: 0; }
        1%       { opacity: 1; top: 0; }
        11%      { opacity: 1; top: 100%; }
        13%      { opacity: 0; top: 100%; }
    }
}

/* ============================================================
   PRICING TIERS (includes/.../pricing-tiers.php)
   Dark band, three glass cards; middle tier raised + accent-bordered.
   Used where a service has honest multi-tier pricing (e.g. Google Ads).
   ============================================================ */
.wn-pricing { position: relative; overflow: hidden; }
.wn-pricing-glow { position: absolute; border-radius: 50%; filter: blur(70px); pointer-events: none; z-index: 0; }
.wn-pricing-glow.is-1 { top: -120px; left: 8%; width: 460px; height: 460px; background: radial-gradient(circle, rgba(var(--svc-accent-rgb), 0.16), transparent 70%); }
.wn-pricing-glow.is-2 { bottom: -140px; right: 6%; width: 400px; height: 400px; background: radial-gradient(circle, rgba(123, 97, 255, 0.14), transparent 70%); }
.wn-pricing .wn-container { position: relative; z-index: 1; }

.wn-pricing-head { text-align: center; align-items: center; max-width: none; margin-bottom: clamp(2.6rem, 5vw, 3.6rem); }
.wn-pricing-head .wn-section-eyebrow { justify-content: center; }
.wn-pricing-head .wn-section-title { max-width: none; }

/* Management-only note — a trust signal, kept at readable size */
.wn-pricing-note {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    justify-content: center;
    max-width: 64ch;
    margin: clamp(2.4rem, 5vw, 3.4rem) auto 0;
    padding: 0.9rem 1.2rem;
    border: 1px solid var(--wn-line-inv);
    border-radius: var(--wn-r-pill);
    font-size: 0.95rem;
    font-weight: 300;
    line-height: 1.5;
    color: var(--wn-ink-inv-muted);
}
.wn-pricing-note svg { width: 20px; height: 20px; color: var(--svc-accent); flex-shrink: 0; }
.wn-pricing-note span strong { color: var(--wn-ink-inv); font-weight: 500; }

.wn-pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.4rem;
    align-items: stretch;
}
.wn-tier {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 2.4rem 1.9rem;
    border-radius: var(--wn-r-lg);
    border: 1px solid var(--wn-glass-border-dark);
    background: var(--wn-glass-bg-dark);
    -webkit-backdrop-filter: blur(22px) saturate(1.4);
    backdrop-filter: blur(22px) saturate(1.4);
    box-shadow: var(--wn-glass-shadow-dark);
}
.wn-tier.is-popular {
    border-color: var(--svc-accent);
    box-shadow: var(--wn-glass-shadow-dark), 0 30px 70px -28px rgba(var(--svc-accent-rgb), 0.32);
}
@media (prefers-reduced-transparency: reduce) {
    .wn-tier { background: rgba(16, 20, 28, 0.96); -webkit-backdrop-filter: none; backdrop-filter: none; }
}
.wn-tier-badge {
    position: absolute;
    top: -13px; left: 50%;
    transform: translateX(-50%);
    padding: 0.32rem 0.95rem;
    border-radius: var(--wn-r-pill);
    background: var(--svc-accent);
    color: #06222a;
    font-family: var(--font-display), sans-serif;
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    white-space: nowrap;
}
.wn-tier-name {
    font-family: var(--font-display), sans-serif;
    font-size: 1.15rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    color: var(--wn-ink-inv);
    margin: 0 0 1rem;
}
.wn-tier-price { display: flex; align-items: baseline; flex-wrap: wrap; margin: 0 0 0.9rem; }
.wn-tier-prefix { font-size: 0.85rem; font-weight: 400; color: var(--wn-ink-inv-muted); margin-right: 0.4rem; }
.wn-tier-amt {
    font-family: var(--font-display), sans-serif;
    font-size: clamp(2.2rem, 3.4vw, 2.7rem);
    font-weight: 300;
    letter-spacing: -0.03em;
    line-height: 1;
    color: var(--wn-ink-inv);
}
.wn-tier-per { font-size: 0.9rem; font-weight: 300; color: var(--wn-ink-inv-muted); margin-left: 0.2rem; }
.wn-tier-desc {
    font-size: 0.9rem;
    font-weight: 300;
    line-height: 1.55;
    color: var(--wn-ink-inv-muted);
    margin: 0 0 1.4rem;
}
.wn-tier-div { height: 1px; background: var(--wn-line-inv); margin: 0 0 1.4rem; }
.wn-tier-leadin { font-size: 0.82rem; font-weight: 500; color: var(--wn-ink-inv); margin: 0 0 0.9rem; }
.wn-tier-feats { list-style: none; margin: 0 0 1.8rem; padding: 0; display: flex; flex-direction: column; gap: 0.7rem; flex: 1; }
.wn-tier-feats li { display: flex; gap: 0.6rem; font-size: 0.9rem; font-weight: 300; line-height: 1.5; color: var(--wn-ink-inv-muted); }
.wn-tier-check { flex-shrink: 0; margin-top: 2px; color: var(--svc-accent); }
.wn-tier-check svg { width: 16px; height: 16px; display: block; }
.wn-tier-cta {
    width: 100%;
    justify-content: center;
    margin-top: auto;
    background: transparent;
    border: 1px solid var(--wn-line-inv-strong, rgba(247, 246, 242, 0.20));
    color: var(--wn-ink-inv);
}
.wn-tier-cta:hover { background: rgba(247, 246, 242, 0.08); }
.wn-tier.is-popular .wn-tier-cta { background: var(--wn-ink-inv); color: var(--wn-ink); border-color: transparent; }
.wn-tier.is-popular .wn-tier-cta:hover { filter: brightness(1.05); background: var(--wn-ink-inv); }

.wn-pricing-closing {
    text-align: center;
    max-width: 52ch;
    text-wrap: balance;
    margin: clamp(2.6rem, 5vw, 3.6rem) auto 0;
    font-size: clamp(1.5rem, 2.6vw, 2.1rem);
    font-weight: 300;
    letter-spacing: -0.025em;
    line-height: 1.3;
    color: var(--wn-ink-inv);
}

@media (max-width: 1024px) {
    .wn-pricing-grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; gap: 1.6rem; }
    .wn-tier.is-popular { transform: none; }
    .wn-tier.is-popular { margin: 0.6rem 0; }
}
