html,body{margin:0;padding:0;font-family:'Poppins','Inter',sans-serif;color:#1a1a1a;overflow-x:hidden}
.hero{position:relative;width:100%;min-height:300px;display:flex;align-items:center;justify-content:center;text-align:center;background-image:url(assets/top-bg.jpg);background-size:cover;background-position:center;background-repeat:no-repeat}
.hero-content{position:relative;max-width:900px;padding:0 20px}
.hero h1{font-size:40px;font-weight:600;line-height:1.25;color:#1386de;margin:25px auto 15px}
.hero h1 .non-profit{color:#000}
.hero p{margin:0 auto 30px;font-size:15px;line-height:1.6;color:#61819d}
.strip{background:#b4dbfc;padding:12px;color:#17609a;font-size:22px;text-align:center;font-weight:600}
.section{padding:0 8% 60px;padding-top:60px}
.two-col{display:flex;gap:60px;align-items:flex-start}
.left{flex:0 0 45%}
.left h2{font-size:26px;line-height:1.4;margin-top:35px}
.left h2 span{color:#4b99d6;font-weight:500}
.btn{display:inline-block;margin:10px 0;background:linear-gradient(135deg,#1e8ed6 0%,#2fd184 100%);color:#fff;padding:12px 24px;border-radius:6px;font-size:14px;text-decoration:none;font-weight:500;box-shadow:0 6px 18px #1e8ed659;transition:all .3s ease}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 22px #1e8ed673}
.quote{position:relative;margin-top:35px;padding-left:110px;font-size:13px;line-height:1.6;color:#666}
.quote p{margin-left:10px}
.quote::before{content:'';position:absolute;left:0;top:6px;width:100px;height:100px;background:#e6f1fb;border-radius:50%}
.quote::after{content:url('assets/quote.png');position:absolute;left:95px;top:-15px;width:25px}
.right{flex:1;position:relative}
.main-img{width:85%;display:block}
@keyframes floatX {
0%{transform:translateX(0px)}
50%{transform:translateX(12px)}
100%{transform:translateX(0px)}
}
.tag{position:absolute;background:#fff;padding:7px 12px 7px 34px;font-size:12px;border-radius:8px;box-shadow:0 6px 16px #0000001a;white-space:nowrap;animation:floatX 5s ease-in-out infinite}
.tag::before{content:'';position:absolute;left:10px;top:50%;transform:translateY(-50%);width:16px;height:16px;background-size:contain;background-repeat:no-repeat}
.tag1{top:5%;left:2%;animation-duration:4s}
.tag2{top:15%;right:-3%;animation-duration:5s;animation-direction:reverse}
.tag3{top:25%;left:-10%;animation-duration:6s}
.tag4{top:65%;right:3%;animation-duration:4.5s;animation-direction:reverse}
.tag5{bottom:18%;left:-10%;animation-duration:5.5s}
.tag6{bottom:5%;right:-6%;animation-duration:6.5s;animation-direction:reverse}
.tag7{top:35%;left:77%;animation-duration:4.2s}
.tag8{top:47%;right:83%;animation-duration:5.8s;animation-direction:reverse}
.tag9{top:91%;left:-4%;animation-duration:6.2s}
.tag1::before{background-image:url(assets/ico1.png)}
.tag3::before{background-image:url(assets/ico2.png)}
.tag8::before{background-image:url(assets/ico3.png)}
.tag5::before{background-image:url(assets/ico4.png)}
.tag9::before{background-image:url(assets/ico5.png)}
.tag2::before{background-image:url(assets/ico6.png)}
.tag7::before{background-image:url(assets/ico7.png)}
.tag4::before{background-image:url(assets/ico8.png)}
.tag6::before{background-image:url(assets/ico9.png)}
.features{background:#fff;padding:0 8% 60px;text-align:center}
.features span{color:#3f8dcb}
.features h4 { color: #9c9c9c;font-weight: 400; }
.features h4 span{color:#3f8dcb; font-weight: 600;}
.grid{margin-top:30px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{display:flex;align-items:center;gap:14px;background:#fff;padding:12px 20px;border-radius:7px;box-shadow:0 5px 15px #dae2ee;text-align:left}
.card::before{content:'';flex-shrink:0;width:36px;height:36px;background-size:contain;background-position:center;background-repeat:no-repeat}
.card-text{display:flex;flex-direction:column}
.card h3{margin:0;font-size:15px;font-weight:600}
.card p{margin:4px 0 0;font-size:13px;color:#666}
.grid .card:nth-child(1)::before{background-image:url(assets/ico10.png)}
.grid .card:nth-child(2)::before{background-image:url(assets/ico11.png)}
.grid .card:nth-child(3)::before{background-image:url(assets/ico12.png)}
.grid .card:nth-child(4)::before{background-image:url(assets/ico13.png)}
.grid .card:nth-child(5)::before{background-image:url(assets/ico14.png)}
.grid .card:nth-child(6)::before{background-image:url(assets/ico15.png)}
.map{padding:60px 20px;text-align:center;background:url(assets/map.png) center/contain no-repeat}
.blob{position:relative;margin:30px auto;width:300px;padding:10px;background:linear-gradient(135deg,#1e8ed6,#2f4bd1);border-radius:100px;color:#fff;top:-10px}
.line-top{border:5px solid #96d1fe;border-radius:5px;width:60px;margin:0 auto}
.blob h3{display:flex;align-items:center;justify-content:center;gap:10px;margin:5px 0;font-size:32px;font-weight:600;margin:0}
.blob h3 span{font-size:14px;font-weight:500;opacity:.9}
.blob::after{content:'';position:absolute;right:-18px;top:50%;transform:translateY(-50%);width:55px;height:55px;background:url(assets/verify.png) center/contain no-repeat}
.final{padding:0 20px 60px;text-align:center}
.final .footer-note{font-size:12px;color:#9c9c9c;text-align:center;margin:5px auto;width:605px}
.final .footer-note span{color:#000;font-weight:700}
.footer a{text-decoration: none; color: inherit;}
.final h2{margin:10px auto 3px}
.final span{color:#1e8ed6}
.footer{text-align:center;padding:18px;border-top:1px solid #ddd;font-size:13px}
.popup-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}
.popup-overlay.active{opacity:1;visibility:visible}
.popup-box{position:relative;background:#fff;border-radius:14px;padding:36px 32px 30px;width:100%;max-width:440px;box-shadow:0 20px 60px #0000002e;transform:translateY(20px);transition:transform .3s ease}
.popup-overlay.active .popup-box{transform:translateY(0)}
.popup-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:18px;color:#888;cursor:pointer;line-height:1;transition:color .2s}
.popup-close:hover{color:#1a1a1a}
.popup-title{margin:0 0 6px;font-size:20px;font-weight:600;color:#1386de}
.popup-sub{margin:0 0 22px;font-size:13px;color:#888}
.popup-form{display:flex;flex-direction:column;gap:14px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:12px;font-weight:600;color:#444}
.form-group input{padding:10px 14px;border:1.5px solid #dde4ee;border-radius:7px;font-size:13px;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s;color:#1a1a1a}
.form-group input::placeholder{color:#aaa}
.form-group input:focus{border-color:#1e8ed6;box-shadow:0 0 0 3px #1e8ed620}
.popup-submit{margin-top:6px;padding:12px;border:none;border-radius:7px;background:linear-gradient(135deg,#1e8ed6 0%,#2fd184 100%);color:#fff;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:0 6px 18px #1e8ed640;transition:transform .2s,box-shadow .2s}
.popup-submit:hover{transform:translateY(-2px);box-shadow:0 10px 22px #1e8ed660}
.form-msg{margin:6px 0 0;font-size:13px;text-align:center;min-height:18px}
.form-msg.success{color:#1dab6e;font-weight:500}
.form-msg.error{color:#e03e3e;font-weight:500}
.popup-form input.popup-error{border-color:#e03e3e;box-shadow:0 0 0 2px #e03e3e26}
@media(max-width:480px) {
.popup-box{padding:28px 20px 24px;margin:0 16px}
.popup-title{font-size:17px}
}
@media(max-width:1024px) {
.hero h1{font-size:28px}
.hero p{font-size:13px}
.section{padding:60px 4% 0;overflow:hidden}
.two-col{gap:20px;align-items:center}
.left{flex:0 0 38%}
.left h2{font-size:19px;line-height:1.5;margin-top:0}
.btn{font-size:13px;padding:10px 18px}
.quote{padding-left:78px;font-size:12px;margin-top:20px}
.quote::before{width:68px;height:68px}
.quote::after{left:64px;top:-10px}
.right{flex:1;overflow:hidden;padding:20px 0}
.main-img{width:100%;display:block;margin:0 auto}
.tag{font-size:10px;padding:5px 10px 5px 26px;white-space:nowrap}
.tag::before{width:14px;height:14px}
.tag2{right:0}
.tag3{left:0}
.tag4{right:0}
.tag5{left:0}
.tag6{right:0;bottom:8%}
.tag9{left:0}
.features{padding:50px 5%}
.features h2{font-size:22px}
.features h4 { font-size: 18px; }
.grid{grid-template-columns:repeat(2,1fr);gap:16px}
.map{padding:50px 20px}
.blob{width:72%;border-radius:80px}
.blob h3{font-size:24px}
.blob::after{right:-14px;width:44px;height:44px}
.final h2{font-size:22px}
.final .footer-note{width:88%}
}
@media(max-width:768px) {
.hero{min-height:auto;padding:0}
.hero h1{font-size:22px;margin:30px auto 12px}
.hero p{font-size:13px}
.strip{font-size:15px;padding:10px 16px}
.section{padding:30px 6% 50px;overflow:hidden}
.two-col{flex-direction:column;gap:0;align-items:stretch}
.left{order:1;flex:none;width:100%}
.left h2{font-size:20px;line-height:1.45;margin-top:20px;text-align:center}
.btn{display:block;text-align:center;margin:16px auto 0;width:fit-content}
.quote{padding-left:0;padding-top:90px;margin-top:28px;text-align:center;font-size:13px}
.quote p{margin-left:0}
.quote::before{left:50%;top:0;transform:translateX(-50%);width:76px;height:76px}
.quote::after{left:50%;top:-4px;transform:translateX(-50%)}
.right{order:2;width:100%;margin-top:40px;padding:50px 0 60px;overflow:hidden;position:relative}
.main-img{width:80%;display:block;margin:0 auto}
.tag{font-size:9px;padding:4px 8px 4px 24px;white-space:nowrap;max-width:44%;animation:none}
.tag::before{width:12px;height:12px;left:7px}
.tag1{top:2%;left:1%;right:auto;animation:floatX 4s ease-in-out infinite}
.tag2{top:2%;right:1%;left:auto;animation:floatX 5s ease-in-out infinite reverse}
.tag3{top:20%;left:1%;right:auto;animation:floatX 6s ease-in-out infinite}
.tag4{top:60%;right:1%;left:auto;animation:floatX 4.5s ease-in-out infinite reverse}
.tag5{bottom:22%;left:1%;right:auto;animation:floatX 5.5s ease-in-out infinite}
.tag6{bottom:5%;right:1%;left:auto;animation:floatX 6.5s ease-in-out infinite reverse}
.tag7{top:38%;right:1%;left:auto;animation:floatX 4.2s ease-in-out infinite}
.tag8{top:48%;left:1%;right:auto;animation:floatX 5.8s ease-in-out infinite reverse}
.tag9{bottom:12%;left:1%;right:auto;animation:floatX 6.2s ease-in-out infinite}
.features{padding:0 5% 40px}
.features h2{font-size:20px}
.features h4 { font-size: 16px; }
.grid{grid-template-columns:1fr;gap:14px}
.map{padding:40px 16px;background-size:cover}
.map h2{font-size:20px}
.blob{width:85%;border-radius:70px}
.blob h3{font-size:22px}
.blob::after{right:-12px;width:40px;height:40px}
.final h2{font-size:20px}
.final .footer-note{width:92%;font-size:11px}
}
@media(max-width:480px) {
.hero h1{font-size:19px;line-height:1.3}
.hero p{font-size:12px}
.strip{font-size:13px}
.section{padding:24px 5% 40px}
.left h2{font-size:17px}
.quote{font-size:12px}
.main-img{width:76%}
.tag{font-size:8px;padding:3px 7px 3px 20px;max-width:42%}
.tag::before{width:10px;height:10px;left:6px;top:10px}
.features{padding:30px 4%}
.features h2{font-size:17px}
.features h4 { font-size: 14px; }
.map h2{font-size:18px}
.final h2{font-size:17px}
.blob{width:95%;padding:8px 10px;border-radius:50px}
.blob h3{font-size:18px;gap:6px}
.blob::after{display:none}
.footer{font-size:12px}
}