eb-player 1.54.57 → 2.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (202) hide show
  1. package/README.md +2 -6
  2. package/dist/build/default.js +1 -1
  3. package/dist/build/eb-player.css +2066 -0
  4. package/dist/build/ebplayer-engines.bundle.js +2393 -0
  5. package/dist/build/ebplayer-engines.bundle.js.map +1 -0
  6. package/dist/build/ebplayer.bundle.js +6603 -0
  7. package/dist/build/ebplayer.bundle.js.map +1 -0
  8. package/dist/build/theme-forja.css +10 -0
  9. package/dist/build/theme-forja.js +1 -0
  10. package/dist/build/theme-modern.css +520 -0
  11. package/dist/build/theme-radio.css +11 -0
  12. package/dist/build/theme-radio.js +1 -0
  13. package/dist/build/theme-snrt.css +11 -0
  14. package/dist/build/theme-snrt.js +1 -0
  15. package/dist/build/theme-v2.css +661 -0
  16. package/dist/build/types/config.d.ts +139 -0
  17. package/dist/build/types/config.d.ts.map +1 -0
  18. package/dist/build/types/core/command-handler.d.ts +49 -0
  19. package/dist/build/types/core/command-handler.d.ts.map +1 -0
  20. package/dist/build/types/core/config.d.ts +174 -0
  21. package/dist/build/types/core/config.d.ts.map +1 -0
  22. package/dist/build/types/core/css/theme-forja.entry.d.ts +2 -0
  23. package/dist/build/types/core/css/theme-forja.entry.d.ts.map +1 -0
  24. package/dist/build/types/core/css/theme-radio.entry.d.ts +2 -0
  25. package/dist/build/types/core/css/theme-radio.entry.d.ts.map +1 -0
  26. package/dist/build/types/core/css/theme-snrt.entry.d.ts +2 -0
  27. package/dist/build/types/core/css/theme-snrt.entry.d.ts.map +1 -0
  28. package/dist/build/types/core/engine-state-sync.d.ts +38 -0
  29. package/dist/build/types/core/engine-state-sync.d.ts.map +1 -0
  30. package/dist/build/types/core/event-bus.d.ts +87 -0
  31. package/dist/build/types/core/event-bus.d.ts.map +1 -0
  32. package/dist/build/types/core/fsm.d.ts +27 -0
  33. package/dist/build/types/core/fsm.d.ts.map +1 -0
  34. package/dist/build/types/core/i18n.d.ts +51 -0
  35. package/dist/build/types/core/i18n.d.ts.map +1 -0
  36. package/dist/build/types/core/index.d.ts +23 -0
  37. package/dist/build/types/core/index.d.ts.map +1 -0
  38. package/dist/build/types/core/lifecycle.d.ts +96 -0
  39. package/dist/build/types/core/lifecycle.d.ts.map +1 -0
  40. package/dist/build/types/core/player-state.d.ts +15 -0
  41. package/dist/build/types/core/player-state.d.ts.map +1 -0
  42. package/dist/build/types/core/types.d.ts +84 -0
  43. package/dist/build/types/core/types.d.ts.map +1 -0
  44. package/dist/build/types/eb-player-standalone.d.ts +12 -0
  45. package/dist/build/types/eb-player-standalone.d.ts.map +1 -0
  46. package/dist/build/types/eb-player.d.ts +43 -0
  47. package/dist/build/types/eb-player.d.ts.map +1 -0
  48. package/dist/build/types/engine-state-sync.d.ts +38 -0
  49. package/dist/build/types/engine-state-sync.d.ts.map +1 -0
  50. package/dist/build/types/engines/abr/dash.d.ts +56 -0
  51. package/dist/build/types/engines/abr/dash.d.ts.map +1 -0
  52. package/dist/build/types/engines/abr/hls.d.ts +105 -0
  53. package/dist/build/types/engines/abr/hls.d.ts.map +1 -0
  54. package/dist/build/types/engines/base-engine.d.ts +56 -0
  55. package/dist/build/types/engines/base-engine.d.ts.map +1 -0
  56. package/dist/build/types/engines/cdn-loader.d.ts +20 -0
  57. package/dist/build/types/engines/cdn-loader.d.ts.map +1 -0
  58. package/dist/build/types/engines/cdn-token-manager.d.ts +136 -0
  59. package/dist/build/types/engines/cdn-token-manager.d.ts.map +1 -0
  60. package/dist/build/types/engines/dash.d.ts +79 -0
  61. package/dist/build/types/engines/dash.d.ts.map +1 -0
  62. package/dist/build/types/engines/drm.d.ts +54 -0
  63. package/dist/build/types/engines/drm.d.ts.map +1 -0
  64. package/dist/build/types/engines/hls-discontinuity-patch.d.ts +43 -0
  65. package/dist/build/types/engines/hls-discontinuity-patch.d.ts.map +1 -0
  66. package/dist/build/types/engines/hls.d.ts +45 -0
  67. package/dist/build/types/engines/hls.d.ts.map +1 -0
  68. package/dist/build/types/engines/index.d.ts +26 -0
  69. package/dist/build/types/engines/index.d.ts.map +1 -0
  70. package/dist/build/types/engines/ios/hls.d.ts +20 -0
  71. package/dist/build/types/engines/ios/hls.d.ts.map +1 -0
  72. package/dist/build/types/engines/poster/hls.d.ts +35 -0
  73. package/dist/build/types/engines/poster/hls.d.ts.map +1 -0
  74. package/dist/build/types/engines/retry/dash.d.ts +39 -0
  75. package/dist/build/types/engines/retry/dash.d.ts.map +1 -0
  76. package/dist/build/types/engines/retry/hls.d.ts +35 -0
  77. package/dist/build/types/engines/retry/hls.d.ts.map +1 -0
  78. package/dist/build/types/engines/snapshot/dash.d.ts +55 -0
  79. package/dist/build/types/engines/snapshot/dash.d.ts.map +1 -0
  80. package/dist/build/types/engines/snapshot/hls.d.ts +108 -0
  81. package/dist/build/types/engines/snapshot/hls.d.ts.map +1 -0
  82. package/dist/build/types/engines/stall-watchdog.d.ts +41 -0
  83. package/dist/build/types/engines/stall-watchdog.d.ts.map +1 -0
  84. package/dist/build/types/event-bus.d.ts +54 -0
  85. package/dist/build/types/event-bus.d.ts.map +1 -0
  86. package/dist/build/types/fsm.d.ts +27 -0
  87. package/dist/build/types/fsm.d.ts.map +1 -0
  88. package/dist/build/types/i18n.d.ts +51 -0
  89. package/dist/build/types/i18n.d.ts.map +1 -0
  90. package/dist/build/types/index.d.ts +21 -0
  91. package/dist/build/types/index.d.ts.map +1 -0
  92. package/dist/build/types/integrations/ads-manager.d.ts +32 -0
  93. package/dist/build/types/integrations/ads-manager.d.ts.map +1 -0
  94. package/dist/build/types/integrations/chromecast-manager.d.ts +50 -0
  95. package/dist/build/types/integrations/chromecast-manager.d.ts.map +1 -0
  96. package/dist/build/types/integrations/epg-manager.d.ts +22 -0
  97. package/dist/build/types/integrations/epg-manager.d.ts.map +1 -0
  98. package/dist/build/types/integrations/index.d.ts +6 -0
  99. package/dist/build/types/integrations/index.d.ts.map +1 -0
  100. package/dist/build/types/integrations/p2p-manager.d.ts +33 -0
  101. package/dist/build/types/integrations/p2p-manager.d.ts.map +1 -0
  102. package/dist/build/types/integrations/playlist-manager.d.ts +21 -0
  103. package/dist/build/types/integrations/playlist-manager.d.ts.map +1 -0
  104. package/dist/build/types/lifecycle.d.ts +64 -0
  105. package/dist/build/types/lifecycle.d.ts.map +1 -0
  106. package/dist/build/types/player-state.d.ts +15 -0
  107. package/dist/build/types/player-state.d.ts.map +1 -0
  108. package/dist/build/types/skin/bars/bottom-bar.d.ts +16 -0
  109. package/dist/build/types/skin/bars/bottom-bar.d.ts.map +1 -0
  110. package/dist/build/types/skin/bars/middle-bar.d.ts +16 -0
  111. package/dist/build/types/skin/bars/middle-bar.d.ts.map +1 -0
  112. package/dist/build/types/skin/bars/top-bar.d.ts +15 -0
  113. package/dist/build/types/skin/bars/top-bar.d.ts.map +1 -0
  114. package/dist/build/types/skin/base-component.d.ts +69 -0
  115. package/dist/build/types/skin/base-component.d.ts.map +1 -0
  116. package/dist/build/types/skin/brand/forja-playlist-bar.d.ts +15 -0
  117. package/dist/build/types/skin/brand/forja-playlist-bar.d.ts.map +1 -0
  118. package/dist/build/types/skin/brand/snrt-radio-carousel.d.ts +16 -0
  119. package/dist/build/types/skin/brand/snrt-radio-carousel.d.ts.map +1 -0
  120. package/dist/build/types/skin/component-registry.d.ts +16 -0
  121. package/dist/build/types/skin/component-registry.d.ts.map +1 -0
  122. package/dist/build/types/skin/controllers/auto-hide.d.ts +27 -0
  123. package/dist/build/types/skin/controllers/auto-hide.d.ts.map +1 -0
  124. package/dist/build/types/skin/controllers/keyboard.d.ts +29 -0
  125. package/dist/build/types/skin/controllers/keyboard.d.ts.map +1 -0
  126. package/dist/build/types/skin/controls/cast-button.d.ts +15 -0
  127. package/dist/build/types/skin/controls/cast-button.d.ts.map +1 -0
  128. package/dist/build/types/skin/controls/forward-button.d.ts +15 -0
  129. package/dist/build/types/skin/controls/forward-button.d.ts.map +1 -0
  130. package/dist/build/types/skin/controls/fullscreen-button.d.ts +17 -0
  131. package/dist/build/types/skin/controls/fullscreen-button.d.ts.map +1 -0
  132. package/dist/build/types/skin/controls/info-button.d.ts +10 -0
  133. package/dist/build/types/skin/controls/info-button.d.ts.map +1 -0
  134. package/dist/build/types/skin/controls/live-sync-button.d.ts +20 -0
  135. package/dist/build/types/skin/controls/live-sync-button.d.ts.map +1 -0
  136. package/dist/build/types/skin/controls/pip-button.d.ts +21 -0
  137. package/dist/build/types/skin/controls/pip-button.d.ts.map +1 -0
  138. package/dist/build/types/skin/controls/play-pause-button.d.ts +14 -0
  139. package/dist/build/types/skin/controls/play-pause-button.d.ts.map +1 -0
  140. package/dist/build/types/skin/controls/rewind-button.d.ts +15 -0
  141. package/dist/build/types/skin/controls/rewind-button.d.ts.map +1 -0
  142. package/dist/build/types/skin/controls/seekbar.d.ts +43 -0
  143. package/dist/build/types/skin/controls/seekbar.d.ts.map +1 -0
  144. package/dist/build/types/skin/controls/settings-panel.d.ts +45 -0
  145. package/dist/build/types/skin/controls/settings-panel.d.ts.map +1 -0
  146. package/dist/build/types/skin/controls/share-button.d.ts +11 -0
  147. package/dist/build/types/skin/controls/share-button.d.ts.map +1 -0
  148. package/dist/build/types/skin/controls/time-display.d.ts +19 -0
  149. package/dist/build/types/skin/controls/time-display.d.ts.map +1 -0
  150. package/dist/build/types/skin/controls/volume-control.d.ts +21 -0
  151. package/dist/build/types/skin/controls/volume-control.d.ts.map +1 -0
  152. package/dist/build/types/skin/icons/icons-modern.d.ts +10 -0
  153. package/dist/build/types/skin/icons/icons-modern.d.ts.map +1 -0
  154. package/dist/build/types/skin/icons/icons.d.ts +10 -0
  155. package/dist/build/types/skin/icons/icons.d.ts.map +1 -0
  156. package/dist/build/types/skin/icons/sprite.d.ts +39 -0
  157. package/dist/build/types/skin/icons/sprite.d.ts.map +1 -0
  158. package/dist/build/types/skin/index.d.ts +24 -0
  159. package/dist/build/types/skin/index.d.ts.map +1 -0
  160. package/dist/build/types/skin/overlays/error-message.d.ts +14 -0
  161. package/dist/build/types/skin/overlays/error-message.d.ts.map +1 -0
  162. package/dist/build/types/skin/overlays/info-overlay.d.ts +15 -0
  163. package/dist/build/types/skin/overlays/info-overlay.d.ts.map +1 -0
  164. package/dist/build/types/skin/overlays/loading-spinner.d.ts +17 -0
  165. package/dist/build/types/skin/overlays/loading-spinner.d.ts.map +1 -0
  166. package/dist/build/types/skin/overlays/socials-overlay.d.ts +17 -0
  167. package/dist/build/types/skin/overlays/socials-overlay.d.ts.map +1 -0
  168. package/dist/build/types/skin/overlays/toast-notification.d.ts +18 -0
  169. package/dist/build/types/skin/overlays/toast-notification.d.ts.map +1 -0
  170. package/dist/build/types/skin/skin-root.d.ts +80 -0
  171. package/dist/build/types/skin/skin-root.d.ts.map +1 -0
  172. package/dist/build/types/types.d.ts +41 -0
  173. package/dist/build/types/types.d.ts.map +1 -0
  174. package/dist/build/types/utils/chapters.d.ts +16 -0
  175. package/dist/build/types/utils/chapters.d.ts.map +1 -0
  176. package/dist/build/types/utils/format-duration.d.ts +9 -0
  177. package/dist/build/types/utils/format-duration.d.ts.map +1 -0
  178. package/dist/build/types/utils/format-wall-clock.d.ts +6 -0
  179. package/dist/build/types/utils/format-wall-clock.d.ts.map +1 -0
  180. package/dist/build/types/utils/settings-helpers.d.ts +41 -0
  181. package/dist/build/types/utils/settings-helpers.d.ts.map +1 -0
  182. package/dist/dev/default.js +6451 -0
  183. package/dist/dev/default.js.map +1 -0
  184. package/dist/dev/easybroadcast.js +6677 -0
  185. package/dist/dev/easybroadcast.js.map +1 -0
  186. package/dist/dev/index.html +24 -0
  187. package/dist/eb-player.css +2066 -0
  188. package/dist/players/default/default.js +400 -1
  189. package/dist/players/default/index.html +1 -5
  190. package/dist/players/forja/forja.js +310 -0
  191. package/dist/players/forja/index.html +1 -0
  192. package/dist/players/videos/equipe/EB_lequipe-preprod.js +1 -0
  193. package/dist/players/videos/equipe/EB_lequipe.js +1 -1
  194. package/dist/players/videos/equipe/equipe.js +1 -1
  195. package/dist/theme-forja.css +10 -0
  196. package/dist/theme-modern.css +520 -0
  197. package/dist/theme-radio.css +11 -0
  198. package/dist/theme-snrt.css +11 -0
  199. package/dist/theme-v2.css +661 -0
  200. package/package.json +34 -3
  201. package/dist/build/forja.js +0 -1
  202. package/dist/players/videos/equipe/EB_lequipe-preprod copy.js +0 -1
@@ -0,0 +1,661 @@
1
+ /**
2
+ * V2 theme — based on snrtlive.ma (Aloula) player styling
3
+ *
4
+ * Applied when the container has [data-theme="v2"].
5
+ * Dark UI with orange accent (#ff841f), Inter font, rounded container,
6
+ * backdrop-blur panels, expandable volume, two-row bottom bar
7
+ * (seekbar on top, buttons below), gradient overlays, centered
8
+ * frosted-glass transport circles, and refined slide/fade animations.
9
+ */
10
+
11
+ /* ============================================================
12
+ Google Fonts (Inter 300-700)
13
+ ============================================================ */
14
+ @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');
15
+
16
+ /* ============================================================
17
+ Root vars & container
18
+ ============================================================ */
19
+ [data-theme="v2"] .eb-player {
20
+ --eb-color-primary: #ff841f;
21
+ --eb-color-progress: #ff841f;
22
+ --eb-color-background: rgba(10, 10, 20, 0.85);
23
+ --eb-accent: #ff841f;
24
+ --eb-color-text: #fff;
25
+ --eb-font-family: 'Inter', -apple-system, sans-serif;
26
+ --eb-font-size-base: 14px;
27
+ --eb-radius-control: 8px;
28
+ --eb-duration-transition: 200ms;
29
+ font-family: 'Inter', -apple-system, sans-serif;
30
+ border-radius: 14px;
31
+ box-shadow: 0 40px 80px rgba(0,0,0,.8), 0 0 0 1px rgba(255,255,255,.06);
32
+ color: #fff;
33
+ }
34
+
35
+ /* ============================================================
36
+ Icons: bolder stroke weight to match filled-style target
37
+ ============================================================ */
38
+ [data-theme="v2"] .eb-player .eb-icon {
39
+ stroke-width: 2.5;
40
+ }
41
+
42
+ /* Fullscreen: fill viewport, drop card styling */
43
+ [data-theme="v2"] .eb-player:fullscreen,
44
+ [data-theme="v2"] .eb-player:-webkit-full-screen {
45
+ border-radius: 0;
46
+ box-shadow: none;
47
+ }
48
+
49
+ /* ============================================================
50
+ Gradients (top & bottom)
51
+ ============================================================ */
52
+ [data-theme="v2"] .eb-player .eb-top-bar {
53
+ background: linear-gradient(to bottom, rgba(0,0,0,.72), transparent);
54
+ height: 110px;
55
+ padding: 14px 16px;
56
+ gap: 6px;
57
+ }
58
+
59
+ [data-theme="v2"] .eb-player .eb-bottom-bar__gradient {
60
+ height: 150px;
61
+ background: linear-gradient(to top, rgba(0,0,0,.9), transparent);
62
+ }
63
+
64
+ /* ============================================================
65
+ Top bar: slide-in from above
66
+ ============================================================ */
67
+ [data-theme="v2"] .eb-player.eb-controls-visible .eb-top-bar {
68
+ opacity: 1;
69
+ transform: translateY(0);
70
+ transition: opacity .3s, transform .3s;
71
+ }
72
+
73
+ [data-theme="v2"] .eb-player.eb-controls-hidden .eb-top-bar {
74
+ opacity: 0;
75
+ transform: translateY(-6px);
76
+ transition: opacity .3s, transform .3s;
77
+ }
78
+
79
+ [data-theme="v2"] .eb-player .eb-top-bar__actions {
80
+ gap: 6px;
81
+ }
82
+
83
+ /* Logo */
84
+ [data-theme="v2"] .eb-player .eb-top-bar__logo {
85
+ max-height: 32px;
86
+ max-width: 120px;
87
+ opacity: .85;
88
+ }
89
+
90
+ /* ============================================================
91
+ Bottom bar: slide-up animation + spacing
92
+ ============================================================ */
93
+ [data-theme="v2"] .eb-player .eb-bottom-bar__controls-row {
94
+ padding: 0 14px 12px;
95
+ gap: 8px;
96
+ }
97
+
98
+ [data-theme="v2"] .eb-player.eb-controls-visible .eb-bottom-bar {
99
+ opacity: 1;
100
+ transform: translateY(0);
101
+ transition: opacity .3s, transform .3s;
102
+ }
103
+
104
+ [data-theme="v2"] .eb-player.eb-controls-hidden .eb-bottom-bar {
105
+ opacity: 0;
106
+ transform: translateY(8px);
107
+ transition: opacity .3s, transform .3s;
108
+ }
109
+
110
+ /* ============================================================
111
+ Bottom bar: single-row layout
112
+ play | live | time | ——seekbar—— | settings | volume | fullscreen
113
+ PiP / Cast are in the top bar (via THEME_LAYOUTS.v2 in config.ts)
114
+ ============================================================ */
115
+
116
+ /* ============================================================
117
+ Middle bar: glassmorphism transport circles
118
+ ============================================================ */
119
+ [data-theme="v2"] .eb-player .eb-middle-bar {
120
+ gap: 28px;
121
+ }
122
+
123
+ [data-theme="v2"] .eb-player.eb-controls-visible .eb-middle-bar {
124
+ opacity: 1;
125
+ transition: opacity .3s;
126
+ }
127
+
128
+ [data-theme="v2"] .eb-player.eb-controls-hidden .eb-middle-bar {
129
+ opacity: 0;
130
+ transition: opacity .3s;
131
+ }
132
+
133
+ /* Central play/pause — large frosted circle */
134
+ [data-theme="v2"] .eb-player .eb-middle-bar__play-btn {
135
+ width: 80px;
136
+ height: 80px;
137
+ border-radius: 50%;
138
+ display: flex;
139
+ align-items: center;
140
+ justify-content: center;
141
+ background: rgba(255,255,255,.15);
142
+ backdrop-filter: blur(8px);
143
+ -webkit-backdrop-filter: blur(8px);
144
+ border: 2px solid rgba(255,255,255,.25);
145
+ color: #fff;
146
+ padding: 0;
147
+ transition: background .15s, transform .25s, opacity .25s;
148
+ }
149
+
150
+ [data-theme="v2"] .eb-player .eb-middle-bar__play-btn:hover {
151
+ background: rgba(255,255,255,.25);
152
+ }
153
+
154
+ [data-theme="v2"] .eb-player .eb-middle-bar__play-btn:active {
155
+ transform: scale(.92);
156
+ }
157
+
158
+ [data-theme="v2"] .eb-player .eb-middle-bar__play-btn .eb-icon {
159
+ width: 32px;
160
+ height: 32px;
161
+ stroke-width: 2.5;
162
+ }
163
+
164
+ /* Seek buttons — smaller frosted circles, same style as play button */
165
+ [data-theme="v2"] .eb-player .eb-middle-bar__seek-btn {
166
+ width: 56px;
167
+ height: 56px;
168
+ border-radius: 50%;
169
+ display: flex;
170
+ flex-direction: column;
171
+ align-items: center;
172
+ justify-content: center;
173
+ background: rgba(255,255,255,.15);
174
+ backdrop-filter: blur(8px);
175
+ -webkit-backdrop-filter: blur(8px);
176
+ border: 2px solid rgba(255,255,255,.25);
177
+ color: #fff;
178
+ gap: 1px;
179
+ padding: 0;
180
+ transition: background .15s;
181
+ }
182
+
183
+ [data-theme="v2"] .eb-player .eb-middle-bar__seek-btn:hover {
184
+ background: rgba(255,255,255,.25);
185
+ }
186
+
187
+ [data-theme="v2"] .eb-player .eb-seek-circle {
188
+ width: 24px;
189
+ height: 24px;
190
+ color: rgba(255,255,255,.85);
191
+ fill: currentColor;
192
+ stroke: none;
193
+ }
194
+
195
+ [data-theme="v2"] .eb-player .eb-seek-label {
196
+ font-size: .75em;
197
+ font-weight: 700;
198
+ color: rgba(255,255,255,.9);
199
+ line-height: 1;
200
+ }
201
+
202
+ /* ============================================================
203
+ Buttons: rounded, soft color, scale on press
204
+ ============================================================ */
205
+ [data-theme="v2"] .eb-player .eb-button:not(.eb-middle-bar__seek-btn):not(.eb-middle-bar__play-btn),
206
+ [data-theme="v2"] .eb-player .eb-play-pause,
207
+ [data-theme="v2"] .eb-player .eb-fullscreen,
208
+ [data-theme="v2"] .eb-player .eb-pip,
209
+ [data-theme="v2"] .eb-player .eb-cast,
210
+ [data-theme="v2"] .eb-player .eb-volume-mute,
211
+ [data-theme="v2"] .eb-player .eb-live-sync {
212
+ color: rgba(255,255,255,.82);
213
+ border-radius: 8px;
214
+ width: 38px;
215
+ height: 38px;
216
+ transition: background .15s, color .15s, transform .1s;
217
+ flex-shrink: 0;
218
+ }
219
+
220
+ [data-theme="v2"] .eb-player .eb-button:not(.eb-middle-bar__seek-btn):not(.eb-middle-bar__play-btn):hover,
221
+ [data-theme="v2"] .eb-player .eb-play-pause:hover,
222
+ [data-theme="v2"] .eb-player .eb-fullscreen:hover,
223
+ [data-theme="v2"] .eb-player .eb-pip:hover,
224
+ [data-theme="v2"] .eb-player .eb-cast:hover,
225
+ [data-theme="v2"] .eb-player .eb-volume-mute:hover,
226
+ [data-theme="v2"] .eb-player .eb-live-sync:hover {
227
+ background: rgba(255,255,255,.12);
228
+ color: #fff;
229
+ }
230
+
231
+ [data-theme="v2"] .eb-player .eb-button:not(.eb-middle-bar__seek-btn):not(.eb-middle-bar__play-btn):active,
232
+ [data-theme="v2"] .eb-player .eb-play-pause:active,
233
+ [data-theme="v2"] .eb-player .eb-fullscreen:active,
234
+ [data-theme="v2"] .eb-player .eb-pip:active,
235
+ [data-theme="v2"] .eb-player .eb-cast:active,
236
+ [data-theme="v2"] .eb-player .eb-volume-mute:active,
237
+ [data-theme="v2"] .eb-player .eb-live-sync:active {
238
+ transform: scale(.88);
239
+ }
240
+
241
+ /* Icon size inside buttons (not middle bar transport) */
242
+ [data-theme="v2"] .eb-player .eb-button:not(.eb-middle-bar__seek-btn):not(.eb-middle-bar__play-btn) .eb-icon,
243
+ [data-theme="v2"] .eb-player .eb-play-pause .eb-icon,
244
+ [data-theme="v2"] .eb-player .eb-fullscreen .eb-icon,
245
+ [data-theme="v2"] .eb-player .eb-pip .eb-icon,
246
+ [data-theme="v2"] .eb-player .eb-cast .eb-icon,
247
+ [data-theme="v2"] .eb-player .eb-volume-mute .eb-icon {
248
+ width: 22px;
249
+ height: 22px;
250
+ }
251
+
252
+ /* Top bar icons slightly larger */
253
+ [data-theme="v2"] .eb-player .eb-top-bar .eb-icon {
254
+ width: 24px;
255
+ height: 24px;
256
+ }
257
+
258
+ /* Play/pause icons should be filled (solid), not stroke outlines */
259
+ [data-theme="v2"] .eb-player .eb-play-pause .eb-icon,
260
+ [data-theme="v2"] .eb-player .eb-middle-bar__play-btn .eb-icon {
261
+ fill: currentColor;
262
+ stroke: none;
263
+ }
264
+
265
+ /* Volume icon: fill the speaker body, keep stroke for sound waves */
266
+ [data-theme="v2"] .eb-player .eb-volume-mute .eb-icon path:first-child {
267
+ fill: currentColor;
268
+ }
269
+
270
+ /* Cast button active state — cyan */
271
+ [data-theme="v2"] .eb-player .eb-cast-active {
272
+ color: #1eb6d4 !important;
273
+ background: rgba(30, 182, 212, .15) !important;
274
+ }
275
+
276
+ [data-theme="v2"] .eb-player .eb-cast-active .eb-icon {
277
+ filter: drop-shadow(0 0 4px rgba(30, 182, 212, .6));
278
+ }
279
+
280
+ /* ============================================================
281
+ Seekbar
282
+ ============================================================ */
283
+ [data-theme="v2"] .eb-player .eb-seekbar-track {
284
+ height: 3px;
285
+ background: rgba(255,255,255,.22);
286
+ border-radius: 3px;
287
+ transition: height .15s;
288
+ }
289
+
290
+ [data-theme="v2"] .eb-player .eb-seekbar:hover .eb-seekbar-track {
291
+ height: 5px;
292
+ }
293
+
294
+ [data-theme="v2"] .eb-player .eb-seekbar-buffered {
295
+ background: rgba(255,255,255,.28);
296
+ border-radius: 3px;
297
+ transition: height .15s;
298
+ }
299
+
300
+ /* Orange gradient fill */
301
+ [data-theme="v2"] .eb-player .eb-seekbar-progress {
302
+ background: linear-gradient(90deg, #ff841f, color-mix(in srgb, #ff841f 70%, #fff));
303
+ border-radius: 3px;
304
+ transition: height .15s;
305
+ }
306
+
307
+ [data-theme="v2"] .eb-player .eb-seekbar-thumb {
308
+ width: 14px;
309
+ height: 14px;
310
+ right: -7px;
311
+ background: #fff;
312
+ box-shadow: 0 0 0 3px rgba(255,132,31,.45);
313
+ }
314
+
315
+ /* ============================================================
316
+ Seekbar tooltip & preview
317
+ ============================================================ */
318
+ [data-theme="v2"] .eb-player .eb-seekbar-tooltip {
319
+ bottom: 28px;
320
+ background: rgba(0,0,0,.88);
321
+ border: 1px solid rgba(255,255,255,.12);
322
+ border-radius: 7px;
323
+ font-size: 11px;
324
+ font-weight: 500;
325
+ padding: 0;
326
+ overflow: hidden;
327
+ box-shadow: 0 4px 16px rgba(0,0,0,.5);
328
+ display: flex;
329
+ flex-direction: column;
330
+ align-items: center;
331
+ }
332
+
333
+ [data-theme="v2"] .eb-player .eb-seekbar-preview {
334
+ width: 160px;
335
+ height: 90px;
336
+ background: #111;
337
+ border: none;
338
+ border-radius: 0;
339
+ margin: 0;
340
+ }
341
+
342
+ /* ============================================================
343
+ Chapter markers
344
+ ============================================================ */
345
+ [data-theme="v2"] .eb-player .eb-chapter-marker {
346
+ width: 2px;
347
+ height: 7px;
348
+ background: rgba(0,0,0,.45);
349
+ border-radius: 1px;
350
+ top: 50%;
351
+ transform: translate(-50%, -50%);
352
+ }
353
+
354
+ /* ============================================================
355
+ Volume: expandable slider, white fill
356
+ ============================================================ */
357
+ [data-theme="v2"] .eb-player .eb-volume-control {
358
+ flex-direction: row;
359
+ gap: 0;
360
+ margin-right: 0;
361
+ }
362
+
363
+ [data-theme="v2"] .eb-player .eb-volume-track {
364
+ width: 0;
365
+ height: 3px;
366
+ background: rgba(255,255,255,.22);
367
+ border-radius: 3px;
368
+ overflow: hidden;
369
+ transition: width .25s ease, margin .25s ease;
370
+ margin: 0;
371
+ }
372
+
373
+ [data-theme="v2"] .eb-player .eb-volume-control:hover .eb-volume-track,
374
+ [data-theme="v2"] .eb-player .eb-volume-control:focus-within .eb-volume-track {
375
+ width: 66px;
376
+ margin: 0 6px 0 2px;
377
+ }
378
+
379
+ [data-theme="v2"] .eb-player .eb-volume-fill {
380
+ background: #fff;
381
+ }
382
+
383
+ [data-theme="v2"] .eb-player .eb-volume-thumb {
384
+ width: 11px;
385
+ height: 11px;
386
+ background: #fff;
387
+ box-shadow: 0 0 0 2px rgba(255,255,255,.35);
388
+ transform: translate(-50%, -50%) scale(0);
389
+ transition: transform .15s;
390
+ }
391
+
392
+ [data-theme="v2"] .eb-player .eb-volume-control:hover .eb-volume-thumb {
393
+ transform: translate(-50%, -50%) scale(1);
394
+ }
395
+
396
+ /* ============================================================
397
+ Time display
398
+ ============================================================ */
399
+ [data-theme="v2"] .eb-player .eb-time-display {
400
+ font-size: 13px;
401
+ color: rgba(255,255,255,.85);
402
+ font-weight: 500;
403
+ letter-spacing: .02em;
404
+ }
405
+
406
+ /* ============================================================
407
+ Live badge — text badge with blinking dot (not icon)
408
+ ============================================================ */
409
+ [data-theme="v2"] .eb-player .eb-live-sync {
410
+ width: auto;
411
+ height: auto;
412
+ padding: 4px 10px;
413
+ border-radius: 6px;
414
+ font-size: 11px;
415
+ font-weight: 700;
416
+ letter-spacing: .08em;
417
+ text-transform: uppercase;
418
+ gap: 5px;
419
+ }
420
+
421
+ /* Hide icon, show dot + label */
422
+ [data-theme="v2"] .eb-player .eb-live-sync__icon {
423
+ display: none;
424
+ }
425
+
426
+ [data-theme="v2"] .eb-player .eb-live-sync__dot {
427
+ display: block;
428
+ width: 6px;
429
+ height: 6px;
430
+ border-radius: 50%;
431
+ background: #fff;
432
+ flex-shrink: 0;
433
+ }
434
+
435
+ [data-theme="v2"] .eb-player .eb-live-sync__label {
436
+ display: block;
437
+ }
438
+
439
+ /* Synced state — red background with blinking dot */
440
+ [data-theme="v2"] .eb-player .eb-live-synced {
441
+ background: rgba(220,38,38,.9);
442
+ color: #fff;
443
+ box-shadow: 0 2px 8px rgba(220,38,38,.4);
444
+ }
445
+
446
+ [data-theme="v2"] .eb-player .eb-live-synced .eb-live-sync__dot {
447
+ animation: eb-v2-blink 1.2s ease infinite;
448
+ }
449
+
450
+ /* Delayed / not-at-live-edge */
451
+ [data-theme="v2"] .eb-player .eb-live-sync:not(.eb-live-synced) {
452
+ background: rgba(60,60,80,.75);
453
+ color: rgba(255,255,255,.7);
454
+ box-shadow: none;
455
+ }
456
+
457
+ [data-theme="v2"] .eb-player .eb-live-sync:not(.eb-live-synced) .eb-live-sync__dot {
458
+ background: rgba(255,255,255,.5);
459
+ animation: none;
460
+ }
461
+
462
+ [data-theme="v2"] .eb-player .eb-live-sync:not(.eb-live-synced):hover {
463
+ background: rgba(220,38,38,.7);
464
+ color: #fff;
465
+ }
466
+
467
+ @keyframes eb-v2-blink {
468
+ 0%, 100% { opacity: 1; }
469
+ 50% { opacity: .15; }
470
+ }
471
+
472
+ /* ============================================================
473
+ Settings panel: glassmorphism dropdown
474
+ ============================================================ */
475
+ [data-theme="v2"] .eb-player .eb-settings-panel {
476
+ background: rgba(10,10,20,.55);
477
+ backdrop-filter: blur(18px) saturate(160%);
478
+ -webkit-backdrop-filter: blur(18px) saturate(160%);
479
+ border-radius: 12px;
480
+ min-width: 300px;
481
+ box-shadow: 0 16px 48px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.1);
482
+ }
483
+
484
+ [data-theme="v2"] .eb-player .eb-settings-menu {
485
+ padding: 0;
486
+ }
487
+
488
+ [data-theme="v2"] .eb-player .eb-settings-category,
489
+ [data-theme="v2"] .eb-player .eb-settings-item,
490
+ [data-theme="v2"] .eb-player .eb-settings-back {
491
+ padding: 15px 20px;
492
+ font-size: 13px;
493
+ color: rgba(255,255,255,.9);
494
+ border-bottom: 1px solid rgba(255,255,255,.06);
495
+ transition: background .12s;
496
+ }
497
+
498
+ [data-theme="v2"] .eb-player .eb-settings-category:last-child,
499
+ [data-theme="v2"] .eb-player .eb-settings-item:last-child {
500
+ border-bottom: none;
501
+ }
502
+
503
+ [data-theme="v2"] .eb-player .eb-settings-category:hover,
504
+ [data-theme="v2"] .eb-player .eb-settings-item:hover,
505
+ [data-theme="v2"] .eb-player .eb-settings-back:hover {
506
+ background: rgba(255,255,255,.05);
507
+ }
508
+
509
+ /* Selected item text */
510
+ [data-theme="v2"] .eb-player .eb-settings-item--selected {
511
+ color: #fff;
512
+ font-weight: 500;
513
+ }
514
+
515
+ /* Active selection dot (filled orange) */
516
+ [data-theme="v2"] .eb-player .eb-settings-item--selected::after {
517
+ content: '';
518
+ width: 10px;
519
+ height: 10px;
520
+ border-radius: 50%;
521
+ background: var(--eb-accent, #ff841f);
522
+ box-shadow: 0 0 0 3px rgba(255,132,31,.25);
523
+ flex-shrink: 0;
524
+ }
525
+
526
+ /* Non-selected items: hollow dot */
527
+ [data-theme="v2"] .eb-player .eb-settings-item:not(.eb-settings-item--selected)::after {
528
+ content: '';
529
+ width: 10px;
530
+ height: 10px;
531
+ border-radius: 50%;
532
+ border: 2px solid rgba(255,255,255,.2);
533
+ flex-shrink: 0;
534
+ }
535
+
536
+ /* Back button */
537
+ [data-theme="v2"] .eb-player .eb-settings-back {
538
+ gap: 14px;
539
+ font-weight: 600;
540
+ }
541
+
542
+ /* ============================================================
543
+ Loading spinner
544
+ ============================================================ */
545
+ [data-theme="v2"] .eb-player .eb-loading .eb-icon {
546
+ width: 52px;
547
+ height: 52px;
548
+ color: rgba(255,255,255,.7);
549
+ filter: drop-shadow(0 1px 6px rgba(0,0,0,.5));
550
+ animation: eb-spin .75s linear infinite;
551
+ }
552
+
553
+ /* ============================================================
554
+ Error overlay
555
+ ============================================================ */
556
+ [data-theme="v2"] .eb-player .eb-error {
557
+ background: rgba(10,10,20,.85);
558
+ backdrop-filter: blur(12px);
559
+ -webkit-backdrop-filter: blur(12px);
560
+ }
561
+
562
+ [data-theme="v2"] .eb-player .eb-error-message {
563
+ font-weight: 400;
564
+ letter-spacing: .01em;
565
+ }
566
+
567
+ [data-theme="v2"] .eb-player .eb-error-retry {
568
+ border-radius: 8px;
569
+ background: rgba(255,255,255,.1);
570
+ border-color: rgba(255,255,255,.15);
571
+ transition: background .2s, color .2s;
572
+ }
573
+
574
+ [data-theme="v2"] .eb-player .eb-error-retry:hover {
575
+ background: rgba(255,255,255,.18);
576
+ }
577
+
578
+ /* ============================================================
579
+ Toast (keyboard hints, status messages)
580
+ ============================================================ */
581
+ [data-theme="v2"] .eb-player .eb-toast {
582
+ background: rgba(0,0,0,.72);
583
+ backdrop-filter: blur(10px);
584
+ -webkit-backdrop-filter: blur(10px);
585
+ border-radius: 10px;
586
+ font-size: 13px;
587
+ padding: 8px 16px;
588
+ }
589
+
590
+ /* ============================================================
591
+ Info & socials overlays
592
+ ============================================================ */
593
+ [data-theme="v2"] .eb-player .eb-info-overlay,
594
+ [data-theme="v2"] .eb-player .eb-socials-overlay {
595
+ background: rgba(10,10,20,.85);
596
+ backdrop-filter: blur(12px);
597
+ -webkit-backdrop-filter: blur(12px);
598
+ }
599
+
600
+ [data-theme="v2"] .eb-player .eb-info-close,
601
+ [data-theme="v2"] .eb-player .eb-socials-close {
602
+ border-radius: 8px;
603
+ background: rgba(255,255,255,.07);
604
+ border-color: rgba(255,255,255,.08);
605
+ transition: background .2s, color .2s;
606
+ }
607
+
608
+ [data-theme="v2"] .eb-player .eb-info-close:hover,
609
+ [data-theme="v2"] .eb-player .eb-socials-close:hover {
610
+ background: rgba(255,255,255,.13);
611
+ color: #fff;
612
+ }
613
+
614
+ [data-theme="v2"] .eb-player .eb-socials-link {
615
+ background: rgba(255,255,255,.07);
616
+ border: 1px solid rgba(255,255,255,.08);
617
+ border-radius: 8px;
618
+ transition: background .2s, color .2s, border-color .2s;
619
+ }
620
+
621
+ [data-theme="v2"] .eb-player .eb-socials-link:hover {
622
+ background: rgba(255,132,31,.15);
623
+ border-color: rgba(255,132,31,.35);
624
+ color: #ffb980;
625
+ }
626
+
627
+ /* ============================================================
628
+ Poster
629
+ ============================================================ */
630
+ [data-theme="v2"] .eb-player .eb-poster {
631
+ background: linear-gradient(135deg, #0f0c29, #302b63, #24243e);
632
+ }
633
+
634
+ /* ============================================================
635
+ Radio overlay
636
+ ============================================================ */
637
+ [data-theme="v2"] .eb-player .eb-radio-overlay {
638
+ background: linear-gradient(135deg, #0f0c29, #302b63, #24243e);
639
+ }
640
+
641
+ [data-theme="v2"] .eb-player .eb-radio-bar {
642
+ background: rgba(255,132,31,.8);
643
+ }
644
+
645
+ /* ============================================================
646
+ Chapter skip button
647
+ ============================================================ */
648
+ [data-theme="v2"] .eb-player .eb-chapter-skip {
649
+ background: rgba(10,10,20,.55);
650
+ backdrop-filter: blur(12px);
651
+ -webkit-backdrop-filter: blur(12px);
652
+ border: 1px solid rgba(255,255,255,.15);
653
+ border-radius: 8px;
654
+ font-size: 12px;
655
+ font-weight: 500;
656
+ transition: background .15s;
657
+ }
658
+
659
+ [data-theme="v2"] .eb-player .eb-chapter-skip:hover {
660
+ background: rgba(255,255,255,.12);
661
+ }