/* ============================================================
   MOBILE BREAKPOINT — max-width: 768px
   Diseño de referencia: Figma frame "DM/Mobile 390/01"
   Breakpoint aplicado: 390px de diseño → 768px como breakpoint CSS
   IMPORTANTE: Siempre usar variables de tokens.css, nunca valores
   hardcodeados de color o tipografía.
   ============================================================ */

/* --- BASE (todos los viewports) ---------------------------------------
   Los elementos exclusivos de mobile están ocultos por defecto y solo se
   muestran dentro del @media. Así el desktop no cambia. */
.hamburger {
  display: none;
}

.menu-overlay {
  display: none;
}

/* Botón Resume del Hero: oculto en desktop, visible solo en mobile. */
.btn--resume-mobile {
  display: none;
}

/* Scroll lock del body cuando el menú está abierto (lo activa el JS).
   Solo se aplica en mobile porque el overlay solo se abre ahí. */
body.menu-open {
  overflow: hidden;
}


@media (max-width: 768px) {

  /* --- GLOBAL --- */
  /* Container: de 120px / 64px a 24px de margen lateral. */
  .container {
    padding-inline: var(--spacing-5); /* 24px */
  }

  /* Contiene el desbordamiento horizontal del título con white-space:nowrap.
     padding-top: 120px → el contenido empieza a 120px del header.
     justify-content: flex-start → el contenido fluye desde arriba, no centrado. */
  .hero {
    overflow-x: clip;
    padding-top: 70px;
    justify-content: flex-start;
  }

  /* Flex column en .hero__inner → habilita align-self en sus hijos directos. */
  .hero__inner {
    display: flex;
    flex-direction: column;
  }

  /* --- ICONO LET'S TALK ---
     display:grid !important anula el display:none de styles.css ≤768px.
     align-self:flex-end !important → borde derecho del flex column padre. */
  .lets-talk {
    display: grid !important;
    position: relative;
    width: 7.25rem;
    align-self: flex-end !important;
    margin-top: var(--spacing-6); /* 32px del botón Resume */
  }

  /* Título en dos líneas a 40px: "I'm" arriba, texto animado abajo.
     flex-direction:column apila los dos spans (el padre es flex en fila). */
  .hero__title {
    font-size: 32px;
    line-height: 40px;
    white-space: normal;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }

  .hero__title .hero__title-thin {
    line-height: 40px;
  }

  .hero__lead {
    font-size: 16px;
  }

  .container--header {
    padding-inline: var(--spacing-5); /* 24px (anula los 64px del header) */
  }

  /* --- HEADER --- */
  /* Altura del header: 78px en mobile (vs 70px desktop). */
  .site-header__inner {
    min-height: 4.875rem; /* 78px */
  }

  /* Header siempre con fondo blur blanco en mobile — igual que .scrolled en desktop.
     El rebote de scroll ya está resuelto con overflow-x:clip en .hero,
     no con la eliminación del backdrop-filter. */
  .site-header {
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(4.15px);
    -webkit-backdrop-filter: blur(4.15px);
    transition: transform 300ms ease;
  }

  /* Hide-on-scroll: el JS añade .header--hidden al bajar (lo quita al subir). */
  .site-header.header--hidden {
    transform: translateY(-100%);
  }

  @media (prefers-reduced-motion: reduce) {
    .site-header {
      transition: none;
    }
  }

  /* Nav links del header desktop: ocultos en mobile. */
  .primary-nav {
    display: none;
  }

  /* Botón Resume del header: oculto en mobile. */
  .site-header .btn {
    display: none;
  }

  /* Botón Resume del Hero: visible en mobile (oculto en desktop).
     Overrides XS-M vs desktop: padding, font-size, line-height y min-height.
     El resto (bg, color, border-radius, gap 4px, icono 20px) se hereda de .btn. */
  .btn--resume-mobile {
    display: inline-flex;
    padding: 12px 16px;
    font-size: 18px;
    line-height: 24px;
    min-height: 48px;
  }

  /* Hamburger button: visible, 48×48px, icono 20×20px, a la derecha. */
  .hamburger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;  /* 48px */
    height: 3rem; /* 48px */
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: 999px;
    cursor: pointer;
    color: var(--color-content-1);
  }

  .hamburger-svg {
    width: 1.25rem;  /* 20px */
    height: 1.25rem; /* 20px */
    flex-shrink: 0;
  }

  .hamburger:focus-visible {
    outline: 2px solid var(--color-focus-ring);
    outline-offset: 2px;
  }

  /* (a) Con el menú abierto, el header (transparente) sube por encima del
     overlay para que el hamburger → X quede visible y clicable sobre el blanco. */
  body.menu-open .site-header {
    z-index: 300; /* > .menu-overlay (200) */
    background-color: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: none;
  }

  /* Con el menú abierto se oculta el logo: solo queda la X sobre el negro. */
  body.menu-open .site-logo {
    visibility: hidden;
  }

  /* X visible sobre fondo negro: currentColor del SVG inline → blanco. */
  body.menu-open .hamburger-svg {
    color: #FFFFFF;
  }

  /* --- MORPHING hamburger → X ---
     Cada barra rota sobre su propio centro (transform-box: fill-box) y se
     desplaza al centro geométrico del viewBox (10,10).
     Barra top: centro y=6.5 → translateY(+3.5) ; barra bottom: y=13.5 → translateY(-3.5). */
  .hamburger-line {
    transform-box: fill-box;
    transform-origin: center;
    transition: transform 300ms ease, opacity 300ms ease;
  }

  #hamburger-btn[aria-expanded="true"] .hamburger-line--top {
    transform: translateY(3.5px) rotate(45deg);
  }

  #hamburger-btn[aria-expanded="true"] .hamburger-line--bottom {
    transform: translateY(-3.5px) rotate(-45deg);
  }

  /* --- OVERLAY MENU --- */
  /* Modal a pantalla completa, fondo blanco. Cerrado: invisible y fuera del
     árbol de accesibilidad (visibility:hidden) → no focusable.
     Abierto (.is-open): visible con fundido + desplazamiento suave. */
  .menu-overlay {
    display: flex;
    flex-direction: column;
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100dvh; /* dvh en vez de vh para iOS Safari */
    overflow: hidden; /* evita scrollbar: el contenido no desborda */
    z-index: 200; /* por encima del header sticky (z-index:100) */
    background-color: #1A1A1A;
    padding: var(--spacing-5); /* 24px */
    padding-top: 15px; /* iguala el padding del header → X alineada con el hamburger */

    /* Estado cerrado */
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: opacity 0.25s ease, transform 0.25s ease,
      visibility 0s linear 0.25s;
  }

  /* Estado abierto */
  .menu-overlay.is-open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    transition: opacity 0.25s ease, transform 0.25s ease,
      visibility 0s linear 0s;
  }

  .menu-overlay__close {
    position: absolute;
    top: 15px;
    right: 24px;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--color-background-1);
  }

  /* Nav del overlay: 4 items centrados vertical y horizontalmente. */
  .menu-overlay__nav {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .menu-overlay__nav ul {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-6); /* 32px entre items */
  }

  /* Items: 48px bold, color de texto principal. */
  .menu-overlay__link {
    display: inline-block;
    font-size: var(--font-size-heading-l);   /* 48px */
    line-height: var(--line-height-heading-l); /* 48px */
    font-weight: var(--font-weight-bold);
    color: #FFFFFF;
    text-decoration: none;
  }

  .menu-overlay__link:focus-visible {
    outline: 2px solid var(--color-focus-ring);
    outline-offset: 4px;
  }

  /* --- Animación de entrada en cascada de los links --- */

  /* Estado base: ocultos y desplazados hacia abajo. */
  .menu-overlay__nav li {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 300ms ease, transform 300ms ease;
  }

  /* Estado abierto: visibles en posición. */
  .menu-overlay.is-open .menu-overlay__nav li {
    opacity: 1;
    transform: translateY(0);
  }

  /* Stagger: delay progresivo por cada link (~60ms entre cada uno). */
  .menu-overlay.is-open .menu-overlay__nav li:nth-child(1) { transition-delay:  80ms; }
  .menu-overlay.is-open .menu-overlay__nav li:nth-child(2) { transition-delay: 140ms; }
  .menu-overlay.is-open .menu-overlay__nav li:nth-child(3) { transition-delay: 200ms; }
  .menu-overlay.is-open .menu-overlay__nav li:nth-child(4) { transition-delay: 260ms; }

  /* Reset del delay al cerrar: la próxima apertura vuelve a animarse. */
  .menu-overlay:not(.is-open) .menu-overlay__nav li {
    transition-delay: 0ms;
  }

  /* Respetar prefers-reduced-motion: sin animación de apertura/cierre,
     ni morphing del hamburger, ni cascada de links. */
  @media (prefers-reduced-motion: reduce) {
    .menu-overlay,
    .menu-overlay.is-open {
      transform: none;
      transition: visibility 0s linear 0s;
    }
    .hamburger-line {
      transition: none !important;
    }
    .menu-overlay__nav li {
      transition: none !important;
    }
  }

  /* ============================================================
     SECCIÓN 1 — THE WORK
  ============================================================ */

  /* Grid de desktop → columna única. .work__cards y .work__grid
     tienen display:contents, así que los <li> son grid items directos.
     Los ponemos en 1 columna a ancho completo. */
  .work {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-6); /* 32px entre heading y primera card */
    margin-top: 0;
  }

  /* El heading de The Work ya no ocupa una celda del grid. */
  .work__heading {
    padding-top: 0;
    padding-right: 0;
  }

  /* .work__cards y .work__grid dejan de ser display:contents
     para poder controlar el layout de las cards. */
  .work__cards {
    display: block;
  }

  .work__grid {
    display: flex;
    flex-direction: column;
    gap: 0;
    list-style: none;
    padding: 0;
    margin: 0;
  }

  /* Cards a ancho completo del contenedor. */
  .project-card {
    width: 100%;
  }

  /* ============================================================
     SECCIÓN 2 — ABOUT ME
  ============================================================ */

  /* Tabs centradas. */
  .tabs__list {
    align-self: center;
  }

  /* Grid 12 cols → columna única apilada. */
  .about {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-6); /* 32px entre bloques */
  }

  .about__heading,
  .about__image,
  .about__content {
    grid-column: unset; /* anula los grid-column del desktop */
  }

  .about__heading {
    padding-top: var(--spacing-5); /* 24px — iguala el padding-top de Core Skills */
    margin-bottom: var(--spacing-4); /* 16px entre título e imagen */
  }

  /* Imagen centrada. */
  .about__image {
    margin-right: 0;
    justify-self: unset;
    margin: 0 auto;
  }

  .about__content {
    padding-top: 0;
  }

  .about__lead {
    padding-top: var(--spacing-7); /* 48px */
  }

  /* ============================================================
     SECCIÓN 3 — CORE SKILLS
  ============================================================ */

  /* Grid 2 cols → columna única. */
  .skills {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-8); /* 64px entre heading y acordeones */
  }

  .skills__heading-col {
    grid-column: unset;
  }

  /* Acordeones a ancho completo (anula grid-column: 7/13). */
  .accordion {
    grid-column: unset;
    width: 100%;
  }

  /* ============================================================
     SECCIÓN 4 — BANNER LOGOS
  ============================================================ */

  /* Detiene el marquee y apila logos en columna centrada. */
  .logos {
    padding-bottom: 80px;
  }

  .logos__marquee {
    animation: none;
    flex-direction: column;
    align-items: center;
    width: 100%;
    padding-block: var(--spacing-6); /* 32px */
    gap: 0;
    pointer-events: none;
  }

  /* Solo el primer track (el real); la copia duplicada se oculta. */
  .logos__track {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-6); /* 32px entre logos */
  }

  .logos__track[aria-hidden="true"] {
    display: none;
  }

  .logos__item {
    padding-inline: 0;
  }

  .logos__item img {
    height: 60px;
    width: auto;
  }

  /* ============================================================
     SECCIÓN 5 — FOOTER
  ============================================================ */

  /* Título "Let's talk" — 48px / line-height 1.1 (vs 64px desktop). */
  .footer__title {
    font-size: 48px;
    line-height: 1.1;
  }

  /* Subtítulo descriptivo — 24px / line-height 1.3 (vs 32px desktop). */
  .footer__lead {
    font-size: 24px;
    line-height: 1.3;
  }

  /* Botón "Get in touch": XS-M Figma + ancho completo.
     background-color y color ya están bien en desktop (blanco/#1A1A1A). */
  .site-footer .footer__cta-btn {
    padding: 12px 16px;
    font-size: 18px;
    min-height: 48px;
    width: 100%;
    justify-content: center;
  }

  /* .footer__actions en columna: links debajo del texto lead,
     CTA debajo de los links. */
  .footer__actions {
    flex-direction: column;
    gap: var(--spacing-5); /* 24px entre links y CTA */
  }

  /* CTA wrap a ancho completo (para que el botón pueda ser 100%). */
  .footer__cta-wrap {
    align-items: stretch;
    padding-bottom: 0;
    width: 100%;
  }

  /* Copyright centrado. */
  .footer__copyright {
    text-align: center;
    font-size: 14px;
    font-weight: 400;
  }

  /* ============================================================
     COMING SOON — página interior (/projects/coming-soon.html)
  ============================================================ */

  /* .page-nav: padding lateral lo gestiona container--header (24px en mobile) */

  /* Padding lateral 24px lo aporta .container; reducimos el respiro vertical. */
  .coming-soon {
    padding-block: var(--spacing-7); /* 48px */
  }

  /* Título: 32px / 40px (vs 48/48 desktop). */
  .coming-soon__title {
    font-size: var(--font-size-heading-s); /* 32px */
    line-height: var(--line-height-heading-s); /* 40px */
    max-width: 100%;
  }

  .coming-soon__title .title-hl__img {
    height: 0.75em;
  }

  /* Subtítulo: 16px (vs 20px desktop). */
  .coming-soon__subtitle {
    font-size: var(--font-size-body-m); /* 16px */
    line-height: var(--line-height-body-m); /* 24px */
    max-width: 100%;
  }

  /* Footer compacto: barra en columna, CTA a ancho completo. */
  .site-footer--compact {
    padding-top: var(--spacing-7); /* 48px */
  }

  .footer-compact__bar {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-5); /* 24px */
    min-height: 0;
  }

  .footer-compact__title {
    order: 1;
  }

  .footer-compact__links {
    order: 2;
    gap: var(--spacing-4); /* 16px */
  }

  /* El CTA reutiliza .footer__cta-btn → ya es width:100% en mobile.
     Aseguramos que ocupe la fila completa también como hijo flex. */
  .footer-compact__cta {
    order: 3;
    align-self: stretch;
  }

  .footer-compact__copyright-bar {
    margin-top: var(--spacing-6); /* 32px */
    text-align: center;
  }
}

/* ============================================================
   EXTRA SMALL — max-width: 380px
   Para viewports de 360px donde el título de coming-soon
   se rompería en 3 líneas con 32px.
   ============================================================ */
@media (max-width: 380px) {
  .coming-soon__title {
    font-size: 28px;
    line-height: 36px;
  }

  .coming-soon__title .title-hl__img {
    height: 0.75em;
  }
}
