/* ==========================================================================
   Shop Social Fans — Theme Stylesheet
   Identity: Clean monochrome (black/white) primary + light blue accent.
   ========================================================================== */

/* ── Design Tokens ────────────────────────────────────────────────────── */
:root{
  /* Mono base */
  --c-ink:#0A0A0A;           /* near-black */
  --c-ink-2:#171717;
  --c-ink-3:#262626;
  --c-text:#1f1f23;
  --c-mute:#6b7280;
  --c-mute-2:#9aa3b2;
  --c-line:#e6e8ee;
  --c-line-2:#f0f1f5;
  --c-bg:#ffffff;
  --c-bg-soft:#f6f8fb;
  --c-bg-card:#ffffff;

  /* Light blue accent system */
  --c-brand:#0EA5E9;         /* sky 500 — primary accent */
  --c-brand-2:#38BDF8;       /* sky 400 */
  --c-brand-3:#7DD3FC;       /* sky 300 */
  --c-brand-soft:#E0F2FE;    /* sky 100 */
  --c-accent:#0284C7;        /* sky 600 — darker hover */
  --c-gold:#F5B544;
  --c-success:#10B981;
  --c-rose:#F43F5E;

  /* Gradients — light & airy */
  --g-hero:linear-gradient(180deg,#FFFFFF 0%,#F0F9FF 55%,#E0F2FE 100%);
  --g-brand:linear-gradient(135deg,#0A0A0A 0%,#1f1f23 100%);    /* mono primary */
  --g-accent:linear-gradient(135deg,#0EA5E9 0%,#38BDF8 100%);   /* blue accent */
  --g-soft:linear-gradient(180deg,#ffffff 0%,#f6f8fb 100%);

  /* Shadows — softer, mono */
  --sh-1:0 1px 2px rgba(10,10,10,.04);
  --sh-2:0 6px 20px -8px rgba(10,10,10,.10);
  --sh-3:0 16px 40px -16px rgba(10,10,10,.16);
  --sh-brand:0 10px 28px -12px rgba(14,165,233,.40);

  /* Radius */
  --r-sm:8px;
  --r-md:12px;
  --r-lg:18px;
  --r-xl:24px;
  --r-pill:999px;

  /* Type */
  --f-sans:'Plus Jakarta Sans','Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --f-display:'Plus Jakarta Sans','Inter',sans-serif;

  /* Layout */
  --container:1200px;
}

/* ── Reset & Base ─────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--f-sans);
  font-feature-settings:'cv11','ss01','ss03';
  color:var(--c-text);
  background:var(--c-bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{color:var(--c-brand);text-decoration:none;transition:color .2s}
a:hover{color:var(--c-brand-2)}
img,svg{max-width:100%;height:auto;display:block}
h1,h2,h3,h4,h5,h6{
  margin:0 0 .55em;color:var(--c-ink);
  font-family:var(--f-display);
  font-weight:800;line-height:1.15;
  letter-spacing:-.02em;
}
h1{font-size:clamp(2.2rem,5vw,3.6rem);letter-spacing:-.03em}
h2{font-size:clamp(1.7rem,3.4vw,2.4rem)}
h3{font-size:1.25rem}
h4{font-size:1.05rem}
p{margin:0 0 1em}
ul{padding-left:0;list-style:none;margin:0}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:rgba(56,189,248,.25)}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.text-center{text-align:center}
.bg-soft{background:var(--c-bg-soft)}
.bg-ink{background:var(--c-ink);color:#dfe3f3}
.eyebrow{
  display:inline-block;font-size:.78rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--c-brand);background:rgba(14,165,233,.08);
  padding:6px 14px;border-radius:var(--r-pill);margin-bottom:18px;
}
.hero .eyebrow,.hero-dark .eyebrow{color:#E9DEFF;background:rgba(125,211,252,.22);border:1px solid rgba(125,211,252,.35);text-shadow:0 1px 2px rgba(0,0,0,.25)}

/* ── Buttons ──────────────────────────────────────────────────────────── */
.btn-primary,.btn-secondary,.btn-outline,.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 26px;border-radius:var(--r-pill);
  font-weight:700;font-size:.95rem;letter-spacing:-.01em;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease,border-color .2s ease;
  cursor:pointer;text-align:center;border:1.5px solid transparent;white-space:nowrap;
}
.btn-primary{background:var(--g-brand);color:#fff!important;box-shadow:var(--sh-brand)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 22px 50px -12px rgba(14,165,233,.5);color:#fff!important}
.btn-secondary{background:var(--c-ink);color:#fff!important}
.btn-secondary:hover{background:#000;transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--c-ink)!important;border-color:var(--c-line)}
.btn-outline:hover{border-color:var(--c-brand);color:var(--c-brand)!important;background:#fff}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff!important;border-color:rgba(255,255,255,.18);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(255,255,255,.15);color:#fff!important}
.btn-sm{padding:9px 18px;font-size:.85rem}
.btn-lg{padding:16px 32px;font-size:1.02rem}
.btn-block{width:100%}

/* ── Top Bar ─────────────────────────────────────────────────────────── */
.top-bar{
  background:var(--c-ink);color:#c8cee8;font-size:.78rem;
  padding:0;margin:0;line-height:1.4;
  border-bottom:1px solid rgba(255,255,255,.04);
  height:40px;min-height:40px;max-height:40px;overflow:hidden;
  display:flex;align-items:center;
}
.top-bar-inner{
  display:flex;flex-wrap:nowrap;gap:22px;justify-content:center;align-items:center;
  width:100%;height:100%;margin:0;padding:0 24px;min-height:0;
}
.top-bar span{white-space:nowrap;display:inline-flex;align-items:center;gap:6px;flex-shrink:0;line-height:1}
@media (max-width:1100px){.top-bar{height:auto;max-height:none}.top-bar-inner{flex-wrap:wrap;padding:8px 24px}}
@media (max-width:760px){.top-bar span:nth-child(n+4){display:none}}
.top-bar .dot{width:6px;height:6px;border-radius:50%;background:var(--c-success);box-shadow:0 0 0 4px rgba(16,185,129,.18);animation:pulseDot 2s infinite}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.45}}
@media (max-width:760px){.top-bar span:nth-child(n+4){display:none}}

/* ── Header ──────────────────────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--c-line-2);
  transition:box-shadow .2s,background .2s;
}
.site-header.scrolled{box-shadow:0 10px 30px -16px rgba(15,18,40,.18);background:rgba(255,255,255,.96)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;gap:24px}

/* Logo */
.site-logo{display:inline-flex;align-items:center;gap:10px;font-size:1.22rem;font-weight:800;color:var(--c-ink);letter-spacing:-.02em}
.site-logo:hover{color:var(--c-ink)}
.site-logo .logo-mark{
  width:36px;height:36px;border-radius:10px;
  background:var(--g-brand);
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:var(--sh-brand);
}
.site-logo .logo-mark svg{width:20px;height:20px}
.site-logo .logo-text{display:inline-flex;flex-direction:column;line-height:1}
.site-logo .logo-text strong{font-weight:800;background:var(--g-brand);-webkit-background-clip:text;background-clip:text;color:transparent}
.site-logo .logo-text small{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--c-mute);font-weight:600;margin-top:3px}

/* Nav */
.main-nav .nav-list{display:flex;gap:0;align-items:center;flex-wrap:nowrap}
.main-nav .nav-list>li>a{
  display:inline-flex;align-items:center;gap:4px;white-space:nowrap;
  padding:9px 11px;color:var(--c-text);font-weight:600;font-size:.9rem;
  border-radius:10px;transition:.2s;
}
@media (max-width:1180px){.main-nav .nav-list>li>a{padding:9px 9px;font-size:.86rem}}
.main-nav .nav-list>li>a:hover{background:var(--c-bg-soft);color:var(--c-brand)}
.has-dropdown{position:relative}
.dropdown{
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);
  background:#fff;min-width:280px;
  box-shadow:var(--sh-3);border:1px solid var(--c-line-2);
  border-radius:var(--r-md);padding:10px;opacity:0;visibility:hidden;transition:.2s;z-index:50;
}
.has-dropdown:hover .dropdown,.has-dropdown.open .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown li a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--c-text);font-size:.9rem;font-weight:500}
.dropdown li a:hover{background:var(--c-bg-soft);color:var(--c-brand)}
.dropdown li a .em{font-size:1.1rem}
.arrow{font-size:.65rem;opacity:.55;transition:transform .2s}
.has-dropdown:hover .arrow{transform:rotate(180deg)}

.nav-cta{display:inline-flex;align-items:center;gap:10px}

/* ── Cart icon in header ─────────────────────────────────────────── */
.cart-link{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:12px;
  color:var(--c-ink);background:var(--c-bg-soft);border:1px solid var(--c-line);
  transition:.2s;margin-left:8px;
}
.cart-link:hover{background:#fff;color:var(--c-brand);border-color:var(--c-brand-3);transform:translateY(-1px);box-shadow:var(--sh-1)}
.cart-link svg{width:20px;height:20px}
.cart-count{
  position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;padding:0 5px;
  border-radius:10px;background:var(--g-brand);color:#fff;font-size:.68rem;
  font-weight:800;display:inline-flex;align-items:center;justify-content:center;
  line-height:1;box-shadow:0 4px 10px rgba(14,165,233,.35);
  border:2px solid #fff;transition:transform .2s;
}
.cart-count.empty{background:#e5e7eb;color:#94a3b8;font-weight:700;box-shadow:none;border-color:#fff}
.cart-link:hover .cart-count{transform:scale(1.1)}
.hamburger{display:none;width:42px;height:42px;flex-direction:column;justify-content:center;align-items:center;gap:5px;border-radius:8px}
.hamburger:hover{background:var(--c-bg-soft)}
.hamburger span{display:block;width:22px;height:2px;background:var(--c-ink);transition:.2s;border-radius:2px}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:991px){
  .main-nav{position:fixed;top:0;right:-100%;width:320px;max-width:88%;height:100vh;background:#fff;padding:90px 22px 30px;overflow-y:auto;transition:right .3s;box-shadow:-12px 0 40px rgba(0,0,0,.2);z-index:90}
  .main-nav.open{right:0}
  .main-nav .nav-list{flex-direction:column;align-items:stretch;gap:0}
  .main-nav .nav-list>li{border-bottom:1px solid var(--c-line-2)}
  .main-nav .nav-list>li>a{padding:14px 4px;justify-content:space-between;font-size:1rem}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:0 0 12px 16px;display:none;min-width:0}
  .has-dropdown.open .dropdown{display:block}
  .hamburger{display:flex}
  .header-inner .nav-cta .btn-primary{display:none}
}

/* ── Sections ────────────────────────────────────────────────────────── */
section{padding:96px 0}
@media (max-width:720px){section{padding:64px 0}}
.section-head{text-align:center;max-width:720px;margin:0 auto 56px}
.section-head h2{margin-bottom:14px}
.section-head p{color:var(--c-mute);font-size:1.06rem;margin:0}

/* ── Hero (light, airy) ──────────────────────────────────────────────── */
.hero{position:relative;background:var(--g-hero);color:var(--c-ink);overflow:hidden;padding:96px 0 88px;border-bottom:1px solid var(--c-line-2)}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(55% 55% at 85% 15%,rgba(14,165,233,.18),transparent 60%),
  radial-gradient(45% 45% at 8% 85%,rgba(125,211,252,.22),transparent 60%);
  pointer-events:none}
.hero::after{content:"";position:absolute;inset:0;background-image:
  linear-gradient(rgba(10,10,10,.035) 1px,transparent 1px),
  linear-gradient(90deg,rgba(10,10,10,.035) 1px,transparent 1px);
  background-size:42px 42px;mask-image:radial-gradient(ellipse at 50% 35%,#000 10%,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 35%,#000 10%,transparent 70%);
  pointer-events:none;opacity:.7}
.hero h1,.hero h2,.hero h3{color:var(--c-ink)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
@media (max-width:960px){.hero-grid{grid-template-columns:1fr;gap:50px;text-align:center}}
.hero-copy h1 .accent{
  background:var(--g-accent);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-copy .lead{color:var(--c-text);font-size:1.18rem;max-width:560px;margin:0 0 32px;line-height:1.65;opacity:.85}
@media (max-width:960px){.hero-copy .lead{margin-left:auto;margin-right:auto}}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:36px}
@media (max-width:960px){.hero-cta{justify-content:center}}
.hero-trust{display:flex;flex-wrap:wrap;gap:22px;color:var(--c-mute);font-size:.88rem;font-weight:600}
@media (max-width:960px){.hero-trust{justify-content:center}}
.hero-trust span{display:inline-flex;align-items:center;gap:8px;color:var(--c-text)}
.hero-trust svg{width:18px;height:18px;color:var(--c-brand)}
/* Hero .eyebrow override (was light-on-dark; now blue chip on white) */
.hero .eyebrow{color:var(--c-brand);background:var(--c-brand-soft);border:1px solid #BAE6FD;text-shadow:none}
/* Hero .btn-ghost was tuned for dark bg — re-tune for light */
.hero .btn-ghost{background:#fff;color:var(--c-ink)!important;border-color:var(--c-line);backdrop-filter:none}
.hero .btn-ghost:hover{background:var(--c-bg-soft);color:var(--c-ink)!important;border-color:var(--c-brand-3)}

/* Hero visual: phone preview + floating cards */
.hero-visual{position:relative;min-height:480px}
.hero-phone{
  width:280px;margin:0 auto;background:linear-gradient(180deg,#171717,#0A0A0A);
  border:8px solid #0A0A0A;border-radius:36px;padding:18px;
  box-shadow:0 40px 80px -20px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.05) inset;
  position:relative;
}
.hero-phone .notch{width:90px;height:18px;border-radius:0 0 12px 12px;background:#000;margin:-18px auto 14px}
.hero-phone .profile{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.hero-phone .avatar{width:46px;height:46px;border-radius:50%;background:var(--g-brand);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800}
.hero-phone .profile strong{color:#fff;font-size:.9rem;display:block}
.hero-phone .profile small{color:#8893b3;font-size:.72rem}
.hero-phone .stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:14px}
.hero-phone .stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:10px 6px;text-align:center}
.hero-phone .stat b{color:#fff;display:block;font-size:.95rem;font-weight:800}
.hero-phone .stat span{color:#8893b3;font-size:.62rem;letter-spacing:.04em}
.hero-phone .chart{height:90px;background:linear-gradient(180deg,rgba(56,189,248,.25),transparent);border-radius:10px;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.05)}
.hero-phone .chart svg{width:100%;height:100%}
.hero-phone .chart .line{stroke:url(#g);stroke-width:2.5;fill:none}
.hero-phone .chart .area{fill:url(#g2);opacity:.45}

.float-card{
  position:absolute;background:#fff;
  border:1px solid var(--c-line);border-radius:14px;
  padding:12px 16px;color:var(--c-ink);display:flex;align-items:center;gap:10px;
  box-shadow:var(--sh-3);min-width:170px;
  animation:floatY 6s ease-in-out infinite;
}
.float-card .ic{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0;background:var(--c-bg-soft)}
.float-card strong{display:block;font-size:.95rem;font-weight:700;line-height:1.1;color:var(--c-ink)}
.float-card span{font-size:.72rem;color:var(--c-mute);display:block;margin-top:2px}
.float-card.f1{top:8%;left:-6%;animation-delay:0s}
.float-card.f1 .ic{background:rgba(2,132,199,.25);color:#0284C7}
.float-card.f2{top:42%;right:-10%;animation-delay:1.5s}
.float-card.f2 .ic{background:rgba(236,72,153,.25);color:#F472B6}
.float-card.f3{bottom:6%;left:-4%;animation-delay:2.6s}
.float-card.f3 .ic{background:rgba(16,185,129,.25);color:#34D399}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media (max-width:960px){.hero-visual{min-height:auto;margin-top:20px}.float-card.f1{left:0}.float-card.f2{right:0}.float-card.f3{left:0}}
@media (max-width:520px){.float-card{display:none}.hero-phone{width:240px}}

/* ── Logo / Trust strip ──────────────────────────────────────────────── */
.trust-strip{padding:42px 0;background:var(--c-bg-soft);border-top:1px solid var(--c-line-2);border-bottom:1px solid var(--c-line-2)}
.trust-strip .label{text-align:center;color:var(--c-mute);font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;font-weight:700;margin-bottom:22px}
.trust-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:36px 48px;color:var(--c-mute);font-weight:700;font-size:1rem;opacity:.8}
.trust-row .pill{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--r-pill);background:#fff;border:1px solid var(--c-line);box-shadow:var(--sh-1);color:var(--c-text);font-size:.86rem}
.trust-row .pill .ic{font-size:1.1rem}

/* ── Platforms (simplified main 4) ───────────────────────────────────── */
.platform-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media (max-width:960px){.platform-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.platform-grid{grid-template-columns:1fr}}
.platform-card{
  position:relative;background:#fff;border:1px solid var(--c-line);
  border-radius:var(--r-lg);padding:30px 26px;color:var(--c-ink)!important;
  display:flex;flex-direction:column;gap:14px;transition:.25s;overflow:hidden;
}
.platform-card::after{content:"";position:absolute;inset:auto -30% -60% auto;width:200px;height:200px;background:var(--g-brand);filter:blur(60px);opacity:0;transition:.3s}
.platform-card:hover{transform:translateY(-6px);border-color:transparent;box-shadow:var(--sh-3)}
.platform-card:hover::after{opacity:.18}
.platform-card .platform-icon{
  width:56px;height:56px;border-radius:14px;background:var(--c-bg-soft);
  display:flex;align-items:center;justify-content:center;font-size:1.6rem;
}
.platform-card.ig .platform-icon{background:linear-gradient(135deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5);color:#fff}
.platform-card.tt .platform-icon{background:#000;color:#fff}
.platform-card.yt .platform-icon{background:#FF0000;color:#fff}
.platform-card.sp .platform-icon{background:#1DB954;color:#fff}
.platform-card.fb .platform-icon{background:#1877F2;color:#fff}
.platform-card.tw .platform-icon{background:#000;color:#fff}
.platform-card.li .platform-icon{background:#0A66C2;color:#fff}
.platform-card.tc .platform-icon{background:#9146FF;color:#fff}
.platform-card.th .platform-icon{background:#000;color:#fff}
.platform-card h3{margin:0;font-size:1.12rem}
.platform-card .services{display:flex;flex-wrap:wrap;gap:6px;margin:0}
.platform-card .services li{font-size:.78rem;font-weight:600;color:var(--c-mute);background:var(--c-bg-soft);border:1px solid var(--c-line-2);padding:4px 10px;border-radius:var(--r-pill)}
.platform-card .from{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px dashed var(--c-line);position:relative;z-index:1}
.platform-card .from small{color:var(--c-mute);font-size:.78rem}
.platform-card .from b{color:var(--c-ink);font-weight:800}
.platform-card .arrow-link{color:var(--c-brand);font-weight:700;font-size:.85rem;display:inline-flex;align-items:center;gap:4px;transition:gap .2s}
.platform-card:hover .arrow-link{gap:8px}

/* "More platforms" inline row */
.more-platforms{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:30px}
.more-platforms a{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--r-pill);background:#fff;border:1px solid var(--c-line);color:var(--c-text)!important;font-size:.86rem;font-weight:600;transition:.2s}
.more-platforms a:hover{border-color:var(--c-brand);color:var(--c-brand)!important;transform:translateY(-2px);box-shadow:var(--sh-1)}

/* ── Why Us / Features ──────────────────────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:880px){.features-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.features-grid{grid-template-columns:1fr}}
.feature-card{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);
  padding:32px 28px;transition:.25s;display:flex;flex-direction:column;gap:12px;
}
.feature-card:hover{border-color:var(--c-brand-3);box-shadow:var(--sh-2);transform:translateY(-4px)}
.feature-card .icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,rgba(14,165,233,.12),rgba(2,132,199,.12));
  color:var(--c-brand);display:flex;align-items:center;justify-content:center;font-size:1.5rem;
  border:1px solid rgba(14,165,233,.12);
}
.feature-card h3{margin:0;font-size:1.08rem}
.feature-card p{color:var(--c-mute);font-size:.95rem;margin:0;line-height:1.6}

/* ── How It Works (3-step) ──────────────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;position:relative}
@media (max-width:880px){.steps{grid-template-columns:1fr}}
.steps::before{
  content:"";position:absolute;top:34px;left:14%;right:14%;height:2px;
  background:repeating-linear-gradient(90deg,var(--c-brand-3) 0 8px,transparent 8px 16px);
  z-index:0;
}
@media (max-width:880px){.steps::before{display:none}}
.step{position:relative;text-align:center;padding:0 12px;z-index:1}
.step .num{
  width:68px;height:68px;border-radius:50%;
  background:#fff;border:2px solid var(--c-brand);
  color:var(--c-brand);font-size:1.5rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;margin:0 auto 18px;
  box-shadow:0 10px 30px -10px rgba(14,165,233,.3);
}
.step h3{font-size:1.15rem;margin-bottom:8px}
.step p{color:var(--c-mute);font-size:.95rem;margin:0}

/* ── Pricing tiers (Starter / Growth / Premium) ─────────────────────── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
@media (max-width:880px){.pricing-grid{grid-template-columns:1fr}}
.pricing-card{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-xl);
  padding:34px 28px;display:flex;flex-direction:column;gap:14px;
  transition:.25s;position:relative;
}
.pricing-card.featured{border:2px solid var(--c-brand);box-shadow:var(--sh-brand);transform:translateY(-6px);background:linear-gradient(180deg,#fff,#F0F9FF)}
.pricing-card.featured::before{
  content:"Most Popular";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--g-brand);color:#fff;font-size:.72rem;font-weight:800;
  letter-spacing:.12em;text-transform:uppercase;padding:6px 14px;border-radius:var(--r-pill);
  box-shadow:var(--sh-brand);
}
.pricing-card .tier-name{font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;color:var(--c-mute);font-weight:700}
.pricing-card .tier-tag{font-size:1.5rem;font-weight:800;color:var(--c-ink);margin:0}
.pricing-card .tier-price{display:flex;align-items:baseline;gap:6px;margin:6px 0 4px}
.pricing-card .tier-price .amt{font-size:2.6rem;font-weight:800;color:var(--c-ink);letter-spacing:-.02em;line-height:1}
.pricing-card .tier-price .per{color:var(--c-mute);font-size:.92rem}
.pricing-card .tier-sub{color:var(--c-mute);font-size:.88rem;margin:0 0 4px}
.pricing-card ul.feats{display:flex;flex-direction:column;gap:8px;margin:14px 0 22px;font-size:.92rem;color:var(--c-text)}
.pricing-card ul.feats li{display:flex;align-items:flex-start;gap:10px}
.pricing-card ul.feats li::before{
  content:"";flex-shrink:0;width:18px;height:18px;border-radius:50%;
  background:rgba(16,185,129,.12);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%2310B981'><path fill-rule='evenodd' d='M16.7 5.3a1 1 0 010 1.4l-7.5 7.5a1 1 0 01-1.4 0l-3.5-3.5a1 1 0 011.4-1.4L8.5 12 15.3 5.3a1 1 0 011.4 0z' clip-rule='evenodd'/></svg>");
  background-position:center;background-repeat:no-repeat;margin-top:3px;
}
.pricing-card .btn-primary,.pricing-card .btn-outline{margin-top:auto;width:100%}

/* ── Subscriptions (recurring growth plans) ──────────────────────────── */
.subs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:880px){.subs-grid{grid-template-columns:1fr}}
.sub-card{
  background:#fff;color:var(--c-text);border-radius:var(--r-xl);padding:32px 28px;
  border:1px solid var(--c-line);position:relative;overflow:hidden;
  display:flex;flex-direction:column;gap:14px;
  transition:.25s;
}
.sub-card:hover{border-color:var(--c-brand-3);box-shadow:var(--sh-3);transform:translateY(-4px)}
.sub-card::before{content:"";position:absolute;inset:auto -40% -60% auto;width:260px;height:260px;background:radial-gradient(circle,rgba(14,165,233,.18),transparent 70%);filter:blur(20px);pointer-events:none}
.sub-card h3{color:var(--c-ink);margin:0;position:relative;z-index:1}
.sub-card .plat{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--c-brand);position:relative;z-index:1}
.sub-card .price{font-size:2.4rem;font-weight:800;letter-spacing:-.02em;line-height:1;color:var(--c-ink);position:relative;z-index:1}
.sub-card .price small{font-size:.88rem;font-weight:500;color:var(--c-mute)}
.sub-card ul{display:flex;flex-direction:column;gap:8px;margin:8px 0 18px;color:var(--c-text);font-size:.92rem;position:relative;z-index:1}
.sub-card ul li{display:flex;align-items:flex-start;gap:8px}
.sub-card ul li::before{content:"✓";color:var(--c-brand);font-weight:800;flex-shrink:0}
.sub-card .btn-primary{position:relative;z-index:1;width:100%}

/* ── Stats Bar ───────────────────────────────────────────────────────── */
.stats-bar{background:var(--g-brand);color:#fff;padding:60px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
@media (max-width:760px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
.stat-num{font-size:2.6rem;font-weight:800;display:block;line-height:1;letter-spacing:-.02em}
.stat-label{color:rgba(255,255,255,.85);font-size:.92rem;margin-top:8px;display:block;font-weight:500}

/* ── Testimonials ────────────────────────────────────────────────────── */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:960px){.testimonials-grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.testimonials-grid{grid-template-columns:1fr}}
.testimonial{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:28px;display:flex;flex-direction:column;gap:14px;transition:.25s}
.testimonial:hover{box-shadow:var(--sh-2);transform:translateY(-3px)}
.testimonial .stars{color:#F5B544;font-size:1rem;letter-spacing:1px}
.testimonial blockquote{margin:0;color:var(--c-text);line-height:1.65;font-size:.97rem}
.testimonial .who{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:8px;border-top:1px solid var(--c-line-2)}
.testimonial .avatar{width:42px;height:42px;border-radius:50%;background:var(--g-brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.92rem;flex-shrink:0}
.testimonial .who strong{display:block;color:var(--c-ink);font-size:.92rem}
.testimonial .who span{color:var(--c-mute);font-size:.8rem}
.testimonial .verified{margin-left:auto;color:var(--c-success);font-size:.72rem;font-weight:700;display:inline-flex;align-items:center;gap:4px}

/* Video testimonials */
.video-testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px}
@media (max-width:880px){.video-testimonials{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.video-testimonials{grid-template-columns:1fr}}
.vt{position:relative;border-radius:var(--r-lg);overflow:hidden;background:linear-gradient(135deg,#161616,#0A0A0A);aspect-ratio:9/13;display:flex;align-items:flex-end;padding:18px;color:#fff;cursor:pointer;border:1px solid rgba(255,255,255,.06)}
.vt::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.7) 100%)}
.vt .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--c-brand);font-size:1.4rem;transition:.2s}
.vt:hover .play{transform:translate(-50%,-50%) scale(1.1)}
.vt .meta{position:relative;z-index:1}
.vt .meta strong{display:block;font-weight:700}
.vt .meta span{font-size:.8rem;color:#cdd3ee}

/* ── Live order ticker ──────────────────────────────────────────────── */
.live-ticker{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);
  padding:18px 22px;display:flex;align-items:center;gap:14px;
  box-shadow:var(--sh-2);max-width:560px;margin:0 auto;
}
.live-ticker .pulse{width:10px;height:10px;border-radius:50%;background:var(--c-success);box-shadow:0 0 0 5px rgba(16,185,129,.18);animation:pulseDot 2s infinite;flex-shrink:0}
.live-ticker .text{font-size:.92rem;color:var(--c-text);line-height:1.4}
.live-ticker .text b{color:var(--c-ink)}
.live-ticker .text small{display:block;color:var(--c-mute);font-size:.78rem;margin-top:2px}

/* ── Compare / Why-Different table ──────────────────────────────────── */
.compare-wrap{overflow-x:auto;border:1px solid var(--c-line);border-radius:var(--r-lg);background:#fff}
.compare{width:100%;border-collapse:collapse;font-size:.95rem;min-width:600px}
.compare th,.compare td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--c-line-2)}
.compare thead th{background:var(--c-bg-soft);font-weight:700;color:var(--c-ink);font-size:.86rem;text-transform:uppercase;letter-spacing:.08em}
.compare th.us{color:var(--c-brand);background:rgba(14,165,233,.06)}
.compare td.us{background:rgba(14,165,233,.04);font-weight:600;color:var(--c-ink)}
.compare .yes{color:var(--c-success);font-weight:700}
.compare .no{color:var(--c-rose);font-weight:600}
.compare tr:last-child td{border-bottom:none}

/* ── FAQ ─────────────────────────────────────────────────────────────── */
.faq-list{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);overflow:hidden;transition:.2s}
.faq-item.open{border-color:var(--c-brand);box-shadow:var(--sh-2)}
.faq-q{width:100%;text-align:left;padding:20px 24px;font-weight:700;color:var(--c-ink);font-size:1rem;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-q::after{content:"+";font-size:1.6rem;color:var(--c-brand);transition:transform .2s;flex-shrink:0;line-height:1}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s,padding .3s;color:var(--c-mute);padding:0 24px}
.faq-item.open .faq-a{max-height:600px;padding:0 24px 22px}
.faq-a p{margin:0}

/* ── Final CTA (mono dark slab — single dark accent in an otherwise light layout) */
.final-cta{background:#0A0A0A;color:#fff;padding:96px 0;text-align:center;position:relative;overflow:hidden}
.final-cta::before{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 60% at 50% 0%,rgba(14,165,233,.28),transparent 70%),
  radial-gradient(40% 40% at 50% 100%,rgba(125,211,252,.10),transparent 70%);
  pointer-events:none}
.final-cta .container{position:relative;z-index:1}
.final-cta h2{color:#fff;margin-bottom:16px}
.final-cta h2 .accent{background:var(--g-accent);-webkit-background-clip:text;background-clip:text;color:transparent}
.final-cta p{color:#d4d4d8;font-size:1.1rem;max-width:600px;margin:0 auto 34px}
.final-cta .btn-primary{background:#fff;color:#0A0A0A!important;box-shadow:0 16px 40px -10px rgba(0,0,0,.5)}
.final-cta .btn-primary:hover{background:var(--c-brand-soft);color:#0A0A0A!important}

/* ── Footer ──────────────────────────────────────────────────────────── */
.site-footer{background:var(--c-ink);color:#a3a9c5;padding-top:72px;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:44px;padding-bottom:52px}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer-col h4{color:#fff;font-size:.86rem;margin-bottom:18px;letter-spacing:.14em;text-transform:uppercase;font-weight:700}
.footer-col ul li{margin-bottom:10px}
.footer-col a{color:#a3a9c5;font-size:.92rem}
.footer-col a:hover{color:#fff}
.footer-about p{color:#a3a9c5;font-size:.92rem;margin-bottom:16px;max-width:320px;line-height:1.65}
.footer-about .site-logo{color:#fff;margin-bottom:14px}
.footer-about .site-logo .logo-text small{color:#8893b3}
.social-links{display:flex;gap:8px}
.social-links a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;color:#fff;transition:.2s;border:1px solid rgba(255,255,255,.06)}
.social-links a:hover{background:var(--g-brand);border-color:transparent;transform:translateY(-2px)}
.social-links svg{width:16px;height:16px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:24px 0;background:#000000}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;color:#7a83a3;font-size:.85rem}
.payment-badges{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.payment-badges .pb{padding:5px 12px;border:1px solid rgba(255,255,255,.08);border-radius:6px;font-size:.7rem;color:#cdd3ee;font-weight:700;letter-spacing:.06em;background:rgba(255,255,255,.02)}

/* ── Sticky mobile CTA bar ──────────────────────────────────────────── */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:90;
  display:none;padding:12px 14px;
  background:rgba(255,255,255,.96);backdrop-filter:blur(12px);
  border-top:1px solid var(--c-line);box-shadow:0 -10px 30px -10px rgba(15,18,40,.18);
}
.sticky-cta .btn-primary{flex:1}
.sticky-cta .btn-outline{flex:1}
@media (max-width:720px){.sticky-cta{display:flex;gap:8px}body{padding-bottom:74px}}

/* ── Generic page elements ──────────────────────────────────────────── */
.breadcrumb{padding:18px 0;color:var(--c-mute);font-size:.9rem}
.breadcrumb a{color:var(--c-mute)}
.breadcrumb a:hover{color:var(--c-brand)}
.seo-content{max-width:860px;margin:0 auto;font-size:1.02rem;color:var(--c-text);line-height:1.8}
.seo-content h2,.seo-content h3{margin-top:1.6em}
.seo-content p{margin-bottom:1.2em}
.seo-content ul,.seo-content ol{padding-left:1.4em;margin-bottom:1.2em}
.seo-content ul li{list-style:disc;margin-bottom:.5em}
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.related-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);padding:24px;transition:.2s;color:var(--c-ink)!important;display:block}
.related-card:hover{border-color:var(--c-brand);transform:translateY(-3px);box-shadow:var(--sh-2)}
.related-card h4{margin-bottom:6px}
.related-card p{color:var(--c-mute);font-size:.88rem;margin:0}

/* Forms */
.ssf-form{display:grid;gap:14px}
.ssf-form label{font-weight:600;font-size:.9rem;color:var(--c-text);display:block;margin-bottom:4px}
.ssf-form input,.ssf-form select,.ssf-form textarea{width:100%;padding:13px 16px;border:1.5px solid var(--c-line);border-radius:10px;font-family:inherit;font-size:1rem;background:#fff;transition:.2s}
.ssf-form input:focus,.ssf-form select:focus,.ssf-form textarea:focus{outline:none;border-color:var(--c-brand);box-shadow:0 0 0 4px rgba(14,165,233,.12)}
.ssf-form textarea{min-height:130px;resize:vertical}
.form-success{padding:16px;background:#d1fae5;color:#065f46;border-radius:10px;margin-bottom:16px}
.form-error{padding:16px;background:#fee2e2;color:#991b1b;border-radius:10px;margin-bottom:16px}

/* Team / About */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin-top:40px}
.team-card{text-align:center;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:28px 20px}
.team-avatar{width:90px;height:90px;border-radius:50%;background:var(--g-brand);color:#fff;font-size:2rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.team-card h4{margin-bottom:4px}
.team-card span{color:var(--c-mute);font-size:.88rem}

.two-col{display:grid;grid-template-columns:1fr 1.4fr;gap:50px;align-items:start}
@media (max-width:880px){.two-col{grid-template-columns:1fr;gap:30px}}

/* Blog */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.blog-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);overflow:hidden;transition:.2s}
.blog-card:hover{transform:translateY(-3px);box-shadow:var(--sh-2)}

/* Fade up */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.fade-up.in-view{opacity:1;transform:none}

/* ─── INNER PAGE HERO (service / page templates) ─────────────────────── */
.page-hero{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg,#F0F9FF 0%,#FFFFFF 100%);
  border-bottom:1px solid var(--c-line-2);
  padding:40px 0 80px;
}
.page-hero::before{
  content:"";position:absolute;inset:auto -10% -50% -10%;height:520px;
  background:radial-gradient(60% 60% at 50% 0%,rgba(56,189,248,.18),transparent 70%);
  pointer-events:none;
}
.page-breadcrumb{position:relative;z-index:1;display:flex;flex-wrap:wrap;align-items:center;gap:8px;color:var(--c-mute);font-size:.86rem;padding:18px 0 26px}
.page-breadcrumb a{color:var(--c-mute);font-weight:500}
.page-breadcrumb a:hover{color:var(--c-brand)}
.page-breadcrumb .sep{color:var(--c-mute-2);opacity:.6}
.page-breadcrumb .current{color:var(--c-ink);font-weight:600}

.page-hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.2fr .9fr;gap:50px;align-items:center}
@media (max-width:880px){.page-hero-grid{grid-template-columns:1fr;gap:36px}}
.page-hero h1{font-size:clamp(2rem,4.4vw,3.1rem);margin-bottom:18px;color:var(--c-ink)}
.page-hero-lead{font-size:1.12rem;color:var(--c-text);max-width:560px;line-height:1.65;margin-bottom:22px}
.page-hero-bullets{display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;margin:0 0 26px;max-width:520px}
.page-hero-bullets li{display:flex;align-items:center;gap:8px;font-size:.95rem;color:var(--c-text);font-weight:500}
.page-hero-bullets .check{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:rgba(16,185,129,.12);color:var(--c-success);font-weight:800;font-size:.78rem;flex-shrink:0}
.page-hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}
.page-hero-rating{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-pill);box-shadow:var(--sh-1)}
.page-hero-rating .stars{color:#F5B544;letter-spacing:1px}
.page-hero-rating strong{color:var(--c-ink);font-weight:800}
.page-hero-rating small{color:var(--c-mute);font-size:.82rem}

/* Decorative card next to hero */
.page-hero-card{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-xl);
  padding:28px;box-shadow:var(--sh-3);position:relative;overflow:hidden;
}
.page-hero-card::before{content:"";position:absolute;inset:auto -30% -50% auto;width:240px;height:240px;background:var(--g-brand);filter:blur(60px);opacity:.18;pointer-events:none}
.phc-head{display:flex;align-items:center;gap:14px;margin-bottom:22px;position:relative;z-index:1}
.phc-icon{width:54px;height:54px;border-radius:14px;background:var(--g-brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.6rem;box-shadow:var(--sh-brand)}
.phc-head strong{display:block;color:var(--c-ink);font-size:1.05rem;font-weight:800}
.phc-head small{color:var(--c-mute);font-size:.82rem}
.phc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px;position:relative;z-index:1}
.phc-stats div{background:var(--c-bg-soft);border:1px solid var(--c-line-2);border-radius:12px;padding:14px 8px;text-align:center}
.phc-stats b{display:block;color:var(--c-ink);font-size:1.15rem;font-weight:800;line-height:1}
.phc-stats span{color:var(--c-mute);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;display:block;margin-top:4px}
.phc-trust{display:flex;flex-wrap:wrap;gap:8px;position:relative;z-index:1}
.phc-trust span{font-size:.78rem;color:var(--c-text);background:var(--c-bg-soft);border:1px solid var(--c-line-2);padding:6px 10px;border-radius:var(--r-pill);font-weight:600}

/* ─── PAGE INTRO ─────────────────────────────────────────────────────── */
.page-intro{padding:60px 0 30px}
.page-intro .intro-text{
  font-size:1.18rem;color:var(--c-text);text-align:center;
  max-width:820px;margin:0 auto;line-height:1.7;font-weight:500;
}

/* ─── PACKAGE CARDS (service pages) ──────────────────────────────────── */
.package-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:880px){.package-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.package-grid{grid-template-columns:1fr}}
.package-card{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-xl);
  padding:30px 26px;display:flex;flex-direction:column;gap:6px;
  transition:.25s;position:relative;text-align:center;
}
.package-card:hover{transform:translateY(-4px);box-shadow:var(--sh-3);border-color:var(--c-brand-3)}
.package-card.featured{border:2px solid var(--c-brand);box-shadow:var(--sh-brand);transform:translateY(-4px);background:linear-gradient(180deg,#fff,#F0F9FF)}
.package-card .best-tag{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--g-brand);color:#fff;font-size:.7rem;font-weight:800;
  letter-spacing:.12em;text-transform:uppercase;padding:6px 14px;border-radius:var(--r-pill);
  box-shadow:var(--sh-brand);white-space:nowrap;
}
.pkg-qty{font-size:2.2rem;font-weight:800;color:var(--c-ink);line-height:1;letter-spacing:-.02em;margin-top:6px}
.pkg-unit{color:var(--c-mute);font-size:.92rem;text-transform:capitalize;margin-bottom:10px}
.pkg-price{margin:8px 0 4px}
.pkg-price .amt{font-size:2rem;font-weight:800;color:var(--c-brand);letter-spacing:-.02em}
.pkg-deliv{color:var(--c-success);font-size:.85rem;font-weight:700;margin-bottom:14px}
.pkg-feats{list-style:none;padding:0;margin:6px 0 22px;text-align:left;display:flex;flex-direction:column;gap:8px}
.pkg-feats li{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;color:var(--c-text)}
.pkg-feats li::before{
  content:"";flex-shrink:0;width:18px;height:18px;border-radius:50%;
  background:rgba(16,185,129,.12);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%2310B981'><path fill-rule='evenodd' d='M16.7 5.3a1 1 0 010 1.4l-7.5 7.5a1 1 0 01-1.4 0l-3.5-3.5a1 1 0 011.4-1.4L8.5 12 15.3 5.3a1 1 0 011.4 0z' clip-rule='evenodd'/></svg>");
  background-position:center;background-repeat:no-repeat;margin-top:2px;
}
.package-card .btn-block{margin-top:auto}

.package-trust{
  display:flex;flex-wrap:wrap;justify-content:center;gap:14px 28px;
  margin-top:36px;padding:20px;background:#fff;border:1px solid var(--c-line);
  border-radius:var(--r-lg);
}
.package-trust span{font-size:.88rem;color:var(--c-text);font-weight:600}

/* ─── LEGACY .hero-dark SHIM (for contact/about/faq/policy pages) ───── */
.hero-dark{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg,#F0F9FF 0%,#FFFFFF 100%);
  border-bottom:1px solid var(--c-line-2);
  padding:64px 0 56px;color:var(--c-ink);
}
.hero-dark::before{
  content:"";position:absolute;inset:auto -10% -50% -10%;height:480px;
  background:radial-gradient(60% 60% at 50% 0%,rgba(56,189,248,.18),transparent 70%);
  pointer-events:none;
}
.hero-dark .hero-content{position:relative;z-index:1;max-width:var(--container);margin:0 auto;padding:0 24px;text-align:left}
.hero-dark h1{font-size:clamp(2rem,4.4vw,3rem);color:var(--c-ink);margin-bottom:14px}
.hero-dark .subline,
.subline{color:var(--c-mute);font-size:1.1rem;max-width:680px;margin:0 0 0;line-height:1.65}
.hero-dark .trust-badges{display:flex;flex-wrap:wrap;gap:14px;margin:22px 0 8px;color:var(--c-text);font-size:.92rem;font-weight:600}
.hero-dark .trust-badges span{background:#fff;border:1px solid var(--c-line);padding:7px 14px;border-radius:var(--r-pill);box-shadow:var(--sh-1)}
.hero-dark .btn-primary{margin-top:18px}

/* ─── Generic page main container (used by contact/about/etc) ──────── */
main.container{padding:60px 24px}
main.container h2{margin-top:0}
main.container h2:first-child{margin-top:0}

/* Two-col contact polish */
.two-col h2{font-size:1.6rem;margin-bottom:14px}
.two-col p{color:var(--c-mute);font-size:1rem}
.two-col .contact-info{display:flex;flex-direction:column;gap:18px;margin-top:24px}
.two-col .contact-info-item{display:flex;gap:14px;align-items:flex-start;padding:18px;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);transition:.2s}
.two-col .contact-info-item:hover{border-color:var(--c-brand-3);box-shadow:var(--sh-1)}
.two-col .contact-info-item .ic{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,rgba(14,165,233,.12),rgba(2,132,199,.12));color:var(--c-brand);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;border:1px solid rgba(14,165,233,.12)}
.two-col .contact-info-item strong{display:block;color:var(--c-ink);font-size:1rem;margin-bottom:4px}
.two-col .contact-info-item a,.two-col .contact-info-item span{color:var(--c-mute);font-size:.93rem;line-height:1.5}
.two-col .contact-info-item a:hover{color:var(--c-brand)}

/* Form polish in two-col */
.two-col .ssf-form{margin-top:8px;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--sh-1)}
.two-col .ssf-form button.btn-primary{margin-top:8px}

/* ───────────────────────────────────────────────────────────────────
   WOOCOMMERCE — Cart, Checkout, My Account, Notices
   ─────────────────────────────────────────────────────────────────── */

/* WooCommerce page hero — make plain WP pages render with breathing room */
body.woocommerce-page,
body.woocommerce-cart,
body.woocommerce-checkout,
body.woocommerce-account{background:var(--c-bg-soft)}
/* Scope the extra padding to MAIN/article wrappers only — NOT the header's .container */
body.woocommerce-page main.container,
body.woocommerce-cart main.container,
body.woocommerce-checkout main.container,
body.woocommerce-account main.container,
body.woocommerce-page .site-main > .container,
body.woocommerce-cart .site-main > .container,
body.woocommerce-checkout .site-main > .container,
body.woocommerce-account .site-main > .container,
body.woocommerce-page .entry-content > .container,
body.woocommerce-cart .woocommerce,
body.woocommerce-checkout .woocommerce,
body.woocommerce-account .woocommerce{padding-top:48px;padding-bottom:80px}

/* Page title that WooCommerce outputs as h1 */
.woocommerce h1.entry-title,
.woocommerce-cart h1,
.woocommerce-checkout h1,
.woocommerce-account h1{
  font-size:clamp(2rem,4vw,2.6rem);margin:0 0 28px;color:var(--c-ink);
  letter-spacing:-.02em;
}

/* Cart layout: 2-column grid (items + totals) */
.woocommerce-cart .woocommerce{display:grid;grid-template-columns:1.6fr 1fr;gap:32px;align-items:start}
@media (max-width:880px){.woocommerce-cart .woocommerce{grid-template-columns:1fr}}
.woocommerce-cart form.woocommerce-cart-form{margin:0}
.woocommerce-cart .cart-collaterals{margin:0;width:100%;float:none}
.woocommerce-cart .cart-collaterals .cart_totals{width:100%;float:none}

/* Cart items table → card */
.woocommerce table.shop_table{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);
  border-collapse:separate;border-spacing:0;overflow:hidden;width:100%;
  box-shadow:var(--sh-1);
}
.woocommerce table.shop_table thead{background:var(--c-bg-soft)}
.woocommerce table.shop_table thead th{
  font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--c-mute);font-weight:700;padding:16px 18px;border-bottom:1px solid var(--c-line-2);
  text-align:left;
}
.woocommerce table.shop_table tbody td{
  padding:18px;border-bottom:1px solid var(--c-line-2);vertical-align:middle;
  color:var(--c-text);font-size:.95rem;background:#fff;
}
.woocommerce table.shop_table tbody tr:last-child td{border-bottom:none}

/* Product thumbnail in cart */
.woocommerce table.shop_table td.product-thumbnail img{
  width:60px;height:60px;border-radius:10px;border:1px solid var(--c-line);
  object-fit:cover;background:var(--c-bg-soft);
}
.woocommerce table.shop_table td.product-thumbnail a{display:inline-block}

/* Product name + meta */
.woocommerce table.shop_table td.product-name a{
  color:var(--c-ink);font-weight:700;font-size:1rem;text-decoration:none;
}
.woocommerce table.shop_table td.product-name a:hover{color:var(--c-brand)}
.woocommerce table.shop_table td.product-name .product-price-line,
.woocommerce table.shop_table td.product-name .product-meta,
.woocommerce table.shop_table td.product-name dl.variation,
.woocommerce table.shop_table td.product-name p.product-short{
  font-size:.85rem;color:var(--c-mute);margin:4px 0 0;line-height:1.5;
}

/* Subtotal column */
.woocommerce table.shop_table td.product-subtotal,
.woocommerce table.shop_table td.product-total{
  font-weight:700;color:var(--c-ink);font-size:1rem;text-align:right;
}

/* Quantity input */
.woocommerce .quantity{display:inline-flex;align-items:center;gap:0;background:var(--c-bg-soft);border:1px solid var(--c-line);border-radius:var(--r-pill);overflow:hidden;height:36px}
.woocommerce .quantity input.qty{
  width:48px;height:36px;border:none;background:transparent;text-align:center;
  font-weight:700;color:var(--c-ink);font-size:.95rem;-moz-appearance:textfield;
}
.woocommerce .quantity input.qty::-webkit-outer-spin-button,
.woocommerce .quantity input.qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.woocommerce .quantity .plus,
.woocommerce .quantity .minus,
.woocommerce .quantity button{
  width:34px;height:36px;background:transparent;border:none;cursor:pointer;
  color:var(--c-mute);font-size:1.1rem;font-weight:700;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
}
.woocommerce .quantity .plus:hover,
.woocommerce .quantity .minus:hover{color:var(--c-brand)}

/* Remove link (the × / trash icon) */
.woocommerce table.shop_table td.product-remove{width:1%;padding-right:8px}
.woocommerce a.remove,
.woocommerce table.shop_table .remove{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  color:var(--c-rose)!important;background:transparent!important;
  font-size:1.4rem;font-weight:400;line-height:1;transition:.2s;text-decoration:none;
}
.woocommerce a.remove:hover,
.woocommerce table.shop_table .remove:hover{background:rgba(244,63,94,.1)!important;color:#dc2626!important}

/* Coupon + Update cart row */
.woocommerce table.shop_table td.actions{
  padding:16px 18px;background:var(--c-bg-soft);border-top:1px solid var(--c-line-2);
}
.woocommerce .coupon{display:inline-flex;gap:8px;align-items:center}
.woocommerce .coupon label{display:none}
.woocommerce input#coupon_code,
.woocommerce input.input-text{
  height:42px;padding:0 14px;border:1px solid var(--c-line);border-radius:10px;
  background:#fff;font-family:inherit;font-size:.95rem;color:var(--c-ink);
  transition:.2s;
}
.woocommerce input.input-text:focus,
.woocommerce input#coupon_code:focus,
.woocommerce textarea:focus,
.woocommerce select:focus{outline:none;border-color:var(--c-brand);box-shadow:0 0 0 4px rgba(14,165,233,.12)}

/* Generic WooCommerce buttons → use brand */
.woocommerce button.button,
.woocommerce input.button,
.woocommerce a.button,
.woocommerce #respond input#submit,
.woocommerce-page button.button,
.woocommerce-page a.button{
  background:var(--g-brand)!important;color:#fff!important;
  padding:12px 22px;border-radius:var(--r-pill);border:none;
  font-family:inherit;font-weight:700;font-size:.92rem;letter-spacing:-.01em;
  cursor:pointer;transition:.2s;text-decoration:none;line-height:1;
  box-shadow:var(--sh-brand);
}
.woocommerce button.button:hover,
.woocommerce a.button:hover,
.woocommerce input.button:hover{
  transform:translateY(-2px);box-shadow:0 22px 50px -12px rgba(14,165,233,.5);color:#fff!important;
}
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce a.button.alt,
.woocommerce #respond input#submit.alt{background:var(--g-brand)!important;color:#fff!important}
.woocommerce button.button[name="update_cart"],
.woocommerce button.button[name="apply_coupon"]{
  background:transparent!important;color:var(--c-ink)!important;
  border:1.5px solid var(--c-line)!important;box-shadow:none!important;
}
.woocommerce button.button[name="update_cart"]:hover,
.woocommerce button.button[name="apply_coupon"]:hover{
  border-color:var(--c-brand)!important;color:var(--c-brand)!important;transform:none;
}

/* Cart totals sidebar card */
.woocommerce-cart .cart_totals{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);
  padding:28px;box-shadow:var(--sh-2);position:sticky;top:90px;
}
.woocommerce-cart .cart_totals h2{
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--c-mute);font-weight:700;margin:0 0 18px;
}
.woocommerce-cart .cart_totals table{width:100%;border-collapse:collapse;margin-bottom:16px;background:transparent;border:none;box-shadow:none}
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td{
  padding:14px 0;border-bottom:1px solid var(--c-line-2);font-size:.95rem;
  background:transparent;
}
.woocommerce-cart .cart_totals table th{color:var(--c-mute);font-weight:600;text-align:left}
.woocommerce-cart .cart_totals table td{color:var(--c-ink);text-align:right;font-weight:700}
.woocommerce-cart .cart_totals table tr.order-total th,
.woocommerce-cart .cart_totals table tr.order-total td{
  font-size:1.1rem;color:var(--c-ink);padding-top:18px;border-top:2px solid var(--c-ink);border-bottom:none;
}
.woocommerce-cart .cart_totals table tr.order-total td .amount,
.woocommerce-cart .cart_totals table tr.order-total td{color:var(--c-brand);font-weight:800}

.woocommerce-cart .wc-proceed-to-checkout{padding:0;margin-top:18px}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button{
  display:block;width:100%;text-align:center;
  background:var(--g-brand)!important;color:#fff!important;
  padding:16px 24px;border-radius:var(--r-pill);font-weight:800;font-size:1rem;
  box-shadow:var(--sh-brand);transition:.2s;
}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover{
  transform:translateY(-2px);box-shadow:0 22px 50px -12px rgba(14,165,233,.5);
}

/* ── BLOCK-BASED Cart & Checkout buttons ──────────────────────────
   WooCommerce now ships with block-powered Cart/Checkout. Their buttons
   use .wc-block-* selectors that don't inherit our brand styles. */

/* Generic block button → brand pill */
.wc-block-components-button:not(.is-link),
button.wc-block-components-button:not(.is-link),
a.wc-block-components-button:not(.is-link),
.wp-block-button__link.wc-block-cart__submit-button,
.wc-block-cart__submit-button,
.wc-block-checkout__actions_row .wc-block-components-button,
.wc-block-components-checkout-place-order-button{
  background:var(--g-brand)!important;
  background-image:var(--g-brand)!important;
  color:#fff!important;
  padding:16px 28px!important;
  border-radius:var(--r-pill)!important;
  border:none!important;
  font-family:var(--f-sans)!important;
  font-weight:800!important;
  font-size:1rem!important;
  letter-spacing:-.01em!important;
  box-shadow:var(--sh-brand)!important;
  cursor:pointer;
  transition:transform .2s,box-shadow .2s!important;
  text-decoration:none!important;
  display:inline-flex!important;
  align-items:center;justify-content:center;gap:8px;
  min-height:auto!important;line-height:1.2!important;
  width:100%;
}
.wc-block-components-button:not(.is-link):hover,
button.wc-block-components-button:not(.is-link):hover,
a.wc-block-components-button:not(.is-link):hover,
.wp-block-button__link.wc-block-cart__submit-button:hover,
.wc-block-cart__submit-button:hover,
.wc-block-checkout__actions_row .wc-block-components-button:hover,
.wc-block-components-checkout-place-order-button:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 50px -12px rgba(14,165,233,.55)!important;
  color:#fff!important;
}

/* Block cart "Proceed to Checkout" container */
.wc-block-cart__submit,
.wp-block-woocommerce-proceed-to-checkout-block{
  margin-top:18px!important;width:100%;
}
.wc-block-cart__submit-container{width:100%}

/* Block button text */
.wc-block-components-button__text{font-weight:800!important;color:#fff!important;font-size:1rem!important}
.wc-block-cart__submit-button .wc-block-components-button__text,
.wc-block-components-checkout-place-order-button .wc-block-components-button__text{color:#fff!important}

/* The "Return to Cart" link on checkout — keep it subtle */
.wc-block-checkout__actions_row .wc-block-components-button.is-link,
a.wc-block-components-button.is-link{
  background:transparent!important;color:var(--c-mute)!important;
  font-weight:600!important;box-shadow:none!important;border:none!important;
  padding:8px 14px!important;text-decoration:none!important;
}
.wc-block-checkout__actions_row .wc-block-components-button.is-link:hover{
  color:var(--c-brand)!important;transform:none;
}

/* Checkout actions row — align Return to Cart left & Place Order right */
.wc-block-checkout__actions_row{
  display:flex!important;justify-content:space-between!important;align-items:center!important;
  gap:18px;flex-wrap:wrap;margin-top:18px;
}
.wc-block-checkout__actions_row .wc-block-components-checkout-place-order-button{
  width:auto!important;min-width:240px;flex:1;max-width:360px;
}

/* Block totals/summary card polish */
.wc-block-components-totals-wrapper,
.wp-block-woocommerce-cart-order-summary-block,
.wp-block-woocommerce-checkout-order-summary-block{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);
  padding:24px;box-shadow:var(--sh-2);
}
.wc-block-components-totals-item{
  display:flex!important;justify-content:space-between;align-items:center;
  padding:12px 0;border-bottom:1px solid var(--c-line-2);
  font-size:.95rem;color:var(--c-text);
}
.wc-block-components-totals-footer-item,
.wc-block-components-totals-item.wc-block-components-totals-footer-item{
  border-top:2px solid var(--c-ink);border-bottom:none;padding-top:16px;margin-top:6px;
  font-size:1.05rem;color:var(--c-ink);font-weight:800;
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value,
.wc-block-components-totals-footer-item .wc-block-formatted-money-amount{
  color:var(--c-brand)!important;font-weight:800;font-size:1.15rem;
}

/* Coupon collapsible */
.wc-block-components-totals-coupon button.wc-block-components-totals-coupon-link{
  color:var(--c-brand)!important;font-weight:600;text-decoration:none;
}
.wc-block-components-totals-coupon button.wc-block-components-totals-coupon-link:hover{color:var(--c-brand-2)!important}

/* Apply Coupon submit inside the panel */
.wc-block-components-totals-coupon__button{
  background:var(--c-ink)!important;color:#fff!important;border-radius:var(--r-pill)!important;
  padding:8px 16px!important;font-weight:700!important;min-height:auto!important;
}

/* "Add coupons" accordion */
.woocommerce-cart .coupons-toggle,
.woocommerce-cart .wc-block-components-totals-coupon{margin:0 0 18px}

/* Empty cart state */
.cart-empty,
.woocommerce-info,
.woocommerce-notice{
  background:#fff;border:1px solid var(--c-line);border-left:4px solid var(--c-brand);
  border-radius:var(--r-md);padding:18px 22px;color:var(--c-text);font-size:.95rem;
  margin-bottom:18px;
}
.return-to-shop{margin-top:18px}
.return-to-shop .button{display:inline-block}

/* WooCommerce notices */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info{
  list-style:none;border-radius:var(--r-md);padding:14px 18px;
  margin:0 0 18px;font-size:.95rem;
}
.woocommerce-message{background:#d1fae5;border-left:4px solid var(--c-success);color:#065f46}
.woocommerce-error{background:#fee2e2;border-left:4px solid var(--c-rose);color:#991b1b}
.woocommerce-info{background:#fff;border:1px solid var(--c-line);border-left:4px solid var(--c-brand)}

/* ── Checkout page ─────────────────────────────────────────────── */
.woocommerce-checkout #customer_details,
.woocommerce-checkout .col-1,
.woocommerce-checkout .col-2{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);
  padding:28px;box-shadow:var(--sh-1);margin-bottom:24px;
}
.woocommerce-checkout h3{font-size:1.2rem;margin:0 0 18px;color:var(--c-ink)}
.woocommerce form .form-row{margin:0 0 16px}
.woocommerce form .form-row label{
  display:block;font-weight:600;font-size:.88rem;color:var(--c-text);margin-bottom:6px;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.select2-container--default .select2-selection--single{
  width:100%;padding:12px 14px;border:1.5px solid var(--c-line);border-radius:10px;
  font-family:inherit;font-size:.95rem;background:#fff;color:var(--c-ink);
  transition:.2s;height:auto;
}
.select2-container--default .select2-selection--single{height:46px;display:flex;align-items:center;padding:0 14px}
.select2-container--default .select2-selection--single .select2-selection__rendered{padding:0;line-height:46px;color:var(--c-ink)}
.select2-container--default .select2-selection--single .select2-selection__arrow{height:46px;right:8px}

#order_review,
.woocommerce-checkout-review-order{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);
  padding:28px;box-shadow:var(--sh-2);
}
#order_review_heading,
h3#order_review_heading{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--c-mute);font-weight:700;margin:0 0 18px}
.woocommerce-checkout #payment{background:transparent;border-radius:0;margin-top:18px}
.woocommerce-checkout #payment ul.payment_methods{border:none;padding:0;background:transparent}
.woocommerce-checkout #payment ul.payment_methods li{
  background:var(--c-bg-soft);border:1px solid var(--c-line-2);border-radius:var(--r-md);
  padding:14px 16px;margin-bottom:8px;list-style:none;
}
.woocommerce-checkout #payment ul.payment_methods li label{font-weight:600;color:var(--c-ink)}
.woocommerce-checkout #payment div.payment_box{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);
  padding:14px;margin-top:10px;font-size:.9rem;color:var(--c-mute);
}
.woocommerce-checkout #payment div.payment_box::before{display:none}
.woocommerce-checkout #place_order{
  width:100%;padding:16px 24px;font-size:1rem;font-weight:800;margin-top:14px;
}

/* ── My Account ────────────────────────────────────────────────── */
.woocommerce-account .woocommerce-MyAccount-navigation ul{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);
  padding:8px;list-style:none;margin:0;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li{margin:0}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a{
  display:block;padding:12px 16px;border-radius:8px;
  color:var(--c-text);font-weight:600;font-size:.95rem;text-decoration:none;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover{background:var(--c-bg-soft);color:var(--c-brand)}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a{background:var(--g-brand);color:#fff}
.woocommerce-account .woocommerce-MyAccount-content{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);
  padding:28px;box-shadow:var(--sh-1);
}
.woocommerce-account .woocommerce{display:grid;grid-template-columns:240px 1fr;gap:24px;align-items:start}
@media (max-width:760px){.woocommerce-account .woocommerce{grid-template-columns:1fr}}

/* ── Checkout top banner ───────────────────────────────────────── */
.ssf-checkout-banner{
  background:var(--g-hero);color:#fff;border-radius:var(--r-xl);
  padding:30px 32px;margin:0 0 28px;position:relative;overflow:hidden;
  box-shadow:var(--sh-3);
}
.ssf-checkout-banner::before{content:"";position:absolute;inset:auto -10% -50% auto;width:300px;height:300px;background:radial-gradient(circle,rgba(56,189,248,.45),transparent 70%);pointer-events:none}
.ssf-checkout-banner-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:center}
@media (max-width:760px){.ssf-checkout-banner-inner{grid-template-columns:1fr;gap:18px}}
.ssf-checkout-banner-headline h2{color:#fff;font-size:1.5rem;margin:0 0 6px;letter-spacing:-.02em}
.ssf-checkout-banner-headline p{color:#cfd5ee;margin:0;font-size:.95rem}
.ssf-checkout-banner-trust{display:flex;flex-direction:column;gap:10px}
.ssf-checkout-banner-trust span{display:inline-flex;align-items:center;gap:10px;color:#e7ebff;font-size:.88rem;font-weight:500}
.ssf-checkout-banner-trust svg{width:18px;height:18px;color:var(--c-brand-3);flex-shrink:0}

/* ── Below "Place Order" reassurance grid ──────────────────────── */
.ssf-checkout-reassure{
  display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
  margin-top:20px;padding-top:20px;border-top:1px dashed var(--c-line);
}
.ssf-checkout-reassure div{display:flex;flex-direction:column;gap:2px;padding:10px;background:var(--c-bg-soft);border-radius:10px}
.ssf-checkout-reassure strong{color:var(--c-ink);font-size:.85rem;font-weight:700}
.ssf-checkout-reassure span{color:var(--c-mute);font-size:.78rem;line-height:1.4}

/* ── Empty cart ────────────────────────────────────────────────── */
.ssf-empty-cart{
  text-align:center;background:#fff;border:1px solid var(--c-line);
  border-radius:var(--r-xl);padding:60px 30px;box-shadow:var(--sh-1);
  max-width:520px;margin:20px auto;
}
.ssf-empty-cart .ec-icon{font-size:3rem;margin-bottom:14px}
.ssf-empty-cart h3{font-size:1.4rem;margin:0 0 10px;color:var(--c-ink)}
.ssf-empty-cart p{color:var(--c-mute);margin:0 0 22px}
.ssf-empty-cart .btn-primary{display:inline-flex}

/* ───────────────────────────────────────────────────────────────────
   WHATSAPP CHAT WIDGET
   ─────────────────────────────────────────────────────────────────── */
.wa-widget{position:fixed;bottom:24px;right:24px;z-index:9999;font-family:var(--f-sans)}

/* Launcher button */
.wa-launcher{
  position:relative;display:inline-flex;align-items:center;gap:8px;
  background:#25D366;color:#fff;border:none;cursor:pointer;
  padding:14px 20px 14px 18px;border-radius:var(--r-pill);
  font-family:inherit;font-weight:700;font-size:.95rem;
  box-shadow:0 10px 25px -5px rgba(37,211,102,.5),0 4px 12px rgba(0,0,0,.15);
  transition:transform .2s,box-shadow .2s;
}
.wa-launcher:hover{transform:translateY(-2px);box-shadow:0 14px 30px -6px rgba(37,211,102,.6),0 6px 18px rgba(0,0,0,.2)}
.wa-launcher svg{width:24px;height:24px;flex-shrink:0}
.wa-launcher-label{line-height:1}
.wa-launcher.is-icon-only{padding:0;width:60px;height:60px;justify-content:center}
.wa-launcher.is-icon-only .wa-launcher-label{display:none}
.wa-pulse{position:absolute;inset:-2px;border-radius:var(--r-pill);border:2px solid #25D366;animation:waPulse 2.2s ease-out infinite;pointer-events:none}
@keyframes waPulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.35);opacity:0}}

/* Popup */
.wa-popup{
  position:absolute;bottom:74px;right:0;width:340px;max-width:calc(100vw - 32px);
  background:#fff;border-radius:18px;overflow:hidden;
  box-shadow:0 24px 60px -16px rgba(15,18,40,.35),0 0 0 1px var(--c-line-2);
  opacity:0;visibility:hidden;transform:translateY(12px) scale(.96);
  transition:opacity .2s,transform .2s,visibility .2s;
  transform-origin:bottom right;
}
.wa-widget.open .wa-popup{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.wa-widget.open .wa-launcher .wa-pulse{display:none}

/* Header */
.wa-head{
  display:flex;align-items:center;gap:12px;padding:16px 18px;
  background:linear-gradient(135deg,#075E54 0%,#128C7E 100%);color:#fff;
}
.wa-avatar{
  width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;
  border:2px solid rgba(255,255,255,.18);
}
.wa-avatar svg{width:24px;height:24px}
.wa-head-text{flex:1;min-width:0;line-height:1.2}
.wa-head-text strong{display:block;font-size:.95rem;font-weight:700;color:#fff}
.wa-status{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;color:rgba(255,255,255,.85);margin-top:2px}
.wa-dot{width:8px;height:8px;border-radius:50%;background:#7BFFB1;box-shadow:0 0 0 3px rgba(123,255,177,.25);animation:pulseDot 2s infinite}
.wa-widget.is-offline .wa-dot{background:#FDBA74;box-shadow:0 0 0 3px rgba(253,186,116,.25);animation:none}
.wa-close{
  background:transparent;border:none;color:rgba(255,255,255,.7);
  font-size:1.6rem;line-height:1;cursor:pointer;width:28px;height:28px;
  display:inline-flex;align-items:center;justify-content:center;border-radius:50%;
  transition:.15s;
}
.wa-close:hover{background:rgba(255,255,255,.15);color:#fff}

/* Body */
.wa-body{
  padding:18px;background:
    linear-gradient(rgba(229,221,213,.55),rgba(229,221,213,.55)),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'><circle cx='20' cy='20' r='1' fill='%23000' opacity='.06'/></svg>");
  background-color:#E5DDD5;
  max-height:340px;overflow-y:auto;
}

/* Bubble */
.wa-bubble{
  background:#fff;border-radius:10px 10px 10px 2px;
  padding:12px 14px;font-size:.92rem;color:var(--c-text);line-height:1.5;
  box-shadow:0 1px 1px rgba(0,0,0,.08);max-width:88%;margin-bottom:14px;
  position:relative;
}
.wa-bubble p{margin:0}
.wa-bubble small{color:var(--c-mute);font-size:.78rem;display:block;margin-top:4px}
.wa-bubble-in{align-self:flex-start}

/* Quick replies */
.wa-quick-replies{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.wa-quick-replies button{
  background:#fff;border:1px solid var(--c-line);
  padding:10px 14px;border-radius:var(--r-pill);
  font-family:inherit;font-size:.85rem;font-weight:600;color:var(--c-text);
  cursor:pointer;text-align:left;transition:.15s;
  box-shadow:0 1px 2px rgba(0,0,0,.04);
}
.wa-quick-replies button:hover{
  background:#DCF8C6;border-color:#25D366;color:#075E54;
  transform:translateX(2px);
}

/* Offline banner */
.wa-offline{
  margin-top:14px;padding:12px 14px;border-radius:10px;
  background:#FEF3C7;border:1px solid #FCD34D;color:#78350F;
}
.wa-offline strong{display:block;font-size:.88rem;margin-bottom:4px;color:#78350F}
.wa-offline p{margin:0;font-size:.8rem;line-height:1.5;color:#78350F}

/* CTA Button */
.wa-cta-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:#25D366;color:#fff!important;text-decoration:none;
  padding:14px 18px;font-weight:700;font-size:.92rem;
  transition:.15s;
}
.wa-cta-btn:hover{background:#1DA851;color:#fff!important}
.wa-cta-btn svg{width:18px;height:18px}
.wa-num{
  display:block;text-align:center;padding:10px;font-size:.78rem;
  color:var(--c-mute);background:#fafafa;border-top:1px solid var(--c-line-2);
}

/* Mobile tweaks */
@media (max-width:520px){
  .wa-widget{bottom:16px;right:16px}
  .wa-launcher{padding:12px 16px 12px 14px;font-size:.88rem}
  .wa-launcher svg{width:22px;height:22px}
  .wa-popup{bottom:68px;right:0;width:calc(100vw - 32px)}
}

/* Don't overlap the sticky mobile CTA — lift the widget above it on small screens */
@media (max-width:720px){
  .wa-widget{bottom:84px}
}
/* ─── SHOP SOCIAL FANS — LAYOUT DIFFERENTIATION OVERRIDES ─────────────
   These ride at the end of the file so they win specificity ties.
   Goal: lighter, airier than the original violet theme + distinct identity.
   ──────────────────────────────────────────────────────────────────── */

/* Top bar — slim sky-blue accent strip instead of dark slab */
.top-bar{
  background:linear-gradient(90deg,#0EA5E9 0%,#38BDF8 100%);
  color:#ffffff;border-bottom:none;
}
.top-bar .dot{background:#ffffff;box-shadow:0 0 0 4px rgba(255,255,255,.25)}

/* Header — sticky white with thin blue underline accent */
.site-header{
  background:rgba(255,255,255,.92);
  border-bottom:1px solid var(--c-line-2);
  box-shadow:none;
}
.site-header.scrolled{
  box-shadow:0 1px 0 var(--c-brand-3),0 8px 24px -16px rgba(10,10,10,.10);
  background:rgba(255,255,255,.98);
}

/* Logo wordmark — Shop Social Fans (mono with blue accent on middle word) */
.site-logo .logo-text{line-height:1.1}
.site-logo .logo-text > span{color:var(--c-ink);font-weight:700;letter-spacing:-.01em}
.site-logo .logo-text strong{
  font-weight:800;
  background:none;-webkit-background-clip:initial;background-clip:initial;
  color:var(--c-brand);
  padding:0 2px;
}
.site-logo .logo-mark{
  width:38px;height:38px;border-radius:10px;
  background:transparent;box-shadow:none;
  border:1px solid var(--c-line);overflow:hidden;
}
.site-logo .logo-mark svg{width:38px;height:38px}

/* Nav — slightly different active/hover feel: underline accent, not chip fill */
.main-nav .nav-list>li>a{
  border-radius:0;position:relative;padding:14px 12px;
}
.main-nav .nav-list>li>a:hover{background:transparent;color:var(--c-brand)}
.main-nav .nav-list>li>a::after{
  content:"";position:absolute;left:12px;right:12px;bottom:6px;height:2px;
  background:var(--c-brand);transform:scaleX(0);transform-origin:left;
  transition:transform .2s ease;border-radius:2px;
}
.main-nav .nav-list>li>a:hover::after,
.has-dropdown:hover>a::after{transform:scaleX(1)}
@media (max-width:991px){
  .main-nav .nav-list>li>a{border-radius:8px;padding:14px 4px}
  .main-nav .nav-list>li>a::after{display:none}
}

/* Cart link — clean outlined */
.cart-link{background:#fff;border:1px solid var(--c-line);color:var(--c-ink)}
.cart-link:hover{background:var(--c-brand-soft);border-color:var(--c-brand-3);color:var(--c-brand)}
.cart-count{background:var(--c-ink);box-shadow:0 4px 10px rgba(10,10,10,.20)}

/* Eyebrow chips — soft sky tint on white */
.eyebrow{
  color:var(--c-brand);background:var(--c-brand-soft);
  border:1px solid #BAE6FD;
}

/* Buttons — mono primary, accent uses blue */
.btn-primary{background:var(--c-ink);color:#fff!important;box-shadow:0 8px 20px -10px rgba(10,10,10,.4)}
.btn-primary:hover{background:#000;box-shadow:0 14px 28px -12px rgba(10,10,10,.5);transform:translateY(-2px)}
.btn-accent{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 26px;border-radius:var(--r-pill);font-weight:700;font-size:.95rem;
  background:var(--g-accent);color:#fff!important;box-shadow:var(--sh-brand);
  border:1.5px solid transparent;transition:transform .2s ease,box-shadow .2s ease;white-space:nowrap;
}
.btn-accent:hover{transform:translateY(-2px);box-shadow:0 18px 38px -12px rgba(14,165,233,.55);color:#fff!important}
.btn-outline{border-color:var(--c-line);color:var(--c-ink)!important}
.btn-outline:hover{border-color:var(--c-ink);background:var(--c-bg-soft);color:var(--c-ink)!important}

/* Section rhythm — tighter, more breathing room between blocks */
section{padding:84px 0}
@media (max-width:720px){section{padding:56px 0}}

/* Cards — softer 1px borders, lighter hover lift */
.platform-card,.feature-card,.testimonial,.pricing-card,.package-card,.sub-card{
  box-shadow:none;
}
.platform-card:hover,.feature-card:hover,.testimonial:hover,
.pricing-card:hover,.package-card:hover,.sub-card:hover{
  box-shadow:var(--sh-2);
}

/* Feature card icon — sky tint on white instead of violet */
.feature-card .icon{
  background:var(--c-brand-soft);
  color:var(--c-brand);
  border:1px solid #BAE6FD;
}

/* Pricing featured card — black border instead of violet */
.pricing-card.featured{
  border:2px solid var(--c-ink);
  box-shadow:0 12px 32px -16px rgba(10,10,10,.25);
  background:#fff;
}
.pricing-card.featured::before{background:var(--c-ink);box-shadow:0 6px 16px -6px rgba(10,10,10,.4)}
.package-card.featured{border:2px solid var(--c-ink);background:#fff;box-shadow:0 12px 32px -16px rgba(10,10,10,.25)}
.package-card .best-tag{background:var(--c-ink);box-shadow:0 6px 16px -6px rgba(10,10,10,.4)}

/* Step circles — black ring, blue fill on hover */
.step .num{
  border-color:var(--c-ink);color:var(--c-ink);
  box-shadow:0 6px 18px -10px rgba(10,10,10,.25);
}
.steps::before{background:repeating-linear-gradient(90deg,var(--c-brand-3) 0 8px,transparent 8px 16px)}

/* Live ticker — soft sky tint background */
.live-ticker{background:linear-gradient(180deg,#fff 0%,var(--c-brand-soft) 100%)}

/* Compare table — accent column uses blue */
.compare th.us{color:var(--c-brand);background:var(--c-brand-soft)}
.compare td.us{background:#F0F9FF}

/* FAQ — open border in accent blue */
.faq-item.open{border-color:var(--c-brand)}
.faq-q::after{color:var(--c-brand)}

/* Forms — focus rings in sky blue */
.ssf-form input:focus,.ssf-form select:focus,.ssf-form textarea:focus{
  border-color:var(--c-brand);box-shadow:0 0 0 4px rgba(14,165,233,.15);
}

/* Inner page hero (.page-hero / .hero-dark) — sky-tinted soft gradient */
.page-hero,.hero-dark{
  background:linear-gradient(180deg,#F0F9FF 0%,#FFFFFF 100%);
  border-bottom:1px solid var(--c-line-2);
}
.page-hero::before,.hero-dark::before{
  background:radial-gradient(60% 60% at 50% 0%,rgba(14,165,233,.16),transparent 70%);
}

/* Footer — keep dark slab but neutralise the leftover violet-tinted greys */
.site-footer{background:#0A0A0A;color:#a1a1aa}
.footer-col a{color:#a1a1aa}
.footer-col a:hover{color:var(--c-brand-2)}
.footer-about p{color:#a1a1aa}
.footer-about .site-logo .logo-text > span{color:#fff}
.footer-about .site-logo .logo-text strong{color:var(--c-brand-2)}
.footer-about .site-logo .logo-text small{color:#71717a}
.social-links a{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.06);color:#fff}
.social-links a:hover{background:var(--c-brand);border-color:var(--c-brand)}
.footer-bottom{background:#000}
.footer-bottom-inner{color:#71717a}
.payment-badges .pb{color:#a1a1aa;background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.08)}

/* Selection */
::selection{background:rgba(14,165,233,.25)}

/* Links default — keep mono text, blue on hover */
a{color:var(--c-brand)}
a:hover{color:var(--c-accent)}
