/* ============================================================
   DAIKU — Responsive
   Mobile overrides + mobile-only component styles.
   Loaded AFTER site.css so specificity wins cleanly.
   ============================================================ */

/* Global: prevent any overflowing child from creating horizontal scroll */
/* clip instead of hidden: avoids creating a scroll container that breaks position:sticky */
html, body { overflow-x: clip; }

/* ─────────────────────────────────────────────────────────────
   DESKTOP: hide mobile-only elements
   ───────────────────────────────────────────────────────────── */
@media (min-width: 761px) {
  .nav__menu   { display: none !important; }
  .nav-drawer  { display: none !important; }
  .plans-mobile { display: none !important; }
}

/* ─────────────────────────────────────────────────────────────
   MOBILE LAYOUT OVERRIDES  (≤ 760 px)
   ───────────────────────────────────────────────────────────── */
@media (max-width: 760px) {

  /* ── Base ── */
  body { width: 100% !important; }

  /* ────────────────── NAV ────────────────── */
  .nav__inner {
    padding: 16px 20px !important;
    max-width: none !important;
  }
  .nav__links,
  .nav__cta { display: none !important; }

  /* Hamburger button */
  .nav__menu {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    border-radius: 999px;
    background: var(--daiku-ink);
    color: var(--daiku-cream);
    border: 0; cursor: pointer;
    flex-shrink: 0;
  }
  .nav__menu span {
    display: block; width: 16px; height: 1.5px;
    background: var(--daiku-cream); position: relative;
  }
  .nav__menu span::before,
  .nav__menu span::after {
    content: ''; position: absolute; left: 0;
    width: 16px; height: 1.5px; background: var(--daiku-cream);
  }
  .nav__menu span::before { top: -5px; }
  .nav__menu span::after  { top:  5px; }

  /* ────────────────── NAV DRAWER ────────────────── */
  .nav-drawer {
    position: fixed; inset: 0; z-index: 49;
    background: var(--daiku-cream);
    display: flex; flex-direction: column;
    padding: 88px 24px 48px;
    transform: translateX(100%);
    transition: transform 350ms cubic-bezier(.2,.7,.3,1);
    overflow-y: auto;
  }
  .nav-drawer.is-open { transform: translateX(0); }

  .nav-drawer__links {
    display: flex; flex-direction: column;
  }
  .nav-drawer__links a {
    display: block; padding: 16px 0;
    border-bottom: 1px solid var(--border-subtle);
    color: var(--daiku-ink); text-decoration: none;
    font-family: var(--font-display);
    font-size: 32px; font-weight: 800;
    letter-spacing: -0.03em; text-transform: uppercase;
    transition: opacity 150ms;
  }
  .nav-drawer__links a:active { opacity: 0.6; }

  .nav-drawer__close {
    position: absolute; top: 20px; right: 20px;
    width: 36px; height: 36px; border-radius: 999px;
    background: var(--daiku-ink); color: var(--daiku-cream);
    display: flex; align-items: center; justify-content: center;
    border: 0; cursor: pointer;
    font-size: 16px; line-height: 1;
  }

  /* ────────────────── HERO ────────────────── */
  .hero--video {
    padding: 0 !important;
    min-height: 640px !important;
  }
  .hero--video .hero__content {
    padding: 48px 20px 40px !important;
    min-height: 640px !important;
    max-width: none !important;
  }
  /* Override inline font-size on hero title spans — 52px keeps "RECÁMARAS" within 350px content area */
  .hero__title .en,
  .hero__title .em,
  .hero__title .it {
    font-size: 52px !important;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .hero__meta {
    margin-top: 24px !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  .hero__scroll { display: none !important; }

  /* ────────────────── SECTIONS ────────────────── */
  .section {
    padding: 64px 20px !important;
    max-width: none !important;
  }

  /* ────────────────── RESUELTO ────────────────── */
  .resuelto {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
  }
  .resuelto__copy  { order: 1; }
  .resuelto__media { order: 2; margin-top: 28px !important; }
  .resuelto__list  { order: 3; grid-template-columns: 1fr !important; gap: 18px !important; margin-top: 28px !important; }
  .resuelto__copy h2 {
    font-size: 48px !important;
    padding: 0 !important;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .resuelto__lead {
    font-size: 15px !important;
    line-height: 1.55 !important;
    letter-spacing: 0 !important;
    max-width: none !important;
    margin: 20px 0 0 !important;
  }

  /* ────────────────── DETALLES ────────────────── */
  .detalles {
    display: block !important;
    height: auto !important;
  }
  .detalles__copy h2 {
    font-size: 48px !important;
    padding: 0 !important;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .detalles__copy p {
    font-size: 15px !important;
    margin: 20px 0 0 !important;
    max-width: 100% !important;
    width: auto !important;
  }
  .detalles__media {
    min-height: auto !important;
    margin-top: 24px !important;
  }

  /* ────────────────── PLANS ────────────────── */
  #planos { padding: 8px 0 !important; }
  .plans {
    border-radius: 28px !important;
    margin: 0 12px !important;
    padding: 0 !important;
  }
  .plans-desktop { display: none !important; }
  .plans-mobile  { display: block !important; padding: 48px 20px !important; }

  /* Plans v2 mobile — active card + preview strip */
  .plans__head--m {
    display: flex; align-items: flex-end;
    justify-content: space-between; gap: 16px;
  }
  .plans__head--m h2 {
    margin: 0;
    font-size: 48px;
    word-break: break-word;
    overflow-wrap: break-word;
    color: var(--daiku-cream);
    line-height: 0.92;
    letter-spacing: -0.04em;
    font-weight: 800;
    text-transform: uppercase;
  }
  .plans__head--m h2 .it {
    font-family: var(--font-display);
    font-weight: 300; font-style: normal;
    text-transform: uppercase; letter-spacing: -0.02em;
  }
  .plans__nav-m { display: flex; gap: 8px; flex-shrink: 0; }
  .plans__nav-btn-m {
    width: 40px; height: 40px; border-radius: 999px;
    background: transparent;
    border: 1px solid rgba(255,250,233,0.35);
    color: var(--daiku-cream);
    font-size: 16px; line-height: 1; cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
  }
  .plans__nav-btn-m:active { background: var(--daiku-cream); color: var(--daiku-ink); }

  .plans__meta {
    margin-top: 24px;
    border-top: 1px solid var(--border-on-dark);
    padding-top: 16px;
    display: grid; gap: 12px;
  }
  .plans__meta .x {
    display: flex; justify-content: space-between; align-items: baseline;
  }
  .plans__meta .lbl {
    font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase;
    opacity: 0.55; font-weight: 500;
  }
  .plans__meta .val { font-size: 14px; font-weight: 500; }

  .plans__active-m {
    margin-top: 24px;
    background: var(--daiku-ink);
    border-radius: 22px;
    border: 1px solid rgba(255,250,233,0.08);
    overflow: hidden;
    animation: planFadeM 320ms var(--ease-out, cubic-bezier(.2,.7,.3,1));
  }
  @keyframes planFadeM {
    from { transform: translateY(12px); }
    to   { transform: translateY(0); }
  }

  .plans__active-img-m {
    position: relative;
    background: var(--daiku-cream);
    margin: 12px; border-radius: 16px; overflow: hidden;
    aspect-ratio: 4/3;
    display: flex; align-items: center; justify-content: center;
  }
  .plans__active-img-m img {
    width: 100%; height: 100%; object-fit: contain; display: block;
  }
  .plans__active-img-m .plans__floor-tag {
    position: absolute; top: 14px; left: 14px;
    background: var(--daiku-ink); color: var(--daiku-cream);
    padding: 7px 12px; border-radius: 999px;
    font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase;
    font-weight: 600;
  }
  .plans__active-img-m.is-empty {
    background: var(--cocoa-50);
    border: 1px dashed var(--border-default);
  }
  .plans__active-img-m.is-empty::after {
    content: "Pega URL de imagen en Tweaks";
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase;
    font-weight: 600; color: var(--cocoa-600);
    text-align: center; padding: 16px; pointer-events: none;
  }

  .plans__active-arrow-m {
    position: absolute; top: 12px; right: 12px;
    width: 38px; height: 38px; border-radius: 999px;
    background: var(--daiku-ink); color: var(--daiku-cream);
    border: 1px solid rgba(255,250,233,0.2);
    font-size: 15px; cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
  }

  .plans__active-specs-m {
    color: var(--daiku-cream);
    padding: 12px 20px 24px;
    display: flex; flex-direction: column; gap: 20px;
  }
  .plans__active-specs-m .plans__specs-head { display: flex; flex-direction: column; gap: 4px; }
  .plans__active-specs-m .plans__specs-head .lbl {
    font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--daiku-beige); font-weight: 500;
  }
  .plans__active-specs-m .plans__specs-head .val {
    font-family: var(--font-display);
    font-size: 44px; font-weight: 800; letter-spacing: -0.03em; line-height: 1;
    text-transform: uppercase; color: var(--daiku-cream); margin-top: 4px;
  }
  .plans__active-specs-m .plans__specs-head .sub {
    font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
    color: rgba(255,250,233,0.55); font-weight: 500; margin-top: 4px;
  }
  .plans__active-specs-m .plans__specs-list {
    list-style: none; margin: 0; padding: 0;
    border-top: 1px solid var(--border-on-dark);
  }
  .plans__active-specs-m .plans__specs-list li {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: 14px 0; border-bottom: 1px solid var(--border-on-dark); gap: 16px;
  }
  .plans__active-specs-m .plans__specs-list li > span {
    font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
    color: rgba(255,250,233,0.6); font-weight: 500;
  }
  .plans__active-specs-m .plans__specs-list li > b {
    font-size: 15px; font-weight: 600; letter-spacing: -0.01em; color: var(--daiku-cream);
  }

  /* Preview strip */
  .plans__previews-m {
    margin-top: 14px;
    display: flex; gap: 12px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 4px 56px 4px 0;
    scrollbar-width: none;
  }
  .plans__previews-m::-webkit-scrollbar { display: none; }

  .plans__preview-m {
    position: relative; flex: 0 0 70%; aspect-ratio: 3/4;
    border-radius: 22px; background: var(--cocoa-50);
    border: 1px solid rgba(255,250,233,0.08);
    overflow: hidden; cursor: pointer; padding: 0;
    scroll-snap-align: start; display: block; text-align: left;
  }
  .plans__preview-img-m {
    position: absolute; inset: 0;
    width: 100%; height: 100%; object-fit: cover; display: block;
  }
  .plans__preview-m::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,0.55) 100%);
    pointer-events: none;
  }
  .plans__preview-chip-m {
    position: absolute; top: 14px; left: 14px;
    background: rgba(15,12,10,0.55); backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px); color: var(--daiku-cream);
    padding: 6px 11px; border-radius: 999px;
    font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase;
    font-weight: 600; border: 1px solid rgba(255,250,233,0.18); z-index: 2;
  }
  .plans__preview-name-m {
    position: absolute; left: 16px; right: 16px; bottom: 18px;
    color: var(--daiku-cream); font-family: var(--font-display);
    font-size: 26px; font-weight: 800; letter-spacing: -0.02em; line-height: 1;
    text-transform: uppercase; z-index: 2;
  }
  .plans__preview-m.is-empty .plans__preview-img-m { display: none; }
  .plans__preview-m.is-empty {
    background: var(--cocoa-100);
    border: 1px dashed rgba(255,250,233,0.2);
  }
  .plans__preview-m.is-empty::after { display: none; }

  /* ────────────────── AMENIDADES ────────────────── */
  .section--dark {
    padding: 0 0 100px !important;
    max-width: none !important;
    border-radius: 25px 25px 0 0 !important;
  }
  .section--dark > * { max-width: none !important; padding: 0 !important; }
  .amen { padding: 50px 20px 0 !important; margin: 0 !important; }
  .amen__head {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    margin-bottom: 28px !important;
    margin: 0 0 28px !important;
  }
  .amen__title,
  .amen__head h2 {
    font-size: 48px !important;
    padding: 0 !important;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .amen__lead,
  .amen__head p { max-width: none !important; font-size: 15px !important; }
  /* Card stack — JS drives positioning; CSS provides base layout */
  .amen-stack-outer { position: relative; }
  .amen__grid {
    display: block !important;
    gap: 0 !important;
    border-radius: 22px !important;
  }
  .amen__card { border-radius: 0 !important; }
  .amen__card.span-2,
  .amen__card.span-3,
  .amen__card.span-4,
  .amen__card.span-6 { grid-column: unset !important; min-height: unset !important; }

  /* ────────────────── AVANCE ────────────────── */
  #avance.section { padding: 0 20px !important; }
  .avance { padding: 64px 20px !important; margin: 0 !important; }
  .avance__head {
    grid-template-columns: 1fr !important;
    padding-bottom: 20px !important;
    margin-bottom: 24px !important;
  }
  .avance__head h2 {
    font-size: 48px !important;
    padding: 0 !important;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .avance__marquee { margin-inline: -20px !important; }

  /* ────────────────── UBICACIÓN ────────────────── */
  #ubicacion.section {
    padding: 64px 20px 100px !important;
    color: var(--daiku-ink) !important;
    font-size: inherit !important;
  }
  .location { display: block !important; margin: 0 !important; }
  .location__copy { padding-right: 0 !important; }
  .location__copy h2 {
    font-size: 48px !important;
    padding: 0 !important;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .location__copy p { font-size: 15px !important; max-width: none !important; }
  .location__addr .val { font-size: 16px !important; }
  .location__map {
    margin-top: 28px !important;
    aspect-ratio: 4/5 !important;
    margin-left: 0 !important;
  }

  /* ────────────────── CONTACT HERO ────────────────── */
  .contact-hero { padding: 100px 20px 48px !important; }
  .contact-hero__title {
    font-size: 48px !important;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .contact-hero__lead {
    font-size: 15px !important;
    margin-bottom: 32px !important;
    max-width: none !important;
  }
  .contact-hero__meta {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    max-width: none !important;
  }

  /* ────────────────── CONTACT FORM ────────────────── */
  .contact { padding: 64px 20px 48px !important; margin: 0 !important; border-radius: 16px 16px 0 0 !important; }
  .contact__inner { padding: 64px 20px 48px !important; max-width: none !important; }
  .contact__grid { grid-template-columns: 1fr !important; gap: 48px !important; }
  .contact__head h2 {
    font-size: 48px !important;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .field-row { display: block !important; }

  /* ────────────────── FOOTER ────────────────── */
  .footer { margin: 0 !important; }
  .footer__inner { padding: 40px 20px 24px !important; margin: 0 !important; }
  .footer__top {
    display: flex !important;
    flex-direction: column !important;
    gap: 32px !important;
  }
  .footer__bottom {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 6px !important;
    margin-top: 40px !important;
  }
}
