/*
Theme Name: ProduccionWeb Demo Avanzado Ingenieria Industrial
Theme URI: https://produccionweb.com/demos/avanzado/ingenieria-industrial/
Author: ProduccionWeb.com
Author URI: https://produccionweb.com/
Description: Demo avanzado para empresa de ingenieria industrial con experiencia 3D, secciones 2D comerciales, proyectos, servicios y contacto.
Version: 1.0.8
Text Domain: pw-adv-industrial
*/

:root {
  --bg: #05080d;
  --bg-2: #091018;
  --panel: #101823;
  --panel-2: #121f2b;
  --line: rgba(151, 176, 198, .18);
  --text: #f5f7fb;
  --muted: #aebccd;
  --soft: #d9e2ec;
  --cyan: #37c9df;
  --green: #74d48b;
  --amber: #f3b44d;
  --red: #ee6d63;
  --shadow: 0 24px 80px rgba(0, 0, 0, .38);
  --radius: 8px;
  color-scheme: dark;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px) 0 0 / 56px 56px,
    linear-gradient(0deg, rgba(255,255,255,.028) 1px, transparent 1px) 0 0 / 56px 56px,
    var(--bg);
  color: var(--text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 16px;
  line-height: 1.6;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(120deg, rgba(55,201,223,.12), transparent 34%),
    linear-gradient(300deg, rgba(243,180,77,.1), transparent 38%),
    linear-gradient(180deg, transparent, rgba(5,8,13,.62) 72%);
  z-index: -1;
}

img, svg, canvas { max-width: 100%; }
a { color: inherit; text-decoration: none; }
p { margin: 0 0 1rem; color: var(--muted); }
h1, h2, h3, h4 { margin: 0; color: var(--text); line-height: 1.05; letter-spacing: 0; }
h1 { font-size: clamp(2.2rem, 3.7vw, 3.65rem); max-width: 12ch; }
h2 { font-size: clamp(1.75rem, 2.9vw, 3.05rem); max-width: 14ch; }
h3 { font-size: clamp(1.18rem, 2vw, 1.65rem); }
ul { margin: 0; padding: 0; list-style: none; }

.screen-reader-text, .skip-link {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
}
.skip-link:focus {
  width: auto;
  height: auto;
  clip: auto;
  z-index: 999;
  top: 12px;
  left: 12px;
  padding: 10px 14px;
  background: #fff;
  color: #08111a;
}

.pwadv-container {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
}

.pwadv-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(5, 8, 13, .84);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(18px);
}

.pwadv-nav {
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.pwadv-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 210px;
  font-weight: 900;
  line-height: 1;
}

.pwadv-mark {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(55,201,223,.44);
  background: linear-gradient(135deg, rgba(55,201,223,.24), rgba(243,180,77,.16));
  box-shadow: 0 12px 34px rgba(55,201,223,.14);
}

.pwadv-brand small {
  display: block;
  margin-top: 4px;
  color: var(--amber);
  font-size: .74rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.pwadv-menu { display: flex; align-items: center; gap: 4px; }
.pwadv-menu li { list-style: none; margin: 0; padding: 0; }
.pwadv-menu a {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 8px 11px;
  color: var(--soft);
  font-size: .93rem;
  font-weight: 750;
}
.pwadv-menu a:hover, .pwadv-menu .current-menu-item > a { color: var(--cyan); }

.pwadv-header-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid rgba(116,212,139,.48);
  background: rgba(116,212,139,.12);
  color: var(--text);
  font-weight: 850;
}

.pwadv-menu-toggle {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.06);
  color: var(--text);
}

.pwadv-main { min-height: 72vh; }
.pwadv-section {
  position: relative;
  padding: 104px 0;
}
.pwadv-section.compact { padding: 76px 0; }
.pwadv-section.dark-band {
  background: rgba(8, 14, 21, .76);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.pwadv-hero {
  position: relative;
  min-height: calc(100vh - 74px);
  display: flex;
  align-items: center;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}

.pwadv-hero-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: .84;
}

.pwadv-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(5,8,13,.96) 0%, rgba(5,8,13,.82) 42%, rgba(5,8,13,.2) 100%),
    linear-gradient(0deg, rgba(5,8,13,.94), transparent 52%);
  pointer-events: none;
}

.pwadv-hero-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, .68fr);
  gap: 42px;
  align-items: center;
  padding: 70px 0;
}

.pwadv-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  color: var(--cyan);
  font-size: .8rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.pwadv-kicker::before {
  content: "";
  width: 34px;
  height: 2px;
  background: currentColor;
}

.pwadv-hero-copy p {
  max-width: 670px;
  font-size: clamp(1.03rem, 1.6vw, 1.28rem);
}

.pwadv-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
}

.pwadv-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.06);
  color: var(--text);
  font-weight: 900;
  transform: translateZ(0);
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.pwadv-btn:hover { transform: translateY(-2px); border-color: rgba(55,201,223,.62); }
.pwadv-btn.primary {
  border-color: rgba(55,201,223,.5);
  background: linear-gradient(135deg, var(--cyan), #1b8fad);
  color: #031018;
}
.pwadv-btn.amber {
  border-color: rgba(243,180,77,.6);
  background: rgba(243,180,77,.14);
}

.pwadv-command {
  perspective: 1200px;
  min-height: 600px;
  display: grid;
  align-content: center;
}
.pwadv-industrial-photo {
  position: relative;
  z-index: 1;
  width: 90%;
  margin: 0 0 -82px 34px;
  overflow: hidden;
  border: 1px solid rgba(55,201,223,.32);
  background: #071018;
  box-shadow: 0 26px 84px rgba(0,0,0,.36);
  transform: rotateZ(1deg);
}
.pwadv-industrial-photo img {
  display: block;
  width: 100%;
  height: 286px;
  object-fit: cover;
  opacity: .82;
  filter: saturate(1.06) contrast(1.05);
}
.pwadv-industrial-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(5,8,13,.66), transparent 54%), linear-gradient(0deg, rgba(5,8,13,.56), transparent 60%);
  pointer-events: none;
}
.pwadv-industrial-photo figcaption {
  position: absolute;
  left: 16px;
  bottom: 16px;
  z-index: 2;
  display: grid;
  gap: 2px;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(5,8,13,.72);
  backdrop-filter: blur(12px);
  color: #fff;
  font-weight: 900;
}
.pwadv-industrial-photo figcaption span {
  display: block;
  color: var(--muted);
  font-size: .75rem;
  font-weight: 700;
}
.pwadv-command-shell {
  position: relative;
  z-index: 2;
  width: 88%;
  justify-self: end;
  padding: 22px;
  border: 1px solid rgba(255,255,255,.18);
  background: linear-gradient(145deg, rgba(16,24,35,.86), rgba(7,12,19,.9));
  box-shadow: var(--shadow);
  transform: rotateX(10deg) rotateY(-13deg);
  transform-style: preserve-3d;
}
.pwadv-command-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}
.pwadv-command-top span { display: block; color: var(--muted); font-size: .85rem; }
.pwadv-status { color: var(--green); font-weight: 900; }

.pwadv-pipeline {
  position: relative;
  display: grid;
  gap: 16px;
  padding: 24px 0;
}
.pwadv-layer {
  position: relative;
  padding: 18px;
  border: 1px solid rgba(55,201,223,.22);
  background: rgba(255,255,255,.055);
  transform: translateZ(var(--z));
  box-shadow: 0 20px 40px rgba(0,0,0,.22);
}
.pwadv-layer strong { display: block; font-size: 1.05rem; }
.pwadv-layer span { color: var(--muted); font-size: .9rem; }
.pwadv-layer i {
  display: block;
  height: 7px;
  margin-top: 14px;
  background: linear-gradient(90deg, var(--cyan), var(--green), var(--amber));
  transform-origin: left;
  animation: pwadvBar 4.8s ease-in-out infinite;
}

.pwadv-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.pwadv-metrics article {
  padding: 14px;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.2);
}
.pwadv-metrics strong { display: block; color: var(--amber); font-size: 1.55rem; line-height: 1; }
.pwadv-metrics span { color: var(--muted); font-size: .77rem; }

.pwadv-head {
  display: grid;
  grid-template-columns: minmax(0, .85fr) minmax(260px, .55fr);
  gap: 34px;
  align-items: end;
  margin-bottom: 36px;
}
.pwadv-head p { max-width: 520px; font-size: 1.06rem; }

.pwadv-grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.pwadv-grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.pwadv-grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }

.pwadv-card,
.pwadv-service,
.pwadv-project,
.pwadv-step,
.pwadv-faq {
  position: relative;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
}
.pwadv-card { padding: 24px; }
.pwadv-service { padding: 24px; min-height: 260px; transform-style: preserve-3d; }
.pwadv-service:hover { border-color: rgba(55,201,223,.42); }
.pwadv-service .num,
.pwadv-step .num {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  margin-bottom: 18px;
  border: 1px solid rgba(243,180,77,.45);
  color: var(--amber);
  font-weight: 950;
}
.pwadv-service p { margin-top: 12px; }
.pwadv-service ul { margin-top: 18px; display: grid; gap: 8px; }
.pwadv-service li { color: var(--soft); font-size: .92rem; }
.pwadv-service li::before { content: "+ "; color: var(--green); font-weight: 900; }

.pwadv-plant {
  position: relative;
  min-height: 480px;
  border: 1px solid rgba(255,255,255,.16);
  background:
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px) 0 0 / 34px 34px,
    linear-gradient(0deg, rgba(255,255,255,.035) 1px, transparent 1px) 0 0 / 34px 34px,
    rgba(12, 20, 30, .7);
  overflow: hidden;
}
.pwadv-plant svg {
  position: absolute;
  inset: 30px;
  width: calc(100% - 60px);
  height: calc(100% - 60px);
}
.pwadv-node {
  position: absolute;
  min-width: 132px;
  padding: 12px;
  border: 1px solid rgba(55,201,223,.4);
  background: rgba(5,8,13,.76);
  box-shadow: 0 18px 40px rgba(0,0,0,.24);
  font-weight: 850;
}
.pwadv-node span { display: block; color: var(--muted); font-size: .78rem; font-weight: 700; }
.pwadv-node.a { top: 8%; left: 8%; }
.pwadv-node.b { top: 28%; right: 8%; border-color: rgba(116,212,139,.44); }
.pwadv-node.c { bottom: 12%; left: 16%; border-color: rgba(243,180,77,.44); }

.pwadv-project {
  overflow: hidden;
}
.pwadv-project-visual {
  min-height: 210px;
  background:
    linear-gradient(135deg, rgba(55,201,223,.22), transparent 42%),
    linear-gradient(315deg, rgba(243,180,77,.18), transparent 44%),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px) 0 0 / 28px 28px,
    #0b131d;
  position: relative;
}
.pwadv-project-visual::before,
.pwadv-project-visual::after {
  content: "";
  position: absolute;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.05);
}
.pwadv-project-visual::before { width: 50%; height: 44%; left: 14%; bottom: 18%; transform: skewX(-12deg); }
.pwadv-project-visual::after { width: 32%; height: 64%; right: 12%; top: 14%; }
.pwadv-project-body { padding: 22px; }
.pwadv-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.pwadv-tags span {
  padding: 6px 9px;
  border: 1px solid var(--line);
  color: var(--soft);
  font-size: .78rem;
  font-weight: 800;
}

.pwadv-step { padding: 22px; min-height: 230px; }
.pwadv-step p { margin-top: 12px; }
.pwadv-step::after {
  content: "";
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 18px;
  height: 3px;
  background: linear-gradient(90deg, var(--cyan), var(--green), var(--amber));
}

.pwadv-proof {
  display: grid;
  grid-template-columns: .92fr 1.08fr;
  gap: 28px;
  align-items: center;
}
.pwadv-proof-list { display: grid; gap: 12px; }
.pwadv-proof-list li {
  padding: 16px 18px;
  border-left: 3px solid var(--cyan);
  background: rgba(255,255,255,.05);
  color: var(--soft);
}

.pwadv-inner-hero {
  padding: 104px 0 70px;
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(90deg, rgba(55,201,223,.11), transparent 45%),
    rgba(6, 11, 17, .7);
}
.pwadv-inner-hero p { max-width: 720px; font-size: 1.12rem; }

.pwadv-copy-grid {
  display: grid;
  grid-template-columns: minmax(0, .88fr) minmax(300px, .52fr);
  gap: 36px;
}
.pwadv-rich > * + * { margin-top: 18px; }
.pwadv-rich h3 { margin-top: 34px; }
.pwadv-aside { align-self: start; position: sticky; top: 100px; }
.pwadv-aside .pwadv-card + .pwadv-card { margin-top: 16px; }

.pwadv-contact {
  display: grid;
  grid-template-columns: .86fr 1.14fr;
  gap: 28px;
}
.pwadv-form {
  display: grid;
  gap: 14px;
}
.pwadv-form label {
  display: grid;
  gap: 7px;
  color: var(--soft);
  font-weight: 800;
}
.pwadv-form input,
.pwadv-form select,
.pwadv-form textarea {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.055);
  color: var(--text);
  padding: 12px 13px;
  font: inherit;
}
.pwadv-form textarea { min-height: 140px; resize: vertical; }
.pwadv-form button { border: 0; cursor: pointer; }

.pwadv-faq { padding: 22px; }
.pwadv-faq p { margin-top: 10px; }

.pwadv-footer {
  padding: 54px 0 32px;
  border-top: 1px solid var(--line);
  background: #05080d;
}
.pwadv-footer-grid {
  display: grid;
  grid-template-columns: 1.2fr .8fr .8fr;
  gap: 24px;
}
.pwadv-footer a { color: var(--muted); }
.pwadv-footer a:hover { color: var(--cyan); }
.pwadv-footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 34px;
  padding-top: 20px;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: .9rem;
}

.pwadv-hero-copy h1 {
  max-width: 10ch;
}
.pwadv-hero-copy p {
  max-width: min(58ch, calc(100vw - 24px));
}
.pwadv-command-shell {
  max-width: calc(100vw - 24px);
}
.pwadv-hero-copy .pwadv-actions {
  max-width: calc(100vw - 40px);
}

@keyframes pwadvBar {
  0%, 100% { transform: scaleX(.28); opacity: .55; }
  50% { transform: scaleX(1); opacity: 1; }
}

@media (max-width: 980px) {
  .pwadv-menu-toggle { display: inline-grid; place-items: center; }
  .pwadv-header-cta { display: none; }
  .pwadv-menu {
    position: absolute;
    left: 16px;
    right: 16px;
    top: 74px;
    display: none;
    padding: 12px;
    border: 1px solid var(--line);
    background: rgba(6, 10, 16, .98);
    box-shadow: var(--shadow);
  }
  .pwadv-menu.is-open { display: grid; }
  .pwadv-menu a { width: 100%; }
  .pwadv-hero-grid,
  .pwadv-head,
  .pwadv-proof,
  .pwadv-copy-grid,
  .pwadv-contact,
  .pwadv-footer-grid { grid-template-columns: 1fr; }
  .pwadv-command { min-height: 420px; }
  .pwadv-command-shell { transform: rotateX(6deg) rotateY(-5deg); }
  .pwadv-industrial-photo { width: 96%; margin-left: 0; }
  .pwadv-grid-4, .pwadv-grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .pwadv-aside { position: static; }
}

@media (max-width: 680px) {
  html, body, .pwadv-site { max-width: 100%; overflow-x: hidden; }
  body { background-size: 42px 42px; }
  .pwadv-container { width: min(100% - 24px, 1180px); }
  .pwadv-brand { min-width: 0; }
  .pwadv-section { padding: 70px 0; }
  .pwadv-hero { min-height: auto; }
  .pwadv-hero-grid { display: block; max-width: 100%; min-width: 0; }
  .pwadv-hero-grid { padding: 58px 0 74px; gap: 26px; }
  .pwadv-hero-copy { width: 100%; min-width: 0; }
  .pwadv-hero-copy h1 { max-width: 11ch !important; font-size: clamp(1.85rem, 8vw, 2.28rem); line-height: 1.12; }
  .pwadv-kicker { font-size: .72rem; }
  .pwadv-kicker::before { width: 24px; }
  .pwadv-actions { display: grid; }
  .pwadv-btn { width: 100%; }
  .pwadv-hero-copy, .pwadv-hero-copy p, .pwadv-hero-copy h1, .pwadv-command-shell { max-width: 100%; overflow-wrap: break-word; }
  .pwadv-grid-4, .pwadv-grid-3, .pwadv-grid-2 { grid-template-columns: 1fr; }
  .pwadv-command { min-height: 0; display:block; }
  .pwadv-industrial-photo { width:100%; margin:28px 0 16px; transform:none; }
  .pwadv-industrial-photo img { height:220px; }
  .pwadv-industrial-photo figcaption { left:12px; right:12px; bottom:12px; }
  .pwadv-command-shell { width:100%; transform: none; padding: 16px; }
  .pwadv-metrics { grid-template-columns: 1fr; }
  .pwadv-plant { min-height: 390px; }
  .pwadv-node { position: relative; inset: auto !important; margin: 10px; }
  .pwadv-plant svg { opacity: .45; }
  .pwadv-footer-bottom { display: grid; }
}
