/* ==========================================================================
   FTS — Faisal TikTok Shop | Design System
   Palette: Deep Teal #285F6B · Neon Green #39FF14 · Black #050505
            Dark Gray #111111 · White #FFFFFF
   Type: Space Grotesk (display) / Inter (body)
   ========================================================================== */

:root{
  --teal: #285F6B;
  --teal-light: #3E8A99;
  --teal-dim: #1B4048;
  --green: #39FF14;
  --green-dim: #1F8C0C;
  --black: #050505;
  --gray-900: #0B0D0D;
  --gray-800: #111111;
  --gray-700: #191c1c;
  --gray-600: #2a2f2f;
  --slate: #9FB4B8;
  --slate-dim: #6b7a7d;
  --white: #FFFFFF;
  --off-white: #F4F7F7;

  --glass-bg: rgba(255,255,255,0.045);
  --glass-border: rgba(255,255,255,0.09);
  --glass-bg-strong: rgba(17,17,17,0.55);

  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --radius-pill: 999px;

  --shadow-glow-green: 0 0 40px rgba(57,255,20,0.18);
  --shadow-glow-teal: 0 0 60px rgba(62,138,153,0.25);
  --shadow-card: 0 10px 40px rgba(0,0,0,0.35);

  --font-display: 'Space Grotesk', 'Segoe UI', sans-serif;
  --font-body: 'Inter', 'Segoe UI', sans-serif;

  --ease: cubic-bezier(.16,.84,.44,1);
  --nav-h: 78px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; overflow-x:hidden; width:100%; }
body{
  margin:0;
  background:var(--black);
  color:var(--off-white);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  width:100%;
  position:relative;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; margin:0; padding:0; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4,h5{
  font-family:var(--font-display);
  font-weight:700;
  line-height:1.12;
  letter-spacing:-0.01em;
  margin:0 0 .5em;
  color:var(--white);
}
p{ margin:0 0 1em; color:var(--slate); }
::selection{ background:var(--green); color:var(--black); }

/* Focus visibility for accessibility */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible{
  outline:2px solid var(--green);
  outline-offset:3px;
  border-radius:4px;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

.container{
  width:100%;
  max-width:1240px;
  margin:0 auto;
  padding:0 24px;
}
.section{ padding:120px 0; position:relative; }
.section-tight{ padding:80px 0; }
@media (max-width:768px){
  .section{ padding:80px 0; }
  .section-tight{ padding:56px 0; }
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-display);
  font-size:12.5px;
  font-weight:600;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--green);
  margin-bottom:18px;
}
.eyebrow::before{
  content:"";
  width:22px; height:1px;
  background:var(--green);
  display:inline-block;
}

.section-head{ max-width:680px; margin-bottom:56px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head h2{ font-size:clamp(28px,4vw,42px); }
.section-head p{ font-size:17px; }

/* ---------- Buttons ---------- */
.btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:15px 30px;
  border-radius:var(--radius-pill);
  font-family:var(--font-display);
  font-weight:600;
  font-size:15px;
  letter-spacing:0.01em;
  border:1px solid transparent;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease), border-color .35s var(--ease), color .35s var(--ease);
  white-space:nowrap;
  isolation:isolate;
  overflow:hidden;
}
.btn-primary{
  background:var(--green);
  color:var(--black);
  box-shadow:0 0 0 0 rgba(57,255,20,0.5);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(57,255,20,0.35);
}
.btn-ghost{
  background:rgba(255,255,255,0.03);
  color:var(--white);
  border-color:rgba(255,255,255,0.18);
  backdrop-filter:blur(10px);
}
.btn-ghost:hover{
  border-color:var(--green);
  color:var(--green);
  transform:translateY(-2px);
}
.btn-sm{ padding:11px 22px; font-size:13.5px; }
.btn-block{ width:100%; }

/* ---------- Loading Screen ---------- */
#loader{
  position:fixed; inset:0; z-index:9999;
  background:var(--black);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:22px;
  transition:opacity .6s var(--ease), visibility .6s var(--ease);
}
#loader.hidden{ opacity:0; visibility:hidden; pointer-events:none; }
.loader-mark{ width:64px; height:64px; opacity:0.95; animation:loaderPulse 1.6s ease-in-out infinite; }
@keyframes loaderPulse{ 0%,100%{ transform:scale(1); filter:drop-shadow(0 0 8px rgba(57,255,20,.25)); } 50%{ transform:scale(1.08); filter:drop-shadow(0 0 22px rgba(57,255,20,.55)); } }
.loader-bar{ width:180px; height:2px; background:rgba(255,255,255,0.1); border-radius:2px; overflow:hidden; }
.loader-bar::after{
  content:""; display:block; height:100%; width:40%;
  background:linear-gradient(90deg, transparent, var(--green), transparent);
  animation:loaderSlide 1.1s ease-in-out infinite;
}
@keyframes loaderSlide{ 0%{ transform:translateX(-120%);} 100%{ transform:translateX(340%);} }
.loader-text{ font-family:var(--font-display); font-size:12px; letter-spacing:0.2em; color:var(--slate); text-transform:uppercase; }

/* ---------- Cursor glow (desktop only) ---------- */
#cursor-glow{
  position:fixed; top:0; left:0; width:26px; height:26px;
  border-radius:50%;
  pointer-events:none; z-index:9998;
  background:radial-gradient(circle, rgba(57,255,20,0.55), rgba(57,255,20,0) 70%);
  transform:translate(-50%,-50%);
  transition:opacity .3s ease;
  mix-blend-mode:screen;
  will-change:transform;
}
@media (hover:none), (pointer:coarse){ #cursor-glow{ display:none; } }

/* ---------- Background atmosphere ---------- */
.bg-clip{ position:fixed; inset:0; overflow:hidden; z-index:0; pointer-events:none; }
.bg-particles{ position:absolute; inset:0; z-index:0; pointer-events:none; opacity:0.55; }
.bg-grid{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 0%, black 40%, transparent 100%);
}
.bg-glow{
  position:absolute; border-radius:50%; filter:blur(90px); pointer-events:none; z-index:0;
  animation:driftGlow 16s ease-in-out infinite;
  max-width:60vw;
}
@keyframes driftGlow{ 0%,100%{ transform:translate(0,0) scale(1);} 50%{ transform:translate(30px,-20px) scale(1.12);} }

/* ---------- Navbar ---------- */
#navbar{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:var(--nav-h);
  display:flex; align-items:center;
  background:transparent;
  border-bottom:1px solid transparent;
  transition:background .4s var(--ease), border-color .4s var(--ease), height .4s var(--ease), backdrop-filter .4s var(--ease);
}
#navbar.scrolled{
  height:68px;
  background:rgba(5,5,5,0.72);
  backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.nav-inner{ width:100%; display:flex; align-items:center; justify-content:space-between; }
.nav-logo{ display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:700; font-size:19px; color:var(--white); }
.nav-logo img{ height:34px; width:auto; }
.nav-links{ display:flex; align-items:center; gap:36px; }
.nav-links a{
  font-size:14.5px; font-weight:500; color:var(--slate);
  position:relative; padding:4px 0; transition:color .25s ease;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px;
  background:var(--green); transition:width .3s var(--ease);
}
.nav-links a:hover{ color:var(--white); }
.nav-links a:hover::after, .nav-links a.active::after{ width:100%; }
.nav-links a.active{ color:var(--green); }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-toggle{ display:none; }

.has-dropdown{ position:relative; }
.dropdown{
  position:absolute; top:calc(100% + 18px); left:50%; transform:translateX(-50%) translateY(6px);
  width:300px; background:var(--glass-bg-strong); backdrop-filter:blur(20px);
  border:1px solid var(--glass-border); border-radius:var(--radius-md);
  padding:10px; opacity:0; visibility:hidden; transition:all .3s var(--ease);
  box-shadow:var(--shadow-card);
}
.has-dropdown:hover .dropdown{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.dropdown a{ display:block; padding:10px 14px; border-radius:8px; font-size:14px; color:var(--slate); }
.dropdown a:hover{ background:rgba(57,255,20,0.08); color:var(--green); }
.dropdown a::after{ display:none; }

@media (max-width:960px){
  .nav-links{
    position:fixed; top:68px; left:0; right:0; bottom:0;
    flex-direction:column; align-items:flex-start; gap:2px;
    background:rgba(5,5,5,0.98); backdrop-filter:blur(20px);
    padding:24px; transform:translateX(100%); transition:transform .4s var(--ease);
    overflow-y:auto;
  }
  .nav-links.open{ transform:translateX(0); }
  .nav-links a{ width:100%; padding:14px 4px; border-bottom:1px solid rgba(255,255,255,0.06); }
  .dropdown{ position:static; opacity:1; visibility:visible; transform:none; width:100%; display:none; background:transparent; border:none; box-shadow:none; padding:0 0 0 12px; }
  .has-dropdown.open .dropdown{ display:block; }
  .nav-cta .btn-ghost{ display:none; }
  .nav-toggle{
    display:flex; flex-direction:column; gap:5px; background:none; border:none; padding:8px; z-index:1001;
  }
  .nav-toggle span{ width:22px; height:2px; background:var(--white); transition:all .3s ease; }
  .nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2){ opacity:0; }
  .nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; align-items:center;
  padding-top:var(--nav-h);
  overflow:hidden;
}
.hero-inner{ position:relative; z-index:2; width:100%; padding:70px 0 60px; text-align:center; }
.hero .eyebrow{ justify-content:center; }
.hero h1{
  font-size:clamp(38px, 6.4vw, 78px);
  max-width:960px; margin-left:auto; margin-right:auto;
}
.hero h1 .accent{ color:var(--green); }
.hero-sub{
  max-width:620px; margin:26px auto 40px; font-size:18px; color:var(--slate);
}
.hero-actions{ display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; margin-bottom:64px; }

.hero-chart{ position:relative; max-width:880px; margin:0 auto; }
.hero-chart svg{ width:100%; height:auto; overflow:visible; }
.chart-path{
  fill:none; stroke:var(--green); stroke-width:2.5; stroke-linecap:round;
  stroke-dasharray:1000; stroke-dashoffset:1000;
  animation:drawPath 2.4s var(--ease) 0.4s forwards;
  filter:drop-shadow(0 0 8px rgba(57,255,20,0.6));
}
@keyframes drawPath{ to{ stroke-dashoffset:0; } }
.chart-area{ opacity:0; animation:fadeIn 1.2s ease 1.8s forwards; }
@keyframes fadeIn{ to{ opacity:1; } }
.chart-node{
  opacity:0; transform-origin:center;
  animation:nodePop .5s var(--ease) forwards;
}
@keyframes nodePop{ from{ opacity:0; transform:scale(0);} to{ opacity:1; transform:scale(1);} }
.chart-node circle.pulse{
  animation:nodePulse 2s ease-in-out infinite;
}
@keyframes nodePulse{ 0%,100%{ r:5; opacity:1;} 50%{ r:9; opacity:0.4;} }

/* Stats */
.stats-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:var(--glass-border); border:1px solid var(--glass-border);
  border-radius:var(--radius-lg); overflow:hidden; margin-top:8px;
}
.stat-cell{
  background:var(--gray-900); padding:34px 20px; text-align:center;
}
.stat-num{ font-family:var(--font-display); font-size:clamp(28px,4vw,42px); font-weight:700; color:var(--white); }
.stat-num .suffix{ color:var(--green); }
.stat-label{ font-size:13px; color:var(--slate); text-transform:uppercase; letter-spacing:0.08em; margin-top:6px; }
@media (max-width:768px){ .stats-grid{ grid-template-columns:repeat(2,1fr);} }

/* ---------- Marquee ---------- */
.marquee-wrap{ overflow:hidden; border-top:1px solid var(--glass-border); border-bottom:1px solid var(--glass-border); padding:26px 0; background:rgba(40,95,107,0.06); }
.marquee-track{ display:flex; width:max-content; gap:60px; animation:marquee 32s linear infinite; }
.marquee-track span{ font-family:var(--font-display); font-size:15px; letter-spacing:0.05em; color:var(--slate); white-space:nowrap; display:flex; align-items:center; gap:14px;}
.marquee-track span::after{ content:"◆"; color:var(--green); font-size:9px; }
@keyframes marquee{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
.marquee-wrap:hover .marquee-track{ animation-play-state:paused; }

/* ---------- Cards / Glass ---------- */
.glass-card{
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  backdrop-filter:blur(14px);
  transition:transform .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.glass-card:hover{ transform:translateY(-6px); border-color:rgba(57,255,20,0.35); box-shadow:var(--shadow-glow-green); }

.grid{ display:grid; gap:24px; }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
@media (max-width:960px){ .grid-3, .grid-4{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:640px){ .grid-3, .grid-4, .grid-2{ grid-template-columns:1fr;} }

.service-card{ padding:32px 28px; }
.service-card .icon{
  width:52px; height:52px; border-radius:14px;
  background:linear-gradient(135deg, rgba(57,255,20,0.15), rgba(40,95,107,0.4));
  display:flex; align-items:center; justify-content:center; margin-bottom:22px;
  border:1px solid rgba(57,255,20,0.2);
}
.service-card .icon svg{ width:24px; height:24px; stroke:var(--green); }
.service-card h3{ font-size:19px; margin-bottom:10px; }
.service-card p{ font-size:14.5px; margin-bottom:16px; }
.service-card .card-link{ font-size:13.5px; font-weight:600; color:var(--green); display:inline-flex; align-items:center; gap:6px; font-family:var(--font-display);}
.service-card .card-link svg{ width:14px; height:14px; transition:transform .3s var(--ease); }
.service-card:hover .card-link svg{ transform:translateX(4px); }

/* Feature / why-choose rows */
.feature-row{ display:flex; gap:18px; padding:22px 0; border-bottom:1px solid var(--glass-border); }
.feature-row:last-child{ border-bottom:none; }
.feature-num{ font-family:var(--font-display); color:var(--teal-light); font-size:14px; padding-top:3px; min-width:34px; }
.feature-row h4{ font-size:16.5px; margin-bottom:6px; color:var(--white); }
.feature-row p{ font-size:14.5px; margin:0; }

/* ---------- Pricing-less CTA band ---------- */
.cta-band{
  position:relative; border-radius:28px; overflow:hidden;
  padding:70px 40px; text-align:center;
  background:linear-gradient(135deg, rgba(40,95,107,0.5), rgba(5,5,5,0.9));
  border:1px solid var(--glass-border);
}
.cta-band h2{ font-size:clamp(26px,3.6vw,38px); max-width:640px; margin:0 auto 16px; }
.cta-band p{ max-width:500px; margin:0 auto 32px; }
.cta-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

/* ---------- Testimonial / logos ---------- */
.quote-card{ padding:30px; }
.quote-card p{ color:var(--off-white); font-size:15.5px; font-style:italic; }
.quote-meta{ display:flex; align-items:center; gap:12px; margin-top:18px; }
.quote-avatar{ width:40px; height:40px; border-radius:50%; background:var(--teal); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:700; color:var(--white); font-size:14px; }
.quote-name{ font-size:14px; color:var(--white); font-weight:600; }
.quote-role{ font-size:12.5px; color:var(--slate-dim); }
.stars{ color:var(--green); font-size:14px; letter-spacing:2px; margin-bottom:12px; }

/* ---------- FAQ Accordion ---------- */
.faq-list{ max-width:820px; margin:0 auto; }
.faq-item{ border-bottom:1px solid var(--glass-border); }
.faq-q{
  width:100%; display:flex; justify-content:space-between; align-items:center; gap:20px;
  padding:24px 4px; background:none; border:none; text-align:left;
  font-family:var(--font-display); font-size:16.5px; color:var(--white); font-weight:600;
}
.faq-q .plus{ font-size:20px; color:var(--green); transition:transform .35s var(--ease); flex-shrink:0; }
.faq-item.open .plus{ transform:rotate(135deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq-a-inner{ padding:0 4px 24px; font-size:15px; color:var(--slate); max-width:720px; }

/* ---------- Breadcrumb ---------- */
.breadcrumb{ font-size:13px; color:var(--slate-dim); padding-top:calc(var(--nav-h) + 32px); }
.breadcrumb a{ color:var(--slate); }
.breadcrumb a:hover{ color:var(--green); }
.breadcrumb .sep{ margin:0 8px; opacity:0.4; }

/* ---------- Page hero (inner pages) ---------- */
.page-hero{ padding:36px 0 70px; text-align:left; position:relative; }
.page-hero.center{ text-align:center; }
.page-hero h1{ font-size:clamp(32px,5vw,54px); max-width:760px; }
.page-hero.center h1{ margin:0 auto; }
.page-hero p{ font-size:17px; max-width:600px; margin-top:18px; }
.page-hero.center p{ margin-left:auto; margin-right:auto; }

/* ---------- Table of contents / blog ---------- */
.blog-layout{ display:grid; grid-template-columns:1fr 280px; gap:60px; align-items:start; }
@media (max-width:900px){ .blog-layout{ grid-template-columns:1fr; } }
.toc{ position:sticky; top:100px; padding:24px; }
.toc h4{ font-size:13px; text-transform:uppercase; letter-spacing:0.1em; color:var(--slate-dim); margin-bottom:14px; }
.toc ul{ display:flex; flex-direction:column; gap:10px; }
.toc a{ font-size:14px; color:var(--slate); }
.toc a:hover{ color:var(--green); }
.share-row{ display:flex; gap:10px; margin-top:26px; }
.share-btn{ width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:var(--glass-bg); border:1px solid var(--glass-border); transition:all .3s ease; }
.share-btn:hover{ border-color:var(--green); color:var(--green); transform:translateY(-2px); }
.share-btn svg{ width:16px; height:16px; }

.article-body h2{ font-size:26px; margin-top:44px; }
.article-body h3{ font-size:20px; margin-top:32px; color:var(--white); }
.article-body p{ font-size:16px; color:var(--slate); }
.article-body ul, .article-body ol{ color:var(--slate); padding-left:22px; margin-bottom:20px; }
.article-body li{ margin-bottom:8px; }
.article-body blockquote{ border-left:3px solid var(--green); padding:6px 22px; margin:28px 0; font-style:italic; color:var(--off-white); }
.article-meta{ display:flex; gap:18px; align-items:center; flex-wrap:wrap; font-size:13.5px; color:var(--slate-dim); margin-bottom:30px; }
.tag-pill{ display:inline-block; padding:6px 14px; border-radius:var(--radius-pill); background:rgba(57,255,20,0.08); color:var(--green); font-size:12px; font-weight:600; border:1px solid rgba(57,255,20,0.2); margin:0 8px 8px 0; }
.blog-card{ overflow:hidden; }
.blog-card .thumb{ height:180px; background:linear-gradient(135deg, var(--teal-dim), var(--gray-900)); position:relative; overflow:hidden; }
.blog-card .thumb-icon{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; opacity:0.5; }
.blog-card .thumb-icon svg{ width:48px; height:48px; stroke:var(--green); }
.blog-card .body{ padding:24px; }
.blog-card .cat{ font-size:11.5px; text-transform:uppercase; letter-spacing:0.08em; color:var(--green); font-weight:700; }
.blog-card h3{ font-size:18px; margin:10px 0; }
.blog-card .meta{ font-size:12.5px; color:var(--slate-dim); }

/* ---------- Forms ---------- */
.form-group{ margin-bottom:20px; }
.form-group label{ display:block; font-size:13.5px; color:var(--slate); margin-bottom:8px; font-weight:500; }
.form-control{
  width:100%; padding:15px 18px; border-radius:var(--radius-sm);
  background:rgba(255,255,255,0.03); border:1px solid var(--glass-border);
  color:var(--white); font-family:var(--font-body); font-size:15px;
  transition:border-color .3s ease, background .3s ease;
}
.form-control:focus{ outline:none; border-color:var(--green); background:rgba(57,255,20,0.03); }
textarea.form-control{ resize:vertical; min-height:130px; }
.form-note{ font-size:13px; color:var(--slate-dim); margin-top:10px; }

.contact-grid{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:50px; }
@media (max-width:860px){ .contact-grid{ grid-template-columns:1fr; } }
.info-card{ padding:26px; display:flex; gap:16px; align-items:flex-start; }
.info-card .icon{ width:44px; height:44px; border-radius:12px; background:rgba(57,255,20,0.1); display:flex; align-items:center; justify-content:center; flex-shrink:0; border:1px solid rgba(57,255,20,0.2); }
.info-card .icon svg{ width:20px; height:20px; stroke:var(--green); }
.info-card h4{ font-size:15.5px; margin-bottom:4px; }
.info-card p{ font-size:14px; margin:0; }
.map-box{ height:220px; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--glass-border); position:relative; }
.map-box iframe{ width:100%; height:100%; border:0; filter:grayscale(1) invert(0.92) contrast(0.9); }

/* ---------- Legal pages ---------- */
.legal-body h2{ font-size:22px; margin-top:38px; }
.legal-body p, .legal-body li{ color:var(--slate); font-size:15px; }
.legal-body ul{ padding-left:20px; margin-bottom:18px; }
.legal-updated{ color:var(--slate-dim); font-size:13.5px; margin-bottom:40px; }

/* ---------- Footer ---------- */
footer{ background:var(--gray-900); border-top:1px solid var(--glass-border); padding-top:80px; position:relative; z-index:1; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-bottom:60px; }
@media (max-width:860px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .footer-grid{ grid-template-columns:1fr; } }
.footer-brand .nav-logo{ margin-bottom:16px; }
.footer-brand p{ font-size:14px; max-width:280px; }
.footer-col h5{ font-family:var(--font-display); font-size:13px; text-transform:uppercase; letter-spacing:0.1em; color:var(--white); margin-bottom:20px; }
.footer-col ul{ display:flex; flex-direction:column; gap:12px; }
.footer-col a{ font-size:14.5px; color:var(--slate); transition:color .25s ease; }
.footer-col a:hover{ color:var(--green); }
.footer-social{ display:flex; gap:12px; margin-top:20px; }
.footer-social a{ width:38px; height:38px; border-radius:50%; background:rgba(255,255,255,0.04); border:1px solid var(--glass-border); display:flex; align-items:center; justify-content:center; }
.footer-social a:hover{ border-color:var(--green); background:rgba(57,255,20,0.08); }
.footer-social svg{ width:16px; height:16px; }
.footer-bottom{ border-top:1px solid var(--glass-border); padding:26px 0; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; font-size:13px; color:var(--slate-dim); }
.footer-bottom a{ color:var(--slate-dim); }
.footer-bottom a:hover{ color:var(--green); }

/* ---------- WhatsApp float ---------- */
.wa-float{
  position:fixed; bottom:26px; right:26px; z-index:900;
  width:60px; height:60px; border-radius:50%;
  background:#25D366; display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 24px rgba(37,211,102,0.4);
  animation:waPulse 2.6s ease-in-out infinite;
}
.wa-float svg{ width:28px; height:28px; fill:#fff; }
@keyframes waPulse{
  0%,100%{ box-shadow:0 6px 24px rgba(37,211,102,0.4), 0 0 0 0 rgba(37,211,102,0.5); }
  50%{ box-shadow:0 6px 30px rgba(37,211,102,0.6), 0 0 0 12px rgba(37,211,102,0); }
}
.wa-float:hover{ transform:scale(1.08); }

/* ---------- Back to top ---------- */
#back-to-top{
  position:fixed; bottom:26px; left:26px; z-index:900;
  width:46px; height:46px; border-radius:50%;
  background:var(--glass-bg-strong); border:1px solid var(--glass-border); backdrop-filter:blur(10px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:all .35s var(--ease);
}
#back-to-top.show{ opacity:1; visibility:visible; transform:translateY(0); }
#back-to-top svg{ width:18px; height:18px; stroke:var(--green); }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in-view{ opacity:1; transform:translateY(0); }
.reveal-delay-1{ transition-delay:0.08s; }
.reveal-delay-2{ transition-delay:0.16s; }
.reveal-delay-3{ transition-delay:0.24s; }
.reveal-delay-4{ transition-delay:0.32s; }

/* ---------- Related / breadcrumb schema pages ---------- */
.related-strip{ display:flex; gap:10px; flex-wrap:wrap; }
.related-strip a{
  padding:9px 18px; border-radius:var(--radius-pill); font-size:13.5px;
  background:var(--glass-bg); border:1px solid var(--glass-border); color:var(--slate);
  transition:all .3s ease;
}
.related-strip a:hover{ border-color:var(--green); color:var(--green); }

.text-center{ text-align:center; }
.mt-0{ margin-top:0; }
.small-caps{ font-family:var(--font-display); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color:var(--slate-dim); }

/* ---------- 404 ---------- */
.error-page{ min-height:80vh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding-top:var(--nav-h); }
.error-code{ font-family:var(--font-display); font-size:clamp(80px,16vw,180px); font-weight:700; color:transparent; -webkit-text-stroke:1.5px rgba(57,255,20,0.5); line-height:1; }

/* ==========================================================================
   EXTRA MOBILE + FIXED-SIZE RESPONSIVE PASS
   ========================================================================== */
html{ -webkit-text-size-adjust:100%; }
body{ overflow-x:hidden; width:100%; }
.container{ width:100%; max-width:1240px; padding:0 20px; }
img, svg{ max-width:100%; height:auto; }

@media (max-width:960px){
  :root{ --nav-h:66px; }
  .container{ padding:0 18px; }
  .section{ padding:64px 0; }
  .section-tight{ padding:48px 0; }
  .hero{ min-height:auto; padding-bottom:20px; }
  .hero-inner{ padding:40px 0 36px; }
  .hero h1{ font-size:clamp(30px,7vw,46px); }
  .hero-sub{ font-size:15.5px; padding:0 6px; }
  .hero-chart{ max-width:100%; }
  .page-hero h1{ font-size:clamp(26px,6vw,36px); }
  .page-hero p{ font-size:15px; }
  .section-head h2{ font-size:clamp(24px,6vw,30px); }
  .cta-band{ padding:44px 22px; border-radius:20px; }
  .cta-band h2{ font-size:clamp(22px,6vw,28px); }
}

@media (max-width:640px){
  .container{ padding:0 16px; }
  .section{ padding:52px 0; }
  .section-tight{ padding:40px 0; }
  h1{ font-size:clamp(26px,7.5vw,36px) !important; }
  .hero h1{ font-size:clamp(26px,7.5vw,36px); line-height:1.2; }
  .hero-sub{ font-size:14.5px; margin:18px auto 28px; }
  .hero-actions{ gap:12px; margin-bottom:40px; }
  .btn{ padding:13px 22px; font-size:14px; }
  .btn-block-mobile, .hero-actions .btn, .cta-actions .btn{ width:100%; }
  .hero-actions, .cta-actions{ flex-direction:column; align-items:stretch; }
  .stats-grid{ grid-template-columns:repeat(2,1fr); border-radius:16px; }
  .stat-cell{ padding:22px 12px; }
  .stat-num{ font-size:26px; }
  .stat-label{ font-size:11px; }
  .eyebrow{ font-size:11px; }
  .section-head{ margin-bottom:36px; }
  .service-card, .info-card, .quote-card{ padding:22px 20px; }
  .glass-card{ border-radius:16px; }
  .feature-row{ padding:16px 0; gap:12px; }
  .marquee-track{ gap:34px; }
  .marquee-track span{ font-size:13px; }
  .nav-logo span{ font-size:17px; }
  .nav-logo img{ height:28px; }
  #navbar{ height:60px; }
  #navbar.scrolled{ height:56px; }
  .nav-links{ top:60px; padding:18px; }
  .breadcrumb{ padding-top:calc(var(--nav-h) + 20px); font-size:12px; }
  .contact-grid{ gap:28px; }
  .form-control{ padding:13px 14px; font-size:14.5px; }
  .toc{ position:static; }
  .article-body h2{ font-size:21px; }
  .article-body h3{ font-size:17px; }
  .article-body p, .article-body li{ font-size:14.5px; }
  .footer-grid{ gap:28px; padding-bottom:40px; }
  footer{ padding-top:52px; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; text-align:left; }
  .wa-float{ width:52px; height:52px; bottom:18px; right:18px; }
  .wa-float svg{ width:24px; height:24px; }
  #back-to-top{ width:40px; height:40px; bottom:18px; left:18px; }
  .error-code{ font-size:clamp(64px,22vw,110px); }
}

@media (max-width:400px){
  .container{ padding:0 14px; }
  .hero h1, h1{ font-size:24px !important; }
  .hero-sub{ font-size:13.5px; }
  .stat-num{ font-size:22px; }
  .btn{ padding:12px 18px; font-size:13px; }
}

/* Prevent any element from forcing horizontal scroll */
table{ display:block; overflow-x:auto; max-width:100%; }
