/* ==========================================================================
   Guardian Intel Security — Services page styles (self-contained)
   Scoped under .gis-services. Brand: navy #0a1730 / gold #fab909
   ========================================================================== */

.gis-services { font-family: 'Open Sans', sans-serif; color: #2a2f3a; }
.gis-services h1, .gis-services h2, .gis-services h3 { font-family: 'Montserrat', sans-serif; }
.gis-services .sv-wrap { max-width: 1170px; margin: 0 auto; padding: 0 20px; width: 100%; }
.gis-services .sv-eyebrow {
    display: inline-block; letter-spacing: 3px; text-transform: uppercase;
    font-size: 13px; font-weight: 700; color: #c9971a; margin-bottom: 14px;
}

/* ---- HERO ---- */
.gis-services .sv-hero {
    position: relative; min-height: 380px; display: flex; align-items: center;
    text-align: center; color: #fff;
    background: linear-gradient(rgba(8,17,34,.78), rgba(8,17,34,.9)),
                url('../img/gispatrolslide.jpg') center center / cover no-repeat;
}
.gis-services .sv-hero .sv-eyebrow { color: #fab909; }
.gis-services .sv-hero h1 { font-size: 50px; font-weight: 700; text-transform: uppercase; margin: 0 0 14px; color: #fff; }
.gis-services .sv-hero h1 span { color: #fab909; }
.gis-services .sv-hero p { font-size: 18px; max-width: 760px; margin: 0 auto; color: #d7dce4; line-height: 1.7; }

/* ---- SECTION shell ---- */
.gis-services .sv-section { padding: 90px 0; }
.gis-services .sv-section.alt { background: #f5f6f8; }
.gis-services .sv-head { text-align: center; max-width: 740px; margin: 0 auto 55px; }
.gis-services .sv-head h2 { font-size: 36px; font-weight: 700; color: #0a1730; margin: 0 0 14px; }
.gis-services .sv-head h2 span { color: #fab909; }
.gis-services .sv-head p { font-size: 17px; color: #5b6470; margin: 0; line-height: 1.75; }

/* ---- SERVICE CARDS ---- */
.gis-services .sv-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.gis-services .sv-card {
    background: #fff; border-radius: 14px; overflow: hidden; display: flex; flex-direction: column;
    box-shadow: 0 10px 30px rgba(10,23,48,.08); transition: transform .35s ease, box-shadow .35s ease;
}
.gis-services .sv-card:hover { transform: translateY(-8px); box-shadow: 0 24px 50px rgba(10,23,48,.16); }
.gis-services .sv-media { position: relative; height: 210px; overflow: hidden; }
.gis-services .sv-media-bg {
    position: absolute; inset: 0; background-size: cover; background-position: center center;
    transition: transform .6s ease;
}
.gis-services .sv-card:hover .sv-media-bg { transform: scale(1.08); }
.gis-services .sv-media::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(8,17,34,.55), rgba(8,17,34,0) 55%);
}
.gis-services .sv-icon {
    position: absolute; bottom: -26px; left: 28px; z-index: 2;
    width: 56px; height: 56px; border-radius: 50%; background: #fab909; color: #0a1730;
    display: flex; align-items: center; justify-content: center; font-size: 22px;
    box-shadow: 0 8px 20px rgba(10,23,48,.25); transition: background .3s, color .3s;
}
.gis-services .sv-card:hover .sv-icon { background: #0a1730; color: #fab909; }
.gis-services .sv-body { padding: 42px 28px 30px; display: flex; flex-direction: column; flex: 1; }
.gis-services .sv-body h3 { font-size: 20px; color: #0a1730; margin: 0 0 12px; }
.gis-services .sv-body p { font-size: 15px; color: #5b6470; line-height: 1.7; margin: 0 0 20px; flex: 1; }
.gis-services .sv-link {
    font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px;
    color: #c9971a; align-self: flex-start; transition: color .3s;
}
.gis-services .sv-link i { margin-left: 7px; transition: transform .3s; }
.gis-services .sv-card:hover .sv-link { color: #0a1730; }
.gis-services .sv-card:hover .sv-link i { transform: translateX(5px); }

/* ---- WHY BAND ---- */
.gis-services .sv-why { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; }
.gis-services .sv-why-item { text-align: center; padding: 0 10px; }
.gis-services .sv-why-ico {
    width: 70px; height: 70px; border-radius: 50%; background: #fff5d8; color: #d39e09;
    display: flex; align-items: center; justify-content: center; font-size: 26px; margin: 0 auto 20px;
}
.gis-services .sv-why-item h3 { font-size: 18px; color: #0a1730; margin: 0 0 10px; }
.gis-services .sv-why-item p { font-size: 14px; color: #5b6470; line-height: 1.7; margin: 0; }

/* ---- CTA band ---- */
.gis-services .sv-cta {
    padding: 84px 0; text-align: center; color: #fff;
    background: linear-gradient(rgba(8,17,34,.9), rgba(8,17,34,.93)),
                url('../img/gisdesk1.jpg') center center / cover no-repeat;
}
.gis-services .sv-cta h2 { font-size: 36px; font-weight: 700; margin: 0 0 14px; color: #fff; }
.gis-services .sv-cta p { font-size: 17px; color: #d7dce4; max-width: 640px; margin: 0 auto 30px; line-height: 1.7; }
.gis-services .sv-btn {
    display: inline-block; padding: 15px 38px; border-radius: 40px; background: #fab909; color: #0a1730;
    font-weight: 700; text-transform: uppercase; letter-spacing: .5px; font-size: 14px; transition: all .3s;
}
.gis-services .sv-btn:hover { background: #fff; color: #0a1730; }

/* ---- Responsive ---- */
@media (max-width: 991px) {
    .gis-services .sv-grid { grid-template-columns: repeat(2, 1fr); }
    .gis-services .sv-why { grid-template-columns: repeat(2, 1fr); gap: 36px 26px; }
    .gis-services .sv-hero h1 { font-size: 38px; }
}
@media (max-width: 600px) {
    .gis-services .sv-grid { grid-template-columns: 1fr; }
    .gis-services .sv-why { grid-template-columns: 1fr; }
    .gis-services .sv-section { padding: 60px 0; }
    .gis-services .sv-hero { min-height: 320px; }
    .gis-services .sv-hero h1 { font-size: 30px; }
    .gis-services .sv-head h2 { font-size: 28px; }
}
