/* ════════════════════════════════════════════════════════════
   DESIGN SYSTEM — "Precision Dark"
   Mismo token set que la página de inicio
════════════════════════════════════════════════════════════ */
:root {
  --g:   #1FA463;
  --b:   #1FA0C8;
  --o:   #F1872D;
  --dk:  #0E1A14;
  --dk2: #141F19;
  --dk3: #1B2820;
  --lt:  #F4F7F5;
  --tx:  #E8EEE9;
  --tx2: #8BA694;
  --wh:  #FFFFFF;
  --ff-h: 'Poppins', sans-serif;
  --ff-b: 'Open Sans', sans-serif;
  --r:    12px;
  --r-lg: 20px;
  --ease: cubic-bezier(.4,0,.2,1);
  --t:    .32s;
  --sh:   0 8px 32px rgba(0,0,0,.35);
  --sh-g: 0 8px 40px rgba(31,164,99,.28);
}
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--ff-b); background:var(--dk); color:var(--tx); overflow-x:hidden; }
h1,h2,h3,h4,h5,h6 { font-family:var(--ff-h); }
a { text-decoration:none; }
img { display:block; max-width:100%; }

/* ── UTILITIES ── */
.sp    { padding:100px 0; }
.sp-sm { padding:64px 0; }

.lbl {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--ff-h); font-size:.7rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--g); margin-bottom:16px;
}
.lbl::before { content:''; width:28px; height:2px; background:var(--g); border-radius:2px; }

.hdg {
  font-size:clamp(1.9rem,3.5vw,2.8rem);
  font-weight:800; line-height:1.1; color:var(--wh); margin-bottom:14px;
}
.hdg em { font-style:normal; color:var(--g); }
.sub { font-size:.96rem; color:var(--tx2); line-height:1.8; max-width:560px; }
.divider { width:40px; height:3px; background:linear-gradient(90deg,var(--g),var(--b)); border-radius:2px; margin:16px 0 28px; }

/* Light-section overrides */
.on-light .hdg   { color:var(--dk); }
.on-light .sub   { color:#4a5e52; }
.on-light .lbl   { color:var(--g); }

/* Buttons */
.btn-g {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--g); color:#fff;
  font-family:var(--ff-h); font-weight:600; font-size:.88rem;
  padding:13px 28px; border-radius:50px; border:none;
  transition:all var(--t) var(--ease);
}
.btn-g:hover { background:#168a52; transform:translateY(-2px); box-shadow:var(--sh-g); color:#fff; }
.btn-out {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; color:var(--wh);
  font-family:var(--ff-h); font-weight:600; font-size:.88rem;
  padding:12px 28px; border-radius:50px; border:1.5px solid rgba(255,255,255,.25);
  transition:all var(--t) var(--ease);
}
.btn-out:hover { border-color:var(--g); color:var(--g); transform:translateY(-2px); }
.btn-ghost {
  display:inline-flex; align-items:center; gap:6px;
  color:var(--g); font-family:var(--ff-h); font-weight:600; font-size:.82rem;
  transition:gap var(--t), color var(--t);
}
.btn-ghost:hover { gap:12px; color:#168a52; }

/* ════════════════════════════════════════════════════════════
   NAVBAR — exact replica from homepage
════════════════════════════════════════════════════════════ */
#nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:20px 0;
  transition:padding var(--t) var(--ease), background var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
#nav.stuck {
  background:rgba(14,26,20,.95);
  backdrop-filter:blur(20px);
  padding:12px 0;
  box-shadow:0 1px 0 rgba(31,164,99,.15), 0 8px 32px rgba(0,0,0,.4);
}
.nav-logo { display:flex; align-items:center; gap:12px; }
/* Nuevo estilo para tu logo en imagen */
.site-logo {
  height: 46px; /* Misma altura que pusimos en el index */
  width: auto;
  display: block;
  transition: height var(--t) var(--ease);
}

/* Reducir tamaño del logo al hacer scroll */
#nav.stuck .site-logo {
  height: 40px; 
}
.logo-name { font-family:var(--ff-h); font-weight:700; font-size:.86rem; color:var(--wh); line-height:1.2; }
.logo-name small { display:block; font-weight:300; font-size:.68rem; color:rgba(255,255,255,.5); letter-spacing:.06em; }
.navbar-nav .nav-link {
  font-family:var(--ff-h); font-size:.84rem; font-weight:500;
  color:rgba(255,255,255,.75) !important; padding:6px 12px !important;
  position:relative; transition:color var(--t);
}
.navbar-nav .nav-link::after {
  content:''; position:absolute; bottom:-2px; left:12px;
  width:0; height:2px; background:var(--g); border-radius:2px;
  transition:width var(--t) var(--ease);
}
.navbar-nav .nav-link:hover { color:var(--wh) !important; }
.navbar-nav .nav-link:hover::after, .navbar-nav .nav-link.active::after { width:calc(100% - 24px); }
.nav-cta {
  font-family:var(--ff-h); font-weight:600; font-size:.82rem;
  color:#fff !important; background:var(--g);
  padding:8px 20px !important; border-radius:50px !important;
  transition:background var(--t), transform var(--t), box-shadow var(--t) !important;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { background:#168a52 !important; transform:translateY(-2px); box-shadow:var(--sh-g) !important; }
.navbar-toggler { border:1.5px solid rgba(255,255,255,.25) !important; padding:6px 10px !important; }
.navbar-toggler-icon {
  background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,255,255,0.8)' stroke-width='2' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}
@media(max-width:991px){
  .navbar-collapse {
    margin-top:10px; background:rgba(14,26,20,.97);
    border-radius:var(--r); padding:20px; box-shadow:var(--sh);
    border:1px solid rgba(31,164,99,.15);
  }
}

/* ════════════════════════════════════════════════════════════
   PAGE HERO — servicios
════════════════════════════════════════════════════════════ */
#page-hero {
  min-height:52vh; padding-top:100px;
  position:relative; overflow:hidden;
  display:flex; align-items:center;
  background:var(--dk);
}
.ph-bg {
  position:absolute; inset:0;
  background:url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?w=1800&q=80') center/cover no-repeat;
  animation:phZoom 14s ease-in-out infinite alternate;
  will-change:transform;
}
@keyframes phZoom {
  from { transform:scale(1.04); }
  to   { transform:scale(1.09); }
}
.ph-ov {
  position:absolute; inset:0;
  background:linear-gradient(105deg,rgba(8,18,13,.94) 0%,rgba(10,22,30,.82) 60%,rgba(0,0,0,.55) 100%);
}
.ph-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(31,164,99,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,164,99,.05) 1px, transparent 1px);
  background-size:60px 60px;
  animation:gridMove 40s linear infinite;
}
@keyframes gridMove {
  from { background-position:0 0; }
  to   { background-position:60px 60px; }
}
.ph-glow {
  position:absolute; pointer-events:none;
  top:-20%; left:-5%; width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle,rgba(31,164,99,.10) 0%,transparent 65%);
}
.ph-inner { position:relative; z-index:2; }

/* Breadcrumb */
.breadcrumb { background:none; padding:0; margin-bottom:14px; }
.breadcrumb-item { font-family:var(--ff-h); font-size:.75rem; color:var(--tx2); }
.breadcrumb-item a { color:var(--tx2); transition:color var(--t); }
.breadcrumb-item a:hover { color:var(--g); }
.breadcrumb-item.active { color:var(--g); }
.breadcrumb-item+.breadcrumb-item::before { color:rgba(255,255,255,.2); }

.ph-tag {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-h); font-size:.7rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--g); margin-bottom:20px;
  padding:7px 16px; border-radius:50px;
  border:1px solid rgba(31,164,99,.3); background:rgba(31,164,99,.08);
}
.ph-h1 {
  font-size:clamp(2.2rem,5.5vw,4rem);
  font-weight:900; color:var(--wh); line-height:1.08;
  margin-bottom:18px;
}
.ph-h1 em { font-style:normal; color:var(--g); }
.ph-p { font-size:1.06rem; color:rgba(255,255,255,.65); line-height:1.85; max-width:520px; }

/* Diagonal cut bottom */
.ph-cut {
  position:absolute; bottom:-1px; left:0; right:0;
  height:72px; background:var(--dk2);
  clip-path:polygon(0 100%, 100% 100%, 100% 0);
}

/* ════════════════════════════════════════════════════════════
   INTRO STRIP
════════════════════════════════════════════════════════════ */
#intro { background:var(--dk2); }

.intro-strip {
  display:grid;
  grid-template-columns:1fr 1px 1fr 1px 1fr;
  gap:0;
  background:var(--dk3);
  border-radius:var(--r-lg);
  border:1px solid rgba(255,255,255,.07);
  overflow:hidden;
}
.intro-strip .col-sep { background:rgba(255,255,255,.06); width:1px; }
.intro-stat {
  padding:32px 36px;
  transition:background var(--t);
}
.intro-stat:hover { background:rgba(31,164,99,.06); }
.intro-stat .n {
  font-family:var(--ff-h); font-size:2.4rem; font-weight:800; line-height:1;
  background:linear-gradient(90deg,var(--g),var(--b));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  margin-bottom:6px;
}
.intro-stat .l { font-size:.82rem; color:var(--tx2); line-height:1.4; }
@media(max-width:767px){
  .intro-strip { grid-template-columns:1fr; }
  .intro-strip .col-sep { width:100%; height:1px; }
}

/* ════════════════════════════════════════════════════════════
   SERVICE BLOCKS — alternating layout
════════════════════════════════════════════════════════════ */
#services-main { background:var(--dk); }

/* Service anchor target offset for navbar */
.svc-anchor { display:block; height:80px; margin-top:-80px; visibility:hidden; }

/* ── Image placeholder ── */
.svc-img-ph {
  width:100%; aspect-ratio:4/3;
  border-radius:var(--r-lg);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:12px; color:rgba(255,255,255,.2); font-size:.82rem;
  position:relative; overflow:hidden;
  transition:transform .5s var(--ease);
}
.svc-img-ph i { font-size:3rem; }
.svc-img-ph.c1 { background:linear-gradient(135deg,#0d2018,#102030); }
.svc-img-ph.c2 { background:linear-gradient(135deg,#0d1e30,#101828); }
.svc-img-ph.c3 { background:linear-gradient(135deg,#1a1a0e,#201808); }
.svc-img-ph.c4 { background:linear-gradient(135deg,#0e1e18,#0c1624); }

.svc-img-wrap {
  position:relative; border-radius:var(--r-lg); overflow:hidden;
  box-shadow:0 24px 64px rgba(0,0,0,.4);
}
.svc-img-wrap:hover .svc-img-ph { transform:scale(1.04); }
/* Glow border on hover */
.svc-img-wrap::after {
  content:''; position:absolute; inset:0; border-radius:var(--r-lg);
  border:1.5px solid rgba(31,164,99,0); transition:border-color var(--t);
  pointer-events:none;
}
.svc-img-wrap:hover::after { border-color:rgba(31,164,99,.4); }

/* Tag badge on image */
.img-badge {
  position:absolute; bottom:16px; left:16px;
  background:rgba(14,26,20,.9); backdrop-filter:blur(12px);
  border:1px solid rgba(31,164,99,.25);
  border-radius:50px; padding:8px 18px;
  font-family:var(--ff-h); font-size:.72rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--g);
  display:flex; align-items:center; gap:8px;
}
.img-badge::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--g); }

/* Text block */
.svc-num {
  font-family:var(--ff-h); font-weight:900; font-size:.72rem;
  letter-spacing:.2em; color:var(--g); margin-bottom:10px; display:block;
}
.svc-title {
  font-size:clamp(1.7rem,3vw,2.4rem); font-weight:800;
  color:var(--wh); line-height:1.1; margin-bottom:14px;
}
.svc-desc {
  font-size:.95rem; color:var(--tx2); line-height:1.85; margin-bottom:28px;
}

/* Sub-services list */
.sub-list { list-style:none; padding:0; margin-bottom:28px; }
.sub-list li {
  display:flex; align-items:flex-start; gap:12px;
  padding:12px 0; border-bottom:1px solid rgba(255,255,255,.06);
  font-size:.9rem; color:var(--tx);
  transition:color var(--t), padding-left var(--t);
  cursor:default;
}
.sub-list li:last-child { border-bottom:none; }
.sub-list li:hover { color:var(--g); padding-left:4px; }
.sub-list li .ico {
  width:34px; height:34px; border-radius:8px;
  background:rgba(31,164,99,.12); color:var(--g);
  display:flex; align-items:center; justify-content:center;
  font-size:.88rem; flex-shrink:0; transition:all var(--t);
}
.sub-list li:hover .ico { background:var(--g); color:#fff; }
.sub-list li .txt h6 {
  font-family:var(--ff-h); font-weight:600; font-size:.88rem;
  color:inherit; margin:0 0 2px;
}
.sub-list li .txt p { font-size:.78rem; color:var(--tx2); margin:0; }

/* Separator between services */
.svc-sep {
  height:1px; background:rgba(255,255,255,.06); margin:80px 0;
}
.svc-sep.colored {
  background:linear-gradient(90deg,transparent,rgba(31,164,99,.3),rgba(31,160,200,.3),transparent);
}

/* ════════════════════════════════════════════════════════════
   MINI-CARDS GRID — for Servicios Generales
════════════════════════════════════════════════════════════ */
.mini-card {
  background:var(--dk3); border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r); padding:24px 20px;
  transition:all var(--t) var(--ease);
  height:100%;
}
.mini-card:hover {
  transform:translateY(-6px);
  border-color:rgba(31,164,99,.35);
  box-shadow:0 16px 40px rgba(0,0,0,.35);
}
.mini-icon {
  width:52px; height:52px; border-radius:12px;
  background:rgba(31,164,99,.12); color:var(--g);
  display:flex; align-items:center; justify-content:center;
  font-size:1.35rem; margin-bottom:14px;
  transition:all var(--t);
}
.mini-card:hover .mini-icon { background:var(--g); color:#fff; transform:rotate(-6deg) scale(1.08); }
.mini-card h6 {
  font-family:var(--ff-h); font-weight:700; font-size:.9rem;
  color:var(--wh); margin-bottom:6px;
}
.mini-card p { font-size:.8rem; color:var(--tx2); line-height:1.6; margin:0; }

/* ════════════════════════════════════════════════════════════
   CTA BANNER
════════════════════════════════════════════════════════════ */
#cta { background:var(--dk2); }
.cta-inner {
  background:linear-gradient(105deg,#0d2018 0%,#0c1e2c 100%);
  border-radius:24px; padding:72px 60px;
  position:relative; overflow:hidden;
  border:1px solid rgba(31,164,99,.18);
}
.cta-inner::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(31,164,99,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,164,99,.05) 1px, transparent 1px);
  background-size:40px 40px;
}
.cta-glow {
  position:absolute; top:-50%; left:-10%;
  width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle,rgba(31,164,99,.15),transparent 60%);
  pointer-events:none;
}
.cta-glow.r { left:auto; right:-10%; top:auto; bottom:-50%;
  background:radial-gradient(circle,rgba(31,160,200,.12),transparent 60%); }
@media(max-width:767px){ .cta-inner { padding:48px 28px; } }

/* ════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════ */
footer {
  background:#07110D; padding:72px 0 0;
  border-top:1px solid rgba(31,164,99,.12);
}
.ft-logo { display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.ft-desc { font-size:.875rem; color:var(--tx2); line-height:1.8; margin-bottom:24px; max-width:280px; }
footer h6 {
  font-family:var(--ff-h); font-size:.7rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,.3); margin-bottom:18px;
}
footer ul { list-style:none; padding:0; }
footer ul li { margin-bottom:8px; }
footer ul li a {
  font-size:.875rem; color:var(--tx2);
  transition:color var(--t), padding-left var(--t); display:inline-block;
}
footer ul li a:hover { color:var(--g); padding-left:6px; }
.ft-contact-item { display:flex; align-items:flex-start; gap:12px; margin-bottom:14px; }
.ft-ico {
  width:34px; height:34px; border-radius:8px;
  background:rgba(31,164,99,.12); color:var(--g);
  display:flex; align-items:center; justify-content:center; font-size:.85rem; flex-shrink:0;
}
.ft-contact-item p { font-size:.84rem; color:var(--tx2); margin:0; line-height:1.5; }
.social-row { display:flex; gap:10px; margin-top:16px; }
.soc {
  width:38px; height:38px; border-radius:9px;
  background:rgba(255,255,255,.06); color:rgba(255,255,255,.5);
  display:flex; align-items:center; justify-content:center; font-size:.95rem;
  transition:all var(--t) var(--ease);
}
.soc:hover { background:var(--g); color:#fff; transform:translateY(-3px) scale(1.05); }
.ft-bottom {
  margin-top:52px; padding:20px 0;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; gap:8px;
  font-size:.78rem; color:rgba(255,255,255,.28);
}

/* ════════════════════════════════════════════════════════════
   WHATSAPP FAB
════════════════════════════════════════════════════════════ */
.wa-fab {
  position:fixed; bottom:26px; right:26px; z-index:9999;
  width:56px; height:56px; border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem;
  box-shadow:0 6px 24px rgba(37,211,102,.5), 0 0 0 0 rgba(37,211,102,.5);
  animation:waRing 3s ease-in-out infinite;
  transition:transform var(--t), box-shadow var(--t);
}
@keyframes waRing {
  0%  { box-shadow:0 6px 24px rgba(37,211,102,.5), 0 0 0 0 rgba(37,211,102,.45); }
  60% { box-shadow:0 6px 24px rgba(37,211,102,.5), 0 0 0 18px rgba(37,211,102,.0); }
  100%{ box-shadow:0 6px 24px rgba(37,211,102,.5), 0 0 0 0 rgba(37,211,102,.0); }
}
.wa-fab:hover { transform:scale(1.12); box-shadow:0 10px 32px rgba(37,211,102,.65); color:#fff; animation:none; }
.wa-tip {
  position:absolute; right:66px;
  background:#07110D; color:var(--wh);
  font-family:var(--ff-h); font-size:.76rem; font-weight:600;
  padding:7px 14px; border-radius:8px; white-space:nowrap;
  border:1px solid rgba(31,164,99,.25);
  pointer-events:none; opacity:0;
  transition:opacity var(--t), right var(--t);
}
.wa-tip::after {
  content:''; position:absolute; right:-6px; top:50%; transform:translateY(-50%);
  border:6px solid transparent; border-left-color:#07110D;
}
.wa-fab:hover .wa-tip { opacity:1; right:70px; }

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════════ */
@media(max-width:991px){ .svc-sep { margin:56px 0; } }
@media(max-width:575px){
  .sp { padding:72px 0; }
  .ph-h1 { font-size:2rem; }
  .wa-fab { bottom:18px; right:18px; width:50px; height:50px; font-size:1.4rem; }
}

/* ═══════════════════════════════════════════════════════════
   REDES SOCIALES PREMIUM (Colores oficiales)
═══════════════════════════════════════════════════════════ */
.social-link {
  width: 38px; 
  height: 38px;
  display: inline-flex; 
  align-items: center; 
  justify-content: center;
  border-radius: 8px;
  background: rgba(255,255,255,.04) !important;
  color: rgba(255,255,255,.6) !important;
  font-size: 1.15rem;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  text-decoration: none;
  border: 1px solid transparent;
}

/* Efecto de elevación base */
.social-link:hover {
  color: #ffffff !important;
  transform: translateY(-3px);
}

/* Colores por red social */
.social-link.facebook:hover { 
  background: #1877F2 !important; 
  box-shadow: 0 4px 12px rgba(24,119,242,.3); 
}
.social-link.instagram:hover { 
  background: #E4405F !important; 
  box-shadow: 0 4px 12px rgba(228,64,95,.3); 
}
.social-link.linkedin:hover { 
  background: #0A66C2 !important; 
  box-shadow: 0 4px 12px rgba(10,102,194,.3); 
}
.social-link.youtube:hover { 
  background: #FF0000 !important; 
  box-shadow: 0 4px 12px rgba(255,0,0,.3); 
}