:root {
  --teal: #0ab5b0;
  --teal-dk: #088a86;
  --teal-lt: #e8f9f8;
  --purple: #7c5abf;
  --purple-lt: #f0eaff;
  --dark: #1a1a2e;
  --gray: #5a6678;
  --light: #f7fbfb;
  --border: #dde9e9;
  --white: #fff;
  --r: 8px;
  --sh: 0 2px 16px rgba(0,0,0,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',Arial,sans-serif;color:var(--dark);background:var(--white);line-height:1.65}
img{max-width:100%;display:block}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--teal-dk)}
h1{font-size:clamp(1.9rem,4vw,3.1rem);font-weight:800;line-height:1.15}
h2{font-size:clamp(1.4rem,3vw,2.1rem);font-weight:700;line-height:1.25}
h3{font-size:1.05rem;font-weight:600}
p{color:var(--gray);line-height:1.7}
.container{max-width:1080px;margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.section-alt{background:var(--light)}

/* ── Nav ── */
.topnav{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:box-shadow .2s}
.topnav.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{display:flex;align-items:center;gap:0}
.nav-logo img{height:52px;width:auto}
.nav-links{display:flex;align-items:center;gap:8px;list-style:none}
.nav-links a{font-size:14px;font-weight:500;color:var(--dark);padding:8px 14px;border-radius:6px;transition:all .15s}
.nav-links a:hover{color:var(--teal);background:var(--teal-lt)}
.nav-links a.active{color:var(--teal)}
.nav-cta{background:var(--teal) !important;color:var(--white) !important;font-weight:600 !important}
.nav-cta:hover{background:var(--teal-dk) !important}
.nav-portal{border:1.5px solid var(--teal);color:var(--teal) !important}
.nav-portal:hover{background:var(--teal-lt) !important}
.nav-portal-btn{border:2px solid #0ab5b0;color:#0ab5b0 !important;padding:8px 18px;border-radius:6px;font-weight:600;text-decoration:none;transition:background .2s,color .2s}
.nav-portal-btn:hover{background:#0ab5b0 !important;color:#fff !important}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:4px;flex-direction:column;gap:5px}
.hamburger span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:.3s}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 30px;border-radius:var(--r);font-weight:600;font-size:15px;cursor:pointer;border:none;transition:all .15s;line-height:1}
.btn-primary{background:var(--teal);color:var(--white)}
.btn-primary:hover{background:var(--teal-dk);color:var(--white)}
.btn-outline{background:transparent;color:var(--teal);border:2px solid var(--teal)}
.btn-outline:hover{background:var(--teal);color:var(--white)}
.btn-white{background:var(--white);color:var(--teal)}
.btn-white:hover{background:rgba(255,255,255,.9)}
.btn-ghost{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.5)}
.btn-ghost:hover{border-color:var(--white);background:rgba(255,255,255,.1)}
.btn-purple{background:var(--purple);color:var(--white)}
.btn-purple:hover{background:#6446a8;color:var(--white)}

/* ── Hero ── */
.hero{background:linear-gradient(135deg,#0ab5b0 0%,#7c5abf 100%);color:var(--white);padding:100px 0 90px;overflow:hidden;position:relative}
.hero::before{content:'';position:absolute;top:-40%;right:-10%;width:600px;height:600px;border-radius:50%;background:rgba(255,255,255,.05)}
.hero::after{content:'';position:absolute;bottom:-30%;left:-5%;width:400px;height:400px;border-radius:50%;background:rgba(255,255,255,.04)}
.hero-inner{position:relative;z-index:1;max-width:660px}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);color:var(--white);font-size:13px;font-weight:600;padding:6px 16px;border-radius:20px;margin-bottom:20px;letter-spacing:.3px}
.hero h1{margin-bottom:18px}
.hero p{color:rgba(255,255,255,.88);font-size:17px;margin-bottom:36px;max-width:520px}
.hero .btn-group{display:flex;gap:14px;flex-wrap:wrap}
.hero-portal-link{margin-top:12px;font-size:0.9rem;opacity:0.85;color:rgba(255,255,255,.85)}
.hero-portal-link a{color:inherit;text-decoration:underline}
.hero-portal-link a:hover{opacity:1}
.hero-badge{display:flex;flex-wrap:wrap;gap:20px;margin-top:52px}
.hero-badge-item{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.8);font-size:13px;font-weight:500}
.hero-badge-item .icon{width:28px;height:28px;background:rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px}

/* ── Section headings ── */
.section-header{text-align:center;margin-bottom:52px}
.section-tag{display:inline-block;background:var(--teal-lt);color:var(--teal-dk);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;padding:5px 14px;border-radius:20px;margin-bottom:12px}
.section-tag-purple{background:var(--purple-lt);color:var(--purple)}
.section-header h2{color:var(--dark);margin-bottom:12px}
.section-header p{max-width:560px;margin:0 auto}

/* ── Cards ── */
.card-grid{display:grid;gap:24px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--white);border-radius:12px;padding:32px;box-shadow:var(--sh);border:1px solid rgba(0,0,0,.04);transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.1)}
.card-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px}
.icon-teal{background:var(--teal-lt)}
.icon-purple{background:var(--purple-lt)}
.card h3{color:var(--dark);margin-bottom:8px;font-size:1.05rem}
.card p{font-size:14px}
.card ul{list-style:none;margin-top:12px}
.card ul li{font-size:13px;color:var(--gray);padding:4px 0;padding-left:18px;position:relative}
.card ul li::before{content:'✓';position:absolute;left:0;color:var(--teal);font-weight:700;font-size:12px}

/* ── Two-col sections ── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.two-col.rev .col-img{order:-1}
.col-img{border-radius:16px;overflow:hidden;background:linear-gradient(135deg,var(--teal-lt),var(--purple-lt));aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:80px}
.col-text .section-tag{text-align:left}
.col-text h2{margin-bottom:16px}
.col-text p{margin-bottom:20px}

/* ── Testimonial ── */
.testimonial-wrap{background:linear-gradient(135deg,var(--teal-lt) 0%,var(--purple-lt) 100%);border-radius:20px;padding:56px 48px;text-align:center}
.testimonial-wrap blockquote{font-size:1.25rem;font-style:italic;color:var(--dark);max-width:620px;margin:0 auto 20px;line-height:1.75}
.testimonial-wrap cite{font-weight:700;color:var(--teal-dk);font-style:normal;font-size:14px}

/* ── Stats band ── */
.stats-band{background:var(--dark);padding:56px 0}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.stat-item{text-align:center;padding:0 32px;border-right:1px solid rgba(255,255,255,.1)}
.stat-item:last-child{border-right:none}
.stat-item .num{font-size:2.8rem;font-weight:800;color:var(--teal);line-height:1}
.stat-item .lbl{color:rgba(255,255,255,.6);font-size:14px;margin-top:6px}

/* ── Services ── */
.services-hero{background:linear-gradient(135deg,#088a86 0%,#0ab5b0 100%);color:var(--white);padding:72px 0 64px}
.services-hero h1{margin-bottom:14px}
.services-hero p{color:rgba(255,255,255,.85);font-size:17px;max-width:560px}
.service-section{margin-bottom:48px}
.service-section h3{color:var(--teal-dk);font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--teal-lt)}
.service-list{list-style:none}
.service-list li{padding:7px 0;padding-left:20px;position:relative;font-size:14px;color:var(--gray)}
.service-list li::before{content:'›';position:absolute;left:0;color:var(--teal);font-weight:700;font-size:16px;line-height:1.3}

/* ── CTA band ── */
.cta-band{background:linear-gradient(135deg,var(--teal) 0%,var(--purple) 100%);padding:72px 0;text-align:center;color:var(--white)}
.cta-band h2{margin-bottom:14px}
.cta-band p{color:rgba(255,255,255,.85);font-size:16px;margin-bottom:32px}
.cta-band .btn-group{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}

/* ── Contact ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:56px;align-items:start}
.contact-info h2{margin-bottom:16px}
.contact-info p{margin-bottom:28px}
.contact-detail{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}
.contact-detail .cd-icon{width:40px;height:40px;background:var(--teal-lt);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.contact-detail .cd-text h4{font-size:13px;font-weight:700;color:var(--dark);margin-bottom:2px}
.contact-detail .cd-text a, .contact-detail .cd-text p{font-size:14px;color:var(--gray)}
.form-card{background:var(--white);border-radius:16px;padding:36px;box-shadow:var(--sh)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:700;color:var(--dark);margin-bottom:5px;text-transform:uppercase;letter-spacing:.3px}
.form-group input,.form-group select,.form-group textarea{width:100%;border:1px solid var(--border);border-radius:6px;padding:11px 13px;font-size:14px;font-family:inherit;color:var(--dark);background:var(--white);transition:border-color .15s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(10,181,176,.1)}
.form-group textarea{resize:vertical;min-height:100px}
.checkbox-group{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.checkbox-group label{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;cursor:pointer;color:var(--gray);text-transform:none;letter-spacing:0}
.checkbox-group input[type=checkbox]{width:15px;height:15px;accent-color:var(--teal);flex-shrink:0}
.form-submit-row{margin-top:8px}

/* ── Footer ── */
.footer{background:var(--dark);color:rgba(255,255,255,.55);padding:56px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:44px}
.footer-logo{height:46px;width:auto;margin-bottom:16px;filter:brightness(0) invert(1);opacity:.75}
.footer-about{font-size:13px;line-height:1.7;max-width:280px}
.footer h4{color:var(--white);font-size:14px;font-weight:600;margin-bottom:14px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:8px}
.footer ul a{font-size:13px;color:rgba(255,255,255,.55);transition:color .15s}
.footer ul a:hover{color:var(--teal)}
.footer .contact-line{font-size:13px;margin-bottom:6px}
.footer .contact-line a{color:rgba(255,255,255,.55)}
.footer .contact-line a:hover{color:var(--teal)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:20px;display:flex;justify-content:space-between;font-size:12px}
.footer-bottom a{color:rgba(255,255,255,.4)}
.footer-bottom a:hover{color:var(--teal)}

/* ── Join CTA card (About page) ── */
.join-cta{background:linear-gradient(135deg,#0ab5b0,#7c5abf);color:#fff;padding:40px;border-radius:12px;text-align:center;margin:40px 0}
.join-cta h3{font-size:1.5rem;margin-bottom:12px;color:#fff}
.join-cta p{margin-bottom:24px;opacity:.9}
.join-cta .btn-primary{background:#fff;color:#0ab5b0;border:none}
.join-cta .btn-primary:hover{background:rgba(255,255,255,.9);color:#0ab5b0}

/* ── Responsive ── */
@media(max-width:900px){
  .g2,.g3{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr;gap:36px}
  .two-col.rev .col-img{order:0}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .stats-grid{grid-template-columns:1fr;gap:28px}
  .stat-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.1);padding:16px 0}
  .stat-item:last-child{border-bottom:none}
}
@media(max-width:640px){
  .nav-links{display:none;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:var(--white);border-bottom:1px solid var(--border);box-shadow:0 4px 16px rgba(0,0,0,.08);padding:8px 16px 16px}
  .nav-links.open{display:flex}
  .nav-links li{border-bottom:1px solid var(--border);padding:2px 0}
  .nav-links li:last-child{border-bottom:none}
  .hamburger{display:flex}
  .nav-portal-btn{display:block;text-align:center;width:100%;padding:10px 0}
  .topnav{position:relative}
  .nav-inner{position:relative}
  .hero{padding:64px 0 56px}
  .section{padding:52px 0}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .form-row{grid-template-columns:1fr}
  .testimonial-wrap{padding:36px 24px}
  .cta-band{padding:52px 0}
}
