
:root{
    --blue:#0b1f61;
    --blue-2:#173689;
    --gold:#d6b26a;
    --red:#c51f27;
    --text:#1f2740;
    --muted:#64708b;
    --white:#ffffff;
    --bg:#f5f7fb;
    --shadow:0 16px 45px rgba(12, 28, 74, 0.12);
    --radius:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:Arial, Helvetica, sans-serif;
    color:var(--text);
    background:#fff;
    line-height:1.6;
}
img{max-width:100%;display:block}
a{text-decoration:none}
.container{width:min(1200px, calc(100% - 32px));margin:0 auto}

.site-header{
    position:sticky;top:0;z-index:999;
    background:linear-gradient(90deg, rgba(8,23,67,.98), rgba(16,39,111,.95));
    border-bottom:3px solid var(--gold);
    box-shadow:0 6px 22px rgba(0,0,0,.12);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px 0}
.brand-link{display:flex;align-items:center;gap:14px;color:#fff}
.brand-logo img,.brand-logo .custom-logo{width:72px;height:72px;object-fit:contain}
.brand-name{display:block;font-size:15px;font-weight:800;line-height:1.2;letter-spacing:.4px;text-transform:uppercase;max-width:280px}
.main-nav .menu{display:flex;list-style:none;gap:34px;margin:0;padding:0}
.main-nav a{color:#fff;font-weight:700;font-size:15px}
.main-nav a:hover{color:#ffe7a8}
.mobile-toggle{display:none;background:#fff;border:none;border-radius:10px;padding:8px 12px;font-size:22px}

.hero{
    position:relative;
    color:#fff;
    min-height:900px;
    background-size:cover;
    background-position:center;
    overflow:hidden;
}
.hero::after{
    content:"";
    position:absolute;inset:auto 0 120px 0;height:220px;
    background:linear-gradient(to bottom, rgba(11,31,97,0) 0%, rgba(11,31,97,.18) 100%);
}
.hero-inner{
    position:relative;z-index:2;
    display:grid;
    grid-template-columns:1.05fr .95fr;
    align-items:end;
    gap:32px;
    padding:120px 0 170px;
}
.hero-copy{max-width:680px}
.hero-copy h1{
    margin:0 0 18px;
    font-size:clamp(42px, 6vw, 74px);
    line-height:1.02;
    font-weight:900;
    letter-spacing:-1.4px;
    text-shadow:0 4px 20px rgba(0,0,0,.18);
}
.hero-sub{
    max-width:620px;
    font-size:clamp(18px, 2vw, 34px);
    line-height:1.32;
    font-weight:600;
    color:rgba(255,255,255,.96);
    margin:0 0 28px;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.btn{
    display:inline-flex;align-items:center;justify-content:center;
    min-width:170px;padding:15px 26px;border-radius:12px;
    font-weight:800;font-size:17px;
    box-shadow:0 12px 24px rgba(0,0,0,.18);
    transition:transform .2s ease, opacity .2s ease;
    color:#fff;
}
.btn:hover{transform:translateY(-2px);opacity:.96}
.btn-red{background:linear-gradient(180deg,#db2a34,#b8141d)}
.btn-blue{background:linear-gradient(180deg,#284ab1,#14348f)}
.hero-visual{display:flex;align-items:flex-end;justify-content:flex-end}
.hero-visual img{
    max-height:720px;
    object-fit:contain;
    filter:drop-shadow(0 14px 40px rgba(0,0,0,.25));
}
.hero-badge-band{
    position:relative;z-index:3;
    margin-top:-70px;
    background:linear-gradient(90deg,#0b1f61,#102f8d);
    border-top:4px solid var(--gold);
    border-bottom:4px solid var(--gold);
    border-radius:42px 42px 0 0;
    display:grid;grid-template-columns:300px 1fr;gap:24px;
    align-items:center;
    padding:20px 30px 26px;
    box-shadow:var(--shadow);
}
.year-badge{display:flex;justify-content:center}
.badge-circle{
    width:240px;height:240px;border-radius:50%;
    padding:10px;background:linear-gradient(180deg,#f8e5ae,#b98b2a);
    box-shadow:0 14px 34px rgba(0,0,0,.22);
}
.badge-inner{
    width:100%;height:100%;border-radius:50%;
    background:radial-gradient(circle at top,#173689 0%,#0b1f61 80%);
    border:6px solid #fff3ca;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    text-align:center;padding:22px;color:#fff;
}
.badge-mini{font-size:13px;font-weight:700;line-height:1.25;margin-bottom:6px}
.badge-years{font-size:42px;font-weight:900;color:#ffd76e;line-height:1}
.badge-date{font-size:20px;font-weight:800}
.badge-text{font-size:28px;line-height:1.35;font-weight:700;color:#fff;max-width:760px}
.badge-text strong,.badge-text b{color:#f7d773}

.section{padding:90px 0}
.alt-bg{
    background:linear-gradient(180deg,#eef3fb 0%,#f7f9fe 100%);
}
.section-head{margin-bottom:34px}
.section-head.center{text-align:center;max-width:900px;margin:0 auto 34px}
.eyebrow{
    display:inline-block;margin-bottom:10px;
    font-size:14px;font-weight:800;letter-spacing:1.8px;text-transform:uppercase;color:var(--red)
}
.section-head h2{
    margin:0 0 12px;
    font-size:clamp(34px,4vw,58px);
    line-height:1.05;
    color:var(--blue);
    font-weight:900;
}
.section-head p{
    margin:0 auto;
    color:var(--muted);
    font-size:20px;
    line-height:1.65;
}

.about-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center
}
.about-image-card img{
    border-radius:26px;box-shadow:var(--shadow);min-height:420px;object-fit:cover;width:100%
}
.about-content-card{
    background:#fff;padding:38px;border-radius:26px;box-shadow:var(--shadow)
}
.about-content-card h3{margin:0 0 12px;color:var(--blue);font-size:34px}
.about-content-card p{margin:0 0 22px;color:var(--muted);font-size:18px}

.cards-grid{
    display:grid;gap:24px
}
.services-grid{grid-template-columns:repeat(4,1fr)}
.service-card{
    overflow:hidden;background:#fff;border-radius:24px;box-shadow:var(--shadow)
}
.service-card img{height:250px;width:100%;object-fit:cover}
.service-card-body{padding:24px}
.service-card h3{margin:0 0 8px;font-size:22px;color:var(--blue)}
.service-card p{margin:0;color:var(--muted)}

.client-logos{
    display:grid;grid-template-columns:repeat(6,1fr);gap:18px
}
.client-logo-item{
    background:#fff;border-radius:20px;box-shadow:var(--shadow);padding:22px;display:flex;align-items:center;justify-content:center;min-height:130px
}
.client-logo-item img{max-height:76px;object-fit:contain;filter:grayscale(100%)}
.client-logo-item:hover img{filter:none}

.industries-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center
}
.industries-image img{
    border-radius:26px;box-shadow:var(--shadow);min-height:420px;object-fit:cover;width:100%
}
.industry-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:24px}
.industry-pill{
    background:#fff;border-left:5px solid var(--gold);
    padding:16px 18px;border-radius:14px;box-shadow:var(--shadow);font-weight:800;color:var(--blue)
}

.gallery-slider{position:relative}
.gallery-track{
    display:flex;overflow:hidden;border-radius:26px;box-shadow:var(--shadow)
}
.gallery-slide{min-width:100%;flex:0 0 100%}
.gallery-slide img{width:100%;height:560px;object-fit:cover}
.gallery-nav{
    position:absolute;top:50%;transform:translateY(-50%);
    width:54px;height:54px;border:none;border-radius:50%;
    background:rgba(11,31,97,.85);color:#fff;font-size:30px;cursor:pointer;z-index:5
}
.gallery-prev{left:18px}.gallery-next{right:18px}

.contact-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:28px}
.contact-card{background:#fff;border-radius:24px;box-shadow:var(--shadow);overflow:hidden}
.map-frame iframe{display:block;width:100%}
.contact-meta{padding:24px 26px}
.contact-meta p{margin:0 0 10px;color:var(--muted)}
.contact-form{padding:28px}
.form-row{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.form-row label{font-weight:700;color:var(--blue)}
.form-row input,.form-row textarea{
    width:100%;padding:14px 16px;border-radius:12px;border:1px solid #d7dceb;font-size:16px
}
.form-row input:focus,.form-row textarea:focus{outline:none;border-color:#2349be;box-shadow:0 0 0 3px rgba(35,73,190,.12)}
.form-message{margin:24px 24px 0;padding:14px 16px;border-radius:12px;font-weight:700}
.form-message.success{background:#e7f7ec;color:#14703a}
.form-message.error{background:#ffe8e8;color:#b61d1d}

.site-footer{
    background:linear-gradient(180deg,#081743,#061134);
    color:#fff;padding:34px 0 28px
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:28px;align-items:start}
.footer-brand{font-size:22px;font-weight:900;margin-bottom:10px}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:8px}
.footer-links a{color:#fff}
.social-links{display:flex;gap:12px;flex-wrap:wrap}
.social-links a,.floating-whatsapp{
    width:48px;height:48px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    background:#fff;color:var(--blue);box-shadow:0 10px 24px rgba(0,0,0,.18)
}
.social-links svg,.floating-whatsapp svg{width:24px;height:24px;fill:currentColor}
.floating-whatsapp{
    position:fixed;left:16px;bottom:20px;z-index:9999;background:#1fb15e;color:#fff
}

.page-default{padding:70px 0}
.default-content{background:#fff;border-radius:20px;padding:30px;box-shadow:var(--shadow)}

@media (max-width: 1100px){
    .services-grid{grid-template-columns:repeat(2,1fr)}
    .client-logos{grid-template-columns:repeat(3,1fr)}
    .hero-inner,.about-grid,.industries-grid,.contact-grid{grid-template-columns:1fr}
    .hero-visual{justify-content:center}
    .hero-visual img{max-height:560px}
    .hero-badge-band{grid-template-columns:1fr;text-align:center}
    .year-badge{order:-1}
}
@media (max-width: 860px){
    .nav-wrap{flex-wrap:wrap}
    .mobile-toggle{display:block}
    .main-nav{width:100%;display:none}
    .main-nav.open{display:block}
    .main-nav .menu{flex-direction:column;gap:12px;padding:12px 0}
    .brand-name{font-size:14px;max-width:220px}
    .hero{min-height:auto}
    .hero-inner{padding:70px 0 120px}
    .hero-copy h1{font-size:44px}
    .hero-sub{font-size:20px}
    .hero-actions{gap:12px}
    .btn{min-width:0;width:auto;padding:14px 18px;font-size:16px}
    .badge-circle{width:210px;height:210px}
    .badge-text{font-size:20px}
    .gallery-slide img{height:380px}
    .footer-grid,.industry-list{grid-template-columns:1fr}
}
@media (max-width: 560px){
    .container{width:min(100% - 22px, 1200px)}
    .brand-logo img,.brand-logo .custom-logo{width:58px;height:58px}
    .hero-copy h1{font-size:36px}
    .section{padding:70px 0}
    .section-head h2{font-size:34px}
    .section-head p{font-size:17px}
    .services-grid,.client-logos{grid-template-columns:1fr}
    .service-card img{height:220px}
    .gallery-nav{width:44px;height:44px}
}
