
:root{
  --navy:#0a0e1a;--navy2:#0f1525;
  --accent:#4f8ef7;--accent2:#7eb3ff;
  --white:#ffffff;--off-white:#f4f6fb;
  --text-dark:#1a1f2e;--text-mid:#3a4255;
  --gray:#8892a4;--gray2:#5a6478;
  --border-light:#e2e8f0;
  --border2:rgba(255,255,255,0.07);
  --gradient:linear-gradient(135deg,#4f8ef7 0%,#7eb3ff 100%);
  --card-shadow:0 4px 24px rgba(0,0,0,0.08);
  --card-shadow-hover:0 14px 44px rgba(0,0,0,0.15);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:"DM Sans",sans-serif;background:var(--white);color:var(--text-dark);overflow-x:hidden;line-height:1.6;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,14,26,0.95);backdrop-filter:blur(20px);border-bottom:1px solid var(--border2);padding:0 48px;display:flex;align-items:center;justify-content:space-between;height:72px;}
.logo{font-family:"Sora",sans-serif;font-size:24px;font-weight:700;color:var(--white);letter-spacing:2px;text-decoration:none;}
.logo span{color:var(--accent);}
.nav-links{display:flex;gap:36px;align-items:center;}
.nav-links a{font-size:14px;font-weight:500;color:rgba(255,255,255,0.75);text-decoration:none;transition:color .2s;position:relative;}
.nav-links a:hover{color:var(--white);}
.nav-links a::after{content:"";position:absolute;bottom:-4px;left:0;right:100%;height:1px;background:var(--accent);transition:right .2s;}
.nav-links a:hover::after{right:0;}
.nav-cta{background:var(--gradient)!important;color:var(--white)!important;padding:10px 22px;border-radius:6px;font-weight:600!important;font-size:13px!important;box-shadow:0 4px 20px rgba(79,142,247,0.3);}
.nav-cta::after{display:none!important;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px;}
.hamburger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;}
.mobile-menu{display:none;position:fixed;top:72px;left:0;right:0;background:var(--navy2);padding:24px 32px;border-bottom:1px solid var(--border2);z-index:999;flex-direction:column;gap:20px;}
.mobile-menu a{font-size:16px;color:var(--white);text-decoration:none;font-weight:500;}
.mobile-menu.open{display:flex;}

/* PAGES */
.page{display:none;padding-top:72px;}
.page.active{display:block;}

/* HERO — uses JS-loaded image via canvas element overlay */
.hero{position:relative;min-height:calc(100vh - 72px);display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:var(--navy);}
/* hero-bg is set by JS with the uploaded image */
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  /* Dark gradient overlay for text readability — heavier at center where text sits */
  background-blend-mode:multiply;
}
/* Extra dark vignette layer for text readability */
.hero-vignette{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse 70% 60% at 50% 45%, rgba(5,8,20,0.72) 0%, rgba(5,8,20,0.45) 55%, rgba(5,8,20,0.25) 100%),
    linear-gradient(to bottom, rgba(5,8,20,0.5) 0%, rgba(5,8,20,0.3) 40%, rgba(5,8,20,0.65) 100%);
}
.hero-content{position:relative;z-index:2;max-width:820px;padding:0 24px;}
.hero h1{
  font-family:"Sora",sans-serif;font-size:clamp(34px,5vw,64px);
  font-weight:700;line-height:1.12;color:var(--white);
  margin-bottom:20px;letter-spacing:-1px;
  text-shadow:0 2px 20px rgba(0,0,0,0.6), 0 0 60px rgba(0,0,0,0.4);
}
.hero h1 em{font-style:normal;color:#4f8ef7;-webkit-text-fill-color:#4f8ef7;text-shadow:0 0 30px rgba(79,142,247,0.6),0 2px 12px rgba(0,0,0,0.5);}
.hero-sub{
  font-size:clamp(15px,2vw,19px);color:rgba(255,255,255,0.92);
  max-width:520px;margin:0 auto 40px;font-weight:400;
  text-shadow:0 1px 12px rgba(0,0,0,0.7);
  background:rgba(10,14,26,0.35);
  display:inline-block;padding:10px 22px;border-radius:8px;
  backdrop-filter:blur(4px);
}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* BUTTONS */
.btn-primary{background:var(--gradient);color:var(--white);padding:14px 30px;border-radius:8px;font-family:"Sora",sans-serif;font-weight:600;font-size:15px;text-decoration:none;border:none;cursor:pointer;box-shadow:0 8px 30px rgba(79,142,247,0.4);transition:transform .2s,box-shadow .2s;display:inline-block;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(79,142,247,0.55);}
.btn-outline{background:rgba(255,255,255,0.12);color:var(--white);padding:13px 30px;border-radius:8px;border:1px solid rgba(255,255,255,0.5);font-family:"Sora",sans-serif;font-weight:500;font-size:15px;text-decoration:none;cursor:pointer;transition:all .2s;display:inline-block;backdrop-filter:blur(6px);}
.btn-outline:hover{border-color:var(--accent2);color:var(--accent2);background:rgba(79,142,247,0.15);}
.btn-light-outline{background:transparent;color:var(--white);padding:13px 30px;border-radius:8px;border:1px solid rgba(255,255,255,0.3);font-family:"Sora",sans-serif;font-weight:500;font-size:15px;cursor:pointer;transition:all .2s;display:inline-block;}
.btn-light-outline:hover{border-color:var(--accent2);color:var(--accent2);}

/* SERVICES */
.services-section{background:var(--white);padding:80px 24px 100px;}
.services-inner{max-width:1160px;margin:0 auto;}
.services-header{text-align:center;margin-bottom:60px;}
.section-label{font-size:11px;letter-spacing:3px;font-weight:600;color:var(--accent);text-transform:uppercase;margin-bottom:12px;display:block;}
.section-title{font-family:"Sora",sans-serif;font-size:clamp(26px,3.5vw,40px);font-weight:700;color:var(--text-dark);line-height:1.2;margin-bottom:14px;}
.section-sub{font-size:17px;color:var(--gray);max-width:560px;margin:0 auto;line-height:1.7;}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:32px;}
.service-card{background:var(--white);border:1px solid var(--border-light);border-radius:12px;overflow:hidden;box-shadow:var(--card-shadow);transition:all .3s;}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--card-shadow-hover);border-color:rgba(79,142,247,0.3);}
.service-card-img{width:100%;height:200px;object-fit:cover;display:block;}
.service-card-body{padding:28px 24px;}
.service-card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.service-icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,rgba(79,142,247,0.12),rgba(126,179,255,0.08));border:1px solid rgba(79,142,247,0.2);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.service-title{font-family:"Sora",sans-serif;font-size:18px;font-weight:700;color:var(--text-dark);}
.service-card p{font-size:14.5px;color:var(--text-mid);line-height:1.75;margin-bottom:10px;}
.service-card ul{list-style:none;margin:10px 0 20px;}
.service-card ul li{font-size:14px;color:var(--text-mid);padding:5px 0 5px 18px;position:relative;border-bottom:1px solid var(--border-light);}
.service-card ul li:last-child{border-bottom:none;}
.service-card ul li::before{content:"→";position:absolute;left:0;color:var(--accent);font-size:11px;top:7px;}
.card-cta{font-size:13px;font-weight:600;color:var(--accent);text-decoration:none;letter-spacing:0.5px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;background:none;border:none;padding:0;transition:gap .2s;}
.card-cta:hover{gap:10px;}

/* CTA STRIP */
.cta-strip{background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);padding:70px 24px;text-align:center;}
.cta-strip h2{font-family:"Sora",sans-serif;font-size:clamp(22px,3vw,36px);font-weight:700;color:var(--white);margin-bottom:14px;}
.cta-strip p{color:rgba(255,255,255,0.65);font-size:16px;margin-bottom:32px;}
.cta-strip-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* PAGE HEROES */
.page-hero{position:relative;padding:80px 24px 60px;text-align:center;overflow:hidden;}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(5,8,18,0.85),rgba(5,8,18,0.95));}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.page-hero > *{position:relative;z-index:1;}
.page-hero h1{font-family:"Sora",sans-serif;font-size:clamp(28px,4vw,52px);font-weight:700;color:var(--white);margin-bottom:12px;text-shadow:0 2px 16px rgba(0,0,0,0.8);}
.page-hero p{font-size:17px;color:rgba(255,255,255,0.9);max-width:560px;margin:0 auto;text-shadow:0 1px 10px rgba(0,0,0,0.7);}

/* TEAM HERO — darker overlay + explicit white text */
.team-hero{position:relative;padding:80px 24px 60px;text-align:center;overflow:hidden;background:var(--navy);}
.team-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center top;opacity:0.25;}
.team-hero-content{position:relative;z-index:1;}
.team-hero-quote{
  font-family:"Sora",sans-serif;
  font-size:clamp(18px,2.5vw,26px);
  color:var(--white) !important;
  font-style:italic;
  max-width:720px;margin:0 auto 18px;line-height:1.55;
  text-shadow:0 1px 8px rgba(0,0,0,0.5);
}
.team-hero-sub{color:rgba(255,255,255,0.65) !important;font-size:15px;text-shadow:0 1px 4px rgba(0,0,0,0.4);}

/* LIGHT SECTION */
.light-section{background:var(--off-white);padding:80px 24px;}
.light-inner{max-width:1100px;margin:0 auto;}

/* MUNI — redesigned flow */
.muni-intro{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-bottom:64px;}
.muni-intro-text{}
.muni-badge{display:inline-block;background:rgba(79,142,247,0.1);border:1px solid rgba(79,142,247,0.25);padding:4px 14px;border-radius:100px;font-size:11px;letter-spacing:2px;color:var(--accent);text-transform:uppercase;font-weight:600;margin-bottom:18px;}
.muni-intro-text h2{font-family:"Sora",sans-serif;font-size:clamp(26px,3vw,38px);font-weight:700;color:var(--text-dark);margin-bottom:8px;}
.muni-intro-text h3{font-size:16px;color:var(--accent);font-weight:400;font-style:italic;margin-bottom:20px;}
.muni-intro-text p{font-size:15px;color:var(--text-mid);line-height:1.8;margin-bottom:12px;}
.muni-hero-img{border-radius:16px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.15);}
.muni-hero-img img{width:100%;height:auto;max-height:440px;object-fit:cover;display:block;}

/* App screenshots section */
.muni-screens-section{margin-bottom:60px;}
.muni-screens-title{font-family:"Sora",sans-serif;font-size:24px;font-weight:700;color:var(--text-dark);margin-bottom:8px;text-align:center;}
.muni-screens-sub{font-size:15px;color:var(--gray);text-align:center;margin-bottom:36px;}
.muni-screens-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start;}
.muni-screen-card{background:var(--white);border-radius:24px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,0.12);border:1px solid var(--border-light);transition:all .3s;}
.muni-screen-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,0.18);}
.muni-screen-card img{width:100%;display:block;border-radius:24px;}
.muni-screen-label{padding:16px;text-align:center;font-family:"Sora",sans-serif;font-size:13px;font-weight:600;color:var(--text-mid);letter-spacing:0.5px;}

/* Features */
.features-title{font-family:"Sora",sans-serif;font-size:22px;font-weight:700;color:var(--text-dark);margin-bottom:24px;}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:16px;margin-bottom:48px;}
.feature-item{background:var(--white);border:1px solid var(--border-light);border-radius:12px;padding:22px 16px;text-align:center;transition:all .3s;box-shadow:0 2px 12px rgba(0,0,0,0.04);}
.feature-item:hover{border-color:rgba(79,142,247,0.3);transform:translateY(-3px);}
.feature-emoji{font-size:26px;margin-bottom:10px;display:block;}
.feature-item h4{font-family:"Sora",sans-serif;font-size:13px;font-weight:600;color:var(--text-dark);margin-bottom:5px;}
.feature-item p{font-size:12px;color:var(--gray);line-height:1.5;}

/* CTA card */
.muni-cta-card{background:var(--white);border:1px solid var(--border-light);border-radius:16px;padding:40px;text-align:center;box-shadow:var(--card-shadow);}
.muni-cta-card h3{font-family:"Sora",sans-serif;font-size:22px;font-weight:700;color:var(--text-dark);margin-bottom:10px;}
.muni-cta-card p{color:var(--gray);margin-bottom:24px;font-size:15px;}

/* TEAM */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px;}
.team-card{background:var(--white);border:1px solid var(--border-light);border-radius:16px;overflow:hidden;box-shadow:var(--card-shadow);transition:all .3s;}
.team-card:hover{transform:translateY(-5px);box-shadow:var(--card-shadow-hover);}
.team-photo-wrap{background:linear-gradient(135deg,#e8edf5,#d4dff0);padding:32px;display:flex;justify-content:center;}
.team-photo{width:130px;height:130px;border-radius:50%;object-fit:cover;border:4px solid var(--white);box-shadow:0 8px 30px rgba(0,0,0,0.15);}
.team-card-body{padding:28px 28px 32px;text-align:center;}
.team-name{font-family:"Sora",sans-serif;font-size:20px;font-weight:700;color:var(--text-dark);margin-bottom:4px;}
.team-role{font-size:12px;color:var(--accent);font-weight:600;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:18px;}
.team-bio{font-size:14.5px;color:var(--text-mid);line-height:1.75;margin-bottom:22px;}
.team-cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--gradient);color:var(--white);padding:10px 22px;border-radius:8px;font-size:13px;font-weight:600;text-decoration:none;transition:all .2s;cursor:pointer;border:none;box-shadow:0 4px 16px rgba(79,142,247,0.3);}
.team-cta-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--accent);padding:10px 22px;border-radius:8px;border:1px solid rgba(79,142,247,0.3);font-size:13px;font-weight:600;text-decoration:none;transition:all .2s;cursor:pointer;}
.team-cta-outline:hover{background:rgba(79,142,247,0.06);}

/* CONTACT */
.contact-grid{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1fr 1.6fr;gap:60px;align-items:start;}
.contact-info h2{font-family:"Sora",sans-serif;font-size:26px;font-weight:700;color:var(--text-dark);margin-bottom:14px;}
.contact-info p{font-size:15px;color:var(--text-mid);line-height:1.8;margin-bottom:32px;}
.contact-detail{display:flex;align-items:center;gap:14px;margin-bottom:20px;}
.contact-icon{width:42px;height:42px;border-radius:10px;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.contact-text{font-size:14px;color:var(--text-mid);}
.contact-text a{color:var(--accent);text-decoration:none;font-weight:500;}
.contact-form-box{background:var(--white);border:1px solid var(--border-light);border-radius:16px;padding:40px;box-shadow:var(--card-shadow);}
.form-group{margin-bottom:20px;}
.form-group label{display:block;font-size:12px;font-weight:600;letter-spacing:1px;color:var(--gray2);text-transform:uppercase;margin-bottom:8px;}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--off-white);border:1px solid var(--border-light);border-radius:8px;padding:12px 16px;color:var(--text-dark);font-family:"DM Sans",sans-serif;font-size:14px;transition:border .2s;outline:none;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);background:var(--white);}
.form-group textarea{resize:vertical;min-height:120px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-submit{width:100%;background:var(--gradient);color:var(--white);border:none;border-radius:8px;padding:14px;font-family:"Sora",sans-serif;font-weight:600;font-size:15px;cursor:pointer;box-shadow:0 6px 24px rgba(79,142,247,0.35);transition:transform .2s;}
.form-submit:hover{transform:translateY(-2px);}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,0.55);backdrop-filter:blur(8px);align-items:center;justify-content:center;padding:24px;}
.modal-overlay.open{display:flex;}
.modal{background:var(--white);border:1px solid var(--border-light);border-radius:20px;padding:40px;max-width:520px;width:100%;position:relative;box-shadow:0 24px 60px rgba(0,0,0,0.2);}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--gray);font-size:22px;cursor:pointer;line-height:1;}
.modal h3{font-family:"Sora",sans-serif;font-size:22px;font-weight:700;color:var(--text-dark);margin-bottom:8px;}
.modal-desc{font-size:14px;color:var(--gray);margin-bottom:24px;line-height:1.6;}

/* FOOTER */
footer{background:var(--navy);border-top:1px solid var(--border2);padding:40px 48px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;}
.footer-logo{font-family:"Sora",sans-serif;font-size:20px;font-weight:700;color:var(--white);}
.footer-logo span{color:var(--accent);}
.footer-text{font-size:13px;color:var(--gray2);}
.footer-links{display:flex;gap:24px;}
.footer-links a{font-size:13px;color:var(--gray2);text-decoration:none;transition:color .2s;}
.footer-links a:hover{color:var(--accent2);}

/* FADE */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease;}
.fade-up.visible{opacity:1;transform:none;}

@media(max-width:900px){
  nav{padding:0 24px;}.nav-links{display:none;}.hamburger{display:flex;}
  .muni-intro{grid-template-columns:1fr;}
  .muni-screens-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  footer{padding:32px 24px;flex-direction:column;text-align:center;}.footer-links{justify-content:center;}
}
@media(max-width:600px){
  .hero{min-height:80vh;}
  .muni-hero-img img{height:250px;}
  .contact-form-box{padding:28px 20px;}
  .form-row{grid-template-columns:1fr;}
  .team-photo-wrap{padding:24px;}
}
