:root{--color-primary:#0a2a5e;--color-secondary:#1a4a8a;--color-accent:#3a7bd5;--color-bg:#ffffff;--color-bg-alt:#f5f7fa;--color-text:#1a1a2e;--color-text-light:#5a6172;--color-border:#dfe3ea;--color-dark:#0c1b33;--font-heading:'Montserrat',sans-serif;--font-body:'Montserrat',sans-serif}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{color-scheme:light;scroll-behavior:smooth}section[id]{scroll-margin-top:80px}body{font-family:var(--font-body);font-size:1rem;line-height:1.7;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,a,input,textarea,select{touch-action:manipulation;-webkit-tap-highlight-color:transparent}a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}img{max-width:100%;height:auto;display:block}h1,h2,h3,h4{font-family:var(--font-heading);line-height:1.2;text-wrap:balance}h1{font-size:3rem;font-weight:800;letter-spacing:2px}h2{font-size:2.25rem;font-weight:700;letter-spacing:1.5px}h3{font-size:1.35rem;font-weight:600}p{font-size:1.05rem;line-height:1.75}.container{max-width:1200px;margin:0 auto;padding:0 20px}.skip-link{position:absolute;top:-100%;left:0;z-index:9999;background:var(--color-primary);color:#fff;padding:12px 24px;font-family:var(--font-heading);font-size:0.9rem;text-decoration:none}.skip-link:focus{top:0}.navbar{position:fixed;top:0;left:0;width:100%;z-index:1000;transition:background-color 0.4s ease,box-shadow 0.4s ease}.navbar.scrolled{background-color:rgba(255,255,255,0.98);box-shadow:0 2px 20px rgba(0,0,0,0.08)}.navbar-inner{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:80px}.navbar-logo img{height:55px;width:auto;transition:filter 0.3s ease}.navbar:not(.scrolled) .navbar-logo img{filter:brightness(0) invert(1)}.nav-links{display:flex;align-items:center;gap:32px;list-style:none}.nav-links a{font-family:var(--font-heading);font-size:0.85rem;font-weight:600;text-decoration:none;color:#fff;letter-spacing:1px;text-transform:uppercase;position:relative;transition:color 0.3s ease}.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--color-accent);transition:width 0.3s ease}.nav-links a:hover::after{width:100%}.navbar.scrolled .nav-links a{color:var(--color-text)}.navbar.scrolled .nav-links a:hover{color:var(--color-primary)}.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;z-index:1001}.hamburger span{display:block;width:24px;height:2px;background:#fff;margin:6px 0;transition:transform 0.3s ease,opacity 0.3s ease}.navbar.scrolled .hamburger span{background:var(--color-text)}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,6px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-6px)}.hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden}.hero-bg{position:absolute;top:0;left:0;width:100%;height:120%;background:url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?w=1400&q=80') center center/cover no-repeat;z-index:0;will-change:transform}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(10,42,94,0.75),rgba(12,27,51,0.85));z-index:1}.hero-shape-1{position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(58,123,213,0.08);filter:blur(80px);top:10%;left:-5%;z-index:2;animation:float 7s ease-in-out infinite}.hero-shape-2{position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,0.05);filter:blur(60px);bottom:15%;right:5%;z-index:2;animation:float 9s ease-in-out infinite 1s}.hero-shape-3{position:absolute;width:150px;height:150px;border-radius:50%;background:rgba(58,123,213,0.06);filter:blur(70px);top:50%;right:25%;z-index:2;animation:float 8s ease-in-out infinite 0.5s}@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(3deg)}}.hero-content{position:relative;z-index:3;text-align:center;max-width:800px;padding:0 24px}.hero-content h1{color:#fff;margin-bottom:20px;animation:fadeInUp 0.8s ease forwards;opacity:0}.hero-content .hero-subtitle{color:rgba(255,255,255,0.88);font-size:1.15rem;font-family:var(--font-body);font-weight:400;margin-bottom:16px;animation:fadeInUp 0.8s ease 0.2s forwards;opacity:0}.hero-content .hero-tagline{color:rgba(255,255,255,0.7);font-size:0.95rem;font-family:var(--font-heading);font-weight:500;letter-spacing:3px;text-transform:uppercase;margin-bottom:40px;animation:fadeInUp 0.8s ease 0.35s forwards;opacity:0}@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.btn-primary{display:inline-block;background:var(--color-accent);color:#fff;font-family:var(--font-heading);font-size:1rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:16px 40px;border:none;border-radius:4px;text-decoration:none;cursor:pointer;transition:background-color 0.3s ease,transform 0.3s ease,box-shadow 0.3s ease;animation:fadeInUp 0.8s ease 0.5s forwards,pulse 2.5s infinite 1.5s;opacity:0}.btn-primary:hover{background:var(--color-secondary);transform:translateY(-2px)}@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(58,123,213,0.4)}50%{box-shadow:0 0 20px 4px rgba(58,123,213,0.15)}}.btn-secondary{display:inline-block;background:transparent;color:var(--color-primary);font-family:var(--font-heading);font-size:0.95rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:14px 36px;border:2px solid var(--color-primary);border-radius:4px;text-decoration:none;cursor:pointer;transition:background-color 0.3s ease,color 0.3s ease,transform 0.3s ease}.btn-secondary:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px)}.section-separator{height:1px;background:linear-gradient(to right,transparent,rgba(10,42,94,0.15),transparent);border:none}.section-title{text-align:center;margin-bottom:56px}.section-title h2{color:var(--color-primary);margin-bottom:16px;position:relative;display:inline-block}.section-title h2::after{content:'';display:block;width:60px;height:3px;background:var(--color-accent);margin:16px auto 0}.section-title p{color:var(--color-text-light);max-width:600px;margin:0 auto;font-size:1.05rem}.porque{padding:100px 0;background:var(--color-bg);position:relative;overflow:hidden}.porque-shape{position:absolute;width:250px;height:250px;border-radius:50%;background:rgba(58,123,213,0.04);filter:blur(80px);animation:float 8s ease-in-out infinite}.porque-shape-1{top:-50px;right:-80px}.porque-shape-2{bottom:-60px;left:-60px;animation-delay:2s}.porque-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative;z-index:1}.porque-card{background:#fff;border:1px solid var(--color-border);border-radius:6px;padding:40px 28px;text-align:center;transition:transform 0.4s ease,box-shadow 0.4s ease,border-color 0.4s ease}.porque-card:hover{transform:translateY(-8px);box-shadow:0 16px 40px rgba(10,42,94,0.1);border-color:var(--color-accent)}.porque-card .card-icon{width:56px;height:56px;background:rgba(10,42,94,0.06);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.porque-card .card-icon .material-icons{font-size:26px;color:var(--color-primary)}.porque-card h3{color:var(--color-primary);margin-bottom:12px;font-size:1.1rem}.porque-card p{color:var(--color-text-light);font-size:0.95rem;line-height:1.65}.counters{padding:64px 0;background:var(--color-primary);position:relative}.counters-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}.counter-item{padding:24px 16px}.counter-number{font-family:var(--font-heading);font-size:2.75rem;font-weight:800;color:#fff;display:block;font-variant-numeric:tabular-nums}.counter-label{font-family:var(--font-heading);font-size:0.8rem;font-weight:500;color:rgba(255,255,255,0.7);letter-spacing:2px;text-transform:uppercase;margin-top:8px}.proceso{padding:100px 0;background:var(--color-bg-alt);position:relative;overflow:hidden}.proceso-shape{position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(10,42,94,0.03);filter:blur(70px);top:20%;right:-40px;animation:float 7s ease-in-out infinite 1s}.proceso-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}.proceso-image{border-radius:8px;overflow:hidden}.proceso-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease;border-radius:8px}.proceso-image:hover img{transform:scale(1.03)}.proceso-text h2{color:var(--color-primary);margin-bottom:24px}.proceso-text h2::after{content:'';display:block;width:60px;height:3px;background:var(--color-accent);margin-top:16px}.proceso-text p{color:var(--color-text-light);margin-bottom:16px}.proceso-text .importadores{display:inline-block;font-family:var(--font-heading);font-weight:700;font-size:0.85rem;letter-spacing:2px;text-transform:uppercase;color:var(--color-primary);border:2px solid var(--color-primary);padding:10px 24px;margin-top:16px;border-radius:4px}.timeline{margin-top:32px}.timeline-item{display:flex;gap:20px;margin-bottom:28px;align-items:flex-start}.timeline-number{flex-shrink:0;width:40px;height:40px;background:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:700;font-size:0.9rem}.timeline-content h3{color:var(--color-primary);margin-bottom:4px;font-size:1.1rem}.timeline-content p{color:var(--color-text-light);font-size:0.95rem}.servicios{padding:100px 0;background:var(--color-bg);position:relative;overflow:hidden}.servicios-shape{position:absolute;width:280px;height:280px;border-radius:50%;background:rgba(58,123,213,0.03);filter:blur(90px);bottom:-80px;left:-60px;animation:float 9s ease-in-out infinite}.servicios-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;position:relative;z-index:1}.servicio-card{background:#fff;border:1px solid var(--color-border);border-radius:6px;overflow:hidden;transition:transform 0.4s ease,box-shadow 0.4s ease,border-color 0.4s ease}.servicio-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(10,42,94,0.1);border-color:var(--color-accent)}.servicio-card-img{overflow:hidden;height:220px}.servicio-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}.servicio-card:hover .servicio-card-img img{transform:scale(1.05)}.servicio-card-body{padding:28px 24px}.servicio-card-body .material-icons{font-size:28px;color:var(--color-accent);margin-bottom:12px}.servicio-card-body h3{color:var(--color-primary);margin-bottom:10px}.servicio-card-body p{color:var(--color-text-light);font-size:0.95rem;line-height:1.65;margin-bottom:20px}.servicio-card-body a{font-family:var(--font-heading);font-size:0.85rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--color-accent);text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:color 0.3s ease,gap 0.3s ease}.servicio-card-body a:hover{color:var(--color-primary);gap:10px}.servicio-card-body a .material-icons{font-size:18px;margin-bottom:0}.galeria{padding:100px 0;background:var(--color-bg-alt);position:relative;overflow:hidden}.galeria::before{content:'';position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(10,42,94,0.03),transparent 60%);top:10%;left:20%;pointer-events:none}.galeria-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;position:relative;z-index:1}.galeria-item{border-radius:6px;overflow:hidden;aspect-ratio:4/3}.galeria-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}.galeria-item:hover img{transform:scale(1.08)}.testimonios{padding:100px 0;background:var(--color-bg);position:relative;overflow:hidden}.testimonios-shape{position:absolute;width:220px;height:220px;border-radius:50%;background:rgba(58,123,213,0.04);filter:blur(70px);top:30%;left:-50px;animation:float 8s ease-in-out infinite 0.5s}.testimonios-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;position:relative;z-index:1}.testimonio-card{background:#fff;border:1px solid var(--color-border);border-radius:6px;padding:36px 28px;transition:transform 0.4s ease,box-shadow 0.4s ease,border-color 0.4s ease}.testimonio-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(10,42,94,0.08);border-color:var(--color-accent)}.testimonio-quote{font-family:var(--font-heading);font-size:3rem;font-weight:800;color:var(--color-accent);line-height:1;opacity:0.3;margin-bottom:-12px}.testimonio-text{color:var(--color-text-light);font-size:0.95rem;font-style:italic;line-height:1.7;margin-bottom:20px}.testimonio-stars{margin-bottom:16px;display:flex;gap:2px}.testimonio-stars .material-icons{font-size:18px;color:#f5a623}.testimonio-author{display:flex;align-items:center;gap:14px}.testimonio-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.testimonio-name{font-family:var(--font-heading);font-weight:600;font-size:0.95rem;color:var(--color-text)}.testimonio-role{font-size:0.82rem;color:var(--color-text-light)}.faq{padding:100px 0;background:var(--color-bg-alt)}.faq-list{max-width:780px;margin:0 auto}.faq-item{border-bottom:1px solid var(--color-border)}.faq-question{width:100%;background:none;border:none;padding:24px 0;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-family:var(--font-heading);font-size:1.05rem;font-weight:600;color:var(--color-text);text-align:left;transition:color 0.3s ease}.faq-question:hover{color:var(--color-primary)}.faq-question .material-icons{font-size:24px;color:var(--color-accent);transition:transform 0.3s ease}.faq-question[aria-expanded="true"] .material-icons{transform:rotate(180deg)}.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s ease,padding 0.4s ease}.faq-answer-inner{padding:0 0 24px;color:var(--color-text-light);font-size:0.95rem;line-height:1.7}.contacto{padding:100px 0;background:var(--color-bg);position:relative;overflow:hidden}.contacto-shape{position:absolute;width:250px;height:250px;border-radius:50%;background:rgba(10,42,94,0.03);filter:blur(80px);bottom:-40px;right:-60px;animation:float 7s ease-in-out infinite}.contacto-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;position:relative;z-index:1}.contacto-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-family:var(--font-heading);font-size:0.82rem;font-weight:600;color:var(--color-text);letter-spacing:0.5px;text-transform:uppercase}.form-group input,.form-group textarea{font-family:var(--font-body);font-size:1rem;padding:14px 16px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-alt);color:var(--color-text);transition:border-color 0.3s ease,box-shadow 0.3s ease}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(58,123,213,0.1);outline:none}.form-group textarea{resize:vertical;min-height:120px}.form-submit{background:var(--color-primary);color:#fff;font-family:var(--font-heading);font-size:0.95rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:16px 40px;border:none;border-radius:4px;cursor:pointer;transition:background-color 0.3s ease,transform 0.3s ease;align-self:flex-start}.form-submit:hover{background:var(--color-secondary);transform:translateY(-2px)}.form-success{display:none;background:rgba(39,174,96,0.1);border:1px solid rgba(39,174,96,0.3);color:#27ae60;padding:16px 20px;border-radius:4px;font-family:var(--font-heading);font-weight:500;font-size:0.95rem}.contacto-info{display:flex;flex-direction:column;gap:24px}.contacto-info h3{color:var(--color-primary);margin-bottom:8px;font-size:1.25rem}.contacto-info-desc{color:var(--color-text-light);font-size:0.95rem;margin-bottom:8px}.info-item{display:flex;align-items:flex-start;gap:16px}.info-item .icon-wrap{flex-shrink:0;width:44px;height:44px;background:rgba(10,42,94,0.06);border-radius:50%;display:flex;align-items:center;justify-content:center}.info-item .icon-wrap .material-icons{font-size:22px;color:var(--color-primary)}.info-item .icon-wrap .fab{font-size:20px;color:var(--color-primary)}.info-item-text{display:flex;flex-direction:column}.info-item-label{font-family:var(--font-heading);font-weight:600;font-size:0.85rem;letter-spacing:0.5px;text-transform:uppercase;color:var(--color-text)}.info-item-value{color:var(--color-text-light);font-size:0.95rem}.info-item-value a{color:var(--color-accent);text-decoration:none;transition:color 0.3s ease}.info-item-value a:hover{color:var(--color-primary)}.contacto-map{margin-top:8px;border-radius:8px;overflow:hidden}.footer{background:var(--color-dark);color:rgba(255,255,255,0.75);padding:80px 0 0}.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.1)}.footer-brand img{height:50px;width:auto;margin-bottom:16px;filter:brightness(0) invert(1)}.footer-brand p{font-size:0.9rem;line-height:1.7;color:rgba(255,255,255,0.6)}.footer h4{color:#fff;font-size:0.85rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:20px}.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px}.footer-links a{color:rgba(255,255,255,0.6);text-decoration:none;font-size:0.9rem;transition:color 0.3s ease}.footer-links a:hover{color:#fff}.footer-social{display:flex;gap:12px;margin-top:8px}.footer-social a{width:40px;height:40px;background:rgba(255,255,255,0.08);border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:background-color 0.3s ease,transform 0.3s ease}.footer-social a:hover{background:var(--color-accent);transform:translateY(-3px)}.footer-social a i{color:#fff;font-size:18px}.footer-bottom{padding:24px 0;text-align:center;font-size:0.82rem;color:rgba(255,255,255,0.45)}.footer-bottom a{color:var(--color-accent);text-decoration:none}.whatsapp-float{position:fixed;bottom:24px;right:24px;width:60px;height:60px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:999;text-decoration:none;box-shadow:0 4px 16px rgba(37,211,102,0.4);animation:whatsappPulse 2s infinite;transition:transform 0.3s ease}.whatsapp-float:hover{transform:scale(1.1)}.whatsapp-float i{color:#fff;font-size:30px}@keyframes whatsappPulse{0%,100%{box-shadow:0 4px 16px rgba(37,211,102,0.4)}50%{box-shadow:0 4px 28px rgba(37,211,102,0.6)}}.reveal{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease,transform 0.6s ease}.reveal.visible{opacity:1;transform:translateY(0)}@media (max-width:1024px){.porque-grid{grid-template-columns:repeat(2,1fr)}.counters-grid{grid-template-columns:repeat(2,1fr);gap:16px}.servicios-grid{grid-template-columns:repeat(2,1fr)}.galeria-grid{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){h1{font-size:2.25rem}h2{font-size:1.75rem}.nav-links{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:var(--color-dark);flex-direction:column;align-items:flex-start;padding:100px 32px 40px;gap:24px;transition:right 0.3s ease;overscroll-behavior:contain}.nav-links.open{right:0}.nav-links a{color:rgba(255,255,255,0.9);font-size:0.95rem}.hamburger{display:block}.proceso-layout{grid-template-columns:1fr;gap:40px}.proceso-image{order:-1}.servicios-grid{grid-template-columns:1fr;max-width:500px;margin:0 auto}.galeria-grid{grid-template-columns:1fr}.testimonios-grid{grid-template-columns:1fr;max-width:500px;margin:0 auto}.contacto-grid{grid-template-columns:1fr;gap:48px}.footer-grid{grid-template-columns:1fr;gap:32px}.porque-grid{grid-template-columns:repeat(2,1fr);gap:12px;max-width:none;margin:0}.porque-card{padding:22px 14px}.porque-card .card-icon{width:46px;height:46px;margin:0 auto 14px}.porque-card .card-icon .material-icons{font-size:22px}.porque-card h3{font-size:1rem;margin-bottom:8px}.porque-card p{font-size:.85rem;line-height:1.5}.counters-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){h1{font-size:1.85rem;letter-spacing:1px}h2{font-size:1.5rem}.container{padding:0 16px}.hero-content .hero-subtitle{font-size:1rem}.btn-primary{padding:14px 32px;font-size:0.9rem}.counter-number{font-size:2.25rem}}@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;transition-duration:0.01ms !important}.reveal{opacity:1;transform:none}}.nav-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);z-index:998}.nav-overlay.active{display:block}

/* =====================================================================
   PREMIUM UPGRADE — Hero + Product Showcase (Industrial-Luxury layer)
   Appended overrides. Safe to remove this block to revert to baseline.
   ===================================================================== */
:root{
  --color-gold:#c8a86b;
  --color-gold-soft:rgba(200,168,107,0.5);
  --ink-deep:#06122a;
  --ease-lux:cubic-bezier(.16,1,.3,1);
}

/* ---------- HERO ---------- */
.hero{height:100vh;min-height:700px}
.hero-bg{
  height:120%;
  /* Imagen cinematográfica de alta resolución (descargable desde Unsplash) */
  background:url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?w=2000&q=85&auto=format&fit=crop') center center/cover no-repeat;
  filter:saturate(1.05) contrast(1.06) brightness(.92);
}
/* Live El Caracol footage as hero background */
.hero-video{
  position:absolute;top:0;left:0;width:100%;height:100%;
  object-fit:cover;object-position:center;z-index:0;pointer-events:none;
}
.hero-overlay{
  /* navy grade + a light black tint so the headline stays legible over video */
  background:
    linear-gradient(rgba(0,0,0,0.38),rgba(0,0,0,0.38)),
    radial-gradient(120% 90% at 75% 10%,rgba(58,123,213,0.16),transparent 55%),
    linear-gradient(115deg,rgba(6,18,42,0.86) 0%,rgba(10,42,94,0.58) 48%,rgba(12,27,51,0.42) 100%);
}
/* Reduced motion / no video: fall back to the static hero image */
@media (prefers-reduced-motion:reduce){ .hero-video{display:none} }
/* Blueprint grid lines */
.hero-grid-lines{
  position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.5;
  background-image:
    linear-gradient(rgba(255,255,255,0.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.045) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(120% 100% at 50% 0%,#000 35%,transparent 80%);
  mask-image:radial-gradient(120% 100% at 50% 0%,#000 35%,transparent 80%);
}
/* Film grain */
.hero-grain{
  position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.5;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.45'/%3E%3C/svg%3E");
}
/* Elevator scan line traveling vertically */
.hero-scanline{
  position:absolute;left:0;right:0;top:0;height:140px;z-index:2;pointer-events:none;
  background:linear-gradient(to bottom,transparent,rgba(120,170,255,0.10) 45%,rgba(200,168,107,0.18) 50%,rgba(120,170,255,0.10) 55%,transparent);
  animation:heroScan 7s var(--ease-lux) infinite;
}
@keyframes heroScan{0%{transform:translateY(-160px);opacity:0}12%{opacity:1}88%{opacity:1}100%{transform:translateY(100vh);opacity:0}}

/* Floor-indicator rail (the signature element) */
.hero-rail{
  position:absolute;z-index:4;top:50%;right:min(6vw,90px);transform:translateY(-50%);
  display:flex;flex-direction:column;align-items:center;gap:14px;
  animation:fadeInUp .8s ease .9s forwards;opacity:0;
}
.hero-rail-floor{
  font-family:var(--font-heading);font-weight:800;font-size:2.4rem;color:#fff;
  line-height:1;font-variant-numeric:tabular-nums;min-width:1.6ch;text-align:center;
  text-shadow:0 0 24px rgba(58,123,213,0.5);
}
.hero-rail-track{
  position:relative;width:4px;height:230px;border-radius:4px;
  background:linear-gradient(to bottom,rgba(255,255,255,0.06),rgba(255,255,255,0.16),rgba(255,255,255,0.06));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.08);
}
.hero-rail-cab{
  position:absolute;left:50%;top:0;width:14px;height:30px;margin-left:-7px;margin-top:-15px;border-radius:3px;
  background:linear-gradient(180deg,var(--color-gold),#9c7e44);
  box-shadow:0 0 18px var(--color-gold-soft),0 0 0 1px rgba(255,255,255,0.2);
  transition:top 1.4s var(--ease-lux);
}
.hero-rail-label{
  font-family:var(--font-heading);font-weight:600;font-size:.62rem;letter-spacing:3px;
  text-transform:uppercase;color:rgba(255,255,255,0.55);
}

/* Kicker badge */
.hero-kicker{
  display:inline-flex;align-items:center;gap:10px;margin-bottom:26px;
  font-family:var(--font-heading);font-size:.72rem;font-weight:600;letter-spacing:3px;
  text-transform:uppercase;color:rgba(255,255,255,0.85);
  padding:9px 18px;border:1px solid rgba(255,255,255,0.18);border-radius:100px;
  background:rgba(255,255,255,0.04);backdrop-filter:blur(6px);
  animation:fadeInUp .8s ease .05s forwards;opacity:0;
}
.hero-kicker-dot{width:7px;height:7px;border-radius:50%;background:var(--color-gold);box-shadow:0 0 0 0 var(--color-gold-soft);animation:dotPulse 2.2s infinite}
@keyframes dotPulse{0%,100%{box-shadow:0 0 0 0 var(--color-gold-soft)}50%{box-shadow:0 0 0 6px rgba(200,168,107,0)}}

.hero-content h1{font-size:clamp(2.4rem,5.2vw,4.1rem);letter-spacing:1.5px;line-height:1.08}
.hero-h1-sub{
  display:inline-block;font-weight:500;
  background:linear-gradient(90deg,#fff,#cfe0ff 60%,var(--color-gold));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}

/* Actions */
.hero-actions{
  display:flex;flex-wrap:wrap;gap:16px;justify-content:center;align-items:center;margin-top:8px;
  animation:fadeInUp .8s ease .6s forwards;opacity:0;
}
.hero-actions .btn-primary{animation:pulse 2.5s infinite 1.6s;opacity:1}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-heading);font-size:.92rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  color:#fff;padding:15px 30px;border-radius:4px;text-decoration:none;
  border:1px solid rgba(255,255,255,0.28);background:rgba(255,255,255,0.04);
  transition:background-color .35s var(--ease-lux),border-color .35s,transform .35s,gap .35s;
}
.btn-ghost .material-icons{font-size:18px;transition:transform .35s var(--ease-lux)}
.btn-ghost:hover{background:rgba(255,255,255,0.12);border-color:var(--color-gold);gap:12px}
.btn-ghost:hover .material-icons{transform:translateY(3px)}

/* Trust stats */
.hero-trust{
  list-style:none;display:flex;justify-content:center;gap:40px;margin-top:48px;flex-wrap:wrap;
  animation:fadeInUp .8s ease .78s forwards;opacity:0;
}
.hero-trust li{display:flex;flex-direction:column;align-items:center;position:relative;padding:0 8px}
.hero-trust li+li::before{content:'';position:absolute;left:-20px;top:50%;transform:translateY(-50%);width:1px;height:32px;background:rgba(255,255,255,0.16)}
.hero-trust strong{font-family:var(--font-heading);font-size:1.7rem;font-weight:800;color:#fff;line-height:1}
.hero-trust span{font-family:var(--font-heading);font-size:.66rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.6);margin-top:7px}

/* Scroll cue */
.hero-scroll{
  position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:8px;text-decoration:none;
  font-family:var(--font-heading);font-size:.62rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;
  color:rgba(255,255,255,0.55);animation:fadeInUp .8s ease 1s forwards;opacity:0;
}
.hero-scroll-track{width:22px;height:36px;border:1px solid rgba(255,255,255,0.35);border-radius:12px;position:relative}
.hero-scroll-dot{position:absolute;left:50%;top:7px;width:4px;height:4px;margin-left:-2px;border-radius:50%;background:var(--color-gold);animation:scrollDot 1.8s var(--ease-lux) infinite}
@keyframes scrollDot{0%{transform:translateY(0);opacity:0}30%{opacity:1}70%{opacity:1}100%{transform:translateY(16px);opacity:0}}

/* ---------- PRODUCT SHOWCASE (Servicios) ---------- */
.servicio-card{position:relative;border-radius:8px;transition:transform .5s var(--ease-lux),box-shadow .5s,border-color .5s}
.servicio-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;z-index:3;
  background:linear-gradient(90deg,var(--color-accent),var(--color-gold));
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease-lux);
}
.servicio-card:hover{transform:translateY(-10px);box-shadow:0 26px 60px rgba(6,18,42,0.18);border-color:var(--color-accent)}
.servicio-card:hover::before{transform:scaleX(1)}

.servicio-index{
  position:absolute;top:14px;right:18px;z-index:3;
  font-family:var(--font-heading);font-weight:800;font-size:1.5rem;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,0.55);letter-spacing:1px;
  transition:-webkit-text-stroke-color .5s,transform .5s var(--ease-lux);
}
.servicio-card:hover .servicio-index{-webkit-text-stroke-color:var(--color-gold);transform:translateY(-2px)}

/* Corner bracket (architectural detail) */
.servicio-corner{
  position:absolute;bottom:16px;right:16px;width:22px;height:22px;z-index:3;pointer-events:none;
  border-right:2px solid var(--color-gold);border-bottom:2px solid var(--color-gold);
  opacity:0;transform:translate(6px,6px);transition:opacity .5s,transform .5s var(--ease-lux);
}
.servicio-card:hover .servicio-corner{opacity:.8;transform:translate(0,0)}

.servicio-card-img{position:relative;height:230px}
.servicio-card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(6,18,42,0.45),transparent 55%);z-index:1;transition:opacity .5s}
.servicio-card:hover .servicio-card-img img{transform:scale(1.08)}
/* Blueprint frame reveal on hover */
.servicio-frame{
  position:absolute;inset:14px;z-index:2;pointer-events:none;border:1px solid rgba(255,255,255,0.6);
  opacity:0;transform:scale(1.04);transition:opacity .5s var(--ease-lux),transform .5s var(--ease-lux);
}
.servicio-card:hover .servicio-frame{opacity:.9;transform:scale(1)}

.servicio-ico{display:inline-flex;width:46px;height:46px;align-items:center;justify-content:center;border-radius:10px;background:rgba(58,123,213,0.1);color:var(--color-accent)!important;font-size:24px!important;margin-bottom:16px!important;transition:background-color .4s,color .4s}
.servicio-card:hover .servicio-ico{background:var(--color-primary);color:#fff!important}

/* Spec chips — slide up on hover */
.servicio-specs{
  list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:0 0 18px;
  max-height:0;opacity:0;overflow:hidden;transform:translateY(8px);
  transition:max-height .5s var(--ease-lux),opacity .45s,transform .5s var(--ease-lux),margin .5s;
}
.servicio-card:hover .servicio-specs{max-height:80px;opacity:1;transform:translateY(0);margin-bottom:18px}
.servicio-specs li{
  font-family:var(--font-heading);font-size:.68rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;
  color:var(--color-secondary);background:var(--color-bg-alt);border:1px solid var(--color-border);
  padding:5px 11px;border-radius:100px;
}
.servicio-link{font-family:var(--font-heading);font-size:.85rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--color-accent);text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:color .3s,gap .3s}
.servicio-link .material-icons{font-size:18px}
.servicio-link:hover{color:var(--color-primary);gap:10px}

/* ---------- Responsive ---------- */
@media (max-width:1100px){.hero-rail{display:none}}
@media (max-width:768px){
  /* Close (X) icon stays white on the dark drawer, even when navbar is scrolled */
  .navbar .hamburger.active span,
  .navbar.scrolled .hamburger.active span{background:#fff}
  /* Drawer links stay light on the dark panel even when navbar is scrolled */
  .navbar .nav-links a,
  .navbar.scrolled .nav-links a{color:rgba(255,255,255,0.92)}
  .navbar .nav-links a:hover,
  .navbar.scrolled .nav-links a:hover{color:#fff}
  .navbar.scrolled .nav-links a::after{background:var(--color-gold)}
  .hero{height:auto;min-height:100svh;align-items:flex-start}
  .hero-content{margin-top:96px;padding-top:48px;padding-bottom:96px}
  .hero-trust{gap:26px;margin-top:36px}
  .hero-trust strong{font-size:1.4rem}
  .hero-trust li+li::before{left:-13px;height:26px}
  .hero-actions{gap:12px}
}
@media (max-width:480px){
  .hero-content{margin-top:84px;padding-top:40px;padding-bottom:88px}
  .hero-trust li:nth-child(3){display:none}
  .btn-ghost{padding:13px 24px;font-size:.85rem}
}
@media (prefers-reduced-motion:reduce){
  .hero-scanline,.hero-scroll-dot,.hero-kicker-dot{animation:none!important}
  .hero-kicker,.hero-actions,.hero-trust,.hero-scroll,.hero-rail{opacity:1!important;animation:none!important}
}

/* =====================================================================
   PREMIUM UPGRADE — El Caracol highlight + Video catalog + Real gallery
   ===================================================================== */
/* ---------- Proyecto Destacado: El Caracol ---------- */
.destacado{padding:110px 0;background:linear-gradient(160deg,var(--ink-deep),var(--color-primary) 60%,var(--color-dark));position:relative;overflow:hidden}
.destacado-glow{position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(58,123,213,.25),transparent 65%);top:-120px;right:-120px;filter:blur(40px);pointer-events:none}
.destacado-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;position:relative;z-index:1}
.destacado-media{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/5;box-shadow:0 30px 70px rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.1)}
.destacado-media video{width:100%;height:100%;object-fit:cover;display:block}
.destacado-media::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(6,18,42,.5),transparent 45%);pointer-events:none}
.destacado-badge{position:absolute;top:18px;left:18px;z-index:2;display:inline-flex;align-items:center;gap:7px;background:rgba(200,168,107,.95);color:var(--ink-deep);font-family:var(--font-heading);font-size:.72rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:8px 16px;border-radius:100px;box-shadow:0 8px 24px rgba(0,0,0,.3)}
.destacado-badge .material-icons{font-size:15px}
.destacado-kicker{margin-bottom:20px}
.destacado-text h2{color:#fff;margin-bottom:22px;font-size:clamp(1.9rem,3.4vw,2.7rem)}
.destacado-text h2::after{content:'';display:block;width:60px;height:3px;background:var(--color-gold);margin-top:16px}
.destacado-quote{position:relative;font-family:var(--font-body);font-style:italic;font-size:1.3rem;line-height:1.6;color:#fff;border-left:3px solid var(--color-gold);padding:4px 0 4px 22px;margin:0 0 22px}
.destacado-text>p{color:rgba(255,255,255,.78);font-size:1.02rem;margin-bottom:28px;max-width:520px}
.destacado-stats{display:flex;gap:36px;margin-bottom:32px;flex-wrap:wrap}
.destacado-stats div{display:flex;flex-direction:column}
.destacado-stats strong{font-family:var(--font-heading);font-size:1.5rem;font-weight:800;color:var(--color-gold);line-height:1}
.destacado-stats span{font-family:var(--font-heading);font-size:.66rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:6px}

/* ---------- Catálogo en video ---------- */
.catalogo{padding:100px 0;background:var(--color-bg);position:relative;overflow:hidden}
.catalogo-shape{position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(58,123,213,.04);filter:blur(90px);top:-60px;right:-80px;animation:float 9s ease-in-out infinite}
.catalogo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;position:relative;z-index:1}
.catalogo-card{background:#fff;border:1px solid var(--color-border);border-radius:10px;overflow:hidden;transition:transform .5s var(--ease-lux),box-shadow .5s,border-color .5s}
.catalogo-card:hover{transform:translateY(-8px);box-shadow:0 24px 56px rgba(6,18,42,.16);border-color:var(--color-accent)}
.catalogo-media{position:relative;aspect-ratio:4/5;overflow:hidden;background:#0c1b33}
.catalogo-media video{width:100%;height:100%;object-fit:cover;display:block}
.catalogo-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.18);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.4);transition:opacity .4s,transform .4s var(--ease-lux);pointer-events:none}
.catalogo-play .material-icons{color:#fff;font-size:32px;margin-left:2px}
.catalogo-media.is-playing .catalogo-play{opacity:0;transform:translate(-50%,-50%) scale(.7)}
.catalogo-body{padding:18px 20px}
.catalogo-cat{display:inline-block;font-family:var(--font-heading);font-size:.66rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--color-accent);background:rgba(58,123,213,.08);padding:4px 11px;border-radius:100px;margin-bottom:10px}
.catalogo-body h3{color:var(--color-primary);font-size:1.05rem;line-height:1.3}

/* ---------- Galería real (fotos verticales) ---------- */
#galeriaGrid{grid-template-columns:repeat(4,1fr);gap:18px}
#galeriaGrid .galeria-item{aspect-ratio:3/4}
#galeriaGrid .galeria-item img{width:100%;height:100%;object-fit:cover}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .catalogo-grid{grid-template-columns:repeat(2,1fr)}
  #galeriaGrid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:768px){
  .destacado{padding:72px 0}
  .destacado-layout{grid-template-columns:1fr;gap:32px}
  .destacado-media{order:-1;aspect-ratio:16/11;max-height:420px}
  .destacado-quote{font-size:1.12rem}
  #galeriaGrid{grid-template-columns:repeat(2,1fr);gap:12px}
}
@media (max-width:560px){
  .catalogo-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}
}
@media (prefers-reduced-motion:reduce){
  .catalogo-play{opacity:1!important}
}

/* =====================================================================
   MARCAS / CLIENTES carousel  +  LÍNEAS DE PRODUCTO  (Carta 2026)
   ===================================================================== */
.marcas{padding:72px 0;overflow:hidden}
.marquee{overflow:hidden;width:100%;padding:8px 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);}
.marquee-track{display:flex;list-style:none;width:max-content;padding:0;margin:0;
  animation:marquee 40s linear infinite}
.marquee--reverse .marquee-track{animation-duration:52s;animation-direction:reverse}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marca-tile,.cliente-tile{flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  height:84px;min-width:210px;margin-right:18px;padding:0 28px;border-radius:10px;text-align:center;
  font-family:var(--font-heading);font-weight:700;letter-spacing:.4px}
.marca-tile{background:var(--color-bg-alt);border:1px solid var(--color-border);color:var(--color-primary);
  font-size:1.05rem;transition:border-color .35s,color .35s,transform .35s}
.marca-tile span{opacity:.88}
.marca-tile:hover{border-color:var(--color-gold);color:var(--color-accent);transform:translateY(-3px)}
.cliente-tile{min-width:240px;background:linear-gradient(135deg,var(--color-primary),#0c1b33);color:#fff;
  font-size:.95rem;box-shadow:0 8px 22px rgba(6,18,42,.14)}
.cliente-tile span{opacity:.94}
.marcas-sublabel{text-align:center;font-family:var(--font-heading);font-weight:600;letter-spacing:2.5px;
  text-transform:uppercase;font-size:.7rem;color:var(--color-secondary);margin:30px 0 16px}
.marcas-note{text-align:center;font-size:.8rem;color:var(--color-secondary);opacity:.7;margin-top:24px;font-style:italic}

.productos{position:relative;padding:96px 0;background:var(--color-bg-alt);overflow:hidden}
.productos-shape{position:absolute;top:-120px;right:-120px;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(58,123,213,.10),transparent 70%);pointer-events:none}
.productos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:48px}
.producto-card{position:relative;display:flex;flex-direction:column;background:#fff;
  border:1px solid var(--color-border);border-radius:12px;overflow:hidden;
  transition:transform .5s var(--ease-lux),box-shadow .5s,border-color .5s}
.producto-card:hover{transform:translateY(-10px);box-shadow:0 26px 60px rgba(6,18,42,.16);border-color:var(--color-accent)}
.producto-media{position:relative;height:240px;overflow:hidden}
.producto-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-lux)}
.producto-card:hover .producto-media img{transform:scale(1.07)}
.producto-media::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(6,18,42,.5),transparent 55%)}
.producto-cat{position:absolute;top:14px;left:14px;z-index:2;font-family:var(--font-heading);
  font-size:.66rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#fff;
  background:rgba(10,42,94,.85);padding:6px 12px;border-radius:100px;backdrop-filter:blur(4px)}
.producto-body{display:flex;flex-direction:column;flex:1;padding:26px}
.producto-ico{width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:12px;background:rgba(58,123,213,.1);color:var(--color-accent)!important;
  font-size:26px!important;margin-bottom:16px;transition:background-color .4s,color .4s}
.producto-card:hover .producto-ico{background:var(--color-primary);color:#fff!important}
.producto-body h3{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;color:var(--color-primary);margin-bottom:10px}
.producto-body p{color:var(--color-secondary);font-size:.95rem;line-height:1.6;margin-bottom:18px}
.producto-specs{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:0 0 22px;padding:0}
.producto-specs li{font-family:var(--font-heading);font-size:.66rem;font-weight:600;letter-spacing:.4px;
  text-transform:uppercase;color:var(--color-secondary);background:var(--color-bg-alt);
  border:1px solid var(--color-border);padding:5px 11px;border-radius:100px}
.producto-body .servicio-link{margin-top:auto}

@media (max-width:980px){.productos-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){
  .productos-grid{grid-template-columns:1fr}
  .marca-tile,.cliente-tile{min-width:168px;height:72px;font-size:.9rem;margin-right:14px;padding:0 20px}
  .cliente-tile{min-width:190px}
}
@media (prefers-reduced-motion:reduce){
  .marquee-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;gap:14px}
  .marquee{-webkit-mask-image:none;mask-image:none}
}

/* =====================================================================
   CLIENTES reales  +  PROYECTOS ENTREGADOS (tabla)  +  CERTIFICACIONES
   +  Firma del Gerente General        (Carta 2026)
   ===================================================================== */
.clientes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:48px}
.cliente-card{position:relative;background:#fff;border:1px solid var(--color-border);border-radius:12px;
  padding:30px 28px;overflow:hidden;transition:transform .5s var(--ease-lux),box-shadow .5s,border-color .5s}
.cliente-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;
  background:linear-gradient(var(--color-accent),var(--color-gold));transform:scaleY(0);transform-origin:top;
  transition:transform .5s var(--ease-lux)}
.cliente-card:hover{transform:translateY(-8px);box-shadow:0 22px 50px rgba(6,18,42,.14);border-color:var(--color-accent)}
.cliente-card:hover::before{transform:scaleY(1)}
.cliente-card-ico{width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:12px;background:rgba(58,123,213,.1);color:var(--color-accent);margin-bottom:18px;transition:.4s}
.cliente-card-ico .material-icons{font-size:26px}
.cliente-card:hover .cliente-card-ico{background:var(--color-primary);color:#fff}
.cliente-card h3{font-family:var(--font-heading);font-size:1.18rem;color:var(--color-primary);margin-bottom:10px}
.cliente-card p{color:var(--color-secondary);font-size:.93rem;line-height:1.6;margin-bottom:18px}
.cliente-card-meta{display:flex;gap:18px;flex-wrap:wrap;border-top:1px solid var(--color-border);padding-top:14px}
.cliente-card-meta span{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-heading);
  font-size:.78rem;font-weight:600;color:var(--color-secondary)}
.cliente-card-meta .material-icons{font-family:'Material Icons';font-size:16px;color:var(--color-accent)}

.proyectos-entregados{padding:96px 0;background:var(--color-bg-alt)}
.pe-table-wrap{margin-top:42px;border:1px solid var(--color-border);border-radius:14px;overflow:hidden;
  background:#fff;box-shadow:0 18px 44px rgba(6,18,42,.07)}
.pe-table{width:100%;border-collapse:collapse;font-size:.92rem}
.pe-table thead th{background:var(--color-primary);color:#fff;font-family:var(--font-heading);font-weight:600;
  font-size:.72rem;letter-spacing:1px;text-transform:uppercase;text-align:left;padding:16px 20px}
.pe-table tbody td{padding:15px 20px;border-top:1px solid var(--color-border);color:var(--color-secondary);vertical-align:middle}
.pe-table tbody tr:nth-child(even){background:#fafbfd}
.pe-table tbody tr{transition:background-color .25s}
.pe-table tbody tr:hover{background:rgba(58,123,213,.06)}
.pe-table td strong{color:var(--color-primary);font-weight:600}
.pe-tag{display:inline-block;font-family:var(--font-heading);font-size:.58rem;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;color:var(--color-accent);background:rgba(58,123,213,.1);padding:2px 8px;border-radius:100px;
  margin-left:6px;vertical-align:middle}
.pe-year{font-family:var(--font-heading);font-weight:700;color:var(--color-primary)}
.pe-note{text-align:center;margin-top:22px;font-size:.85rem;color:var(--color-secondary);opacity:.8}
.pe-table thead th:not(:last-child){border-right:1px solid rgba(255,255,255,.18)}
.pe-table tbody td:not(:last-child){border-right:1px solid var(--color-border)}
.pe-table th:nth-child(2),.pe-table td:nth-child(2),.pe-table th:nth-child(5),.pe-table td:nth-child(5){text-align:center}
.pe-table td:nth-child(3){color:var(--color-text);font-weight:500}
.pe-table tbody tr.pe-extra{display:none}
.pe-table.is-expanded tbody tr.pe-extra{display:table-row}
.pe-toggle-wrap{text-align:center;margin-top:26px}
.pe-toggle{font-family:var(--font-heading);font-size:.78rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--color-primary);background:#fff;border:1.5px solid var(--color-primary);border-radius:100px;padding:12px 30px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background-color .3s,color .3s,transform .3s,box-shadow .3s}
.pe-toggle:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:0 12px 26px rgba(10,42,94,.18)}
.pe-toggle .material-icons{font-size:18px;transition:transform .3s}
.pe-toggle[aria-expanded="true"] .material-icons{transform:rotate(180deg)}
@media (max-width:760px){
  .pe-table thead{display:none}
  .pe-table,.pe-table tbody,.pe-table tr,.pe-table td{display:block;width:100%}
  .pe-table tbody tr{padding:14px 0}
  .pe-table tbody tr:not(:first-child){border-top:1px solid var(--color-border)}
  .pe-table tbody tr:nth-child(even){background:#fff}
  .pe-table.is-expanded tbody tr.pe-extra{display:block}
  .pe-table td{border:0;padding:9px 18px;display:flex;justify-content:space-between;gap:16px;align-items:center;text-align:right}
  .pe-table td::before{content:attr(data-label);font-family:var(--font-heading);font-weight:700;font-size:.64rem;
    letter-spacing:.5px;text-transform:uppercase;color:var(--color-accent);text-align:left;flex:0 0 auto}
}

.certificaciones{padding:90px 0}
.certs-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:44px}
.cert-chip{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--color-border);
  border-radius:10px;padding:16px 18px;transition:transform .35s var(--ease-lux),border-color .35s,box-shadow .35s}
.cert-chip:hover{transform:translateY(-4px);border-color:var(--color-gold);box-shadow:0 14px 30px rgba(6,18,42,.1)}
.cert-chip .material-icons{font-size:26px;color:var(--color-gold);flex:0 0 auto}
.cert-chip div{display:flex;flex-direction:column;min-width:0}
.cert-chip strong{font-family:var(--font-heading);font-size:.84rem;color:var(--color-primary);line-height:1.2}
.cert-chip span{font-size:.73rem;color:var(--color-secondary);margin-top:3px}
@media (max-width:980px){.certs-grid{grid-template-columns:repeat(3,1fr)}.clientes-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.certs-grid{grid-template-columns:repeat(2,1fr)}.clientes-grid{grid-template-columns:1fr}}

.firma{display:flex;align-items:center;gap:16px;margin:26px 0 6px}
.firma-rule{width:46px;height:2px;flex:0 0 auto;background:linear-gradient(90deg,var(--color-accent),var(--color-gold))}
.firma-text{display:flex;flex-direction:column}
.firma-name{font-family:var(--font-heading);font-size:1rem;color:var(--color-primary)}
.firma-role{font-size:.82rem;color:var(--color-secondary)}
