/* ============================================================
   MEDISEG · Páginas internas (Nosotros / Productos)
   Misma sobriedad que el home: claro, aireado, navy + teal.
   Sin fondos oscuros ni fotográficos. Producto sobre fondos limpios.
   Reutiliza tokens de styles.css.
   ============================================================ */

:root {
  --ms-cyan: #2a93b8;
  --ms-ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --ms-shadow: 0 22px 54px rgba(8, 26, 43, 0.08);
  --ms-shadow-hover: 0 34px 76px rgba(8, 26, 43, 0.13);
}

/* ---------- Scroll reveal (sutil) ---------- */
[data-reveal] {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.7s var(--ms-ease), transform 0.7s var(--ms-ease);
  transition-delay: var(--d, 0s);
  will-change: opacity, transform;
}
[data-reveal="left"] { transform: translateX(-26px); }
[data-reveal="right"] { transform: translateX(26px); }
[data-reveal].in-view { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1 !important; transform: none !important; transition: none !important; }
  html { scroll-behavior: auto; }
}

/* ---------- Scaffolding ---------- */
.ms-page main { position: relative; z-index: 2; background: var(--soft); overflow-x: clip; }
.ms-h2 {
  margin: 14px 0 0; color: var(--navy-2);
  font-family: Sora, Manrope, sans-serif; font-weight: 800;
  font-size: clamp(2rem, 3.4vw, 3.1rem); line-height: 1.06; letter-spacing: -1.3px;
  text-wrap: balance;
}
.ms-sub { margin: 16px 0 0; max-width: 560px; color: var(--muted); font-size: 16.5px; line-height: 1.65; text-wrap: pretty; }
.eyebrow.ms-mono { font-family: "JetBrains Mono", Sora, monospace; }

/* ============================================================
   HERO INTERNO (claro, como el home)
   ============================================================ */
.ms-hero {
  position: relative; overflow: hidden;
  padding: clamp(116px, 13vw, 168px) 0 clamp(56px, 7vw, 92px);
  background: linear-gradient(180deg, #ffffff 0%, #f4f9f9 100%);
}
.ms-hero::before {
  content: ""; position: absolute; top: -180px; right: -160px; width: 560px; height: 560px;
  background: radial-gradient(circle, rgba(20,163,160,0.10), rgba(20,163,160,0) 68%);
  border-radius: 50%; pointer-events: none;
}
.ms-hero .container { position: relative; z-index: 2; }
.ms-hero-grid { display: grid; grid-template-columns: 1.06fr 0.94fr; gap: clamp(36px, 5vw, 80px); align-items: center; }
.ms-hero-copy { max-width: 600px; }
.ms-hero h1 {
  margin: 18px 0 0; color: var(--navy-2);
  font-family: Sora, Manrope, sans-serif; font-weight: 800;
  font-size: clamp(2.6rem, 5.2vw, 4.4rem); line-height: 0.98; letter-spacing: -2px; text-wrap: balance;
}
.ms-hero h1 span { color: var(--teal); }
.ms-hero-copy > p { margin: 22px 0 0; max-width: 520px; color: var(--muted); font-size: clamp(1.02rem, 1.4vw, 1.18rem); line-height: 1.66; }
.ms-hero .actions { margin-top: 30px; }
.ms-hero .btn { min-height: 54px; border-radius: 999px; }

/* stage: panel claro con un único producto protagonista */
.ms-stage {
  position: relative; border-radius: 28px; overflow: hidden;
  min-height: clamp(340px, 40vw, 460px); display: grid; place-items: center; padding: clamp(28px, 4vw, 48px);
  background: radial-gradient(circle at 50% 32%, #ffffff, #eef6f6);
  border: 1px solid var(--line); box-shadow: var(--ms-shadow);
}
.ms-stage::after {
  content: ""; position: absolute; right: -60px; bottom: -70px; width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(20,163,160,0.12), rgba(20,163,160,0)); pointer-events: none;
}
.ms-stage img { position: relative; max-width: 78%; max-height: clamp(280px, 32vw, 380px); object-fit: contain; filter: drop-shadow(0 26px 34px rgba(8,26,43,0.16)); }
.ms-stage-chip {
  position: absolute; z-index: 3; display: inline-flex; align-items: center; gap: 10px;
  padding: 11px 16px; border-radius: 14px; background: rgba(255,255,255,0.9); backdrop-filter: blur(12px);
  border: 1px solid var(--line); box-shadow: 0 14px 32px rgba(8,26,43,0.1);
  font-family: Sora, sans-serif; font-weight: 700; font-size: 13px; color: var(--navy-2);
}
.ms-stage-chip b { font-family: "JetBrains Mono", monospace; color: var(--teal); font-size: 12px; }
.ms-stage-chip--tl { top: 22px; left: 22px; }
.ms-stage-chip--br { bottom: 22px; right: 22px; }
.ms-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--teal); box-shadow: 0 0 0 4px rgba(20,163,160,0.16); }

/* stats row */
.ms-stats { display: flex; flex-wrap: wrap; gap: 32px 44px; margin-top: 38px; padding-top: 28px; border-top: 1px solid var(--line); }
.ms-stat b { display: block; font-family: Sora, sans-serif; font-size: clamp(1.7rem, 2.4vw, 2.2rem); font-weight: 800; color: var(--navy-2); letter-spacing: -1px; line-height: 1; }
.ms-stat span { display: block; margin-top: 7px; font-size: 12.5px; color: var(--muted-2); font-weight: 700; letter-spacing: 0.5px; }

/* ============================================================
   PROPÓSITO (editorial claro)
   ============================================================ */
.ms-story-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(32px, 5vw, 80px); align-items: start; }
.ms-statement { font-family: Sora, sans-serif; font-weight: 700; color: var(--navy-2); font-size: clamp(1.6rem, 2.6vw, 2.35rem); line-height: 1.2; letter-spacing: -0.8px; text-wrap: balance; }
.ms-statement em { font-style: normal; color: var(--teal); }
.ms-story-body { display: grid; gap: 18px; padding-top: 6px; }
.ms-story-body p { margin: 0; color: var(--muted); font-size: 16.5px; line-height: 1.7; }
.ms-story-body strong { color: var(--navy-2); font-weight: 700; }

/* ============================================================
   PROCESO (timeline claro, sin nodos oscuros)
   ============================================================ */
.ms-steps { display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; margin-top: clamp(36px, 4vw, 52px); }
.ms-step {
  position: relative; padding: 28px 22px; background: #fff; border: 1px solid var(--line); border-radius: 18px;
  transition: transform 0.28s var(--ms-ease), box-shadow 0.28s var(--ms-ease), border-color 0.28s var(--ms-ease);
}
.ms-step:hover { transform: translateY(-6px); box-shadow: var(--ms-shadow); border-color: #bfe0de; }
.ms-step b { font-family: "JetBrains Mono", monospace; font-size: 12px; font-weight: 700; letter-spacing: 1px; color: var(--teal); }
.ms-step h4 { margin: 14px 0 8px; color: var(--navy-2); font-family: Sora, sans-serif; font-size: 1.02rem; font-weight: 700; }
.ms-step p { margin: 0; color: var(--muted); font-size: 13.8px; line-height: 1.55; }

/* ============================================================
   A QUIÉN ATENDEMOS (chips/cards claras minimalistas)
   ============================================================ */
.ms-aud-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; margin-top: clamp(32px, 4vw, 48px); }
.ms-aud {
  display: flex; flex-direction: column; gap: 10px; padding: 22px 20px;
  background: #fff; border: 1px solid var(--line); border-radius: 16px;
  transition: transform 0.24s var(--ms-ease), box-shadow 0.24s var(--ms-ease), border-color 0.24s var(--ms-ease);
}
.ms-aud:hover { transform: translateY(-4px); box-shadow: var(--ms-shadow); border-color: #bfe0de; }
.ms-aud-mark { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; background: #e7f4f3; color: #0e7c7a; }
.ms-aud-mark svg { width: 20px; height: 20px; }
.ms-aud h4 { margin: 2px 0 0; color: var(--navy-2); font-family: Sora, sans-serif; font-size: 14.5px; font-weight: 700; }
.ms-aud p { margin: 0; color: var(--muted-2); font-size: 12.6px; line-height: 1.5; }

/* ============================================================
   CTA final (claro)
   ============================================================ */
.ms-cta {
  position: relative; overflow: hidden; border-radius: 28px;
  padding: clamp(44px, 6vw, 76px); text-align: center;
  background: radial-gradient(circle at 50% 0%, #ffffff, #eef6f6);
  border: 1px solid var(--line); box-shadow: var(--ms-shadow);
}
.ms-cta .eyebrow { justify-content: center; }
.ms-cta h2 { margin: 16px auto 0; max-width: 640px; color: var(--navy-2); font-family: Sora, sans-serif; font-weight: 800; font-size: clamp(2rem, 3.6vw, 3rem); line-height: 1.06; letter-spacing: -1.2px; text-wrap: balance; }
.ms-cta p { margin: 18px auto 0; max-width: 520px; color: var(--muted); font-size: 1.04rem; line-height: 1.6; }
.ms-cta .actions { margin-top: 30px; justify-content: center; }
.ms-cta .btn { min-height: 54px; border-radius: 999px; }

/* ============================================================
   PRODUCTOS · categorías (tiles con degradado, estilo home)
   ============================================================ */
.ms-cats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: clamp(28px, 4vw, 44px); }
.ms-cat {
  position: relative; overflow: hidden; border-radius: 22px; min-height: 300px; isolation: isolate;
  display: flex; flex-direction: column; justify-content: flex-end; padding: 24px;
  border: 1px solid rgba(8,26,43,0.06); box-shadow: var(--ms-shadow);
  transition: transform 0.3s var(--ms-ease), box-shadow 0.3s var(--ms-ease);
}
.ms-cat:hover { transform: translateY(-6px); box-shadow: var(--ms-shadow-hover); }
.ms-cat img { position: absolute; left: 24px; right: 24px; top: 26px; width: calc(100% - 48px); height: 56%; object-fit: contain; z-index: 1; filter: drop-shadow(0 18px 26px rgba(4,17,31,0.22)); transition: transform 0.4s var(--ms-ease); }
.ms-cat:hover img { transform: translateY(-6px) scale(1.04); }
.ms-cat::after { content: ""; position: absolute; inset: 0; z-index: 2; background: linear-gradient(180deg, transparent 48%, rgba(8,26,43,0.06) 62%, rgba(8,26,43,0.74) 100%); }
.ms-cat-body { position: relative; z-index: 3; }
.ms-cat-tag { display: inline-flex; margin-bottom: 8px; padding: 6px 11px; border-radius: 999px; font-family: "JetBrains Mono", monospace; font-size: 10px; font-weight: 800; letter-spacing: 1px; background: rgba(255,255,255,0.9); color: var(--navy-2); }
.ms-cat h3 { margin: 0; color: #fff; font-family: Sora, sans-serif; font-size: 1.6rem; font-weight: 800; letter-spacing: -0.5px; }
.ms-cat p { margin: 7px 0 0; color: rgba(255,255,255,0.86); font-size: 13px; line-height: 1.5; }
.ms-cat-arrow { position: absolute; top: 20px; right: 20px; z-index: 4; width: 38px; height: 38px; display: grid; place-items: center; border-radius: 50%; background: rgba(255,255,255,0.92); color: var(--navy-2); font-size: 17px; font-weight: 800; transition: background 0.26s, color 0.26s; }
.ms-cat:hover .ms-cat-arrow { background: var(--teal); color: #fff; }
.ms-cat--pastas { background: radial-gradient(circle at 28% 16%, rgba(224,72,154,0.4), rgba(224,72,154,0) 44%), linear-gradient(150deg, #4e217d 0%, #142d82 56%, #0a1a4d 100%); }
.ms-cat--cepillos { background: radial-gradient(circle at 24% 16%, rgba(124,222,235,0.5), rgba(124,222,235,0) 44%), linear-gradient(150deg, #bfe9f3 0%, #4fb7cf 52%, #0b6782 100%); }
.ms-cat--insumos { background: radial-gradient(circle at 78% 14%, rgba(72,140,255,0.3), rgba(72,140,255,0) 42%), linear-gradient(150deg, #14233a 0%, #18283d 52%, #07101b 100%); }

/* ============================================================
   PRODUCTOS · filtros + grid (claro)
   ============================================================ */
.ms-catalog-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.ms-filterbar {
  display: flex; flex-wrap: wrap; gap: 8px; margin: clamp(26px, 3.5vw, 38px) 0 clamp(28px, 4vw, 40px);
  padding: 8px; border-radius: 999px; background: #fff; width: fit-content; max-width: 100%;
  border: 1px solid var(--line); box-shadow: 0 10px 30px rgba(8,26,43,0.06);
}
.ms-filter {
  display: inline-flex; align-items: center; gap: 7px; padding: 11px 20px; border: 0; border-radius: 999px;
  background: transparent; color: var(--navy-2); font-family: Manrope, sans-serif; font-weight: 800;
  font-size: 14px; cursor: pointer; transition: background 0.22s, color 0.22s; white-space: nowrap;
}
.ms-filter small { font-family: "JetBrains Mono", monospace; font-size: 11px; font-weight: 700; opacity: 0.5; }
.ms-filter:hover { background: #e7f4f3; color: #0e7c7a; }
.ms-filter.active { background: var(--teal); color: #fff; }
.ms-filter.active small { opacity: 0.8; color: #fff; }

.ms-pgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px, 2vw, 24px); }
.ms-pcard {
  position: relative; display: flex; flex-direction: column; overflow: hidden;
  background: #fff; border: 1px solid var(--line); border-radius: 20px;
  transition: transform 0.28s var(--ms-ease), box-shadow 0.28s var(--ms-ease), border-color 0.28s var(--ms-ease);
}
.ms-pcard:hover { transform: translateY(-6px); box-shadow: var(--ms-shadow-hover); border-color: #bfe0de; }
.ms-pcard-media { position: relative; height: 240px; display: grid; place-items: center; padding: 26px; background: #f6fbfa; border-bottom: 1px solid var(--line); }
.ms-pcard-media img { max-width: 80%; max-height: 188px; object-fit: contain; filter: drop-shadow(0 16px 22px rgba(8,26,43,0.12)); transition: transform 0.38s var(--ms-ease); }
.ms-pcard:hover .ms-pcard-media img { transform: translateY(-5px) scale(1.04); }
.ms-pcard-tag {
  position: absolute; top: 15px; left: 15px; padding: 6px 11px; border-radius: 999px;
  font-family: "JetBrains Mono", monospace; font-size: 9.5px; font-weight: 800; letter-spacing: 1px;
  text-transform: uppercase; color: #fff;
}
.tag-pastas { background: var(--teal); }
.tag-cepillos { background: var(--ms-cyan); }
.tag-insumos { background: var(--navy-2); }
.ms-pcard-body { display: flex; flex-direction: column; gap: 7px; padding: 22px 22px 24px; flex: 1; }
.ms-pcard-brand { margin: 0; font-family: "JetBrains Mono", monospace; font-size: 10.5px; font-weight: 700; letter-spacing: 1.4px; text-transform: uppercase; color: var(--muted-2); }
.ms-pcard-body h3 { margin: 0; color: var(--navy-2); font-family: Sora, sans-serif; font-size: 1.12rem; font-weight: 700; line-height: 1.22; letter-spacing: -0.3px; }
.ms-pcard-desc { margin: 0; color: var(--muted); font-size: 13.6px; line-height: 1.55; flex: 1; }
.ms-pcard-btn {
  display: inline-flex; align-items: center; gap: 9px; align-self: flex-start; margin-top: 8px;
  padding: 0; border: 0; background: transparent; color: #0e7c7a;
  font-family: Manrope, sans-serif; font-weight: 800; font-size: 13.5px; cursor: pointer;
}
.ms-pcard-btn span { display: grid; place-items: center; width: 26px; height: 26px; border-radius: 50%; background: #e7f4f3; transition: transform 0.26s var(--ms-ease), background 0.26s, color 0.26s; }
.ms-pcard-btn:hover span { transform: translateX(3px); background: var(--teal); color: #fff; }

/* ============================================================
   Modal (claro)
   ============================================================ */
.ms-page .modal-panel { box-shadow: 0 50px 120px rgba(4,17,31,0.4); }
.ms-page .modal-media { position: relative; background: radial-gradient(circle at 50% 36%, #ffffff, #eef6f6); }
.ms-page .modal-media img { max-height: 360px; filter: drop-shadow(0 24px 30px rgba(8,26,43,0.16)); }
.ms-page .modal-content { padding: 42px 38px; display: flex; flex-direction: column; gap: 2px; }
.ms-page .modal-content .tag { margin: 0; font-family: "JetBrains Mono", monospace; font-size: 11px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: #0e7c7a; }
.ms-page .modal-content h2 { margin: 10px 0 0; color: var(--navy-2); font-family: Sora, sans-serif; font-size: clamp(1.5rem, 2.6vw, 2rem); font-weight: 800; line-height: 1.1; letter-spacing: -0.6px; }
.ms-modal-desc { margin: 14px 0 0; color: var(--muted); font-size: 15px; line-height: 1.62; }
.ms-page .modal-content h3 { margin: 24px 0 12px; color: var(--navy-2); font-family: Sora, sans-serif; font-size: 0.92rem; font-weight: 700; letter-spacing: 0.3px; }
.ms-page .modal-content ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 9px; }
.ms-page .modal-content ul li { position: relative; padding-left: 24px; color: var(--muted); font-size: 14px; line-height: 1.5; }
.ms-page .modal-content ul li::before { content: ""; position: absolute; left: 0; top: 6px; width: 13px; height: 13px; border-radius: 5px; background: #e7f4f3; box-shadow: inset 0 0 0 2px var(--teal); }
.ms-modal-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.ms-modal-actions .btn { flex: 1; min-width: 140px; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 980px) {
  .ms-hero-grid, .ms-story-grid { grid-template-columns: 1fr; }
  .ms-hero-media { order: -1; }
  .ms-cats, .ms-pgrid { grid-template-columns: repeat(2, 1fr); }
  .ms-aud-row { grid-template-columns: repeat(3, 1fr); }
  .ms-steps { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .ms-cats, .ms-pgrid, .ms-aud-row, .ms-steps { grid-template-columns: 1fr; }
  .ms-filterbar { width: 100%; border-radius: 18px; overflow-x: auto; flex-wrap: nowrap; }
  .ms-modal-actions .btn { flex: 1 1 100%; }
  .ms-statement { font-size: 1.4rem; }
  .ms-stage img { max-width: 70%; }
}
