/* ===== MOGIDOC landing — mobile-first. Tokens desde DESIGN.md ===== */
:root{
  --primary:#031635;          /* deep corporate blue */
  --primary-2:#1a2b4b;
  --primary-grad:linear-gradient(160deg,#0a2147 0%,#031635 60%,#020e22 100%);
  --accent:#0D9488;           /* action teal */
  --accent-600:#0b7e74;
  --accent-soft:#d6f1ec;
  --indigo:#6161FF;
  --surface:#f7f9fb;
  --surface-2:#eef2f6;
  --white:#ffffff;
  --ink:#0f1b2d;
  --ink-2:#1f2a3a;
  --muted:#5a6577;
  --muted-2:#8a93a3;
  --border:#e2e8f0;
  --border-2:#d8dee7;
  --success:#10B981;
  --warning:#F59E0B;
  --radius:.5rem;
  --radius-md:.75rem;
  --radius-lg:1rem;
  --radius-xl:1.5rem;
  --shadow-sm:0 1px 2px rgba(15,27,45,.06),0 1px 3px rgba(15,27,45,.05);
  --shadow:0 4px 12px rgba(3,22,53,.08);
  --shadow-lg:0 24px 60px -20px rgba(3,22,53,.35);
  --maxw:1200px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--ink);background:var(--white);
  font-family:Inter,system-ui,sans-serif;font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5{font-family:"Hanken Grotesk",Inter,sans-serif;margin:0;line-height:1.12;letter-spacing:-.02em}
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:16px}

/* ===== Buttons ===== */
.btn{
  --pad:12px 18px;display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:Inter;font-weight:600;font-size:15px;padding:var(--pad);border-radius:var(--radius);
  border:1px solid transparent;cursor:pointer;transition:.18s var(--ease);white-space:nowrap;
}
.btn--lg{--pad:14px 24px;font-size:16px}
.btn--primary{background:var(--primary);color:#fff}
.btn--primary:hover{background:#0a2655;transform:translateY(-1px);box-shadow:var(--shadow)}
.btn--ghost{color:var(--ink-2)}
.btn--ghost:hover{color:var(--primary)}
.btn--outline{border-color:var(--border-2);color:var(--ink-2);background:#fff}
.btn--outline:hover{border-color:var(--primary);color:var(--primary)}
.btn--on-dark{background:transparent;border-color:rgba(255,255,255,.35);color:#fff}
.btn--on-dark:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn:active{transform:translateY(0) scale(.985)}
.ico-wa{flex:none;margin-right:-2px}

/* Botón destacado para fondos oscuros: recuadro blanco con glow teal + brillo que barre */
.btn--glow{position:relative;overflow:hidden;background:#fff;color:var(--primary);font-weight:700;
  box-shadow:0 0 0 1px rgba(255,255,255,.5),0 10px 30px -8px rgba(13,148,136,.55),0 0 44px rgba(13,148,136,.28)}
.btn--glow:hover{transform:translateY(-2px);
  box-shadow:0 0 0 1px #fff,0 16px 40px -8px rgba(13,148,136,.7),0 0 56px rgba(13,148,136,.4)}
.btn--glow::after{content:"";position:absolute;top:0;bottom:0;left:-60%;width:40%;
  background:linear-gradient(100deg,transparent,rgba(13,148,136,.18),transparent);
  transform:skewX(-18deg);animation:btn-shine 3.2s ease-in-out infinite}
@keyframes btn-shine{0%{left:-60%}55%{left:130%}100%{left:130%}}
@media (prefers-reduced-motion:reduce){.btn--glow::after{animation:none;display:none}}

/* ===== Eyebrow / heads ===== */
.eyebrow{display:inline-block;font-family:Inter;font-weight:600;font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.eyebrow--teal{color:#0a5f57;background:var(--accent-soft);
  padding:6px 12px;border-radius:999px;letter-spacing:.1em}    /* texto oscurecido para AA 4.5:1 sobre teal-soft */
.section__head{max-width:680px;margin:0 auto 36px;text-align:center}
.section__head h2{font-size:clamp(26px,6vw,40px);color:var(--ink)}
.section__head p{color:var(--muted);font-size:16px;margin-top:14px}
.section__head--dark h2{color:#fff}
.section__head--dark p{color:rgba(226,232,240,.8)}

/* ===== Nav ===== */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);
  background:linear-gradient(90deg,rgba(214,241,236,.82),rgba(216,226,255,.7));
  border-bottom:1px solid rgba(13,148,136,.18);transition:.2s var(--ease)}
.nav--scrolled{border-bottom-color:rgba(13,148,136,.30);
  background:linear-gradient(90deg,rgba(214,241,236,.95),rgba(225,233,255,.92))}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:60px;gap:12px}
.brand{display:flex;align-items:center;gap:10px}
.brand__logo{height:36px;width:auto;display:block}      /* logo vertical: alto fijo, sin deformar */
.brand__name{font-family:"Hanken Grotesk";font-weight:700;letter-spacing:.14em;font-size:18px;color:var(--primary)}
.nav__links{display:none}
.nav__actions{display:flex;align-items:center;gap:10px}
.nav__cta-mobile{display:none}   /* CTA dentro del menú hamburguesa: solo visible en mobile */

/* Hamburguesa (solo mobile) */
.nav__burger{display:none;flex-direction:column;justify-content:center;gap:5px;
  width:42px;height:42px;padding:9px;border:none;background:transparent;cursor:pointer}
.nav__burger span{display:block;height:2px;width:100%;background:var(--primary);border-radius:2px;
  transition:.25s var(--ease)}
.nav--open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav--open .nav__burger span:nth-child(2){opacity:0}
.nav--open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:1023px){
  .nav__burger{display:inline-flex}
  /* el CTA del top bar tapaba la "C" de MOGIDOC en mobile: se oculta y pasa al menú */
  .nav__actions .btn--primary{display:none}
  /* panel desplegable con los links */
  .nav--open .nav__links{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:rgba(255,255,255,.97);backdrop-filter:blur(10px);
    border-bottom:1px solid var(--border);box-shadow:0 14px 28px rgba(3,22,53,.12);
    padding:10px 16px 14px;gap:2px}
  .nav--open .nav__links a{padding:13px 10px;font-size:15px;font-weight:500;color:var(--ink-2);border-radius:8px}
  .nav--open .nav__links a:active,.nav--open .nav__links a:hover{background:var(--surface)}
  /* CTA "Solicitar demo" como botón al pie del menú */
  .nav--open .nav__links .nav__cta-mobile{display:flex;justify-content:center;align-items:center;gap:8px;
    margin-top:8px;padding:14px;color:#fff;background:var(--primary);border-radius:10px;font-weight:600}
  .nav--open .nav__links .nav__cta-mobile:active,
  .nav--open .nav__links .nav__cta-mobile:hover{background:#0a2655}
}

/* ===== Botón flotante: volver arriba (glass) ===== */
.to-top{position:fixed;right:16px;bottom:16px;z-index:60;
  width:48px;height:48px;border-radius:50%;display:grid;place-items:center;cursor:pointer;
  color:var(--primary);background:rgba(255,255,255,.55);
  backdrop-filter:blur(12px) saturate(1.6);-webkit-backdrop-filter:blur(12px) saturate(1.6);
  border:1px solid rgba(255,255,255,.65);box-shadow:0 8px 26px rgba(3,22,53,.20);
  opacity:0;visibility:hidden;transform:translateY(12px);transition:.28s var(--ease)}
.to-top.is-visible{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:rgba(255,255,255,.78);transform:translateY(-2px);box-shadow:0 12px 30px rgba(3,22,53,.26)}
.to-top:active{transform:translateY(0) scale(.94)}
@media (min-width:768px){.to-top{right:24px;bottom:24px;width:52px;height:52px}}
@media (prefers-reduced-motion:reduce){.to-top{transition:opacity .2s}}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;background:#fff}  /* blanco: el fondo del JPG se funde */
.hero__grid{display:grid;grid-template-columns:1fr;gap:8px;align-items:center;padding:40px 16px 0}
.hero h1{font-size:clamp(30px,8.5vw,56px);font-weight:800;color:var(--primary)}
.lede{font-size:17px;color:var(--muted);margin-top:18px;max-width:54ch}
.hero__cta{display:flex;gap:12px;margin-top:26px;flex-wrap:wrap}
.hero__cta .btn{width:100%}
.hero__trust{list-style:none;display:flex;flex-wrap:wrap;gap:8px 20px;padding:0;margin:26px 0 0}
.hero__trust li{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:500;color:var(--ink-2)}
.hero__trust .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}

/* ===== Hero media (médico con tablet, fondo blanco que se funde) ===== */
/* mobile: anclado abajo y recortado al médico para que no "flote" como sticker */
.hero__media{position:relative;width:100%;margin:14px 0 0;height:clamp(360px,96vw,480px);overflow:hidden}
/* contain + anclado abajo: en mobile se ve el médico ENTERO (no recortado) */
.hero__doc{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:50% 100%;display:block}

/* ===== Devices (laptop/teléfonos en otras secciones) ===== */

/* Laptop — portátil de aluminio plateado, bisel negro fino (estilo MacBook).
   La tapa se abre por animación (perspectiva 3D). */
/* width:89% (no 100%) para que el "deck" (base, margin:0 -6% → 112% de ancho) no
   sobresalga del viewport en mobile; en desktop igual topa con max-width:480px. */
.laptop{width:89%;max-width:480px;margin:0 auto;perspective:1700px}
.laptop__lid{position:relative;transform-origin:50% 100%;
  background:linear-gradient(150deg,#d8dce3 0%,#b8bec9 55%,#9aa0ad 100%); /* canto de aluminio */
  padding:5px;border-radius:15px 15px 7px 7px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75),inset 0 0 0 1px rgba(255,255,255,.25),
    0 18px 30px -10px rgba(3,22,53,.28),0 44px 72px -26px rgba(3,22,53,.40)}
.laptop__screen{position:relative;border:8px solid #0a0c12;border-radius:7px;overflow:hidden;background:#0b1426;
  box-shadow:inset 0 0 0 1px #000}
.laptop__screen img{width:100%;display:block}
.laptop__screen::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(120deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,.04) 15%,rgba(255,255,255,0) 30%)}
.laptop__cam{position:absolute;top:6px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;
  background:#1b2230;box-shadow:0 0 0 2px rgba(0,0,0,.3);z-index:2}
.laptop__deck{height:16px;margin:0 -6%;position:relative;
  background:linear-gradient(180deg,#eef0f4 0%,#cfd4dd 42%,#a9afba 100%);
  border-radius:0 0 8px 8px;
  box-shadow:inset 0 2px 2px rgba(255,255,255,.8),0 5px 10px rgba(3,22,53,.22)}
.laptop__deck::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;border-radius:0 0 8px 8px;
  background:linear-gradient(180deg,transparent,rgba(3,22,53,.16))}
.laptop__notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:96px;height:7px;
  background:linear-gradient(#bcc2cc,#9ba2ae);border-radius:0 0 8px 8px;box-shadow:inset 0 -1px 1px rgba(3,22,53,.25)}

/* Phone — usa el marco real (assets/phone-frame.png) como overlay.
   La captura se recorta exacta a la ventana de pantalla, sin desbordar. */
.phone{position:relative;width:200px;margin:0 auto;aspect-ratio:595/1200}
/* cuerpo blanco + sombra del teléfono (detrás de todo) */
.phone::before{content:"";position:absolute;inset:1.5%;border-radius:9%/4.4%;background:#fff;
  box-shadow:0 2px 6px rgba(3,22,53,.12),0 18px 30px -8px rgba(3,22,53,.28),0 44px 64px -22px rgba(3,22,53,.38);z-index:0}
.phone__screen{position:absolute;left:5.46%;top:1.6%;width:89.09%;height:96.87%;
  border-radius:6.48%/2.95%;overflow:hidden;background:#0b1426;z-index:2}
.phone__screen img{width:100%;height:100%;object-fit:cover;object-position:50% 0;display:block}
/* reflejo de vidrio sobre la pantalla (look premium) */
.phone__screen::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(125deg,rgba(255,255,255,.12) 0%,rgba(255,255,255,.03) 14%,rgba(255,255,255,0) 30%)}
/* contorno del frame por encima */
.phone::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:url("assets/phone-frame.png") center/100% 100% no-repeat}

/* ===== Strip — banda teal que corta el hero y al médico ===== */
.strip{position:relative;z-index:2;background:linear-gradient(90deg,var(--accent-600),var(--accent))}
.strip__inner{display:flex;flex-direction:column;align-items:center;gap:12px;padding:18px 16px;text-align:center}
.strip__inner>span{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.82);font-weight:700}
.strip__items{display:flex;align-items:center;gap:10px 12px;flex-wrap:wrap;justify-content:center;color:#fff}
.strip__items b{font-family:"Hanken Grotesk";font-weight:600;font-size:14px}
.strip__items i{color:rgba(255,255,255,.45);font-style:normal}

/* ===== Sections ===== */
.section{padding:56px 0}
.section--alt{background:var(--surface)}

/* Roles */
.roles{display:grid;grid-template-columns:1fr;gap:16px}
.role{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;
  transition:.2s var(--ease)}
.role:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.role--accent{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow)}
.role__tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent-600);background:var(--accent-soft);border-radius:999px;padding:4px 12px;margin-bottom:14px}
.role h3{font-size:19px;color:var(--ink)}
.role p{font-size:15px;color:var(--muted);margin:9px 0 0}

/* Comprobación */
.features{display:grid;grid-template-columns:1fr;gap:28px;align-items:center}
.feature-grid{display:grid;grid-template-columns:1fr;gap:16px}
.feature{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;
  transition:.2s var(--ease)}
.feature:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--border-2)}
.feature__icon{width:46px;height:46px;display:grid;place-items:center;border-radius:12px;
  background:var(--accent-soft);color:var(--accent-600);margin-bottom:14px;transition:.2s var(--ease)}
.feature__icon svg{width:24px;height:24px}
.feature:hover .feature__icon{background:var(--accent);color:#fff}
.feature h3{font-size:17px;color:var(--ink)}
.feature p{font-size:14px;color:var(--muted);margin:8px 0 0}
.features__device{display:flex;justify-content:center;order:-1}
.features__device .phone{width:230px}

/* Split sections */
.split{display:grid;grid-template-columns:1fr;gap:32px;align-items:center}
.split__copy h2{font-size:clamp(24px,6vw,36px);color:var(--ink);margin-top:6px}
.split__copy .lede{margin-top:14px;font-size:16px}
.checklist{list-style:none;padding:0;margin:22px 0 26px;display:grid;gap:14px}
.checklist li{position:relative;padding-left:30px;font-size:15px;color:var(--muted)}
.checklist li strong{color:var(--ink-2);font-weight:600}
.checklist li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;
  background:var(--accent-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%230b7e74' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat}

.split__phones{position:relative;display:flex;justify-content:center;align-items:center;min-height:430px}
.split__phones .phone{position:absolute;width:210px}
.phone--tilt-l{transform:translateX(-26%) rotate(-4deg);filter:saturate(.97)}
.phone--tilt-r{transform:translateX(22%) rotate(4deg)}
.phone--front{z-index:3}
.split__laptop{display:flex;justify-content:center}

/* Browser frame */
.browser{max-width:1000px;margin:0 auto;border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow-lg);background:#fff}
.browser__bar{display:flex;align-items:center;gap:7px;padding:10px 14px;background:#f1f4f8;border-bottom:1px solid var(--border)}
.browser__bar span{width:11px;height:11px;border-radius:50%;background:#cdd5e0}
.browser__bar span:nth-child(1){background:#f7768e}
.browser__bar span:nth-child(2){background:#f5c451}
.browser__bar span:nth-child(3){background:#5fd07f}
.browser__bar em{margin-left:10px;font-style:normal;font-size:12px;color:var(--muted-2);
  background:#fff;border:1px solid var(--border);border-radius:20px;padding:3px 12px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.browser img{width:100%;display:block}

/* ===== Cycle (dark) ===== */
.cycle{padding:56px 0;background:var(--primary-grad);color:#fff}
.cycle__steps{list-style:none;counter-reset:c;padding:0;margin:0;
  display:grid;grid-template-columns:1fr;gap:16px}
.cycle__steps li{position:relative;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius-lg);padding:22px;overflow:hidden;transition:.2s var(--ease)}
.cycle__steps li::after{content:"";position:absolute;left:0;top:0;height:2px;width:100%;
  background:linear-gradient(90deg,var(--accent),transparent 70%)}
.cycle__steps li:hover{background:rgba(255,255,255,.07);border-color:rgba(13,148,136,.4)}
.cycle__num{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;
  background:var(--accent);color:#fff;font-family:"Hanken Grotesk";font-weight:700;font-size:17px;margin-bottom:14px}
.cycle__steps h4{font-size:17px;color:#fff}
.cycle__steps p{margin:7px 0 0;font-size:14px;color:rgba(226,232,240,.75)}

/* ===== Cards ===== */
.cards{display:grid;grid-template-columns:1fr;gap:16px}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:.2s var(--ease)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--border-2)}
.card__ic{width:52px;height:52px;display:grid;place-items:center;border-radius:14px;
  background:var(--accent-soft);color:var(--accent-600);margin-bottom:16px;transition:.2s var(--ease)}
.card__ic svg{width:26px;height:26px}
.card:hover .card__ic{background:var(--accent);color:#fff}
.card h3{font-size:18px;color:var(--ink)}
.card p{font-size:14.5px;color:var(--muted);margin:9px 0 0}

/* Cards en carrusel: autoscroll + arrastre (mouse/dedo). El JS maneja el movimiento;
   acá: track horizontal, fade en bordes, padding vertical para no recortar el hover-lift. */
.cards-marquee{overflow-x:auto;overflow-y:hidden;cursor:grab;scrollbar-width:none;
  -webkit-mask:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);
  mask:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.cards-marquee::-webkit-scrollbar{display:none}
.cards-marquee.is-dragging{cursor:grabbing}
.cards-marquee.is-dragging .card{pointer-events:none}      /* evita clicks fantasma al arrastrar */
.cards-marquee .cards{display:flex;flex-wrap:nowrap;width:max-content;gap:18px;padding:16px 2px}
.cards-marquee .card{flex:0 0 320px}
/* indicadores (líneas): la activa en teal */
.cards-dots{display:flex;justify-content:center;gap:8px;margin-top:18px}
.cards-dots button{width:26px;height:4px;padding:0;border:none;border-radius:2px;cursor:pointer;
  background:var(--border-2);transition:.25s var(--ease)}
.cards-dots button:hover{background:var(--muted-2)}
.cards-dots button.is-active{background:var(--accent);width:34px}

/* ===== CTA ===== */
.cta{padding:56px 0;background:
  radial-gradient(600px 300px at 50% 0%,rgba(13,148,136,.18),transparent 60%),var(--primary)}
.cta__inner{text-align:center;max-width:680px}
.cta h2{font-size:clamp(26px,6vw,42px);color:#fff}
.cta p{color:rgba(226,232,240,.82);font-size:17px;margin:16px 0 28px}
.cta__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ===== Footer ===== */
.footer{background:#04101f;color:#cdd6e3;padding:48px 0 26px}
.footer__inner{display:grid;grid-template-columns:1fr;gap:32px}
.footer__brand .brand__name{color:#fff}
.footer__brand p{margin:16px 0 0;font-size:14px;color:#8a97a8;max-width:42ch}
.footer__cols{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.footer__cols h5{font-family:Inter;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#7e8b9d;margin:0 0 14px}
.footer__cols a{display:block;font-size:14px;color:#cdd6e3;margin-bottom:10px;transition:.15s}
.footer__cols a:hover{color:#fff}
.footer__legal{display:flex;flex-direction:column;gap:10px;
  margin-top:32px;padding-top:22px;border-top:1px solid rgba(255,255,255,.08);
  font-size:12.5px;color:#6f7d90}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(18px);transition:.7s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
.gsap .reveal{transition:none}      /* GSAP maneja el transform */
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* =========================================================
   TABLET — min-width: 768px
   ========================================================= */
@media (min-width:768px){
  .container{padding-inline:24px}
  .section{padding:80px 0}
  .cycle,.cta{padding:84px 0}
  .section__head{margin-bottom:48px}
  .section__head p{font-size:17px}

  .strip__inner{flex-direction:row;justify-content:center;gap:24px}
  .strip__items b{font-size:15px}

  .hero__cta .btn{width:auto}

  .roles{grid-template-columns:repeat(3,1fr);gap:20px}
  .feature-grid{grid-template-columns:1fr 1fr;gap:18px}
  .cycle__steps{grid-template-columns:1fr 1fr;gap:20px}
  .cards{grid-template-columns:1fr 1fr;gap:20px}

  .footer__inner{grid-template-columns:1.4fr 1.6fr;gap:48px}
  .footer__legal{flex-direction:row;justify-content:space-between;gap:16px;flex-wrap:wrap}

  .features__device .phone{width:248px}
  .split__phones{min-height:540px}
  .split__phones .phone{width:280px}
}

/* =========================================================
   DESKTOP — min-width: 1024px
   ========================================================= */
@media (min-width:1024px){
  .nav__inner{height:66px}
  .nav__links{display:flex;gap:28px}
  .nav__links a{font-size:14px;font-weight:500;color:var(--muted);transition:.15s}
  .nav__links a:hover{color:var(--primary)}

  /* La altura del hero (y por ende el alto del médico) escala con el ancho de viewport,
     no con el largo del texto: así el médico no se achica al acortar el copy ni queda
     chico en monitores anchos. SIN position:relative para que el médico se ancle al
     borde del viewport (.hero) y no al del .container centrado (1200px). */
  .hero__grid{grid-template-columns:1fr;gap:0;padding:56px 24px 0;min-height:clamp(700px,52vw,880px);align-items:center}
  .hero__copy{position:relative;z-index:2;align-self:center;max-width:560px;padding:40px 0 56px}
  .hero .lede{margin-top:20px}
  .hero__cta{margin-top:30px}
  .hero__trust{margin-top:30px}

  /* el médico ocupa el alto del hero, detrás del texto y anclado al strip;
     arranca bajo el nav para no cortar la cabeza, sin clip para ver la tablet */
  /* height:auto es CLAVE: resetea el height:clamp(...) de la regla mobile, que si no
     se hereda y deja el media en 400px (el médico chico y flotando). Con height:auto,
     top:62 + bottom:0 definen el alto real del media (= alto del hero). */
  .hero__media{position:absolute;z-index:1;top:62px;right:0;bottom:0;height:auto;width:clamp(460px,48vw,860px);
    max-width:none;margin:0;overflow:visible;pointer-events:none}
  /* Imagen ya recortada a la figura (assets/doc-figure.png), sin blanco: ocupa todo el
     alto del hero y se ancla al fondo, sin flotar. */
  .hero__doc{position:absolute;right:0;bottom:0;height:100%;width:auto;max-width:none}

  .features{grid-template-columns:1.4fr .9fr;gap:48px}
  .features__device{order:0}
  .split__phones{min-height:620px}
  .split__phones .phone{width:320px}
  .cycle__steps{grid-template-columns:repeat(3,1fr);gap:22px}
  .cards{grid-template-columns:repeat(3,1fr)}

  .split{grid-template-columns:1fr 1fr;gap:56px}
  .split--rev .split__copy{order:2}

  .footer__cols{grid-template-columns:repeat(2,1fr)}
}

@media (min-width:1140px){
  .footer__cols{grid-template-columns:repeat(2,minmax(0,1fr))}
}
