:root{
  --bg: #000000;
  --text: #ffffff;
  --card: #ffffff;
  --muted: #9aa4ad;
  --accent: #39b54a;
  --accent-600: #2f9b3d;
  --glass: rgba(255,255,255,0.03);
  --glass-2: rgba(255,255,255,0.06);
  --container: 1180px;
  --radius: 12px;
  --gap: 20px;
  --shadow-sm: 0 8px 30px rgba(0,0,0,0.6);
  --shadow-lg: 0 18px 50px rgba(0,0,0,0.7);
  --neon: #7AF59A;
  --footer-sep: rgba(57,181,74,0.12);
  --transition: 220ms cubic-bezier(.2,.9,.2,1);
}

/* ======================
   Accessibility helpers
   ====================== */
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* =========
   Base reset
   ========= */
* { box-sizing: border-box; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background: var(--bg);
  color: var(--text);
  line-height: 1.45;
}
.container { max-width: var(--container); margin: 0 auto; padding: 0 20px; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ============
   Buttons common
   ============ */
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:8px 14px;
  border-radius:10px;
  cursor:pointer;
  border:0;
  font-weight:800;
  text-decoration:none;
  transition: transform 120ms ease, box-shadow 160ms ease, background var(--transition), color var(--transition);
}
.btn:focus { outline: 3px solid rgba(57,181,74,0.12); outline-offset: 2px; }

/* Primary hero CTA - white */
.btn-primary {
  background: #ffffff;
  color: #021014;
  padding:10px 16px;
  border-radius:10px;
  font-weight:700;
  box-shadow: var(--shadow-sm);
  border: 1px solid rgba(0,0,0,0.06);
}
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(2,6,23,0.18); }

/* Signup CTAs (green) */
.btn-primary.signup-cta,
.btn-primary.signup-btn {
  background: linear-gradient(90deg,#39b54a,#2f9b3d);
  color:#fff;
  box-shadow: 0 12px 40px rgba(57,181,74,0.12);
  border: 1px solid rgba(0,0,0,0.06);
}
.btn-primary.signup-cta:hover,
.btn-primary.signup-btn:hover { transform: translateY(-3px); }

/* Outline variant */
.btn-outline {
  background: transparent;
  color: var(--text);
  border: 1px solid rgba(255,255,255,0.06);
  padding:10px 14px;
  border-radius:10px;
}
.btn-outline:hover { background: rgba(255,255,255,0.02); color: var(--accent); }

/* ============

   Header & Nav
   ============ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 160;
  background: linear-gradient(180deg, rgba(0,0,0,0.96), rgba(0,0,0,0.9));
  border-bottom: 1px solid rgba(255,255,255,0.03);
  backdrop-filter: blur(6px);
}
.header-inner { display:flex; align-items:center; justify-content:space-between; gap:var(--gap); padding:14px 0; }
.brand img { height:40px; width:auto; display:block; }

/* Hamburger (mobile) */
.hamburger-btn { display:none; background:transparent; border:0; padding:8px; cursor:pointer; }
.hamburger-icon { width:22px; height:2px; background:var(--text); position:relative; display:block; }
.hamburger-icon::before, .hamburger-icon::after { content:""; position:absolute; left:0; right:0; height:2px; background:var(--text); }
.hamburger-icon::before { top:-7px } .hamburger-icon::after { top:7px }

/* Nav layout */
.nav { display:flex; align-items:center; gap:18px; width:100%; justify-content:flex-end; }
.nav-list { display:flex; gap:6px; list-style:none; margin:0; padding:0; align-items:center; }
.nav-list > li { position:relative; }
.nav-link, .dropdown-toggle {
  color: var(--text);
  padding:10px 14px;
  border-radius:10px;
  font-weight:700;
  background:transparent;
  transition: color var(--transition), background var(--transition);
}
.nav-link:hover, .dropdown-toggle:hover { color: var(--accent); background: rgba(255,255,255,0.02); }

/* underline effect */
.nav-link::after, .dropdown-toggle::after {
  content: "";
  position:absolute; left:14px; right:14px; height:3px; bottom:-7px;
  background:transparent; transform-origin:left center; transform:scaleX(0);
  transition: transform 180ms cubic-bezier(.2,.9,.2,1), background-color 180ms ease; border-radius:3px;
}
.nav-link:hover::after { background: var(--accent); transform: scaleX(1); }

/* Dropdown menu */
.dropdown-menu {
  position:absolute; top:calc(100% + 12px); left:0; min-width:320px;
  background: linear-gradient(180deg,#0b0b0b,#0f0f0f);
  color: var(--text);
  border-radius:12px; padding:12px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.7); border:1px solid rgba(255,255,255,0.03);
  opacity:0; transform:translateY(8px) scale(.98); pointer-events:none; transition:opacity 160ms ease, transform 160ms ease; z-index:120;
}
.dropdown.open > .dropdown-menu,
.dropdown:hover > .dropdown-menu,
.dropdown:focus-within > .dropdown-menu {
  opacity:1; transform:translateY(0) scale(1); pointer-events:auto;
}
.dropdown-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.dropdown-item { padding:10px 12px; border-radius:8px; display:flex; flex-direction:column; gap:4px; color:var(--text); }
.dropdown-item .item-title { font-weight:800; }
.dropdown-item .item-desc { color:var(--muted); font-size:13px; }

/* ===========
   Hero slider
   =========== */
.hero-slider { margin-top:10px; margin-bottom:24px; }
.slider-viewport {
  position: relative;
  height: 320px;
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.02));
  border-radius: 14px;
  padding: 22px;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateX(30px);
  transition: opacity 600ms var(--transition), transform 600ms var(--transition);
  display:flex; align-items:center; justify-content:center; padding:12px;
}
.slide[aria-hidden="false"] { opacity:1; transform: translateX(0); }
.slide-inner { display:grid; grid-template-columns:420px 1fr; gap:28px; align-items:center; width:100%; }
.slide-img { width:100%; max-width:420px; height:auto; border-radius:12px; object-fit:contain; box-shadow:0 10px 30px rgba(0,0,0,0.45); }
.slide-title { margin:0 0 8px; font-size:1.6rem; line-height:1.05; font-weight:800; }
.slide-lead { margin:0 0 18px; color:var(--muted); font-size:1rem; }

/* slider controls */
.slider-controls { display:flex; align-items:center; justify-content:center; gap:12px; margin-top:14px; }
.control { background:transparent; color:var(--muted); border:0; font-size:22px; cursor:pointer; padding:8px 12px; border-radius:8px; }
.control:hover { color:var(--text); }
.indicators { display:flex; gap:8px; align-items:center; }
.indicator { width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.03); cursor:pointer; }
.indicator.active { background:var(--accent); box-shadow: 0 4px 10px rgba(57,181,74,0.18); }

/* =========
   Sections
   ========= */
.section { padding:36px 0; }
.grid-3 { display:grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.card { background:var(--card); color:#0b1220; padding:18px; border-radius:12px; box-shadow:var(--shadow-sm); border:1px solid rgba(15,23,42,0.04); }
.card-title { font-weight:700; margin:0 0 8px; }
.card-body { color:#334155; margin:0 0 12px; }
.card-link { font-weight:700; color:var(--accent); }

/* =================
   Advantages (3D)
   ================= */
.advantages { padding: 48px 0; }
.advantages-header { text-align:center; max-width:840px; margin:0 auto 28px; }
.advantages-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:stretch; }
.adv3d { perspective:1200px; -webkit-perspective:1200px; }
.card-3d {
  position:relative; width:100%; min-height:180px; border-radius:16px;
  transform-style:preserve-3d; transition: transform 600ms var(--transition), box-shadow 400ms ease;
  background: linear-gradient(180deg,#fff,#fbfbfb); border:1px solid rgba(15,23,42,0.06); box-shadow: 0 12px 40px rgba(2,6,23,0.45);
  overflow: visible; animation: cardFloat 7.5s ease-in-out infinite; display:flex; align-items:flex-start;
}
@keyframes cardFloat { 0% { transform: translateY(0) } 50% { transform: translateY(-10px) } 100% { transform: translateY(0) } }
.card-3d:hover { transform: translateY(-6px) scale(1.01); box-shadow: 0 30px 80px rgba(2,6,23,0.5); }
.card-layer { position:absolute; inset:0; border-radius:16px; pointer-events:none; }
.card-content { z-index:4; padding:18px; display:flex; align-items:flex-start; width:100%; box-sizing:border-box; }
.adv-body { display:flex; gap:14px; align-items:flex-start; }
.adv-icon { width:48px; height:48px; flex:0 0 48px; }
.adv-title { margin:0 0 6px; font-size:1.05rem; font-weight:800; color:#0b1220; }
.adv-desc { margin:0; color:#334155; font-size:0.95rem; line-height:1.45; }

/* ================
   Impact / Stats
   ================ */
.impact-stats.colorful { padding: 46px 0 72px; position:relative; }
#impact-sparkles { position:absolute; inset:0; pointer-events:none; overflow:visible; z-index:10; }
.impact-inner { text-align:center; max-width:1080px; margin:0 auto; }
.stats-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; align-items:stretch; margin-top:8px; }

/* ================
   How It Works
   ================ */
.how-it-works { padding:56px 0 84px; background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.02)); border-radius:14px; margin-top:28px; }
.how-header { text-align:center; margin-bottom:20px; }
.how-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:20px; align-items:stretch; grid-auto-rows: minmax(180px, auto); }

.step-card {
  display:flex; gap:12px; align-items:flex-start;
  background: linear-gradient(180deg,#fff,#fbfbfb);
  color:#06202a; border-radius:12px; padding:14px;
  box-shadow:0 14px 36px rgba(0,0,0,0.38); border:1px solid rgba(2,6,23,0.06);
  height: 100%;
  min-height: 180px;
  overflow: auto;
  position: relative;
  transform-origin: center;
  opacity: 1;
}

.step-num {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: linear-gradient(180deg, var(--accent), var(--accent-600));
  color: #fff;
  font-weight: 900;
  font-size: 0.9rem;
  box-shadow: 0 6px 20px rgba(57,181,74,0.10);
}

.step-content { flex: 1 1 auto; overflow: auto; padding-right: 8px; }
.step-content h3 { margin:0 0 8px; font-size:1rem; font-weight:800; }
.step-content p { margin:0; color:#334155; font-size:0.95rem; line-height:1.45; }

@keyframes hwZoomIn {
  0% { opacity: 0; transform: scale(.96) translateY(12px); }
  60% { opacity: 1; transform: scale(1.02) translateY(-6px); }
  100% { opacity: 1; transform: scale(1) translateY(0); }
}

.step-card.active {
  animation-name: hwZoomIn;
  animation-duration: 520ms;
  animation-fill-mode: both;
  animation-timing-function: cubic-bezier(.2,.9,.2,1);
  z-index: 4;
}

.step-card:hover { transform: translateY(-6px) scale(1.01); box-shadow: 0 30px 80px rgba(2,6,23,0.5); }

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
  .step-card, .step-card.active, .how-grid.play-sequence .step-card { animation: none !important; opacity: 1 !important; transform: none !important; }
  .card-3d { animation: none !important; }
}

/* responsive */
@media (max-width: 1200px) {
  .advantages-grid { grid-template-columns: repeat(2,1fr); }
  .how-grid { grid-template-columns: repeat(2,1fr); grid-auto-rows: minmax(160px, auto); }
}
@media (max-width: 640px) {
  .how-grid { grid-template-columns: 1fr; grid-auto-rows: auto; }
  .step-card { height: auto; min-height: 120px; }
}

/* ================
   Packages / Pricing
   ================ */
.packages.modern { padding:56px 0; position:relative; }
.packages-header { text-align:center; max-width:900px; margin:0 auto 22px; }
.packages-header .overline { color: var(--neon); font-weight:900; letter-spacing:1px; margin-bottom:8px; }
.packages-title { font-family:"Poppins",sans-serif; font-weight:900; font-size:1.6rem; margin:0 0 8px; color:#f8fff7; }
.packages-lead { color: rgba(248,255,247,0.85); margin:0 auto 18px; max-width:760px; }

.pricing-toggle { display:inline-flex; gap:8px; margin-top:12px; border-radius:14px; padding:6px; background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01)); }
.toggle-btn { background:transparent; border:0; color:var(--muted); padding:8px 14px; border-radius:10px; cursor:pointer; font-weight:800; transition: background var(--transition), color var(--transition); }
.toggle-btn.active { color:#fff; background: linear-gradient(90deg, var(--accent), var(--accent-600)); box-shadow: 0 8px 26px rgba(39,133,44,0.12); }

.packages-slider-wrap { display:flex; align-items:center; gap:12px; position:relative; margin-top:18px; }
.packages-slider { overflow:hidden; width:100%; position:relative; }
.packages-track { display:flex; gap:18px; transition: transform 420ms cubic-bezier(.2,.9,.2,1); will-change: transform; }
.package-card { background: linear-gradient(180deg,#fff,#fbfbfb); color:#06202a; border-radius:14px; padding:56px 18px 18px 18px; box-shadow:0 24px 70px rgba(2,6,23,0.35); border:1px solid rgba(2,6,23,0.06); display:flex; flex-direction:column; gap:12px; min-height:340px; flex:0 0 320px; box-sizing:border-box; position:relative; }
.pkg-top { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-top:8px; }
.pkg-title { margin:0; font-weight:900; font-family:"Poppins",sans-serif; font-size:1rem; color:#06202a; }
.pkg-price { background: linear-gradient(90deg,#7AF59A,#39b54a); color:#02262a; padding:10px 14px; border-radius:10px; font-weight:900; display:inline-flex; align-items:center; gap:8px; min-height:56px; box-shadow:0 8px 22px rgba(57,181,74,0.06); line-height:1; font-size:1rem; }
.pkg-list { margin:0; padding-left:18px; list-style:decimal; display:flex; flex-direction:column; gap:8px; color:#234; }
.pkg-footer { margin-top:auto; display:flex; justify-content:flex-end; }
.btn-primary.signup-btn { background: linear-gradient(90deg,#39b54a,#2f9b3d); color:#fff; padding:10px 14px; border-radius:10px; border:0; cursor:pointer; font-weight:800; }
.pkg-badge { position:absolute; left:12px; top:18px; background:#06202a; color:#fff; padding:6px 10px; border-radius:10px; font-weight:900; font-size:0.82rem; z-index:60; }
.pkg-badge.premium { background: linear-gradient(90deg,#0b2a2a,#143d33); color:#FFD86B; }

/* yearly promo chip */
.pkg-free { display:none; position:absolute; right:12px; top:18px; background:#06202a; color:#fff; padding:6px 10px; border-radius:10px; font-weight:800; font-size:0.82rem; z-index:60; }
.packages-slider.yearly .pkg-free { display:block; }

/* nav arrows */
.pkg-nav { background: rgba(255,255,255,0.03); color:#fff; border:0; width:44px; height:44px; border-radius:10px; font-size:22px; display:grid; place-items:center; cursor:pointer; transition: transform 120ms ease, background 120ms ease; }
.pkg-nav:hover { transform: translateY(-4px); background: rgba(57,181,74,0.08); color: var(--accent); }
.pkg-nav:disabled { opacity:0.35; cursor:not-allowed; }

/* responsiveness */
@media (max-width:1100px) { .package-card { flex:0 0 48%; } }
@media (max-width:720px) { .package-card { flex:0 0 88%; } .pkg-nav { display:none; } }

/* ========
   FAQs
   ======== */
.faqs,
section.faqs,
.faq-section {
  padding:36px 0 72px;
}
.faqs-header,
.faqs .faqs-header {
  text-align:center;
  max-width:880px;
  margin:0 auto 20px;
}
.faqs-list,
.faqs .faqs-list {
  max-width:980px;
  margin:16px auto 0;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.faq-item {
  background:linear-gradient(180deg,#fff,#fbfbfb);
  border-radius:12px;
  border:1px solid rgba(2,6,23,0.06);
  box-shadow:0 12px 40px rgba(2,6,23,0.18);
  overflow:visible;
}
.faq-question {
  width:100%; text-align:left;
  background: linear-gradient(90deg, var(--accent), var(--accent-600));
  border:0; padding:16px 18px; font-weight:800; font-size:1rem; color:#06202a;
  display:flex; align-items:center; justify-content:space-between; gap:12px; cursor:pointer; border-radius:12px; box-shadow:0 6px 18px rgba(0,0,0,0.12);
}
.faq-toggle { display:inline-block; width:28px; height:28px; border-radius:6px; background: rgba(0,0,0,0.06); color:#fff; display:grid; place-items:center; transform:rotate(0); transition: transform 200ms ease, background-color 200ms ease; }
.faq-question[aria-expanded="true"] .faq-toggle { transform:rotate(45deg); background: rgba(57,181,74,0.12); color:#7AF59A; }
.faq-answer { padding:0 18px 18px 18px; color:#234; line-height:1.6; }
.faq-answer[hidden] { display:none !important; }

/* =================
   Footer top + bottom
   ================= */
.footer-top { padding:36px 0 18px; border-top:1px solid rgba(255,255,255,0.03); background: linear-gradient(180deg, rgba(255,255,255,0.01), transparent); }
.footer-top-inner { max-width: var(--container); margin:0 auto; padding:18px 20px; }
.footer-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:20px; align-items:start; }
.footer-col { color: var(--text); padding:6px 0; }
.footer-col + .footer-col { border-left: 2px solid var(--footer-sep); padding-left:20px; }
.footer-col h4 { margin:0 0 10px; font-size:0.95rem; color:#fff; font-weight:900; }
.footer-col ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.footer-col a { color: rgba(255,255,255,0.92); text-decoration:none; font-weight:700; transition: color var(--transition); }
.footer-col a:hover { color: var(--accent); }

/* Social icons (icons only) */
/* Social icons (transparent images only - no background box) */
.socials {
  display: flex;
  gap: 12px;         
  margin-top: 8px;
  align-items: center;
}

.social-btn {
  display: inline-block;    
  width: 28px;               
  height: 28px;
  cursor: pointer;
  transition: transform 120ms ease, opacity 160ms ease;
  background: none !important;     
  border: none !important;        
  border-radius: 0;               
  padding: 0;
  line-height: 0;                 
}

.social-btn img {                   
  width: 100%;                       
  height: 100%;
  display: block;
  object-fit: contain;             
}

.social-btn:hover {
  transform: scale(1.15);           
  opacity: 0.9;                     
}

/* Default behavior: icons white on dark surfaces, change color on hover to green */
.social-btn { color: #fff; }
.social-btn:hover,
.social-btn:focus { color: var(--accent); transform: translateY(-3px); background: rgba(57,181,74,0.06); }

/* Specific override when social buttons appear on a white info card (like contact page) */
/* Make icons black by default on the contact info card, and turn green on hover */
.info-card .social-btn {
  background: rgba(2,6,23,0.06);
  color: #000000;               /* ICON COLOR SET TO BLACK FOR CONTACT INFO */
  border: 1px solid rgba(2,6,23,0.06);
}
.info-card .social-btn:hover,
.info-card .social-btn:focus {
  background: transparent;
  color: var(--accent);       /* turns green on hover */
  transform: translateY(-3px);
}

/* Contact form: make outline buttons visible on white panels */
.contact-card .btn-outline,
.contact-form .btn-outline {
  color: #06202a; /* dark text so it's visible on white background */
  background: transparent;
  border: 1px solid rgba(2,6,23,0.06);
  box-shadow: none;
  transition: color 160ms ease, background 160ms ease, transform 120ms ease;
}

.contact-card .btn-outline:hover,
.contact-form .btn-outline:hover,
.contact-card .btn-outline:focus,
.contact-form .btn-outline:focus {
  color: var(--accent); /* green on hover */
  background: rgba(57,181,74,0.06);
  transform: translateY(-2px);
  outline: none;
}

/* bottom footer */
.site-footer { border-top:1px solid rgba(255,255,255,0.03); padding:18px 0; background: linear-gradient(180deg, rgba(0,0,0,0.02), transparent); }
.footer-inner { display:flex; gap:12px; align-items:center; justify-content:center; color: rgba(255,255,255,0.6); font-size:0.95rem; }
.footer-inner .copyright { text-align:center; font-weight:700; }

/* =====================
   WhatsApp floating CTA
   ===================== */
.float-whatsapp {
  position: fixed;
  left: 16px;
  bottom: 16px;
  z-index: 180;
  width: 64px;
  height: 64px;
  display: inline-grid;
  place-items: center;
  border-radius: 14px;
  background: transparent;
  padding: 6px;
}

.float-whatsapp img {
  width: 52px;
  height: 52px;
  display: block;
  object-fit: contain;
}



//* ================================================
   BLOG SECTION - FULLY RESPONSIVE 2025/2026 VERSION
   Mobile-first + clean scaling
   ================================================ */

.blog-section {
  padding: 4rem 1rem 3rem;
  background: #000000;
  color: #ffffff;
}

.section-title {
  font-size: clamp(2.2rem, 6vw, 3.4rem);
  margin-bottom: 3rem;
  text-align: center;
  color: #00ff9d;
  text-shadow: 0 0 20px rgba(0, 255, 157, 0.6);
  letter-spacing: 1.5px;
}

/* Featured Post */
.featured-post {
  margin-bottom: 3.5rem;
}

.blog-card.featured {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.8rem;
  max-width: 1300px;
  margin: 0 auto 3.5rem;
  border-radius: 20px;
  background: linear-gradient(145deg, #0a0a0a, #121212);
  border: 1px solid rgba(0, 255, 157, 0.25);
  overflow: hidden;
  box-shadow: 0 15px 45px rgba(0, 0, 0, 0.75);
}

.blog-card.featured .blog-image {
  height: 260px;
}

.blog-card.featured .blog-content {
  padding: 2rem 1.8rem;
}

.blog-card.featured h3 {
  font-size: clamp(1.8rem, 5vw, 2.4rem);
}

/* Normal Blog Grid */
.blog-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}

.blog-card {
  background: linear-gradient(145deg, #0a0a0a, #121212);
  border: 1px solid rgba(0, 255, 157, 0.15);
  border-radius: 16px;
  overflow: hidden;
  transition: all 0.4s ease;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.7);
}

.blog-card:hover {
  transform: translateY(-12px);
  border-color: #00ff9d;
  box-shadow: 0 0 45px rgba(0, 255, 157, 0.35),
              inset 0 0 20px rgba(0, 255, 157, 0.15);
}

.blog-image {
  height: 220px;
  overflow: hidden;
  position: relative;
}

.blog-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.55s ease;
  filter: brightness(0.82) contrast(1.12);
}

.blog-card:hover .blog-image img {
  transform: scale(1.12);
  filter: brightness(1.1) contrast(1.2);
}

.blog-content {
  padding: 1.6rem 1.5rem 2rem;
}

.category {
  font-size: 0.82rem;
  padding: 0.4rem 1rem;
  margin-bottom: 1rem;
}

.blog-content h3 {
  font-size: clamp(1.28rem, 4vw, 1.55rem);
  margin-bottom: 0.9rem;
  line-height: 1.3;
}

.excerpt {
  font-size: 0.95rem;
  line-height: 1.6;
  margin-bottom: 1.3rem;
  color: #bbbbbb;
}

.meta {
  font-size: 0.84rem;
  gap: 1rem;
}

.read-more {
  font-size: 0.9rem;
}

/* Load More Button */
.load-more .btn {
  padding: 1rem 2.8rem;
  font-size: 1.05rem;
  min-width: 240px;
}

/* ──────────────────────────────────────────────
   RESPONSIVE BREAKPOINTS
─────────────────────────────────────────────── */

@media (min-width: 576px) {
  .blog-section {
    padding: 5rem 1.5rem 4rem;
  }
  
  .blog-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 2.2rem;
  }
  
  .blog-card.featured .blog-image {
    height: 320px;
  }
}

@media (min-width: 768px) {
  .blog-section {
    padding: 6rem 2rem 5rem;
  }
  
  .blog-grid {
    gap: 2.5rem;
  }
  
  .blog-card.featured {
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
  }
  
  .blog-card.featured .blog-image {
    height: 100%;
  }
  
  .blog-image {
    height: 240px;
  }
}

@media (min-width: 992px) {
  .blog-section {
    padding: 7rem 0 6rem;
  }
  
  .blog-grid {
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
    gap: 2.8rem;
  }
  
  .section-title {
    font-size: 3.4rem;
  }
  
  .blog-card.featured {
    margin-bottom: 5.5rem;
  }
  
  .blog-card.featured .blog-content {
    padding: 3.2rem 3rem;
  }
}

@media (min-width: 1200px) {
  .blog-grid {
    gap: 3rem;
  }
  
  .blog-image {
    height: 260px;
  }
}




/* Tooltip */
.float-whatsapp::after {
  content: "Need Help? Chat with us";
  position: absolute;
  left: calc(64px + 16px);
  bottom: 50%;
  transform: translateY(50%) scale(0.9);
  white-space: nowrap;

  background: linear-gradient(135deg, #25D366, #1ebe5d);
  color: #ffffff;
  padding: 10px 16px 10px 42px; /* left padding icon ke liye */
  border-radius: 12px;
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: 0.2px;
  box-shadow: 0 12px 35px rgba(37, 211, 102, 0.45);
  text-shadow: 0 1px 2px rgba(0,0,0,0.25);

  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
}

/* WhatsApp icon inside tooltip */
.float-whatsapp::before {
  content: "";
  position: absolute;
  left: calc(64px + 26px);
  bottom: 50%;
  transform: translateY(50%);

  width: 18px;
  height: 18px;
  background: url("assets/whatsapp.png") no-repeat center;
  background-size: contain;

  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
}

/* Show on hover */
.float-whatsapp:hover::after,
.float-whatsapp:hover::before {
  opacity: 1;
  visibility: visible;
  transform: translateY(50%) scale(1);
}

/* Mobile hide tooltip */
@media (max-width: 420px) {
  .float-whatsapp::after,
  .float-whatsapp::before {
    display: none;
  }
}


/* Focus outlines */
.btn:focus,
.nav-link:focus,
.footer-col a:focus,
.social-btn:focus,
.pkg-nav:focus,
.toggle-btn:focus,
.faq-question:focus {
  outline: 3px solid rgba(57,181,74,0.12);
  outline-offset: 3px;
}

/* Reduced motion preference */
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; }
}

/* ==========================================================================
   Final explicit override: force-center testimonials (ensures no other rules
   accidentally shift the active testimonial card)
   ========================================================================== */
.testimonials,
.testimonials.modern,
.testimonials .testimonials-slider,
.testimonials.modern .testimonials-slider,
.testimonials-slider {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

.testi-track,
.testimonials .testi-track,
.testimonials-track {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
}

.testimonial,
.testimonials .testimonial,
.testimonial.is-active,
.testimonials .testimonial.is-active {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 0 auto !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.testi-card,
.testimonial .testi-card,
.testimonials .testi-card {
  margin: 0 auto !important;
  max-width: 980px !important;
  width: 100% !important;
}



/* Make outline buttons visible inside the red warning box */
.warning-box .btn-outline {
  color: #7a0505; /* dark red so it's readable on the light warning background */
  background: transparent;
  border: 1px solid rgba(122,5,5,0.12);
  box-shadow: none;
}

.warning-box .btn-outline:hover,
.warning-box .btn-outline:focus {
  color: var(--accent); /* green on hover */
  background: rgba(57,181,74,0.06);
  transform: translateY(-2px);
}


/* Make outline buttons visible on white card backgrounds (pricing "Need a custom plan?" etc.) */
.card .btn-outline,
.card a.btn-outline,
.pkg-cta-center .btn-outline {
  color: #06202a; /* dark text for visibility */
  background: transparent;
  border: 1px solid rgba(2,6,23,0.08);
  box-shadow: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 10px;
  font-weight: 800;
}

.card .btn-outline:hover,
.card a.btn-outline:hover,
.pkg-cta-center .btn-outline:hover {
  color: var(--accent); /* green on hover */
  background: rgba(57,181,74,0.06);
  transform: translateY(-2px);
}



/* =====================
   Back to top (FINAL)
   ===================== */
.float-top {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 300;

  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--accent);   /* green */
  cursor: pointer;

  transition: background 140ms ease, transform 140ms ease;
}

.float-top:hover {
  background: var(--accent-600);
  transform: translateY(-2px);
}




/* ================================================
   FINAL COMPLETE RESPONSIVE FIXES + PERFECT MOBILE MENU (Latest 2025)
   Overlay Dropdown + Immediate Login/Signup + No Extra Gaps
   Paste this ENTIRE block at the VERY END of your styles.css
   ================================================ */

/* Global safety */
html, body {
  overflow-x: hidden !important;
}

/* ====================
   HEADER & LOGO
   ==================== */
.brand img {
  height: 40px;
  width: auto;
  max-width: 160px;
  display: block;
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  padding: 14px 0;
}

/* Desktop safe – keep original desktop behavior */
@media (min-width: 993px) {
  .brand img {
    height: 40px !important;
    max-width: 160px !important;
  }
  .header-inner {
    gap: 40px !important;
    padding: 14px 0 !important;
  }
  .hamburger-btn {
    display: none !important;
  }
  .nav {
    position: static !important;
    width: auto !important;
    height: auto !important;
    background: transparent !important;
    padding: 0 !important;
  }
  .nav-list {
    display: flex !important;
    flex-direction: row !important;
  }
}

/* ====================
   MOBILE MENU – MODERN OVERLAY + IMMEDIATE BUTTONS
   ==================== */
@media (max-width: 992px) {
  .brand img {
    height: 28px !important;
    max-width: 130px !important;
  }
  .brand {
    margin-left: 12px !important;
  }
  .header-inner {
    padding: 10px 0 !important;
    gap: 12px !important;
  }
  .hamburger-btn {
    display: block !important;
    padding: 8px;
  }

  /* Main mobile nav – full-screen overlay from right */
  .nav {
    position: fixed;
    inset: 0 0 0 auto;
    width: 100%;
    max-width: 360px;
    height: 100vh;
    background: rgba(11,11,11,0.96);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transform: translateX(100%);
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    z-index: 9999;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
  }

  .nav.show {
    transform: translateX(0);
  }

  /* Content fade-in when menu opens */
  .nav.show .nav-list,
  .nav.show .nav-actions {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.4s ease 0.15s, transform 0.4s ease 0.15s;
  }

  /* Main menu items list */
  .nav-list {
    flex-direction: column;
    width: 100%;
    gap: 6px;
    margin: 90px 0 40px 0;
    padding: 0 24px;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.35s ease, transform 0.35s ease;
  }

  .nav-list > li {
    width: 100%;
  }

  /* Menu links & Services toggle */
  .nav-link,
  .dropdown-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 16px 20px;
    font-size: 1.08rem;
    font-weight: 700;
    color: #ffffff;
    border-radius: 10px;
    background: rgba(255,255,255,0.04);
    transition: all 0.22s ease;
  }

  .nav-link:hover,
  .dropdown-toggle:hover,
  .nav-link:active,
  .dropdown-toggle:active {
    background: rgba(57,181,74,0.18);
    color: var(--accent);
  }

  /* Disable desktop underline in mobile */
  .nav-link::after,
  .dropdown-toggle::after {
    display: none !important;
  }

  /* Services Dropdown – OVERLAY (no layout shift) */
  .dropdown[data-dropdown] {
    position: relative;
  }

  .dropdown-menu {
    position: absolute !important;
    top: 100%;
    left: 0;
    width: 100%;
    margin-top: 8px;
    background: rgba(20,20,20,0.96);
    border: 1px solid rgba(57,181,74,0.15);
    border-radius: 10px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.65);
    padding: 12px 0;
    z-index: 10;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px) scale(0.98);
    transition: opacity 0.25s ease, visibility 0.25s ease, transform 0.25s ease;
    pointer-events: none;
  }

  .dropdown.open .dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
    pointer-events: auto;
  }

  .dropdown-grid {
    display: flex;
    flex-direction: column;
    gap: 4px;
  }

  .dropdown-item {
    padding: 14px 20px;
    font-size: 1rem;
    color: #ddd;
  }

  .dropdown-item:hover {
    background: rgba(57,181,74,0.12);
    color: var(--accent);
  }

  /* Login + Signup – appear immediately at bottom */
  .nav-actions {
    margin-top: auto;
    padding: 24px;
    display: flex !important;
    flex-direction: column;
    gap: 16px;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.4s ease 0.25s, transform 0.4s ease 0.25s;
  }

  .nav.show .nav-actions {
    opacity: 1;
    transform: translateY(0);
  }

  .nav-actions .btn-outline,
  .nav-actions .btn-primary {
    width: 100%;
    padding: 14px;
    font-size: 1.05rem;
    justify-content: center;
    border-radius: 10px;
  }
}

/* Very small phones */
@media (max-width: 576px) {
  .brand img {
    height: 26px !important;
    max-width: 120px !important;
  }
  .brand {
    margin-left: 10px !important;
  }
}

/* ====================
   HERO SLIDER (kept as is – buttons hidden on mobile)
   ==================== */
.slider-viewport {
  height: 320px;
  min-height: auto;
  padding: 22px;
  overflow: hidden;
}

.slide-inner {
  grid-template-columns: 420px 1fr;
  gap: 28px;
  align-items: center;
}

.slide-img {
  max-width: 420px;
  height: auto;
  object-fit: contain;
}

/* Desktop hero */
@media (min-width: 993px) {
  .slider-viewport {
    height: 320px !important;
    min-height: auto !important;
  }
  .slide-inner {
    grid-template-columns: 420px 1fr !important;
    text-align: left !important;
  }
  .slide-img {
    max-width: 420px !important;
  }
}

/* Mobile hero */
@media (max-width: 992px) {
  .hero-slider {
    margin-top: 4px !important;
    margin-bottom: 10px !important;
  }
  .slider-viewport {
    height: auto !important;
    min-height: 240px !important;
    padding: 10px 8px !important;
    border-radius: 10px !important;
    overflow: hidden !important;
  }
  .slide {
    padding: 0 !important;
  }
  .slide-inner {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    text-align: center !important;
    align-items: center !important;
  }
  .slide-visual {
    width: 100% !important;
    max-height: 100px !important;
    overflow: hidden !important;
  }
  .slide-img {
    width: 100% !important;
    max-height: 100px !important;
    height: auto !important;
    object-fit: contain !important;
    object-position: center !important;
    margin: 0 auto !important;
    border-radius: 8px !important;
  }
  .slide-copy {
    padding: 0 6px !important;
  }
  .slide-title {
    font-size: 1.35rem !important;
    margin: 0 0 4px !important;
    line-height: 1.1 !important;
  }
  .slide-lead {
    font-size: 0.82rem !important;
    margin: 0 0 10px !important;
    line-height: 1.3 !important;
  }
  .slide-cta-row,
  .slide-cta-row .btn {
    display: none !important;
  }
}

/* Very small phones – hero */
@media (max-width: 576px) {
  .slider-viewport {
    min-height: 220px !important;
    padding: 8px 6px !important;
  }
  .slide-visual {
    max-height: 90px !important;
  }
  .slide-img {
    max-height: 90px !important;
  }
  .slide-title {
    font-size: 1.25rem !important;
  }
  .slide-lead {
    font-size: 0.8rem !important;
  }
}

/* Other sections – single column on mobile */
@media (max-width: 992px) {
  .grid-3,
  .advantages-grid,
  .stats-grid,
  .how-grid,
  .footer-grid {
    grid-template-columns: 1fr !important;
  }
  .package-card {
    width: 100% !important;
  }
  .pkg-nav {
    display: none !important;
  }
}

/* Image safety */
img,
.slide-img {
  height: auto !important;
  max-width: 100% !important;
  object-fit: contain !important;
}



/* About section */

@media only screen and (max-width: 768px) {

    /* About ke main containers ko force karo */
    .about-section,
    .about-container,
    .about-wrapper,
    .about-content,
    .about-text,
    .about-description,
    section[id="about"],
    .about-area {                     /* apne section ka class/id jo bhi hai yahan likh do */
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding-left: 15px !important;
        padding-right: 15px !important;
        overflow-x: hidden !important;
        overflow: hidden !important;
    }

    /* Text ko break karo taake bahar na nikle */
    p, li, span, div, h1, h2, h3, h4, .about-content * {
        word-break: break-word !important;    /* bohot lambi line ko tod dega */
        overflow-wrap: break-word !important;
        hyphens: auto;
        white-space: normal !important;
    }

    /* Agar koi image ya div bahar ja raha */
    img, .about-img, .profile-photo {
        max-width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
}



/* ==================== BLOG GRID - FORCE DESKTOP BEHAVIOR ==================== */
@media (min-width: 993px) {
  .blog-grid {
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr)) !important;
    gap: 2.8rem !important;
  }

  .blog-card.featured {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* Extra safety - agar kahin aur se override ho raha ho */
.blog-section .blog-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(380px, 1fr)) !important;
}

@media (max-width: 992px) {
  .blog-section .blog-grid {
    grid-template-columns: 1fr !important; /* mobile pe single column */
  }
}


