/* ═══════════════════════════════════════════════════════════════════════════
   Ópera de Morelia — FASE J4 polish completo
   Sección por sección, Apple-tier real
   ═══════════════════════════════════════════════════════════════════════════ */

/* ──────────── 1. INTRO SECTION — agregar foto centrada ──────────── */
.mod-intro-split{
  display: block !important;
  text-align: center !important;
  max-width: 1080px !important;
  margin: 0 auto !important;
}
.mod-intro-split .mod-intro-text{
  margin: 0 auto 64px !important;
  max-width: 720px !important;
  text-align: center !important;
}
.mod-intro-split .mod-intro-img{
  display: block !important;
  position: relative !important;
  max-width: 980px !important;
  margin: 0 auto !important;
  aspect-ratio: 16 / 9 !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,0.6) !important;
}
.mod-intro-split .mod-intro-img img{
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
}

/* ──────────── 2. OMAR PORTRAIT — centered Apple People style ──────────── */
/* Hide remaining eyebrows in non-mod-section containers */
.mod-portrait .mod-eyebrow:not(.opm-keep-eyebrow),
.mod-photomoment .mod-eyebrow:not(.opm-keep-eyebrow),
.mod-quote .mod-eyebrow:not(.opm-keep-eyebrow),
.mod-historia .mod-eyebrow:not(.opm-keep-eyebrow){
  display: none !important;
}

.mod-portrait{
  text-align: center !important;
  padding: clamp(120px, 16vh, 180px) 0 !important;
}
.mod-portrait-inner{
  display: block !important;
  max-width: 760px !important;
  margin: 0 auto !important;
  padding: 0 24px !important;
  text-align: center !important;
}
.mod-portrait-img{
  display: block !important;
  width: 280px !important;
  height: 280px !important;
  margin: 0 auto 48px !important;
  border-radius: 50% !important;
  overflow: hidden !important;
  position: relative !important;
  box-shadow: 0 20px 60px -10px rgba(0,0,0,0.5) !important;
}
.mod-portrait-img img{
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: 50% 18% !important;
  display: block !important;
}
.mod-portrait-signature{
  display: none !important;
}
.mod-portrait-body{
  max-width: 580px !important;
  margin: 0 auto !important;
  text-align: center !important;
}
.mod-portrait-name{
  font-family: var(--font-display, 'Fraunces'), Georgia, serif !important;
  font-variation-settings: "opsz" 96, "SOFT" 50, "wght" 500 !important;
  font-style: normal !important;
  font-size: clamp(2.6rem, 5vw, 4rem) !important;
  letter-spacing: -0.025em !important;
  line-height: 1.04 !important;
  color: #F2EDE2 !important;
  margin: 0 0 10px !important;
}
.mod-portrait-role{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
  text-transform: none !important;
  color: rgba(189,176,157,0.95) !important;
  margin: 0 0 36px !important;
  font-style: normal !important;
}
.mod-portrait .mod-prose,
.mod-portrait .mod-prose p{
  text-align: center !important;
  max-width: 560px !important;
  margin: 0 auto 22px !important;
  font-size: 16px !important;
  line-height: 1.65 !important;
}
.mod-portrait .mod-cta-row{
  justify-content: center !important;
  margin-top: 36px !important;
}

/* ──────────── 3. COLABORADORES — Apple Partners minimal cards ──────────── */
.mod-collab{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 24px !important;
  max-width: 1080px !important;
  margin: 56px auto 0 !important;
  text-align: left !important;
}
.mod-collab-item{
  background: transparent !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 18px !important;
  padding: 36px 32px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 12px !important;
  transition: border-color .25s, background .25s, transform .25s !important;
  min-height: 220px !important;
}
.mod-collab-item:hover{
  border-color: rgba(189,176,157,0.32) !important;
  background: rgba(255,255,255,0.025) !important;
  transform: translateY(-2px) !important;
}
.mod-collab-name,
.mod-collab-item h3{
  font-family: var(--font-display, 'Fraunces'), Georgia, serif !important;
  font-variation-settings: "opsz" 36, "SOFT" 50, "wght" 500 !important;
  font-style: normal !important;
  font-weight: 500 !important;
  font-size: 1.5rem !important;
  letter-spacing: -0.015em !important;
  line-height: 1.15 !important;
  color: #F2EDE2 !important;
  margin: 0 !important;
  padding: 0 !important;
}
.mod-collab-meta,
.mod-collab-item .mod-collab-meta{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: rgba(189,176,157,0.7) !important;
  margin: 0 !important;
  padding: 0 !important;
  font-style: normal !important;
}
.mod-collab-desc,
.mod-collab-item p:not(.mod-collab-meta){
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  letter-spacing: -0.005em !important;
  color: rgba(255,255,255,0.62) !important;
  margin: 8px 0 0 !important;
  padding: 0 !important;
  text-align: left !important;
  font-style: normal !important;
}

@media (max-width: 860px){
  .mod-collab{ grid-template-columns: 1fr !important; }
}

/* ──────────── 4. ESCUELA CARDS 2-UP — Apple Education ──────────── */
.mod-cards-2{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 24px !important;
  max-width: 1180px !important;
  margin: 56px auto 0 !important;
}
.mod-card-2{
  background: rgba(255,255,255,0.02) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 22px !important;
  overflow: hidden !important;
  text-decoration: none !important;
  color: inherit !important;
  display: block !important;
  transition: transform .3s cubic-bezier(.16,1,.3,1), border-color .3s !important;
}
.mod-card-2:hover{
  transform: translateY(-4px) !important;
  border-color: rgba(189,176,157,0.32) !important;
}
.mod-card-2-img{
  aspect-ratio: 16 / 10 !important;
  overflow: hidden !important;
  background: #000 !important;
}
.mod-card-2-img img{
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform .6s cubic-bezier(.16,1,.3,1) !important;
}
.mod-card-2:hover .mod-card-2-img img{
  transform: scale(1.05) !important;
}
.mod-card-2-body{
  padding: 32px 32px 36px !important;
  text-align: left !important;
}
.mod-card-2-body h3{
  font-family: var(--font-display, 'Fraunces'), Georgia, serif !important;
  font-variation-settings: "opsz" 72, "SOFT" 50, "wght" 500 !important;
  font-style: normal !important;
  font-weight: 500 !important;
  font-size: 1.75rem !important;
  letter-spacing: -0.02em !important;
  line-height: 1.1 !important;
  color: #F2EDE2 !important;
  margin: 0 0 12px !important;
}
.mod-card-2-body p{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
  letter-spacing: -0.005em !important;
  color: rgba(255,255,255,0.66) !important;
  margin: 0 0 18px !important;
}
.mod-card-link{
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: -0.005em !important;
  color: #BDB09D !important;
  transition: gap .25s !important;
}
.mod-card-link::after{ content: "→" !important; transition: transform .25s !important; }
.mod-card-2:hover .mod-card-link{ gap: 10px !important; }
.mod-card-2:hover .mod-card-link::after{ transform: translateX(3px) !important; }

@media (max-width: 760px){
  .mod-cards-2{ grid-template-columns: 1fr !important; }
}

/* ──────────── 5. PRODUCCIONES 3-UP cards — Apple polish ──────────── */
.mod-cards-3{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 24px !important;
  max-width: 1180px !important;
  margin: 56px auto 0 !important;
}
.mod-cards-3 .mod-card{
  background: rgba(255,255,255,0.02) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  transition: transform .3s cubic-bezier(.16,1,.3,1), border-color .3s !important;
}
.mod-cards-3 .mod-card:hover{
  transform: translateY(-4px) !important;
  border-color: rgba(189,176,157,0.32) !important;
}
.mod-card-img{
  aspect-ratio: 4 / 3 !important;
  overflow: hidden !important;
  position: relative !important;
}
.mod-card-img img{
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform .6s cubic-bezier(.16,1,.3,1) !important;
}
.mod-card:hover .mod-card-img img{ transform: scale(1.05) !important; }
.mod-card-body{
  padding: 24px 24px 28px !important;
}
.mod-card-title{
  font-family: var(--font-display, 'Fraunces'), Georgia, serif !important;
  font-variation-settings: "opsz" 36, "SOFT" 50, "wght" 500 !important;
  font-style: normal !important;
  font-size: 1.35rem !important;
  letter-spacing: -0.015em !important;
  line-height: 1.18 !important;
  color: #F2EDE2 !important;
  margin: 0 0 8px !important;
}
.mod-card-meta{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: rgba(255,255,255,0.6) !important;
  margin: 0 !important;
  font-style: normal !important;
}
.mod-card-year{
  position: absolute !important;
  top: 14px !important;
  left: 14px !important;
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 10.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.85) !important;
  background: rgba(0,0,0,0.5) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  backdrop-filter: blur(8px) !important;
  padding: 6px 12px !important;
  border-radius: 980px !important;
  font-style: normal !important;
}

@media (max-width: 960px){
  .mod-cards-3{ grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 600px){
  .mod-cards-3{ grid-template-columns: 1fr !important; }
}

/* ──────────── 6. PULL QUOTE — Apple-tier center ──────────── */
.mod-quote{
  background: #000 !important;
  padding: clamp(120px, 18vh, 200px) 0 !important;
  text-align: center !important;
}
.mod-quote-inner{
  max-width: 920px !important;
  margin: 0 auto !important;
  padding: 0 24px !important;
}
.mod-quote p{
  font-family: var(--font-display, 'Fraunces'), Georgia, serif !important;
  font-variation-settings: "opsz" 144, "SOFT" 70, "wght" 400 !important;
  font-style: italic !important;
  font-size: clamp(1.8rem, 3.8vw, 3rem) !important;
  line-height: 1.22 !important;
  letter-spacing: -0.018em !important;
  color: #F2EDE2 !important;
  max-width: 880px !important;
  margin: 0 auto 28px !important;
  text-align: center !important;
}
.mod-quote-mark{ display: none !important; }
.mod-quote-cite{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;
  text-transform: none !important;
  color: rgba(189,176,157,0.85) !important;
  font-style: normal !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
}
.mod-quote-cite::before{
  content: "" !important;
  width: 28px !important;
  height: 1px !important;
  background: rgba(189,176,157,0.5) !important;
}

/* ──────────── 7. TIMELINE — Apple polish ──────────── */
.mod-timeline-list{
  max-width: 1080px !important;
  margin: 56px auto 0 !important;
}
.mod-timeline-item{
  display: grid !important;
  grid-template-columns: 100px 1fr auto !important;
  gap: 32px !important;
  align-items: baseline !important;
  padding: 28px 0 !important;
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
  transition: background .25s !important;
}
.mod-timeline-item:hover{
  background: linear-gradient(90deg, transparent, rgba(189,176,157,0.04) 50%, transparent) !important;
}
.mod-timeline-year{
  font-family: var(--font-display, 'Fraunces'), Georgia, serif !important;
  font-variation-settings: "opsz" 72, "SOFT" 50, "wght" 500 !important;
  font-style: normal !important;
  font-size: 1.5rem !important;
  letter-spacing: -0.015em !important;
  color: rgba(189,176,157,0.9) !important;
}
.mod-timeline-content h3,
.mod-timeline-title{
  font-family: var(--font-display, 'Fraunces'), Georgia, serif !important;
  font-variation-settings: "opsz" 48, "SOFT" 50, "wght" 500 !important;
  font-style: normal !important;
  font-size: 1.2rem !important;
  letter-spacing: -0.012em !important;
  color: #F2EDE2 !important;
  margin: 0 0 6px !important;
}
.mod-timeline-meta,
.mod-timeline-content p{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 13.5px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: rgba(255,255,255,0.6) !important;
  margin: 0 !important;
  font-style: normal !important;
}
.mod-timeline-badge{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 10.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: rgba(189,176,157,0.75) !important;
  white-space: nowrap !important;
}

@media (max-width: 720px){
  .mod-timeline-item{
    grid-template-columns: 70px 1fr !important;
    gap: 18px !important;
  }
  .mod-timeline-badge{ grid-column: 2 !important; margin-top: 6px !important; }
}

/* ──────────── 8. NEWSLETTER — Apple subscribe polish ──────────── */
.opm-newsletter{
  background: #000 !important;
  padding: clamp(120px, 18vh, 200px) 0 !important;
  border-top: 1px solid rgba(255,255,255,0.06) !important;
}
.opm-newsletter-inner{
  text-align: center !important;
}
.opm-newsletter-h2{
  font-family: var(--font-display, 'Fraunces'), Georgia, serif !important;
  font-variation-settings: "opsz" 144, "SOFT" 50, "wght" 500 !important;
  font-style: normal !important;
  font-size: clamp(2.4rem, 5vw, 4rem) !important;
  letter-spacing: -0.025em !important;
  line-height: 1.06 !important;
  color: #F2EDE2 !important;
}
.opm-newsletter-h2 em{
  font-style: normal !important;
  color: #BDB09D !important;
}
.opm-newsletter-lede{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 17px !important;
  font-weight: 400 !important;
  line-height: 1.55 !important;
  letter-spacing: -0.008em !important;
  color: rgba(255,255,255,0.68) !important;
  max-width: 540px !important;
  margin: 18px auto 40px !important;
}
.opm-newsletter-form{
  max-width: 480px !important;
  margin: 0 auto !important;
}
.opm-newsletter-input{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 15px !important;
  letter-spacing: -0.005em !important;
}
.opm-newsletter-submit{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: -0.005em !important;
  background: #F2EDE2 !important;
  color: #1d1d1f !important;
}
.opm-newsletter-submit:hover{ background: #ffffff !important; }
.opm-newsletter-fine{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 12px !important;
  color: rgba(255,255,255,0.42) !important;
}

/* ──────────── 9. ESTUDIA + CONTACTO forms (legacy preserved) ──────────── */
.estudia, #contacto{
  padding: clamp(120px, 16vh, 180px) 0 !important;
  background: #000 !important;
  position: relative !important;
}
.estudia .section-bg, #contacto .section-bg{
  position: absolute !important;
  inset: 0 !important;
  opacity: 0.18 !important;
  overflow: hidden !important;
}
.estudia .section-bg img, #contacto .section-bg img{
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
}
.estudia .section-inner, #contacto .section-inner{
  position: relative !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 0 clamp(24px, 6vw, 64px) !important;
  z-index: 2 !important;
}
.estudia .section-eyebrow, #contacto .section-eyebrow{
  display: none !important;
}
.estudia .section-title, #contacto .section-title{
  font-family: var(--font-display, 'Fraunces'), Georgia, serif !important;
  font-variation-settings: "opsz" 144, "SOFT" 50, "wght" 500 !important;
  font-style: normal !important;
  font-size: clamp(2.4rem, 5vw, 4rem) !important;
  line-height: 1.06 !important;
  letter-spacing: -0.025em !important;
  color: #F2EDE2 !important;
  text-align: center !important;
  margin-bottom: 16px !important;
}
.estudia .section-title em, #contacto .section-title em,
.estudia .section-title i, #contacto .section-title i{
  font-style: normal !important;
  color: #BDB09D !important;
}
.estudia .section-lede, #contacto .section-lede{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 17px !important;
  font-weight: 400 !important;
  line-height: 1.55 !important;
  color: rgba(255,255,255,0.68) !important;
  max-width: 580px !important;
  text-align: center !important;
  margin: 0 auto 64px !important;
}
.estudia input,
.estudia textarea,
.estudia select,
#contacto input,
#contacto textarea,
#contacto select{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  padding: 14px 18px !important;
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 10px !important;
  color: #F2EDE2 !important;
  transition: border-color .2s, background .2s !important;
}
.estudia input:focus,
.estudia textarea:focus,
.estudia select:focus,
#contacto input:focus,
#contacto textarea:focus,
#contacto select:focus{
  outline: none !important;
  border-color: rgba(189,176,157,0.65) !important;
  background: rgba(255,255,255,0.06) !important;
}
.estudia label, #contacto label{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
  text-transform: none !important;
  color: rgba(255,255,255,0.7) !important;
  margin-bottom: 8px !important;
}
.estudia button[type=submit], #contacto button[type=submit],
.estudia .btn-submit, #contacto .btn-submit{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: -0.005em !important;
  padding: 14px 26px !important;
  background: #F2EDE2 !important;
  color: #1d1d1f !important;
  border: none !important;
  border-radius: 980px !important;
  cursor: pointer !important;
  transition: background .2s, transform .2s !important;
}
.estudia button[type=submit]:hover, #contacto button[type=submit]:hover{
  background: #ffffff !important;
  transform: translateY(-1px) !important;
}

/* ──────────── 10. FOOTER — Apple minimal ──────────── */
footer{
  background: #000 !important;
  padding: 80px 0 36px !important;
  border-top: 1px solid rgba(255,255,255,0.06) !important;
}
footer .footer-inner{
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 0 clamp(24px, 6vw, 64px) !important;
}
.footer-name{
  font-family: var(--font-display, 'Fraunces'), Georgia, serif !important;
  font-variation-settings: "opsz" 36, "SOFT" 50, "wght" 500 !important;
  font-style: normal !important;
  font-size: 17px !important;
  letter-spacing: -0.01em !important;
  text-transform: none !important;
  color: #F2EDE2 !important;
}
.footer-sub, .footer-desc{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  line-height: 1.55 !important;
  color: rgba(255,255,255,0.5) !important;
  font-style: normal !important;
}
.footer-col h4, .footer-col-title{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 11.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.85) !important;
  margin: 0 0 14px !important;
  font-style: normal !important;
}
.footer-col li a{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 13.5px !important;
  font-weight: 400 !important;
  color: rgba(255,255,255,0.6) !important;
  text-decoration: none !important;
  letter-spacing: -0.005em !important;
  transition: color .2s !important;
  font-style: normal !important;
}
.footer-col li a:hover{
  color: #F2EDE2 !important;
}
.footer-bot{
  border-top: 1px solid rgba(255,255,255,0.06) !important;
  margin-top: 48px !important;
  padding-top: 28px !important;
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
  font-size: 12px !important;
  color: rgba(255,255,255,0.4) !important;
  font-style: normal !important;
}

/* ──────────── 11. SEARCH OVERLAY — Inter Tight font fix ──────────── */
.opm-search-input{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
}
.opm-search-result-title{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
}
.opm-search-result-desc{
  font-family: var(--font-body, 'Inter Tight'), sans-serif !important;
}

/* ──────────── 12. FINAL CTA — Apple polish ──────────── */
.mod-final-cta{
  padding: clamp(120px, 18vh, 200px) 0 !important;
  text-align: center !important;
  background: #000 !important;
}
.mod-final-cta .mod-h2{
  font-size: clamp(2.4rem, 5.4vw, 4.2rem) !important;
  margin-bottom: 18px !important;
}
.mod-final-cta .mod-lede{
  max-width: 580px !important;
  margin: 18px auto 40px !important;
}
.mod-final-cta .mod-cta-row{
  justify-content: center !important;
  gap: 12px !important;
}
