/* =========================================================================
   SILVER SECURITY — stylesheet
   Satin silver + steel, dark navy accents. Display: Cormorant Garamond.
   Body: Source Sans 3. Utility/mono: JetBrains Mono.
   ========================================================================= */


/* ---------------------------------- Tokens ------------------------------ */
:root{
  /* Navy — used as accent / drama sections */
  --navy-950:#070d18;
  --navy-900:#0c1830;
  --navy-850:#0f1d38;
  --navy-800:#142847;
  --navy-700:#1c3a68;
  --navy-600:#2c5290;
  --navy-400:#5c80b6;

  /* Satin silver / steel — base + primary */
  --silver-50:#f6f7f8;
  --silver-100:#eceef1;
  --silver-200:#dde1e5;
  --silver-300:#c7cdd3;
  --silver-400:#aab1b9;
  --silver-500:#8c949c;
  --silver-600:#6c7379;
  --silver-700:#4d5258;

  --ink:#11151b;
  --white:#ffffff;

  --metal-gradient: linear-gradient(135deg,#fbfbfc 0%,#dfe2e5 22%,#aeb4ba 46%,#cfd3d7 64%,#f3f4f5 84%,#c4c9cd 100%);
  --metal-gradient-soft: linear-gradient(135deg,#eef0f1 0%,#d6dadd 50%,#eef0f1 100%);
  --navy-gradient: linear-gradient(165deg,var(--navy-900) 0%,var(--navy-950) 55%,#04070d 100%);

  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'Source Sans 3',system-ui,-apple-system,Segoe UI,sans-serif;
  --font-mono:'JetBrains Mono',monospace;

  --container:1240px;
  --section-pad: clamp(72px, 9vw, 132px);
  --radius: 4px;

  --shadow-lg: 0 30px 70px -20px rgba(7,13,24,.45);
  --shadow-sm: 0 10px 24px -12px rgba(7,13,24,.25);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------------------------------- Reset -------------------------------- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
}
body{margin:0;}
img{max-width:100%;display:block;}
ul{margin:0;padding:0;list-style:none;}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;}
input,textarea,select{font:inherit;}
h1,h2,h3,h4,p,figure{margin:0;}

body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--silver-50);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

:focus-visible{outline:3px solid var(--navy-600);outline-offset:2px;}

/* ---------------------------------- i18n --------------------------------- */
html[data-lang="es"] .i18n[lang="en"]{display:none;}
html[data-lang="en"] .i18n[lang="es"]{display:none;}
.i18n{display:inherit;}

/* ---------------------------------- Layout ------------------------------- */
.container{max-width:var(--container);margin:0 auto;padding:0 28px;}
.section{padding:var(--section-pad) 0;position:relative;}
.section--tight{padding:calc(var(--section-pad) * .5) 0;}
.section-head{max-width:760px;margin:0 0 56px;}
.section-head.center{margin-inline:auto;text-align:center;}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-size:13px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--navy-700);
  margin-bottom:18px;
}
.eyebrow::before{content:"";width:18px;height:1px;background:var(--navy-700);}
.eyebrow.on-dark{color:var(--silver-300);}
.eyebrow.on-dark::before{background:var(--silver-400);}

.section-title{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:.02em;
  text-transform:uppercase;
  font-size:clamp(30px, 4vw, 50px);
  line-height:1.05;
  color:var(--navy-900);
}
.section-title.on-dark{color:var(--white);}
.section-title .accent{color:var(--navy-700);}
.on-dark .section-title.accent,
.section-title.on-dark .accent{color:var(--silver-300);}

.lede{
  font-size:clamp(16px,1.6vw,18.5px);
  line-height:1.65;
  color:var(--silver-700);
  margin-top:18px;
}
.lede.on-dark{color:var(--silver-300);}

/* ---------------------------------- Buttons ------------------------------ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-display);font-weight:600;font-size:15px;
  letter-spacing:.12em;text-transform:uppercase;
  padding:16px 30px;
  border-radius:2px;
  border:1px solid transparent;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease);
  white-space:nowrap;
}
.btn-primary{
  background:var(--metal-gradient);
  color:var(--navy-950);
  box-shadow:var(--shadow-sm);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -10px rgba(7,13,24,.4);}
.btn-outline{
  background:transparent;
  border-color:rgba(255,255,255,.35);
  color:var(--white);
}
.btn-outline:hover{border-color:var(--white);background:rgba(255,255,255,.06);transform:translateY(-2px);}
.btn-outline.on-light{border-color:var(--navy-800);color:var(--navy-900);}
.btn-outline.on-light:hover{background:var(--navy-900);color:var(--white);}
.btn-arrow{transition:transform .35s var(--ease);}
.btn:hover .btn-arrow{transform:translateX(4px);}
.btn-sm{padding:11px 20px;font-size:11.5px;}

/* ---------------------------------- Topbar -------------------------------- */
.topbar{
  background:var(--navy-950);
  color:var(--silver-300);
  font-family:var(--font-body);
  font-size:12.5px;
  letter-spacing:.04em;
}
.topbar .container{
  display:flex;align-items:center;justify-content:space-between;
  height:38px;
}
.topbar-left{display:flex;align-items:center;gap:22px;}
.topbar-left a{display:flex;align-items:center;gap:7px;color:var(--silver-300);transition:color .2s;}
.topbar-left a:hover{color:var(--white);}
.topbar-left svg{width:13px;height:13px;flex:none;opacity:.85;}
.topbar-left span.sep{display:none;}

.lang-switch{display:flex;align-items:center;border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:2px;gap:2px;}
.lang-switch button{
  background:transparent;border:none;color:var(--silver-400);
  font-family:var(--font-body);font-size:11px;letter-spacing:.06em;
  padding:4px 11px;border-radius:18px;transition:.25s;
}
.lang-switch button[aria-pressed="true"]{background:var(--metal-gradient);color:var(--navy-950);font-weight:600;}

/* ---------------------------------- Header / Nav -------------------------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:var(--navy-950);
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:box-shadow .4s var(--ease);
}
.site-header.is-scrolled{box-shadow:0 16px 30px -18px rgba(0,0,0,.5);}

.nav{display:flex;align-items:center;justify-content:space-between;height:88px;}
.brand{display:flex;align-items:center;gap:14px;color:var(--white);}
.brand img{height:54px;width:auto;}
.brand-word{font-family:var(--font-display);line-height:1;}
.brand-word b{display:block;font-size:21px;font-weight:700;letter-spacing:.02em;color:var(--white);}
.brand-word small{display:block;font-family:var(--font-body);font-size:9.5px;letter-spacing:.16em;color:var(--silver-400);margin-top:3px;}

.nav-links{display:flex;align-items:center;gap:38px;}
.nav-links > li{position:relative;}
.nav-links a{
  font-family:var(--font-body);font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--silver-200);padding:10px 0;display:inline-block;position:relative;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:4px;width:0;height:1px;background:var(--white);transition:width .3s var(--ease);}
.nav-links a:hover::after,.nav-links li.open > a::after{width:100%;}
.nav-links a:hover{color:var(--white);}

.has-dropdown > a{display:flex;align-items:center;gap:6px;}
.has-dropdown svg{width:9px;height:9px;transition:transform .3s;}
.has-dropdown.open svg{transform:rotate(180deg);}
.dropdown{
  position:absolute;top:100%;left:50%;transform:translate(-50%,8px);
  min-width:300px;background:var(--white);border-radius:3px;
  box-shadow:var(--shadow-lg);padding:10px;
  opacity:0;visibility:hidden;transition:opacity .25s var(--ease), transform .25s var(--ease);
}
.has-dropdown:hover .dropdown,.has-dropdown.open .dropdown{opacity:1;visibility:visible;transform:translate(-50%,14px);}
.dropdown a{
  display:flex;align-items:center;gap:10px;color:var(--navy-900) !important;
  font-family:var(--font-body);text-transform:none;letter-spacing:0;font-size:14.5px;font-weight:600;
  padding:11px 14px;border-radius:2px;
}
.dropdown a:hover{background:var(--silver-100);}
.dropdown a::after{display:none;}
.dropdown a span.num{font-family:var(--font-body);font-size:10.5px;color:var(--silver-500);font-weight:600;}

.nav-cta{display:flex;align-items:center;gap:20px;}
.nav-cta .btn{display:none;}
@media (min-width:1080px){.nav-cta .btn{display:inline-flex;}}

.burger{
  display:flex;flex-direction:column;justify-content:center;gap:5px;
  width:42px;height:42px;border:1px solid rgba(255,255,255,.25);background:transparent;border-radius:2px;
}
.burger span{height:1.5px;width:18px;background:var(--white);margin:0 auto;transition:.3s;}
@media (min-width:1080px){.burger{display:none;}}
@media (max-width:1079px){.nav-links{display:none;}}

/* Mobile overlay nav */
.mobile-nav{
  position:fixed;inset:0;background:var(--navy-950);z-index:90;
  display:flex;flex-direction:column;
  transform:translateY(-100%);transition:transform .45s var(--ease);
  overflow-y:auto;
}
.mobile-nav.open{transform:translateY(0);}
.mobile-nav-top{display:flex;align-items:center;justify-content:space-between;height:88px;padding:0 28px;border-bottom:1px solid rgba(255,255,255,.08);}
.mobile-nav-close{width:42px;height:42px;border:1px solid rgba(255,255,255,.25);background:transparent;border-radius:2px;color:var(--white);font-size:20px;}
.mobile-nav-links{padding:30px 28px;display:flex;flex-direction:column;}
.mobile-nav-links a{
  font-family:var(--font-display);font-size:30px;text-transform:uppercase;font-weight:700;
  color:var(--white);padding:16px 0;border-bottom:1px solid rgba(255,255,255,.08);
}
.mobile-sub{padding-left:18px;display:flex;flex-direction:column;}
.mobile-sub a{font-family:var(--font-body);font-size:16px;font-weight:600;text-transform:none;padding:11px 0;border-bottom:none;color:var(--silver-300);}
.mobile-nav-foot{margin-top:auto;padding:28px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;}

/* ---------------------------------- Hero --------------------------------- */
.hero{
  position:relative;
  background:var(--navy-gradient);
  overflow:hidden;
  padding-top:clamp(70px,12vw,150px);
  padding-bottom:clamp(60px,9vw,110px);
}
.hero::before{ /* brushed diagonal hairlines */
  content:"";position:absolute;inset:0;opacity:.5;
  background:repeating-linear-gradient(115deg, rgba(255,255,255,.025) 0 1px, transparent 1px 7px);
  pointer-events:none;
}
.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;
}
.hero-copy{max-width:600px;}
.hero-stars{display:flex;align-items:center;gap:10px;color:var(--silver-400);margin-bottom:20px;}
.hero-stars svg{width:13px;height:13px;}
.hero-eyebrow{
  font-family:var(--font-display);font-size:13px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--silver-300);
}
.hero h1{
  font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  font-size:clamp(44px,7.2vw,82px);line-height:1;letter-spacing:.02em;
  color:var(--white);margin-top:18px;
}
.hero h1 .line2{
  background:var(--metal-gradient);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero p.lede{color:var(--silver-300);max-width:520px;}
.hero-ctas{display:flex;flex-wrap:wrap;gap:16px;margin-top:38px;}

.hero-visual{position:relative;height:clamp(360px,46vw,560px);}
.hero-wolf-glow{
  position:absolute;inset:-8%;
  background:radial-gradient(closest-side, rgba(170,177,185,.22), transparent 70%);
  z-index:1;
}
.hero-ring{
  position:absolute;border:1px solid rgba(255,255,255,.08);border-radius:50%;
  top:50%;left:54%;transform:translate(-50%,-50%);
}
.hero-ring.r1{width:112%;height:112%;}
.hero-ring.r2{width:84%;height:84%;border-color:rgba(255,255,255,.12);}
.hero-wolf{
  position:absolute;left:54%;top:50%;transform:translate(-50%,-50%);
  width:min(62%, 420px);
  filter:drop-shadow(0 30px 60px rgba(0,0,0,.55));
  z-index:2;
}
.hero-wolf img{width:100%;}
.scanline{
  position:absolute;left:8%;right:8%;height:2px;top:18%;
  background:linear-gradient(90deg, transparent, rgba(220,226,230,.9), transparent);
  z-index:3;animation:scan 5.5s ease-in-out infinite;
  mix-blend-mode:screen;
}
@keyframes scan{
  0%,100%{top:14%;opacity:0;}
  8%{opacity:.85;}
  50%{top:82%;opacity:.85;}
  58%{opacity:0;}
}
@media (prefers-reduced-motion: reduce){.scanline{display:none;}}

.hero-stats{
  position:relative;z-index:2;
  margin-top:clamp(48px,7vw,84px);
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:34px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.stat b{
  display:block;font-family:var(--font-display);font-weight:700;
  font-size:clamp(22px,3.4vw,40px);color:var(--white);line-height:1.05;
}
.stat span{
  display:block;margin-top:8px;font-family:var(--font-body);font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;color:var(--silver-400);
}

/* ---------------------------------- Credential strip ---------------------- */
.credential-strip{
  background:var(--silver-100);border-bottom:1px solid var(--silver-200);
}
.credential-strip .container{
  display:flex;align-items:center;gap:18px;padding-top:18px;padding-bottom:18px;
  font-family:var(--font-body);font-size:12.5px;color:var(--navy-800);letter-spacing:.02em;
}
.credential-strip svg{width:22px;height:22px;flex:none;color:var(--navy-700);}

/* ---------------------------------- Watermark helper ----------------------- */
.watermark{
  position:absolute;pointer-events:none;z-index:0;opacity:.07;
  filter:grayscale(1);
}
.watermark.dark{opacity:.06;}
.section-relative{position:relative;z-index:1;overflow:hidden;}

/* ---------------------------------- About -------------------------------- */
.about-grid{display:grid;grid-template-columns:1fr .85fr;gap:64px;align-items:start;}
.about-copy p{color:var(--silver-700);line-height:1.75;font-size:16.5px;}
.about-copy p + p{margin-top:16px;}
.cards-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:36px;}
.mv-card{
  background:var(--white);border:1px solid var(--silver-200);border-radius:3px;
  padding:28px 26px;border-top:3px solid transparent;border-image:var(--metal-gradient);border-image-slice:1;
  box-shadow:var(--shadow-sm);
}
.mv-card h4{
  font-family:var(--font-display);font-size:14px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--navy-700);margin-bottom:12px;
}
.mv-card p{color:var(--silver-700);font-size:14.5px;line-height:1.65;}

.about-panel{
  position:relative;border-radius:4px;overflow:hidden;
  min-height:420px;display:flex;align-self:stretch;
  box-shadow:var(--shadow-lg);
  clip-path:polygon(0 0,100% 0,100% 92%,92% 100%,0 100%);
}
.about-panel img.guard-photo{
  width:100%;height:100%;object-fit:cover;object-position:center top;display:block;
}
.about-panel .watermark{width:120%;right:-25%;top:-10%;opacity:.14;}
.about-panel-stat b{
  display:block;font-family:var(--font-display);font-weight:700;
  font-size:clamp(48px,6vw,72px);line-height:1;
  background:var(--metal-gradient);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.about-panel-stat span{
  display:block;margin-top:10px;font-family:var(--font-body);font-size:12px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--silver-300);
}
.about-panel-exp{position:relative;z-index:1;text-align:center;}
.about-panel-shield{
  width:90px;height:90px;
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  background:var(--metal-gradient);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;
}
.about-panel-shield svg{width:46px;height:46px;color:var(--navy-900);}
.about-exp-label{
  font-family:var(--font-display);font-weight:700;font-size:clamp(20px,2.2vw,27px);
  letter-spacing:.01em;text-transform:uppercase;
  background:var(--metal-gradient);-webkit-background-clip:text;background-clip:text;color:transparent;
  margin:0;line-height:1.1;
}
.about-exp-sub{
  font-family:var(--font-display);font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--silver-400);margin:10px 0 0;
}

/* ---------------------------------- Hex badge -------------------------------- */
.hex{
  width:74px;height:84px;flex:none;
  clip-path:polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  background:var(--metal-gradient);
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.5);
}
.hex svg,.hex span{position:relative;z-index:1;}
.hex svg{width:30px;height:30px;color:var(--navy-900);}
.hex.dark{background:var(--navy-800);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);}
.hex.dark svg{color:var(--silver-200);}

/* ---------------------------------- Values -------------------------------- */
.values-section{background:var(--navy-gradient);color:var(--white);padding:clamp(36px,4.5vw,56px) 0;}
.values-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:1px;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.15);
  max-width:1000px;margin:0 auto;
}
.value-tile{
  background:var(--white);padding:20px 14px 16px;
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;
  transition:background .3s var(--ease);cursor:default;
}
.value-tile:hover{background:var(--silver-100);}
.value-tile:hover .val-img{opacity:1;}
.val-svg{width:18px;height:18px;flex:none;color:var(--navy-900);stroke-width:1.7;}
.val-img{width:34px;height:34px;flex:none;object-fit:contain;opacity:1;filter:brightness(0) invert(1) sepia(1) saturate(8) hue-rotate(195deg) brightness(0.38);}
.value-tile:hover .val-img{opacity:1;}
.value-tile .num{display:none;}
.value-tile .name{
  font-family:var(--font-display);font-weight:700;letter-spacing:.01em;text-transform:uppercase;
  font-size:11.5px;color:var(--navy-900);line-height:1.1;
}

/* ---------------------------------- Services -------------------------------- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.service-card{
  background:var(--white);border:1px solid var(--silver-200);border-radius:3px;
  padding:34px 30px;display:flex;flex-direction:column;gap:18px;
  transition:box-shadow .35s var(--ease), transform .35s var(--ease), border-color .35s;
}
.service-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--silver-300);}
.service-card h3{
  font-family:var(--font-display);font-weight:700;font-size:20px;text-transform:uppercase;
  letter-spacing:-.01em;color:var(--navy-900);
}
.service-card > p{color:var(--silver-700);font-size:15px;line-height:1.6;}
.service-card.span-2{grid-column:span 2;}

.svc-toggle{
  margin-top:auto;display:inline-flex;align-items:center;gap:8px;align-self:flex-start;
  font-family:var(--font-display);font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--navy-700);background:none;border:none;padding:0;
}
.svc-toggle svg{width:10px;height:10px;transition:transform .3s;}
.service-card.open .svc-toggle svg{transform:rotate(180deg);}
.svc-detail{
  max-height:0;overflow:hidden;transition:max-height .4s var(--ease);
}
.service-card.open .svc-detail{max-height:600px;}
.svc-detail-inner{padding-top:14px;border-top:1px solid var(--silver-200);margin-top:4px;}
.svc-sub{margin-bottom:16px;}
.svc-sub:last-child{margin-bottom:0;}
.svc-sub h5{
  font-family:var(--font-display);font-size:13px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--navy-800);margin-bottom:6px;
}
.svc-sub p{color:var(--silver-700);font-size:14px;line-height:1.6;margin:0 0 8px;}
.svc-sub ul{display:flex;flex-direction:column;gap:6px;}
.svc-sub li{
  font-size:13.5px;color:var(--silver-700);line-height:1.5;
  display:flex;gap:9px;
}
.svc-sub li::before{content:"";width:6px;height:6px;margin-top:6px;flex:none;background:var(--metal-gradient);}

.svc-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media (max-width:900px){.svc-detail-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:600px){.svc-detail-grid{grid-template-columns:1fr;}}

/* Prevent CSS Grid's default min-width:auto from forcing tracks
   wider than their container (classic mobile overflow trap). */
.services-grid > *, .values-grid > *, .cards-2 > *, .form-row > *,
.contact-grid > *, .footer-top > *, .why-wrap > *, .about-grid > *,
.hero-grid > *, .svc-detail-grid > *{min-width:0;}

/* ---------------------------------- Why us -------------------------------- */
.why-wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:60px;align-items:start;}
.why-list{display:flex;flex-direction:column;}
.why-item{
  display:flex;gap:20px;padding:24px 0;border-bottom:1px solid var(--silver-200);
}
.why-item:first-child{padding-top:0;}
.why-item .idx{
  width:42px;height:42px;flex:none;object-fit:contain;opacity:.75;
  filter:brightness(0) saturate(100%) invert(8%) sepia(50%) saturate(1200%) hue-rotate(195deg) brightness(90%);
}
.why-item h4{
  font-family:var(--font-display);font-weight:700;font-size:17px;text-transform:uppercase;letter-spacing:-.01em;color:var(--navy-900);
}
.why-item p{margin-top:6px;color:var(--silver-700);font-size:14.5px;line-height:1.6;}

/* ---------------------------------- Alliances / CTA band -------------------------------- */
.cta-band{
  background:var(--navy-gradient);color:var(--white);text-align:center;position:relative;overflow:hidden;
}
.cta-band .watermark{width:140%;left:-20%;top:-30%;opacity:.08;}
.cta-band-inner{max-width:760px;margin:0 auto;position:relative;z-index:1;}
.cta-band .section-title{margin-bottom:18px;}
.cta-band .btn-row{display:flex;gap:16px;justify-content:center;margin-top:34px;flex-wrap:wrap;}

/* ---------------------------------- Contact -------------------------------- */
.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:0;border-radius:4px;overflow:hidden;box-shadow:var(--shadow-lg);}
.contact-info{background:var(--navy-gradient);color:var(--white);padding:52px 44px;position:relative;overflow:hidden;}
.contact-info .watermark{width:130%;right:-30%;bottom:-15%;opacity:.08;}
.contact-info-list{margin-top:34px;display:flex;flex-direction:column;gap:28px;position:relative;z-index:1;}
.contact-info-item{display:flex;gap:16px;}
.contact-info-item .hex{width:54px;height:62px;}
.contact-info-item .hex svg{width:22px;height:22px;}
.contact-info-item h4{
  font-family:var(--font-display);font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--silver-400);
}
.contact-info-item p,.contact-info-item a{display:block;margin-top:6px;color:var(--white);font-size:15.5px;line-height:1.55;}
.contact-info-item a:hover{text-decoration:underline;}
.contact-map{margin-top:34px;border:1px solid rgba(255,255,255,.15);position:relative;z-index:1;}
.contact-map iframe{width:100%;height:200px;display:block;filter:grayscale(.3) contrast(1.05);}

.contact-form-wrap{background:var(--white);padding:52px 44px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{margin-bottom:20px;}
.field label{
  display:block;font-family:var(--font-display);font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--silver-600);margin-bottom:8px;
}
.field input,.field textarea{
  width:100%;border:1px solid var(--silver-300);border-radius:2px;padding:13px 14px;
  background:var(--silver-50);font-family:var(--font-body);font-size:15px;color:var(--ink);
  transition:border-color .25s, background .25s;
}
.field input:focus,.field textarea:focus{border-color:var(--navy-600);background:var(--white);outline:none;}
.field textarea{resize:vertical;min-height:120px;}
.form-foot{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:8px;}
.form-note{font-size:12.5px;color:var(--silver-500);}
.form-status{font-size:13.5px;font-family:var(--font-body);margin-top:14px;}
.form-status.ok{color:#1f7a4d;}
.form-status.err{color:#b3402d;}
.hp-field{position:absolute;left:-9999px;opacity:0;}

/* ---------------------------------- Footer -------------------------------- */
.site-footer{background:var(--navy-950);color:var(--silver-400);position:relative;overflow:hidden;}
.site-footer .watermark{width:46%;right:0;bottom:-6%;opacity:.05;}
.footer-top{display:grid;grid-template-columns:1.3fr .8fr .8fr 1fr;gap:48px;padding:var(--section-pad) 0 56px;position:relative;z-index:1;}
.footer-brand{display:flex;align-items:center;gap:14px;margin-bottom:18px;}
.footer-brand img{height:46px;}
.footer-brand b{font-family:var(--font-display);font-size:18px;color:var(--white);letter-spacing:.01em;}
.footer-about p{font-size:14px;line-height:1.7;max-width:320px;color:var(--silver-500);}
.footer-col h5{
  font-family:var(--font-display);font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--silver-300);margin-bottom:18px;
}
.footer-col ul{display:flex;flex-direction:column;gap:12px;}
.footer-col a{font-size:14.5px;color:var(--silver-400);transition:color .2s;}
.footer-col a:hover{color:var(--white);}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding:24px 0;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:13px;color:var(--silver-600);position:relative;z-index:1;
}
.footer-bottom .lang-switch{border-color:rgba(255,255,255,.12);}

/* ---------------------------------- WhatsApp float -------------------------------- */
.float-wa{
  position:fixed;bottom:26px;right:26px;z-index:80;
  width:58px;height:58px;border-radius:50%;
  background:#1fb854;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 30px -8px rgba(31,184,84,.55);
  transition:transform .3s var(--ease);
}
.float-wa:hover{transform:scale(1.08);}
.float-wa svg{width:28px;height:28px;}
.float-wa .ping{
  position:absolute;inset:0;border-radius:50%;background:#1fb854;opacity:.55;
  animation:ping 2.4s ease-out infinite;
}
@keyframes ping{0%{transform:scale(1);opacity:.55;}100%{transform:scale(1.9);opacity:0;}}
@media (prefers-reduced-motion: reduce){.float-wa .ping{display:none;}}

/* ---------------------------------- Reveal animation -------------------------------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease), transform .7s var(--ease);}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;}}

/* ---------------------------------- Divider -------------------------------- */
.angled-top{clip-path:polygon(0 18px,100% 0,100% 100%,0 100%);margin-top:-18px;}

/* ---------------------------------- Responsive -------------------------------- */
@media (max-width:1080px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-visual{order:-1;height:300px;margin-bottom:10px;}
  .hero-wolf{left:50%;width:min(58%,300px);}
  .hero-stats{grid-template-columns:repeat(2,1fr);row-gap:28px;}
  .about-grid{grid-template-columns:1fr;}
  .about-panel{min-height:300px;}
  .values-grid{grid-template-columns:repeat(2,1fr);}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .service-card.span-2{grid-column:span 2;}
  .why-wrap{grid-template-columns:1fr;gap:36px;}
  .contact-grid{grid-template-columns:1fr;}
}
@media (max-width:760px){
  .container{padding:0 20px;}
  .topbar .container{height:auto;flex-direction:column;gap:8px;padding:8px 20px;}
  .topbar-left{flex-wrap:wrap;gap:14px;justify-content:center;}
  .nav{height:76px;}
  .brand img{height:44px;}
  .brand-word b{font-size:17px;}
  .cards-2{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:repeat(2,1fr);}
  .values-grid{grid-template-columns:repeat(3,1fr);}
  .value-tile{padding:16px 10px;}
  .services-grid{grid-template-columns:1fr;}
  .service-card.span-2{grid-column:span 1;}
  .form-row{grid-template-columns:1fr;}
  .contact-info,.contact-form-wrap{padding:38px 26px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px;}
  .footer-about{grid-column:span 2;}
  .hero-stats{grid-template-columns:repeat(2,1fr);}
  .hero-ring{display:none;}
  .btn{white-space:normal;}
}
@media (max-width:480px){
  .footer-top{grid-template-columns:1fr;}
  .footer-about{grid-column:span 1;}
  .float-wa{width:50px;height:50px;bottom:18px;right:18px;}
}

/* ---------------------------------- Careers -------------------------------- */
.careers-wrap{
  display:grid;grid-template-columns:1fr 1.4fr;gap:56px;align-items:start;
}
.careers-text{max-width:400px;}
.careers-email-btn{
  display:inline-flex;align-items:center;gap:10px;margin-top:22px;
  font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--navy-900);background:var(--metal-gradient);
  padding:14px 24px;border-radius:2px;
  box-shadow:0 8px 20px -8px rgba(7,13,24,.25);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.careers-email-btn:hover{transform:translateY(-2px);box-shadow:0 14px 28px -8px rgba(7,13,24,.35);}
.careers-note{
  margin-top:12px;font-size:14px;color:var(--silver-600);font-family:var(--font-display);
  letter-spacing:.04em;
}
.careers-form-wrap{
  background:var(--white);border:1px solid var(--silver-200);border-radius:3px;
  padding:36px 32px;border-top:3px solid transparent;border-image:var(--metal-gradient);border-image-slice:1;
}
.careers-form-title{
  font-family:var(--font-display);font-weight:700;font-size:18px;text-transform:uppercase;
  letter-spacing:-.01em;color:var(--navy-900);margin-bottom:4px;
}
@media(max-width:900px){.careers-wrap{grid-template-columns:1fr;gap:32px;}.careers-text{max-width:100%;}}

/* ---------------------------------- Allies logo strip -------------------------------- */
.allies-strip{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:24px;
  padding:32px 0 0;
  position:relative;z-index:2;
}
.ally-logo{
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  border-radius:6px;
  padding:16px 28px;
  transition:background .3s,transform .3s;
}
.ally-logo:hover{background:rgba(255,255,255,.2);transform:translateY(-2px);}
.ally-logo img{height:64px;width:auto;max-width:120px;object-fit:contain;}

/* ---------------------------------- Services image grid -------------------------------- */
.svc-img-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:8px;
}
.svc-img-card{
  position:relative;height:380px;overflow:hidden;
  border-radius:4px;cursor:pointer;
  box-shadow:var(--shadow-sm);
}
.svc-img-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform .6s var(--ease);
}
.svc-img-card:hover .svc-img-bg{transform:scale(1.07);}
.svc-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(7,13,24,.95) 0%,rgba(7,13,24,.5) 55%,rgba(7,13,24,.15) 100%);
  transition:background .4s;
}
.svc-img-card:hover .svc-img-overlay{
  background:linear-gradient(to top,rgba(7,13,24,.98) 0%,rgba(7,13,24,.6) 55%,rgba(7,13,24,.2) 100%);
}
.svc-img-content{
  position:absolute;bottom:0;left:0;right:0;
  padding:24px 22px;
}
.svc-num-tag{
  font-family:var(--font-body);font-size:11px;letter-spacing:.12em;
  color:var(--silver-400);display:block;margin-bottom:8px;
}
.svc-img-title{
  font-family:var(--font-display);font-weight:700;font-size:17px;
  text-transform:uppercase;letter-spacing:-.01em;color:var(--white);
  line-height:1.15;margin-bottom:10px;
}
.svc-img-desc{
  font-size:13px;line-height:1.55;color:var(--silver-300);
  margin-bottom:14px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.svc-img-link{
  font-family:var(--font-body);font-size:11.5px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--silver-400);
  transition:color .3s,letter-spacing .3s;display:inline-block;
}
.svc-img-card:hover .svc-img-link{color:var(--white);letter-spacing:.12em;}

/* top accent line on hover */
.svc-img-card::after{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--metal-gradient);opacity:0;transition:opacity .4s;
}
.svc-img-card:hover::after{opacity:1;}

@media(max-width:1080px){
  .svc-img-grid{grid-template-columns:repeat(2,1fr);height:auto;}
  .svc-img-card{height:300px;}
}
@media(max-width:640px){
  .svc-img-grid{grid-template-columns:1fr;}
  .svc-img-card{height:260px;}
}

/* ---------------------------------- Pendon services grid -------------------------------- */
.pendon-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.15);
  border-radius:4px;
  overflow:hidden;
}
.pendon-item{
  display:flex;align-items:center;gap:16px;
  padding:20px 24px;
  background:var(--white);
  font-family:var(--font-display);font-weight:700;
  font-size:14px;text-transform:uppercase;letter-spacing:0em;
  color:var(--navy-900);
  text-decoration:none;
  transition:background .25s,color .25s,padding-left .25s;
  cursor:pointer;
}
.pendon-item:hover{background:var(--silver-100);color:var(--navy-950);padding-left:28px;}
.pendon-icon{
  width:42px;height:42px;flex:none;
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  background:var(--navy-900);
  display:flex;align-items:center;justify-content:center;
  transition:transform .25s;
}
.pendon-item:hover .pendon-icon{transform:scale(1.08);}
.pendon-icon svg{width:20px;height:20px;color:var(--white);}

@media(max-width:900px){.pendon-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:540px){
  .pendon-grid{grid-template-columns:repeat(2,1fr);}
  .pendon-item{padding:14px 12px;gap:10px;font-size:11px;letter-spacing:.02em;}
  .pendon-icon{width:32px;height:32px;}
  .pendon-icon svg{width:15px;height:15px;}
}
