/* ========================= PEDEX – Base y variables ========================= */ :root { –navy: #0f1e2e; –steel: #4f647c; –green: #143a2f; –white: #f8fafd; –paper: #ffffff; –text: #13263f; –muted: #5f7086; –border: #d5deea; –radius: 14px; –shadow: 0 14px 30px rgba(10, 25, 42, 0.08); }* { box-sizing: border-box; }html { scroll-behavior: smooth; }body { margin: 0; font-family: “Inter”, Arial, sans-serif; color: var(–text); background: var(–white); line-height: 1.6; }img { max-width: 100%; }h1, h2, h3 { margin-top: 0; line-height: 1.2; font-family: “Playfair Display”, Georgia, serif; }a { color: inherit; }.container { width: min(1120px, 92%); margin-inline: auto; }.narrow { max-width: 760px; }.sr-only { position: absolute; width: 1px; height: 1px; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); }.skip-link { position: absolute; left: -1000px; top: 8px; background: var(–green); color: #fff; padding: 0.7rem 1rem; border-radius: 8px; }.skip-link:focus { left: 8px; z-index: 999; }/* ========================= Header y navegación ========================= */ .site-header { position: sticky; top: 0; z-index: 50; background: rgba(15, 30, 46, 0.94); backdrop-filter: blur(10px); border-bottom: 1px solid rgba(255, 255, 255, 0.08); }.nav-wrap { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 0.9rem 0; }.brand { text-decoration: none; color: #fff; }.brand__name { display: block; font-size: 1.16rem; letter-spacing: 0.08em; }.brand__sub { font-size: 0.72rem; color: #bdd0e7; letter-spacing: 0.08em; }.menu-toggle { border: 1px solid rgba(255, 255, 255, 0.35); background: transparent; color: #fff; border-radius: 8px; padding: 0.45rem 0.7rem; font: inherit; }.main-nav { position: absolute; inset: 68px 0 auto 0; background: #12263b; border-bottom: 1px solid rgba(255, 255, 255, 0.1); display: none; }.main-nav.is-open { display: block; }.main-nav ul { margin: 0; padding: 0.8rem 4%; list-style: none; }.main-nav a { display: block; padding: 0.55rem 0; color: #e5edf8; text-decoration: none; }/* ========================= Botones e interacción ========================= */ .btn { display: inline-block; text-decoration: none; border-radius: 999px; padding: 0.78rem 1.25rem; font-weight: 600; border: 1px solid transparent; transition: transform 220ms ease, box-shadow 220ms ease, opacity 220ms ease; }.btn:hover, .btn:focus-visible { transform: translateY(-1px); box-shadow: 0 8px 16px rgba(9, 24, 42, 0.14); opacity: 0.96; }.btn–primary { background: var(–green); color: #fff; }.btn–ghost { color: #fff; border-color: rgba(255, 255, 255, 0.55); }.btn–secondary { border-color: #a8b7cc; color: #1e3653; }/* ========================= Hero + formulario ========================= */ .hero { position: relative; min-height: 92vh; overflow: hidden; }.hero__bg, .hero__overlay { position: absolute; inset: 0; width: 100%; height: 100%; }.hero__bg { object-fit: cover; } .hero__overlay { background: rgba(15, 30, 46, 0.82); }.hero__layout { position: relative; z-index: 1; padding: 5.4rem 0 3.5rem; display: grid; gap: 1.4rem; }.hero__content { color: #fff; } .hero__eyebrow { text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.78rem; color: #c3d2e5; } .hero h1 { font-size: clamp(2rem, 7vw, 3.5rem); margin-bottom: 0.9rem; } .hero__lead { color: #d9e5f5; } .hero__actions { display: flex; flex-direction: column; gap: 0.75rem; margin-top: 1.35rem; } .hero__note { font-size: 0.84rem; color: #c6d3e5; margin-top: 1rem; }.hero-form, .cta-form { background: var(–paper); border: 1px solid var(–border); border-radius: var(–radius); padding: 1rem; box-shadow: var(–shadow); }.hero-form h2 { font-size: 1.2rem; margin-bottom: 0.75rem; }label { display: block; font-size: 0.93rem; margin-bottom: 0.7rem; color: #223c5a; }input, select, textarea { width: 100%; margin-top: 0.28rem; padding: 0.68rem; border: 1px solid #b6c4d6; border-radius: 8px; font: inherit; }input:focus, select:focus, textarea:focus { outline: 2px solid #2f5e98; outline-offset: 1px; }.form-feedback { min-height: 1.2rem; font-size: 0.88rem; margin-top: 0.55rem; }.form-feedback.is-error { color: #952a2a; } .form-feedback.is-success { color: #1f5f48; }/* ========================= Secciones y tarjetas ========================= */ .section { padding: clamp(3rem, 8vw, 5.5rem) 0; } .section–alt { background: #ecf2f8; }.metrics { background: #14283d; border-top: 1px solid rgba(255, 255, 255, 0.08); border-bottom: 1px solid rgba(255, 255, 255, 0.08); }.metrics__grid { display: grid; gap: 0.7rem; padding: 1.15rem 0; }.metrics__grid article { color: #dbe5f2; border-left: 2px solid rgba(255, 255, 255, 0.16); padding-left: 0.8rem; }.metrics__grid strong { display: block; color: #fff; font-size: 1.34rem; }.flow { margin: 1.2rem 0; display: grid; gap: 0.65rem; }.flow__node, .flow__arrow { background: var(–paper); border: 1px solid var(–border); border-radius: 10px; padding: 0.85rem; text-align: center; box-shadow: var(–shadow); }.flow__arrow { font-weight: 700; color: #284664; }.shield-grid, .cards-grid { display: grid; gap: 0.95rem; }.shield-card, .product-card, .holding, .table-wrap { background: var(–paper); border: 1px solid var(–border); border-radius: var(–radius); box-shadow: var(–shadow); }.shield-card, .product-card, .holding { padding: 1.1rem; }.shield-card span { color: var(–green); font-weight: 700; } .shield-card h3 { display: inline; margin-left: 0.35rem; font-size: 1.02rem; }.table-wrap { overflow-x: auto; }table { width: 100%; border-collapse: collapse; min-width: 460px; }th, td { text-align: left; padding: 0.9rem; border-bottom: 1px solid var(–border); }th { background: #e6edf6; color: #223d5a; }.holding__root { background: var(–navy); color: #fff; padding: 0.8rem; border-radius: 10px; text-align: center; margin-bottom: 0.85rem; }.holding__children { display: grid; gap: 0.7rem; }.holding__children span { background: #f7fafe; border: 1px solid var(–border); border-radius: 9px; padding: 0.7rem; text-align: center; }/* ========================= CTA final y footer ========================= */ .cta { background: linear-gradient(140deg, #0f1e2e, #18324a); color: #fff; }.cta__layout { display: grid; gap: 1rem; }.cta .cta-form label { color: #223c5a; }.site-footer { background: #0a1624; color: #d2deee; padding-top: 1.1rem; }.footer-grid { display: grid; gap: 0.75rem; }.footer-brand { font-weight: 700; }.site-footer ul { list-style: none; padding: 0; margin: 0; }.site-footer a { color: #dbe7f6; text-decoration: none; }.copyright { margin: 0; padding: 0.9rem 4%; border-top: 1px solid rgba(255, 255, 255, 0.08); font-size: 0.85rem; }/* ========================= Animación fade-in en scroll ========================= */ .reveal-on-scroll { opacity: 0; transform: translateY(16px); transition: opacity 700ms ease, transform 700ms ease; }.reveal-on-scroll.is-visible { opacity: 1; transform: translateY(0); }/* ========================= Breakpoints solicitados ========================= */ /* Tablet: 768–1023px */ @media (min-width: 768px) { .menu-toggle { display: none; }.main-nav { position: static; display: block; background: transparent; border: 0; }.main-nav ul { display: flex; gap: 1rem; padding: 0; }.main-nav a { padding: 0.25rem 0; }.hero__layout { grid-template-columns: 1.2fr 0.95fr; align-items: center; gap: 1.2rem; }.hero__actions { flex-direction: row; flex-wrap: wrap; }.metrics__grid, .shield-grid, .cards-grid, .holding__children, .cta__layout, .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }.flow { grid-template-columns: repeat(7, minmax(0, 1fr)); align-items: center; } }/* Desktop: 1024px+ */ @media (min-width: 1024px) { .metrics__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } .shield-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .cards-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .holding__children { grid-template-columns: repeat(3, minmax(0, 1fr)); } .cta__layout { grid-template-columns: 1.2fr 1fr; align-items: start; } .footer-grid { grid-template-columns: 1fr auto; align-items: center; } }@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }.reveal-on-scroll { opacity: 1; transform: none; } }