/*
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.14
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;
}

/* ═══ CASE STUDY ═══ */
.case-study { padding:5rem 3rem; background:var(--warm); }
.case-card {
    display:grid; grid-template-columns:220px 1fr; gap:0;
    background:var(--white); border:1px solid var(--sand);
    border-radius:20px; overflow:hidden; max-width:900px; margin:0 auto;
    box-shadow:0 4px 24px rgba(0,0,0,.04);
}
.case-card__left {
    background:linear-gradient(135deg,var(--navy),var(--slate),#1a6db5);
    color:#fff; display:flex; flex-direction:column;
    align-items:center; justify-content:center; padding:2.5rem; text-align:center;
}
.case-card__num {
    font-family:var(--display); font-size:5rem; font-weight:900;
    color:var(--teal-bright); line-height:1;
    text-shadow:0 0 40px rgba(52,239,202,.3);
}
.case-card__label {
    font-size:.72rem; color:rgba(255,255,255,.5); font-weight:600;
    text-transform:uppercase; letter-spacing:1px; margin-top:.35rem; line-height:1.3;
}
.case-card__right { padding:2.5rem 3rem; display:flex; flex-direction:column; justify-content:center; }
.case-card__tag {
    display:inline-block; align-self:flex-start;
    background:rgba(16,184,148,.1); color:var(--teal);
    font-size:.68rem; font-weight:800; padding:.25rem .6rem;
    border-radius:4px; letter-spacing:.8px; text-transform:uppercase;
    margin-bottom:.75rem; border:1px solid rgba(16,184,148,.2);
}
.case-card__right h3 {
    font-family:var(--display); font-size:1.5rem; font-weight:700;
    color:var(--ink); margin-bottom:.65rem; line-height:1.3;
}
.case-card__right p {
    font-size:.95rem; color:var(--text-mid); line-height:1.7; margin-bottom:1.25rem;
}
.case-card__foot { display:flex; align-items:center; gap:1.25rem; flex-wrap:wrap; }
.case-card__src { font-size:.8rem; color:var(--text-soft); font-weight:600; }
.case-card__src strong { color:var(--ink); }

@media(max-width:768px){
    .case-study { padding:3rem 1.5rem; }
    .case-card { grid-template-columns:1fr; }
    .case-card__left { padding:2rem; }
    .case-card__right { padding:2rem; }
    .case-card__foot { flex-direction:column; align-items:flex-start; }
}

/* ═══ 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;
}

/* ═══════════════════════════════════════════════
   PART 5: INNER PAGE DESIGN SYSTEM (v5.1)
   Unified styles for about, contact, legal, pricing
   ═══════════════════════════════════════════════ */

/* === Page wrapper === */
.pg { max-width:900px; margin:0 auto; padding:3rem 2rem 4rem; }
.pg--wide { max-width:1200px; }

/* === Page hero === */
.pg-hero { text-align:center; margin-bottom:3rem; }
.pg-hero h1 {
    font-family:var(--display); font-size:clamp(2.2rem,5vw,3.2rem);
    font-weight:400; color:var(--ink); line-height:1.15;
    margin-bottom:1rem;
}
.pg-hero p {
    font-size:1.15rem; color:var(--text-mid); line-height:1.7;
    max-width:680px; margin:0 auto;
}

/* === Typography === */
.pg h2 {
    font-family:var(--display); font-size:clamp(1.5rem,3vw,2rem);
    font-weight:400; color:var(--ink); line-height:1.3;
    margin:2.5rem 0 1rem; padding-bottom:.75rem;
    border-bottom:1px solid var(--sand);
}
.pg h3 {
    font-size:1.15rem; font-weight:700; color:var(--ink);
    margin:1.75rem 0 .5rem;
}
.pg p { margin-bottom:1rem; color:var(--text-mid); line-height:1.75; font-size:1rem; }
.pg strong { color:var(--text); font-weight:700; }
.pg a { color:var(--blue); text-decoration:underline; text-underline-offset:2px; }
.pg a:hover { color:var(--ink); }
.pg ul, .pg ol { margin:1rem 0 1.5rem 1.5rem; color:var(--text-mid); }
.pg li { margin-bottom:.5rem; line-height:1.7; }

/* === Cards === */
.pg-card {
    background:var(--white); border:1px solid var(--sand);
    border-radius:14px; padding:2.5rem;
    box-shadow:0 2px 12px rgba(0,0,0,.03);
    margin-bottom:2rem; transition:all .3s;
}
.pg-card:hover { box-shadow:0 8px 28px rgba(0,0,0,.06); }
.pg-card h3 {
    font-family:var(--display); font-size:1.4rem; color:var(--ink);
    margin:0 0 1rem; border:none; padding:0;
}

/* === Feature list (tick items) === */
.pg-features { list-style:none; margin:1.5rem 0; padding:0; }
.pg-features li {
    display:flex; align-items:flex-start; gap:.75rem;
    padding:.65rem 0; color:var(--text-mid); font-size:1rem; line-height:1.6;
}
.pg-features li::before {
    content:"✓"; flex-shrink:0;
    width:26px; height:26px; border-radius:50%;
    background:rgba(16,184,148,.1); color:var(--teal);
    font-weight:700; font-size:.85rem;
    display:flex; align-items:center; justify-content:center;
    margin-top:.15rem;
}

/* === Values list === */
.pg-values { list-style:none; margin:2rem 0; padding:0; display:grid; gap:1.25rem; }
.pg-values li {
    background:var(--white); border:1px solid var(--sand);
    border-left:4px solid var(--blue); border-radius:12px;
    padding:1.75rem 2rem; transition:all .3s;
}
.pg-values li:hover { border-left-color:var(--teal); transform:translateX(4px); box-shadow:0 8px 24px rgba(0,0,0,.05); }
.pg-values li strong {
    display:block; font-family:var(--sans); font-size:1.15rem;
    font-weight:800; color:var(--ink); margin-bottom:.4rem;
}
.pg-values li p { margin:0; font-size:.95rem; }

/* === Stats bar === */
.pg-stats {
    display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem;
    margin:2.5rem 0; padding:2rem;
    background:var(--warm); border:1px solid var(--sand); border-radius:14px;
}
.pg-stat { text-align:center; padding:1rem; }
.pg-stat__num {
    font-family:var(--display); font-size:2.5rem; font-weight:700;
    color:var(--teal); line-height:1; margin-bottom:.4rem;
}
.pg-stat__label { font-size:.85rem; color:var(--text-soft); font-weight:500; }

/* === CTA box === */
.pg-cta {
    background:linear-gradient(135deg,var(--navy),var(--slate));
    border-radius:16px; padding:3.5rem; text-align:center; color:#fff;
    margin:3rem 0; position:relative; overflow:hidden;
}
.pg-cta::before {
    content:''; position:absolute; inset:0;
    background:radial-gradient(ellipse 50% 60% at 50% 100%,rgba(16,184,148,.12),transparent);
}
.pg-cta > * { position:relative; z-index:1; }
.pg-cta h3 {
    font-family:var(--display); font-size:clamp(1.6rem,3.5vw,2.2rem);
    font-weight:400; margin-bottom:1rem; color:#fff !important; border:none !important; padding:0;
}
.pg-cta p { color:rgba(255,255,255,.8); font-size:1.05rem; margin-bottom:2rem; }
.pg-cta strong { color:#fff; }

/* === Contact form === */
.pg-form { max-width:600px; margin:2rem auto 0; }
.pg-form__group { margin-bottom:1.25rem; }
.pg-form label {
    display:block; font-weight:700; font-size:.9rem; color:var(--ink);
    margin-bottom:.4rem; letter-spacing:.01em;
}
.pg-form input,
.pg-form textarea,
.pg-form select {
    width:100%; padding:.9rem 1.1rem; border:1.5px solid var(--sand);
    border-radius:10px; font-family:var(--sans); font-size:1rem;
    color:var(--text); background:var(--white);
    transition:all .2s;
}
.pg-form input:focus,
.pg-form textarea:focus {
    border-color:var(--teal); outline:none;
    box-shadow:0 0 0 3px rgba(16,184,148,.1);
}
.pg-form input::placeholder,
.pg-form textarea::placeholder { color:var(--text-soft); opacity:.6; }
.pg-form textarea { resize:vertical; min-height:140px; }
.pg-form .btn { width:100%; justify-content:center; margin-top:.5rem; }

/* === Image frame === */
.pg-img {
    display:grid; place-items:center; margin:2.5rem 0;
}
.pg-img__frame {
    width:min(100%,560px); border-radius:14px; overflow:hidden;
    box-shadow:0 8px 32px rgba(0,0,0,.08); border:1px solid var(--sand);
    background:var(--warm);
}
.pg-img__frame img { display:block; width:100%; height:auto; }

/* === Contact info grid === */
.pg-contact-grid {
    display:grid; grid-template-columns:1fr 1fr; gap:2rem;
    margin:2rem 0;
}
.pg-contact-card {
    background:var(--warm); border:1px solid var(--sand);
    border-radius:14px; padding:2rem; text-align:center;
    transition:all .3s;
}
.pg-contact-card:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.05); }
.pg-contact-card i { font-size:1.5rem; color:var(--teal); margin-bottom:.75rem; display:block; }
.pg-contact-card h3 { font-size:1rem; font-weight:700; color:var(--ink); margin:0 0 .5rem; border:none; padding:0; }
.pg-contact-card p { margin:0; font-size:.9rem; }
.pg-contact-card a { color:var(--blue); }

/* === Social links === */
.pg-socials { display:flex; gap:1rem; justify-content:center; margin:1.5rem 0; }
.pg-socials a {
    width:48px; height:48px; border-radius:12px;
    background:var(--warm); border:1px solid var(--sand);
    display:grid; place-items:center; font-size:1.2rem; color:var(--navy);
    transition:all .2s; text-decoration:none;
}
.pg-socials a:hover { background:var(--ink); color:#fff; border-color:var(--ink); transform:translateY(-2px); }

/* === Legal page specifics === */
.pg--legal h2 { font-size:1.35rem; }
.pg--legal h3 { font-size:1.1rem; }

/* === Disclaimer banner === */
.pg-banner {
    background:var(--warm); border:1px solid var(--sand); border-left:4px solid var(--teal);
    border-radius:12px; padding:1.5rem 2rem; margin:2rem 0;
}
.pg-banner p { margin:0; font-size:.95rem; }

/* === Pricing page === */
.pg--pricing { max-width:1200px; }

/* Benefits grid */
.pg-benefits-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; margin:2rem 0; }
.pg-benefit {
    background:var(--warm); border-radius:12px; padding:1.75rem;
    border:1px solid var(--sand); transition:all .3s;
}
.pg-benefit:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.05); }
.pg-benefit h3 { font-size:1rem; font-weight:800; color:var(--ink); margin:0 0 .4rem; border:none; padding:0; }
.pg-benefit p { margin:0; font-size:.88rem; color:var(--text-soft); }

/* Solution selector tabs */
.pg-tabs { display:flex; gap:.5rem; justify-content:center; margin:2rem 0; flex-wrap:wrap; }
.pg-tab {
    padding:.75rem 1.5rem; border-radius:50px;
    font-weight:700; font-size:.9rem; cursor:pointer;
    border:2px solid var(--sand); background:var(--white); color:var(--text-mid);
    transition:all .2s; text-decoration:none; display:inline-block;
}
.pg-tab:hover, .pg-tab.active { background:var(--ink); color:#fff; border-color:var(--ink); }

/* Pricing cards */
.pg-pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; margin:2rem 0; }
.pg-price-card {
    background:var(--white); border:1.5px solid var(--sand);
    border-radius:16px; padding:2.5rem 2rem; transition:all .3s;
    position:relative;
}
.pg-price-card:hover { transform:translateY(-4px); box-shadow:0 12px 36px rgba(0,0,0,.06); }
.pg-price-card.featured { border-color:var(--teal); }
.pg-price-card.featured::before {
    content:'Most Popular'; position:absolute; top:-12px; left:50%; transform:translateX(-50%);
    background:var(--teal); color:#fff; font-size:.7rem; font-weight:700;
    padding:.3rem .8rem; border-radius:50px; letter-spacing:.5px; text-transform:uppercase;
}
.pg-price-card__name { font-weight:800; font-size:1.2rem; color:var(--ink); margin-bottom:.25rem; }
.pg-price-card__price {
    font-family:var(--display); font-size:2.8rem; font-weight:700; color:var(--ink);
    margin:1rem 0; line-height:1;
}
.pg-price-card__price span { font-size:.95rem; color:var(--text-soft); font-family:var(--sans); font-weight:500; }
.pg-price-card__desc { font-size:.9rem; color:var(--text-soft); margin-bottom:1.25rem; }
.pg-price-card ul { list-style:none; padding:0; margin:0 0 1.5rem; }
.pg-price-card li {
    padding:.35rem 0; color:var(--text-mid); font-size:.88rem;
    display:flex; align-items:center; gap:.5rem;
}
.pg-price-card li::before { content:"✓"; color:var(--teal); font-weight:700; font-size:.85rem; }
.pg-price-card .btn { width:100%; }

/* === Inner page responsive === */
@media(max-width:768px){
    .pg { padding:2rem 1.5rem 3rem; }
    .pg-stats { grid-template-columns:1fr; }
    .pg-contact-grid { grid-template-columns:1fr; }
    .pg-benefits-grid { grid-template-columns:1fr; }
    .pg-cta { padding:2.5rem 1.5rem; }
    .pg-pricing-grid { grid-template-columns:1fr; }
    .pg-form { padding:0; }
}
@media(max-width:480px){
    .pg { padding:1.5rem 1rem 2rem; }
    .pg-card { padding:1.5rem; }
    .pg-values li { padding:1.25rem; }
}


/* ═══════════════════════════════════════════════
   PART 6: ABOUT PAGE STYLES (v5.2)
   ═══════════════════════════════════════════════ */

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

/* Founder intro */
.about-founder {
    display:grid; grid-template-columns:auto 1fr; gap:2.5rem; align-items:start;
    background:var(--warm); border:1px solid var(--sand);
    border-radius:20px; padding:3rem; margin:2.5rem 0;
}
.about-founder__avatar {
    width:100px; height:100px; border-radius:50%;
    background:linear-gradient(135deg,var(--navy),var(--slate));
    color:#fff; display:grid; place-items:center;
    font-family:var(--display); font-size:2.2rem; font-weight:700;
    box-shadow:0 8px 24px rgba(15,43,68,.2); flex-shrink:0;
}
.about-founder__name { font-family:var(--display); font-size:1.6rem; font-weight:700; color:var(--ink); margin-bottom:.25rem; }
.about-founder__role { font-size:.85rem; font-weight:600; color:var(--teal); text-transform:uppercase; letter-spacing:.8px; margin-bottom:1rem; }
.about-founder p { color:var(--text-mid); font-size:1rem; line-height:1.75; margin-bottom:1rem; }
.about-founder p:last-child { margin-bottom:0; }

/* Products mini grid */
.about-products { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; margin:1.5rem 0 2rem; }
.about-prod {
    background:var(--white); border:1px solid var(--sand);
    border-radius:14px; padding:1.75rem; transition:all .3s;
}
.about-prod:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.05); border-color:var(--blue); }
.about-prod__num { font-family:var(--display); font-size:2rem; font-weight:900; color:var(--sand); margin-bottom:.5rem; line-height:1; transition:color .3s; }
.about-prod:hover .about-prod__num { color:var(--sky); }
.about-prod h3 { font-size:1.05rem; font-weight:800; color:var(--ink); margin:0 0 .4rem; border:none; padding:0; }
.about-prod p { font-size:.88rem; color:var(--text-soft); margin:0; line-height:1.6; }
.about-prod--teal:hover { border-color:var(--teal); }
.about-prod--teal:hover .about-prod__num { color:var(--teal-bright); }

/* Case study */
.about-case {
    display:grid; grid-template-columns:200px 1fr; gap:0;
    background:var(--warm); border:1px solid var(--sand);
    border-radius:20px; overflow:hidden; margin:1.5rem 0 2rem;
}
.about-case__left {
    background:linear-gradient(135deg,var(--navy),var(--slate),#1a6db5);
    color:#fff; display:flex; flex-direction:column;
    align-items:center; justify-content:center; padding:2rem; text-align:center;
}
.about-case__num { font-family:var(--display); font-size:4.5rem; font-weight:900; color:var(--teal-bright); line-height:1; text-shadow:0 0 30px rgba(52,239,202,.3); }
.about-case__label { font-size:.72rem; color:rgba(255,255,255,.5); font-weight:600; text-transform:uppercase; letter-spacing:1px; margin-top:.25rem; line-height:1.3; }
.about-case__right { padding:2.5rem; display:flex; flex-direction:column; justify-content:center; }
.about-case__tag { display:inline-block; align-self:flex-start; background:rgba(16,184,148,.1); color:var(--teal); font-size:.68rem; font-weight:800; padding:.25rem .6rem; border-radius:4px; letter-spacing:.8px; text-transform:uppercase; margin-bottom:.75rem; border:1px solid rgba(16,184,148,.2); }
.about-case__right h3 { font-family:var(--display); font-size:1.3rem; color:var(--ink); margin:0 0 .65rem; border:none; padding:0; line-height:1.3; }
.about-case__right p { font-size:.92rem; color:var(--text-mid); line-height:1.65; margin:0 0 .75rem; }
.about-case__src { font-size:.8rem; color:var(--text-soft); font-weight:600; }
.about-case__src strong { color:var(--ink); }

@media(max-width:768px){
    .about-founder { grid-template-columns:1fr; text-align:center; }
    .about-founder__avatar { margin:0 auto; }
    .about-products { grid-template-columns:1fr; }
    .about-case { grid-template-columns:1fr; }
    .about-case__left { padding:1.5rem; }
}


/* ═══════════════════════════════════════════════
   PART 7: SOLUTIONS PAGE STYLES (v5.2)
   ═══════════════════════════════════════════════ */

/* Hero */
.sol-hero { text-align:center; margin-bottom:3rem; }
.sol-hero .eyebrow { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--teal); margin-bottom:.75rem; display:block; }
.sol-hero h1 { font-family:var(--display); font-size:clamp(2.2rem,5vw,3.2rem); font-weight:400; color:var(--ink); line-height:1.15; margin-bottom:1.25rem; border:none; padding:0; }
.sol-hero h1 strong { font-weight:900; }
.sol-hero p { font-size:1.15rem; color:var(--text-mid); line-height:1.7; max-width:640px; margin:0 auto 2rem; }
.sol-hero__btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* Section head */
.sol-section-head { margin:4rem 0 1.5rem; text-align:center; }
.sol-section-head h2 { font-family:var(--display); font-size:clamp(1.6rem,3.5vw,2.2rem); font-weight:400; color:var(--ink); margin-bottom:.5rem; border:none; padding:0; }
.sol-section-head p { color:var(--text-soft); font-size:1rem; max-width:560px; margin:0 auto; }

/* Solution cards */
.sol-card { background:var(--white); border:1.5px solid var(--sand); border-radius:18px; padding:2.5rem; margin-bottom:1.5rem; position:relative; overflow:hidden; transition:all .3s; }
.sol-card:hover { box-shadow:0 12px 36px rgba(0,0,0,.05); transform:translateY(-2px); }
.sol-card__head { display:flex; align-items:flex-start; gap:1.5rem; margin-bottom:1.25rem; }
.sol-card__num { font-family:var(--display); font-size:3rem; font-weight:900; color:var(--sand); line-height:1; flex-shrink:0; min-width:50px; transition:color .3s; }
.sol-card:hover .sol-card__num { color:var(--sky); }
.sol-card--teal:hover .sol-card__num { color:var(--teal-bright); }
.sol-card__title { font-family:var(--sans); font-size:1.3rem; font-weight:800; color:var(--ink); margin-bottom:.15rem; }
.sol-card__subtitle { font-size:.85rem; color:var(--text-soft); font-weight:500; }
.sol-card__desc { color:var(--text-mid); font-size:1rem; line-height:1.7; margin-bottom:1.25rem; }

/* Solution features 2-col */
.sol-features { list-style:none; margin:0 0 1.5rem; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:.5rem .75rem; }
.sol-features li { display:flex; align-items:flex-start; gap:.5rem; font-size:.88rem; color:var(--text-mid); line-height:1.5; }
.sol-features li::before { content:"✓"; flex-shrink:0; color:var(--teal); font-weight:700; font-size:.85rem; margin-top:.1rem; }

/* Price badge */
.sol-price { display:inline-block; margin-top:.75rem; background:rgba(16,184,148,.08); color:var(--teal); font-size:.82rem; font-weight:700; padding:.4rem .9rem; border-radius:50px; border:1px solid rgba(16,184,148,.15); }
.sol-card__foot { display:flex; gap:.75rem; flex-wrap:wrap; align-items:center; }

/* Deep dive dark section */
.sol-deep {
    background:var(--ink); border-radius:20px; padding:3rem;
    color:#fff; margin:2rem 0; position:relative; overflow:hidden;
}
.sol-deep::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 40% 50% at 0% 100%,rgba(16,184,148,.15),transparent),radial-gradient(ellipse 40% 50% at 100% 0%,rgba(77,163,255,.1),transparent); }
.sol-deep > * { position:relative; z-index:1; }
.sol-deep h3 { font-family:var(--display); font-size:1.6rem; font-weight:400; margin-bottom:.5rem; color:#fff !important; border:none !important; padding:0; }
.sol-deep h3 em { font-style:italic; color:var(--teal-bright); }
.sol-deep > p { color:rgba(255,255,255,.65); font-size:.95rem; margin-bottom:2rem; }

/* Deep dive tier cards */
.sol-deep-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:1rem; margin-bottom:2rem; }
.sol-deep-card { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:14px; padding:1.5rem; transition:all .3s; }
.sol-deep-card:hover { background:rgba(255,255,255,.09); transform:translateY(-3px); }
.sol-deep-card h4 { font-size:.95rem; font-weight:800; color:#fff; margin-bottom:.5rem; }
.sol-deep-card ul { list-style:none; padding:0; margin:0; }
.sol-deep-card li { font-size:.82rem; color:rgba(255,255,255,.6); padding:.2rem 0; display:flex; align-items:flex-start; gap:.4rem; }
.sol-deep-card li::before { content:"→"; color:var(--teal-bright); font-weight:700; font-size:.75rem; }
.sol-deep-card .sol-price { background:rgba(52,239,202,.12); color:var(--teal-bright); border-color:rgba(52,239,202,.2); }

/* How it helps */
.sol-helps { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; margin:1.5rem 0 2rem; }
.sol-help { background:var(--warm); border:1px solid var(--sand); border-radius:14px; padding:1.75rem; transition:all .3s; }
.sol-help:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.05); }
.sol-help__icon { font-size:1.3rem; color:var(--teal); margin-bottom:.75rem; }
.sol-help h3 { font-size:1.05rem; font-weight:800; color:var(--ink); margin:0 0 .5rem; border:none; padding:0; }
.sol-help p { font-size:.88rem; color:var(--text-soft); line-height:1.6; margin:0; }

/* Stats row */
.sol-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin:2rem 0; padding:2rem; background:var(--warm); border:1px solid var(--sand); border-radius:14px; }
.sol-stat { text-align:center; }
.sol-stat__num { font-family:var(--display); font-size:2.5rem; font-weight:700; color:var(--teal); line-height:1; margin-bottom:.3rem; }
.sol-stat__label { font-size:.82rem; color:var(--text-soft); font-weight:500; }

/* Steps */
.sol-steps { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin:1.5rem 0 2rem; }
.sol-step { text-align:center; background:var(--white); border-radius:14px; padding:2rem 1.5rem; border:1px solid var(--sand); transition:all .3s; }
.sol-step:hover { transform:translateY(-4px); box-shadow:0 12px 32px rgba(0,0,0,.05); }
.sol-step__badge { width:36px; height:36px; border-radius:50%; margin:0 auto .75rem; background:var(--ink); color:#fff; font-size:.8rem; font-weight:800; display:grid; place-items:center; }
.sol-step h3 { font-size:1.05rem; font-weight:800; color:var(--ink); margin:0 0 .4rem; border:none; padding:0; }
.sol-step p { font-size:.88rem; color:var(--text-soft); line-height:1.6; margin:0; }

/* Solutions CTA */
.sol-cta { background:linear-gradient(135deg,var(--navy),var(--slate)); border-radius:16px; padding:3.5rem; text-align:center; color:#fff; margin:3rem 0 0; position:relative; overflow:hidden; }
.sol-cta::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 50% 60% at 50% 100%,rgba(16,184,148,.12),transparent); }
.sol-cta > * { position:relative; z-index:1; }
.sol-cta h3 { font-family:var(--display); font-size:clamp(1.6rem,3.5vw,2.2rem); font-weight:400; margin-bottom:1rem; color:#fff !important; border:none; padding:0; }
.sol-cta p { color:rgba(255,255,255,.8); font-size:1.05rem; margin-bottom:2rem; }
.sol-cta strong { color:#fff; }
.sol-cta__btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* Contact bar */
.sol-contact { text-align:center; margin:2rem 0 0; padding:1.5rem; background:var(--warm); border:1px solid var(--sand); border-radius:14px; }
.sol-contact p { font-size:.9rem; color:var(--text-soft); margin:0; }
.sol-contact a { color:var(--blue); font-weight:600; }

/* Solutions responsive */
@media(max-width:768px){
    .sol-features { grid-template-columns:1fr; }
    .sol-deep-grid,.sol-helps,.sol-steps,.sol-stats { grid-template-columns:1fr; }
    .sol-deep { padding:2rem 1.5rem; }
    .sol-card__head { flex-direction:column; gap:.5rem; }
    .sol-cta { padding:2.5rem 1.5rem; }
    .sol-hero__btns,.sol-cta__btns,.sol-card__foot { flex-direction:column; align-items:stretch; }
    .sol-hero__btns .btn,.sol-cta__btns .btn,.sol-card__foot .btn { justify-content:center; }
}


/* ═══════════════════════════════════════════════
   PART 8: FEATURES PAGE STYLES (v5.4)
   ═══════════════════════════════════════════════ */

/* Hero */
.feat-hero { text-align:center; margin-bottom:3rem; }
.feat-hero .eyebrow { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--teal); margin-bottom:.75rem; display:block; }
.feat-hero h1 { font-family:var(--display); font-size:clamp(2.2rem,5vw,3rem); font-weight:400; color:var(--ink); line-height:1.15; margin-bottom:1rem; border:none; padding:0; }
.feat-hero h1 strong { font-weight:900; }
.feat-hero p { font-size:1.1rem; color:var(--text-mid); line-height:1.7; max-width:640px; margin:0 auto; }

/* Trust bar */
.feat-trust { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; margin:0 0 3.5rem; }
.feat-trust-item { background:var(--warm); border:1px solid var(--sand); border-radius:14px; padding:1.5rem; text-align:center; transition:all .3s; }
.feat-trust-item:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.04); }
.feat-trust-item i { font-size:1.2rem; color:var(--teal); margin-bottom:.6rem; display:block; }
.feat-trust-item h3 { font-size:.95rem; font-weight:800; color:var(--ink); margin:0 0 .3rem; border:none; padding:0; }
.feat-trust-item p { font-size:.82rem; color:var(--text-soft); line-height:1.5; margin:0; }

/* Product section */
.feat-product { margin-bottom:3.5rem; }
.feat-product__head { display:flex; align-items:flex-start; gap:1.5rem; margin-bottom:1.5rem; }
.feat-product__num { font-family:var(--display); font-size:3.5rem; font-weight:900; color:var(--sand); line-height:1; flex-shrink:0; transition:color .3s; }
.feat-product:hover .feat-product__num { color:var(--sky); }
.feat-product--teal:hover .feat-product__num { color:var(--teal-bright); }
.feat-product__label { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--teal); margin-bottom:.25rem; }
.feat-product__title { font-family:var(--sans); font-size:1.5rem; font-weight:800; color:var(--ink); margin-bottom:.2rem; }
.feat-product__subtitle { font-size:.95rem; color:var(--text-mid); }

/* Intro + features layout */
.feat-product__body { display:grid; grid-template-columns:1fr 1fr; gap:2rem; margin-bottom:1.5rem; }
.feat-product__intro p { color:var(--text-mid); font-size:.95rem; line-height:1.75; margin-bottom:1rem; }
.feat-product__intro p:last-child { margin-bottom:0; }

/* Feature columns */
.feat-cols { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
.feat-col h4 { font-size:.82rem; font-weight:800; text-transform:uppercase; letter-spacing:.8px; color:var(--ink); margin:0 0 .5rem; padding-bottom:.4rem; border-bottom:2px solid var(--sand); }
.feat-col ul { list-style:none; padding:0; margin:0; }
.feat-col li { display:flex; align-items:flex-start; gap:.45rem; font-size:.85rem; color:var(--text-mid); padding:.25rem 0; line-height:1.5; }
.feat-col li::before { content:"✓"; flex-shrink:0; color:var(--teal); font-weight:700; font-size:.8rem; margin-top:.1rem; }

/* Price + CTA */
.feat-product__foot { display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.feat-price { display:inline-block; background:rgba(16,184,148,.08); color:var(--teal); font-size:.82rem; font-weight:700; padding:.4rem .9rem; border-radius:50px; border:1px solid rgba(16,184,148,.15); }

/* Divider */
.feat-divider { height:1px; background:var(--sand); margin:0 0 3.5rem; border:none; }

/* Deep dive expandable */
.feat-detail { background:var(--ink); border-radius:16px; padding:0; margin-top:1.5rem; overflow:hidden; color:#fff; }
.feat-detail summary { display:flex; align-items:center; gap:.75rem; padding:1.25rem 1.75rem; cursor:pointer; font-weight:700; font-size:.9rem; color:rgba(255,255,255,.75); list-style:none; transition:all .2s; }
.feat-detail summary::-webkit-details-marker { display:none; }
.feat-detail summary::before { content:"▶"; font-size:.6rem; color:var(--teal-bright); transition:transform .2s; }
.feat-detail[open] summary::before { transform:rotate(90deg); }
.feat-detail summary:hover { color:#fff; }
.feat-detail__inner { padding:0 1.75rem 1.75rem; }
.feat-detail__grid { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
.feat-detail__col h4 { font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.6px; color:var(--teal-bright) !important; margin:0 0 .5rem; border:none !important; padding:0; }
.feat-detail__col ul { list-style:none; padding:0; margin:0; }
.feat-detail__col li { font-size:.82rem; color:rgba(255,255,255,.6); padding:.2rem 0; display:flex; align-items:flex-start; gap:.4rem; }
.feat-detail__col li::before { content:"→"; color:var(--teal-bright); font-weight:700; font-size:.7rem; }
.feat-detail__col li strong { color:rgba(255,255,255,.85); }

/* Comparison strip */
.feat-compare { background:var(--warm); border:1px solid var(--sand); border-radius:16px; padding:2.5rem; margin:3.5rem 0; text-align:center; }
.feat-compare h2 { font-family:var(--display); font-size:1.6rem; font-weight:400; color:var(--ink); margin-bottom:.5rem; border:none; padding:0; }
.feat-compare > p { color:var(--text-soft); font-size:.95rem; margin-bottom:1.5rem; max-width:500px; margin-left:auto; margin-right:auto; }
.feat-compare__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; text-align:left; }
.feat-compare__item { background:var(--white); border:1px solid var(--sand); border-radius:12px; padding:1.5rem; transition:all .3s; }
.feat-compare__item:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.04); }
.feat-compare__item h3 { font-size:.95rem; font-weight:800; color:var(--ink); margin:0 0 .75rem; border:none; padding:0; }
.feat-compare__item ul { list-style:none; padding:0; margin:0; }
.feat-compare__item li { font-size:.82rem; color:var(--text-mid); padding:.2rem 0; display:flex; align-items:flex-start; gap:.4rem; }
.feat-compare__item li::before { content:"✓"; color:var(--teal); font-weight:700; font-size:.8rem; }

/* Features CTA */
.feat-cta { background:linear-gradient(135deg,var(--navy),var(--slate)); border-radius:16px; padding:3.5rem; text-align:center; color:#fff; margin:3rem 0 0; position:relative; overflow:hidden; }
.feat-cta::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 50% 60% at 50% 100%,rgba(16,184,148,.12),transparent); }
.feat-cta > * { position:relative; z-index:1; }
.feat-cta h3 { font-family:var(--display); font-size:clamp(1.6rem,3.5vw,2.2rem); font-weight:400; margin-bottom:1rem; color:#fff !important; border:none !important; padding:0; }
.feat-cta p { color:rgba(255,255,255,.8); font-size:1.05rem; margin-bottom:2rem; }
.feat-cta strong { color:#fff; }
.feat-cta__btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* Glass button (used in dark CTAs) */
.btn--glass { background:rgba(255,255,255,.08); color:#fff; border:1.5px solid rgba(255,255,255,.15); }
.btn--glass:hover { background:rgba(255,255,255,.15); }

/* Features responsive */
@media(max-width:768px){
    .feat-trust,.feat-compare__grid { grid-template-columns:1fr; }
    .feat-product__body { grid-template-columns:1fr; }
    .feat-cols { grid-template-columns:1fr; }
    .feat-detail__grid { grid-template-columns:1fr; }
    .feat-product__head { flex-direction:column; gap:.5rem; }
    .feat-cta { padding:2.5rem 1.5rem; }
    .feat-cta__btns { flex-direction:column; align-items:stretch; }
    .feat-cta__btns .btn { justify-content:center; }
    .feat-product__foot { flex-direction:column; align-items:stretch; }
    .feat-product__foot .btn { justify-content:center; }
}


/* ═══════════════════════════════════════════════
   PART 9: PRICING PAGE STYLES (v5.5)
   ═══════════════════════════════════════════════ */

/* Hero */
.price-hero { text-align:center; margin-bottom:2.5rem; }
.price-hero .eyebrow { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--teal); margin-bottom:.75rem; display:block; }
.price-hero h1 { font-family:var(--display); font-size:clamp(2.2rem,5vw,3rem); font-weight:400; color:var(--ink); line-height:1.15; margin-bottom:1rem; border:none; padding:0; }
.price-hero h1 strong { font-weight:900; }
.price-hero > p { font-size:1.1rem; color:var(--text-mid); line-height:1.7; max-width:640px; margin:0 auto; }

/* Benefits */
.price-benefits { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin:0 0 2.5rem; }
.price-benefit { background:var(--warm); border:1px solid var(--sand); border-radius:12px; padding:1.25rem; text-align:center; transition:all .3s; }
.price-benefit:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,.04); }
.price-benefit h3 { font-size:.88rem; font-weight:800; color:var(--ink); margin:0 0 .25rem; border:none; padding:0; }
.price-benefit p { font-size:.78rem; color:var(--text-soft); line-height:1.4; margin:0; }

/* Stats */
.price-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin:0 0 3rem; padding:2rem; background:var(--ink); border-radius:16px; color:#fff; position:relative; overflow:hidden; }
.price-stats::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 40% 50% at 0% 100%,rgba(16,184,148,.15),transparent); }
.price-stats > * { position:relative; z-index:1; }
.price-stat { text-align:center; }
.price-stat__num { font-family:var(--display); font-size:2.2rem; font-weight:700; color:var(--teal-bright); line-height:1; margin-bottom:.3rem; }
.price-stat__label { font-size:.8rem; color:rgba(255,255,255,.6); font-weight:500; }

/* Selector */
.price-selector { margin:0 0 3rem; }
.price-selector h2 { font-family:var(--display); font-size:1.8rem; font-weight:400; color:var(--ink); text-align:center; margin-bottom:1.5rem; border:none; padding:0; }
.price-selector-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.25rem; }
.price-sol { background:var(--white); border:1.5px solid var(--sand); border-radius:16px; padding:2rem 1.5rem; text-align:center; cursor:pointer; transition:all .3s; position:relative; }
.price-sol:hover { transform:translateY(-4px); box-shadow:0 12px 36px rgba(0,0,0,.06); border-color:var(--blue); }
.price-sol--teal:hover { border-color:var(--teal); }
.price-sol__num { font-family:var(--display); font-size:2rem; font-weight:900; color:var(--sand); margin-bottom:.5rem; transition:color .3s; }
.price-sol:hover .price-sol__num { color:var(--sky); }
.price-sol--teal:hover .price-sol__num { color:var(--teal-bright); }
.price-sol h3 { font-size:1.05rem; font-weight:800; color:var(--ink); margin:0 0 .4rem; border:none; padding:0; }
.price-sol p { font-size:.82rem; color:var(--text-soft); line-height:1.5; margin-bottom:1rem; }
.price-sol__from { display:inline-block; background:rgba(16,184,148,.08); color:var(--teal); font-size:.78rem; font-weight:700; padding:.35rem .75rem; border-radius:50px; border:1px solid rgba(16,184,148,.15); }
.price-sol__new { position:absolute; top:-.5rem; right:1rem; background:var(--teal); color:#fff; font-size:.6rem; font-weight:800; padding:.2rem .5rem; border-radius:4px; letter-spacing:.8px; text-transform:uppercase; }

/* Sections */
.price-section { display:none; animation:priceFadeIn .3s ease; }
.price-section.active { display:block; }
@keyframes priceFadeIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }

.price-section__head { text-align:center; margin-bottom:2rem; }
.price-section__nav { display:flex; justify-content:center; gap:.75rem; margin-bottom:1.5rem; flex-wrap:wrap; }
.price-nav-btn { padding:.6rem 1.2rem; border-radius:8px; font-weight:700; font-size:.82rem; cursor:pointer; border:1.5px solid var(--sand); background:var(--white); color:var(--text-mid); transition:all .2s; font-family:var(--sans); }
.price-nav-btn:hover { border-color:var(--ink); color:var(--ink); }
.price-nav-btn--current { background:var(--ink); color:#fff; border-color:var(--ink); cursor:default; }
.price-section__title { font-family:var(--display); font-size:clamp(1.6rem,3.5vw,2.2rem); font-weight:400; color:var(--ink); margin-bottom:.5rem; border:none; padding:0; }
.price-section__sub { color:var(--text-soft); font-size:1rem; max-width:600px; margin:0 auto 1.5rem; }

/* Toggle */
.price-toggle-wrap { display:flex; justify-content:center; margin-bottom:2rem; }
.price-toggle { display:inline-flex; align-items:center; gap:1rem; background:var(--warm); padding:.6rem 1.25rem; border-radius:50px; border:1px solid var(--sand); }
.price-toggle__label { font-weight:600; font-size:.85rem; color:var(--text-soft); transition:color .2s; }
.price-toggle__label--active { color:var(--ink); }
.price-toggle__switch { position:relative; width:48px; height:26px; cursor:pointer; }
.price-toggle__switch input { opacity:0; width:0; height:0; }
.price-toggle__slider { position:absolute; cursor:pointer; inset:0; background:var(--sand); border-radius:26px; transition:.3s; }
.price-toggle__slider::before { position:absolute; content:""; height:20px; width:20px; left:3px; bottom:3px; background:#fff; border-radius:50%; transition:.3s; box-shadow:0 1px 4px rgba(0,0,0,.15); }
.price-toggle__switch input:checked + .price-toggle__slider { background:var(--teal); }
.price-toggle__switch input:checked + .price-toggle__slider::before { transform:translateX(22px); }
.price-save { font-size:.72rem; font-weight:700; color:var(--teal); background:rgba(16,184,148,.1); padding:.2rem .5rem; border-radius:4px; margin-left:.25rem; }

/* Price cards */
.price-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.5rem; margin-bottom:2rem; }
.price-card { background:var(--white); border:1.5px solid var(--sand); border-radius:16px; padding:2rem 1.75rem; display:flex; flex-direction:column; transition:all .3s; position:relative; }
.price-card:hover { transform:translateY(-4px); box-shadow:0 12px 36px rgba(0,0,0,.06); }
.price-card--featured { border-color:var(--teal); box-shadow:0 4px 20px rgba(16,184,148,.12); }
.price-card--featured::before { content:'Most Popular'; position:absolute; top:-.65rem; left:50%; transform:translateX(-50%); background:var(--teal); color:#fff; font-size:.65rem; font-weight:800; padding:.25rem .75rem; border-radius:50px; letter-spacing:.5px; text-transform:uppercase; white-space:nowrap; }
.price-card__name { font-size:1.2rem; font-weight:800; color:var(--ink); margin-bottom:.35rem; }
.price-card__desc { font-size:.85rem; color:var(--text-soft); margin-bottom:1.25rem; line-height:1.5; }
.price-card__price { margin-bottom:1.25rem; text-align:center; }
.price-card__amount { font-family:var(--display); font-size:2.8rem; font-weight:700; color:var(--ink); line-height:1; }
.price-card__amount span { font-size:.9rem; color:var(--text-soft); font-family:var(--sans); font-weight:500; }
.price-card__period { font-size:.82rem; color:var(--text-soft); margin-top:.25rem; }
.price-card__setup { font-size:.78rem; color:var(--text-soft); margin-top:.2rem; }
.price-card__features { list-style:none; padding:0; margin:0 0 1.5rem; flex-grow:1; }
.price-card__features li { display:flex; align-items:flex-start; gap:.5rem; font-size:.84rem; color:var(--text-mid); padding:.25rem 0; line-height:1.45; }
.price-card__features li::before { content:"✓"; flex-shrink:0; color:var(--teal); font-weight:700; font-size:.8rem; margin-top:.1rem; }
.price-card .btn { width:100%; justify-content:center; margin-top:auto; }

/* Enterprise card */
.price-enterprise { grid-column:1/-1; background:var(--warm); border:2px solid var(--blue); border-radius:16px; padding:2.5rem; margin-top:.5rem; }
.price-enterprise__head { background:linear-gradient(135deg,var(--navy),var(--slate)); color:#fff; border-radius:12px; padding:1.75rem; text-align:center; margin-bottom:2rem; position:relative; overflow:hidden; }
.price-enterprise__head::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 50% 60% at 50% 100%,rgba(16,184,148,.12),transparent); }
.price-enterprise__head > * { position:relative; z-index:1; }
.price-enterprise__head h3 { font-family:var(--display); font-size:1.5rem; font-weight:400; margin-bottom:.25rem; color:#fff !important; border:none !important; padding:0; }
.price-enterprise__head p { color:rgba(255,255,255,.7); font-size:.9rem; margin:0; }
.price-enterprise__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-bottom:1.5rem; }
.price-enterprise__col { background:var(--white); border:1px solid var(--sand); border-radius:12px; padding:1.5rem; }
.price-enterprise__col h4 { font-size:.95rem; font-weight:800; color:var(--ink); margin:0 0 .75rem; border:none; padding:0; }
.price-enterprise__col ul { list-style:none; padding:0; margin:0; }
.price-enterprise__col li { display:flex; align-items:flex-start; gap:.4rem; font-size:.82rem; color:var(--text-mid); padding:.2rem 0; }
.price-enterprise__col li::before { content:"✓"; color:var(--teal); font-weight:700; font-size:.8rem; }
.price-enterprise .btn { max-width:350px; margin:0 auto; display:flex; }

/* Sectors bar */
.price-sectors { background:var(--warm); border:1px solid var(--sand); border-radius:14px; padding:2rem; text-align:center; margin-top:1rem; }
.price-sectors p { font-size:.95rem; color:var(--text-mid); margin:0; }

/* Pricing CTA */
.price-cta { background:linear-gradient(135deg,var(--navy),var(--slate)); border-radius:16px; padding:3.5rem; text-align:center; color:#fff; margin:3rem 0 0; position:relative; overflow:hidden; }
.price-cta::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 50% 60% at 50% 100%,rgba(16,184,148,.12),transparent); }
.price-cta > * { position:relative; z-index:1; }
.price-cta h3 { font-family:var(--display); font-size:clamp(1.6rem,3.5vw,2.2rem); font-weight:400; margin-bottom:1rem; color:#fff !important; border:none !important; padding:0; }
.price-cta p { color:rgba(255,255,255,.8); font-size:1.05rem; margin-bottom:2rem; }
.price-cta strong { color:#fff; }
.price-cta__btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* Pricing case study inline */
.price-case { display:grid; grid-template-columns:180px 1fr; gap:0; background:var(--white); border:1.5px solid var(--sand); border-radius:18px; overflow:hidden; margin-top:1.5rem; box-shadow:0 4px 20px rgba(0,0,0,.04); }
.price-case__left { background:linear-gradient(135deg,var(--navy),var(--slate),#1a6db5); color:#fff; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:2rem; text-align:center; }
.price-case__num { font-family:var(--display); font-size:4.5rem; font-weight:900; color:var(--teal-bright); line-height:1; text-shadow:0 0 30px rgba(52,239,202,.3); }
.price-case__label { font-size:.7rem; color:rgba(255,255,255,.5); font-weight:600; text-transform:uppercase; letter-spacing:1px; margin-top:.25rem; line-height:1.3; }
.price-case__right { padding:2rem 2.5rem; display:flex; flex-direction:column; justify-content:center; }
.price-case__tag { display:inline-block; align-self:flex-start; background:rgba(16,184,148,.1); color:var(--teal); font-size:.65rem; font-weight:800; padding:.2rem .5rem; border-radius:4px; letter-spacing:.8px; text-transform:uppercase; margin-bottom:.6rem; border:1px solid rgba(16,184,148,.2); }
.price-case__right h4 { font-family:var(--display); font-size:1.35rem; font-weight:700; color:var(--ink); margin:0 0 .5rem; border:none; padding:0; }
.price-case__right p { font-size:.9rem; color:var(--text-mid); line-height:1.65; margin:0 0 1rem; }
.price-case__foot { display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.price-case__src { font-size:.8rem; color:var(--text-soft); font-weight:600; }
.price-case__src strong { color:var(--ink); }

/* Pricing responsive */
@media(max-width:1024px){ .price-selector-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:768px){
    .price-benefits,.price-stats { grid-template-columns:1fr; }
    .price-selector-grid { grid-template-columns:1fr; }
    .price-grid { grid-template-columns:1fr; }
    .price-enterprise__grid { grid-template-columns:1fr; }
    .price-section__nav { flex-direction:column; align-items:center; }
    .price-cta { padding:2.5rem 1.5rem; }
    .price-cta__btns { flex-direction:column; align-items:stretch; }
    .price-cta__btns .btn { justify-content:center; }
    .price-case { grid-template-columns:1fr; }
    .price-case__right { padding:1.5rem; }
    .price-case__foot { flex-direction:column; align-items:flex-start; }
}


/* ═══════════════════════════════════════════════
   PART 10: CONTACT PAGE STYLES (v5.7)
   ═══════════════════════════════════════════════ */

/* Hero */
.ct-hero { text-align:center; margin-bottom:3rem; }
.ct-eyebrow { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--teal); margin-bottom:.75rem; display:block; }
.ct-hero h1 { font-family:var(--display); font-size:clamp(2rem,5vw,2.8rem); font-weight:400; color:var(--ink); line-height:1.2; margin-bottom:1rem; border:none; padding:0; }
.ct-hero h1 em { font-style:italic; font-weight:400; }
.ct-hero > p { font-size:1.05rem; color:var(--text-mid); line-height:1.7; max-width:580px; margin:0 auto; }

/* Contact cards */
.ct-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; margin-bottom:2rem; }
.ct-card { background:var(--white); border:1.5px solid var(--sand); border-radius:16px; padding:2rem 1.5rem; text-align:center; text-decoration:none; transition:all .3s; display:flex; flex-direction:column; align-items:center; }
.ct-card:hover { transform:translateY(-4px); box-shadow:0 12px 36px rgba(0,0,0,.06); border-color:var(--teal); }
.ct-card__icon { width:52px; height:52px; border-radius:14px; background:rgba(16,184,148,.08); color:var(--teal); display:flex; align-items:center; justify-content:center; font-size:1.25rem; margin-bottom:1rem; }
.ct-card:hover .ct-card__icon { background:var(--teal); color:#fff; }
.ct-card h3 { font-size:1.05rem; font-weight:800; color:var(--ink); margin:0 0 .4rem; border:none; padding:0; }
.ct-card p { font-size:.85rem; color:var(--text-soft); line-height:1.5; margin:0 0 .75rem; flex-grow:1; }
.ct-card__link { font-size:.82rem; font-weight:700; color:var(--teal); }
.ct-card:hover .ct-card__link { color:var(--ink); }

/* Quick contact bar */
.ct-quick { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-bottom:2.5rem; }
.ct-quick__item { display:flex; align-items:center; gap:.75rem; padding:1.25rem; background:var(--warm); border:1px solid var(--sand); border-radius:12px; text-decoration:none; color:var(--text); transition:all .3s; }
a.ct-quick__item:hover { border-color:var(--teal); transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,.04); }
.ct-quick__item i { font-size:1.2rem; color:var(--teal); flex-shrink:0; width:24px; text-align:center; }
.ct-quick__item strong { display:block; font-size:.9rem; font-weight:700; color:var(--ink); line-height:1.3; }
.ct-quick__item span { display:block; font-size:.75rem; color:var(--text-soft); font-weight:500; }

/* Office */
.ct-office { display:grid; grid-template-columns:auto 1fr; gap:0; background:var(--white); border:1.5px solid var(--sand); border-radius:16px; overflow:hidden; margin-bottom:2.5rem; }
.ct-office__map { background:linear-gradient(135deg,var(--navy),var(--slate)); color:rgba(255,255,255,.3); display:flex; align-items:center; justify-content:center; padding:2.5rem; font-size:3rem; min-width:140px; }
.ct-office__info { padding:2rem 2.5rem; }
.ct-office__info h3 { font-family:var(--display); font-size:1.2rem; font-weight:700; color:var(--ink); margin:0 0 .5rem; border:none; padding:0; }
.ct-office__info p { font-size:.92rem; color:var(--text-mid); line-height:1.6; margin:0 0 .5rem; }
.ct-office__reg { font-size:.78rem !important; color:var(--text-soft) !important; margin-top:.5rem !important; }
.ct-office__link { display:inline-flex; align-items:center; gap:.35rem; font-size:.85rem; font-weight:700; color:var(--teal); text-decoration:none; margin-top:.5rem; }
.ct-office__link:hover { color:var(--ink); }

/* Form */
.ct-form-section { margin-bottom:2.5rem; }
.ct-form-section h2 { font-family:var(--display); font-size:1.5rem; font-weight:700; color:var(--ink); margin-bottom:.35rem; border:none; padding:0; }
.ct-form-section > p { font-size:.92rem; color:var(--text-soft); margin-bottom:1.5rem; }
.ct-form { background:var(--warm); border:1px solid var(--sand); border-radius:16px; padding:2rem; }
.ct-form__row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.ct-form__group { margin-bottom:1rem; }
.ct-form__group label { display:block; font-size:.82rem; font-weight:700; color:var(--ink); margin-bottom:.35rem; }
.ct-form__group input,
.ct-form__group textarea { width:100%; padding:.75rem 1rem; border:1.5px solid var(--sand); border-radius:10px; font-family:var(--sans); font-size:.9rem; color:var(--text); background:var(--white); transition:border-color .2s; }
.ct-form__group input:focus,
.ct-form__group textarea:focus { outline:none; border-color:var(--teal); box-shadow:0 0 0 3px rgba(16,184,148,.1); }
.ct-form__group textarea { resize:vertical; min-height:100px; }

/* CTA */
.ct-cta { background:linear-gradient(135deg,var(--navy),var(--slate)); border-radius:16px; padding:3rem; text-align:center; color:#fff; position:relative; overflow:hidden; }
.ct-cta::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 50% 60% at 50% 100%,rgba(16,184,148,.12),transparent); }
.ct-cta > * { position:relative; z-index:1; }
.ct-cta h3 { font-family:var(--display); font-size:1.5rem; font-weight:400; margin-bottom:.75rem; color:#fff !important; border:none !important; padding:0; }
.ct-cta p { color:rgba(255,255,255,.8); font-size:.95rem; margin-bottom:1.75rem; max-width:500px; margin-left:auto; margin-right:auto; }
.ct-cta__btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* Contact responsive */
@media(max-width:768px){
    .ct-cards { grid-template-columns:1fr; }
    .ct-quick { grid-template-columns:1fr; }
    .ct-office { grid-template-columns:1fr; }
    .ct-office__map { min-width:auto; padding:1.5rem; font-size:2rem; }
    .ct-office__info { padding:1.5rem; }
    .ct-form__row { grid-template-columns:1fr; }
    .ct-cta { padding:2rem 1.5rem; }
    .ct-cta__btns { flex-direction:column; align-items:stretch; }
    .ct-cta__btns .btn { justify-content:center; }
}


/* ═══════════════════════════════════════════════
   PART 11: FAQ PAGE STYLES (v5.10)
   ═══════════════════════════════════════════════ */

/* Hero */
.faq-hero { text-align:center; margin-bottom:3rem; }
.faq-eyebrow { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--teal); margin-bottom:.75rem; display:block; }
.faq-hero h1 { font-family:var(--display); font-size:clamp(2rem,5vw,2.8rem); font-weight:400; color:var(--ink); line-height:1.2; margin-bottom:1rem; border:none; padding:0; }
.faq-hero h1 em { font-style:italic; font-weight:400; }
.faq-hero > p { font-size:1.05rem; color:var(--text-mid); line-height:1.7; max-width:580px; margin:0 auto 1.5rem; }

/* Chatbot hint */
.faq-chatbot-hint {
    display:inline-flex; align-items:flex-start; gap:.75rem;
    background:rgba(16,184,148,.06); border:1.5px solid rgba(16,184,148,.15);
    border-radius:14px; padding:1rem 1.5rem; max-width:560px; text-align:left;
}
.faq-chatbot-hint i { color:var(--teal); font-size:1.2rem; flex-shrink:0; margin-top:.15rem; }
.faq-chatbot-hint span { font-size:.88rem; color:var(--text-mid); line-height:1.55; }
.faq-chatbot-hint em { font-style:italic; color:var(--teal); font-weight:600; }

/* FAQ list */
.faq-list { margin-bottom:2.5rem; }

/* FAQ item */
.faq-item { background:var(--white); border:1.5px solid var(--sand); border-radius:14px; margin-bottom:1rem; transition:all .3s; overflow:hidden; }
.faq-item:hover { border-color:var(--blue); box-shadow:0 6px 20px rgba(0,0,0,.04); }
.faq-item--open { border-color:var(--teal); box-shadow:0 6px 24px rgba(16,184,148,.08); }
.faq-item button { width:100%; background:none; border:none; padding:1.25rem 1.5rem; font-size:1rem; font-weight:700; color:var(--ink); display:flex; justify-content:space-between; align-items:center; cursor:pointer; text-align:left; font-family:var(--sans); gap:1rem; transition:background .2s; }
.faq-item button:hover { background:var(--warm); }
.faq-item button i { color:var(--teal); font-size:.75rem; transition:transform .3s; flex-shrink:0; }
.faq-item--open button i { transform:rotate(180deg); }

/* FAQ answer */
.faq-answer { max-height:0; overflow:hidden; transition:max-height .35s ease, padding .35s ease; padding:0 1.5rem; }
.faq-answer--open { max-height:2000px; padding:0 1.5rem 1.5rem; }
.faq-answer p { font-size:.92rem; color:var(--text-mid); line-height:1.7; margin-bottom:.75rem; }
.faq-answer ul { list-style:none; padding:0; margin:0 0 .75rem; }
.faq-answer li { display:flex; align-items:flex-start; gap:.5rem; font-size:.88rem; color:var(--text-mid); padding:.2rem 0; line-height:1.5; }
.faq-answer li::before { content:"✓"; flex-shrink:0; color:var(--teal); font-weight:700; font-size:.8rem; margin-top:.15rem; }
.faq-answer a { color:var(--teal); font-weight:700; text-decoration:none; }
.faq-answer a:hover { color:var(--ink); text-decoration:underline; }
.faq-answer strong { color:var(--ink); }

/* Highlight box */
.faq-highlight { background:var(--warm); border:1px solid var(--sand); border-radius:12px; padding:1.25rem 1.5rem; margin:.75rem 0 1rem; }
.faq-highlight h4 { font-size:.88rem; font-weight:800; color:var(--ink); margin:0 0 .5rem; border:none; padding:0; }

/* Success box */
.faq-success { background:rgba(16,184,148,.06); border-left:4px solid var(--teal); border-radius:8px; padding:1rem 1.25rem; margin:0 0 1rem; }
.faq-success strong { display:block; color:var(--teal); font-size:.92rem; margin-bottom:.25rem; }
.faq-success p { margin:0; font-size:.88rem; }

/* Stats row */
.faq-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:.75rem; margin-bottom:1rem; }
.faq-stat { background:var(--warm); border:1px solid var(--sand); border-radius:10px; padding:1rem; text-align:center; border-left:3px solid var(--teal); }
.faq-stat strong { display:block; font-size:.85rem; font-weight:800; color:var(--ink); margin-bottom:.15rem; }
.faq-stat span { font-size:.8rem; color:var(--teal); font-weight:700; }

/* Products grid */
.faq-products { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; margin:.75rem 0 1rem; }
.faq-prod { background:var(--warm); border:1px solid var(--sand); border-radius:10px; padding:1rem 1.25rem; }
.faq-prod strong { display:block; font-size:.88rem; font-weight:800; color:var(--ink); margin-bottom:.2rem; }
.faq-prod span { font-size:.82rem; color:var(--text-soft); line-height:1.45; }

/* Sectors tags */
.faq-sectors { display:flex; flex-wrap:wrap; gap:.5rem; margin:.5rem 0; }
.faq-sectors span { background:var(--warm); border:1px solid var(--sand); border-radius:50px; padding:.35rem .85rem; font-size:.8rem; font-weight:600; color:var(--text-mid); }

/* CTA */
.faq-cta { background:linear-gradient(135deg,var(--navy),var(--slate)); border-radius:16px; padding:3rem; text-align:center; color:#fff; position:relative; overflow:hidden; }
.faq-cta::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 50% 60% at 50% 100%,rgba(16,184,148,.12),transparent); }
.faq-cta > * { position:relative; z-index:1; }
.faq-cta h3 { font-family:var(--display); font-size:1.5rem; font-weight:400; margin-bottom:.75rem; color:#fff !important; border:none !important; padding:0; }
.faq-cta p { color:rgba(255,255,255,.8); font-size:.95rem; margin-bottom:1.75rem; max-width:520px; margin-left:auto; margin-right:auto; }
.faq-cta em { font-style:italic; color:var(--teal-bright); }
.faq-cta__btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* FAQ responsive */
@media(max-width:768px){
    .faq-stats { grid-template-columns:1fr; }
    .faq-products { grid-template-columns:1fr; }
    .faq-cta { padding:2rem 1.5rem; }
    .faq-cta__btns { flex-direction:column; align-items:stretch; }
    .faq-cta__btns .btn { justify-content:center; }
    .faq-chatbot-hint { flex-direction:column; text-align:center; align-items:center; }
}


/* ═══════════════════════════════════════════════
   PART 12: GDPR PAGE STYLES (v5.11)
   ═══════════════════════════════════════════════ */

/* Hero */
.gdpr-hero { text-align:center; margin-bottom:3rem; }
.gdpr-shield { width:64px; height:64px; border-radius:18px; background:rgba(16,184,148,.08); color:var(--teal); display:flex; align-items:center; justify-content:center; font-size:1.6rem; margin:0 auto 1rem; border:1.5px solid rgba(16,184,148,.15); }
.gdpr-eyebrow { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--teal); margin-bottom:.75rem; display:block; }
.gdpr-hero h1 { font-family:var(--display); font-size:clamp(2rem,5vw,2.8rem); font-weight:400; color:var(--ink); line-height:1.2; margin-bottom:1rem; border:none; padding:0; }
.gdpr-hero h1 em { font-style:italic; font-weight:400; }
.gdpr-hero > p { font-size:1rem; color:var(--text-mid); line-height:1.7; max-width:620px; margin:0 auto 1.25rem; }
.gdpr-badges { display:flex; flex-wrap:wrap; gap:.5rem; justify-content:center; margin-bottom:1rem; }
.gdpr-badges span { display:inline-flex; align-items:center; gap:.35rem; background:var(--warm); border:1px solid var(--sand); border-radius:50px; padding:.4rem .85rem; font-size:.75rem; font-weight:700; color:var(--ink); }
.gdpr-badges i { color:var(--teal); font-size:.7rem; }
.gdpr-date { font-size:.8rem; color:var(--text-soft); font-weight:600; }

/* Sections */
.gdpr-sections { margin-bottom:2.5rem; }

/* Card */
.gdpr-card { background:var(--white); border:1.5px solid var(--sand); border-radius:16px; padding:2rem; margin-bottom:1.25rem; position:relative; transition:all .3s; }
.gdpr-card:hover { border-color:var(--blue); box-shadow:0 6px 20px rgba(0,0,0,.04); }
.gdpr-card--highlight { background:var(--warm); border-color:var(--teal); }
.gdpr-card__num { position:absolute; top:1.25rem; right:1.5rem; font-family:var(--display); font-size:1.5rem; font-weight:900; color:var(--sand); line-height:1; }
.gdpr-card:hover .gdpr-card__num { color:var(--sky); }
.gdpr-card--highlight .gdpr-card__num { color:rgba(16,184,148,.2); }
.gdpr-card h2 { font-family:var(--display); font-size:1.2rem; font-weight:700; color:var(--ink); margin:0 0 .75rem; padding-right:3rem; border:none; padding-top:0; }
.gdpr-card p { font-size:.92rem; color:var(--text-mid); line-height:1.7; margin-bottom:.75rem; }
.gdpr-card p:last-child { margin-bottom:0; }
.gdpr-card ul { list-style:none; padding:0; margin:0 0 .75rem; }
.gdpr-card ul:last-child { margin-bottom:0; }
.gdpr-card li { display:flex; align-items:flex-start; gap:.5rem; font-size:.88rem; color:var(--text-mid); padding:.25rem 0; line-height:1.55; }
.gdpr-card li::before { content:"✓"; flex-shrink:0; color:var(--teal); font-weight:700; font-size:.8rem; margin-top:.15rem; }
.gdpr-card strong { color:var(--ink); }
.gdpr-card a { color:var(--teal); font-weight:700; text-decoration:none; }
.gdpr-card a:hover { color:var(--ink); text-decoration:underline; }

/* Note box */
.gdpr-note { background:var(--warm); border:1px solid var(--sand); border-radius:10px; padding:1.25rem; margin-top:.75rem; }
.gdpr-note h4 { font-size:.85rem; font-weight:800; color:var(--ink); margin:0 0 .5rem; border:none; padding:0; }

/* Rights grid */
.gdpr-rights { display:grid; grid-template-columns:repeat(3,1fr); gap:.6rem; margin:.75rem 0 1rem; }
.gdpr-right { background:var(--warm); border:1px solid var(--sand); border-radius:10px; padding:.85rem 1rem; }
.gdpr-right strong { display:block; font-size:.82rem; font-weight:800; color:var(--ink); margin-bottom:.15rem; }
.gdpr-right span { font-size:.78rem; color:var(--text-soft); line-height:1.4; }

/* Contact box */
.gdpr-contact { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; margin:0 0 1rem; }
.gdpr-contact__item { display:flex; align-items:center; gap:.75rem; background:var(--warm); border:1px solid var(--sand); border-radius:10px; padding:1rem; }
.gdpr-contact__item i { color:var(--teal); font-size:1.1rem; flex-shrink:0; }
.gdpr-contact__item strong { display:block; font-size:.82rem; font-weight:700; color:var(--ink); margin-bottom:.1rem; }

/* Footer */
.gdpr-footer { text-align:center; padding:1.5rem; background:var(--warm); border:1px solid var(--sand); border-radius:12px; }
.gdpr-footer p { font-size:.82rem; color:var(--text-soft); line-height:1.5; margin:0; }

/* GDPR responsive */
@media(max-width:768px){
    .gdpr-rights { grid-template-columns:1fr 1fr; }
    .gdpr-contact { grid-template-columns:1fr; }
    .gdpr-badges { flex-direction:column; align-items:center; }
}
@media(max-width:480px){
    .gdpr-rights { grid-template-columns:1fr; }
    .gdpr-card { padding:1.5rem; }
}


/* ═══════════════════════════════════════════════
   PART 13: SHARED LEGAL PAGE STYLES (v5.12)
   Terms, Privacy, Refund, AI Disclaimer
   ═══════════════════════════════════════════════ */

/* Hero */
.legal-hero { text-align:center; margin-bottom:3rem; }
.legal-icon { width:64px; height:64px; border-radius:18px; background:var(--warm); color:var(--blue); display:flex; align-items:center; justify-content:center; font-size:1.6rem; margin:0 auto 1rem; border:1.5px solid var(--sand); }
.legal-eyebrow { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--teal); margin-bottom:.75rem; display:block; }
.legal-hero h1 { font-family:var(--display); font-size:clamp(2rem,5vw,2.8rem); font-weight:400; color:var(--ink); line-height:1.2; margin-bottom:1rem; border:none; padding:0; }
.legal-hero h1 em { font-style:italic; font-weight:400; }
.legal-hero > p { font-size:1rem; color:var(--text-mid); line-height:1.7; max-width:600px; margin:0 auto 1rem; }
.legal-date { font-size:.8rem; color:var(--text-soft); font-weight:600; }

/* Sections */
.legal-sections { margin-bottom:2.5rem; }

/* Card */
.legal-card { background:var(--white); border:1.5px solid var(--sand); border-radius:16px; padding:2rem; margin-bottom:1.25rem; position:relative; transition:all .3s; }
.legal-card:hover { border-color:var(--blue); box-shadow:0 6px 20px rgba(0,0,0,.04); }
.legal-card--highlight { background:var(--warm); border-color:var(--blue); }
.legal-card__num { position:absolute; top:1.25rem; right:1.5rem; font-family:var(--display); font-size:1.5rem; font-weight:900; color:var(--sand); line-height:1; }
.legal-card:hover .legal-card__num { color:var(--sky); }
.legal-card h2 { font-family:var(--display); font-size:1.2rem; font-weight:700; color:var(--ink); margin:0 0 .75rem; padding-right:3rem; border:none; padding-top:0; }
.legal-card p { font-size:.92rem; color:var(--text-mid); line-height:1.7; margin-bottom:.75rem; }
.legal-card p:last-child { margin-bottom:0; }
.legal-card ul { list-style:none; padding:0; margin:0 0 .75rem; }
.legal-card ul:last-child { margin-bottom:0; }
.legal-card li { display:flex; align-items:flex-start; gap:.5rem; font-size:.88rem; color:var(--text-mid); padding:.25rem 0; line-height:1.55; }
.legal-card li::before { content:"✓"; flex-shrink:0; color:var(--teal); font-weight:700; font-size:.8rem; margin-top:.15rem; }
.legal-card strong { color:var(--ink); }
.legal-card a { color:var(--teal); font-weight:700; text-decoration:none; }
.legal-card a:hover { color:var(--ink); text-decoration:underline; }

/* Note box */
.legal-note { background:rgba(26,109,181,.05); border:1px solid rgba(26,109,181,.15); border-radius:10px; padding:1.25rem; margin:.75rem 0; }
.legal-note h4 { font-size:.85rem; font-weight:800; color:var(--blue); margin:0 0 .5rem; border:none; padding:0; }
.legal-note p { margin-bottom:0; }

/* Contact grid */
.legal-contact { display:grid; grid-template-columns:repeat(3,1fr); gap:.75rem; margin:.75rem 0; }
.legal-contact__item { display:flex; align-items:flex-start; gap:.75rem; background:var(--warm); border:1px solid var(--sand); border-radius:10px; padding:1rem; }
.legal-contact__item i { color:var(--teal); font-size:1rem; flex-shrink:0; margin-top:.15rem; }
.legal-contact__item strong { display:block; font-size:.82rem; font-weight:700; color:var(--ink); margin-bottom:.1rem; }
.legal-contact__item div { font-size:.85rem; color:var(--text-mid); line-height:1.5; }

/* Footer */
.legal-footer { text-align:center; padding:1.5rem; background:var(--warm); border:1px solid var(--sand); border-radius:12px; }
.legal-footer p { font-size:.82rem; color:var(--text-soft); line-height:1.5; margin:0; }

/* Legal responsive */
@media(max-width:768px){
    .legal-contact { grid-template-columns:1fr; }
    .legal-card { padding:1.5rem; }
}
