/* LCH TV Player CSS */
:root {
  --card-max-w: 870px;
  --ctrl-size: 46px;
  --ctrl-font: 20px;
  --glass: rgba(255,255,255,.78);
  --glass-hover: rgba(255,255,255,.96);
  --border: rgba(17,24,39,.15);
  --icon: #111;
  --radius: 14px;
  --pad: clamp(10px, 2.4vw, 16px);
}

.lch-tvp-wrap {
  width: 100%;
  margin: 0 auto;
}

.lch-player-container {
  background: transparent;
  border-radius: var(--radius);
  overflow: hidden;
  width: 100%;
  max-width: var(--card-max-w);
  margin: 0 auto;
  position: relative;
  height: auto !important;
}

.lch-player-video {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: transparent;
  overflow: hidden;
  border-radius: var(--radius);
}

.lch-player-video video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover; /* ajustado via JS */
  background: transparent;
  display: block;
  border: 0;
}

.lch-overlay {
  position: absolute;
  inset: var(--pad);
  border-radius: inherit;
  pointer-events: none;
}

.lch-controls {
  position: absolute;
  left: 0; right: 0;
  bottom: calc(env(safe-area-inset-bottom) + var(--pad));
  display: flex; gap: 10px;
  align-items: center; justify-content: center;
  pointer-events: none;
}

.lch-controls-left, .lch-controls-right { display: flex; gap: 10px; }
.lch-controls-left  { position: absolute; left:  var(--pad); }
.lch-controls-right { position: absolute; right: var(--pad); }

.lch-btn-circle, google-cast-launcher {
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--ctrl-size);
  height: var(--ctrl-size);
  border-radius: 999px;
  background: var(--glass);
  color: var(--icon);
  border: 1px solid var(--border);
  box-shadow: 0 4px 14px rgba(0,0,0,.16);
  backdrop-filter: blur(6px) saturate(160%);
  -webkit-backdrop-filter: blur(6px) saturate(160%);
  cursor: pointer;
  transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
  touch-action: manipulation;
}
.lch-btn-circle:hover,
.lch-btn-circle:focus-visible,
google-cast-launcher:hover,
google-cast-launcher:focus-visible {
  background: var(--glass-hover);
  transform: translateY(-1px);
  outline: none;
  box-shadow: 0 6px 18px rgba(0,0,0,.2);
}
.lch-btn-circle i { font-size: var(--ctrl-font); line-height: 1; }

google-cast-launcher {
  --disconnected-color: #111;
  --connected-color: #2563eb;
  --connecting-color: #f59e0b;
}

.lch-banner {
  position: absolute; left: 50%;
  transform: translateX(-50%);
  bottom: calc(80px + env(safe-area-inset-bottom));
  background: rgba(17,17,17,.82);
  color: #fff; padding: 8px 12px;
  border-radius: 10px; font-size: 13px;
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
  max-width: min(92%, 520px);
  text-align: center; display: none;
  pointer-events: none;
}
.lch-banner.show { display: block; }

.lch-unmute {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%,-50%);
  pointer-events: auto;
  background: var(--glass-hover); color: #111;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 10px 16px; font-weight: 700;
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
  display: none;
  backdrop-filter: blur(6px) saturate(160%);
  -webkit-backdrop-filter: blur(6px) saturate(160%);
}
.lch-unmute.show { display: inline-flex; gap: 8px; align-items: center; }

@media (max-width: 640px) {
  :root { --ctrl-size: 54px; --ctrl-font: 22px; }
}
@media (min-width: 1280px) {
  :root { --ctrl-size: 48px; --ctrl-font: 20px; }
}
