/* ---------------------
       THEME VARIABLES
       --------------------- */
    :root{
      --bg: #f6f7fb;
      --section-bg: #ffffff;
      --muted: #6b7280;
      --text: #07203a;
      --accent: #6c5ce7;        /* purple */
      --accent-2: #00c37a;      /* bright green */
      --glass: rgba(255,255,255,0.7);
      --glass-2: rgba(255,255,255,0.12);
      --card-radius: 14px;
      --shadow: 0 10px 30px rgba(16,24,40,0.06);
      --nav-blur: 10px;
      --maxw: 1200px;
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
    }

    [data-theme="dark"]{
      --bg: #071025;
      --section-bg: rgba(255,255,255,0.02);
      --muted: #9aa9bf;
      --text: #e6f7ff;
      --accent: #9b84ff;
      --accent-2: #38d39f;
      --glass: rgba(255,255,255,0.04);
      --glass-2: rgba(255,255,255,0.02);
      --shadow: 0 10px 30px rgba(0,0,0,0.6);
    }

    /* ---------------------
       GLOBAL LAYOUT
       --------------------- */
    *{box-sizing:border-box}
    html,body{height:100%}
    body{
      margin:0;
      background:#fff;
      color:var(--text);
      -webkit-font-smoothing:antialiased;
      -moz-osx-font-smoothing:grayscale;
      padding-top:78px; /* space for fixed navbar */
      transition: background .35s ease, color .35s ease;
    }
    .container-max{max-width:var(--maxw); margin:0 auto; padding:0 20px;}


html, body {
  overflow-x: hidden; /* hides horizontal scroll */
}



a{
  text-decoration: none;
}



h3,h4{
  font-size: 16px;
}




    /* ---------------------
       NAVBAR
       --------------------- */
    .site-nav{
      position:fixed;
      top:0; left:0; right:0;
      z-index:999;
      display:flex;
      align-items:center;
      height:76px;
      backdrop-filter: blur(var(--nav-blur));
      transition: background .25s ease, box-shadow .25s ease, transform .2s ease;
      padding:0 18px;
    }
    .site-nav.scrolled{ box-shadow: var(--shadow); transform: translateY(0); }
    .nav-inner{ width:100%; max-width:var(--maxw); margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:12px; }
    .brand { display:flex; align-items:center; gap:10px; text-decoration:none; font-weight:800; font-size:1.05rem; color:var(--text); }
    .brand .logo-wrap{ width:44px; height:44px; display:inline-grid; place-items:center; border-radius:10px; background:linear-gradient(135deg,var(--accent), #b695ff); color:white; box-shadow:0 6px 18px rgba(108,92,231,0.18); }
    .nav-links{ display:flex; gap:12px; align-items:center;}
    .nav-links a{ color:var(--muted); font-weight:600; text-decoration:none; padding:8px 10px; border-radius:10px; transition: color .18s, background .18s; }
    .nav-links a:hover{ color:var(--accent); background:transparent; }
    .cta-group{ display:flex; gap:8px; align-items:center; }
    .btn-ghost{ background:transparent; border:1px solid rgba(0,0,0,0.06); color:var(--muted); padding:8px 12px; border-radius:10px; }
    .btn-primary{
      background:linear-gradient(90deg,var(--accent), #a78bfa);
      color:white;
      border:0;
      padding:10px 14px;
      border-radius:12px;
      font-weight:700;
      box-shadow:0 8px 30px rgba(108,92,231,0.12);
    }
    .theme-toggle{ background:transparent; border:0; color:var(--muted); font-size:1.2rem; display:inline-flex; align-items:center; gap:8px; padding:6px; border-radius:8px; }

    /* ---------------------
       HERO
       --------------------- */
    .hero{
      position:relative;
      padding:80px 0 40px;
      overflow:visible;
    }
    .hero-inner{ display:flex; gap:32px; align-items:center; justify-content:space-between; flex-wrap:wrap; }
    .hero-left{ flex:1 1 460px; min-width:280px; }
    .hero-right{ flex:1 1 420px; min-width:260px; display:flex; justify-content:center; align-items:center; }
    .kicker{ display:inline-block; background:linear-gradient(90deg,var(--accent-2), #6c5ce7); color:white; padding:6px 10px; border-radius:999px; font-weight:700; font-size:13px; margin-bottom:14px; }
    .hero h1{ font-size:2.55rem; line-height:1.02; margin:0 0 12px; letter-spacing:-0.6px; }
    .hero p.lead{ color:var(--muted); font-size:1.05rem; margin-bottom:18px; max-width:56ch; }
    .hero-ctas{ display:flex; gap:12px; flex-wrap:wrap; margin-top:10px; }
    .hero-features{ display:flex; gap:12px; margin-top:22px; flex-wrap:wrap; }
    .feature-pill{ background:var(--glass); padding:10px 12px; border-radius:999px; color:var(--muted); font-weight:700; box-shadow:var(--shadow); }



/* HERO */
.hero {
  position: relative;
  padding: 80px 0 40px;
  overflow: hidden; /* so background stays in bounds */
  background: radial-gradient(circle at 20% 20%, rgba(108, 92, 231, 0.05), transparent 60%),
              radial-gradient(circle at 80% 80%, rgba(0, 195, 122, 0.05), transparent 60%);
}

/* Animated dotted pattern */
.hero::before {
  content: "";
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background-image: radial-gradient(rgba(108, 92, 231, 0.15) 1px, transparent 1px);
  background-size: 24px 24px;
  animation: moveDots 18s linear infinite;
  z-index: 0;
}

@keyframes moveDots {
  from { transform: translate(0, 0); }
  to { transform: translate(24px, 24px); }
}



/* Floating shape animation */







/* Base style for all floating shapes */
.float-shape {
  position: absolute;
  z-index: 1;
  opacity: 0.6; /* slight transparency */
  pointer-events: none; /* shapes don't block clicks */
}

/* Different movement patterns */
.float-shape.one {
  animation: floatAround1 18s ease-in-out infinite;
}

.float-shape.two {
  animation: floatAround2 22s ease-in-out infinite;
}

.float-shape.three {
  animation: floatAround3 20s ease-in-out infinite;
}

/* Keyframes for varied drift */
@keyframes floatAround1 {
  0%   { transform: translate(0px, 0px) rotate(0deg); }
  25%  { transform: translate(20px, -15px) rotate(5deg); }
  50%  { transform: translate(35px, 10px) rotate(10deg); }
  75%  { transform: translate(15px, 25px) rotate(6deg); }
  100% { transform: translate(0px, 0px) rotate(0deg); }
}

@keyframes floatAround2 {
  0%   { transform: translate(0px, 0px) rotate(0deg); }
  25%  { transform: translate(-15px, 20px) rotate(-4deg); }
  50%  { transform: translate(-30px, -10px) rotate(-8deg); }
  75%  { transform: translate(-10px, 15px) rotate(-3deg); }
  100% { transform: translate(0px, 0px) rotate(0deg); }
}

@keyframes floatAround3 {
  0%   { transform: translate(0px, 0px) rotate(0deg); }
  25%  { transform: translate(10px, 25px) rotate(6deg); }
  50%  { transform: translate(-20px, 20px) rotate(-6deg); }
  75%  { transform: translate(15px, -20px) rotate(5deg); }
  100% { transform: translate(0px, 0px) rotate(0deg); }
}















.hero-inner {
  position: relative;
  z-index: 2;
  display: flex;
  gap: 32px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

/* Fade-up animation for hero content */
.hero-left, .hero-right{
  animation: fadeUp 1s ease forwards;
  opacity: 0;
}
.hero-left { animation-delay: 0.2s; }
.hero-right { animation-delay: 0.4s; }

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}















    /* floating shapes */
   
    /* Illustration card */
    .ill-card{
      width:100%;
      max-width:520px;
      border-radius:20px;
      padding:18px;
      background:linear-gradient(180deg, rgba(255,255,255,0.9), rgba(255,255,255,0.7));
      box-shadow:var(--shadow);
      display:flex; flex-direction:column; gap:12px;
    }
    [data-theme="dark"] .ill-card{
      background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
      border:1px solid rgba(255,255,255,0.03);
    }

    /* ---------------------
       SERVICES
       --------------------- */
    section{ padding:64px 0; }
    .section-head{ text-align:center; margin-bottom:36px; }
    .services-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:18px; }

    .service-card{
      border-radius:14px; padding:18px; background:var(--section-bg); box-shadow:var(--shadow);
      
      display:flex; gap:12px; align-items:flex-start;
    }
    .service-card:hover{ transform: translateY(-8px); box-shadow: 0 18px 40px rgba(2,6,23,0.12); }
    .service-icon{ width:54px; height:54px; border-radius:12px; display:grid; place-items:center; color:white; font-size:1.35rem; flex:0 0 54px; }
    .service-title{ font-weight:800; margin:0;  font-size: 14px;}
    .service-desc{ color:var(--muted); margin:0; font-size:12px; }




    /* ---------------------
       PRICING
       --------------------- */
    .pricing-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px; }
    .plan{ padding:20px; border-radius:14px; background:var(--section-bg); box-shadow:var(--shadow); text-align:center; }
    .plan .price{ font-size:1.75rem; font-weight:800; color:var(--accent); }

    /* ---------------------
       HOW IT WORKS
       --------------------- */
    .steps{ display:flex; gap:18px; flex-wrap:wrap; justify-content:center; }
    .step{ width:220px; padding:18px; background:var(--glass); border-radius:14px; text-align:center; }

    /* ---------------------
       TESTIMONIALS
       --------------------- */
    .testi-wrap{ display:flex; gap:14px; overflow:hidden; align-items:center; justify-content:center; }
    .testi{ min-width:280px; padding:18px; border-radius:12px; background:var(--section-bg); box-shadow:var(--shadow); }

    /* ---------------------
       FOOTER
       --------------------- */
    footer.site-footer{ padding:36px 0; border-top:1px solid rgba(0,0,0,0.04); color:var(--muted); background:transparent; }

    /* ---------------------
       RESPONSIVE
       --------------------- */
    @media (max-width:992px){
      .hero h1{ font-size:2rem; }
      .brand { font-size:1rem; }
      .hero-right{ margin-top:18px; }
    }
    @media (max-width:540px){
      .nav-links{ display:none; }
      .cta-group{ gap:6px; }
      .hero h1{ font-size:1.6rem; }
      .hero p.lead{ font-size:0.98rem; }
      .ill-card{ max-width:100%; padding:14px; border-radius:12px; }
    }

    /* small utilities */
    .muted { color:var(--muted); }
    .text-accent { color:var(--accent); }
    .text-accent-2 { color:var(--accent-2); }