:root{
--navy:#061f3f;
--blue:#0b2d5c;
--soft:#f3f6fa;
--soft2:#eaf0f6;
--white:#fff;
--text:#10233f;
--muted:#536174;
--line:#dfe7ef;
--shadow:0 18px 45px rgba(6,31,63,.08);
}

*{box-sizing:border-box}

html,
body{
max-width:100%;
overflow-x:hidden;
}

img,
svg{
max-width:100%;
}

html{scroll-behavior:smooth}

body{
margin:0;
font-family:"Helvetica Neue",Arial,sans-serif;
background:#f6f9fc;
color:var(--text);
}

a{text-decoration:none;color:inherit}

header{
height:92px;
padding:0 6%;
display:flex;
align-items:center;
justify-content:space-between;
background:rgba(255,255,255,.96);
border-bottom:1px solid var(--line);
}


.brand-logo{
display:block;
height:78px;
width:auto;
object-fit:contain;
}

.brand picture,
.hero-image picture{
display:block;
}

@media(max-width:520px){
.brand-logo{
height:64px;
}
}


.brand{
font-weight:800;
font-size:21px;
letter-spacing:.13em;
color:var(--navy);
line-height:1.05;
}

.brand span{
display:block;
font-weight:400;
font-size:12px;
letter-spacing:.42em;
margin-top:8px;
color:var(--muted);
}

.header-btn{
display:inline-flex;
align-items:center;
gap:10px;
padding:14px 24px;
background:#0b3a6f;
color:#fff;
border-radius:16px;
font-weight:700;
box-shadow:0 10px 24px rgba(6,31,63,.18);
max-width:100%;
min-width:0;
text-align:center;
white-space:normal;
}

.header-btn svg,
.btn svg{
width:18px;
height:18px;
stroke:currentColor;
stroke-width:2;
fill:none;
stroke-linecap:round;
stroke-linejoin:round;
}

.hero{
padding:46px 6% 34px;
background:#f6f9fc;
}

.hero-wrap{
max-width:1420px;
margin:0 auto;
display:grid;
grid-template-columns:.82fr 1.18fr;
gap:58px;
align-items:start;
}

.hero-image{
align-self:start;
}

.kicker,
.section-label{
font-size:13px;
letter-spacing:.24em;
text-transform:uppercase;
font-weight:800;
color:var(--blue);
}

.kicker{margin-bottom:24px}

h1{
margin:0 0 24px;
max-width:650px;
font-size:clamp(42px,5vw,72px);
line-height:1.02;
letter-spacing:0;
color:var(--navy);
}

.lead{
max-width:600px;
margin:0 0 34px;
font-size:19px;
line-height:1.72;
color:var(--muted);
}

.cta{
display:flex;
gap:16px;
flex-wrap:wrap;
margin-bottom:30px;
}

.btn{
display:inline-flex;
align-items:center;
justify-content:center;
gap:10px;
padding:16px 26px;
border-radius:16px;
font-weight:800;
font-size:16px;
max-width:100%;
min-width:0;
white-space:normal;
text-align:center;
}

.btn.primary{
background:#0b3a6f;
color:#fff;
box-shadow:0 12px 28px rgba(6,31,63,.18);
}

.btn.secondary{
background:#fff;
color:var(--navy);
border:1px solid var(--navy);
}

.badges{
display:flex;
gap:28px;
flex-wrap:wrap;
color:var(--navy);
font-size:15px;
font-weight:700;
}

.badges span{
display:flex;
align-items:center;
gap:8px;
min-width:0;
}

.badges svg{
width:18px;
height:18px;
stroke:var(--navy);
stroke-width:2;
fill:none;
stroke-linecap:round;
stroke-linejoin:round;
}

.hero-image{
position:relative;
overflow:hidden;
border-radius:30px;
box-shadow:0 28px 70px rgba(6,31,63,.16);
background:var(--navy);
}

.hero-image:after{
content:"";
position:absolute;
inset:0;
background:linear-gradient(90deg,rgba(6,31,63,.28),rgba(6,31,63,.16));
}

.hero-image img{
display:block;
width:100%;
height:520px;
object-fit:cover;
filter:grayscale(.34) saturate(.52) brightness(.76);
}

section{
padding:34px 6%;
background:#f6f9fc;
}



section.light,
section.soft{background:#eaf3fb}

.inner{
max-width:1420px;
margin:0 auto;
min-width:0;
}

.section-label{
margin-bottom:24px;
}

.grid-3{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:22px;
margin-bottom:26px;
}

.grid-4{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:22px;
margin-bottom:26px;
}

.hero-wrap > *,
.grid-3 > *,
.grid-4 > *,
.projects > *,
.contact-grid > *,
.footer-grid > *,
.link-grid > *,
.cta > *,
.badges > *,
.topnav > *{
min-width:0;
}

.card{
background:#fdfefe;
border:1px solid var(--line);
border-radius:24px;
padding:30px;
box-shadow:var(--shadow);
display:block;
}

.icon{
width:58px;
height:58px;
border-radius:17px;
background:var(--navy);
display:flex;
align-items:center;
justify-content:center;
flex-shrink:0;
}

.icon svg{
width:29px;
height:29px;
stroke:#fff;
stroke-width:2.2;
fill:none;
stroke-linecap:round;
stroke-linejoin:round;
}

.card h3{
margin:0 0 10px;
font-size:22px;
line-height:1.2;
color:var(--navy);
}

.card p{
margin:0;
font-size:16px;
line-height:1.58;
color:var(--muted);
}

.step{
background:#fff;
border:1px solid var(--line);
border-radius:24px;
padding:26px;
box-shadow:var(--shadow);
}

.num{
width:56px;
height:56px;
border-radius:16px;
background:var(--soft2);
display:flex;
align-items:center;
justify-content:center;
font-size:28px;
font-weight:800;
color:var(--navy);
margin-bottom:18px;
}

.step strong{
display:block;
font-size:19px;
margin-bottom:8px;
color:var(--navy);
}

.step p{
margin:0;
font-size:15px;
line-height:1.55;
color:var(--muted);
}

.zone-card{
background:#fff;
border:1px solid var(--line);
border-radius:24px;
padding:32px;
box-shadow:var(--shadow);
display:block;
max-width:900px;
}

footer{
background:var(--navy);
color:#fff;
padding:34px 6%;
}

.footer-inner{
max-width:1420px;
margin:0 auto;
display:flex;
justify-content:space-between;
gap:24px;
flex-wrap:wrap;
align-items:center;
}

.footer-inner strong{
letter-spacing:.08em;
}

.footer-contact{
display:flex;
gap:34px;
flex-wrap:wrap;
}


@media(max-width:1280px){

.grid-3{
grid-template-columns:repeat(2,1fr);
}

}

@media(max-width:980px){

header{
height:auto;
padding:22px 6%;
flex-direction:column;
align-items:flex-start;
gap:18px;
}

.header-btn{width:100%;justify-content:center}

.hero{
padding:48px 6%;
}

.hero-wrap{
grid-template-columns:1fr;
gap:36px;
}

.hero-image img{
height:360px;
}

.cta{
flex-direction:column;
}

.btn{
width:100%;
}

.grid-3,
.grid-4{
grid-template-columns:1fr;
}

.footer-inner{
align-items:flex-start;
}
}

@media(max-width:520px){
section{padding:42px 5%}
.hero{padding:38px 5%}
header{padding:16px 5%}
h1{
font-size:34px;
line-height:1.08;
}

.lead{
font-size:17px;
}

.hero-image img{
height:280px;
}

.icon{
width:54px;
height:54px;
}

.brand{
font-size:18px;
}

.brand-logo{
height:54px;
max-width:100%;
}

.brand span{
font-size:10px;
}

.kicker,
.section-label{
letter-spacing:.12em;
overflow-wrap:anywhere;
}

.topnav{
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:8px;
overflow-x:visible;
padding-bottom:0;
}

.topnav a{
display:flex;
align-items:center;
justify-content:center;
font-size:13px;
padding:9px 12px;
text-align:center;
}

.header-btn{
padding:13px 18px;
}

.badges{
gap:12px;
}

.badges span{
font-size:14px;
}
}

.progress{
height:10px;
background:#dfeaf5;
border-radius:999px;
overflow:hidden;
margin-bottom:24px;
position:relative;
}

.progress span{
display:block;
height:100%;
background:linear-gradient(90deg,#0b2d5c,#3c7bc4);
border-radius:999px;
}

.p25 span{width:25%}
.p50 span{width:50%}
.p75 span{width:75%}
.p100 span{width:100%}



.p100{
background:#f3f8ff;
}

.num{
display:none;
}


.accordion{
display:grid;
gap:14px;
max-width:960px;
}

.acc-item{
background:#fff;
border:1px solid var(--line);
border-radius:20px;
box-shadow:0 12px 30px rgba(6,31,63,.055);
overflow:hidden;
}

.acc-btn{
width:100%;
border:0;
background:#fff;
padding:24px 28px;
display:flex;
align-items:center;
justify-content:space-between;
gap:20px;
cursor:pointer;
font:inherit;
color:var(--navy);
text-align:left;
}

.acc-title{
display:flex;
align-items:center;
gap:18px;
font-size:22px;
font-weight:800;
}

.acc-plus{
font-size:28px;
line-height:1;
font-weight:300;
transition:.2s;
}

.acc-content{
max-height:0;
overflow:hidden;
transition:max-height .25s ease;
}

.acc-content-inner{
padding:0 28px 26px 110px;
color:var(--muted);
font-size:17px;
line-height:1.6;
}

.acc-item.active .acc-content{
max-height:220px;
}

.acc-item.active .acc-plus{
transform:rotate(45deg);
}

@media(max-width:700px){
.acc-content-inner{padding:0 22px 24px 22px}
.acc-btn{padding:22px}
.acc-title{font-size:20px}
}


.projects{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:22px;
}

.project{
background:#fff;
border:1px solid var(--line);
border-radius:24px;
overflow:hidden;
box-shadow:var(--shadow);
}

.project-img{
height:240px;
background-size:cover;
background-position:center;
position:relative;
}

.project-img:after{
content:"";
position:absolute;
inset:0;
background:rgba(6,31,63,.18);
}

.project-body{
padding:24px;
}

.project-body h3{
margin:0 0 10px;
font-size:22px;
color:var(--navy);
}

.project-body p{
margin:0;
line-height:1.6;
color:var(--muted);
}

@media(max-width:900px){
.projects{
grid-template-columns:1fr;
}
}



.topnav{
display:flex;
gap:34px;
align-items:center;
min-width:0;
}

.topnav a{
font-size:15px;
font-weight:700;
color:var(--navy);
opacity:.78;
transition:.2s;
}

.topnav a:hover{
opacity:1;
}

.contact-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:22px;
}

.contact-card{
background:#fff;
border:1px solid var(--line);
border-radius:24px;
padding:28px;
box-shadow:var(--shadow);
}

.contact-card h3{
margin:0 0 12px;
font-size:22px;
color:var(--navy);
}

.contact-card p{
margin:0;
line-height:1.7;
color:var(--muted);
}

@media(max-width:980px){

.topnav{
display:flex;
width:100%;
max-width:100%;
gap:10px;
overflow-x:auto;
padding-bottom:4px;
-webkit-overflow-scrolling:touch;
}

.topnav a{
white-space:nowrap;
font-size:14px;
padding:10px 14px;
border:1px solid var(--line);
border-radius:999px;
background:#fff;
}

.contact-grid{
grid-template-columns:1fr;
}

}

@media(max-width:520px){
header > *{
max-width:100%;
}

.topnav{
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:8px;
overflow-x:visible;
padding-bottom:0;
}

.topnav a{
display:flex;
align-items:center;
justify-content:center;
white-space:normal;
font-size:13px;
padding:9px 12px;
text-align:center;
}
}

@media(max-width:400px){
.topnav{
grid-template-columns:1fr;
}
}



.whatsapp-float{
position:fixed;
right:22px;
bottom:118px;
width:64px;
height:64px;
border-radius:50%;
background:#0b3a6f;
display:flex;
align-items:center;
justify-content:center;
box-shadow:0 14px 34px rgba(6,31,63,.24);
z-index:9999;
transition:.2s;
}

.whatsapp-float:hover{
transform:translateY(-2px);
}

.whatsapp-float svg{
width:34px;
height:34px;
fill:#fff;
}

@media(max-width:700px){
.whatsapp-float{
display:none;
}
}

/* ===== FIXED HEADER GLOBAL ===== */
header{
position:sticky;
top:0;
z-index:9999;
backdrop-filter:blur(14px);
-webkit-backdrop-filter:blur(14px);
}

html{
scroll-padding-top:96px;
}

/* ===== SHARED INTERNAL PAGE COMPONENTS ===== */

.link-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
gap:16px;
}

.link-grid.wide{
grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
gap:14px;
}

.link-card{
display:block;
padding:18px;
border:1px solid #e5e7eb;
border-radius:14px;
text-decoration:none;
color:#0f172a;
font-weight:700;
background:#f8fafc;
transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
}

.link-card:hover{
transform:translateY(-2px);
border-color:#cbd5e1;
box-shadow:0 12px 28px rgba(6,31,63,.08);
}

.link-card.white{
background:#fff;
padding:16px;
}

.content-box{
margin-top:40px;
padding:32px;
border:1px solid #e5e7eb;
border-radius:18px;
background:#ffffff;
}

.content-box.soft-box{
margin-top:50px;
background:#f8fafc;
}

.content-box h2{
margin-top:0;
}

.center-link{
padding:24px;
text-align:center;
}

.center-link a{
color:#0f172a;
font-weight:600;
text-decoration:none;
}

.inline-cta{
display:inline-block;
padding:14px 24px;
background:#0f172a;
color:#fff;
text-decoration:none;
border-radius:12px;
font-weight:700;
}

.text-center{
text-align:center;
}


/* ===== FOOTER NAV V1 ===== */
.footer-grid{
max-width:1420px;
margin:0 auto;
display:grid;
grid-template-columns:1.2fr repeat(4,1fr);
gap:34px;
align-items:start;
}

.footer-brand{
line-height:1.6;
}

.footer-col h3{
margin:0 0 14px;
font-size:15px;
letter-spacing:.12em;
text-transform:uppercase;
color:#fff;
}

.footer-col a{
display:block;
margin:0 0 10px;
color:rgba(255,255,255,.78);
font-size:15px;
}

.footer-col a:hover{
color:#fff;
}

.footer-meta{
max-width:1420px;
margin:28px auto 0;
padding-top:20px;
border-top:1px solid rgba(255,255,255,.16);
display:flex;
justify-content:space-between;
gap:18px;
flex-wrap:wrap;
color:rgba(255,255,255,.72);
font-size:14px;
}

@media(max-width:980px){
.footer-grid{
grid-template-columns:1fr 1fr;
}
}

@media(max-width:520px){
.footer-grid{
grid-template-columns:1fr;
}
}
