/*
Theme Name: Thinking ForWord Home Focus
Theme URI: https://thinkingforword.com/
Author: Thinking ForWord Team
Author URI: https://thinkingforword.com/
Description: A theme focused on the home page design, supporting separate pages.
Version: 5.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: thinking-forward-homefocus
*/

/* ═══════════════════════════════════════════════
   PART 1: GLOBAL & NEW HOMEPAGE STYLES (v5.0)
   ═══════════════════════════════════════════════ */

:root {
    --ink: #0d1f33;
    --navy: #12344f;
    --slate: #1e4a6e;
    --blue: #1a6db5;
    --sky: #4da3ff;
    --teal: #10b894;
    --teal-bright: #34efca;
    --mint: #d1fae5;
    --cream: #ffffff;
    --warm: #f7f9fc;
    --sand: #e2eaf2;
    --text: #1a1a2e;
    --text-mid: #3d4f63;
    --text-soft: #5f7389;
    --white: #ffffff;
    --accent: #ff6b35;
    --display: 'Playfair Display', Georgia, serif;
    --sans: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body {
    font-family: var(--sans); color: var(--text); line-height:1.7;
    background: var(--white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    padding-top: 96px; /* space for fixed header */
}

/* Grain overlay */
body::after {
    content:''; position:fixed; inset:0; z-index:10000; pointer-events:none;
    opacity:.15;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
}

::selection { background:rgba(16,184,148,.2); }
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--white); }
::-webkit-scrollbar-thumb { background:var(--navy); border-radius:3px; }

a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }

.container { max-width:1320px; margin:0 auto; padding:0 3rem; }

/* ═══ ANIMATIONS ═══ */
@keyframes fadeUp { from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn { from{opacity:0}to{opacity:1} }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)} }
@keyframes orbFloat {
    0%,100% { transform:translate(0,0) scale(1); }
    33% { transform:translate(30px,-40px) scale(1.05); }
    66% { transform:translate(-20px,30px) scale(.95); }
}
@keyframes glow { 0%,100%{opacity:.4}50%{opacity:.8} }

/* ═══ HEADER ═══ */
.hdr {
    position:fixed; top:0; left:0; right:0; z-index:999;
    padding:1.75rem 3rem;
    display:flex; justify-content:space-between; align-items:center;
    background:rgba(255,255,255,.95); backdrop-filter:blur(24px) saturate(1.6);
    border-bottom:1px solid rgba(0,0,0,.06);
    transition:all .3s;
}
.hdr-logo {
    display:flex; align-items:center; gap:.75rem;
    font-weight:800; font-size:1.75rem; color:var(--navy);
    letter-spacing:-.03em; text-decoration:none;
}
.hdr-logo img { height:48px; width:auto; }
.hdr-nav { display:flex; align-items:center; gap:2.5rem; list-style:none; }
.hdr-nav a {
    font-size:1.05rem; font-weight:600; color:var(--text-mid);
    transition:color .2s; letter-spacing:.01em; text-decoration:none;
}
.hdr-nav a:hover { color:var(--ink); }
.hdr-cta {
    background:linear-gradient(135deg,#10b894,#0dd4a8); color:#fff!important; padding:.85rem 2rem;
    border-radius:8px; font-weight:700; font-size:1rem;
    transition:all .2s; letter-spacing:.02em; box-shadow:0 3px 12px rgba(16,184,148,.3);
}
.hdr-cta:hover { background:linear-gradient(135deg,#12cca3,#10e4b4); transform:translateY(-1px); box-shadow:0 6px 20px rgba(16,184,148,.35); }

/* Mobile nav toggle */
.nav-toggle { display:none; width:40px; height:32px; border:0; background:transparent; padding:0; margin-left:auto; cursor:pointer; position:relative; z-index:1001; }
.nav-toggle .bar { display:block; height:3px; margin:6px 0; background:var(--navy); transition:transform .2s ease, opacity .2s ease; border-radius:2px; }

@media (max-width:900px) {
    .nav-toggle { display:inline-block; }
    .hdr { padding:1.25rem 1.5rem; }
    .hdr-logo { font-size:1.4rem; }
    .hdr-logo img { height:38px; }
    .hdr-nav {
        position:fixed; top:0; right:-100%; width:280px; height:100vh;
        background:#fff; flex-direction:column; gap:0;
        padding:5rem 1.5rem 2rem; box-shadow:-8px 0 24px rgba(0,0,0,.1);
        transition:right .3s ease; z-index:1000;
    }
    .hdr-nav.open { right:0; }
    .hdr-nav li { width:100%; }
    .hdr-nav a { padding:.9rem 0; display:block; border-bottom:1px solid rgba(0,0,0,.04); font-size:1rem; }
    .hdr-cta { text-align:center; margin-top:1rem; display:block; }
    html.nav-open { overflow:hidden; }
    .nav-toggle[aria-expanded="true"] .bar:nth-child(1) { transform:translateY(9px) rotate(45deg); }
    .nav-toggle[aria-expanded="true"] .bar:nth-child(2) { opacity:0; }
    .nav-toggle[aria-expanded="true"] .bar:nth-child(3) { transform:translateY(-9px) rotate(-45deg); }
}

/* ═══ HERO ═══ */
.hero {
    position:relative; overflow:hidden;
    padding:6rem 2.5rem 6rem;
    background:var(--ink); color:#fff;
    min-height:calc(100vh - 96px); display:flex; align-items:center;
}
.hero::after {
    content:''; position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
        linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
    background-size:80px 80px;
}
.hero-orb {
    position:absolute; border-radius:50%; filter:blur(100px);
    animation:orbFloat 12s ease-in-out infinite;
}
.hero-orb--1 { width:600px; height:600px; background:rgba(16,184,148,.25); top:-10%; left:-5%; }
.hero-orb--2 { width:500px; height:500px; background:rgba(77,163,255,.25); bottom:-15%; right:-10%; animation-delay:-4s; }
.hero-orb--3 { width:300px; height:300px; background:rgba(255,107,53,.12); top:40%; left:50%; animation-delay:-8s; }
.hero .container { position:relative; z-index:2; }
.hero-layout { display:grid; grid-template-columns:1fr 420px; gap:6rem; align-items:center; }

.hero-tag {
    display:inline-flex; align-items:center; gap:.6rem;
    font-size:.75rem; font-weight:600; text-transform:uppercase; letter-spacing:1.5px;
    color:var(--teal-bright); margin-bottom:2rem;
    opacity:0; animation:fadeUp .6s ease .2s forwards;
}
.hero-tag__dot { width:8px; height:8px; border-radius:50%; background:var(--teal-bright); box-shadow:0 0 12px var(--teal-bright); animation:pulse 2s ease-in-out infinite; }

.hero h1 {
    font-family:var(--display); font-weight:400;
    font-size:clamp(2.6rem,5.5vw,4.2rem); line-height:1.08;
    letter-spacing:-.03em; margin-bottom:2rem;
    opacity:0; animation:fadeUp .8s ease .3s forwards;
}
.hero h1 strong { font-weight:900; }
.hero h1 i {
    font-style:italic; color:var(--teal-bright); position:relative;
}
.hero h1 i::after {
    content:''; position:absolute; bottom:4px; left:0; right:0;
    height:3px; background:var(--teal); border-radius:2px; opacity:.5;
}

.hero-copy {
    font-size:1.15rem; line-height:1.8; color:rgba(255,255,255,.75);
    max-width:520px; margin-bottom:2.5rem;
    opacity:0; animation:fadeUp .8s ease .45s forwards;
}

.hero-btns {
    display:flex; gap:1rem; flex-wrap:wrap;
    opacity:0; animation:fadeUp .8s ease .55s forwards;
}

/* ═══ BUTTONS ═══ */
.btn {
    display:inline-flex; align-items:center; gap:.5rem;
    padding:1rem 2rem; border-radius:10px;
    font-family:var(--sans); font-weight:700; font-size:.95rem;
    transition:all .25s; cursor:pointer; border:none; text-decoration:none;
}
.btn--teal { background:linear-gradient(135deg,#10b894,#0dd4a8); color:#fff; box-shadow:0 4px 24px rgba(16,184,148,.45); }
.btn--teal:hover { transform:translateY(-2px); box-shadow:0 12px 36px rgba(16,184,148,.5); background:linear-gradient(135deg,#12cca3,#10e4b4); }
.btn--glass { background:rgba(255,255,255,.06); color:#fff; border:1.5px solid rgba(255,255,255,.15); backdrop-filter:blur(8px); }
.btn--glass:hover { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.3); }
.btn--dark { background:var(--ink); color:#fff; box-shadow:0 4px 20px rgba(10,22,40,.3); }
.btn--dark:hover { transform:translateY(-2px); box-shadow:0 12px 32px rgba(10,22,40,.4); }
.btn--outline { background:transparent; color:var(--ink); border:2px solid var(--sand); }
.btn--outline:hover { border-color:var(--ink); background:rgba(10,22,40,.03); }

/* Hero proof cards */
.hero-proof {
    display:flex; flex-direction:column; gap:1rem;
    opacity:0; animation:fadeUp .8s ease .6s forwards;
}
.proof-card {
    background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
    border-radius:14px; padding:1.75rem 2rem;
    backdrop-filter:blur(16px);
    display:flex; align-items:center; gap:1.25rem;
    transition:all .3s;
}
.proof-card:hover { background:rgba(255,255,255,.08); transform:translateX(-6px); }
.proof-card__val {
    font-family:var(--display); font-size:3.2rem; font-weight:700;
    color:var(--teal-bright); line-height:1; min-width:90px;
    text-shadow:0 0 30px rgba(52,239,202,.3);
}
.proof-card__text { font-size:.82rem; color:rgba(255,255,255,.55); font-weight:600; text-transform:uppercase; letter-spacing:1px; line-height:1.4; }

/* ═══ TRUST BAR ═══ */
.trust-bar {
    background:var(--ink); border-top:1px solid rgba(255,255,255,.05);
    padding:1.25rem 0;
}
.trust-bar__inner {
    display:flex; align-items:center; justify-content:center;
    gap:2.5rem; flex-wrap:wrap;
    font-size:.75rem; font-weight:600; color:rgba(255,255,255,.55);
    text-transform:uppercase; letter-spacing:1.2px;
    max-width:1320px; margin:0 auto; padding:0 2rem;
}
.trust-bar__item { display:flex; align-items:center; gap:.4rem; white-space:nowrap; }
.trust-bar__item::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--teal-bright); }

/* ═══ PAIN STATEMENT ═══ */
.pain {
    padding:5rem 3rem; background:var(--white);
    border-bottom:1px solid rgba(0,0,0,.04);
}
.pain-inner { max-width:820px; margin:0 auto; }
.pain-lines { display:flex; flex-direction:column; gap:1.25rem; margin-bottom:3rem; }
.pain-line {
    font-size:clamp(1.15rem,2.5vw,1.4rem); line-height:1.5;
    color:var(--text-mid); display:flex; align-items:flex-start; gap:1rem;
    padding:1.25rem 1.75rem; border-radius:12px;
    background:var(--warm); border-left:3px solid var(--sand);
    transition:all .3s;
}
.pain-line:hover { border-left-color:var(--blue); transform:translateX(4px); background:#eef4fb; }
.pain-icon { font-size:1.4rem; flex-shrink:0; margin-top:.1rem; }
.pain-fix { text-align:center; }
.pain-fix p {
    font-family:var(--display); font-size:clamp(2.2rem,4.5vw,3.2rem);
    font-weight:900; color:var(--ink); margin-bottom:.5rem;
}
.pain-fix .pain-sub {
    font-size:1.05rem; color:var(--teal); font-weight:600;
}

/* ═══ PRODUCTS ═══ */
.products { padding:6rem 0; background:var(--white); }
.products-head { margin-bottom:4rem; }
.products-head .eyebrow,
.how-head .eyebrow,
.finder-head .eyebrow,
.benefits-head .eyebrow,
.sectors-head .eyebrow {
    font-size:.72rem; font-weight:700; text-transform:uppercase;
    letter-spacing:2px; color:var(--teal); margin-bottom:.75rem;
    display:block;
}
.products-head h2,
.how-head h2,
.finder-head h2,
.benefits-head h2,
.sectors-head h2 {
    font-family:var(--display); font-size:clamp(2rem,4vw,2.8rem);
    font-weight:400; color:var(--ink); line-height:1.15;
}

.products-list { display:flex; flex-direction:column; gap:0; }
.prod-row {
    display:grid; grid-template-columns:80px 1fr; gap:2rem;
    padding:2.5rem 0; border-bottom:1px solid rgba(0,0,0,.06);
    align-items:start; transition:all .3s;
    cursor:default; position:relative;
}
.prod-row:first-child { border-top:1px solid rgba(0,0,0,.06); }
.prod-row:hover { padding-left:1rem; }
.prod-row:hover .prod-num { color:var(--sky); text-shadow:0 0 20px rgba(77,163,255,.3); }
.prod-row--teal:hover .prod-num { color:var(--teal-bright); text-shadow:0 0 20px rgba(52,239,202,.3); }
.prod-row--teal .prod-tag { background:var(--teal); }

.prod-num {
    font-family:var(--display); font-size:3.5rem; font-weight:900;
    color:#b0c4d8; line-height:1; transition:all .3s;
}
.prod-content h3 {
    font-family:var(--sans); font-size:1.35rem; font-weight:800;
    color:var(--ink); margin-bottom:.5rem; letter-spacing:-.02em;
    display:flex; align-items:center; gap:.75rem;
}
.prod-tag {
    font-size:.6rem; font-weight:800; text-transform:uppercase;
    letter-spacing:1px; background:var(--blue); color:#fff;
    padding:.2rem .5rem; border-radius:4px; vertical-align:middle;
}
.prod-content p { color:var(--text-mid); font-size:1rem; line-height:1.7; max-width:680px; }

/* ═══ HOW IT WORKS ═══ */
.how { padding:7rem 0; background:var(--warm); position:relative; }
.how-head { text-align:center; margin-bottom:4rem; }
.how-steps {
    display:grid; grid-template-columns:repeat(3,1fr); gap:2rem;
    position:relative;
}
.how-steps::before {
    content:''; position:absolute; top:52px; left:calc(16.66% + 16px); right:calc(16.66% + 16px);
    height:2px; background:linear-gradient(90deg,var(--blue),var(--teal)); z-index:0;
}
.step {
    text-align:center; position:relative; z-index:1;
    background:var(--white); border-radius:16px; padding:3rem 2rem 2.5rem;
    border:1px solid rgba(0,0,0,.04);
    box-shadow:0 4px 20px rgba(0,0,0,.03);
    transition:all .35s;
}
.step:hover { transform:translateY(-6px); box-shadow:0 20px 48px rgba(0,0,0,.07); }
.step__badge {
    position:absolute; top:-16px; left:50%; transform:translateX(-50%);
    width:36px; height:36px; border-radius:50%;
    background:var(--ink); color:#fff;
    font-size:.8rem; font-weight:800; display:grid; place-items:center;
    border:3px solid var(--warm);
    box-shadow:0 4px 12px rgba(10,22,40,.15);
}
.step__icon {
    width:56px; height:56px; border-radius:14px; margin:0 auto 1.25rem;
    background:linear-gradient(135deg,rgba(16,184,148,.12),rgba(16,184,148,.04));
    display:grid; place-items:center; font-size:1.3rem; color:var(--teal);
    border:1px solid rgba(16,184,148,.15);
}
.step h3 { font-weight:800; font-size:1.1rem; color:var(--ink); margin-bottom:.5rem; }
.step p { color:var(--text-soft); font-size:.9rem; line-height:1.6; }
.step__time {
    display:inline-block; margin-top:1rem;
    background:rgba(16,184,148,.12); color:var(--teal);
    font-size:.78rem; font-weight:700; padding:.35rem .85rem;
    border-radius:50px;
}

/* ═══ FINDER ═══ */
.finder {
    padding:7rem 0; background:var(--ink); color:#fff;
    position:relative; overflow:hidden;
}
.finder::before {
    content:''; position:absolute; inset:0;
    background:
        radial-gradient(ellipse 40% 50% at 0% 100%, rgba(16,184,148,.2),transparent),
        radial-gradient(ellipse 40% 50% at 100% 0%, rgba(77,163,255,.15),transparent);
}
.finder .container { position:relative; z-index:1; }
.finder-head { text-align:center; margin-bottom:3.5rem; }
.finder-head .eyebrow { color:var(--teal-bright); }
.finder-head h2 { color:#fff; }
.finder-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; max-width:880px; margin:0 auto; }
.fc {
    padding:2.25rem; border-radius:14px;
    background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07);
    transition:all .3s; cursor:default;
    display:flex; flex-direction:column; justify-content:space-between; min-height:180px;
}
.fc:hover { background:rgba(255,255,255,.08); transform:translateY(-4px); border-color:rgba(255,255,255,.12); }
.fc__q {
    font-family:var(--display); font-style:italic;
    font-size:1.15rem; line-height:1.5; color:rgba(255,255,255,.8);
    margin-bottom:1.5rem;
}
.fc__a {
    display:inline-flex; align-items:center; gap:.4rem; align-self:flex-start;
    font-size:.88rem; font-weight:700; color:var(--teal-bright);
    padding:.45rem .95rem; background:rgba(52,239,202,.15); border-radius:8px;
    border:1px solid rgba(52,239,202,.2); transition:all .2s;
    text-shadow:0 0 12px rgba(52,239,202,.3);
}

/* ═══ BENEFITS ═══ */
.benefits { padding:6rem 0; background:var(--white); }
.benefits-head { text-align:center; margin-bottom:4rem; }
.benefits-head p { color:var(--text-soft); font-size:1.05rem; max-width:480px; margin:.75rem auto 0; }
.benefits-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.bg-card {
    padding:2.25rem; border-radius:14px; background:var(--warm);
    border:1px solid transparent; transition:all .3s;
}
.bg-card:hover { background:var(--white); border-color:var(--sand); transform:translateY(-3px); box-shadow:0 12px 32px rgba(0,0,0,.04); }
.bg-card__icon {
    width:48px; height:48px; border-radius:12px;
    background:linear-gradient(135deg,var(--blue),var(--sky));
    color:#fff;
    display:grid; place-items:center; font-size:1.1rem;
    margin-bottom:1.25rem;
    box-shadow:0 4px 16px rgba(26,109,181,.25);
}
.bg-card h3 { font-weight:800; font-size:1.05rem; color:var(--ink); margin-bottom:.4rem; }
.bg-card p { color:var(--text-soft); font-size:.88rem; line-height:1.65; }

/* ═══ SECTORS ═══ */
.sectors { padding:6rem 0; background:var(--warm); }
.sectors-head { text-align:center; margin-bottom:4rem; }
.sectors-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.sc {
    background:var(--white); border-radius:14px; padding:2rem;
    border-left:4px solid var(--blue); transition:all .3s;
}
.sc:hover { transform:translateX(4px); box-shadow:0 8px 28px rgba(0,0,0,.06); border-left-color:var(--sky); }
.sc--new { border-left-color:var(--teal); }
.sc--new:hover { border-left-color:var(--teal-bright); }
.sc__head { display:flex; align-items:center; gap:.6rem; margin-bottom:.65rem; }
.sc__icon { font-size:1.2rem; color:var(--blue); }
.sc--new .sc__icon { color:var(--teal); }
.sc h3 { font-size:1.05rem; font-weight:800; color:var(--ink); }
.sc--new h3 { color:var(--teal); }
.sc > p { color:var(--text-soft); font-size:.85rem; line-height:1.6; margin-bottom:.65rem; }
.sc-list { list-style:none; padding:0; }
.sc-list li { font-size:.8rem; color:var(--text-soft); padding:.2rem 0; display:flex; align-items:center; gap:.4rem; }
.sc-list li::before { content:"→"; font-weight:700; color:var(--blue); font-size:.75rem; }
.sc--new .sc-list li::before { color:var(--teal); }

/* ═══ RESULT ═══ */
.result { padding:6rem 0; background:var(--white); }
.result-card {
    max-width:960px; margin:0 auto;
    background:var(--warm); border:1px solid var(--sand);
    border-radius:20px; overflow:hidden;
    display:grid; grid-template-columns:280px 1fr;
}
.result-left {
    background:linear-gradient(135deg,var(--navy),var(--slate),#1a6db5);
    color:#fff; display:flex; flex-direction:column;
    align-items:center; justify-content:center; padding:3rem 2rem;
    text-align:center;
}
.result-left__num {
    font-family:var(--display); font-size:6.5rem; font-weight:900;
    line-height:1; color:var(--teal-bright); margin-bottom:.25rem;
    text-shadow:0 0 40px rgba(52,239,202,.4);
}
.result-left__label { font-size:.78rem; color:rgba(255,255,255,.6); font-weight:600; text-transform:uppercase; letter-spacing:1.2px; line-height:1.4; }
.result-right { padding:3rem; display:flex; flex-direction:column; justify-content:center; }
.result-right__tag {
    display:inline-block; align-self:flex-start;
    background:rgba(16,184,148,.1); color:var(--teal);
    font-size:.7rem; font-weight:800; padding:.3rem .7rem;
    border-radius:4px; letter-spacing:.8px; text-transform:uppercase;
    margin-bottom:1rem; border:1px solid rgba(16,184,148,.2);
}
.result-right h3 { font-family:var(--display); font-size:1.5rem; color:var(--ink); margin-bottom:.75rem; line-height:1.3; }
.result-right p { color:var(--text-mid); font-size:.95rem; line-height:1.7; }
.result-right__src { margin-top:1.25rem; font-size:.82rem; color:var(--text-soft); font-weight:600; }
.result-right__src strong { color:var(--ink); }

/* ═══ COMPLIANCE ═══ */
.compliance { padding:5rem 0; background:linear-gradient(135deg,var(--navy),var(--slate)); color:#fff; text-align:center; position:relative; overflow:hidden; }
.compliance::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 60% at 50% 120%,rgba(16,184,148,.1),transparent); }
.compliance .container { position:relative; z-index:1; }
.compliance h2 { font-family:var(--display); font-size:clamp(1.8rem,3vw,2.2rem); font-weight:400; margin-bottom:2.5rem; }
.compliance-badges { display:flex; justify-content:center; gap:1rem; flex-wrap:wrap; }
.cb {
    display:flex; align-items:center; gap:.55rem;
    padding:.9rem 1.5rem; border-radius:10px;
    background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
    font-size:.9rem; font-weight:600; transition:all .3s;
}
.cb:hover { background:rgba(255,255,255,.15); transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,.15); }
.cb i { color:var(--teal-bright); font-size:1.15rem; filter:drop-shadow(0 0 6px rgba(52,239,202,.4)); }

/* ═══ TESTIMONIALS ═══ */
.reviews { padding:6rem 0; background:var(--warm); }
.reviews-head { text-align:center; margin-bottom:3rem; }
.reviews-head h2 { font-family:var(--display); font-size:clamp(2rem,3.5vw,2.4rem); font-weight:400; color:var(--ink); }
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.rv {
    background:var(--white); border:1px solid rgba(0,0,0,.04);
    border-radius:16px; padding:2.25rem;
    transition:all .35s;
}
.rv:hover { transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,.05); }
.rv__stars { color:#f5a623; font-size:.95rem; letter-spacing:.15rem; margin-bottom:1rem; text-shadow:0 0 8px rgba(245,166,35,.3); }
.rv blockquote { margin:0 0 1.5rem; }
.rv blockquote p { font-size:.95rem; line-height:1.65; color:var(--text-mid); font-style:italic; }
.rv__who { display:flex; align-items:center; gap:.75rem; }
.rv__avatar {
    width:42px; height:42px; border-radius:50%;
    background:linear-gradient(135deg,var(--warm),var(--sand));
    display:grid; place-items:center; font-weight:800; font-size:.85rem;
    color:var(--navy);
}
.rv__name { font-weight:800; font-size:.85rem; color:var(--ink); }
.rv__role { font-size:.78rem; color:var(--text-soft); }

/* ═══ FOUNDER ═══ */
.founder { padding:5rem 0; background:var(--warm); }
.founder-card {
    max-width:860px; margin:0 auto;
    display:grid; grid-template-columns:auto 1fr; gap:2.5rem; align-items:center;
    background:var(--white); border:1px solid var(--sand);
    border-radius:20px; padding:3rem;
}
.founder-avatar {
    width:80px; height:80px; border-radius:50%;
    background:linear-gradient(135deg,var(--navy),var(--slate));
    color:#fff; display:grid; place-items:center;
    font-family:var(--display); font-size:1.8rem; font-weight:700;
    box-shadow:0 8px 24px rgba(15,43,68,.2);
    flex-shrink:0;
}
.founder-body h3 {
    font-family:var(--display); font-size:1.4rem; font-weight:700;
    color:var(--ink); margin-bottom:.75rem; line-height:1.3;
}
.founder-body p {
    color:var(--text-mid); font-size:.95rem; line-height:1.75;
    margin-bottom:1.25rem;
}
.founder-tags { display:flex; gap:.75rem; flex-wrap:wrap; }
.founder-tags span {
    font-size:.78rem; font-weight:700; color:var(--ink);
    background:var(--warm); padding:.4rem .85rem; border-radius:50px;
    border:1px solid var(--sand); letter-spacing:.02em;
}

/* ═══ FINAL CTA ═══ */
.cta-final {
    padding:8rem 3rem; text-align:center;
    background:var(--white); position:relative;
}
.cta-final::before {
    content:''; position:absolute; inset:0;
    background:radial-gradient(ellipse 50% 40% at 50% 100%, rgba(16,184,148,.04),transparent);
}
.cta-final__inner { max-width:620px; margin:0 auto; position:relative; z-index:1; }
.cta-final h2 {
    font-family:var(--display); font-size:clamp(2.2rem,4.5vw,3rem);
    font-weight:400; color:var(--ink); line-height:1.15;
    margin-bottom:1.25rem;
}
.cta-final p { font-size:1.1rem; color:var(--text-mid); line-height:1.7; margin-bottom:2.5rem; }
.cta-final__btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* ═══ HOMEPAGE RESPONSIVE ═══ */
@media(max-width:1024px){
    .hero-layout{grid-template-columns:1fr;gap:3rem}
    .hero{min-height:auto;padding:4rem 2rem}
    .benefits-grid,.sectors-grid,.reviews-grid{grid-template-columns:1fr 1fr}
    .how-steps{grid-template-columns:1fr;gap:2.5rem} .how-steps::before{display:none}
    .finder-grid{grid-template-columns:1fr 1fr}
    .result-card{grid-template-columns:1fr}
    .result-left{padding:2.5rem}
}
@media(max-width:768px){
    .container{padding:0 1.5rem}
    .hero{padding:3rem 1.5rem 4rem}
    .benefits-grid,.sectors-grid,.reviews-grid,.finder-grid{grid-template-columns:1fr}
    .pain{padding:3rem 1.5rem}
    .pain-line{font-size:1rem;padding:1rem 1.25rem}
    .pain-fix p{font-size:2rem}
    .founder-card{grid-template-columns:1fr;text-align:center}
    .founder-avatar{margin:0 auto}
    .founder-tags{justify-content:center}
    .cta-final{padding:5rem 1.5rem}
    .cta-final__btns{flex-direction:column;align-items:center}
    .btn{width:100%;max-width:320px;justify-content:center}
    .compliance-badges{flex-direction:column;align-items:center}
    .trust-bar__inner{gap:1rem;flex-direction:column}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}


/* ═══════════════════════════════════════════════
   PART 2: FOOTER STYLES (preserved from v4.0)
   ═══════════════════════════════════════════════ */

footer {
    background: #1a2332;
    color: #c9d1d9;
    padding: 2.5rem 2rem 1.5rem;
    font-family: var(--sans);
    border-top: 3px solid var(--navy);
}
.footer-main { max-width: 1200px; margin: 0 auto; }
.footer-top {
    display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 2.5rem; padding-bottom: 2rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.footer-column h4 {
    font-size: 0.85rem; text-transform: uppercase;
    letter-spacing: 1.5px; color: #fff; font-weight: 600; margin-bottom: 1rem;
}
.company-info { padding-right: 2rem; }
.company-logo {
    font-size: 1.5rem; font-weight: 700; color: #fff;
    margin-bottom: 0.75rem; letter-spacing: 0.5px;
    display:inline-flex; align-items:center; gap:.5rem; white-space:nowrap;
}
.company-logo img { height: 1.5rem; width: auto; margin-right: 0.5rem; vertical-align: middle; }
.company-tagline { font-size: 0.95rem; color: #8b949e; line-height: 1.6; margin-bottom: 1rem; }
.company-location { font-size: 0.9rem; color: #8b949e; margin-bottom: 0.5rem; font-weight: 700; }
.company-certifications { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid rgba(255, 255, 255, 0.1); }
.certifications-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 1px; color: #8b949e; margin-bottom: 0.4rem; }
.certifications-list { font-size: 0.85rem; color: #c9d1d9; }
.footer-links { list-style: none; padding: 0; }
.footer-links li { margin-bottom: 0.6rem; }
.footer-links a { color: #8b949e; text-decoration: none; transition: color 0.3s; font-size: 0.9rem; display: inline-block; }
.footer-links a:hover { color: #fff; padding-left: 4px; }
.contact-info { font-size: 0.9rem; }
.contact-item { margin-bottom: 0.75rem; }
.contact-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 1px; color: #8b949e; margin-bottom: 0.25rem; }
.contact-value { color: #c9d1d9; }
.contact-value a { color: #c9d1d9; text-decoration: none; transition: color 0.3s; }
.contact-value a:hover { color: #fff; }
.social-media { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid rgba(255, 255, 255, 0.1); }
.social-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 1px; color: #8b949e; margin-bottom: 0.6rem; }
.social-links { display: flex; gap: 1rem; }
.social-links a { color: #8b949e; font-size: 20px; text-decoration: none; transition: color 0.3s, transform 0.3s; display: inline-block; }
.social-links a:hover { color: #fff; transform: translateY(-2px); }
.footer-bottom {
    background:#1a2332;
    display:flex !important; justify-content:center !important; align-items:center !important;
    padding:4px 0 !important; border-top:none;
    margin-top:1.5rem;
}
.footer-bottom .copyright {
    margin:0 !important; text-align:center !important; line-height:1.35 !important;
    font-size:0.9rem !important; color:rgba(255,255,255,.9);
}
.footer-legal-links { display:none !important; }

/* Footer responsive */
@media (max-width: 1024px) { .footer-top { grid-template-columns: 1fr 1fr; gap: 1.5rem; } }
@media (max-width: 768px) {
    .footer-top { grid-template-columns: 1fr; gap: 2rem; }
    .footer-bottom { flex-direction: column; gap: 1rem; text-align: center; }
    .company-info { padding-right: 0; }
    footer { padding-bottom: calc(72px + 24px); }
}


/* ═══════════════════════════════════════════════
   PART 3: CHATBOT COEXISTENCE
   ═══════════════════════════════════════════════ */

:root { --chat-bubble-size:72px; }
#amy-chat-widget,
.aimy-chat-widget,
#tf-chat-widget {
    position: fixed; right: 20px; bottom: 20px; z-index: 2147483000;
}
#amy-chat-widget *, .aimy-chat-widget * {
    line-height: normal; letter-spacing: normal; white-space: normal;
}


/* ═══════════════════════════════════════════════
   PART 4: LEGACY PAGE TEMPLATE SUPPORT
   Styles needed for pricing, about, contact, etc.
   ═══════════════════════════════════════════════ */

/* Page containers */
.page-pricing,
.page-about,
.page-contact,
.page-terms,
.page-privacy,
.page-gdpr,
.page-refund,
.page-ai-disclaimer {
    max-width:1200px; margin:2rem auto; padding:0 2rem;
    font-family: var(--sans); color:var(--text); line-height:1.7;
}

/* Shared section styles for inner pages */
.page-pricing h1,
.page-about h1,
.page-contact h1 {
    font-family:var(--display); font-size:clamp(2rem,4vw,3rem);
    color:var(--ink); margin-bottom:1.5rem;
}

.page-pricing h2,
.page-about h2,
.page-contact h2 {
    font-family:var(--display); font-size:clamp(1.5rem,3vw,2.2rem);
    color:var(--ink); margin-bottom:1rem;
}

/* Legal page base */
.legal-page { max-width:900px; margin:6rem auto 2rem; padding:0 2rem; }
.legal-page h1 { font-family:var(--display); font-size:2.2rem; color:var(--ink); margin-bottom:1.5rem; }
.legal-page h2 { font-size:1.5rem; color:var(--ink); margin:2rem 0 .75rem; }
.legal-page h3 { font-size:1.2rem; color:var(--text); margin:1.5rem 0 .5rem; }
.legal-page p { margin-bottom:1rem; color:var(--text-mid); }
.legal-page ul, .legal-page ol { margin:1rem 0 1rem 2rem; color:var(--text-mid); }
.legal-page li { margin-bottom:.5rem; }
.legal-page a { color:var(--blue); text-decoration:underline; }

/* Pricing page specific styles (needed for page-pricing.php) */
.uk-benefits { padding:4rem 0; }
.uk-benefits__title { font-family:var(--display); text-align:center; margin-bottom:2rem; color:var(--ink); }
.benefit-item { padding:1.5rem; background:var(--warm); border-radius:12px; }
.benefit-item__title { font-weight:700; color:var(--ink); margin-bottom:.5rem; }
.benefit-item__description { color:var(--text-soft); font-size:.9rem; }
.impact-stats { padding:4rem 0; text-align:center; }
.impact-stats__title { font-family:var(--display); margin-bottom:2rem; color:var(--ink); }
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1.5rem; }
.stat-item { padding:2rem; background:var(--warm); border-radius:12px; text-align:center; }
.stat-item__number { font-family:var(--display); font-size:2.5rem; color:var(--teal); font-weight:700; }
.stat-item__label { font-size:.85rem; color:var(--text-soft); margin-top:.5rem; }

/* Pricing cards */
.pricing-section { padding:4rem 0; }
.pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:2rem; }
.pricing-card { background:var(--white); border:1px solid var(--sand); border-radius:16px; padding:2.5rem; transition:all .3s; }
.pricing-card:hover { transform:translateY(-4px); box-shadow:0 12px 32px rgba(0,0,0,.06); }
.pricing-card.featured { border-color:var(--teal); box-shadow:0 4px 20px rgba(16,184,148,.15); }
.pricing-card h3 { font-size:1.3rem; font-weight:800; color:var(--ink); margin-bottom:.5rem; }
.pricing-card .price { font-family:var(--display); font-size:2.5rem; color:var(--ink); margin:1rem 0; }
.pricing-card .price span { font-size:1rem; color:var(--text-soft); font-family:var(--sans); }
.pricing-card ul { list-style:none; padding:0; margin:1.5rem 0; }
.pricing-card li { padding:.4rem 0; color:var(--text-mid); font-size:.9rem; }
.pricing-card li::before { content:"✓ "; color:var(--teal); font-weight:700; }
.pricing-card .btn { width:100%; justify-content:center; margin-top:1rem; }

/* About page */
.about-hero { padding:4rem 0; text-align:center; }
.about-content { max-width:800px; margin:0 auto; }
.about-content p { margin-bottom:1.5rem; color:var(--text-mid); font-size:1.05rem; }

/* Contact page */
.contact-form-wrapper { max-width:600px; margin:2rem auto; }
.contact-form-wrapper input,
.contact-form-wrapper textarea,
.contact-form-wrapper select {
    width:100%; padding:.9rem 1rem; border:1px solid var(--sand);
    border-radius:8px; font-family:var(--sans); font-size:1rem;
    margin-bottom:1rem; transition:border-color .2s;
}
.contact-form-wrapper input:focus,
.contact-form-wrapper textarea:focus {
    border-color:var(--blue); outline:none; box-shadow:0 0 0 3px rgba(26,109,181,.1);
}
