@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.2/css/all.min.css');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --purple-900:#241154;
  --purple-800:#341c7a;
  --purple-700:#4b2fb0;
  --purple-600:#5e3fd1;
  --purple-500:#7a5cf0;
  --purple-400:#9b82f5;
  --purple-100:#efe9ff;
  --accent:#2fe6c9;
  --gold:#ffb703;
  --dark:#1b1330;
  --gray:#68657a;
  --light-bg:#f7f5fc;
  --white:#ffffff;
  --radius:14px;
  --shadow:0 15px 40px rgba(75,47,176,.15);
  --transition:.3s ease;
}
html{scroll-behavior:smooth;}
body{
  font-family:'Poppins',sans-serif;
  color:var(--dark);
  line-height:1.7;
  background:var(--white);
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
h1,h2,h3,h4{font-weight:700;line-height:1.25;}
.container{width:100%;max-width:1180px;margin:0 auto;padding:0 20px;}
.accent{color:var(--accent);}
.gold{color:var(--gold);}
section.page.active{display:block;animation:fadeIn .5s ease;}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 30px;border-radius:50px;font-weight:600;font-size:.95rem;
  cursor:pointer;border:2px solid transparent;transition:var(--transition);
  white-space:nowrap;
}
.btn-solid{background:var(--white);color:var(--purple-700);}
.btn-solid:hover{background:var(--accent);color:var(--white);transform:translateY(-3px);}
.btn-outline{border-color:rgba(255,255,255,.7);color:var(--white);}
.btn-outline:hover{background:var(--white);color:var(--purple-700);transform:translateY(-3px);}
.btn-purple{background:var(--purple-700);color:var(--white);}
.btn-purple:hover{background:var(--purple-900);transform:translateY(-3px);}
.btn-small{padding:9px 20px;font-size:.8rem;}

/* Section helpers */
.overline{
  display:inline-block;color:var(--purple-600);font-weight:700;letter-spacing:2px;
  text-transform:uppercase;font-size:.8rem;margin-bottom:12px;
}
.section-title{font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:16px;}
.section-sub{color:var(--gray);max-width:640px;margin:0 auto 40px;font-size:.98rem;}
.center{text-align:center;}
.divider{width:70px;height:4px;background:var(--accent);border-radius:4px;margin:0 auto 30px;}
.section-pad{padding:90px 0;}
.bg-light{background:var(--light-bg);}

/* ============================================================
   1. HEADER / NAVIGATION
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  background:rgba(36,17,84,.35);
  backdrop-filter:blur(6px);
  transition:var(--transition);
}
.site-header.scrolled{background:var(--purple-900);box-shadow:0 8px 25px rgba(0,0,0,.2);}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 20px;
}
.logo{font-size:1.4rem;font-weight:800;color:var(--white);letter-spacing:1px;}
.logo span{color:var(--accent);}
.main-nav ul{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.main-nav > ul > li{position:relative;}
.main-nav a.nav-link{
  display:flex;align-items:center;gap:5px;color:var(--white);
  font-size:.85rem;font-weight:500;padding:10px 12px;border-radius:6px;
  transition:var(--transition);
}
.main-nav > ul > li > a.nav-link:hover,
.main-nav > ul > li.current > a.nav-link{color:var(--accent);}
.main-nav .dropdown{
  display: flex;
  flex-direction: column;
  position:absolute;top:100%;left:0;background:var(--white);
  min-width:200px;border-radius:10px;box-shadow:var(--shadow);
  padding:8px;opacity:0;visibility:hidden;transform:translateY(10px);
  transition:var(--transition);
}
.has-dropdown:hover .dropdown,
.has-dropdown.open .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.main-nav .dropdown a{
  display:block;padding:10px 14px;border-radius:6px;color:var(--dark);font-size:.85rem;font-weight:500;
}
.main-nav .dropdown a:hover{background:var(--purple-100);color:var(--purple-700);}
.hamburger{
  display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;z-index:1100;
}
.hamburger span{width:26px;height:3px;background:var(--white);border-radius:3px;transition:var(--transition);}
.hamburger.active span:nth-child(1){transform:translateY(8px) rotate(45deg);}
.hamburger.active span:nth-child(2){opacity:0;}
.hamburger.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}

@media(max-width:992px){
  .hamburger{display:flex;}
  .main-nav{
    position:fixed;top:0;right:-100%;width:290px;height:100vh;background:var(--purple-900);
    padding:90px 25px 30px;transition:right .35s ease;overflow-y:auto;
  }
  .main-nav.open{right:0;}
  .main-nav ul{flex-direction:column;align-items:flex-start;gap:0;width:100%;}
  .main-nav > ul > li{width:100%;}
  .main-nav a.nav-link{width:100%;padding:12px 6px;border-bottom:1px solid rgba(255,255,255,.08);justify-content:space-between;}
  .main-nav .dropdown{
    position:static;opacity:1;visibility:visible;transform:none;background:rgba(255,255,255,.06);
    display:none;box-shadow:none;margin-top:4px;
  }
  .has-dropdown.open .dropdown{display:block;}
  .main-nav .dropdown a{color:var(--white);}
  .main-nav .dropdown a:hover{background:rgba(255,255,255,.1);color:var(--accent);}
}

/* ============================================================
   2. HOME PAGE
   ============================================================ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  background:linear-gradient(135deg,var(--purple-800),var(--purple-600));
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.08) 1.5px,transparent 1.5px);
  background-size:22px 22px;opacity:.5;
}
.hero-slide{display:none;position:relative;z-index:2;padding:140px 0 100px;}
.hero-slide.active{display:block;animation:fadeIn .7s ease;}
.hero-slide h1{
  color:var(--white);font-size:clamp(2rem,5vw,3.4rem);max-width:800px;margin-bottom:22px;
}
.hero-slide p{color:rgba(255,255,255,.85);max-width:560px;margin-bottom:34px;font-size:1.02rem;}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap;}
.hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:48px;height:48px;border-radius:50%;border:2px solid rgba(255,255,255,.6);
  background:rgba(255,255,255,.08);color:var(--white);display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:var(--transition);
}
.hero-arrow:hover{background:var(--accent);border-color:var(--accent);color:var(--purple-900);}
.hero-arrow.prev{left:24px;}
.hero-arrow.next{right:24px;}
.hero-dots{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:10px;}
.hero-dots span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:var(--transition);}
.hero-dots span.active{background:var(--accent);width:26px;border-radius:6px;}

.who-we-are{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.who-img{
  aspect-ratio:1/.85;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--purple-600),var(--purple-400));
  display:flex;align-items:center;justify-content:center;position:relative;box-shadow:var(--shadow);
}
.who-img i{font-size:5rem;color:rgba(255,255,255,.85);}
.who-img .badge{
  position:absolute;bottom:-22px;right:-22px;background:var(--white);border-radius:16px;
  padding:18px 22px;box-shadow:var(--shadow);text-align:center;
}
.who-img .badge strong{display:block;font-size:1.6rem;color:var(--purple-700);}
.who-img .badge span{font-size:.75rem;color:var(--gray);}
.who-text ul{margin-top:20px;display:flex;flex-direction:column;gap:12px;}
.who-text ul li{display:flex;gap:10px;align-items:flex-start;font-size:.93rem;color:var(--gray);}
.who-text ul li i{color:var(--accent);margin-top:4px;}

.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.service-card{
  background:var(--white);border-radius:var(--radius);padding:40px 28px;text-align:center;
  box-shadow:var(--shadow);transition:var(--transition);border:1px solid #f0edfa;cursor:pointer;
}
.service-card:hover{transform:translateY(-10px);border-color:var(--purple-500);}
.service-card .icon-circle{
  width:70px;height:70px;border-radius:50%;background:var(--purple-100);color:var(--purple-700);
  display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin:0 auto 20px;transition:var(--transition);
}
.service-card:hover .icon-circle{background:var(--purple-700);color:var(--white);}
.service-card h3{margin-bottom:10px;font-size:1.1rem;}
.service-card p{color:var(--gray);font-size:.9rem;}

.stats-bar{
  background:linear-gradient(135deg,var(--purple-900),var(--purple-700));
  padding:60px 0;
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center;}
.stats-grid h3{color:var(--accent);font-size:2.6rem;}
.stats-grid span{color:rgba(255,255,255,.8);font-size:.85rem;letter-spacing:.5px;text-transform:uppercase;}

.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.testi-card{background:var(--white);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);border:1px solid #f0edfa;}
.testi-card .stars{color:var(--gold);margin-bottom:14px;font-size:.85rem;}
.testi-card p{color:var(--gray);font-size:.9rem;margin-bottom:18px;}
.testi-user{display:flex;align-items:center;gap:12px;}
.testi-user .avatar{
  width:44px;height:44px;border-radius:50%;background:var(--purple-100);color:var(--purple-700);
  display:flex;align-items:center;justify-content:center;font-weight:700;
}
.testi-user strong{display:block;font-size:.9rem;}
.testi-user small{color:var(--gray);}

.cta-banner{
  background:linear-gradient(135deg,var(--purple-700),var(--purple-500));
  border-radius:var(--radius);padding:60px 40px;text-align:center;color:var(--white);
  margin:0 20px;
}
.cta-banner h2{margin-bottom:14px;}
.cta-banner p{color:rgba(255,255,255,.85);max-width:560px;margin:0 auto 26px;}

/* ============================================================
   3. INNER PAGE HERO (shared across all inner pages)
   ============================================================ */
.page-hero{
  background:linear-gradient(135deg,var(--purple-800),var(--purple-600));
  padding:160px 0 70px;position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.08) 1.5px,transparent 1.5px);
  background-size:22px 22px;opacity:.5;
}
.page-hero .container{position:relative;z-index:2;}
.page-hero h1{color:var(--white);font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:12px;}
.page-hero .breadcrumb{color:rgba(255,255,255,.75);font-size:.85rem;}
.page-hero .breadcrumb a{color:var(--accent);}
.page-hero .breadcrumb span{margin:0 8px;}

/* ============================================================
   4. GENERIC CONTENT COMPONENTS
   ============================================================ */
.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;}
.info-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.info-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.info-card{
  background:var(--white);border:1px solid #ece7fb;border-radius:var(--radius);padding:28px;
  box-shadow:var(--shadow);transition:var(--transition);
}
.info-card:hover{transform:translateY(-6px);}
.info-card i{font-size:1.5rem;color:var(--purple-600);margin-bottom:14px;}
.info-card h3,.info-card h4{margin-bottom:8px;}
.info-card p{color:var(--gray);font-size:.9rem;}

.checklist li{
  display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;font-size:.94rem;color:var(--gray);
}
.checklist li i{color:var(--accent);margin-top:4px;flex-shrink:0;}
.checklist.cross li i{color:#ff5470;}

.timeline{position:relative;padding-left:36px;border-left:3px solid var(--purple-100);}
.timeline-item{position:relative;padding-bottom:34px;}
.timeline-item::before{
  content:attr(data-step);position:absolute;left:-49px;top:0;width:32px;height:32px;border-radius:50%;
  background:var(--purple-700);color:var(--white);display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:700;
}
.timeline-item h4{margin-bottom:6px;}
.timeline-item p{color:var(--gray);font-size:.9rem;}

table.data-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}
table.data-table th{background:var(--purple-700);color:var(--white);text-align:left;padding:14px 18px;font-size:.82rem;text-transform:uppercase;letter-spacing:.5px;}
table.data-table td{padding:14px 18px;border-bottom:1px solid #f0edfa;font-size:.9rem;color:var(--dark);}
table.data-table tr:last-child td{border-bottom:none;}
.table-wrap{overflow-x:auto;}

.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px;}
.filter-btn{
  padding:9px 20px;border-radius:50px;border:2px solid var(--purple-200,#ded3fb);background:var(--white);
  color:var(--purple-700);font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition);
}
.filter-btn.active,.filter-btn:hover{background:var(--purple-700);border-color:var(--purple-700);color:var(--white);}
.rank-badge{
  display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;
  background:var(--purple-100);color:var(--purple-700);font-weight:700;font-size:.78rem;margin-right:8px;
}
.stars-inline{color:var(--gold);font-size:.82rem;}
.tag{display:inline-block;padding:4px 10px;border-radius:6px;font-size:.72rem;font-weight:600;background:var(--purple-100);color:var(--purple-700);}

.faq-item{border-bottom:1px solid #eee6ff;}
.faq-question{
  width:100%;display:flex;justify-content:space-between;align-items:center;padding:20px 4px;
  background:none;border:none;text-align:left;font-size:1rem;font-weight:600;cursor:pointer;color:var(--dark);
}
.faq-question i{transition:var(--transition);color:var(--purple-600);}
.faq-item.active .faq-question i{transform:rotate(45deg);}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.faq-answer p{padding:0 4px 20px;color:var(--gray);font-size:.9rem;}

.callout{
  border-radius:var(--radius);padding:28px;display:flex;gap:18px;align-items:flex-start;
  background:#fff4e5;border:1px solid #ffdca8;
}
.callout.danger{background:#ffe9ec;border-color:#ffb9c4;}
.callout i{font-size:1.6rem;color:var(--gold);}
.callout.danger i{color:#ff5470;}
.callout h4{margin-bottom:6px;}
.callout p{color:var(--gray);font-size:.9rem;}

.legal p{margin-bottom:16px;color:var(--gray);font-size:.93rem;}
.legal h3{margin:30px 0 12px;color:var(--purple-800);}

.tier-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.tier-card{
  border-radius:var(--radius);padding:30px 22px;text-align:center;background:var(--white);
  border:2px solid #ece7fb;box-shadow:var(--shadow);transition:var(--transition);position:relative;
}
.tier-card.featured{border-color:var(--purple-600);transform:scale(1.04);}
.tier-card .tier-icon{font-size:2rem;margin-bottom:14px;}
.tier-card h3{margin-bottom:6px;}
.tier-card .points{color:var(--purple-700);font-weight:700;margin-bottom:16px;}
.tier-card ul{text-align:left;display:flex;flex-direction:column;gap:8px;}
.tier-card ul li{font-size:.85rem;color:var(--gray);display:flex;gap:8px;}
.tier-card ul li i{color:var(--accent);}

.calculator{
  background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:34px;
  display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;
}
.calculator input{
  width:100%;padding:14px 16px;border-radius:10px;border:2px solid #ece7fb;font-size:1rem;font-family:inherit;
  margin-bottom:16px;
}
.calc-result{background:var(--purple-100);border-radius:12px;padding:22px;text-align:center;}
.calc-result h3{color:var(--purple-700);font-size:1.8rem;}

.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;}
.contact-info-card{
  display:flex;gap:16px;align-items:flex-start;background:var(--white);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow);margin-bottom:18px;border:1px solid #ece7fb;
}
.contact-info-card i{font-size:1.3rem;color:var(--purple-700);background:var(--purple-100);width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.contact-info-card h4{margin-bottom:4px;}
.contact-info-card p{color:var(--gray);font-size:.88rem;}
.contact-form{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:36px;border:1px solid #ece7fb;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{margin-bottom:18px;}
.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:8px;}
.form-group input,.form-group textarea{
  width:100%;padding:13px 16px;border-radius:10px;border:2px solid #ece7fb;font-family:inherit;font-size:.92rem;
  transition:var(--transition);
}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--purple-500);}
.form-msg{display:none;padding:14px 16px;border-radius:10px;margin-bottom:18px;font-size:.88rem;}
.form-msg.show{display:block;}
.form-msg.success{background:#e6faf5;color:#0d8a6e;border:1px solid #b7ecdb;}
.map-box{
  margin-top:26px;height:220px;border-radius:var(--radius);background:linear-gradient(135deg,var(--purple-100),#fff);
  display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--purple-600);
  border:2px dashed var(--purple-400);gap:8px;
}
.social-row{display:flex;gap:12px;margin-top:20px;}
.social-row a{
  width:42px;height:42px;border-radius:50%;background:var(--purple-100);color:var(--purple-700);
  display:flex;align-items:center;justify-content:center;transition:var(--transition);
}
.social-row a:hover{background:var(--purple-700);color:var(--white);}

/* ============================================================
   5. FOOTER
   ============================================================ */
.site-footer{background:var(--dark);color:rgba(255,255,255,.7);padding:70px 0 20px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:40px;margin-bottom:40px;}
.footer-grid h4{color:var(--white);margin-bottom:18px;font-size:1rem;}
.footer-grid p{font-size:.88rem;line-height:1.8;}
.footer-links li{margin-bottom:10px;}
.footer-links a{font-size:.88rem;transition:var(--transition);}
.footer-links a:hover{color:var(--accent);}
.newsletter-form{display:flex;margin-top:14px;}
.newsletter-form input{flex:1;padding:12px 14px;border:none;border-radius:8px 0 0 8px;font-family:inherit;}
.newsletter-form button{padding:12px 16px;background:var(--purple-600);color:var(--white);border:none;border-radius:0 8px 8px 0;cursor:pointer;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;text-align:center;font-size:.8rem;}

/* Back to top */
.back-to-top{
  position:fixed;bottom:26px;right:26px;width:48px;height:48px;border-radius:50%;
  background:var(--purple-700);color:var(--white);display:flex;align-items:center;justify-content:center;
  cursor:pointer;opacity:0;visibility:hidden;transition:var(--transition);z-index:999;box-shadow:var(--shadow);
}
.back-to-top.show{opacity:1;visibility:visible;}
.back-to-top:hover{background:var(--purple-900);}

/* ============================================================
   6. RESPONSIVE
   ============================================================ */
@media(max-width:992px){
  .who-we-are{grid-template-columns:1fr;}
  .service-grid,.stats-grid,.testi-grid,.info-grid-3,.info-grid-4{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .tier-grid{grid-template-columns:repeat(2,1fr);}
  .contact-grid{grid-template-columns:1fr;}
  .calculator{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .section-pad{padding:60px 0;}
  .service-grid,.stats-grid,.testi-grid,.info-grid,.info-grid-3,.info-grid-4,.tier-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .hero-arrow{width:38px;height:38px;}
  .cta-banner{margin:0 12px;padding:40px 20px;}
}
