/*
Theme Name: Token Market Maker
Theme URI: https://tokenmarketmaker.io
Author: SevenHash
Author URI: https://www.sevenhash.com
Description: White/Black/Green. Cormorant Garamond + Outfit. Clean grid animation on dark sections only. Blog sidebar + social share + related posts. 100% WordPress editable. Mobile/iPad/Desktop ready.
Version: 6.0.0
License: GNU General Public License v2 or later
Text Domain: tokenmarketmaker
*/

/* ── TOKENS ─────────────────────────────────────── */
:root {
  /* Backgrounds */
  --bg:   #ffffff;
  --bg2:  #f6f6f6;
  --bg3:  #eeeeee;
  --blk:  #111111;
  --blk2: #1a1a1a;
  --blk3: #252525;
  /* Green accent */
  --grn:  #00c853;
  --grn2: #00e676;
  --gb:   rgba(0,200,83,0.07);
  --gbr:  rgba(0,200,83,0.22);
  /* Text */
  --text:  #444444;
  --text2: #777777;
  --text3: #aaaaaa;
  /* Borders */
  --bdr:  rgba(0,0,0,0.09);
  --bdr2: rgba(0,0,0,0.18);
  /* Fonts */
  --fh: 'Cormorant Garamond','Playfair Display',Georgia,serif;
  --fb: 'Outfit','DM Sans',system-ui,sans-serif;
  --fm: 'Fira Code',monospace;
  /* Shape */
  --r:  10px;
  --rl: 16px;
  --rx: 24px;
  /* Motion */
  --ease: cubic-bezier(0.4,0,0.2,1);
  --t:    0.3s cubic-bezier(0.4,0,0.2,1);
  /* Spacing — overridden by Customizer */
  --sp:  120px;
  --gap: 28px;
  --cp:  36px;
}

/* ── RESET ──────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body { background:var(--bg); color:var(--text); font-family:var(--fb); font-size:17px; line-height:1.75; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
a { color:var(--blk); text-decoration:none; transition:color var(--t); }
a:hover { color:var(--grn); }
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
h1,h2,h3,h4,h5,h6 { font-family:var(--fh); color:var(--blk); line-height:1.1; font-weight:600; }

/* ── LAYOUT ─────────────────────────────────────── */
.wrap { max-width:1200px; margin:0 auto; padding:0 40px; }
.tmm-section { padding:var(--sp) 0; position:relative; z-index:1; overflow:hidden; }
.s-dark { background:var(--blk); }
.s-grey { background:var(--bg2); }
.tmm-center { text-align:center; }
.tmm-center .tmm-desc,
.tmm-center .tmm-desc-w { margin-left:auto; margin-right:auto; }
/* Section separators */
.tmm-section + .tmm-section { border-top:1px solid var(--bdr); }
.s-dark + .s-dark,
.s-dark + .tmm-section,
.tmm-section + .s-dark { border-top:none; }
/* Section alias for older templates */
section.section { padding:var(--sp) 0; position:relative; z-index:1; overflow:hidden; }

/* ── GRID ANIMATION — DARK SECTIONS ONLY ─────────── */
/* Only used inside .s-dark sections — green tinted grid */
.grid-dark {
  position:absolute; inset:0; pointer-events:none; z-index:0; overflow:hidden;
}
.grid-dark::before {
  content:'';
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(0,200,83,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,200,83,0.06) 1px, transparent 1px);
  background-size:52px 52px;
  animation:gridMove 20s linear infinite;
}
@keyframes gridMove { 0%{background-position:0 0} 100%{background-position:52px 52px} }

/* Floating dots for dark sections hero-like areas */
.float-dot {
  position:absolute; width:3px; height:3px; border-radius:50%;
  background:var(--grn); opacity:0;
  animation:floatUp 5s ease-in-out infinite;
}
@keyframes floatUp {
  0%  { opacity:0; transform:translateY(0) scale(0.5); }
  40% { opacity:0.6; }
  100%{ opacity:0; transform:translateY(-60px) scale(1.5); }
}

/* ── TYPOGRAPHY ─────────────────────────────────── */
.eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--fm); font-size:11px; font-weight:500;
  letter-spacing:.22em; text-transform:uppercase; color:var(--grn); margin-bottom:18px;
}
.eyebrow::before,.eyebrow::after { content:''; display:block; width:22px; height:1.5px; background:var(--grn); opacity:.5; }
.eyebrow-w {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--fm); font-size:11px; font-weight:500;
  letter-spacing:.22em; text-transform:uppercase; color:var(--grn2); margin-bottom:18px;
}
.eyebrow-w::before,.eyebrow-w::after { content:''; display:block; width:22px; height:1.5px; background:var(--grn2); opacity:.4; }
.h1   { font-family:var(--fh); font-size:clamp(52px,8.5vw,108px); font-weight:600; line-height:1.0; letter-spacing:-.03em; color:var(--blk); }
.h2   { font-family:var(--fh); font-size:clamp(36px,5vw,62px); font-weight:600; line-height:1.07; color:var(--blk); }
.h2-w { font-family:var(--fh); font-size:clamp(36px,5vw,62px); font-weight:600; line-height:1.07; color:#ffffff; }
.gi   { color:var(--grn); font-style:italic; }
.gi-w { color:var(--grn2); font-style:italic; }
.tmm-desc   { font-size:18px; line-height:1.85; color:var(--text);  max-width:620px; font-family:var(--fb); }
.tmm-desc-w { font-size:17px; line-height:1.85; color:#999999; max-width:620px; font-family:var(--fb); }
.div-line   { width:48px; height:2.5px; background:var(--grn); margin:18px 0; border-radius:2px; }
.div-line.c { margin-left:auto; margin-right:auto; }
.green-t    { color:var(--grn); font-weight:600; }
.red-t      { color:#e24b4a; }

/* ── ANIMATIONS ─────────────────────────────────── */
@keyframes fadeInUp  { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
@keyframes botFloat  { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }
@keyframes glowGrn   { 0%,100%{filter:drop-shadow(0 0 18px rgba(0,200,83,.25))} 50%{filter:drop-shadow(0 0 38px rgba(0,200,83,.55))} }
@keyframes pulse     { 0%,100%{box-shadow:0 0 0 0 rgba(0,200,83,.5)} 70%{box-shadow:0 0 0 8px rgba(0,200,83,0)} }
@keyframes marquee   { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
@keyframes barGrow   { from{height:0} to{height:var(--bh,30px)} }
@keyframes scanLine  { 0%{transform:translateY(0);opacity:.5} 100%{transform:translateY(130px);opacity:0} }

.reveal   { opacity:0; transform:translateY(24px); transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal.in { opacity:1; transform:translateY(0); }
.reveal-l  { opacity:0; transform:translateX(-28px); transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal-l.in { opacity:1; transform:translateX(0); }
.reveal-r  { opacity:0; transform:translateX(28px); transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal-r.in { opacity:1; transform:translateX(0); }
.d1{transition-delay:.07s} .d2{transition-delay:.14s} .d3{transition-delay:.21s}
.d4{transition-delay:.28s} .d5{transition-delay:.35s} .d6{transition-delay:.42s}

/* ── BUTTONS ─────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:15px 34px; border-radius:var(--r); font-family:var(--fb); font-weight:700;
  font-size:15px; cursor:pointer; text-decoration:none; transition:all var(--t);
  white-space:nowrap; letter-spacing:.02em; border:2px solid transparent;
}
.btn-blk { background:var(--blk); color:#fff; border-color:var(--blk); }
.btn-blk:hover { background:var(--blk2); border-color:var(--blk2); color:#fff; box-shadow:0 6px 24px rgba(0,0,0,.2); }
.btn-grn { background:var(--grn); color:var(--blk); border-color:var(--grn); font-weight:800; }
.btn-grn:hover { background:var(--grn2); border-color:var(--grn2); color:var(--blk); box-shadow:0 6px 24px rgba(0,200,83,.3); }
.btn-outline { background:transparent; color:var(--blk); border:2px solid var(--blk); }
.btn-outline:hover { background:var(--blk); color:#fff; }
.btn-outline-w { background:transparent; color:#fff; border:2px solid rgba(255,255,255,.3); }
.btn-outline-w:hover { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.6); color:#fff; }
.btn-lg { padding:18px 44px; font-size:17px; }
.btn-sm { padding:10px 22px; font-size:13px; }

/* ── CARDS ───────────────────────────────────────── */
.card {
  background:var(--bg); border:1px solid var(--bdr); border-radius:var(--rl);
  padding:var(--cp); transition:border-color var(--t),box-shadow var(--t);
  position:relative; overflow:hidden;
}
.card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2.5px;
  background:var(--grn); opacity:0; transition:opacity var(--t);
}
.card:hover { border-color:var(--gbr); box-shadow:0 0 0 3px rgba(0,200,83,.07),0 8px 28px rgba(0,0,0,.05); }
.card:hover::before { opacity:1; }
.card-icon { width:54px; height:54px; background:var(--gb); border:1px solid var(--gbr); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:22px; }
.card h4 { font-family:var(--fh); font-size:22px; margin-bottom:12px; color:var(--blk); }
.card p  { font-size:15px; color:var(--text2); line-height:1.75; }

/* ── HEADER — ALWAYS WHITE ───────────────────────── */
#hdr {
  position:fixed; top:0; left:0; right:0; z-index:9999;
  background:#ffffff;
  border-bottom:1px solid var(--bdr);
  transition:box-shadow var(--t);
}
#hdr.scrolled { box-shadow:0 2px 20px rgba(0,0,0,.1); }
.hdr-bar { padding:18px 0; }
.nav-row { display:flex; align-items:center; justify-content:space-between; gap:24px; }
.logo { display:flex; align-items:center; gap:12px; text-decoration:none; flex-shrink:0; }
.logo-mark {
  width:46px; height:46px; background:var(--blk); border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--fm); font-size:12px; font-weight:800; color:var(--grn);
  letter-spacing:.03em; flex-shrink:0;
}
.logo img { max-height:50px; width:auto; }
.logo-txt { font-family:var(--fh); font-size:20px; font-weight:700; color:var(--blk); line-height:1.1; }
.logo-txt span { display:block; font-family:var(--fb); font-size:10px; font-weight:400; letter-spacing:.18em; text-transform:uppercase; color:var(--text3); margin-top:2px; }
.mnav { display:flex; align-items:center; gap:2px; flex:1; justify-content:center; }
.mnav a { font-size:14px; font-weight:500; color:var(--text2); padding:8px 14px; border-radius:8px; transition:all var(--t); font-family:var(--fb); }
.mnav a:hover,.mnav a.active { color:var(--blk); background:var(--bg2); }
.ncta { flex-shrink:0; }
.ham { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; background:none; border:none; }
.ham span { display:block; width:22px; height:1.5px; background:var(--blk); border-radius:2px; }

/* ── MOBILE MENU ─────────────────────────────────── */
.mob-menu { display:none; position:fixed; inset:0; background:var(--bg); z-index:9998; flex-direction:column; padding:100px 40px 40px; gap:4px; overflow-y:auto; }
.mob-menu.open { display:flex; }
.mob-menu a { font-family:var(--fh); font-size:28px; font-weight:600; color:var(--blk); padding:14px 0; border-bottom:1px solid var(--bdr); }
.mob-menu a:hover { color:var(--grn); }
.mob-close { position:fixed; top:18px; right:18px; background:var(--bg2); border:1px solid var(--bdr); border-radius:50%; width:44px; height:44px; display:flex; align-items:center; justify-content:center; cursor:pointer; color:var(--blk); font-size:20px; z-index:9999; line-height:1; }

/* ── HERO ────────────────────────────────────────── */
.hero { min-height:100vh; display:flex; align-items:center; padding:150px 0 100px; position:relative; overflow:hidden; background:var(--bg); }
.hero-inner { display:grid; grid-template-columns:55% 45%; gap:0; align-items:center; position:relative; z-index:2; width:100%; }
.hero-content { position:relative; z-index:3; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:var(--gb); border:1px solid var(--gbr); border-radius:100px; padding:8px 18px; font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--grn); margin-bottom:28px; animation:fadeInUp .7s ease both; font-family:var(--fb); }
.hero-dot { width:7px; height:7px; background:var(--grn); border-radius:50%; animation:pulse 2s ease-in-out infinite; display:inline-block; }
.hero-title { font-family:var(--fh); font-size:clamp(52px,7.5vw,100px); font-weight:600; line-height:1.0; letter-spacing:-.03em; color:var(--blk); margin-bottom:24px; animation:fadeInUp .8s ease .1s both; }
.hero-title .gi { color:var(--grn); font-style:italic; }
.hero-sub { font-size:clamp(16px,2vw,19px); color:var(--text2); line-height:1.8; max-width:520px; margin-bottom:40px; animation:fadeInUp .8s ease .2s both; font-family:var(--fb); }
.hero-ctas { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:52px; animation:fadeInUp .8s ease .3s both; }
.hero-trust { display:flex; flex-wrap:wrap; gap:22px; animation:fadeInUp .8s ease .4s both; }
.trust-i { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text2); font-weight:500; font-family:var(--fb); }
.trust-i::before { content:''; width:18px; height:18px; background:var(--gb) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%2300c853' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center/10px; border:1px solid var(--gbr); border-radius:50%; flex-shrink:0; }
.hero-bot-col { display:flex; align-items:center; justify-content:center; position:relative; z-index:1; }
.hero-bot-svg { width:100%; max-width:460px; animation:botFloat 6s ease-in-out infinite, glowGrn 4s ease-in-out infinite; }

/* ── MARQUEE ─────────────────────────────────────── */
.marquee-wrap { background:var(--blk); padding:13px 0; overflow:hidden; }
.marquee-track { display:flex; animation:marquee 24s linear infinite; width:max-content; }
.marquee-item { display:flex; align-items:center; gap:8px; padding:0 28px; font-family:var(--fm); font-size:12px; color:#555; white-space:nowrap; border-right:1px solid var(--blk3); }
.marquee-item span { color:var(--grn); }
.marquee-dot { width:4px; height:4px; border-radius:50%; background:var(--grn); flex-shrink:0; }

/* ── STATS BAR ───────────────────────────────────── */
.stats-bar { background:var(--blk); padding:52px 0; position:relative; }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); max-width:960px; margin:0 auto; }
.stat-item { text-align:center; padding:22px 20px; border-right:1px solid var(--blk3); }
.stat-item:last-child { border-right:none; }
.stat-val { font-family:var(--fh); font-size:52px; font-weight:600; color:var(--grn); letter-spacing:-.02em; line-height:1; margin-bottom:8px; }
.stat-lbl { font-size:11px; color:#666; text-transform:uppercase; letter-spacing:.12em; font-weight:500; font-family:var(--fb); }

/* ── PROBLEM / SOLUTION ──────────────────────────── */
.ps-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--gap); margin-top:60px; }
.ps-item { background:var(--bg); border:1px solid var(--bdr); border-radius:var(--rl); padding:30px; display:flex; gap:16px; align-items:flex-start; transition:border-color var(--t),box-shadow var(--t); }
.ps-item.bad  { border-left:3px solid #e24b4a; }
.ps-item.good { border-left:3px solid var(--grn); }
.ps-item.bad:hover  { box-shadow:0 0 0 2px rgba(226,75,74,.09); }
.ps-item.good:hover { border-color:var(--gbr); box-shadow:0 0 0 3px rgba(0,200,83,.07); }
.ps-item.dark { background:var(--blk2); border-color:var(--blk3); }
.ps-item.dark h4 { color:#fff; }
.ps-item.dark p  { color:#888; }
.ps-icon { width:44px; height:44px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.ps-item.bad .ps-icon  { background:rgba(226,75,74,.07); }
.ps-item.good .ps-icon { background:var(--gb); }
.ps-item h4 { font-family:var(--fb); font-size:16px; font-weight:700; color:var(--blk); margin-bottom:8px; }
.ps-item p  { font-size:14px; color:var(--text2); line-height:1.7; }

/* ── FEATURE GRID ────────────────────────────────── */
.feat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); margin-top:60px; }

/* ── KEY FACTORS ─────────────────────────────────── */
.factors-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--gap); margin-top:60px; }
.factor-card { background:var(--bg); border:1px solid var(--bdr); border-radius:var(--rl); padding:var(--cp); transition:border-color var(--t),box-shadow var(--t); }
.factor-card:hover { border-color:var(--gbr); box-shadow:0 0 0 3px rgba(0,200,83,.07); }
.factor-icon { font-size:32px; margin-bottom:18px; }
.factor-card h4 { font-family:var(--fh); font-size:22px; font-weight:600; color:var(--blk); margin-bottom:12px; }
.factor-card p  { font-size:15px; color:var(--text2); line-height:1.75; }

/* ── STEPS ───────────────────────────────────────── */
.steps-row { display:grid; grid-template-columns:repeat(5,1fr); gap:0; margin-top:60px; position:relative; }
.steps-row::before { content:''; position:absolute; top:27px; left:10%; right:10%; height:1.5px; background:linear-gradient(90deg,transparent,var(--gbr),transparent); }
.step { text-align:center; padding:0 14px; }
.step-num { width:56px; height:56px; border-radius:50%; background:var(--blk); display:flex; align-items:center; justify-content:center; font-family:var(--fh); font-size:20px; font-weight:600; color:var(--grn); margin:0 auto 22px; position:relative; z-index:1; transition:all var(--t); }
.step:hover .step-num { background:var(--grn); color:var(--blk); box-shadow:0 0 0 6px rgba(0,200,83,.12); }
.step h4 { font-family:var(--fh); font-size:18px; font-weight:600; color:var(--blk); margin-bottom:8px; }
.step p  { font-size:13px; color:var(--text2); line-height:1.65; font-family:var(--fb); }

/* ── EXCHANGES — 72px logos ──────────────────────── */
.exc-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(158px,163px)); gap:var(--gap); margin-top:60px; justify-content:center; }
.exc-pill { background:var(--bg); border:1px solid var(--bdr); border-radius:var(--rl); padding:22px 16px; text-align:center; transition:border-color var(--t),box-shadow var(--t); display:flex; flex-direction:column; align-items:center; gap:12px; }
.exc-pill.dark { background:var(--blk2); border-color:var(--blk3); }
.exc-pill:hover { border-color:var(--gbr); box-shadow:0 0 0 3px rgba(0,200,83,.07); }
.exc-logo { width:72px; height:72px; border-radius:12px; object-fit:contain; background:var(--bg2); padding:8px; }
.exc-logo-placeholder { width:72px; height:72px; border-radius:12px; background:var(--bg2); border:1px solid var(--bdr); display:flex; align-items:center; justify-content:center; font-family:var(--fh); font-size:22px; font-weight:700; color:var(--blk); }
.exc-logo-placeholder.dark { background:var(--blk3); color:#fff; border-color:var(--blk3); }
.exc-name { font-weight:600; font-size:14px; color:var(--blk); font-family:var(--fb); }
.exc-name.dark { color:#fff; }
.exc-type-badge { font-size:10px; color:var(--text3); background:var(--bg2); padding:3px 10px; border-radius:100px; font-family:var(--fb); }
.exc-type-badge.dark { background:var(--blk3); color:#666; }

/* ── CLIENTS — 80px logos ────────────────────────── */
.clients-section { padding:var(--sp) 0; background:var(--bg2); position:relative; overflow:hidden; border-top:1px solid var(--bdr); }
.clients-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(158px,163px)); gap:var(--gap); margin-top:60px; justify-content:center; }
.client-card { background:var(--bg); border:1px solid var(--bdr); border-radius:var(--rl); padding:28px 20px; text-align:center; transition:border-color var(--t),box-shadow var(--t); position:relative; overflow:hidden; }
.client-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2.5px; background:var(--grn); opacity:0; transition:opacity var(--t); }
.client-card:hover { border-color:var(--gbr); box-shadow:0 0 0 3px rgba(0,200,83,.07); }
.client-card:hover::before { opacity:1; }
.client-logo-wrap { height:84px; display:flex; align-items:center; justify-content:center; margin-bottom:14px; }
.client-logo-wrap img { max-height:80px; max-width:140px; width:auto; object-fit:contain; }
.client-logo-placeholder { width:68px; height:68px; border-radius:14px; background:var(--bg2); border:1px solid var(--bdr); display:flex; align-items:center; justify-content:center; font-family:var(--fh); font-size:24px; font-weight:700; color:var(--blk); margin:0 auto; }
.client-name   { font-family:var(--fh); font-size:18px; font-weight:600; color:var(--blk); margin-bottom:4px; }
.client-ticker { font-family:var(--fm); font-size:11px; color:var(--grn); letter-spacing:.1em; }

/* ── TESTIMONIALS ────────────────────────────────── */
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); margin-top:60px; align-items:stretch; }
.testi-card { background:var(--bg); border:1px solid var(--bdr); border-radius:var(--rl); padding:var(--cp); position:relative; transition:border-color var(--t),box-shadow var(--t); display:flex; flex-direction:column; }
.testi-card::before { content:'"'; position:absolute; top:14px; right:20px; font-family:var(--fh); font-size:80px; line-height:1; color:var(--grn); opacity:.1; pointer-events:none; }
.testi-card:hover { border-color:var(--gbr); box-shadow:0 0 0 3px rgba(0,200,83,.07); }
.testi-stars  { color:var(--blk); font-size:14px; letter-spacing:2px; margin-bottom:16px; }
.testi-text   { font-size:15px; color:var(--text2); line-height:1.8; font-style:italic; margin-bottom:26px; flex:1; }
.testi-author { display:flex; align-items:center; gap:12px; }
.testi-av     { width:46px; height:46px; border-radius:50%; background:var(--blk); display:flex; align-items:center; justify-content:center; font-family:var(--fh); font-weight:600; font-size:17px; color:var(--grn); flex-shrink:0; }
.testi-name   { font-weight:700; font-size:14px; color:var(--blk); font-family:var(--fb); }
.testi-role   { font-size:12px; color:var(--text3); margin-top:2px; font-family:var(--fb); }

/* ── FAQ ─────────────────────────────────────────── */
.faq-list { max-width:780px; margin:60px auto 0; }
.faq-item { border:1px solid var(--bdr); border-radius:var(--r); margin-bottom:12px; overflow:hidden; transition:border-color var(--t); }
.faq-item.open { border-color:var(--gbr); box-shadow:0 0 0 3px rgba(0,200,83,.06); }
.faq-btn { width:100%; text-align:left; padding:22px 28px; background:var(--bg); border:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; font-family:var(--fb); font-size:16px; font-weight:600; color:var(--blk); transition:background var(--t); }
.faq-btn:hover { background:var(--bg2); }
.faq-plus { width:30px; height:30px; border-radius:50%; background:var(--blk); display:flex; align-items:center; justify-content:center; color:var(--grn); font-size:18px; flex-shrink:0; transition:all var(--t); }
.faq-item.open .faq-plus { transform:rotate(45deg); background:var(--grn); color:var(--blk); }
.faq-body { max-height:0; overflow:hidden; transition:max-height .45s var(--ease); background:var(--bg); }
.faq-item.open .faq-body { max-height:300px; }
.faq-inner { padding:20px 28px 26px; font-size:15px; color:var(--text2); line-height:1.8; border-top:1px solid var(--bdr); font-family:var(--fb); }

/* ── COMPARE TABLE ───────────────────────────────── */
.cmp-wrap { overflow-x:auto; border-radius:var(--rl); border:1px solid var(--bdr); margin-top:52px; }
.cmp-table { width:100%; border-collapse:separate; border-spacing:0; min-width:640px; }
.cmp-table thead th { padding:18px 20px; font-family:var(--fb); font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; background:var(--bg2); color:var(--text2); border-bottom:1px solid var(--bdr); }
.cmp-table thead th:first-child { text-align:left; border-radius:var(--r) 0 0 0; }
.cmp-table thead th:last-child { border-radius:0 var(--r) 0 0; background:var(--gb); color:var(--grn); border:1px solid var(--gbr); border-bottom:none; }
.cmp-table tbody td { padding:16px 20px; text-align:center; border-bottom:1px solid var(--bdr); font-size:14px; color:var(--text2); font-family:var(--fb); }
.cmp-table tbody td:first-child { text-align:left; color:var(--blk); font-weight:500; }
.cmp-table tbody td.hl { background:var(--gb); border-left:1px solid var(--gbr); border-right:1px solid var(--gbr); color:var(--blk); font-weight:700; }
.cmp-table tbody tr:hover td { background:var(--bg2); }
.cmp-table tbody tr:hover td.hl { background:rgba(0,200,83,.12); }

/* ── PRICING ─────────────────────────────────────── */
.price-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); margin-top:64px; }
.price-card { background:var(--bg); border:1px solid var(--bdr); border-radius:var(--rl); padding:40px 32px; position:relative; transition:border-color var(--t),box-shadow var(--t); overflow:hidden; }
.price-card::after { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:transparent; transition:background var(--t); }
.price-card:hover { border-color:var(--gbr); box-shadow:0 0 0 3px rgba(0,200,83,.07); }
.price-card:hover::after { background:var(--grn); }
.price-card.feat { border:2px solid var(--blk); }
.price-card.feat::after { background:var(--grn); }
.price-badge { position:absolute; top:-1px; right:22px; background:var(--blk); color:var(--grn); font-size:10px; font-weight:800; padding:5px 14px; border-radius:0 0 8px 8px; letter-spacing:.1em; text-transform:uppercase; font-family:var(--fb); }
.price-tier   { font-family:var(--fm); font-size:11px; font-weight:600; letter-spacing:.15em; text-transform:uppercase; color:var(--grn); margin-bottom:12px; }
.price-name   { font-family:var(--fh); font-size:28px; font-weight:600; color:var(--blk); margin-bottom:6px; }
.price-exch   { font-size:14px; color:var(--text3); margin-bottom:24px; font-family:var(--fb); }
.price-amount { font-family:var(--fh); font-size:52px; font-weight:600; color:var(--blk); line-height:1; margin-bottom:8px; letter-spacing:-.03em; }
.price-amount span { font-size:22px; color:var(--text3); font-family:var(--fb); font-weight:400; }
.price-sub    { font-size:14px; color:var(--grn); font-weight:700; margin-bottom:28px; font-family:var(--fb); }
.price-feats  { display:flex; flex-direction:column; gap:12px; margin-bottom:28px; }
.price-feat   { display:flex; align-items:center; gap:10px; font-size:14px; color:var(--text); font-family:var(--fb); }
.price-feat::before { content:'✓'; color:var(--grn); font-weight:800; flex-shrink:0; }
.dashboard-badge { display:inline-flex; align-items:center; gap:7px; background:var(--gb); border:1px solid var(--gbr); border-radius:100px; padding:7px 16px; font-size:12px; color:var(--grn); font-weight:700; margin-top:10px; font-family:var(--fb); }
/* Pricing page button - explicit visible style */
.price-card .btn { width:100%; justify-content:center; margin-top:22px; font-size:16px; padding:16px; }
.pricing-note-box { background:var(--bg2); border:1px solid var(--bdr); border-left:3px solid var(--grn); border-radius:var(--rl); padding:26px 30px; margin-top:24px; }
.pricing-note-box + .pricing-note-box { margin-top:14px; }
.pricing-note-box h4 { font-size:18px; margin-bottom:10px; color:var(--blk); }
.pricing-note-box p  { font-size:14px; color:var(--text2); line-height:1.75; font-family:var(--fb); }

/* ── ROI ─────────────────────────────────────────── */
.callout { background:var(--gb); border:1px solid var(--gbr); border-radius:var(--rl); padding:24px 32px; margin:32px 0; font-size:16px; color:var(--blk); line-height:1.7; text-align:center; font-family:var(--fb); }
.callout strong { color:var(--grn); }
.roi-box { background:var(--bg2); border:1px solid var(--bdr); border-radius:var(--rx); padding:48px; margin-top:56px; }
.roi-bar-wrap { margin:24px 0 10px; }
.roi-bar-lbl  { display:flex; justify-content:space-between; font-size:13px; color:var(--text2); margin-bottom:9px; font-family:var(--fb); }
.roi-track    { height:38px; background:var(--bg3); border-radius:var(--r); overflow:hidden; border:1px solid var(--bdr); }
.roi-fill     { height:100%; border-radius:var(--r); display:flex; align-items:center; padding-left:14px; font-family:var(--fm); font-size:13px; font-weight:600; width:0; transition:width 1.6s var(--ease); }
.roi-fill.bad  { background:linear-gradient(90deg,rgba(226,75,74,.25),rgba(226,75,74,.5)); color:#cc3333; }
.roi-fill.good { background:linear-gradient(90deg,var(--grn),var(--grn2)); color:var(--blk); }
.roi-save { text-align:center; padding:28px; background:var(--gb); border:1px solid var(--gbr); border-radius:var(--rl); margin-top:24px; }
.roi-save-val { font-family:var(--fh); font-size:56px; font-weight:600; color:var(--grn); letter-spacing:-.03em; }
.roi-save-lbl { font-size:14px; color:var(--text2); margin-top:6px; font-family:var(--fb); }

/* ── OWNERSHIP ───────────────────────────────────── */
.own-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--gap); margin-top:60px; }
.own-card { background:var(--bg); border-radius:var(--rl); padding:var(--cp); position:relative; overflow:hidden; border:1px solid var(--bdr); }
.own-card.bad  { border-left:3px solid #e24b4a; }
.own-card.good { border-left:3px solid var(--grn); }
.own-card.bad::before  { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:#e24b4a; }
.own-card.good::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grn); }
.own-lbl { font-family:var(--fm); font-size:11px; font-weight:600; letter-spacing:.15em; text-transform:uppercase; margin-bottom:14px; }
.own-card.bad .own-lbl  { color:#e24b4a; }
.own-card.good .own-lbl { color:var(--grn); }
.own-card h3 { font-size:26px; margin-bottom:16px; color:var(--blk); }
.own-list { display:flex; flex-direction:column; gap:12px; }
.own-list li { display:flex; align-items:flex-start; gap:10px; font-size:14px; color:var(--text2); line-height:1.6; font-family:var(--fb); }
.own-card.bad  .own-list li::before { content:'✗'; color:#e24b4a; font-weight:700; flex-shrink:0; }
.own-card.good .own-list li::before { content:'✓'; color:var(--grn); font-weight:700; flex-shrink:0; }

/* ── SECURITY ────────────────────────────────────── */
.sec-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); margin-top:52px; }
.sec-card { background:var(--bg); border:1px solid var(--bdr); border-radius:var(--rl); padding:var(--cp); transition:border-color var(--t),box-shadow var(--t); text-align:center; }
.sec-card:hover { border-color:var(--gbr); box-shadow:0 0 0 3px rgba(0,200,83,.07); }
.sec-icon { font-size:34px; margin-bottom:18px; }
.sec-card h4 { font-size:17px; font-weight:600; color:var(--blk); margin-bottom:10px; font-family:var(--fb); }
.sec-card p  { font-size:14px; color:var(--text2); line-height:1.7; font-family:var(--fb); }

/* ── FORM ────────────────────────────────────────── */
.form-box { background:var(--bg); border:1px solid var(--bdr); border-radius:var(--rl); padding:52px; max-width:720px; margin:0 auto; box-shadow:0 4px 32px rgba(0,0,0,.05); }
.form-row   { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group { margin-bottom:20px; }
.form-lbl   { display:block; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--text2); margin-bottom:9px; font-family:var(--fb); }
.form-field { width:100%; padding:14px 18px; background:var(--bg2); border:1px solid var(--bdr2); border-radius:var(--r); color:var(--blk); font-family:var(--fb); font-size:15px; transition:all var(--t); -webkit-appearance:none; }
.form-field:focus { outline:none; border-color:var(--grn); box-shadow:0 0 0 3px rgba(0,200,83,.08); background:var(--bg); }
.form-field::placeholder { color:var(--text3); }
textarea.form-field { min-height:100px; resize:vertical; }
.form-submit { width:100%; padding:17px; background:var(--blk); color:#fff; font-family:var(--fb); font-weight:700; font-size:16px; border:none; border-radius:var(--r); cursor:pointer; transition:all var(--t); }
.form-submit:hover { background:var(--blk2); box-shadow:0 8px 24px rgba(0,0,0,.2); }
.form-note { text-align:center; font-size:12px; color:var(--text3); margin-top:16px; font-family:var(--fb); }
#form-success { display:none; background:var(--gb); border:1px solid var(--gbr); border-radius:var(--r); padding:24px; text-align:center; color:var(--grn); margin-top:16px; font-family:var(--fb); }
#form-error   { display:none; color:#e24b4a; font-size:13px; text-align:center; margin-top:10px; font-family:var(--fb); }

/* ── CALENDLY ────────────────────────────────────── */
.cal-section { padding:var(--sp) 0; position:relative; overflow:hidden; background:var(--bg2); border-top:1px solid var(--bdr); }
.cal-widget  { border-radius:var(--rl); overflow:hidden; border:1px solid var(--bdr); box-shadow:0 8px 48px rgba(0,0,0,.07); margin-top:44px; }

/* ── DISCLAIMER ──────────────────────────────────── */
.disc-bar { background:rgba(0,200,83,.04); border-top:1px solid var(--gbr); border-bottom:1px solid var(--gbr); padding:18px 0; }
.disc-inner { display:flex; gap:14px; align-items:flex-start; }
.disc-inner p { font-size:12px; color:var(--text2); line-height:1.7; font-family:var(--fb); }
.disc-inner strong { color:var(--grn); }

/* ── FOOTER ──────────────────────────────────────── */
#footer { background:var(--blk); }
.footer-main { padding:80px 0 60px; }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:56px; }
.footer-desc { font-size:14px; color:#666; line-height:1.85; margin:18px 0 26px; max-width:280px; font-family:var(--fb); }
.footer-socials { display:flex; gap:8px; flex-wrap:wrap; }
.soc-btn { width:38px; height:38px; border-radius:9px; background:var(--blk2); border:1px solid var(--blk3); display:flex; align-items:center; justify-content:center; color:#666; font-size:14px; text-decoration:none; transition:all var(--t); cursor:pointer; }
.soc-btn:hover { background:var(--grn); border-color:var(--grn); color:var(--blk); }
.footer-col-h { font-family:var(--fb); font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.15em; color:#555; margin-bottom:22px; }
.footer-links { display:flex; flex-direction:column; gap:12px; }
.footer-links a { font-size:14px; color:#777; transition:color var(--t); font-family:var(--fb); }
.footer-links a:hover { color:var(--grn); }
.footer-bottom { border-top:1px solid var(--blk3); padding:24px 0; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-copy    { font-size:12px; color:#555; font-family:var(--fb); }
.footer-powered { font-size:12px; color:#555; display:flex; align-items:center; gap:5px; font-family:var(--fb); }
.footer-powered a { color:var(--grn); font-weight:600; }
.footer-legal   { width:100%; font-size:11px; color:#555; line-height:1.6; opacity:.6; padding-top:12px; border-top:1px solid var(--blk3); margin-top:6px; font-family:var(--fb); }
.footer-email   { font-size:13px; color:#555; margin-top:12px; font-family:var(--fb); }
.footer-email a { color:var(--grn); }

/* ── COOKIE BANNER ───────────────────────────────── */
#cookie-bar { position:fixed; bottom:24px; left:50%; transform:translateX(-50%); z-index:9999; background:var(--blk); border:1px solid var(--blk3); border-radius:var(--rl); padding:22px 28px; max-width:640px; width:calc(100% - 48px); display:flex; align-items:center; gap:20px; box-shadow:0 8px 40px rgba(0,0,0,.4); flex-wrap:wrap; transition:all .4s var(--ease); }
#cookie-bar.hide { opacity:0; transform:translateX(-50%) translateY(20px); pointer-events:none; }
.cookie-txt { font-size:13px; color:#aaa; line-height:1.6; flex:1; min-width:180px; font-family:var(--fb); }
.cookie-txt strong { color:#fff; }
.cookie-txt a { color:var(--grn); }
.cookie-btns { display:flex; gap:10px; flex-shrink:0; }
.cookie-ok { padding:10px 22px; background:var(--grn); color:var(--blk); border:none; border-radius:var(--r); font-weight:800; font-size:13px; cursor:pointer; font-family:var(--fb); }
.cookie-no { padding:10px 16px; background:transparent; color:#666; border:1px solid var(--blk3); border-radius:var(--r); font-size:13px; cursor:pointer; font-family:var(--fb); }

/* ── PAGE HERO (inner pages) ─────────────────────── */
.page-hero { padding:160px 0 80px; background:var(--blk); position:relative; overflow:hidden; }
.page-hero .wrap { position:relative; z-index:2; }

/* ── FINAL CTA ───────────────────────────────────── */
.final-cta { text-align:center; padding:var(--sp) 0; position:relative; overflow:hidden; background:var(--blk); }
.final-cta > .wrap { position:relative; z-index:2; }
.final-cta::before { content:''; position:absolute; width:600px; height:600px; border-radius:50%; background:radial-gradient(circle,rgba(0,200,83,.08) 0%,transparent 65%); top:50%; left:50%; transform:translate(-50%,-50%); pointer-events:none; }

/* ── ABOUT ───────────────────────────────────────── */
.about-grid  { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-text p { font-size:15px; color:var(--text); line-height:1.9; margin-bottom:20px; font-family:var(--fb); }
.about-stats  { display:grid; grid-template-columns:1fr 1fr; gap:var(--gap); }
.about-stat   { background:var(--bg2); border:1px solid var(--bdr); border-radius:var(--r); padding:28px; text-align:center; }
.about-stat-val { font-family:var(--fh); font-size:40px; font-weight:600; color:var(--blk); }
.about-stat-val span { color:var(--grn); }
.about-stat-lbl { font-size:12px; color:var(--text3); margin-top:5px; font-family:var(--fb); }
.powered-by { display:inline-flex; align-items:center; gap:7px; font-size:13px; color:var(--text3); padding:9px 18px; background:var(--bg2); border:1px solid var(--bdr); border-radius:100px; margin-top:28px; font-family:var(--fb); }
.powered-by a { color:var(--grn); font-weight:600; }

/* ── EXCHANGE CTA BOX ────────────────────────────── */
.exc-cta-box { background:var(--bg2); border:1.5px solid var(--bdr2); border-radius:var(--rl); padding:48px 40px; text-align:center; margin-top:48px; }
.exc-cta-box h4 { font-family:var(--fh); font-size:28px; font-weight:600; color:var(--blk); margin-bottom:14px; }
.exc-cta-box p  { font-size:15px; color:var(--text2); margin-bottom:28px; font-family:var(--fb); max-width:560px; margin-left:auto; margin-right:auto; }

/* ── BLOG ────────────────────────────────────────── */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); margin-top:60px; }
.blog-card { background:var(--bg); border:1px solid var(--bdr); border-radius:var(--rl); overflow:hidden; transition:border-color var(--t),box-shadow var(--t); }
.blog-card:hover { border-color:var(--gbr); box-shadow:0 0 0 3px rgba(0,200,83,.07); }
.blog-thumb { height:210px; overflow:hidden; background:var(--bg2); }
.blog-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.blog-card:hover .blog-thumb img { transform:scale(1.04); }
.blog-body  { padding:28px; }
.blog-cat   { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--grn); margin-bottom:12px; font-family:var(--fb); }
.blog-title { font-family:var(--fh); font-size:22px; font-weight:600; color:var(--blk); line-height:1.3; margin-bottom:12px; }
.blog-title a { color:inherit; }
.blog-title a:hover { color:var(--grn); }
.blog-exc  { font-size:14px; color:var(--text2); line-height:1.7; margin-bottom:18px; font-family:var(--fb); }
.blog-meta { display:flex; justify-content:space-between; align-items:center; font-size:12px; color:var(--text3); font-family:var(--fb); }

/* ── BLOG SIDEBAR LAYOUT ─────────────────────────── */
.blog-layout { display:grid; grid-template-columns:1fr 300px; gap:52px; align-items:start; margin-top:52px; }
.blog-sidebar { position:sticky; top:100px; }
.sidebar-widget { background:var(--bg2); border:1px solid var(--bdr); border-radius:var(--rl); padding:28px; margin-bottom:22px; }
.sidebar-widget-title { font-family:var(--fh); font-size:22px; font-weight:600; color:var(--blk); display:block; margin-bottom:20px; padding-bottom:12px; border-bottom:2.5px solid var(--grn); }
.sidebar-post { display:flex; gap:14px; margin-bottom:18px; padding-bottom:18px; border-bottom:1px solid var(--bdr); }
.sidebar-post:last-child { margin-bottom:0; padding-bottom:0; border-bottom:none; }
.sidebar-thumb { width:74px; height:74px; border-radius:10px; overflow:hidden; flex-shrink:0; background:var(--bg3); }
.sidebar-thumb img { width:100%; height:100%; object-fit:cover; }
.sidebar-post-cat   { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--grn); margin-bottom:5px; font-family:var(--fb); }
.sidebar-post-title { font-family:var(--fh); font-size:16px; font-weight:600; color:var(--blk); line-height:1.3; }
.sidebar-post-title a { color:inherit; }
.sidebar-post-title a:hover { color:var(--grn); }
.sidebar-post-date  { font-size:11px; color:var(--text3); margin-top:4px; font-family:var(--fb); }

/* ── POST CONTENT ────────────────────────────────── */
.post-content { font-size:17px; line-height:1.9; color:var(--text); font-family:var(--fb); }
.post-content h2 { font-family:var(--fh); font-size:34px; color:var(--blk); margin:42px 0 16px; }
.post-content h3 { font-family:var(--fh); font-size:26px; color:var(--blk); margin:30px 0 14px; }
.post-content p  { margin-bottom:22px; }
.post-content ul,.post-content ol { margin:18px 0 18px 28px; }
.post-content li { margin-bottom:10px; }
.post-content blockquote { border-left:3px solid var(--grn); padding:18px 24px; background:var(--gb); border-radius:0 var(--r) var(--r) 0; margin:26px 0; font-style:italic; }
.post-content a { color:var(--grn); }
.post-content strong { color:var(--blk); }
.post-content img { border-radius:var(--r); margin:22px 0; }

/* ── POST META (author name) ─────────────────────── */
.post-meta { display:flex; align-items:center; gap:20px; flex-wrap:wrap; font-size:13px; color:var(--text3); font-family:var(--fb); margin-top:12px; }
.post-meta-author { display:flex; align-items:center; gap:8px; color:var(--blk); font-weight:600; }
.post-meta-av { width:32px; height:32px; border-radius:50%; background:var(--blk); display:flex; align-items:center; justify-content:center; font-family:var(--fh); font-weight:600; font-size:13px; color:var(--grn); flex-shrink:0; }

/* ── SOCIAL SHARE BAR ────────────────────────────── */
.share-bar { display:flex; align-items:center; gap:10px; padding:24px 0; border-top:1px solid var(--bdr); border-bottom:1px solid var(--bdr); margin:40px 0; flex-wrap:wrap; }
.share-label { font-family:var(--fb); font-size:12px; font-weight:700; color:var(--blk); text-transform:uppercase; letter-spacing:.1em; margin-right:4px; }
.share-btn { display:inline-flex; align-items:center; gap:7px; padding:9px 16px; border-radius:8px; font-size:13px; font-weight:600; text-decoration:none; font-family:var(--fb); transition:all var(--t); }
.share-x  { background:#000; color:#fff; } .share-x:hover  { background:#222; color:#fff; }
.share-li { background:#0077b5; color:#fff; } .share-li:hover { background:#005f8e; color:#fff; }
.share-wa { background:#25d366; color:#fff; } .share-wa:hover { background:#128c7e; color:#fff; }
.share-tg { background:#2ca5e0; color:#fff; } .share-tg:hover { background:#1a8bc4; color:#fff; }
.share-cp { background:var(--bg2); color:var(--blk); border:1px solid var(--bdr); } .share-cp:hover { background:var(--bg3); color:var(--blk); }

/* ── RELATED POSTS ───────────────────────────────── */
.related-posts { margin-top:56px; padding-top:48px; border-top:2px solid var(--bdr); }
.related-title { font-family:var(--fh); font-size:32px; font-weight:600; color:var(--blk); margin-bottom:32px; }
.related-title span { color:var(--grn); font-style:italic; }
.related-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }

/* ── RESPONSIVE ──────────────────────────────────── */
/* Desktop large */
@media(min-width:1400px){
  .wrap { max-width:1320px; }
}
/* Tablet 768-1100px */
@media(max-width:1100px){
  .footer-grid { grid-template-columns:1fr 1fr; gap:40px; }
  .price-grid  { grid-template-columns:1fr; max-width:460px; margin-left:auto; margin-right:auto; }
  .steps-row   { grid-template-columns:repeat(3,1fr); }
  .steps-row::before { display:none; }
  .hero-inner  { grid-template-columns:60% 40%; }
  .blog-layout { grid-template-columns:1fr 260px; gap:32px; }
}
/* iPad 769-900 */
@media(max-width:900px){
  .feat-grid,.sec-grid  { grid-template-columns:1fr 1fr; }
  .testi-grid            { grid-template-columns:1fr 1fr; }
  .about-grid,.own-grid  { grid-template-columns:1fr; gap:40px; }
  .blog-grid             { grid-template-columns:1fr 1fr; }
  .stats-grid            { grid-template-columns:1fr 1fr; }
  .stat-item:nth-child(2){ border-right:none; }
  .factors-grid          { grid-template-columns:1fr; }
  .hero-inner            { grid-template-columns:1fr; }
  .hero-bot-col          { display:none; }
  .blog-layout           { grid-template-columns:1fr; }
  .blog-sidebar          { position:static; }
  .related-grid          { grid-template-columns:1fr 1fr; }
}
/* Mobile */
@media(max-width:768px){
  :root { --sp:72px; --gap:16px; --cp:24px; }
  .hero { min-height:auto; padding:120px 0 80px; }
  .hero-title { font-size:clamp(38px,10vw,60px); }
  .mnav,.ncta { display:none; }
  .ham { display:flex; }
  .ps-grid,.feat-grid,.sec-grid,.testi-grid,.blog-grid { grid-template-columns:1fr; }
  .steps-row  { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .about-stats,.form-row { grid-template-columns:1fr 1fr; }
  .hero-ctas { flex-direction:column; }
  .price-grid,.own-grid { grid-template-columns:1fr; }
  #cookie-bar { flex-direction:column; align-items:flex-start; }
  .wrap { padding:0 20px; }
  .exc-grid,.clients-grid { grid-template-columns:repeat(2,1fr); justify-content:start; }
  .share-bar { gap:7px; }
  .share-btn { padding:8px 12px; font-size:12px; }
  .related-grid { grid-template-columns:1fr; }
  .blog-layout { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .stat-item { border-right:none; border-bottom:1px solid var(--blk3); }
  .cmp-table { font-size:12px; }
}
@media(max-width:480px){
  .exc-grid,.clients-grid { grid-template-columns:repeat(2,1fr); }
}
.admin-bar #hdr { top:32px; }
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg2); }
::-webkit-scrollbar-thumb { background:#ccc; border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--grn); }

/* ── COMPATIBILITY FIXES — old v5 class names ───── */
/* These ensure any leftover old classes still display correctly */

/* Old cyan classes → green */
.cyan-i  { color: var(--grn) !important; font-style: italic; }
.green-i { color: var(--grn) !important; font-style: italic; }

/* Old desc/center classes */
.desc    { font-size:18px; line-height:1.85; color:var(--text); max-width:620px; font-family:var(--fb); }
.center  { text-align:center; }
.center .desc { margin-left:auto; margin-right:auto; }

/* Dark section text — always white inside .s-dark */
.s-dark h1,.s-dark h2,.s-dark h3,.s-dark h4 { color:#ffffff; }
.s-dark .h1,.s-dark .h2,.s-dark .eyebrow    { color:#ffffff; }
.s-dark p,.s-dark .desc,.s-dark .tmm-desc   { color:#999999; }
.s-dark .div-line                            { background:var(--grn); }
.s-dark .eyebrow::before,.s-dark .eyebrow::after { background:var(--grn); opacity:.5; }

/* Page hero — always dark bg, always white text */
.page-hero h1,.page-hero h2,.page-hero .h1,.page-hero .h2 { color:#ffffff !important; }
.page-hero p,.page-hero .tmm-desc,.page-hero .desc         { color:#999999 !important; }
.page-hero .eyebrow                                         { color:var(--grn) !important; }

/* Final CTA — dark bg, white text */
.final-cta h1,.final-cta h2,.final-cta .h2,.final-cta .h2-w { color:#ffffff !important; }
.final-cta p,.final-cta .tmm-desc,.final-cta .tmm-desc-w    { color:#999999 !important; }
.final-cta .eyebrow,.final-cta .eyebrow-w                    { color:var(--grn) !important; }

/* Old grid-bg class → same as grid-dark */
.grid-bg { position:absolute; inset:0; pointer-events:none; z-index:0; overflow:hidden; }
.grid-bg::before {
  content:'';
  position:absolute; inset:0;
  background-image: linear-gradient(rgba(0,200,83,0.06) 1px,transparent 1px), linear-gradient(90deg,rgba(0,200,83,0.06) 1px,transparent 1px);
  background-size:52px 52px;
  animation:gridMove 20s linear infinite;
}

/* Old s-darker */
.s-darker { background:var(--bg2); }

/* btn-cyan → btn-grn equivalent */
.btn-cyan { background:var(--grn); color:var(--blk); border:2px solid var(--grn); font-weight:800; }
.btn-cyan:hover { background:var(--grn2); border-color:var(--grn2); color:var(--blk); }

/* Surf variables for v5 compat */
:root {
  --surf:  var(--bg2);
  --surf2: var(--bg3);
  --cyan:  var(--grn);
  --cyan2: var(--grn);
  --bc:    var(--gbr);
  --cbg:   var(--gb);
  --border: var(--bdr);
}

/* wrap inside any dark section always above grid */
.s-dark > .wrap,
.page-hero > .wrap,
.final-cta > .wrap,
.stats-bar > .wrap,
.marquee-wrap > .wrap {
  position: relative;
  z-index: 2;
}

/* ══ GLOBAL FIXES v6.1 ════════════════════════════ */

/* 1. Footer logo — white text on dark bg */
#footer .logo-txt        { color: #ffffff !important; }
#footer .logo-txt span   { color: #666666 !important; }
#footer .logo-mark       { background: var(--blk2) !important; color: var(--grn) !important; border: 1px solid #333; }

/* 2. Calendly section — light bg, dark text */
.cal-section             { background: var(--bg2) !important; }
.cal-section .h2         { color: var(--blk) !important; }
.cal-section .eyebrow    { color: var(--grn) !important; }
.cal-section .tmm-desc,
.cal-section .desc,
.cal-section p           { color: var(--text2) !important; }
.cal-section .trust-i    { color: var(--text2) !important; }

/* 3. Final CTA dark section — btn-outline must be white bordered */
.tmm-cta-dark .btn-outline,
.final-cta .btn-outline  {
  color: #ffffff !important;
  border-color: rgba(255,255,255,.35) !important;
  background: transparent !important;
}
.tmm-cta-dark .btn-outline:hover,
.final-cta .btn-outline:hover {
  background: rgba(255,255,255,.1) !important;
  border-color: rgba(255,255,255,.6) !important;
}
/* Also fix tmm-desc color in dark CTA */
.final-cta .tmm-desc,
.final-cta p             { color: #999999 !important; }

/* 4. Privacy/Terms/Disclaimer/Cookie pages — white bg, dark text */
.page-privacy-policy .tmm-section,
.page-terms-conditions .tmm-section,
.page-disclaimer .tmm-section,
.page-cookie-policy .tmm-section { background: var(--bg) !important; }

/* Generic page.php template — make content readable */
.page-content h1,.page-content h2,.page-content h3 { color: var(--blk) !important; font-family: var(--fh); margin-bottom: 16px; margin-top: 32px; }
.page-content p  { color: var(--text) !important; font-family: var(--fb); margin-bottom: 18px; line-height: 1.8; }
.page-content a  { color: var(--grn) !important; }
.page-content ul,.page-content ol { margin: 16px 0 16px 28px; color: var(--text); font-family: var(--fb); }
.page-content li { margin-bottom: 10px; }

/* 5. About page — reduce top gap */
.page-template-page-about .tmm-section:first-of-type { padding-top: 60px !important; }

/* 6. White-on-white text — headings on light calendly section */
.cal-section h2 { color: var(--blk) !important; }

/* 7. Second button visibility in all CTAs */
.btn-outline-w {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid rgba(255,255,255,.35) !important;
}
.btn-outline-w:hover {
  background: rgba(255,255,255,.1) !important;
  border-color: rgba(255,255,255,.65) !important;
  color: #ffffff !important;
}

/* 8. Privacy/legal pages heading color */
.entry-content h1,.entry-content h2,.entry-content h3 { color: var(--blk) !important; font-family: var(--fh); }
.entry-content p,.entry-content li { color: var(--text) !important; font-family: var(--fb); line-height: 1.8; }

/* 9. Bot SVG — ensure it doesn't overflow on mobile */
.hero-bot-svg { overflow: visible; }
@media(max-width:900px) { .hero-bot-col { display: none !important; } }
