/* ═══════════════════════════════════════════════════════════════════════════
   Ópera de Morelia — Search overlay + Video component styles
   ═══════════════════════════════════════════════════════════════════════════ */

/* ──────────── SEARCH OVERLAY (Apple-style spotlight) ──────────── */
.opm-search-overlay{
  position:fixed;
  inset:0;
  z-index:9999;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s cubic-bezier(.4,0,.2,1);
}
.opm-search-overlay.is-open{
  opacity:1;
  pointer-events:auto;
}
.opm-search-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0.72);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  backdrop-filter:blur(20px) saturate(140%);
  overflow: hidden;
}
.opm-search-backdrop::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image: url('/img/2026/la-mulata-museo/partitura-firmada-omar-nieto.jpg');
  background-size: cover;
  background-position: center 40%;
  filter: grayscale(100%) contrast(1.1) brightness(0.7);
  opacity: 0.28;
  pointer-events: none;
  z-index: 0;
}
.opm-search-backdrop::after{
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 100% 80% at 50% 30%, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.75) 60%, rgba(0,0,0,0.92) 100%);
  pointer-events: none;
  z-index: 1;
}
.opm-search-panel{
  position:relative;
  max-width:680px;
  margin:8vh auto 0;
  background:rgba(20,20,22,0.92);
  -webkit-backdrop-filter:blur(40px) saturate(180%);
  backdrop-filter:blur(40px) saturate(180%);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:18px;
  padding:18px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,0.7);
  transform:translateY(-12px);
  opacity:0;
  transition:transform .35s cubic-bezier(.16,1,.3,1), opacity .25s ease;
}
.opm-search-overlay.is-open .opm-search-panel{
  transform:translateY(0);
  opacity:1;
}
.opm-search-bar{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 18px;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.opm-search-bar::before{
  content:"";
  width:18px;
  height:18px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23BDB09D' stroke-width='2' stroke-linecap='round'><circle cx='11' cy='11' r='7'/><path d='m20 20-3.5-3.5'/></svg>") center/contain no-repeat;
  flex:0 0 auto;
  opacity:0.85;
}
.opm-search-input{
  flex:1 1 auto;
  background:transparent;
  border:none;
  outline:none;
  color:#F2EDE2;
  font-family:'Inter',sans-serif;
  font-size:18px;
  font-weight:400;
  letter-spacing:-0.01em;
}
.opm-search-input::placeholder{
  color:rgba(255,255,255,0.4);
  font-weight:400;
}
.opm-search-close{
  flex:0 0 auto;
  width:34px;
  height:34px;
  background:rgba(255,255,255,0.08);
  border:none;
  border-radius:50%;
  color:#F2EDE2;
  font-size:20px;
  line-height:1;
  cursor:pointer;
  transition:background .15s;
}
.opm-search-close:hover{
  background:rgba(255,255,255,0.16);
}

.opm-search-results{
  list-style:none;
  margin:0;
  padding:8px;
  max-height:54vh;
  overflow-y:auto;
}
.opm-search-result{
  border-radius:10px;
  transition:background .15s;
}
.opm-search-result a{
  display:block;
  padding:14px 18px;
  text-decoration:none;
  color:#F2EDE2;
}
.opm-search-result.is-active,
.opm-search-result:hover{
  background:rgba(189,176,157,0.12);
}
.opm-search-result-title{
  display:block;
  font-family:'Inter',sans-serif;
  font-size:15px;
  font-weight:600;
  letter-spacing:-0.01em;
  color:#F2EDE2;
}
.opm-search-result-desc{
  display:block;
  margin-top:3px;
  font-family:'Inter',sans-serif;
  font-size:13px;
  font-weight:400;
  color:rgba(255,255,255,0.55);
}
.opm-search-empty{
  padding:32px;
  text-align:center;
  color:rgba(255,255,255,0.5);
  font-family:'Inter',sans-serif;
  font-size:14px;
}
.opm-search-hint{
  padding:12px 18px 4px;
  text-align:center;
  color:rgba(255,255,255,0.36);
  font-family:'Inter',sans-serif;
  font-size:11px;
  letter-spacing:0.04em;
}
.opm-search-hint kbd{
  display:inline-block;
  padding:2px 7px;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:4px;
  font-family:'Inter',sans-serif;
  font-size:11px;
  font-weight:500;
  color:rgba(255,255,255,0.7);
}

html.opm-search-locked{ overflow:hidden; }

/* Search trigger discreet in nav */
.opm-search-trigger{
  background:transparent;
  border:none;
  cursor:pointer;
  padding:8px;
  color:rgba(255,255,255,0.7);
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:'Inter',sans-serif;
  font-size:13px;
  border-radius:6px;
  transition:color .15s, background .15s;
}
.opm-search-trigger:hover{
  color:#F2EDE2;
  background:rgba(255,255,255,0.06);
}
.opm-search-trigger::before{
  content:"";
  width:14px;
  height:14px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round'><circle cx='11' cy='11' r='7'/><path d='m20 20-3.5-3.5'/></svg>") center/contain no-repeat;
  flex:0 0 auto;
}

@media (max-width:600px){
  .opm-search-panel{ margin:4vh 16px 0; }
  .opm-search-results{ max-height:62vh; }
}

/* ──────────── VIDEO COMPONENT (autoplay safe, brand frame) ──────────── */
.opm-video{
  position:relative;
  width:100%;
  background:#0a0a0a;
  overflow:hidden;
  border-radius:8px;
}
.opm-video[data-aspect="16-9"]{ aspect-ratio:16/9; }
.opm-video[data-aspect="4-3"]{ aspect-ratio:4/3; }
.opm-video[data-aspect="1-1"]{ aspect-ratio:1/1; }
.opm-video[data-aspect="9-16"]{ aspect-ratio:9/16; max-width:380px; margin:0 auto; }

.opm-video video,
.opm-video img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

.opm-video::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.45) 100%);
  pointer-events:none;
  opacity:0.7;
}

.opm-video-caption{
  position:absolute;
  left:24px;
  bottom:22px;
  z-index:1;
  font-family:'Inter',sans-serif;
  font-size:13px;
  font-weight:500;
  letter-spacing:0.02em;
  color:#F2EDE2;
  text-shadow:0 1px 3px rgba(0,0,0,0.6);
}

/* ──────────── VISUALLY HIDDEN utility ──────────── */
.visually-hidden{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
