:root{
  /* Typography */
  --font-brand: 'EngraversGothic', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;

  /* Palette (given) */
  --black:#0b0f0e;
  --emerald-900:#141a18;
  --emerald-800:#1f2a27;
  --emerald-700:#0e3b2e;
  --emerald-600:#145c44;
  --emerald-500:#1e7f5c;
  --bone:#d8d8d8;
  --gray-200:#bfc5c3;
  --white:#f2f2f2;
  --cherry:#6a0f1a;

  /* Tokens */
  /* Porsche-like: full white canvas */
  --bg: #ffffff;
  --ink: var(--black);
  --muted: rgba(11,15,14,.68);
  --stroke: rgba(11,15,14,.14);
  --radius: 18px;
  /* Softer, minimal shadows */
  --shadow: 0 10px 30px rgba(11,15,14,.08);
  --ease: cubic-bezier(.2,.8,.2,1);
}

@font-face{
  font-family:'EngraversGothic';
  src:url('assets/fonts/EngraversGothic-Regular.otf') format('opentype');
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

*{box-sizing:border-box}
html,body{background:#ffffff;height:100%}

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-brand);
}

.wrap{width:min(1200px,calc(100% - 36px));margin:0 auto}

/* Topbar */
.topbar{
  position:fixed;
  top:0; left:0; right:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 18px;
  background:rgba(11,15,14,.62);
  border-bottom:1px solid rgba(30,127,92,.18);
  backdrop-filter:blur(14px);
  transition: background .28s var(--ease), border-color .28s var(--ease), padding .28s var(--ease);
}

/* When scrolling, make it slightly more solid (still dark, V7 vibe) */
.topbar.is-solid{
  background:rgba(11,15,14,.90);
  border-bottom-color: rgba(30,127,92,.26);
  padding:12px 18px;
}

/* V12: compact sticky (premium) */
.topbar.is-compact{
  padding:8px 18px;
}
.topbar.is-compact .brand__logo{width:26px;height:26px}
.topbar.is-compact .brand__name{font-size:11px}
.topbar.is-compact .nav__link{padding:8px 10px}
.topbar.is-compact .lang{padding:8px 10px}
.topbar.is-compact .menu{padding:8px 10px}

.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--white)}
.brand__logo{width:30px;height:30px;object-fit:contain;filter:drop-shadow(0 16px 22px rgba(0,0,0,.35))}
.brand__name{letter-spacing:.22em;text-transform:uppercase;font-size:12px}

.nav{display:flex;gap:10px;align-items:center}
.nav__link{
  color:rgba(242,242,242,.88);
  text-decoration:none;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid transparent;
  transition:background .25s var(--ease),color .25s var(--ease),transform .25s var(--ease),border-color .25s var(--ease);
}

.nav__link:hover{color:var(--white);background:rgba(242,242,242,.08);transform:translateY(-1px)}
.nav__link--cta{color:#f2f2f2;border-color:rgba(30,127,92,.70);background:rgba(20,92,68,.38)}
.nav__link--cta:hover{background:rgba(30,127,92,.30)}

.topbar__actions{display:flex;align-items:center;gap:10px}
.lang{
  border:1px solid rgba(242,242,242,.18);
  background:rgba(242,242,242,.06);
  color:var(--white);
  border-radius:999px;
  padding:10px 12px;
  display:flex;
  align-items:center;
  gap:10px;
}
.lang__dot{width:8px;height:8px;border-radius:99px;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));box-shadow:0 0 0 4px rgba(30,127,92,.14)}
.menu{display:none;border:1px solid rgba(242,242,242,.18);background:rgba(242,242,242,.06);color:var(--white);border-radius:12px;padding:10px 12px}

/* Drawer */
.drawer{position:fixed;inset:0;z-index:60;display:none}
.drawer.is-on{display:block}
.drawer__backdrop{position:absolute;inset:0;z-index:0;background:rgba(11,15,14,.55);backdrop-filter:blur(10px)}
.drawer__panel{position:absolute;right:0;top:0;z-index:1;height:100%;width:min(380px,92vw);border-left:1px solid rgba(242,242,242,.14);background:rgba(11,15,14,.78);backdrop-filter:blur(18px);padding:16px}
.drawer__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.drawer__title{color:var(--white);letter-spacing:.22em;text-transform:uppercase;font-size:12px}
.drawer__close{border:1px solid rgba(242,242,242,.18);background:rgba(242,242,242,.06);color:var(--white);border-radius:10px;padding:8px 10px}
.drawer__link{display:block;padding:12px 10px;margin-top:8px;border-radius:12px;text-decoration:none;color:var(--white);border:1px solid rgba(242,242,242,.14);background:rgba(242,242,242,.04)}
.drawer__link--cta{border-color:rgba(30,127,92,.55);background:rgba(20,92,68,.20)}

/* Hero (video) */
.hero{
  position:relative;
  height:100vh;
  min-height:640px;
  overflow:hidden;
  display:grid;
  place-items:center;
}
.hero__video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.hero__overlay{
  position:absolute;
  inset:0;
  /* V12: overlay responds to scroll via --ov-a */
  background:linear-gradient(180deg,
    rgba(0,0,0, calc(.70 * var(--ov-a, 1))) 0%,
    rgba(0,0,0, calc(.52 * var(--ov-a, 1))) 55%,
    rgba(0,0,0, calc(.62 * var(--ov-a, 1))) 100%
  );
}

.hero__content{
  position:relative;
  width:min(980px,calc(100% - 36px));
  padding:22px;
  text-align:center;
  color:var(--white);
  /* V12: subtle Porsche-like fade/slide on scroll */
  transform:translateY(var(--hero-y, 0px));
  opacity:var(--hero-o, 1);
  will-change: transform, opacity;
}
.hero__kicker{
  font-family:var(--font-display);
  letter-spacing:.35em;
  text-transform:uppercase;
  font-size:12px;
  color:rgba(242,242,242,.92);
  text-shadow:0 8px 20px rgba(0,0,0,.8);
  margin-bottom:16px;
}

.hero__title{
  font-family:var(--font-display);
  font-weight:400;
  letter-spacing:.22em;
  text-transform:uppercase;
  line-height:1.08;
  margin:0;
  font-size:clamp(34px,5.4vw,64px);
  color:#ffffff;
  text-shadow:0 10px 28px rgba(0,0,0,.85);
}
.hero__subtitle{
  color:rgba(242,242,242,.82);
  font-size:14px;
  line-height:1.75;
  max-width:52ch;
  margin:0 auto;
  letter-spacing:.04em;
  text-shadow:0 2px 18px rgba(0,0,0,.55);
}
.hero__actions{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap;justify-content:center}

.hero__link{
  display:inline-block;
  margin-top:14px;
  color:rgba(242,242,242,.78);
  text-decoration:none;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:10px;
  border-bottom:1px solid rgba(242,242,242,.24);
  padding-bottom:6px;
  transition: color .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease);
}
.hero__link:hover{color:#ffffff;border-bottom-color:rgba(30,127,92,.55);transform:translateY(-1px)}

.scrollCue{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:16px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:rgba(242,242,242,.62);
  letter-spacing:.32em;
  font-size:10px;
}
.scrollCue__dot{
  width:7px;height:7px;border-radius:99px;
  background:rgba(242,242,242,.75);
  box-shadow:0 0 0 4px rgba(30,127,92,.10);
  animation:cue 2.0s infinite;
}
@keyframes cue{0%,100%{transform:translateY(0);opacity:.95}50%{transform:translateY(8px);opacity:.55}}

/* Sections */
.section{padding:72px 0; scroll-margin-top:90px}
.section--alt{background:#ffffff;border-top:1px solid rgba(11,15,14,.08);border-bottom:1px solid rgba(11,15,14,.08)}
.h2{margin:0 0 10px;letter-spacing:.34em;font-size:12px;text-transform:uppercase;color:rgba(11,15,14,.72)}
.muted{color:var(--muted);line-height:1.7;letter-spacing:.02em}

/* Buttons */
.btn{
  display:inline-block;
  text-decoration:none;
  border-radius:999px;
  padding:12px 16px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  transition:transform .25s var(--ease),background .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease);
}
.btn--primary{background:var(--emerald-600);border:1px solid rgba(20,92,68,.85);color:var(--white);box-shadow:0 18px 50px rgba(20,92,68,.18)}
.btn--primary:hover{transform:translateY(-1px);background:var(--emerald-500);border-color:rgba(30,127,92,.95)}
.btn--ghost{background:rgba(242,242,242,.06);border:1px solid rgba(242,242,242,.18);color:var(--white)}
.btn--ghost:hover{transform:translateY(-1px);background:rgba(242,242,242,.10)}

.btn--outline{background:transparent;border:1px solid var(--stroke);color:var(--ink)}
.btn--outline:hover{transform:translateY(-1px);border-color:rgba(11,15,14,.55);background:rgba(11,15,14,.92);color:#ffffff}

/* Pills */
.pill{font-size:10px;padding:8px 10px;border-radius:999px;border:1px solid rgba(30,127,92,.55);background:rgba(20,92,68,.24);color:rgba(242,242,242,.92);letter-spacing:.22em;text-transform:uppercase}
.pill--ghost{border-color:rgba(242,242,242,.18);background:rgba(242,242,242,.06);color:rgba(242,242,242,.78)}

/* Platforms */
.platformGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.platform{
  position:relative;
  border-radius:22px;
  padding:18px 16px;
  border:1px solid var(--stroke);
  background:#fff;
  box-shadow:none;
  text-decoration:none;
  color:var(--ink);
  overflow:hidden;
  transition:transform .25s var(--ease),border-color .25s var(--ease);
}
.platform:hover{transform:translateY(-2px);border-color:rgba(30,127,92,.45)}
.platform__title{letter-spacing:.12em;text-transform:uppercase;font-size:13px}
.platform__sub{margin-top:8px;color:rgba(11,15,14,.62);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.platform__tag{
  position:absolute;top:12px;right:12px;
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  padding:8px 10px;border-radius:999px;
  background:rgba(30,127,92,.12);
  border:1px solid rgba(30,127,92,.32);
  color:var(--emerald-600);
}
.platform--disabled{opacity:.55;filter:saturate(.85)}

/* Feature blocks (clean, white) */
.featureGrid{display:grid;gap:18px;margin-top:26px}
.feature{display:grid;grid-template-columns:1.15fr .85fr;gap:0;overflow:hidden;border-radius:22px;border:1px solid var(--stroke);background:#fff;box-shadow:none;transition:border-color .25s var(--ease), transform .25s var(--ease)}
.feature:hover{border-color:rgba(30,127,92,.35);transform:translateY(-1px)}
.feature:nth-child(even){grid-template-columns:.85fr 1.15fr}
.feature__media{min-height:320px;background-size:cover;background-position:center;position:relative}
.feature__media::after{content:"";position:absolute;inset:0;background:linear-gradient(to right, rgba(242,242,242,.06), rgba(11,15,14,.22))}
.feature:nth-child(even) .feature__media::after{background:linear-gradient(to left, rgba(242,242,242,.06), rgba(11,15,14,.22))}
.feature__body{padding:28px 26px;display:flex;flex-direction:column;justify-content:center}
.feature__title{font-size:22px;letter-spacing:.14em;text-transform:uppercase;margin:0 0 10px}
.feature__text{color:rgba(11,15,14,.70);line-height:1.7;margin:0 0 16px;max-width:44ch;letter-spacing:.02em}
.feature__link{margin-top:6px}

/* Specs */
.specband{border-top:1px solid var(--stroke);border-bottom:1px solid var(--stroke)}
.specgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:18px}
.spec{padding:18px 16px;border-radius:18px;border:1px solid var(--stroke);background:#fff;box-shadow:var(--shadow)}
.spec__num{font-size:26px;letter-spacing:.18em;text-transform:uppercase;margin:0 0 8px}
.spec__label{color:rgba(11,15,14,.68);margin:0;line-height:1.55;font-size:11px;letter-spacing:.22em;text-transform:uppercase}

/* Final CTA */
.ctaFinal{padding:78px 0}
.ctaFinal__wrap{display:flex;gap:22px;align-items:center;justify-content:space-between;border:1px solid var(--stroke);border-radius:26px;padding:44px 26px;background:#fff;box-shadow:var(--shadow)}
.ctaFinal__kicker{color:rgba(11,15,14,.70);letter-spacing:.42em;font-size:12px;text-transform:uppercase}
.ctaFinal__title{font-size:clamp(28px,3.2vw,44px);letter-spacing:.14em;text-transform:uppercase;margin:10px 0 10px}
.ctaFinal__sub{color:rgba(11,15,14,.70);max-width:70ch;margin:0;line-height:1.75;letter-spacing:.02em}
.ctaFinal__actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.ctaFinal .btn--ghost{color:var(--ink);border-color:var(--stroke);background:rgba(191,197,195,.16)}
.ctaFinal .btn--ghost:hover{background:rgba(191,197,195,.22)}

/* Footer */
.footer{border-top:1px solid var(--stroke);padding:26px 0;background:var(--bg)}
.footer__grid{width:min(1200px,calc(100% - 36px));margin:0 auto;display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:14px;align-items:start}
.footer__logo{width:34px;height:34px;object-fit:contain}
.footer__title{letter-spacing:.22em;text-transform:uppercase;font-size:11px;margin-bottom:10px}
.footer__link{display:block;color:rgba(11,15,14,.64);text-decoration:none;margin-top:8px}
.footer__link:hover{color:var(--emerald-600)}

/* Responsive */
@media (max-width:980px){
  .nav{display:none}
  .menu{display:block}
  .footer__grid{grid-template-columns:1fr}
  .hero{height:92vh}
  .platformGrid{grid-template-columns:1fr 1fr}
  .feature{grid-template-columns:1fr}
  .feature:nth-child(even){grid-template-columns:1fr}
  .feature__media{min-height:240px}
  .feature__media::after, .feature:nth-child(even) .feature__media::after{background:linear-gradient(to bottom, rgba(242,242,242,.08), rgba(11,15,14,.26))}
  .specgrid{grid-template-columns:1fr 1fr}
  .ctaFinal__wrap{flex-direction:column;align-items:flex-start}
  .ctaFinal__actions{justify-content:flex-start}
}
@media (max-width:520px){
  .platformGrid{grid-template-columns:1fr}
  .specgrid{grid-template-columns:1fr}
}



/* --- Process page (V12+) --- */
.pageHead{padding:84px 0 40px;border-bottom:1px solid rgba(20,92,68,.12);background:#ffffff}
.pageHead .lead{max-width:62ch}
.kicker{font-family:var(--font-brand);letter-spacing:.24em;text-transform:uppercase;font-size:.72rem;color:rgba(11,15,14,.68)}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

.processGrid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:18px}
.stepCard{display:grid;grid-template-columns:64px 1fr;gap:14px;padding:16px 16px;border:1px solid rgba(20,92,68,.16);border-radius:18px;background:#ffffff}
.stepCard__num{font-family:var(--font-brand);letter-spacing:.16em;font-size:.95rem;color:rgba(11,15,14,.78);display:flex;align-items:flex-start;justify-content:center;padding-top:2px}
.stepCard__body h3{margin:0 0 6px;font-family:var(--font-brand);letter-spacing:.12em;text-transform:uppercase;font-size:.9rem}
.stepCard__body p{margin:0 0 10px;color:rgba(11,15,14,.76);max-width:68ch}

.miniList{margin:0;padding-left:18px;color:rgba(11,15,14,.70)}
.miniList li{margin:4px 0}
.section--tight{padding-top:32px}

.materialGrid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:14px}
.materialCard{border:1px solid rgba(20,92,68,.16);border-radius:18px;padding:16px;background:#ffffff}
.materialCard h3{margin:10px 0 6px;font-family:var(--font-brand);letter-spacing:.12em;text-transform:uppercase;font-size:.9rem}
.swatch{height:72px;border-radius:14px;border:1px solid rgba(11,15,14,.12);background:linear-gradient(135deg, rgba(11,15,14,.88), rgba(11,15,14,.65))}
.swatch--twill{background:linear-gradient(135deg, rgba(11,15,14,.88), rgba(14,59,46,.55))}
.swatch--forged{background:radial-gradient(circle at 30% 30%, rgba(30,127,92,.35), rgba(11,15,14,.92))}
.swatch--spread{background:linear-gradient(135deg, rgba(20,92,68,.55), rgba(11,15,14,.88))}

.qcGrid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:14px}
.qcCard{border:1px solid rgba(20,92,68,.16);border-radius:18px;padding:16px;background:#ffffff}
.qcCard h3{margin:0 0 10px;font-family:var(--font-brand);letter-spacing:.12em;text-transform:uppercase;font-size:.9rem}
.checkList{list-style:none;margin:0;padding:0;color:rgba(11,15,14,.74)}
.checkList li{position:relative;padding-left:18px;margin:8px 0}
.checkList li:before{content:"";position:absolute;left:0;top:.45em;width:8px;height:8px;border-radius:99px;background:var(--emerald-600);box-shadow:0 0 0 3px rgba(20,92,68,.16)}

.section--cta{padding:34px 0 54px}
.cta{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;border:1px solid rgba(20,92,68,.18);border-radius:22px;padding:18px 18px;background:#ffffff}

/* responsive */
@media (min-width: 900px){
  .processGrid{grid-template-columns:1fr 1fr}
  .stepCard{min-height:172px}
  .materialGrid{grid-template-columns:1fr 1fr 1fr}
  .qcGrid{grid-template-columns:1fr 1fr}
}

/* ---------- Page transition overlay (to configurator) ---------- */
.pageFx{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:0;transition:opacity .25s ease}
.pageFx.is-on{opacity:1}
.pageFx__veil{position:absolute;inset:0;background:
  radial-gradient(900px 700px at 18% 20%, rgba(30,127,92,.18), transparent 60%),
  radial-gradient(900px 700px at 82% 0%, rgba(20,92,68,.22), transparent 60%),
  linear-gradient(180deg, #050608, #0b0f0e);
  transform:translateY(12px);opacity:0;transition:transform .55s cubic-bezier(.2,.8,.2,1), opacity .55s cubic-bezier(.2,.8,.2,1)
}
.pageFx.is-on .pageFx__veil{transform:translateY(0);opacity:1}
.pageFx__mark{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(520px, calc(100vw - 28px));
  border-radius:22px;border:1px solid rgba(242,242,242,.10);background:rgba(11,15,14,.55);backdrop-filter:blur(16px);
  padding:22px 18px;text-align:center;box-shadow:0 26px 80px rgba(0,0,0,.70);
  opacity:0;transform:translate(-50%,-50%) scale(.98);transition:opacity .45s cubic-bezier(.2,.8,.2,1), transform .45s cubic-bezier(.2,.8,.2,1)
}
.pageFx.is-on .pageFx__mark{opacity:1;transform:translate(-50%,-50%) scale(1)}
.pageFx__logo{width:62px;height:62px;object-fit:contain;filter:drop-shadow(0 16px 26px rgba(0,0,0,.55))}
.pageFx__bar{height:10px;border-radius:999px;border:1px solid rgba(242,242,242,.10);background:rgba(242,242,242,.03);margin:14px auto 4px;overflow:hidden;width:76%}
.pageFx__bar span{display:block;height:100%;width:40%;background:linear-gradient(90deg, rgba(30,127,92,0), rgba(30,127,92,.60), rgba(20,92,68,.60), rgba(30,127,92,0));animation:pagefx 1.1s linear infinite}
@keyframes pagefx{0%{transform:translateX(-60%)}100%{transform:translateX(220%)}}

.materialImg {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: 12px;
  margin-bottom: 1rem;
  transition: transform 0.4s ease;
}

.materialCard:hover .materialImg {
  transform: scale(1.05);
}

.brand__logo{
  height: 28px;
  width: auto;
  display: block;
  filter: drop-shadow(0 2px 10px rgba(0,0,0,.65));
}

.topbar--overlay{
  background: rgba(0,0,0,.25);
  backdrop-filter: blur(10px);
}

.scrollCue {
  color: #1e7f5c;
}

.scrollCue__dot {
  background-color: #59c59d;
}

.scrollCue:hover {
  color: #145c44; /* verde un poco más oscuro */
}

.scrollCue:hover .scrollCue__dot {
  background-color: #145c44;
}

body.has-drawer{overflow:hidden}

@media (max-width: 980px){
  .drawer__backdrop{backdrop-filter:none;background:rgba(11,15,14,.72)}
  .drawer__panel{backdrop-filter:none;background:rgba(11,15,14,.96)}
}


/* ===== Procesos: artículo 01 con galería propia ===== */
.stepCard--analysis {
  align-items: start;
}

.stepGallery {
  margin-top: 16px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.stepGallery__img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  border-radius: 14px;
  border: 1px solid rgba(20,92,68,.14);
  background: #fff;
  padding: 8px;
  box-shadow: 0 8px 24px rgba(11,15,14,.06);
}

/* que NO hereden el estilo de materialImg */
.stepCard--analysis .materialImg {
  all: unset;
}

/* Desktop: la tarjeta 01 ocupa todo el ancho */
@media (min-width: 900px) {
  .stepCard--analysis {
    grid-column: 1 / -1;
  }

  .stepCard--analysis .stepGallery {
    grid-template-columns: repeat(3, 1fr);
    align-items: start;
  }
}

.stepCard--analysis .stepCard__body h3 {
  margin-bottom: 10px;
}

.stepCard--analysis .miniList {
  margin-bottom: 16px;
}

.stepCard--analysis {
  border-color: rgba(20,92,68,.24);
  box-shadow: 0 12px 34px rgba(11,15,14,.05);
}