/* ===== KM Security & Payroll Management — Navy & Steel Theme =====
   Professional corporate palette for a security & payroll company */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Spectral:ital,wght@0,400;0,500;0,600;1,400&display=swap');

:root{
  --navy:#0f2747;          /* primary deep navy */
  --navy-2:#16335c;        /* lighter navy panel */
  --steel:#2e4a6b;         /* steel blue */
  --steel-soft:#7d93b0;    /* muted steel for text on dark */
  --amber:#c8862b;         /* warm accent */
  --amber-soft:#e0b878;    /* soft amber */
  --paper:#f6f7f9;         /* clean off-white background */
  --paper-2:#eceef2;       /* tinted panel */
  --ink:#1c2632;           /* near-black body text */
  --muted:#5b6675;         /* slate grey muted text */
  --line:#dde1e8;          /* hairline borders */
  --white:#ffffff;
  --shadow:0 18px 50px -20px rgba(15,39,71,.35);
  --radius:14px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Spectral',Georgia,serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4,h5,.font-sora{font-family:'Sora',sans-serif}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
section{position:relative}

/* ---------- Top utility bar ---------- */
.topbar{
  background:var(--navy);
  color:#c4cedd;
  font-family:'Sora',sans-serif;
  font-size:.78rem;
  letter-spacing:.02em;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;
  height:42px;flex-wrap:wrap;gap:8px}
.topbar .tb-left{display:flex;gap:22px;flex-wrap:wrap}
.topbar .tb-left span{display:flex;align-items:center;gap:7px}
.topbar .tb-right{display:flex;align-items:center;gap:8px;color:var(--amber-soft)}
.topbar svg{width:14px;height:14px;opacity:.9}

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(246,247,249,.95);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:88px}
.brand{display:flex;align-items:center;gap:13px}
.brand-logo{width:60px;height:60px;flex:none;border-radius:50%;object-fit:cover}
.brand-text strong{
  font-family:'Sora',sans-serif;font-weight:700;font-size:1.05rem;
  color:var(--navy);display:block;line-height:1.15;letter-spacing:-.01em;
}
.brand-text small{font-family:'Sora',sans-serif;font-size:.68rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--amber)}

.menu{display:flex;align-items:center;gap:6px;font-family:'Sora',sans-serif;
  font-size:.86rem;font-weight:500}
.menu a{padding:10px 14px;border-radius:8px;color:var(--steel);transition:.2s}
.menu a:hover,.menu a.active{background:var(--navy);color:#fff}
.menu .has-sub{position:relative}
.menu .sub{
  position:absolute;top:calc(100% + 8px);left:0;min-width:235px;
  background:var(--white);border:1px solid var(--line);border-radius:12px;
  box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;
  transform:translateY(8px);transition:.22s}
.menu .has-sub:hover .sub{opacity:1;visibility:visible;transform:translateY(0)}
.menu .sub a{display:block;border-radius:7px}
.menu .has-sub:last-child .sub{left:auto;right:0}
.btn-portal{
  background:var(--amber);color:var(--navy)!important;font-weight:600;
  border-radius:8px!important;padding:11px 18px!important;
}
.btn-portal:hover{background:var(--amber-soft)!important}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{display:block;width:26px;height:2px;background:var(--navy);
  margin:6px 0;transition:.3s}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:'Sora',sans-serif;font-weight:600;font-size:.88rem;
  padding:14px 26px;border-radius:9px;cursor:pointer;border:0;transition:.25s;
}
.btn svg{width:16px;height:16px}
.btn-amber{background:var(--amber);color:var(--navy)}
.btn-amber:hover{background:var(--amber-soft);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;
  border:1px solid rgba(255,255,255,.45)}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:var(--amber-soft)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:var(--steel)}

/* ---------- Hero ---------- */
.hero{
  background:
    linear-gradient(115deg,rgba(15,39,71,.97) 40%,rgba(22,51,92,.82) 100%),
    radial-gradient(circle at 82% 22%,rgba(200,134,43,.32),transparent 55%),
    var(--navy);
  color:var(--white);overflow:hidden;
}
.hero .wrap{position:relative;z-index:2;padding-top:96px;padding-bottom:104px}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:'Sora',sans-serif;font-size:.72rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--amber-soft);
  border:1px solid rgba(200,134,43,.5);padding:8px 15px;border-radius:30px;
  margin-bottom:26px;
}
.hero h1{
  font-size:clamp(2.5rem,5.6vw,4.3rem);font-weight:800;line-height:1.05;
  letter-spacing:-.02em;margin-bottom:22px;
}
.hero h1 em{font-family:'Spectral',serif;font-style:italic;font-weight:500;
  color:var(--amber-soft);}
.hero p.lead{font-size:1.12rem;color:#c3cdda;max-width:480px;margin-bottom:34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-side{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-radius:18px;padding:30px;backdrop-filter:blur(6px);
}
.hero-side h4{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--amber-soft);margin-bottom:18px}
.cred{display:flex;gap:13px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.cred:last-child{border-bottom:0}
.cred svg{width:20px;height:20px;color:var(--amber-soft);flex:none;margin-top:3px}
.cred b{font-family:'Sora',sans-serif;font-size:.86rem;display:block;color:#fff}
.cred span{font-size:.85rem;color:#9aa6b6}

/* ---------- Stats strip ---------- */
.stats{background:var(--navy-2);color:#fff}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;padding:46px 26px}
.stat{text-align:center;border-right:1px solid rgba(255,255,255,.13)}
.stat:last-child{border-right:0}
.stat .num{font-family:'Sora',sans-serif;font-size:2.5rem;font-weight:800;
  color:var(--amber-soft);line-height:1}
.stat .lbl{font-family:'Sora',sans-serif;font-size:.76rem;letter-spacing:.12em;
  text-transform:uppercase;color:#9aa6b6;margin-top:8px}

/* ---------- Section heading ---------- */
.sec{padding:96px 0}
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.kicker{font-family:'Sora',sans-serif;font-size:.74rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--amber);
  display:flex;align-items:center;gap:10px;margin-bottom:16px}
.sec-head.center .kicker{justify-content:center}
.kicker::before{content:"";width:30px;height:2px;background:var(--amber)}
.sec-head.center .kicker::before{display:none}
.sec h2{font-size:clamp(2rem,3.6vw,2.9rem);font-weight:800;color:var(--navy);
  line-height:1.1;letter-spacing:-.02em}
.sec h2 em{font-style:italic;font-weight:500;font-family:'Spectral',serif;
  color:var(--steel)}
.sec-head p{margin-top:16px;color:var(--muted);font-size:1.05rem}

/* ---------- Service cards ---------- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.svc-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:36px 30px;transition:.3s;position:relative;overflow:hidden;
}
.svc-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;
  background:var(--amber);transition:.35s}
.svc-card:hover{transform:translateY(-7px);box-shadow:var(--shadow);
  border-color:transparent}
.svc-card:hover::before{width:100%}
.svc-ico{
  width:58px;height:58px;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--steel),var(--navy));color:var(--amber-soft);
  margin-bottom:22px;
}
.svc-ico svg{width:27px;height:27px}
.svc-card h3{font-size:1.28rem;color:var(--navy);margin-bottom:12px}
.svc-card p{color:var(--muted);font-size:.97rem;margin-bottom:18px}
.svc-link{font-family:'Sora',sans-serif;font-size:.82rem;font-weight:600;
  color:var(--steel);display:inline-flex;align-items:center;gap:7px}
.svc-link svg{width:15px;height:15px;transition:.25s}
.svc-card:hover .svc-link svg{transform:translateX(4px)}

/* ---------- About split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-visual{
  background:linear-gradient(150deg,var(--navy),var(--steel));
  border-radius:18px;padding:46px;color:#fff;position:relative;overflow:hidden;
  box-shadow:var(--shadow);
}
.about-visual::after{content:"";position:absolute;right:-60px;bottom:-60px;
  width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle,rgba(200,134,43,.32),transparent 70%)}
.about-visual .estd{font-family:'Sora',sans-serif;font-size:5rem;font-weight:800;
  color:var(--amber-soft);line-height:1}
.about-visual .estd-sub{font-family:'Sora',sans-serif;letter-spacing:.14em;
  text-transform:uppercase;font-size:.8rem;color:#9aa6b6;margin-bottom:30px}
.legal-row{display:flex;justify-content:space-between;gap:12px;
  padding:13px 0;border-bottom:1px solid rgba(255,255,255,.14);font-size:.9rem}
.legal-row:last-child{border-bottom:0}
.legal-row span:first-child{color:#9aa6b6;font-family:'Sora',sans-serif;
  font-size:.78rem;letter-spacing:.05em}
.legal-row span:last-child{font-family:'Sora',sans-serif;font-weight:600;
  color:var(--amber-soft)}
.about-text p{color:var(--muted);margin-bottom:18px}
.tick-list{list-style:none;margin:22px 0}
.tick-list li{display:flex;gap:12px;margin-bottom:13px;color:var(--ink);
  font-size:.98rem}
.tick-list svg{width:20px;height:20px;color:var(--amber);flex:none;margin-top:3px}

/* ---------- Clients ---------- */
.clients-wrap{background:var(--navy);color:#fff}
.client-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1);
  border-radius:14px;overflow:hidden}
.client-cell{
  background:var(--navy-2);padding:34px 26px;display:flex;flex-direction:column;
  gap:8px;transition:.3s;min-height:150px;
}
.client-cell:hover{background:var(--steel)}
.client-cell .cnum{font-family:'Sora',sans-serif;font-size:.78rem;
  color:var(--amber-soft);font-weight:600}
.client-cell h4{font-size:1.12rem;color:#fff}
.client-cell p{font-size:.86rem;color:#9aa6b6}

/* ---------- Why / features ---------- */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.why-card{padding:30px 24px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--white);transition:.3s}
.why-card:hover{border-color:var(--amber);transform:translateY(-5px)}
.why-card .wnum{font-family:'Sora',sans-serif;font-weight:800;font-size:1.1rem;
  color:var(--amber);margin-bottom:14px}
.why-card h4{font-family:'Sora',sans-serif;font-size:1.02rem;color:var(--navy);
  margin-bottom:8px}
.why-card p{font-size:.9rem;color:var(--muted)}

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(120deg,var(--navy),var(--steel));
  color:#fff;text-align:center;padding:78px 26px;position:relative;overflow:hidden;
}
.cta-band::after{content:"";position:absolute;left:50%;top:-80px;
  width:300px;height:300px;transform:translateX(-50%);border-radius:50%;
  background:radial-gradient(circle,rgba(200,134,43,.26),transparent 70%)}
.cta-band h2{font-size:clamp(1.9rem,3.5vw,2.7rem);font-weight:800;
  margin-bottom:14px;position:relative}
.cta-band p{color:#c3cdda;max-width:540px;margin:0 auto 30px;position:relative}
.cta-band .btn{position:relative}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:46px}
.contact-info .ci-card{background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);padding:26px;margin-bottom:18px;display:flex;gap:16px}
.ci-card .ci-ico{width:46px;height:46px;border-radius:11px;flex:none;
  background:var(--navy);color:var(--amber-soft);display:grid;place-items:center}
.ci-card .ci-ico svg{width:21px;height:21px}
.ci-card h4{font-family:'Sora',sans-serif;font-size:.86rem;color:var(--navy);
  margin-bottom:5px;letter-spacing:.04em}
.ci-card p{font-size:.93rem;color:var(--muted)}
.form-card{background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);padding:38px;box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{font-family:'Sora',sans-serif;font-size:.78rem;font-weight:600;
  color:var(--navy);display:block;margin-bottom:7px;letter-spacing:.04em}
.field input,.field textarea,.field select{
  width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:9px;
  font-family:'Spectral',serif;font-size:.97rem;background:var(--paper);
  transition:.2s;color:var(--ink)}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:0;border-color:var(--amber);background:#fff;
  box-shadow:0 0 0 3px rgba(200,134,43,.2)}
.field textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{font-size:.82rem;color:var(--muted);margin-top:6px}
.text-danger{color:#c0392b;font-size:.8rem;font-family:'Sora',sans-serif;
  display:block;margin-top:5px}
.alert-success{background:#eaf3ec;border:1px solid #b6d8be;
  color:#1f6f3a;border-radius:10px;padding:14px 16px;font-size:.92rem;
  font-family:'Sora',sans-serif;margin-bottom:22px}
.input-validation-error{border-color:#c0392b!important}

/* ---------- Page hero (inner) ---------- */
.page-hero{
  background:linear-gradient(115deg,rgba(15,39,71,.97),rgba(22,51,92,.88)),
    radial-gradient(circle at 85% 30%,rgba(200,134,43,.3),transparent 55%),
    var(--navy);
  color:#fff;padding:78px 0;
}
.page-hero .crumb{font-family:'Sora',sans-serif;font-size:.78rem;
  color:var(--amber-soft);letter-spacing:.06em;margin-bottom:14px}
.page-hero h1{font-size:clamp(2.1rem,4.4vw,3.2rem);font-weight:800;
  letter-spacing:-.02em}
.page-hero p{color:#c3cdda;max-width:560px;margin-top:14px;font-size:1.05rem}

/* ---------- Service detail ---------- */
.detail-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:48px;
  align-items:start}
.detail-body h3{font-family:'Sora',sans-serif;font-size:1.4rem;color:var(--navy);
  margin:34px 0 14px}
.detail-body h3:first-child{margin-top:0}
.detail-body p{color:var(--muted);margin-bottom:16px}
.detail-body ul{list-style:none;margin:14px 0 24px}
.detail-body ul li{display:flex;gap:11px;margin-bottom:11px;color:var(--ink)}
.detail-body ul li svg{width:19px;height:19px;color:var(--amber);flex:none;
  margin-top:3px}
.aside-card{background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);padding:28px;position:sticky;top:112px}
.aside-card h4{font-family:'Sora',sans-serif;font-size:1.05rem;color:var(--navy);
  margin-bottom:16px}
.aside-list a{display:flex;justify-content:space-between;align-items:center;
  padding:13px 0;border-bottom:1px solid var(--line);font-family:'Sora',sans-serif;
  font-size:.9rem;color:var(--steel);transition:.2s}
.aside-list a:last-child{border-bottom:0}
.aside-list a:hover{color:var(--amber);padding-left:6px}
.aside-list a svg{width:15px;height:15px}
.aside-cta{margin-top:22px;background:var(--navy);color:#fff;border-radius:11px;
  padding:24px;text-align:center}
.aside-cta p{font-size:.9rem;color:#c3cdda;margin-bottom:14px}
.aside-cta .ph{font-family:'Sora',sans-serif;font-size:1.3rem;font-weight:800;
  color:var(--amber-soft);margin-bottom:14px}

/* ---------- Downloads ---------- */
.dl-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.dl-card{background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);padding:24px;display:flex;gap:18px;
  align-items:center;transition:.3s}
.dl-card:hover{border-color:var(--amber);transform:translateY(-4px);
  box-shadow:var(--shadow)}
.dl-ico{width:52px;height:52px;border-radius:11px;flex:none;
  background:linear-gradient(150deg,var(--steel),var(--navy));
  color:var(--amber-soft);display:grid;place-items:center}
.dl-ico svg{width:24px;height:24px}
.dl-card h4{font-family:'Sora',sans-serif;font-size:1rem;color:var(--navy)}
.dl-card p{font-size:.84rem;color:var(--muted)}
.dl-card .dl-btn{margin-left:auto;font-family:'Sora',sans-serif;font-size:.8rem;
  font-weight:600;color:var(--amber);display:flex;align-items:center;
  gap:6px;flex:none}
.dl-btn svg{width:15px;height:15px}

/* ---------- Footer ---------- */
.footer{background:var(--navy);color:#9aa6b6;padding:66px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:40px;
  padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer h5{font-family:'Sora',sans-serif;font-size:.82rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--amber);margin-bottom:20px}
.footer .f-brand{display:flex;align-items:center;gap:13px;margin-bottom:18px}
.footer .f-brand .brand-logo{width:54px;height:54px;background:#fff;padding:3px}
.footer .f-brand .brand-text strong{color:#fff}
.footer p{font-size:.92rem;margin-bottom:10px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:11px}
.footer ul li a{font-size:.92rem;transition:.2s}
.footer ul li a:hover{color:var(--amber-soft);padding-left:5px}
.footer .f-contact li{display:flex;gap:10px;font-size:.92rem}
.footer .f-contact svg{width:16px;height:16px;color:var(--amber);flex:none;
  margin-top:4px}
.footer-bottom{display:flex;justify-content:space-between;padding:24px 0;
  font-size:.84rem;flex-wrap:wrap;gap:10px}
.footer-bottom .iso{color:var(--amber-soft);font-family:'Sora',sans-serif}

/* ---------- Client logo grid ---------- */
.logo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.logo-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 20px;text-align:center;transition:.3s;
  display:flex;flex-direction:column;align-items:center;gap:14px;min-height:190px;
  justify-content:center;
}
.logo-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);
  border-color:var(--amber)}
.logo-card .logo-img{
  width:100px;height:70px;object-fit:contain;
}
.logo-card .logo-badge{
  width:70px;height:70px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--steel),var(--navy));
  color:var(--amber-soft);font-family:'Sora',sans-serif;font-weight:800;
  font-size:1.5rem;letter-spacing:.02em;
}
.logo-card h4{font-family:'Sora',sans-serif;font-size:.92rem;color:var(--navy);
  line-height:1.3}
.logo-card p{font-size:.8rem;color:var(--muted)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);
  transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero-grid,.split,.contact-grid,.detail-grid{grid-template-columns:1fr}
  .services-grid,.why-grid,.client-grid,.dl-grid{grid-template-columns:1fr 1fr}
  .logo-grid{grid-template-columns:1fr 1fr}
  .stats .wrap{grid-template-columns:1fr 1fr;gap:34px}
  .stat:nth-child(2){border-right:0}
  .footer-grid{grid-template-columns:1fr 1fr}
  .aside-card{position:static}
}
@media(max-width:680px){
  .menu{
    position:fixed;inset:88px 0 auto 0;background:var(--paper);
    flex-direction:column;align-items:stretch;padding:18px;gap:4px;
    border-bottom:1px solid var(--line);transform:translateY(-130%);
    transition:.35s;box-shadow:var(--shadow)}
  .menu.open{transform:translateY(0)}
  .menu .sub{position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;border:0;padding:0 0 0 14px;margin-top:4px}
  .nav-toggle{display:block}
  .services-grid,.why-grid,.client-grid,.dl-grid,.form-row,
  .stats .wrap,.logo-grid{grid-template-columns:1fr}
  .stat{border-right:0;border-bottom:1px solid rgba(255,255,255,.13);
    padding-bottom:22px}
  .stat:last-child{border-bottom:0}
  .footer-grid{grid-template-columns:1fr}
  .topbar .tb-left{display:none}
  .sec{padding:64px 0}
}
