/* Uttam Singh | Meta Ads Expert | styles.css | uttamsingh.in */
/* ============================================================
   DESIGN TOKENS — Single source of truth
   (Remove :root from inline critical CSS; keep only here)
============================================================ */
:root {
  --bg:  #F7F4EF;
  --bg2: #EDE9E1;
  --bg3: #E2DDD4;
  --card: #fff;
  --bd:  rgba(0,0,0,.08);
  --wa:  #25D366;
  --wa2: #34C879;
  --wad: #128C7E;
  --fb:  #1877F2;
  --fbd: #0A5394;
  --tx:  #18181E;
  --tx2: #4A4A6A;
  --tx3: #8A8AAA;
  --f:   'Inter', system-ui, sans-serif;
  --rc:  20px;
  --rb:  14px;
  --rp:  100px;
  --sc:  0 2px 24px rgba(0,0,0,.07), 0 1px 0 rgba(255,255,255,.9) inset;
  --sw:  0 0 24px rgba(37,211,102,.3), 0 4px 14px rgba(37,211,102,.2);
  --sb:  0 0 20px rgba(24,119,242,.2);
}

/* ============================================================
   RESET
============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; text-size-adjust: 100%; -webkit-text-size-adjust: 100%; }
body { background: var(--bg); color: var(--tx); font-family: var(--f); line-height: 1.6; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; height: auto; }
svg { display: block; flex-shrink: 0; }
ul, ol { list-style: none; }

/* ============================================================
   ACCESSIBILITY
============================================================ */
.skip { position: absolute; left: -9999px; top: 0; background: var(--fb); color: #fff; padding: 8px 16px; z-index: 9999; border-radius: 0 0 8px 0; font-size: .875rem; font-weight: 600; }
.skip:focus { left: 0; }

/* ============================================================
   AMBIENT BACKGROUND
============================================================ */
.orb-a, .orb-b { position: fixed; border-radius: 50%; pointer-events: none; z-index: 0; filter: blur(90px); }
.orb-a { width: 680px; height: 680px; background: radial-gradient(circle, rgba(24,119,242,.08) 0%, transparent 70%); top: -200px; right: -200px; }
.orb-b { width: 500px; height: 500px; background: radial-gradient(circle, rgba(37,211,102,.07) 0%, transparent 70%); bottom: -100px; left: -150px; }
.bg-dots { position: fixed; inset: 0; pointer-events: none; z-index: 0; background-image: radial-gradient(rgba(0,0,0,.06) 1px, transparent 1px); background-size: 32px 32px; mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, #000 20%, transparent 100%); }

@media (prefers-reduced-motion: no-preference) {
  .orb-a { animation: orbFloat 18s ease-in-out infinite; }
  .orb-b { animation: orbFloat 24s ease-in-out infinite reverse; }
  @keyframes orbFloat {
    0%, 100% { transform: translate(0,0) scale(1); }
    33%       { transform: translate(30px,-40px) scale(1.05); }
    66%       { transform: translate(-20px,30px) scale(.97); }
  }
}

/* ============================================================
   HEADER
============================================================ */
.hdr { position: sticky; top: 0; z-index: 100; background: rgba(247,244,239,.88); backdrop-filter: blur(18px) saturate(150%); -webkit-backdrop-filter: blur(18px) saturate(150%); border-bottom: 1px solid rgba(0,0,0,.08); }
.hdr-in { max-width: 720px; margin: 0 auto; padding: 14px 20px; display: flex; align-items: center; justify-content: space-between; }
.logo-nm { font-size: 1.1rem; font-weight: 800; letter-spacing: -.02em; color: var(--tx); }
.logo-nm em { font-style: normal; color: var(--wad); }
.hdr-cta { display: inline-flex; align-items: center; gap: 7px; background: rgba(37,211,102,.08); border: 1px solid rgba(37,211,102,.3); color: var(--wad); font-size: .8rem; font-weight: 600; padding: 8px 16px; border-radius: var(--rp); transition: all .25s ease; white-space: nowrap; }
.hdr-cta:hover { background: rgba(37,211,102,.18); border-color: rgba(37,211,102,.55); box-shadow: var(--sw); transform: translateY(-1px); }

/* ============================================================
   LAYOUT
============================================================ */
.page { position: relative; z-index: 1; }
.wrap { max-width: 720px; margin: 0 auto; padding: 20px 16px 48px; display: flex; flex-direction: column; gap: 16px; }

/* ============================================================
   CARD
============================================================ */
.card { background: var(--card); border: 1px solid var(--bd); border-radius: var(--rc); box-shadow: var(--sc); overflow: hidden; position: relative; transition: border-color .3s, box-shadow .3s; }
.card:hover { border-color: rgba(0,0,0,.13); box-shadow: 0 6px 32px rgba(0,0,0,.1); }
.card-bar { height: 2px; background: linear-gradient(90deg, #1877F2 0%, #25D366 50%, #128C7E 100%); background-size: 200% 100%; }

@media (prefers-reduced-motion: no-preference) {
  .card-bar { animation: barShimmer 4s linear infinite; }
  @keyframes barShimmer {
    0%   { background-position: 0% 0%; }
    100% { background-position: 200% 0%; }
  }
}

/* ============================================================
   SECTIONS
============================================================ */
.sec { padding: 32px 28px; }
.sec-lbl { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.lbl-line { display: block; width: 22px; height: 2px; background: linear-gradient(90deg, #25D366, #128C7E); border-radius: 2px; flex-shrink: 0; }
.lbl-text { font-size: .72rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--wad); }
.sec-h2 { font-size: clamp(1.3rem, 4vw, 1.65rem); font-weight: 800; letter-spacing: -.03em; color: var(--tx); line-height: 1.2; margin-bottom: 10px; }
.sec-p { font-size: .9rem; color: var(--tx2); line-height: 1.65; max-width: 560px; margin-bottom: 24px; }
.divider { height: 1px; background: linear-gradient(90deg, transparent, rgba(0,0,0,.1), transparent); margin: 0 28px; }

/* ============================================================
   HERO
============================================================ */
.hero { padding: 32px 28px 24px; }
.h-badge { margin-bottom: 20px; }
.h-badge-pill { display: inline-flex; align-items: center; gap: 8px; background: rgba(0,0,0,.04); border: 1px solid rgba(0,0,0,.09); border-radius: var(--rp); padding: 6px 14px; font-size: .78rem; font-weight: 500; color: var(--tx2); }
.h-badge-dot { display: block; width: 7px; height: 7px; border-radius: 50%; background: var(--wa); flex-shrink: 0; }
.h-h1 { font-size: clamp(2rem, 7vw, 2.9rem); font-weight: 900; line-height: 1.12; letter-spacing: -.04em; margin-bottom: 16px; color: var(--tx); }
.hl { background: linear-gradient(135deg, #128C7E, #25D366, #128C7E); background-size: 200% 100%; -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.h-sub { font-size: .95rem; color: var(--tx2); line-height: 1.7; margin-bottom: 18px; max-width: 500px; }
.h-sub strong { color: var(--tx); font-weight: 600; }

@media (prefers-reduced-motion: no-preference) {
  .h-badge-dot { animation: livePulse 2s ease-out infinite; }
  .hl { animation: waShift 3s ease infinite; }
  @keyframes livePulse {
    0%  { box-shadow: 0 0 0 0 rgba(37,211,102,.6); }
    70% { box-shadow: 0 0 0 8px rgba(37,211,102,0); }
    100%{ box-shadow: 0 0 0 0 rgba(37,211,102,0); }
  }
  @keyframes waShift {
    0%, 100% { background-position: 0% 50%; }
    50%       { background-position: 100% 50%; }
  }
}

/* ============================================================
   URGENCY
============================================================ */
.h-spots { display: inline-flex; align-items: center; gap: 8px; background: rgba(37,211,102,.07); border: 1px solid rgba(37,211,102,.2); border-radius: 10px; padding: 8px 14px; margin-bottom: 22px; transition: background .4s, border-color .4s; }
.spots-dot { display: block; width: 6px; height: 6px; border-radius: 50%; background: var(--wa); flex-shrink: 0; transition: background .4s; }
.spots-txt { font-size: .8rem; color: var(--wad); font-weight: 500; }
.spots-txt b { font-weight: 700; color: var(--wa); }

@media (prefers-reduced-motion: no-preference) {
  .spots-dot { animation: spotPulse 1.5s ease-in-out infinite; }
  @keyframes spotPulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: .5; transform: scale(.8); }
  }
}

/* ============================================================
   CTA BUTTON
============================================================ */
.btn-wa { display: flex; align-items: center; gap: 12px; background: linear-gradient(135deg, #25D366, #128C7E, #25D366); background-size: 200% 100%; border-radius: var(--rb); padding: 14px 18px; cursor: pointer; text-decoration: none; border: none; position: relative; overflow: hidden; transition: transform .2s, box-shadow .2s; width: 100%; }
.btn-wa:hover { transform: translateY(-2px) scale(1.01); box-shadow: var(--sw); }
.btn-wa:active { transform: translateY(0) scale(.99); }
.btn-ico { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 10px; background: rgba(255,255,255,.2); flex-shrink: 0; }
.btn-ico svg { stroke: #fff !important; }
.btn-body { flex: 1; min-width: 0; }
.btn-main { display: block; font-size: .95rem; font-weight: 700; color: #fff; line-height: 1.2; }
.btn-hint { display: block; font-size: .73rem; color: rgba(255,255,255,.85); margin-top: 2px; }
.btn-tag { font-size: .78rem; font-weight: 700; color: #fff; white-space: nowrap; background: rgba(255,255,255,.2); padding: 4px 10px; border-radius: 6px; flex-shrink: 0; }

@media (prefers-reduced-motion: no-preference) {
  .btn-wa { animation: waGrad 4s ease infinite; }
  .btn-wa::before { content: ''; position: absolute; inset: 0; background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,.25) 50%, transparent 60%); background-size: 200% 100%; animation: btnShimmer 3s ease-in-out infinite; }
  .btn-ico { animation: iconWiggle 3s ease-in-out infinite 1s; }
  @keyframes waGrad {
    0%, 100% { background-position: 0% 50%; }
    50%       { background-position: 100% 50%; }
  }
  @keyframes btnShimmer {
    0%   { background-position: -200% 0; }
    100% { background-position:  200% 0; }
  }
  @keyframes iconWiggle {
    0%, 90%, 100% { transform: rotate(0); }
    92%           { transform: rotate(-12deg); }
    96%           { transform: rotate(12deg); }
  }
}

/* ============================================================
   TRUST STRIP
============================================================ */
.risk { display: flex; flex-wrap: wrap; gap: 10px 20px; margin-top: 14px; }
.risk-i { display: flex; align-items: center; gap: 5px; font-size: .78rem; color: var(--tx3); }
.risk-chk { color: var(--wa); font-size: .85rem; }

/* ============================================================
   SOCIAL PROOF
============================================================ */
.proof { display: flex; align-items: center; gap: 12px; margin-top: 20px; padding-top: 20px; border-top: 1px solid rgba(0,0,0,.07); }
.avs { display: flex; }
.av { width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .65rem; font-weight: 700; border: 2px solid var(--bg); flex-shrink: 0; }
.av + .av { margin-left: -10px; }
.av1 { background: linear-gradient(135deg, #1877F2, #64a8ff); color: #fff; }
.av2 { background: linear-gradient(135deg, #C13584, #F080CC); color: #fff; }
.av3 { background: linear-gradient(135deg, #25D366, #34C879); color: #fff; }
.av4 { background: linear-gradient(135deg, #128C7E, #25D366); color: #fff; }
.av-x { background: var(--bg3); color: var(--tx3); font-size: .6rem; }
.proof-stars { color: #C8831A; font-size: .9rem; letter-spacing: 1px; }
.proof-copy { font-size: .78rem; color: var(--tx2); }
.proof-copy b { color: var(--tx); font-weight: 600; }
.proof-link { font-size: .72rem; color: var(--fb); text-decoration: underline; margin-left: 4px; }

/* ============================================================
   PLATFORM CHIPS
============================================================ */
.h-plat { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.chip { display: inline-flex; align-items: center; gap: 6px; padding: 5px 12px; border-radius: var(--rp); font-size: .76rem; font-weight: 500; color: var(--tx2); border: 1px solid rgba(0,0,0,.09); background: rgba(0,0,0,.03); transition: all .2s; }
.chip:hover { background: rgba(0,0,0,.06); color: var(--tx); }
.cdot { display: block; width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; }
.c-fb .cdot { background: #1877F2; }
.c-ig .cdot { background: #C13584; }
.c-wa .cdot { background: #25D366; }
.c-go .cdot { background: #EA4335; }

/* ============================================================
   STAT BAR
============================================================ */
.stat-bar { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid rgba(0,0,0,.07); }
.sb { padding: 20px 18px; text-align: center; border-right: 1px solid rgba(0,0,0,.07); transition: background .2s; }
.sb:last-child { border-right: none; }
.sb:hover { background: rgba(0,0,0,.02); }
.sb-n { font-size: 1.6rem; font-weight: 800; line-height: 1; letter-spacing: -.03em; margin-bottom: 4px; }
.n-wa { color: var(--wad); }
.n-tx { color: var(--tx); }
.sb-l { font-size: .73rem; color: var(--tx3); font-weight: 500; }

/* ============================================================
   PLATFORMS GRID
============================================================ */
.plat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; margin-top: 4px; }
.plat { display: flex; align-items: center; gap: 10px; background: #fff; border: 1px solid rgba(0,0,0,.08); border-radius: 14px; padding: 14px 16px; transition: all .25s; box-shadow: 0 1px 4px rgba(0,0,0,.05); }
.plat:hover { border-color: rgba(24,119,242,.25); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(24,119,242,.12); }
.plat-ico { width: 38px; height: 38px; border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.plat-nm { font-size: .83rem; font-weight: 600; color: var(--tx2); }

/* ============================================================
   SERVICE CARDS
============================================================ */
.svc-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.svc-card { background: #fff; border: 1px solid rgba(0,0,0,.07); border-radius: 16px; padding: 18px; transition: all .3s; position: relative; overflow: hidden; box-shadow: 0 1px 4px rgba(0,0,0,.04); display: flex; flex-direction: column; }
.svc-card::before { content: ''; position: absolute; inset: 0; border-radius: 16px; background: radial-gradient(circle at 30% 30%, rgba(24,119,242,.04) 0%, transparent 60%); opacity: 0; transition: opacity .3s; }
.svc-card:hover { border-color: rgba(24,119,242,.2); transform: translateY(-3px); box-shadow: 0 12px 32px rgba(24,119,242,.1); }
.svc-card:hover::before { opacity: 1; }
.svc-hd { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.svc-ico { width: 36px; height: 36px; border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: box-shadow .3s; }
.svc-card:hover .svc-ico { box-shadow: 0 4px 16px rgba(24,119,242,.15); }
.svc-tag { font-size: .66rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--tx3); background: rgba(0,0,0,.04); border: 1px solid rgba(0,0,0,.08); border-radius: 4px; padding: 2px 7px; }
.svc-h3 { font-size: .93rem; font-weight: 700; color: var(--tx); margin-bottom: 6px; line-height: 1.3; }
.svc-p { font-size: .82rem; color: var(--tx2); line-height: 1.6; flex: 1; }

/* ============================================================
   PROBLEM SECTION — uses site design system
============================================================ */
.prob-list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; list-style: none; padding: 0; }
.prob-item { display: flex; align-items: flex-start; gap: 10px; background: #fff; border: 1px solid rgba(234,67,53,.12); border-left: 3px solid rgba(234,67,53,.5); border-radius: 10px; padding: 12px 14px; box-shadow: 0 1px 4px rgba(0,0,0,.04); transition: border-color .25s, box-shadow .25s, transform .25s; }
.prob-item:hover { border-color: rgba(234,67,53,.3); box-shadow: 0 4px 16px rgba(234,67,53,.1); transform: translateX(3px); }
.prob-item-icon { display: flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 50%; background: rgba(234,67,53,.08); flex-shrink: 0; margin-top: 1px; }
.prob-item-text { font-size: .87rem; color: var(--tx2); line-height: 1.55; }
.prob-item-text strong { color: var(--tx); font-weight: 700; }

/* ============================================================
   SOLUTION RESULTS ROW
============================================================ */
.sol-result { display: flex; flex-wrap: wrap; gap: 8px 16px; margin-top: 24px; background: linear-gradient(135deg, rgba(37,211,102,.07), rgba(24,119,242,.05)); border: 1px solid rgba(37,211,102,.2); border-radius: 14px; padding: 14px 18px; }
.sol-metric { display: inline-flex; align-items: center; gap: 5px; font-size: .9rem; font-weight: 700; color: var(--tx); }

/* ============================================================
   ABOUT — with real photo support
============================================================ */
.about-row { display: flex; gap: 20px; align-items: flex-start; margin-bottom: 28px; }
.about-av-wrap { flex-shrink: 0; }
.about-av { width: 72px; height: 72px; border-radius: 50%; background: linear-gradient(135deg, #1877F2, #64a8ff); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; font-weight: 800; color: #fff; position: relative; overflow: hidden; }
.about-av img { width: 100%; height: 100%; object-fit: cover; object-position: center top; position: absolute; inset: 0; }

@media (prefers-reduced-motion: no-preference) {
  .about-av { animation: avatarGlow 3s ease-in-out infinite; }
  @keyframes avatarGlow {
    0%, 100% { box-shadow: 0 0 0 3px rgba(24,119,242,.25), 0 0 0 7px rgba(24,119,242,.08); }
    50%       { box-shadow: 0 0 0 4px rgba(24,119,242,.4),  0 0 0 10px rgba(24,119,242,.12); }
  }
}

.av-star { position: absolute; bottom: -3px; right: -3px; background: var(--wa); color: #fff; width: 20px; height: 20px; border-radius: 50%; font-size: .65rem; display: flex; align-items: center; justify-content: center; border: 2px solid var(--bg); font-weight: 700; }
.about-h2 { font-size: 1.3rem; font-weight: 800; color: var(--tx); letter-spacing: -.02em; margin-bottom: 4px; }
.about-role { font-size: .8rem; color: var(--fb); font-weight: 500; margin-bottom: 10px; }
.about-bio { font-size: .87rem; color: var(--tx2); line-height: 1.65; margin-bottom: 12px; }
.certs { display: flex; flex-wrap: wrap; gap: 8px; }
.cert { display: inline-flex; align-items: center; gap: 5px; font-size: .73rem; font-weight: 500; color: var(--wad); background: rgba(37,211,102,.07); border: 1px solid rgba(37,211,102,.2); border-radius: var(--rp); padding: 4px 10px; }
.cert-dot { display: block; width: 5px; height: 5px; border-radius: 50%; background: var(--wa); flex-shrink: 0; }
.about-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; padding-top: 20px; border-top: 1px solid rgba(0,0,0,.07); }
.ast { text-align: center; }
.ast-n { font-size: 1.3rem; font-weight: 800; color: var(--wa); letter-spacing: -.02em; margin-bottom: 2px; }
.ast-l { font-size: .73rem; color: var(--tx3); }

/* ============================================================
   INDUSTRIES
============================================================ */
.ind-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 8px; }
.ind { display: flex; align-items: center; gap: 8px; background: #fff; border: 1px solid rgba(0,0,0,.07); border-radius: 12px; padding: 11px 13px; transition: all .25s; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.ind:hover { background: #f0f5ff; border-color: rgba(24,119,242,.2); transform: translateY(-2px); box-shadow: 0 4px 16px rgba(24,119,242,.1); }
.ind-ico { width: 26px; height: 26px; border-radius: 7px; background: rgba(24,119,242,.08); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ind-nm { font-size: .79rem; font-weight: 500; color: var(--tx2); }

/* ============================================================
   PRICING
============================================================ */
.price-note { font-size: .78rem; color: var(--tx3); background: rgba(37,211,102,.07); border: 1px solid rgba(37,211,102,.15); border-radius: 8px; padding: 8px 14px; margin-bottom: 20px; display: inline-block; }
.plans { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 14px; }
.plan { border-radius: 18px; overflow: hidden; border: 1px solid rgba(0,0,0,.08); background: #fff; position: relative; transition: all .3s; box-shadow: 0 2px 12px rgba(0,0,0,.06); }
.plan:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,.12); }
.plan-top { height: 3px; background: rgba(0,0,0,.06); }
.plan-start .plan-top { background: linear-gradient(90deg, #1877F2, #0A5394); }
.plan-scale .plan-top { background: linear-gradient(90deg, #25D366, #128C7E); }
.hot { border: 1px solid rgba(24,119,242,.3); box-shadow: 0 0 0 1px rgba(24,119,242,.08), 0 8px 32px rgba(24,119,242,.12); }

@media (prefers-reduced-motion: no-preference) {
  .hot { animation: planGlow 3s ease-in-out infinite; }
  @keyframes planGlow {
    0%, 100% { box-shadow: 0 0 0 1px rgba(24,119,242,.08), 0 8px 32px rgba(24,119,242,.12); }
    50%       { box-shadow: 0 0 0 1px rgba(24,119,242,.18), 0 12px 40px rgba(24,119,242,.2); }
  }
}

.plan-badge { background: linear-gradient(90deg, #0A5394, #1877F2); padding: 7px 16px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.pb-star { color: #B2F5D0; font-size: .75rem; }
.pb-txt { font-size: .72rem; font-weight: 700; color: #fff; letter-spacing: .04em; text-transform: uppercase; }

@media (prefers-reduced-motion: no-preference) {
  .pb-star { animation: starTwinkle 2s ease-in-out infinite; }
  @keyframes starTwinkle {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: .5; transform: scale(.85); }
  }
}

.plan-body { padding: 22px 20px; }
.plan-hd { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 16px; }
.plan-h3 { font-size: 1.05rem; font-weight: 800; color: var(--tx); }
.plan-sm { font-size: .75rem; color: var(--tx3); margin-top: 3px; }
.plan-sm b { color: var(--tx2); }
.plan-pr { text-align: right; }
.plan-cur { font-size: .85rem; color: var(--tx3); line-height: 1; }
.plan-amt { font-size: 1.6rem; font-weight: 800; color: var(--tx); line-height: 1.1; }
.plan-per { font-size: .68rem; color: var(--tx3); }
.plan-div { height: 1px; background: rgba(0,0,0,.07); margin-bottom: 16px; }
.pfeats { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.pf { display: flex; align-items: flex-start; gap: 8px; font-size: .8rem; color: var(--tx2); line-height: 1.4; }
.pf-c { width: 16px; height: 16px; border-radius: 50%; background: rgba(37,211,102,.12); border: 1px solid rgba(37,211,102,.2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.plan-btn { display: block; text-align: center; font-size: .83rem; font-weight: 700; padding: 12px 16px; border-radius: 12px; transition: all .25s; border: none; cursor: pointer; text-decoration: none; }
.pb-ol { border: 1px solid rgba(24,119,242,.25); color: var(--fb); background: rgba(24,119,242,.06); }
.pb-ol:hover { background: rgba(24,119,242,.13); border-color: rgba(24,119,242,.5); }
.pb-blue { background: linear-gradient(135deg, #1877F2, #64a8ff); color: #fff; box-shadow: 0 4px 16px rgba(24,119,242,.28); }
.pb-blue:hover { box-shadow: 0 6px 24px rgba(24,119,242,.4); transform: translateY(-1px); }
.pb-wa { border: 1px solid rgba(37,211,102,.35); color: var(--wad); background: rgba(37,211,102,.08); }
.pb-wa:hover { background: rgba(37,211,102,.14); border-color: rgba(37,211,102,.6); }

/* ============================================================
   REVIEWS
============================================================ */
.rdots { display: flex; gap: 6px; margin-top: 16px; margin-bottom: 4px; }
.rdot { width: 6px; height: 6px; border-radius: 3px; background: rgba(0,0,0,.15); transition: all .4s; }
.rdot.on { width: 20px; background: var(--fb); }
.revs { display: flex; gap: 12px; overflow-x: auto; scroll-snap-type: x mandatory; padding: 16px 28px 24px; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
.revs::-webkit-scrollbar { display: none; }
.rev { min-width: 240px; max-width: 260px; background: #fff; border: 1px solid rgba(0,0,0,.07); border-radius: 16px; padding: 18px; flex-shrink: 0; scroll-snap-align: start; transition: all .3s; box-shadow: 0 1px 6px rgba(0,0,0,.05); }
.rev:hover { border-color: rgba(24,119,242,.2); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(24,119,242,.1); }
.rev-top { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.rev-av { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .65rem; font-weight: 700; flex-shrink: 0; }
.ra1 { background: linear-gradient(135deg, #1877F2, #64a8ff); color: #fff; }
.ra2 { background: linear-gradient(135deg, #C13584, #F080CC); color: #fff; }
.ra3 { background: linear-gradient(135deg, #25D366, #34C879); color: #fff; }
.ra4 { background: linear-gradient(135deg, #128C7E, #25D366); color: #fff; }
.ra5 { background: linear-gradient(135deg, #8B5CF6, #C4B5FD); color: #fff; }
.ra6 { background: linear-gradient(135deg, #EC4899, #F9A8D4); color: #fff; }
.ra7 { background: linear-gradient(135deg, #F97316, #FB923C); color: #fff; }
.ra8 { background: linear-gradient(135deg, #14B8A6, #99F6E4); color: #0A0D1A; }
.rev-nm { font-size: .83rem; font-weight: 700; color: var(--tx); }
.rev-biz { font-size: .72rem; color: var(--tx3); }
.rev-str { color: #C8831A; font-size: .8rem; letter-spacing: 1px; margin-bottom: 8px; }
.rev-p { font-size: .8rem; color: var(--tx2); line-height: 1.55; margin-bottom: 10px; font-style: italic; }
.rev-tag { display: inline-block; font-size: .69rem; font-weight: 600; color: var(--wad); background: rgba(37,211,102,.1); border: 1px solid rgba(37,211,102,.2); border-radius: 4px; padding: 2px 7px; }
.trust-row { display: flex; flex-wrap: wrap; gap: 8px; padding: 16px 28px 28px; }
.tp { display: inline-flex; align-items: center; gap: 5px; font-size: .73rem; color: var(--tx3); font-weight: 500; background: #fff; border: 1px solid rgba(0,0,0,.08); border-radius: var(--rp); padding: 5px 12px; box-shadow: 0 1px 3px rgba(0,0,0,.04); }

/* ============================================================
   GUARANTEE & STEPS
============================================================ */
.guar { display: flex; gap: 16px; align-items: flex-start; background: rgba(37,211,102,.05); border: 1px solid rgba(37,211,102,.18); border-radius: 16px; padding: 18px 20px; }
.guar-ico { width: 42px; height: 42px; border-radius: 12px; background: rgba(37,211,102,.12); border: 1px solid rgba(37,211,102,.25); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

@media (prefers-reduced-motion: no-preference) {
  .guar-ico { animation: shieldPulse 2.5s ease-in-out infinite; }
  @keyframes shieldPulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(37,211,102,.3); }
    50%       { box-shadow: 0 0 0 8px rgba(37,211,102,0); }
  }
}

.guar-h3 { font-size: .95rem; font-weight: 700; color: var(--wa); margin-bottom: 4px; }
.guar-p { font-size: .83rem; color: var(--tx2); line-height: 1.55; }
.guar-p strong { color: var(--tx); }
.steps { display: flex; flex-direction: column; }
.step { display: flex; gap: 16px; align-items: flex-start; padding: 16px 0; }
.step:not(:last-child) { border-bottom: 1px dashed rgba(0,0,0,.08); }
.step-n { width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0; background: linear-gradient(135deg, rgba(24,119,242,.12), rgba(24,119,242,.04)); border: 1px solid rgba(24,119,242,.25); display: flex; align-items: center; justify-content: center; font-size: .85rem; font-weight: 800; color: var(--fb); transition: all .3s; }
.step:hover .step-n { background: linear-gradient(135deg, #1877F2, #64a8ff); color: #fff; border-color: transparent; box-shadow: var(--sb); }
.step-h4 { font-size: .9rem; font-weight: 700; color: var(--tx); margin-bottom: 4px; }
.step-p { font-size: .82rem; color: var(--tx2); line-height: 1.55; }

/* ============================================================
   FAQ
============================================================ */
.faq-wrap { display: flex; flex-direction: column; gap: 8px; }
.faq-hd { margin-bottom: 4px; }
details { background: #fff; border: 1px solid rgba(0,0,0,.08); border-radius: 14px; overflow: hidden; transition: border-color .25s; box-shadow: 0 1px 4px rgba(0,0,0,.04); }
details[open] { border-color: rgba(24,119,242,.3); }
details[open] summary { color: var(--fb); }
summary { cursor: pointer; list-style: none; padding: 16px 20px; font-size: .88rem; font-weight: 600; color: var(--tx); display: flex; align-items: center; justify-content: space-between; gap: 12px; transition: color .2s; user-select: none; }
summary::-webkit-details-marker { display: none; }
summary::after { content: '+'; font-size: 1.2rem; font-weight: 300; color: var(--tx3); flex-shrink: 0; transition: transform .25s; }
details[open] summary::after { transform: rotate(45deg); color: var(--fb); }
.faq-a { padding: 0 20px 16px; font-size: .83rem; color: var(--tx2); line-height: 1.65; }

/* ============================================================
   FINAL CTA
============================================================ */
.final-cta { background: linear-gradient(135deg, rgba(24,119,242,.06) 0%, rgba(37,211,102,.06) 100%); border: 1px solid rgba(37,211,102,.18); border-radius: var(--rc); padding: 36px 28px; text-align: center; position: relative; overflow: hidden; box-shadow: 0 2px 20px rgba(0,0,0,.06); }
.final-cta::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 50% at 50% 0%, rgba(37,211,102,.08) 0%, transparent 70%); pointer-events: none; }
.final-h2 { font-size: clamp(1.5rem, 5vw, 2rem); font-weight: 900; letter-spacing: -.04em; color: var(--tx); margin-bottom: 8px; }
.final-p { font-size: .9rem; color: var(--tx2); margin-bottom: 20px; }
.urgency-strip { display: inline-flex; align-items: center; gap: 8px; background: rgba(37,211,102,.07); border: 1px solid rgba(37,211,102,.2); border-radius: 10px; padding: 8px 14px; margin-bottom: 24px; }
.urgency-p { font-size: .8rem; color: var(--wad); margin: 0; }
.urgency-p span { font-weight: 700; color: var(--wa); }

@media (prefers-reduced-motion: no-preference) {
  .urgency-strip svg { animation: clockTick 1s step-end infinite; }
  @keyframes clockTick {
    0%, 100% { opacity: 1; }
    50%       { opacity: .5; }
  }
}

/* ============================================================
   FOOTER
============================================================ */
.ft { padding: 28px; border-top: 1px solid rgba(0,0,0,.08); text-align: center; }
.ft-nm { font-size: 1.05rem; font-weight: 800; color: var(--tx); letter-spacing: -.02em; }
.ft-nm em { font-style: normal; color: var(--wad); }
.ft-tag { font-size: .76rem; color: var(--tx3); line-height: 1.7; margin: 8px 0 20px; }
.ft-nav { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px 16px; margin-bottom: 20px; }
.ft-lk { font-size: .76rem; color: var(--tx3); transition: color .2s; }
.ft-lk:hover { color: var(--fb); }
.socials { display: flex; justify-content: center; gap: 8px; margin-bottom: 20px; }
.soc { width: 34px; height: 34px; border-radius: 9px; display: flex; align-items: center; justify-content: center; background: #fff; border: 1px solid rgba(0,0,0,.09); transition: all .2s; box-shadow: 0 1px 3px rgba(0,0,0,.05); }
.soc:hover { background: #EEF4FF; border-color: rgba(24,119,242,.25); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(24,119,242,.12); }
.soc:hover svg { stroke: var(--fb); }
.soc svg { stroke: #6C6880; transition: stroke .2s; }
.ft-bot { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 10px; border-top: 1px solid rgba(0,0,0,.07); padding-top: 16px; }
.ft-copy { font-size: .72rem; color: var(--tx3); }
.ft-cert { display: inline-flex; align-items: center; gap: 5px; font-size: .72rem; color: var(--fb); font-weight: 500; }

/* ============================================================
   STICKY CTA BAR
============================================================ */
.sticky { position: fixed; bottom: 0; left: 0; right: 0; z-index: 200; padding: 10px 12px 12px; background: rgba(247,244,239,.95); backdrop-filter: blur(16px); border-top: 1px solid rgba(0,0,0,.09); transform: translateY(100%); transition: transform .4s cubic-bezier(.4,0,.2,1); box-shadow: 0 -4px 24px rgba(0,0,0,.1); }
.sticky.show { transform: translateY(0); }
.sticky-inner { display: flex; align-items: center; gap: 12px; background: linear-gradient(135deg, #25D366, #128C7E, #25D366); background-size: 200% 100%; border-radius: 14px; padding: 12px 18px; transition: transform .2s; }
.sticky-inner:hover { transform: scale(1.01); }
.si-main { display: block; font-size: .88rem; font-weight: 700; color: #fff; }
.si-sub { display: block; font-size: .7rem; color: rgba(255,255,255,.85); }
.si-tag { font-size: .78rem; font-weight: 700; color: #fff; white-space: nowrap; background: rgba(255,255,255,.2); padding: 3px 9px; border-radius: 6px; }

@media (prefers-reduced-motion: no-preference) {
  .sticky-inner { animation: waGrad 4s ease infinite; }
}

/* ============================================================
   SCROLL REVEAL — visible by default; animated only after JS adds .js-ready to body
============================================================ */
.reveal { opacity: 1; transform: none; }
.js-ready .reveal { opacity: 0; transform: translateY(24px); transition: opacity .6s ease, transform .6s ease; }
.js-ready .reveal.in { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) { .js-ready .reveal { opacity: 1; transform: none; transition: none; } }

/* ============================================================
   SVG DRAW ANIMATION
============================================================ */
.anim-draw path,
.anim-draw circle,
.anim-draw rect,
.anim-draw polyline,
.anim-draw line,
.anim-draw ellipse {
  stroke-dasharray: 200;
  stroke-dashoffset: 200;
}

@media (prefers-reduced-motion: no-preference) {
  .anim-draw.drawn path,
  .anim-draw.drawn circle,
  .anim-draw.drawn rect,
  .anim-draw.drawn polyline,
  .anim-draw.drawn line,
  .anim-draw.drawn ellipse {
    stroke-dashoffset: 0;
    transition: stroke-dashoffset .8s cubic-bezier(.4,0,.2,1);
  }
}

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width: 480px) {
  .hdr-in { padding: 12px 16px; }
  .hero { padding: 24px 18px 20px; }
  .sec { padding: 24px 18px; }
  .stat-bar .sb { padding: 16px 10px; }
  .sb-n { font-size: 1.3rem; }
  .plans { grid-template-columns: 1fr; }
  .about-row { flex-direction: column; align-items: center; text-align: center; }
  .certs { justify-content: center; }
  .about-stats { grid-template-columns: repeat(3, 1fr); }
  .trust-row { padding: 12px 18px 18px; }
  .ft { padding: 20px 18px; }
  .revs { padding: 12px 18px 20px; }
  .final-cta { padding: 28px 18px; }
  .svc-grid { grid-template-columns: 1fr; }
  .svc-card { padding: 16px; }
  .plat-grid { grid-template-columns: repeat(2, 1fr); }
  .ind-grid { grid-template-columns: repeat(2, 1fr); }
  .h-spots { flex-wrap: wrap; }
}

@media (max-width: 420px) {
  .btn-wa { padding: 13px 14px; gap: 10px; }
  .btn-ico { width: 36px; height: 36px; }
  .btn-main { font-size: .88rem; }
  .btn-hint { font-size: .68rem; }
  .btn-tag { display: none; }
}

@media (max-width: 360px) {
  .stat-bar { grid-template-columns: repeat(3, 1fr); }
  .sb-n { font-size: 1.1rem; }
}