/* ============================================================
 * v2.1.149 — Watch Live Cinema · Sanctuary chat · Rich notes · Stylus
 * Single overlay sheet. Scoped to .eos-watch--cinema.
 * No layer overlaps any other layer.
 * ============================================================ */


/* Brand variables */
.eos-watch--cinema {
  --cn-radius: 14px;
  --cn-radius-sm: 10px;
  --cn-amber: #F5A312;
  --cn-amber-dark: #B86B00;
  --cn-amber-soft: #FFC76E;
  --cn-amber-glow: rgba(245, 163, 18, 0.18);
  --cn-bg: #FFFFFF;
  --cn-bg-soft: rgba(0, 0, 0, 0.04);
  --cn-bg-softer: rgba(0, 0, 0, 0.025);
  --cn-fg: #1A1A2E;
  --cn-muted: rgba(0, 0, 0, 0.55);
  --cn-border: rgba(0, 0, 0, 0.08);
  --cn-shadow: 0 1px 2px rgba(0,0,0,0.04), 0 12px 36px rgba(0,0,0,0.08);
  --eos-side-w: 440px;
}
[data-theme="dark"] .eos-watch--cinema {
  --cn-bg: #11161D;
  --cn-bg-soft: rgba(255, 255, 255, 0.04);
  --cn-bg-softer: rgba(255, 255, 255, 0.025);
  --cn-fg: #E6E7EA;
  --cn-muted: rgba(255, 255, 255, 0.55);
  --cn-border: rgba(255, 255, 255, 0.08);
  --cn-shadow: 0 12px 36px rgba(0,0,0,0.45);
}

/* Outer grid (wins .eos-watch from player.css) */
.eos-watch--cinema {
  display: grid !important;
  grid-template-columns: minmax(0, 1.55fr) minmax(0, 1fr) !important;
  grid-template-areas: "top top" "stage side" "extra extra" !important;
  gap: 18px !important;
  max-width: 1600px !important;
  margin: 18px auto 60px !important;
  padding: 0 20px !important;
}
.eos-watch--cinema > .eos-cn-top { grid-area: top; margin-bottom: 0 !important; }
.eos-watch--cinema > .eos-watch-stage { grid-area: stage; min-width: 0; }
.eos-watch--cinema > .eos-side { grid-area: side; }
.eos-watch--cinema > .eos-watch__resizer { display: none !important; }

/* ====== Top bar ====== */
.eos-cn-top {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 16px;
  border-radius: var(--cn-radius);
  background: rgba(255,255,255,0.72);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  backdrop-filter: blur(20px) saturate(160%);
  border: 0.5px solid var(--cn-border);
  box-shadow: var(--cn-shadow);
}
[data-theme="dark"] .eos-cn-top { background: rgba(17,22,29,0.72); }
.eos-cn-live {
  font-size: 10px; font-weight: 700; letter-spacing: 0.5px;
  background: linear-gradient(135deg, #DC2626, #B91C1C);
  color: #FFFFFF; padding: 4px 10px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 5px;
  animation: cnLivePulse 2s ease-in-out infinite;
  text-transform: uppercase;
}
@keyframes cnLivePulse { 0%,100% { box-shadow: 0 0 0 0 rgba(220,38,38,.4); } 50% { box-shadow: 0 0 0 6px rgba(220,38,38,0); } }
.eos-cn-live span { width: 6px; height: 6px; border-radius: 50%; background: #FFFFFF; display: inline-block; }
.eos-cn-soon { font-size: 10.5px; font-weight: 600; background: var(--cn-amber-glow); color: var(--cn-amber-dark); padding: 4px 11px; border-radius: 999px; display: inline-flex; align-items: center; gap: 5px; }
[data-theme="dark"] .eos-cn-soon { color: var(--cn-amber-soft); }
.eos-cn-top__title { display: flex; flex-direction: column; min-width: 0; line-height: 1.2; flex: 1; }
.eos-cn-top__t { font-size: 14px; font-weight: 600; color: var(--cn-fg); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.eos-cn-top__s { font-size: 11px; opacity: 0.55; margin-top: 1px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.eos-cn-top__views { font-size: 11.5px; opacity: 0.7; display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; background: var(--cn-bg-soft); border-radius: 999px; white-space: nowrap; }
.eos-cn-top__act { display: flex; gap: 4px; flex-shrink: 0; }
.eos-cn-ibtn {
  width: 34px; height: 34px; border-radius: 10px; border: 0;
  background: var(--cn-bg-soft); color: inherit;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 15px; cursor: pointer;
  transition: background 120ms ease, transform 120ms ease, color 120ms ease;
}
.eos-cn-ibtn:hover { background: var(--cn-amber-glow); color: var(--cn-amber-dark); transform: translateY(-1px); }
[data-theme="dark"] .eos-cn-ibtn:hover { color: var(--cn-amber-soft); }
.eos-cn-ibtn.is-on { background: linear-gradient(135deg, var(--cn-amber), var(--cn-amber-dark)); color: #FFFFFF; }

/* ====== Stage column ====== */
.eos-watch--cinema .eos-watch-stage {
  display: flex !important; flex-direction: column !important; gap: 14px;
}

/* ====== Player + chrome strip BELOW iframe ====== */
.eos-watch--cinema .eos-player {
  border-radius: var(--cn-radius);
  box-shadow: var(--cn-shadow);
  overflow: hidden;
  position: relative;
}

/* Floating reactions over video */
.eos-cn-rx { position: absolute; inset: 0; pointer-events: none; z-index: 4; overflow: hidden; }
.eos-cn-rx__bubble {
  position: absolute; bottom: 90px;
  font-size: 26px; width: 42px; height: 42px;
  background: rgba(255,255,255,0.15);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  animation: cnRxRise 3.6s cubic-bezier(0.22,1,0.36,1) forwards;
}
@keyframes cnRxRise {
  0% { opacity: 0; transform: translateY(14px) scale(0.7); }
  18% { opacity: 1; transform: translateY(-20px) scale(1); }
  60% { opacity: 1; transform: translateY(-160px) scale(1.05); }
  100% { opacity: 0; transform: translateY(-280px) scale(0.95); }
}

/* Reaction bar = vertical strip, right-middle of player, out of YouTube's way */
.eos-cn-rxbar {
  position: absolute;
  right: 12px; top: 50%; transform: translate(0, -50%);
  z-index: 5;
  background: rgba(0,0,0,0.55);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border: 0.5px solid rgba(255,255,255,0.16);
  border-radius: 999px; padding: 4px;
  display: flex; flex-direction: column; gap: 3px;
  opacity: 0;
  transition: opacity 200ms ease;
}
.eos-watch--cinema .eos-player:hover .eos-cn-rxbar,
.eos-watch--cinema.is-cn-ctlshow .eos-cn-rxbar { opacity: 1; }
.eos-cn-rxbar button {
  width: 30px; height: 30px; border: 0; background: transparent;
  font-size: 16px; color: #FFFFFF; cursor: pointer; border-radius: 50%;
  transition: transform 120ms ease, background 120ms ease;
}
.eos-cn-rxbar button:hover { transform: scale(1.18); background: rgba(245,163,18,0.30); }

/* Player chrome strip BELOW the iframe — never overlaps YouTube */
.eos-cn-chrome {
  display: flex; align-items: center; gap: 5px;
  padding: 10px 12px;
  background: var(--cn-bg);
  border: 0.5px solid var(--cn-border);
  border-radius: var(--cn-radius);
  flex-wrap: wrap;
  box-shadow: var(--cn-shadow);
}
.eos-cn-chrome button, .eos-cn-chrome a {
  height: 32px; min-width: 34px; padding: 0 10px;
  border: 0.5px solid var(--cn-border);
  background: var(--cn-bg-soft);
  color: var(--cn-fg);
  border-radius: 9px;
  font: inherit; font-size: 11.5px; font-weight: 600;
  display: inline-flex; align-items: center; gap: 5px;
  cursor: pointer;
  text-decoration: none;
  transition: background 120ms ease, color 120ms ease, border-color 120ms ease;
}
.eos-cn-chrome button:hover, .eos-cn-chrome a:hover {
  background: var(--cn-amber-glow);
  color: var(--cn-amber-dark);
  border-color: rgba(245,163,18,0.30);
}
[data-theme="dark"] .eos-cn-chrome button:hover, [data-theme="dark"] .eos-cn-chrome a:hover { color: var(--cn-amber-soft); }
.eos-cn-chrome__sep { width: 1px; height: 22px; background: var(--cn-border); margin: 0 4px; }
.eos-cn-chrome__sp { flex: 1; }

/* View modes */
.eos-watch--cinema.is-cn-theater {
  grid-template-columns: 1fr !important;
  grid-template-areas: "top" "stage" "side" "extra" !important;
}
.eos-watch--cinema.is-cn-theater > .eos-side { height: 420px; }
.eos-watch--cinema.is-cn-cinema {
  position: fixed; inset: 0; z-index: 9000;
  grid-template-columns: 1fr !important;
  grid-template-areas: "stage" !important;
  background: #000; padding: 0 !important; margin: 0 !important; max-width: none !important;
}
.eos-watch--cinema.is-cn-cinema > .eos-cn-top { display: none; }
.eos-watch--cinema.is-cn-cinema > .eos-watch-stage > *:not(.eos-player) { display: none; }
.eos-watch--cinema.is-cn-cinema > .eos-side {
  position: fixed; right: 14px; top: 14px; bottom: 14px; width: 380px;
  background: rgba(17,22,29,0.82);
  -webkit-backdrop-filter: blur(28px);
  backdrop-filter: blur(28px);
  border: 0.5px solid rgba(255,255,255,0.12);
  border-radius: 14px; z-index: 9001; display: flex !important;
}
.eos-watch--cinema.is-cn-cinema .eos-player { height: 100vh; width: 100vw; border-radius: 0; }
.eos-watch--cinema.is-cn-pip > .eos-watch-stage > .eos-player {
  position: fixed; bottom: 18px; right: 18px;
  width: 320px; height: 180px; z-index: 9000;
  border-radius: 12px; box-shadow: 0 18px 60px rgba(0,0,0,0.45);
}

/* ============================================================
 * Side dock — Sanctuary
 * Layers: tabs > utility row > pinned > stream > compose. No overlaps.
 * ============================================================ */
.eos-watch--cinema .eos-side {
  border-radius: var(--cn-radius) !important;
  background: var(--cn-bg) !important;
  border: 0.5px solid var(--cn-border) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 640px !important;
  max-height: 84vh !important;
  margin: 0 !important;
  width: auto !important;
  box-shadow: var(--cn-shadow);
  position: relative;
}
.eos-watch--cinema .eos-side::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 120px;
  background: radial-gradient(ellipse at top, var(--cn-amber-glow), transparent 70%);
  pointer-events: none; z-index: 1;
}

/* Tabs row */
.eos-watch--cinema .eos-side-tabs {
  position: relative; z-index: 2;
  display: flex !important;
  padding: 10px 10px 0 !important;
  background: transparent;
  border-bottom: 0.5px solid var(--cn-border) !important;
}
.eos-watch--cinema .eos-side-tab {
  flex: 1; padding: 11px 4px;
  font-size: 12.5px; font-weight: 500; text-align: center;
  border: 0; background: transparent; color: var(--cn-fg); cursor: pointer;
  opacity: 0.5; border-bottom: 2px solid transparent;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  transition: opacity 160ms ease, color 160ms ease, border-color 160ms ease;
}
.eos-watch--cinema .eos-side-tab svg { width: 15px; height: 15px; }
.eos-watch--cinema .eos-side-tab.is-active {
  opacity: 1; color: var(--cn-amber-dark);
  border-bottom-color: var(--cn-amber);
}
[data-theme="dark"] .eos-watch--cinema .eos-side-tab.is-active { color: var(--cn-amber-soft); }

/* Panel container */
.eos-watch--cinema .eos-side-panel {
  position: relative; z-index: 2;
  flex: 1; min-height: 0;
  display: none; flex-direction: column;
  padding: 0;
}
.eos-watch--cinema .eos-side-panel.is-active { display: flex; }
.eos-watch--cinema .eos-side-expand { display: none !important; }

/* ============================================================
 * CHAT
 * ============================================================ */

/* Utility row (mode toggle + lang pill + bookmarks + search) */
.eos-watch--cinema .eos-chat-mode {
  display: flex !important;
  flex: 1;
  margin: 0 !important;
  padding: 2px !important;
  background: var(--cn-bg-soft) !important;
  border-radius: 999px !important;
  border: 0 !important;
  gap: 0 !important;
}
.eos-watch--cinema .eos-chat-mode-btn {
  flex: 1; border: 0; background: transparent; color: var(--cn-fg);
  font: inherit; font-size: 11.5px; font-weight: 500;
  padding: 6px 10px; border-radius: 999px;
  cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 5px;
  opacity: 0.7;
  transition: background 160ms ease, opacity 160ms ease, color 160ms ease, box-shadow 160ms ease;
}
.eos-watch--cinema .eos-chat-mode-btn.is-on {
  background: var(--cn-bg);
  opacity: 1; color: var(--cn-amber-dark);
  box-shadow: 0 1px 3px rgba(0,0,0,0.10);
}
[data-theme="dark"] .eos-watch--cinema .eos-chat-mode-btn.is-on { background: #1F2932; color: var(--cn-amber-soft); }

/* Utility lane wraps the mode toggle and the small icons in a single row */
.eos-watch--cinema .eos-chat-utility-lane {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 10px;
  background: var(--cn-bg-softer);
  border-bottom: 0.5px solid var(--cn-border);
}
.eos-watch--cinema .eos-chat-utility-lane .eos-chat-mode { flex: 1; }
.eos-watch--cinema .eos-chat-utility-lane .eos-chat-util-pill {
  height: 30px; padding: 0 10px; border-radius: 999px;
  background: var(--cn-bg-soft); border: 0.5px solid transparent;
  color: var(--cn-fg);
  font-size: 11px; font-weight: 600;
  display: inline-flex; align-items: center; gap: 5px;
  cursor: pointer; transition: background 120ms ease;
}
.eos-watch--cinema .eos-chat-utility-lane .eos-chat-util-pill:hover { background: var(--cn-amber-glow); color: var(--cn-amber-dark); }
.eos-watch--cinema .eos-chat-utility-lane .eos-chat-util-ico {
  width: 30px; height: 30px; border-radius: 8px;
  background: var(--cn-bg-soft); border: 0;
  color: var(--cn-muted);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0;
  transition: background 120ms ease, color 120ms ease;
}
.eos-watch--cinema .eos-chat-utility-lane .eos-chat-util-ico:hover { background: var(--cn-amber-glow); color: var(--cn-amber-dark); }

/* The original floating buttons → fold into the utility lane via :empty + positioned absolute fallback */
.eos-watch--cinema .eos-chat-search-toggle,
.eos-watch--cinema .eos-chat-bm-toggle,
.eos-watch--cinema .eos-chat-langpill {
  position: static !important;
  top: auto !important; right: auto !important;
  width: 30px !important; height: 30px !important;
  background: var(--cn-bg-soft) !important;
  border: 0 !important;
  color: var(--cn-muted) !important;
  border-radius: 8px !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0;
  box-shadow: none !important;
  margin: 0 !important;
}
.eos-watch--cinema .eos-chat-langpill { width: auto !important; padding: 0 10px !important; border-radius: 999px !important; }
.eos-watch--cinema .eos-chat-search-toggle:hover,
.eos-watch--cinema .eos-chat-bm-toggle:hover,
.eos-watch--cinema .eos-chat-langpill:hover {
  background: var(--cn-amber-glow) !important;
  color: var(--cn-amber-dark) !important;
}
.eos-watch--cinema .eos-chat-langpill__lbl { font-size: 10.5px; font-weight: 600; }

/* Chat pane */
.eos-watch--cinema .eos-chat-pane {
  display: none !important; flex: 1; min-height: 0;
  flex-direction: column !important;
}
.eos-watch--cinema .eos-chat-pane.is-active { display: flex !important; }

/* Chat surface */
.eos-watch--cinema .eos-chat {
  flex: 1; min-height: 0;
  display: flex !important; flex-direction: column !important;
  background: transparent;
  border: 0 !important;
  border-radius: 0 !important;
  position: relative;
}

/* Message stream */
.eos-watch--cinema .eos-chat-stream {
  flex: 1; min-height: 0; overflow-y: auto;
  padding: 14px 12px 8px !important;
  scroll-behavior: smooth;
}
.eos-watch--cinema .eos-chat-stream::-webkit-scrollbar { width: 5px; }
.eos-watch--cinema .eos-chat-stream::-webkit-scrollbar-thumb { background: var(--cn-border); border-radius: 3px; }

/* Message bubble — Sanctuary */
.eos-watch--cinema .eos-msg {
  display: grid !important;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 9px !important;
  margin-bottom: 4px !important;
  padding: 7px 10px !important;
  border-radius: 11px !important;
  background: transparent !important;
  transition: background 160ms ease;
}
.eos-watch--cinema .eos-msg:hover { background: var(--cn-bg-soft) !important; }
.eos-watch--cinema .eos-msg-avatar,
.eos-watch--cinema .eos-msg__avatar {
  width: 32px !important; height: 32px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--cn-amber), var(--cn-amber-dark));
  color: #FFFFFF;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 11px;
  flex-shrink: 0;
  box-shadow: 0 1px 3px rgba(0,0,0,0.10);
}
.eos-watch--cinema .eos-msg-body, .eos-watch--cinema .eos-msg__body { min-width: 0; }
.eos-watch--cinema .eos-msg-head, .eos-watch--cinema .eos-msg__head {
  display: flex; align-items: baseline; gap: 6px;
  font-size: 11px; margin-bottom: 2px;
}
.eos-watch--cinema .eos-msg-name, .eos-watch--cinema .eos-msg-user {
  font-weight: 600; font-size: 12px; color: var(--cn-fg);
}
.eos-watch--cinema .eos-msg-time, .eos-watch--cinema .eos-msg-ts {
  font-size: 10.5px; opacity: 0.45; font-variant-numeric: tabular-nums;
}
.eos-watch--cinema .eos-msg-text, .eos-watch--cinema .eos-msg__text {
  font-size: 13.5px; line-height: 1.5; color: var(--cn-fg); word-wrap: break-word;
}

/* Compose */
.eos-watch--cinema .eos-chat-form {
  background: var(--cn-bg) !important;
  border: 0 !important;
  border-top: 0.5px solid var(--cn-border) !important;
  border-radius: 0 !important;
  padding: 10px 12px 12px !important;
  display: flex !important; align-items: center !important; gap: 6px !important;
}
.eos-watch--cinema .eos-chat-emoji-btn {
  width: 36px !important; height: 36px !important;
  border-radius: 50% !important;
  background: var(--cn-bg-soft) !important;
  border: 0 !important; color: var(--cn-muted) !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0;
}
.eos-watch--cinema .eos-chat-emoji-btn:hover {
  background: var(--cn-amber-glow) !important; color: var(--cn-amber-dark) !important;
}
.eos-watch--cinema .eos-chat-input {
  flex: 1; min-width: 0;
  border-radius: 999px !important;
  padding: 9px 16px !important;
  background: var(--cn-bg-soft) !important;
  border: 0.5px solid transparent !important;
  font-size: 13.5px !important;
  color: var(--cn-fg);
  outline: none !important;
  transition: border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}
.eos-watch--cinema .eos-chat-input:focus {
  border-color: var(--cn-amber) !important;
  background: var(--cn-bg) !important;
  box-shadow: 0 0 0 3px var(--cn-amber-glow);
}
.eos-watch--cinema .eos-chat-input[data-placeholder]:empty::before {
  content: attr(data-placeholder);
  color: var(--cn-muted); opacity: 0.7; pointer-events: none;
}
.eos-watch--cinema .eos-chat-send {
  width: 40px !important; height: 40px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--cn-amber), var(--cn-amber-dark)) !important;
  color: #FFFFFF !important; border: 0 !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(245,163,18,0.30);
  transition: transform 120ms ease;
}
.eos-watch--cinema .eos-chat-send:hover { transform: scale(1.08); }
.eos-watch--cinema .eos-chat-signin {
  margin: 12px !important; text-align: center; font-size: 12.5px;
  padding: 10px 14px; border-radius: 10px;
  background: var(--cn-amber-glow); color: var(--cn-amber-dark);
}
[data-theme="dark"] .eos-watch--cinema .eos-chat-signin { color: var(--cn-amber-soft); }
.eos-watch--cinema .eos-chat-signin a { color: inherit; text-decoration: none; font-weight: 600; }
.eos-watch--cinema .eos-chat-embed { width: 100%; height: 100%; flex: 1; border: 0; min-height: 480px; }

/* ============================================================
 * NOTES — Rich text editor + stylus canvas
 * ============================================================ */
.eos-watch--cinema .eos-notes {
  display: flex !important; flex-direction: column !important;
  height: 100%;
  padding: 0;
  position: relative;
}
.eos-watch--cinema .eos-notes h3 {
  margin: 12px 14px 4px;
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.6px; text-transform: uppercase;
  opacity: 0.55;
}
.eos-watch--cinema .eos-notes-help {
  margin: 0 14px 8px; font-size: 11.5px; opacity: 0.55;
}

/* Mode switch — Type / Draw */
.eos-nt-modes {
  display: flex; padding: 2px;
  margin: 4px 14px 10px;
  background: var(--cn-bg-soft);
  border-radius: 999px;
  align-self: flex-start;
}
.eos-nt-modes button {
  border: 0; background: transparent; color: var(--cn-fg);
  font: inherit; font-size: 11.5px; font-weight: 500;
  padding: 6px 12px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 5px;
  cursor: pointer; opacity: 0.65;
}
.eos-nt-modes button.is-on {
  background: var(--cn-bg); opacity: 1;
  color: var(--cn-amber-dark);
  box-shadow: 0 1px 3px rgba(0,0,0,0.10);
}
[data-theme="dark"] .eos-nt-modes button.is-on { background: #1F2932; color: var(--cn-amber-soft); }

/* Rich text toolbar */
.eos-nt-tb {
  padding: 4px 10px;
  background: var(--cn-bg-softer);
  border-top: 0.5px solid var(--cn-border);
  border-bottom: 0.5px solid var(--cn-border);
  display: flex; flex-direction: column; gap: 4px;
}
.eos-nt-tb-row { display: flex; align-items: center; gap: 3px; flex-wrap: wrap; padding: 3px 0; }
.eos-nt-tb button {
  height: 30px; min-width: 30px; padding: 0 7px;
  border: 0; background: transparent; color: var(--cn-fg);
  font: inherit; font-size: 12.5px; font-weight: 500;
  border-radius: 7px;
  display: inline-flex; align-items: center; justify-content: center; gap: 4px;
  cursor: pointer;
  transition: background 120ms ease;
}
.eos-nt-tb button:hover { background: var(--cn-bg-soft); }
.eos-nt-tb button.is-on { background: var(--cn-amber-glow); color: var(--cn-amber-dark); }
[data-theme="dark"] .eos-nt-tb button.is-on { color: var(--cn-amber-soft); }
.eos-nt-tb__sep { width: 1px; height: 18px; background: var(--cn-border); margin: 0 3px; }
.eos-nt-tb__sp { flex: 1; }

.eos-nt-tb-b { font-weight: 700; font-family: serif; font-size: 14px; }
.eos-nt-tb-i { font-style: italic; font-family: serif; font-size: 14px; }
.eos-nt-tb-u { text-decoration: underline; font-size: 14px; }
.eos-nt-tb-s { text-decoration: line-through; font-size: 14px; }

.eos-nt-tb select {
  height: 30px; padding: 0 8px;
  border-radius: 7px;
  background: var(--cn-bg);
  border: 0.5px solid var(--cn-border);
  color: var(--cn-fg);
  font: inherit; font-size: 11.5px;
}

.eos-nt-colors {
  display: inline-flex; align-items: center; gap: 4px;
  height: 30px; padding: 0 8px;
  border-radius: 7px;
  background: var(--cn-bg-soft);
}
.eos-nt-colors__lbl { font-size: 10.5px; opacity: 0.6; margin-right: 2px; }
.eos-nt-swatch {
  width: 14px; height: 14px; border-radius: 50%;
  cursor: pointer;
  border: 1px solid rgba(0,0,0,0.10);
}

/* Editor body */
.eos-nt-editor {
  flex: 1; min-height: 280px;
  padding: 16px 18px;
  font-size: 14px; line-height: 1.65;
  font-family: 'Inter', system-ui, sans-serif;
  overflow-y: auto;
  outline: none;
  color: var(--cn-fg);
}
.eos-nt-editor[data-placeholder]:empty::before {
  content: attr(data-placeholder);
  color: var(--cn-muted); opacity: 0.55;
  pointer-events: none;
}
.eos-nt-editor h1 { font-size: 20px; font-weight: 600; margin: 0 0 12px; }
.eos-nt-editor h2 { font-size: 16px; font-weight: 600; margin: 16px 0 8px; color: var(--cn-amber-dark); }
[data-theme="dark"] .eos-nt-editor h2 { color: var(--cn-amber-soft); }
.eos-nt-editor h3 { font-size: 14px; font-weight: 600; margin: 12px 0 6px; opacity: 0.85; }
.eos-nt-editor p { margin: 0 0 8px; }
.eos-nt-editor ul, .eos-nt-editor ol { padding-left: 22px; margin: 6px 0 10px; }
.eos-nt-editor li { margin-bottom: 4px; }
.eos-nt-editor blockquote {
  border-left: 3px solid #1D9E75;
  padding: 4px 14px;
  font-family: Georgia, serif; font-style: italic; opacity: 0.85;
  margin: 10px 0;
  background: rgba(29,158,117,0.05);
  border-radius: 0 6px 6px 0;
}
[data-theme="dark"] .eos-nt-editor blockquote { border-left-color: #5DCAA5; background: rgba(93,202,165,0.08); }
.eos-nt-editor a { color: #185FA5; text-decoration: underline; }
[data-theme="dark"] .eos-nt-editor a { color: #85B7EB; }
.eos-nt-editor .eos-nt-ts {
  display: inline-flex; align-items: center;
  font-size: 11px; font-weight: 600;
  background: var(--cn-amber-glow); color: var(--cn-amber-dark);
  padding: 2px 9px; border-radius: 999px;
  font-family: monospace;
  margin-right: 6px; vertical-align: middle;
  cursor: pointer; user-select: none;
}
[data-theme="dark"] .eos-nt-editor .eos-nt-ts { color: var(--cn-amber-soft); }

/* Canvas overlay for stylus */
.eos-nt-canvaswrap {
  position: absolute;
  left: 0; right: 0;
  pointer-events: none;
  z-index: 5;
}
.eos-nt-canvas {
  width: 100%; height: 100%;
  display: block;
}
.eos-watch--cinema .eos-notes.is-draw .eos-nt-canvaswrap { pointer-events: auto; }
.eos-watch--cinema .eos-notes.is-draw .eos-nt-editor {
  pointer-events: none;
  opacity: 0.55;
}

/* Stylus tool palette */
.eos-nt-palette {
  position: absolute; left: 14px; top: 120px;
  z-index: 8;
  display: none; flex-direction: column; gap: 4px;
  padding: 7px;
  background: var(--cn-bg);
  border: 0.5px solid var(--cn-border);
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}
.eos-watch--cinema .eos-notes.is-draw .eos-nt-palette { display: flex; }
.eos-nt-palette button {
  width: 34px; height: 34px; border-radius: 9px;
  background: transparent; border: 0; color: var(--cn-fg);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 15px; cursor: pointer;
}
.eos-nt-palette button:hover { background: var(--cn-bg-soft); }
.eos-nt-palette button.is-on { background: linear-gradient(135deg, var(--cn-amber), var(--cn-amber-dark)); color: #FFFFFF; }
.eos-nt-palette__sep { width: 22px; height: 1px; background: var(--cn-border); margin: 3px auto; }

/* Pen-detected toast */
.eos-nt-pendet {
  position: absolute; top: 12px; right: 14px;
  z-index: 8;
  font-size: 11px; font-weight: 600;
  background: linear-gradient(135deg, rgba(127,119,221,0.22), rgba(127,119,221,0.08));
  color: #534AB7;
  border: 0.5px solid rgba(127,119,221,0.32);
  padding: 5px 11px; border-radius: 999px;
  display: none; align-items: center; gap: 5px;
  animation: ntDetPulse 2.5s ease-in-out infinite;
}
.eos-watch--cinema .eos-notes.has-pen .eos-nt-pendet { display: inline-flex; }
@keyframes ntDetPulse { 0%,100% { box-shadow: 0 0 0 0 rgba(127,119,221,0.30); } 50% { box-shadow: 0 0 0 5px rgba(127,119,221,0); } }
[data-theme="dark"] .eos-nt-pendet { color: #AFA9EC; }

/* Notes footer */
.eos-nt-foot {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 14px;
  border-top: 0.5px solid var(--cn-border);
  background: var(--cn-bg-softer);
}
.eos-nt-foot__wc { font-size: 10.5px; opacity: 0.55; }
.eos-nt-foot__act { margin-left: auto; display: flex; gap: 5px; }
.eos-nt-foot__btn {
  padding: 6px 11px; font-size: 11.5px;
  border-radius: 8px; border: 0.5px solid var(--cn-border);
  background: var(--cn-bg); color: var(--cn-fg);
  display: inline-flex; align-items: center; gap: 5px;
  cursor: pointer;
}
.eos-nt-foot__btn:hover { background: var(--cn-amber-glow); color: var(--cn-amber-dark); border-color: rgba(245,163,18,0.30); }

/* Hide the legacy notes inner structure that we're replacing */
.eos-watch--cinema .eos-notes textarea#eos-notes-textarea,
.eos-watch--cinema .eos-notes .eos-notes-meta { display: none !important; }

/* ============================================================
 * BIBLE — restored
 * ============================================================ */
.eos-watch--cinema .eos-bible {
  display: flex !important; flex-direction: column !important;
  height: 100%;
  padding: 12px 14px;
  overflow: hidden;
}
.eos-watch--cinema .eos-bible-brand {
  display: flex !important; align-items: center; gap: 8px;
  margin: 0 0 10px !important;
  padding: 11px 13px !important;
  background: linear-gradient(135deg, rgba(29,158,117,0.12), rgba(29,158,117,0.04)) !important;
  border: 0.5px solid rgba(29,158,117,0.25) !important;
  border-left: 3px solid #1D9E75;
  border-radius: 10px !important;
}
[data-theme="dark"] .eos-watch--cinema .eos-bible-brand {
  background: linear-gradient(135deg, rgba(93,202,165,0.16), rgba(93,202,165,0.05)) !important;
  border-color: rgba(93,202,165,0.32) !important;
  border-left-color: #5DCAA5;
}
.eos-watch--cinema .eos-bible-brand-name {
  margin: 0; flex: 1;
  font-size: 12.5px; font-weight: 600; letter-spacing: 0.3px;
  color: #0F6E56;
  display: inline-flex; align-items: center; gap: 6px;
}
.eos-watch--cinema .eos-bible-brand-name::before { content: "📖"; font-size: 14px; }
[data-theme="dark"] .eos-watch--cinema .eos-bible-brand-name { color: #5DCAA5; }
.eos-watch--cinema .eos-bible-brand-actions { display: flex !important; gap: 4px; margin-left: auto; }
.eos-watch--cinema .eos-bible-brand-ic {
  width: 30px !important; height: 30px !important;
  border-radius: 8px !important;
  background: rgba(29,158,117,0.14) !important;
  color: #0F6E56 !important; border: 0 !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  cursor: pointer; text-decoration: none;
}
.eos-watch--cinema .eos-bible-brand-ic:hover { background: rgba(29,158,117,0.24) !important; }
[data-theme="dark"] .eos-watch--cinema .eos-bible-brand-ic { background: rgba(93,202,165,0.18) !important; color: #5DCAA5 !important; }
[data-theme="dark"] .eos-watch--cinema .eos-bible-brand-ic:hover { background: rgba(93,202,165,0.30) !important; }

.eos-watch--cinema .eos-bible-toolbar {
  display: flex !important; gap: 5px; flex-wrap: wrap;
  margin: 0 0 12px !important;
}
.eos-watch--cinema .eos-bible-chip {
  background: var(--cn-bg-soft) !important;
  border: 0.5px solid var(--cn-border) !important;
  border-radius: 999px !important;
  padding: 6px 12px !important;
  font-size: 12px !important; font-weight: 500;
  color: var(--cn-fg) !important;
  cursor: pointer;
  display: inline-flex !important; align-items: center; gap: 5px;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}
.eos-watch--cinema .eos-bible-chip:hover {
  background: var(--cn-amber-glow) !important;
  border-color: rgba(245,163,18,0.32) !important;
  color: var(--cn-amber-dark) !important;
}
[data-theme="dark"] .eos-watch--cinema .eos-bible-chip:hover { color: var(--cn-amber-soft) !important; }
.eos-watch--cinema .eos-bible-tb-btn {
  width: 32px !important; height: 32px !important;
  background: var(--cn-bg-soft) !important;
  border: 0.5px solid var(--cn-border) !important;
  border-radius: 9px !important;
  color: var(--cn-fg) !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
}
.eos-watch--cinema .eos-bible-tb-btn:hover {
  background: var(--cn-amber-glow) !important; color: var(--cn-amber-dark) !important;
}
.eos-watch--cinema .eos-bible-tb-aa { font-weight: 600; font-size: 13px; }
.eos-watch--cinema .eos-bible-tb-aa .aa-a-sm { font-size: 10px; opacity: 0.7; }
.eos-watch--cinema .eos-bible-tb-aa .aa-a-lg { font-size: 14px; margin-left: 1px; }

.eos-watch--cinema .eos-bible-recents-head {
  display: flex !important; align-items: center; justify-content: space-between;
  font-size: 10.5px; opacity: 0.55;
  text-transform: uppercase; letter-spacing: 0.5px; font-weight: 600;
  margin: 0 0 8px;
}
.eos-watch--cinema .eos-bible-quick {
  list-style: none; padding: 0; margin: 0 0 12px;
  display: flex; flex-wrap: wrap; gap: 5px;
}
.eos-watch--cinema .eos-bible-quick li {
  font-size: 12px; padding: 5px 11px;
  background: var(--cn-bg-soft);
  border: 0.5px solid var(--cn-border);
  border-radius: 999px;
}
.eos-watch--cinema .eos-bible-recents-empty {
  font-size: 12px; opacity: 0.5; line-height: 1.5;
  margin: 4px 0 12px;
}
.eos-watch--cinema .eos-bible-result-wrap {
  flex: 1; min-height: 0; overflow-y: auto;
  padding: 2px;
}
.eos-watch--cinema .eos-bible-pop {
  position: absolute !important; left: 14px !important; right: 14px !important;
  top: 60px !important; z-index: 20;
  background: var(--cn-bg) !important;
  border: 0.5px solid var(--cn-border) !important;
  border-radius: 12px !important;
  box-shadow: 0 18px 60px rgba(0,0,0,0.20);
  padding: 14px !important;
}

/* ============================================================
 * Meta strip + replays
 * ============================================================ */
.eos-watch--cinema .eos-watch-meta {
  margin-top: 0;
  padding: 14px 0 0;
  border-top: 0.5px solid var(--cn-border);
  display: flex; flex-direction: column; gap: 6px;
}
.eos-watch--cinema .eos-watch-status {
  font-size: 11px; font-weight: 600; opacity: 0.55;
  text-transform: uppercase; letter-spacing: 0.5px;
}
.eos-watch--cinema .eos-watch-title { font-size: 24px; font-weight: 600; margin: 4px 0; line-height: 1.22; }
.eos-watch--cinema .eos-watch-credits { font-size: 13px; opacity: 0.7; margin: 0; }
.eos-watch--cinema .eos-watch-scripture { font-family: Georgia, serif; font-style: italic; font-size: 14px; opacity: 0.78; margin: 8px 0 0; }
.eos-watch--cinema .eos-watch-actions { margin-top: 14px; display: flex; gap: 6px; flex-wrap: wrap; }
.eos-watch--cinema .eos-chip {
  background: var(--cn-bg-soft); border: 0.5px solid var(--cn-border);
  border-radius: 999px; padding: 7px 13px; font-size: 12.5px;
  color: var(--cn-fg); text-decoration: none;
  display: inline-flex; align-items: center; gap: 5px; cursor: pointer;
}
.eos-watch--cinema .eos-chip:hover { background: var(--cn-amber-glow); color: var(--cn-amber-dark); border-color: rgba(245,163,18,0.32); }
.eos-watch--cinema .eos-watch-replays { grid-column: 1 / -1; margin-top: 26px; }

/* ============================================================
 * Responsive
 * ============================================================ */
@media (max-width: 1100px) {
  .eos-watch--cinema {
    grid-template-columns: 1fr !important;
    grid-template-areas: "top" "stage" "side" "extra" !important;
    padding: 0 14px !important;
  }
  .eos-watch--cinema > .eos-side { height: 70vh; min-height: 480px !important; }
}
@media (max-width: 720px) {
  .eos-watch--cinema { padding: 0 8px !important; margin: 10px auto 40px !important; }
  .eos-cn-top { padding: 9px 11px; gap: 7px; }
  .eos-cn-top__s { display: none; }
  .eos-cn-top__views { display: none; }
  .eos-watch--cinema .eos-watch-title { font-size: 20px; }
  .eos-cn-chrome { padding: 8px 9px; }
  .eos-cn-chrome button, .eos-cn-chrome a { padding: 0 8px; font-size: 11px; }
}

/* Tablet — give notes more room when active */
@media (min-width: 768px) and (max-width: 1099px) {
  .eos-watch--cinema .eos-notes.is-draw {
    position: fixed; inset: 60px 14px 14px; z-index: 7000;
    background: var(--cn-bg);
    border-radius: 16px;
    box-shadow: 0 24px 80px rgba(0,0,0,0.40);
  }
}


/* v2.1.150 — hide the legacy floating icon buttons since their twins now live in the utility lane */
.eos-watch--cinema #eos-chat > .eos-chat-search-toggle:not(.eos-chat-util-ico),
.eos-watch--cinema #eos-chat > .eos-chat-bm-toggle:not(.eos-chat-util-ico),
.eos-watch--cinema #eos-chat > .eos-chat-langpill:not(.eos-chat-util-pill) {
  display: none !important;
}
.eos-watch--cinema #eos-chat > .eos-chat-bm-panel { right: 14px !important; top: 14px !important; z-index: 20; }

/* v2.1.150 — Sanctuary bubble styling for the real .eos-chat-msg class used by chat.js */
.eos-watch--cinema .eos-chat-msg {
  display: grid !important;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 9px !important;
  margin-bottom: 4px !important;
  padding: 8px 10px !important;
  border-radius: 11px !important;
  background: transparent !important;
  position: relative;
  transition: background 160ms ease;
}
.eos-watch--cinema .eos-chat-msg:hover { background: var(--cn-bg-soft) !important; }
.eos-watch--cinema .eos-chat-msg .eos-chat-msg__avatar,
.eos-watch--cinema .eos-chat-msg .eos-chat-msg-avatar,
.eos-watch--cinema .eos-chat-msg-av,
.eos-watch--cinema .eos-chat-msg__av {
  width: 32px !important; height: 32px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--cn-amber), var(--cn-amber-dark)) !important;
  color: #FFFFFF !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  font-weight: 600; font-size: 11px;
  flex-shrink: 0;
  box-shadow: 0 1px 3px rgba(0,0,0,0.10);
}
.eos-watch--cinema .eos-chat-msg__head,
.eos-watch--cinema .eos-chat-msg-head { font-size: 11px; margin-bottom: 2px; }
.eos-watch--cinema .eos-chat-msg__name,
.eos-watch--cinema .eos-chat-msg-name,
.eos-watch--cinema .eos-chat-msg__user,
.eos-watch--cinema .eos-chat-msg-user { font-weight: 600; font-size: 12px; color: var(--cn-fg); }
.eos-watch--cinema .eos-chat-msg__time,
.eos-watch--cinema .eos-chat-msg-time,
.eos-watch--cinema .eos-chat-msg__ts,
.eos-watch--cinema .eos-chat-msg-ts { font-size: 10.5px; opacity: 0.45; font-variant-numeric: tabular-nums; }
.eos-watch--cinema .eos-chat-msg__text,
.eos-watch--cinema .eos-chat-msg-text,
.eos-watch--cinema .eos-chat-msg__body,
.eos-watch--cinema .eos-chat-msg-body { font-size: 13.5px; line-height: 1.5; color: var(--cn-fg); word-wrap: break-word; }

/* Make sure tooltips/notifications inside the chat don't push the stream around */
.eos-watch--cinema #eos-chat-typing { padding: 4px 12px; font-size: 11px; opacity: 0.6; }
.eos-watch--cinema #eos-chat-pin { margin: 10px 12px; padding: 9px 12px; border-radius: 10px; background: var(--cn-amber-glow); }

/* v2.1.151 — Neutralise the legacy resizer JS that still sets inline top/--eos-side-w on .eos-side */
.eos-watch--cinema .eos-side {
  top: 0 !important;
  left: auto !important;
  position: relative !important;
}
.eos-watch--cinema {
  --eos-side-w: 100% !important;
}
.eos-watch--cinema > .eos-watch-stage,
.eos-watch--cinema > .eos-side {
  align-self: start !important;
}


/* v2.1.154 — Prevent stylus / touch from scrolling the page while drawing */
.eos-watch--cinema .eos-nt-canvas {
  touch-action: none !important;
  -ms-touch-action: none !important;
}
.eos-watch--cinema .eos-notes.is-draw {
  touch-action: none !important;
}
.eos-watch--cinema .eos-nt-canvaswrap {
  touch-action: none !important;
  overscroll-behavior: contain;
}
