@videojs/html 0.1.0-preview.9 → 10.0.0-alpha.11

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 (888) hide show
  1. package/README.md +4 -2
  2. package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js +6 -0
  3. package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js.map +1 -0
  4. package/dist/default/_virtual/inline-css_src/define/audio/skin.js +6 -0
  5. package/dist/default/_virtual/inline-css_src/define/audio/skin.js.map +1 -0
  6. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js +6 -0
  7. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -0
  8. package/dist/default/_virtual/inline-css_src/define/video/skin.js +6 -0
  9. package/dist/default/_virtual/inline-css_src/define/video/skin.js.map +1 -0
  10. package/dist/default/define/audio/minimal-skin.css +636 -0
  11. package/dist/default/define/audio/minimal-skin.js +114 -0
  12. package/dist/default/define/audio/minimal-skin.js.map +1 -0
  13. package/dist/default/define/audio/minimal-skin.tailwind.js +121 -0
  14. package/dist/default/define/audio/minimal-skin.tailwind.js.map +1 -0
  15. package/dist/default/define/audio/player.js +19 -0
  16. package/dist/default/define/audio/player.js.map +1 -0
  17. package/dist/default/define/audio/skin.css +661 -0
  18. package/dist/default/define/audio/skin.js +105 -0
  19. package/dist/default/define/audio/skin.js.map +1 -0
  20. package/dist/default/define/audio/skin.tailwind.js +111 -0
  21. package/dist/default/define/audio/skin.tailwind.js.map +1 -0
  22. package/dist/default/define/background/player.js +19 -0
  23. package/dist/default/define/background/player.js.map +1 -0
  24. package/dist/default/define/background/skin.css +27 -0
  25. package/dist/default/define/background/skin.js +35 -0
  26. package/dist/default/define/background/skin.js.map +1 -0
  27. package/dist/default/define/background/video.js +3 -0
  28. package/dist/default/define/media/background-video.js +14 -0
  29. package/dist/default/define/media/background-video.js.map +1 -0
  30. package/dist/default/define/media/container.js +8 -0
  31. package/dist/default/define/media/container.js.map +1 -0
  32. package/dist/default/define/media/hls-video.js +14 -0
  33. package/dist/default/define/media/hls-video.js.map +1 -0
  34. package/dist/default/define/media/simple-hls-video.js +13 -0
  35. package/dist/default/define/media/simple-hls-video.js.map +1 -0
  36. package/dist/default/define/safe-define.js +9 -0
  37. package/dist/default/define/safe-define.js.map +1 -0
  38. package/dist/default/define/skin-mixin.js +69 -0
  39. package/dist/default/define/skin-mixin.js.map +1 -0
  40. package/dist/default/define/ui/alert-dialog-close.js +8 -0
  41. package/dist/default/define/ui/alert-dialog-close.js.map +1 -0
  42. package/dist/default/define/ui/alert-dialog-description.js +8 -0
  43. package/dist/default/define/ui/alert-dialog-description.js.map +1 -0
  44. package/dist/default/define/ui/alert-dialog-title.js +8 -0
  45. package/dist/default/define/ui/alert-dialog-title.js.map +1 -0
  46. package/dist/default/define/ui/alert-dialog.js +14 -0
  47. package/dist/default/define/ui/alert-dialog.js.map +1 -0
  48. package/dist/default/define/ui/buffering-indicator.js +8 -0
  49. package/dist/default/define/ui/buffering-indicator.js.map +1 -0
  50. package/dist/default/define/ui/captions-button.js +7 -0
  51. package/dist/default/define/ui/captions-button.js.map +1 -0
  52. package/dist/default/define/ui/controls-group.js +8 -0
  53. package/dist/default/define/ui/controls-group.js.map +1 -0
  54. package/dist/default/define/ui/controls.js +10 -0
  55. package/dist/default/define/ui/controls.js.map +1 -0
  56. package/dist/default/define/ui/fullscreen-button.js +8 -0
  57. package/dist/default/define/ui/fullscreen-button.js.map +1 -0
  58. package/dist/default/define/ui/mute-button.js +8 -0
  59. package/dist/default/define/ui/mute-button.js.map +1 -0
  60. package/dist/default/define/ui/pip-button.js +8 -0
  61. package/dist/default/define/ui/pip-button.js.map +1 -0
  62. package/dist/default/define/ui/play-button.js +8 -0
  63. package/dist/default/define/ui/play-button.js.map +1 -0
  64. package/dist/default/define/ui/playback-rate-button.js +8 -0
  65. package/dist/default/define/ui/playback-rate-button.js.map +1 -0
  66. package/dist/default/define/ui/popover.js +8 -0
  67. package/dist/default/define/ui/popover.js.map +1 -0
  68. package/dist/default/define/ui/poster.js +8 -0
  69. package/dist/default/define/ui/poster.js.map +1 -0
  70. package/dist/default/define/ui/seek-button.js +8 -0
  71. package/dist/default/define/ui/seek-button.js.map +1 -0
  72. package/dist/default/define/ui/slider-buffer.js +8 -0
  73. package/dist/default/define/ui/slider-buffer.js.map +1 -0
  74. package/dist/default/define/ui/slider-fill.js +8 -0
  75. package/dist/default/define/ui/slider-fill.js.map +1 -0
  76. package/dist/default/define/ui/slider-thumb.js +8 -0
  77. package/dist/default/define/ui/slider-thumb.js.map +1 -0
  78. package/dist/default/define/ui/slider-thumbnail.js +8 -0
  79. package/dist/default/define/ui/slider-thumbnail.js.map +1 -0
  80. package/dist/default/define/ui/slider-track.js +8 -0
  81. package/dist/default/define/ui/slider-track.js.map +1 -0
  82. package/dist/default/define/ui/slider-value.js +8 -0
  83. package/dist/default/define/ui/slider-value.js.map +1 -0
  84. package/dist/default/define/ui/slider.js +18 -0
  85. package/dist/default/define/ui/slider.js.map +1 -0
  86. package/dist/default/define/ui/thumbnail.js +8 -0
  87. package/dist/default/define/ui/thumbnail.js.map +1 -0
  88. package/dist/default/define/ui/time-group.js +8 -0
  89. package/dist/default/define/ui/time-group.js.map +1 -0
  90. package/dist/default/define/ui/time-separator.js +8 -0
  91. package/dist/default/define/ui/time-separator.js.map +1 -0
  92. package/dist/default/define/ui/time-slider.js +22 -0
  93. package/dist/default/define/ui/time-slider.js.map +1 -0
  94. package/dist/default/define/ui/time.js +12 -0
  95. package/dist/default/define/ui/time.js.map +1 -0
  96. package/dist/default/define/ui/tooltip-group.js +8 -0
  97. package/dist/default/define/ui/tooltip-group.js.map +1 -0
  98. package/dist/default/define/ui/tooltip.js +8 -0
  99. package/dist/default/define/ui/tooltip.js.map +1 -0
  100. package/dist/default/define/ui/volume-slider.js +18 -0
  101. package/dist/default/define/ui/volume-slider.js.map +1 -0
  102. package/dist/default/define/video/minimal-skin.css +873 -0
  103. package/dist/default/define/video/minimal-skin.js +160 -0
  104. package/dist/default/define/video/minimal-skin.js.map +1 -0
  105. package/dist/default/define/video/minimal-skin.tailwind.js +180 -0
  106. package/dist/default/define/video/minimal-skin.tailwind.js.map +1 -0
  107. package/dist/default/define/video/player.js +19 -0
  108. package/dist/default/define/video/player.js.map +1 -0
  109. package/dist/default/define/video/skin.css +878 -0
  110. package/dist/default/define/video/skin.js +156 -0
  111. package/dist/default/define/video/skin.js.map +1 -0
  112. package/dist/default/define/video/skin.tailwind.js +170 -0
  113. package/dist/default/define/video/skin.tailwind.js.map +1 -0
  114. package/dist/default/icons/dist/render/default/index.js +27 -0
  115. package/dist/default/icons/dist/render/default/index.js.map +1 -0
  116. package/dist/default/icons/dist/render/minimal/index.js +27 -0
  117. package/dist/default/icons/dist/render/minimal/index.js.map +1 -0
  118. package/dist/default/index.js +48 -0
  119. package/dist/default/media/background-video/index.js +83 -0
  120. package/dist/default/media/background-video/index.js.map +1 -0
  121. package/dist/default/media/container-element.js +15 -0
  122. package/dist/default/media/container-element.js.map +1 -0
  123. package/dist/default/media/hls-video/index.js +25 -0
  124. package/dist/default/media/hls-video/index.js.map +1 -0
  125. package/dist/default/media/simple-hls-video/index.js +21 -0
  126. package/dist/default/media/simple-hls-video/index.js.map +1 -0
  127. package/dist/default/player/context.js +14 -0
  128. package/dist/default/player/context.js.map +1 -0
  129. package/dist/default/player/create-player.js +24 -0
  130. package/dist/default/player/create-player.js.map +1 -0
  131. package/dist/default/player/player-controller.js +66 -0
  132. package/dist/default/player/player-controller.js.map +1 -0
  133. package/dist/default/presets/audio.js +7 -0
  134. package/dist/default/presets/background.js +3 -0
  135. package/dist/default/presets/video.js +7 -0
  136. package/dist/default/skins/dist/default/default/tailwind/audio.tailwind.js +58 -0
  137. package/dist/default/skins/dist/default/default/tailwind/audio.tailwind.js.map +1 -0
  138. package/dist/default/skins/dist/default/default/tailwind/components/buffering.js +9 -0
  139. package/dist/default/skins/dist/default/default/tailwind/components/buffering.js.map +1 -0
  140. package/dist/default/skins/dist/default/default/tailwind/components/button.js +12 -0
  141. package/dist/default/skins/dist/default/default/tailwind/components/button.js.map +1 -0
  142. package/dist/default/skins/dist/default/default/tailwind/components/controls.js +8 -0
  143. package/dist/default/skins/dist/default/default/tailwind/components/controls.js.map +1 -0
  144. package/dist/default/skins/dist/default/default/tailwind/components/error.js +15 -0
  145. package/dist/default/skins/dist/default/default/tailwind/components/error.js.map +1 -0
  146. package/dist/default/skins/dist/default/default/tailwind/components/icon-state.js +29 -0
  147. package/dist/default/skins/dist/default/default/tailwind/components/icon-state.js.map +1 -0
  148. package/dist/default/skins/dist/default/default/tailwind/components/icon.js +10 -0
  149. package/dist/default/skins/dist/default/default/tailwind/components/icon.js.map +1 -0
  150. package/dist/default/skins/dist/default/default/tailwind/components/overlay.js +8 -0
  151. package/dist/default/skins/dist/default/default/tailwind/components/overlay.js.map +1 -0
  152. package/dist/default/skins/dist/default/default/tailwind/components/playback-rate.js +6 -0
  153. package/dist/default/skins/dist/default/default/tailwind/components/playback-rate.js.map +1 -0
  154. package/dist/default/skins/dist/default/default/tailwind/components/popup.js +13 -0
  155. package/dist/default/skins/dist/default/default/tailwind/components/popup.js.map +1 -0
  156. package/dist/default/skins/dist/default/default/tailwind/components/root.js +8 -0
  157. package/dist/default/skins/dist/default/default/tailwind/components/root.js.map +1 -0
  158. package/dist/default/skins/dist/default/default/tailwind/components/seek.js +11 -0
  159. package/dist/default/skins/dist/default/default/tailwind/components/seek.js.map +1 -0
  160. package/dist/default/skins/dist/default/default/tailwind/components/slider.js +21 -0
  161. package/dist/default/skins/dist/default/default/tailwind/components/slider.js.map +1 -0
  162. package/dist/default/skins/dist/default/default/tailwind/components/surface.js +8 -0
  163. package/dist/default/skins/dist/default/default/tailwind/components/surface.js.map +1 -0
  164. package/dist/default/skins/dist/default/default/tailwind/components/time.js +10 -0
  165. package/dist/default/skins/dist/default/default/tailwind/components/time.js.map +1 -0
  166. package/dist/default/skins/dist/default/default/tailwind/components/tooltip-state.js +28 -0
  167. package/dist/default/skins/dist/default/default/tailwind/components/tooltip-state.js.map +1 -0
  168. package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js +55 -0
  169. package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -0
  170. package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js +44 -0
  171. package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -0
  172. package/dist/default/skins/dist/default/minimal/tailwind/components/buffering.js +6 -0
  173. package/dist/default/skins/dist/default/minimal/tailwind/components/buffering.js.map +1 -0
  174. package/dist/default/skins/dist/default/minimal/tailwind/components/button-group.js +8 -0
  175. package/dist/default/skins/dist/default/minimal/tailwind/components/button-group.js.map +1 -0
  176. package/dist/default/skins/dist/default/minimal/tailwind/components/button.js +12 -0
  177. package/dist/default/skins/dist/default/minimal/tailwind/components/button.js.map +1 -0
  178. package/dist/default/skins/dist/default/minimal/tailwind/components/controls.js +8 -0
  179. package/dist/default/skins/dist/default/minimal/tailwind/components/controls.js.map +1 -0
  180. package/dist/default/skins/dist/default/minimal/tailwind/components/error.js +15 -0
  181. package/dist/default/skins/dist/default/minimal/tailwind/components/error.js.map +1 -0
  182. package/dist/default/skins/dist/default/minimal/tailwind/components/icon-state.js +29 -0
  183. package/dist/default/skins/dist/default/minimal/tailwind/components/icon-state.js.map +1 -0
  184. package/dist/default/skins/dist/default/minimal/tailwind/components/icon.js +10 -0
  185. package/dist/default/skins/dist/default/minimal/tailwind/components/icon.js.map +1 -0
  186. package/dist/default/skins/dist/default/minimal/tailwind/components/overlay.js +8 -0
  187. package/dist/default/skins/dist/default/minimal/tailwind/components/overlay.js.map +1 -0
  188. package/dist/default/skins/dist/default/minimal/tailwind/components/popup.js +12 -0
  189. package/dist/default/skins/dist/default/minimal/tailwind/components/popup.js.map +1 -0
  190. package/dist/default/skins/dist/default/minimal/tailwind/components/root.js +8 -0
  191. package/dist/default/skins/dist/default/minimal/tailwind/components/root.js.map +1 -0
  192. package/dist/default/skins/dist/default/minimal/tailwind/components/seek.js +11 -0
  193. package/dist/default/skins/dist/default/minimal/tailwind/components/seek.js.map +1 -0
  194. package/dist/default/skins/dist/default/minimal/tailwind/components/slider.js +20 -0
  195. package/dist/default/skins/dist/default/minimal/tailwind/components/slider.js.map +1 -0
  196. package/dist/default/skins/dist/default/minimal/tailwind/components/time.js +14 -0
  197. package/dist/default/skins/dist/default/minimal/tailwind/components/time.js.map +1 -0
  198. package/dist/default/skins/dist/default/minimal/tailwind/components/tooltip-state.js +28 -0
  199. package/dist/default/skins/dist/default/minimal/tailwind/components/tooltip-state.js.map +1 -0
  200. package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js +44 -0
  201. package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -0
  202. package/dist/default/store/container-mixin.js +95 -0
  203. package/dist/default/store/container-mixin.js.map +1 -0
  204. package/dist/default/store/provider-mixin.js +39 -0
  205. package/dist/default/store/provider-mixin.js.map +1 -0
  206. package/dist/default/ui/alert-dialog/alert-dialog-close-element.js +46 -0
  207. package/dist/default/ui/alert-dialog/alert-dialog-close-element.js.map +1 -0
  208. package/dist/default/ui/alert-dialog/alert-dialog-description-element.js +26 -0
  209. package/dist/default/ui/alert-dialog/alert-dialog-description-element.js.map +1 -0
  210. package/dist/default/ui/alert-dialog/alert-dialog-element.js +73 -0
  211. package/dist/default/ui/alert-dialog/alert-dialog-element.js.map +1 -0
  212. package/dist/default/ui/alert-dialog/alert-dialog-title-element.js +26 -0
  213. package/dist/default/ui/alert-dialog/alert-dialog-title-element.js.map +1 -0
  214. package/dist/default/ui/alert-dialog/context.js +9 -0
  215. package/dist/default/ui/alert-dialog/context.js.map +1 -0
  216. package/dist/default/ui/buffering-indicator/buffering-indicator-element.js +47 -0
  217. package/dist/default/ui/buffering-indicator/buffering-indicator-element.js.map +1 -0
  218. package/dist/default/ui/captions-button/captions-button-element.js +25 -0
  219. package/dist/default/ui/captions-button/captions-button-element.js.map +1 -0
  220. package/dist/default/ui/context-part-element.js +28 -0
  221. package/dist/default/ui/context-part-element.js.map +1 -0
  222. package/dist/default/ui/controls/context.js +9 -0
  223. package/dist/default/ui/controls/context.js.map +1 -0
  224. package/dist/default/ui/controls/controls-element.js +36 -0
  225. package/dist/default/ui/controls/controls-element.js.map +1 -0
  226. package/dist/default/ui/controls/controls-group-element.js +25 -0
  227. package/dist/default/ui/controls/controls-group-element.js.map +1 -0
  228. package/dist/default/ui/fullscreen-button/fullscreen-button-element.js +25 -0
  229. package/dist/default/ui/fullscreen-button/fullscreen-button-element.js.map +1 -0
  230. package/dist/default/ui/media-button-element.js +50 -0
  231. package/dist/default/ui/media-button-element.js.map +1 -0
  232. package/dist/default/ui/media-element.js +9 -0
  233. package/dist/default/ui/media-element.js.map +1 -0
  234. package/dist/default/ui/media-ui-element.js +22 -0
  235. package/dist/default/ui/media-ui-element.js.map +1 -0
  236. package/dist/default/ui/mute-button/mute-button-element.js +25 -0
  237. package/dist/default/ui/mute-button/mute-button-element.js.map +1 -0
  238. package/dist/default/ui/pip-button/pip-button-element.js +25 -0
  239. package/dist/default/ui/pip-button/pip-button-element.js.map +1 -0
  240. package/dist/default/ui/play-button/play-button-element.js +25 -0
  241. package/dist/default/ui/play-button/play-button-element.js.map +1 -0
  242. package/dist/default/ui/playback-rate-button/playback-rate-button-element.js +25 -0
  243. package/dist/default/ui/playback-rate-button/playback-rate-button-element.js.map +1 -0
  244. package/dist/default/ui/popover/popover-element.js +168 -0
  245. package/dist/default/ui/popover/popover-element.js.map +1 -0
  246. package/dist/default/ui/poster/poster-element.js +22 -0
  247. package/dist/default/ui/poster/poster-element.js.map +1 -0
  248. package/dist/default/ui/seek-button/seek-button-element.js +32 -0
  249. package/dist/default/ui/seek-button/seek-button-element.js.map +1 -0
  250. package/dist/default/ui/slider/context.js +9 -0
  251. package/dist/default/ui/slider/context.js.map +1 -0
  252. package/dist/default/ui/slider/slider-buffer-element.js +21 -0
  253. package/dist/default/ui/slider/slider-buffer-element.js.map +1 -0
  254. package/dist/default/ui/slider/slider-element.js +122 -0
  255. package/dist/default/ui/slider/slider-element.js.map +1 -0
  256. package/dist/default/ui/slider/slider-fill-element.js +21 -0
  257. package/dist/default/ui/slider/slider-fill-element.js.map +1 -0
  258. package/dist/default/ui/slider/slider-preview-element.js +51 -0
  259. package/dist/default/ui/slider/slider-preview-element.js.map +1 -0
  260. package/dist/default/ui/slider/slider-thumb-element.js +43 -0
  261. package/dist/default/ui/slider/slider-thumb-element.js.map +1 -0
  262. package/dist/default/ui/slider/slider-thumbnail-element.js +23 -0
  263. package/dist/default/ui/slider/slider-thumbnail-element.js.map +1 -0
  264. package/dist/default/ui/slider/slider-track-element.js +21 -0
  265. package/dist/default/ui/slider/slider-track-element.js.map +1 -0
  266. package/dist/default/ui/slider/slider-value-element.js +38 -0
  267. package/dist/default/ui/slider/slider-value-element.js.map +1 -0
  268. package/dist/default/ui/thumbnail/thumbnail-element.js +139 -0
  269. package/dist/default/ui/thumbnail/thumbnail-element.js.map +1 -0
  270. package/dist/default/ui/time/time-element.js +59 -0
  271. package/dist/default/ui/time/time-element.js.map +1 -0
  272. package/dist/default/ui/time/time-group-element.js +12 -0
  273. package/dist/default/ui/time/time-group-element.js.map +1 -0
  274. package/dist/default/ui/time/time-separator-element.js +17 -0
  275. package/dist/default/ui/time/time-separator-element.js.map +1 -0
  276. package/dist/default/ui/time-slider/time-slider-element.js +133 -0
  277. package/dist/default/ui/time-slider/time-slider-element.js.map +1 -0
  278. package/dist/default/ui/tooltip/context.js +9 -0
  279. package/dist/default/ui/tooltip/context.js.map +1 -0
  280. package/dist/default/ui/tooltip/tooltip-element.js +154 -0
  281. package/dist/default/ui/tooltip/tooltip-element.js.map +1 -0
  282. package/dist/default/ui/tooltip/tooltip-group-element.js +38 -0
  283. package/dist/default/ui/tooltip/tooltip-group-element.js.map +1 -0
  284. package/dist/default/ui/volume-slider/volume-slider-element.js +122 -0
  285. package/dist/default/ui/volume-slider/volume-slider-element.js.map +1 -0
  286. package/dist/dev/_virtual/inline-css_src/define/audio/minimal-skin.js +6 -0
  287. package/dist/dev/_virtual/inline-css_src/define/audio/minimal-skin.js.map +1 -0
  288. package/dist/dev/_virtual/inline-css_src/define/audio/skin.js +6 -0
  289. package/dist/dev/_virtual/inline-css_src/define/audio/skin.js.map +1 -0
  290. package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js +6 -0
  291. package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -0
  292. package/dist/dev/_virtual/inline-css_src/define/video/skin.js +6 -0
  293. package/dist/dev/_virtual/inline-css_src/define/video/skin.js.map +1 -0
  294. package/dist/dev/define/audio/minimal-skin.css +636 -0
  295. package/dist/dev/define/audio/minimal-skin.d.ts +21 -0
  296. package/dist/dev/define/audio/minimal-skin.d.ts.map +1 -0
  297. package/dist/dev/define/audio/minimal-skin.js +114 -0
  298. package/dist/dev/define/audio/minimal-skin.js.map +1 -0
  299. package/dist/dev/define/audio/minimal-skin.tailwind.d.ts +20 -0
  300. package/dist/dev/define/audio/minimal-skin.tailwind.d.ts.map +1 -0
  301. package/dist/dev/define/audio/minimal-skin.tailwind.js +121 -0
  302. package/dist/dev/define/audio/minimal-skin.tailwind.js.map +1 -0
  303. package/dist/dev/define/audio/player.d.ts +17 -0
  304. package/dist/dev/define/audio/player.d.ts.map +1 -0
  305. package/dist/dev/define/audio/player.js +19 -0
  306. package/dist/dev/define/audio/player.js.map +1 -0
  307. package/dist/dev/define/audio/skin.css +661 -0
  308. package/dist/dev/define/audio/skin.d.ts +21 -0
  309. package/dist/dev/define/audio/skin.d.ts.map +1 -0
  310. package/dist/dev/define/audio/skin.js +105 -0
  311. package/dist/dev/define/audio/skin.js.map +1 -0
  312. package/dist/dev/define/audio/skin.tailwind.d.ts +20 -0
  313. package/dist/dev/define/audio/skin.tailwind.d.ts.map +1 -0
  314. package/dist/dev/define/audio/skin.tailwind.js +111 -0
  315. package/dist/dev/define/audio/skin.tailwind.js.map +1 -0
  316. package/dist/dev/define/background/player.d.ts +17 -0
  317. package/dist/dev/define/background/player.d.ts.map +1 -0
  318. package/dist/dev/define/background/player.js +19 -0
  319. package/dist/dev/define/background/player.js.map +1 -0
  320. package/dist/dev/define/background/skin.css +27 -0
  321. package/dist/dev/define/background/skin.d.ts +20 -0
  322. package/dist/dev/define/background/skin.d.ts.map +1 -0
  323. package/dist/dev/define/background/skin.js +35 -0
  324. package/dist/dev/define/background/skin.js.map +1 -0
  325. package/dist/dev/define/background/video.d.ts +2 -0
  326. package/dist/dev/define/background/video.js +3 -0
  327. package/dist/dev/define/feature/video.js +0 -0
  328. package/dist/dev/define/media/background-video.d.ts +14 -0
  329. package/dist/dev/define/media/background-video.d.ts.map +1 -0
  330. package/dist/dev/define/media/background-video.js +14 -0
  331. package/dist/dev/define/media/background-video.js.map +1 -0
  332. package/dist/dev/define/media/container.d.ts +9 -0
  333. package/dist/dev/define/media/container.d.ts.map +1 -0
  334. package/dist/dev/define/media/container.js +8 -0
  335. package/dist/dev/define/media/container.js.map +1 -0
  336. package/dist/dev/define/media/hls-video.d.ts +14 -0
  337. package/dist/dev/define/media/hls-video.d.ts.map +1 -0
  338. package/dist/dev/define/media/hls-video.js +14 -0
  339. package/dist/dev/define/media/hls-video.js.map +1 -0
  340. package/dist/dev/define/media/simple-hls-video.d.ts +14 -0
  341. package/dist/dev/define/media/simple-hls-video.d.ts.map +1 -0
  342. package/dist/dev/define/media/simple-hls-video.js +13 -0
  343. package/dist/dev/define/media/simple-hls-video.js.map +1 -0
  344. package/dist/dev/define/safe-define.d.ts +9 -0
  345. package/dist/dev/define/safe-define.d.ts.map +1 -0
  346. package/dist/dev/define/safe-define.js +9 -0
  347. package/dist/dev/define/safe-define.js.map +1 -0
  348. package/dist/dev/define/skin-mixin.d.ts +21 -0
  349. package/dist/dev/define/skin-mixin.d.ts.map +1 -0
  350. package/dist/dev/define/skin-mixin.js +69 -0
  351. package/dist/dev/define/skin-mixin.js.map +1 -0
  352. package/dist/dev/define/ui/alert-dialog-close.d.ts +9 -0
  353. package/dist/dev/define/ui/alert-dialog-close.d.ts.map +1 -0
  354. package/dist/dev/define/ui/alert-dialog-close.js +8 -0
  355. package/dist/dev/define/ui/alert-dialog-close.js.map +1 -0
  356. package/dist/dev/define/ui/alert-dialog-description.d.ts +9 -0
  357. package/dist/dev/define/ui/alert-dialog-description.d.ts.map +1 -0
  358. package/dist/dev/define/ui/alert-dialog-description.js +8 -0
  359. package/dist/dev/define/ui/alert-dialog-description.js.map +1 -0
  360. package/dist/dev/define/ui/alert-dialog-title.d.ts +9 -0
  361. package/dist/dev/define/ui/alert-dialog-title.d.ts.map +1 -0
  362. package/dist/dev/define/ui/alert-dialog-title.js +8 -0
  363. package/dist/dev/define/ui/alert-dialog-title.js.map +1 -0
  364. package/dist/dev/define/ui/alert-dialog.d.ts +15 -0
  365. package/dist/dev/define/ui/alert-dialog.d.ts.map +1 -0
  366. package/dist/dev/define/ui/alert-dialog.js +14 -0
  367. package/dist/dev/define/ui/alert-dialog.js.map +1 -0
  368. package/dist/dev/define/ui/buffering-indicator.d.ts +9 -0
  369. package/dist/dev/define/ui/buffering-indicator.d.ts.map +1 -0
  370. package/dist/dev/define/ui/buffering-indicator.js +8 -0
  371. package/dist/dev/define/ui/buffering-indicator.js.map +1 -0
  372. package/dist/dev/define/ui/captions-button.d.ts +9 -0
  373. package/dist/dev/define/ui/captions-button.d.ts.map +1 -0
  374. package/dist/dev/define/ui/captions-button.js +7 -0
  375. package/dist/dev/define/ui/captions-button.js.map +1 -0
  376. package/dist/dev/define/ui/controls-group.d.ts +9 -0
  377. package/dist/dev/define/ui/controls-group.d.ts.map +1 -0
  378. package/dist/dev/define/ui/controls-group.js +8 -0
  379. package/dist/dev/define/ui/controls-group.js.map +1 -0
  380. package/dist/dev/define/ui/controls.d.ts +9 -0
  381. package/dist/dev/define/ui/controls.d.ts.map +1 -0
  382. package/dist/dev/define/ui/controls.js +10 -0
  383. package/dist/dev/define/ui/controls.js.map +1 -0
  384. package/dist/dev/define/ui/fullscreen-button.d.ts +9 -0
  385. package/dist/dev/define/ui/fullscreen-button.d.ts.map +1 -0
  386. package/dist/dev/define/ui/fullscreen-button.js +8 -0
  387. package/dist/dev/define/ui/fullscreen-button.js.map +1 -0
  388. package/dist/dev/define/ui/mute-button.d.ts +9 -0
  389. package/dist/dev/define/ui/mute-button.d.ts.map +1 -0
  390. package/dist/dev/define/ui/mute-button.js +8 -0
  391. package/dist/dev/define/ui/mute-button.js.map +1 -0
  392. package/dist/dev/define/ui/pip-button.d.ts +9 -0
  393. package/dist/dev/define/ui/pip-button.d.ts.map +1 -0
  394. package/dist/dev/define/ui/pip-button.js +8 -0
  395. package/dist/dev/define/ui/pip-button.js.map +1 -0
  396. package/dist/dev/define/ui/play-button.d.ts +9 -0
  397. package/dist/dev/define/ui/play-button.d.ts.map +1 -0
  398. package/dist/dev/define/ui/play-button.js +8 -0
  399. package/dist/dev/define/ui/play-button.js.map +1 -0
  400. package/dist/dev/define/ui/playback-rate-button.d.ts +9 -0
  401. package/dist/dev/define/ui/playback-rate-button.d.ts.map +1 -0
  402. package/dist/dev/define/ui/playback-rate-button.js +8 -0
  403. package/dist/dev/define/ui/playback-rate-button.js.map +1 -0
  404. package/dist/dev/define/ui/popover.d.ts +9 -0
  405. package/dist/dev/define/ui/popover.d.ts.map +1 -0
  406. package/dist/dev/define/ui/popover.js +8 -0
  407. package/dist/dev/define/ui/popover.js.map +1 -0
  408. package/dist/dev/define/ui/poster.d.ts +9 -0
  409. package/dist/dev/define/ui/poster.d.ts.map +1 -0
  410. package/dist/dev/define/ui/poster.js +8 -0
  411. package/dist/dev/define/ui/poster.js.map +1 -0
  412. package/dist/dev/define/ui/seek-button.d.ts +9 -0
  413. package/dist/dev/define/ui/seek-button.d.ts.map +1 -0
  414. package/dist/dev/define/ui/seek-button.js +8 -0
  415. package/dist/dev/define/ui/seek-button.js.map +1 -0
  416. package/dist/dev/define/ui/slider-buffer.d.ts +9 -0
  417. package/dist/dev/define/ui/slider-buffer.d.ts.map +1 -0
  418. package/dist/dev/define/ui/slider-buffer.js +8 -0
  419. package/dist/dev/define/ui/slider-buffer.js.map +1 -0
  420. package/dist/dev/define/ui/slider-fill.d.ts +9 -0
  421. package/dist/dev/define/ui/slider-fill.d.ts.map +1 -0
  422. package/dist/dev/define/ui/slider-fill.js +8 -0
  423. package/dist/dev/define/ui/slider-fill.js.map +1 -0
  424. package/dist/dev/define/ui/slider-thumb.d.ts +9 -0
  425. package/dist/dev/define/ui/slider-thumb.d.ts.map +1 -0
  426. package/dist/dev/define/ui/slider-thumb.js +8 -0
  427. package/dist/dev/define/ui/slider-thumb.js.map +1 -0
  428. package/dist/dev/define/ui/slider-thumbnail.d.ts +9 -0
  429. package/dist/dev/define/ui/slider-thumbnail.d.ts.map +1 -0
  430. package/dist/dev/define/ui/slider-thumbnail.js +8 -0
  431. package/dist/dev/define/ui/slider-thumbnail.js.map +1 -0
  432. package/dist/dev/define/ui/slider-track.d.ts +9 -0
  433. package/dist/dev/define/ui/slider-track.d.ts.map +1 -0
  434. package/dist/dev/define/ui/slider-track.js +8 -0
  435. package/dist/dev/define/ui/slider-track.js.map +1 -0
  436. package/dist/dev/define/ui/slider-value.d.ts +9 -0
  437. package/dist/dev/define/ui/slider-value.d.ts.map +1 -0
  438. package/dist/dev/define/ui/slider-value.js +8 -0
  439. package/dist/dev/define/ui/slider-value.js.map +1 -0
  440. package/dist/dev/define/ui/slider.d.ts +9 -0
  441. package/dist/dev/define/ui/slider.d.ts.map +1 -0
  442. package/dist/dev/define/ui/slider.js +18 -0
  443. package/dist/dev/define/ui/slider.js.map +1 -0
  444. package/dist/dev/define/ui/thumbnail.d.ts +9 -0
  445. package/dist/dev/define/ui/thumbnail.d.ts.map +1 -0
  446. package/dist/dev/define/ui/thumbnail.js +8 -0
  447. package/dist/dev/define/ui/thumbnail.js.map +1 -0
  448. package/dist/dev/define/ui/time-group.d.ts +9 -0
  449. package/dist/dev/define/ui/time-group.d.ts.map +1 -0
  450. package/dist/dev/define/ui/time-group.js +8 -0
  451. package/dist/dev/define/ui/time-group.js.map +1 -0
  452. package/dist/dev/define/ui/time-separator.d.ts +9 -0
  453. package/dist/dev/define/ui/time-separator.d.ts.map +1 -0
  454. package/dist/dev/define/ui/time-separator.js +8 -0
  455. package/dist/dev/define/ui/time-separator.js.map +1 -0
  456. package/dist/dev/define/ui/time-slider.d.ts +9 -0
  457. package/dist/dev/define/ui/time-slider.d.ts.map +1 -0
  458. package/dist/dev/define/ui/time-slider.js +22 -0
  459. package/dist/dev/define/ui/time-slider.js.map +1 -0
  460. package/dist/dev/define/ui/time.d.ts +9 -0
  461. package/dist/dev/define/ui/time.d.ts.map +1 -0
  462. package/dist/dev/define/ui/time.js +12 -0
  463. package/dist/dev/define/ui/time.js.map +1 -0
  464. package/dist/dev/define/ui/tooltip-group.d.ts +9 -0
  465. package/dist/dev/define/ui/tooltip-group.d.ts.map +1 -0
  466. package/dist/dev/define/ui/tooltip-group.js +8 -0
  467. package/dist/dev/define/ui/tooltip-group.js.map +1 -0
  468. package/dist/dev/define/ui/tooltip.d.ts +9 -0
  469. package/dist/dev/define/ui/tooltip.d.ts.map +1 -0
  470. package/dist/dev/define/ui/tooltip.js +8 -0
  471. package/dist/dev/define/ui/tooltip.js.map +1 -0
  472. package/dist/dev/define/ui/volume-slider.d.ts +9 -0
  473. package/dist/dev/define/ui/volume-slider.d.ts.map +1 -0
  474. package/dist/dev/define/ui/volume-slider.js +18 -0
  475. package/dist/dev/define/ui/volume-slider.js.map +1 -0
  476. package/dist/dev/define/video/minimal-skin.css +873 -0
  477. package/dist/dev/define/video/minimal-skin.d.ts +21 -0
  478. package/dist/dev/define/video/minimal-skin.d.ts.map +1 -0
  479. package/dist/dev/define/video/minimal-skin.js +160 -0
  480. package/dist/dev/define/video/minimal-skin.js.map +1 -0
  481. package/dist/dev/define/video/minimal-skin.tailwind.d.ts +20 -0
  482. package/dist/dev/define/video/minimal-skin.tailwind.d.ts.map +1 -0
  483. package/dist/dev/define/video/minimal-skin.tailwind.js +180 -0
  484. package/dist/dev/define/video/minimal-skin.tailwind.js.map +1 -0
  485. package/dist/dev/define/video/player.d.ts +17 -0
  486. package/dist/dev/define/video/player.d.ts.map +1 -0
  487. package/dist/dev/define/video/player.js +19 -0
  488. package/dist/dev/define/video/player.js.map +1 -0
  489. package/dist/dev/define/video/skin.css +878 -0
  490. package/dist/dev/define/video/skin.d.ts +21 -0
  491. package/dist/dev/define/video/skin.d.ts.map +1 -0
  492. package/dist/dev/define/video/skin.js +156 -0
  493. package/dist/dev/define/video/skin.js.map +1 -0
  494. package/dist/dev/define/video/skin.tailwind.d.ts +20 -0
  495. package/dist/dev/define/video/skin.tailwind.d.ts.map +1 -0
  496. package/dist/dev/define/video/skin.tailwind.js +170 -0
  497. package/dist/dev/define/video/skin.tailwind.js.map +1 -0
  498. package/dist/dev/icons/dist/render/default/index.js +27 -0
  499. package/dist/dev/icons/dist/render/default/index.js.map +1 -0
  500. package/dist/dev/icons/dist/render/minimal/index.js +27 -0
  501. package/dist/dev/icons/dist/render/minimal/index.js.map +1 -0
  502. package/dist/dev/index.d.ts +48 -0
  503. package/dist/dev/index.js +48 -0
  504. package/dist/dev/media/background-video/index.d.ts +15 -0
  505. package/dist/dev/media/background-video/index.d.ts.map +1 -0
  506. package/dist/dev/media/background-video/index.js +83 -0
  507. package/dist/dev/media/background-video/index.js.map +1 -0
  508. package/dist/dev/media/container-element.d.ts +12 -0
  509. package/dist/dev/media/container-element.d.ts.map +1 -0
  510. package/dist/dev/media/container-element.js +15 -0
  511. package/dist/dev/media/container-element.js.map +1 -0
  512. package/dist/dev/media/hls-video/index.d.ts +12 -0
  513. package/dist/dev/media/hls-video/index.d.ts.map +1 -0
  514. package/dist/dev/media/hls-video/index.js +25 -0
  515. package/dist/dev/media/hls-video/index.js.map +1 -0
  516. package/dist/dev/media/simple-hls-video/index.d.ts +11 -0
  517. package/dist/dev/media/simple-hls-video/index.d.ts.map +1 -0
  518. package/dist/dev/media/simple-hls-video/index.js +21 -0
  519. package/dist/dev/media/simple-hls-video/index.js.map +1 -0
  520. package/dist/dev/player/context.d.ts +16 -0
  521. package/dist/dev/player/context.d.ts.map +1 -0
  522. package/dist/dev/player/context.js +14 -0
  523. package/dist/dev/player/context.js.map +1 -0
  524. package/dist/dev/player/create-player.d.ts +65 -0
  525. package/dist/dev/player/create-player.d.ts.map +1 -0
  526. package/dist/dev/player/create-player.js +24 -0
  527. package/dist/dev/player/create-player.js.map +1 -0
  528. package/dist/dev/player/player-controller.d.ts +57 -0
  529. package/dist/dev/player/player-controller.d.ts.map +1 -0
  530. package/dist/dev/player/player-controller.js +66 -0
  531. package/dist/dev/player/player-controller.js.map +1 -0
  532. package/dist/dev/presets/audio.d.ts +6 -0
  533. package/dist/dev/presets/audio.js +7 -0
  534. package/dist/dev/presets/background.d.ts +2 -0
  535. package/dist/dev/presets/background.js +3 -0
  536. package/dist/dev/presets/video.d.ts +6 -0
  537. package/dist/dev/presets/video.js +7 -0
  538. package/dist/dev/skins/dist/default/default/tailwind/audio.tailwind.js +58 -0
  539. package/dist/dev/skins/dist/default/default/tailwind/audio.tailwind.js.map +1 -0
  540. package/dist/dev/skins/dist/default/default/tailwind/components/buffering.js +9 -0
  541. package/dist/dev/skins/dist/default/default/tailwind/components/buffering.js.map +1 -0
  542. package/dist/dev/skins/dist/default/default/tailwind/components/button.js +12 -0
  543. package/dist/dev/skins/dist/default/default/tailwind/components/button.js.map +1 -0
  544. package/dist/dev/skins/dist/default/default/tailwind/components/controls.js +8 -0
  545. package/dist/dev/skins/dist/default/default/tailwind/components/controls.js.map +1 -0
  546. package/dist/dev/skins/dist/default/default/tailwind/components/error.js +15 -0
  547. package/dist/dev/skins/dist/default/default/tailwind/components/error.js.map +1 -0
  548. package/dist/dev/skins/dist/default/default/tailwind/components/icon-state.js +29 -0
  549. package/dist/dev/skins/dist/default/default/tailwind/components/icon-state.js.map +1 -0
  550. package/dist/dev/skins/dist/default/default/tailwind/components/icon.js +10 -0
  551. package/dist/dev/skins/dist/default/default/tailwind/components/icon.js.map +1 -0
  552. package/dist/dev/skins/dist/default/default/tailwind/components/overlay.js +8 -0
  553. package/dist/dev/skins/dist/default/default/tailwind/components/overlay.js.map +1 -0
  554. package/dist/dev/skins/dist/default/default/tailwind/components/playback-rate.js +6 -0
  555. package/dist/dev/skins/dist/default/default/tailwind/components/playback-rate.js.map +1 -0
  556. package/dist/dev/skins/dist/default/default/tailwind/components/popup.js +13 -0
  557. package/dist/dev/skins/dist/default/default/tailwind/components/popup.js.map +1 -0
  558. package/dist/dev/skins/dist/default/default/tailwind/components/root.js +8 -0
  559. package/dist/dev/skins/dist/default/default/tailwind/components/root.js.map +1 -0
  560. package/dist/dev/skins/dist/default/default/tailwind/components/seek.js +11 -0
  561. package/dist/dev/skins/dist/default/default/tailwind/components/seek.js.map +1 -0
  562. package/dist/dev/skins/dist/default/default/tailwind/components/slider.js +21 -0
  563. package/dist/dev/skins/dist/default/default/tailwind/components/slider.js.map +1 -0
  564. package/dist/dev/skins/dist/default/default/tailwind/components/surface.js +8 -0
  565. package/dist/dev/skins/dist/default/default/tailwind/components/surface.js.map +1 -0
  566. package/dist/dev/skins/dist/default/default/tailwind/components/time.js +10 -0
  567. package/dist/dev/skins/dist/default/default/tailwind/components/time.js.map +1 -0
  568. package/dist/dev/skins/dist/default/default/tailwind/components/tooltip-state.js +28 -0
  569. package/dist/dev/skins/dist/default/default/tailwind/components/tooltip-state.js.map +1 -0
  570. package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js +55 -0
  571. package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -0
  572. package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js +44 -0
  573. package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -0
  574. package/dist/dev/skins/dist/default/minimal/tailwind/components/buffering.js +6 -0
  575. package/dist/dev/skins/dist/default/minimal/tailwind/components/buffering.js.map +1 -0
  576. package/dist/dev/skins/dist/default/minimal/tailwind/components/button-group.js +8 -0
  577. package/dist/dev/skins/dist/default/minimal/tailwind/components/button-group.js.map +1 -0
  578. package/dist/dev/skins/dist/default/minimal/tailwind/components/button.js +12 -0
  579. package/dist/dev/skins/dist/default/minimal/tailwind/components/button.js.map +1 -0
  580. package/dist/dev/skins/dist/default/minimal/tailwind/components/controls.js +8 -0
  581. package/dist/dev/skins/dist/default/minimal/tailwind/components/controls.js.map +1 -0
  582. package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js +15 -0
  583. package/dist/dev/skins/dist/default/minimal/tailwind/components/error.js.map +1 -0
  584. package/dist/dev/skins/dist/default/minimal/tailwind/components/icon-state.js +29 -0
  585. package/dist/dev/skins/dist/default/minimal/tailwind/components/icon-state.js.map +1 -0
  586. package/dist/dev/skins/dist/default/minimal/tailwind/components/icon.js +10 -0
  587. package/dist/dev/skins/dist/default/minimal/tailwind/components/icon.js.map +1 -0
  588. package/dist/dev/skins/dist/default/minimal/tailwind/components/overlay.js +8 -0
  589. package/dist/dev/skins/dist/default/minimal/tailwind/components/overlay.js.map +1 -0
  590. package/dist/dev/skins/dist/default/minimal/tailwind/components/popup.js +12 -0
  591. package/dist/dev/skins/dist/default/minimal/tailwind/components/popup.js.map +1 -0
  592. package/dist/dev/skins/dist/default/minimal/tailwind/components/root.js +8 -0
  593. package/dist/dev/skins/dist/default/minimal/tailwind/components/root.js.map +1 -0
  594. package/dist/dev/skins/dist/default/minimal/tailwind/components/seek.js +11 -0
  595. package/dist/dev/skins/dist/default/minimal/tailwind/components/seek.js.map +1 -0
  596. package/dist/dev/skins/dist/default/minimal/tailwind/components/slider.js +20 -0
  597. package/dist/dev/skins/dist/default/minimal/tailwind/components/slider.js.map +1 -0
  598. package/dist/dev/skins/dist/default/minimal/tailwind/components/time.js +14 -0
  599. package/dist/dev/skins/dist/default/minimal/tailwind/components/time.js.map +1 -0
  600. package/dist/dev/skins/dist/default/minimal/tailwind/components/tooltip-state.js +28 -0
  601. package/dist/dev/skins/dist/default/minimal/tailwind/components/tooltip-state.js.map +1 -0
  602. package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js +44 -0
  603. package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -0
  604. package/dist/dev/store/container-mixin.d.ts +16 -0
  605. package/dist/dev/store/container-mixin.d.ts.map +1 -0
  606. package/dist/dev/store/container-mixin.js +95 -0
  607. package/dist/dev/store/container-mixin.js.map +1 -0
  608. package/dist/dev/store/provider-mixin.d.ts +17 -0
  609. package/dist/dev/store/provider-mixin.d.ts.map +1 -0
  610. package/dist/dev/store/provider-mixin.js +39 -0
  611. package/dist/dev/store/provider-mixin.js.map +1 -0
  612. package/dist/dev/store/types.d.ts +16 -0
  613. package/dist/dev/store/types.d.ts.map +1 -0
  614. package/dist/dev/ui/alert-dialog/alert-dialog-close-element.d.ts +20 -0
  615. package/dist/dev/ui/alert-dialog/alert-dialog-close-element.d.ts.map +1 -0
  616. package/dist/dev/ui/alert-dialog/alert-dialog-close-element.js +46 -0
  617. package/dist/dev/ui/alert-dialog/alert-dialog-close-element.js.map +1 -0
  618. package/dist/dev/ui/alert-dialog/alert-dialog-description-element.d.ts +17 -0
  619. package/dist/dev/ui/alert-dialog/alert-dialog-description-element.d.ts.map +1 -0
  620. package/dist/dev/ui/alert-dialog/alert-dialog-description-element.js +26 -0
  621. package/dist/dev/ui/alert-dialog/alert-dialog-description-element.js.map +1 -0
  622. package/dist/dev/ui/alert-dialog/alert-dialog-element.d.ts +22 -0
  623. package/dist/dev/ui/alert-dialog/alert-dialog-element.d.ts.map +1 -0
  624. package/dist/dev/ui/alert-dialog/alert-dialog-element.js +73 -0
  625. package/dist/dev/ui/alert-dialog/alert-dialog-element.js.map +1 -0
  626. package/dist/dev/ui/alert-dialog/alert-dialog-title-element.d.ts +17 -0
  627. package/dist/dev/ui/alert-dialog/alert-dialog-title-element.d.ts.map +1 -0
  628. package/dist/dev/ui/alert-dialog/alert-dialog-title-element.js +26 -0
  629. package/dist/dev/ui/alert-dialog/alert-dialog-title-element.js.map +1 -0
  630. package/dist/dev/ui/alert-dialog/context.d.ts +14 -0
  631. package/dist/dev/ui/alert-dialog/context.d.ts.map +1 -0
  632. package/dist/dev/ui/alert-dialog/context.js +9 -0
  633. package/dist/dev/ui/alert-dialog/context.js.map +1 -0
  634. package/dist/dev/ui/buffering-indicator/buffering-indicator-element.d.ts +21 -0
  635. package/dist/dev/ui/buffering-indicator/buffering-indicator-element.d.ts.map +1 -0
  636. package/dist/dev/ui/buffering-indicator/buffering-indicator-element.js +48 -0
  637. package/dist/dev/ui/buffering-indicator/buffering-indicator-element.js.map +1 -0
  638. package/dist/dev/ui/captions-button/captions-button-element.d.ts +19 -0
  639. package/dist/dev/ui/captions-button/captions-button-element.d.ts.map +1 -0
  640. package/dist/dev/ui/captions-button/captions-button-element.js +25 -0
  641. package/dist/dev/ui/captions-button/captions-button-element.js.map +1 -0
  642. package/dist/dev/ui/context-part-element.d.ts +32 -0
  643. package/dist/dev/ui/context-part-element.d.ts.map +1 -0
  644. package/dist/dev/ui/context-part-element.js +28 -0
  645. package/dist/dev/ui/context-part-element.js.map +1 -0
  646. package/dist/dev/ui/controls/context.d.ts +10 -0
  647. package/dist/dev/ui/controls/context.d.ts.map +1 -0
  648. package/dist/dev/ui/controls/context.js +9 -0
  649. package/dist/dev/ui/controls/context.js.map +1 -0
  650. package/dist/dev/ui/controls/controls-element.d.ts +13 -0
  651. package/dist/dev/ui/controls/controls-element.d.ts.map +1 -0
  652. package/dist/dev/ui/controls/controls-element.js +37 -0
  653. package/dist/dev/ui/controls/controls-element.js.map +1 -0
  654. package/dist/dev/ui/controls/controls-group-element.d.ts +16 -0
  655. package/dist/dev/ui/controls/controls-group-element.d.ts.map +1 -0
  656. package/dist/dev/ui/controls/controls-group-element.js +25 -0
  657. package/dist/dev/ui/controls/controls-group-element.js.map +1 -0
  658. package/dist/dev/ui/fullscreen-button/fullscreen-button-element.d.ts +19 -0
  659. package/dist/dev/ui/fullscreen-button/fullscreen-button-element.d.ts.map +1 -0
  660. package/dist/dev/ui/fullscreen-button/fullscreen-button-element.js +25 -0
  661. package/dist/dev/ui/fullscreen-button/fullscreen-button-element.js.map +1 -0
  662. package/dist/dev/ui/media-button-element.d.ts +24 -0
  663. package/dist/dev/ui/media-button-element.d.ts.map +1 -0
  664. package/dist/dev/ui/media-button-element.js +51 -0
  665. package/dist/dev/ui/media-button-element.js.map +1 -0
  666. package/dist/dev/ui/media-element.d.ts +12 -0
  667. package/dist/dev/ui/media-element.d.ts.map +1 -0
  668. package/dist/dev/ui/media-element.js +9 -0
  669. package/dist/dev/ui/media-element.js.map +1 -0
  670. package/dist/dev/ui/media-ui-element.d.ts +17 -0
  671. package/dist/dev/ui/media-ui-element.d.ts.map +1 -0
  672. package/dist/dev/ui/media-ui-element.js +23 -0
  673. package/dist/dev/ui/media-ui-element.js.map +1 -0
  674. package/dist/dev/ui/mute-button/mute-button-element.d.ts +19 -0
  675. package/dist/dev/ui/mute-button/mute-button-element.d.ts.map +1 -0
  676. package/dist/dev/ui/mute-button/mute-button-element.js +25 -0
  677. package/dist/dev/ui/mute-button/mute-button-element.js.map +1 -0
  678. package/dist/dev/ui/pip-button/pip-button-element.d.ts +19 -0
  679. package/dist/dev/ui/pip-button/pip-button-element.d.ts.map +1 -0
  680. package/dist/dev/ui/pip-button/pip-button-element.js +25 -0
  681. package/dist/dev/ui/pip-button/pip-button-element.js.map +1 -0
  682. package/dist/dev/ui/play-button/play-button-element.d.ts +20 -0
  683. package/dist/dev/ui/play-button/play-button-element.d.ts.map +1 -0
  684. package/dist/dev/ui/play-button/play-button-element.js +25 -0
  685. package/dist/dev/ui/play-button/play-button-element.js.map +1 -0
  686. package/dist/dev/ui/playback-rate-button/playback-rate-button-element.d.ts +18 -0
  687. package/dist/dev/ui/playback-rate-button/playback-rate-button-element.d.ts.map +1 -0
  688. package/dist/dev/ui/playback-rate-button/playback-rate-button-element.js +25 -0
  689. package/dist/dev/ui/playback-rate-button/playback-rate-button-element.js.map +1 -0
  690. package/dist/dev/ui/popover/popover-element.d.ts +66 -0
  691. package/dist/dev/ui/popover/popover-element.d.ts.map +1 -0
  692. package/dist/dev/ui/popover/popover-element.js +168 -0
  693. package/dist/dev/ui/popover/popover-element.js.map +1 -0
  694. package/dist/dev/ui/poster/poster-element.d.ts +18 -0
  695. package/dist/dev/ui/poster/poster-element.d.ts.map +1 -0
  696. package/dist/dev/ui/poster/poster-element.js +22 -0
  697. package/dist/dev/ui/poster/poster-element.js.map +1 -0
  698. package/dist/dev/ui/seek-button/seek-button-element.d.ts +22 -0
  699. package/dist/dev/ui/seek-button/seek-button-element.d.ts.map +1 -0
  700. package/dist/dev/ui/seek-button/seek-button-element.js +32 -0
  701. package/dist/dev/ui/seek-button/seek-button-element.js.map +1 -0
  702. package/dist/dev/ui/slider/context.d.ts +24 -0
  703. package/dist/dev/ui/slider/context.d.ts.map +1 -0
  704. package/dist/dev/ui/slider/context.js +9 -0
  705. package/dist/dev/ui/slider/context.js.map +1 -0
  706. package/dist/dev/ui/slider/slider-buffer-element.d.ts +15 -0
  707. package/dist/dev/ui/slider/slider-buffer-element.d.ts.map +1 -0
  708. package/dist/dev/ui/slider/slider-buffer-element.js +21 -0
  709. package/dist/dev/ui/slider/slider-buffer-element.js.map +1 -0
  710. package/dist/dev/ui/slider/slider-element.d.ts +57 -0
  711. package/dist/dev/ui/slider/slider-element.d.ts.map +1 -0
  712. package/dist/dev/ui/slider/slider-element.js +122 -0
  713. package/dist/dev/ui/slider/slider-element.js.map +1 -0
  714. package/dist/dev/ui/slider/slider-events.d.ts +18 -0
  715. package/dist/dev/ui/slider/slider-events.d.ts.map +1 -0
  716. package/dist/dev/ui/slider/slider-fill-element.d.ts +15 -0
  717. package/dist/dev/ui/slider/slider-fill-element.d.ts.map +1 -0
  718. package/dist/dev/ui/slider/slider-fill-element.js +21 -0
  719. package/dist/dev/ui/slider/slider-fill-element.js.map +1 -0
  720. package/dist/dev/ui/slider/slider-preview-element.js +51 -0
  721. package/dist/dev/ui/slider/slider-preview-element.js.map +1 -0
  722. package/dist/dev/ui/slider/slider-thumb-element.d.ts +14 -0
  723. package/dist/dev/ui/slider/slider-thumb-element.d.ts.map +1 -0
  724. package/dist/dev/ui/slider/slider-thumb-element.js +43 -0
  725. package/dist/dev/ui/slider/slider-thumb-element.js.map +1 -0
  726. package/dist/dev/ui/slider/slider-thumbnail-element.d.ts +12 -0
  727. package/dist/dev/ui/slider/slider-thumbnail-element.d.ts.map +1 -0
  728. package/dist/dev/ui/slider/slider-thumbnail-element.js +23 -0
  729. package/dist/dev/ui/slider/slider-thumbnail-element.js.map +1 -0
  730. package/dist/dev/ui/slider/slider-track-element.d.ts +15 -0
  731. package/dist/dev/ui/slider/slider-track-element.d.ts.map +1 -0
  732. package/dist/dev/ui/slider/slider-track-element.js +21 -0
  733. package/dist/dev/ui/slider/slider-track-element.js.map +1 -0
  734. package/dist/dev/ui/slider/slider-value-element.d.ts +19 -0
  735. package/dist/dev/ui/slider/slider-value-element.d.ts.map +1 -0
  736. package/dist/dev/ui/slider/slider-value-element.js +38 -0
  737. package/dist/dev/ui/slider/slider-value-element.js.map +1 -0
  738. package/dist/dev/ui/thumbnail/thumbnail-element.d.ts +43 -0
  739. package/dist/dev/ui/thumbnail/thumbnail-element.d.ts.map +1 -0
  740. package/dist/dev/ui/thumbnail/thumbnail-element.js +139 -0
  741. package/dist/dev/ui/thumbnail/thumbnail-element.js.map +1 -0
  742. package/dist/dev/ui/time/time-element.d.ts +32 -0
  743. package/dist/dev/ui/time/time-element.d.ts.map +1 -0
  744. package/dist/dev/ui/time/time-element.js +60 -0
  745. package/dist/dev/ui/time/time-element.js.map +1 -0
  746. package/dist/dev/ui/time/time-group-element.d.ts +9 -0
  747. package/dist/dev/ui/time/time-group-element.d.ts.map +1 -0
  748. package/dist/dev/ui/time/time-group-element.js +12 -0
  749. package/dist/dev/ui/time/time-group-element.js.map +1 -0
  750. package/dist/dev/ui/time/time-separator-element.d.ts +10 -0
  751. package/dist/dev/ui/time/time-separator-element.d.ts.map +1 -0
  752. package/dist/dev/ui/time/time-separator-element.js +17 -0
  753. package/dist/dev/ui/time/time-separator-element.js.map +1 -0
  754. package/dist/dev/ui/time-slider/time-slider-element.d.ts +50 -0
  755. package/dist/dev/ui/time-slider/time-slider-element.d.ts.map +1 -0
  756. package/dist/dev/ui/time-slider/time-slider-element.js +134 -0
  757. package/dist/dev/ui/time-slider/time-slider-element.js.map +1 -0
  758. package/dist/dev/ui/tooltip/context.d.ts +9 -0
  759. package/dist/dev/ui/tooltip/context.d.ts.map +1 -0
  760. package/dist/dev/ui/tooltip/context.js +9 -0
  761. package/dist/dev/ui/tooltip/context.js.map +1 -0
  762. package/dist/dev/ui/tooltip/tooltip-element.d.ts +54 -0
  763. package/dist/dev/ui/tooltip/tooltip-element.d.ts.map +1 -0
  764. package/dist/dev/ui/tooltip/tooltip-element.js +154 -0
  765. package/dist/dev/ui/tooltip/tooltip-element.js.map +1 -0
  766. package/dist/dev/ui/tooltip/tooltip-group-element.d.ts +27 -0
  767. package/dist/dev/ui/tooltip/tooltip-group-element.d.ts.map +1 -0
  768. package/dist/dev/ui/tooltip/tooltip-group-element.js +38 -0
  769. package/dist/dev/ui/tooltip/tooltip-group-element.js.map +1 -0
  770. package/dist/dev/ui/volume-slider/volume-slider-element.d.ts +45 -0
  771. package/dist/dev/ui/volume-slider/volume-slider-element.d.ts.map +1 -0
  772. package/dist/dev/ui/volume-slider/volume-slider-element.js +123 -0
  773. package/dist/dev/ui/volume-slider/volume-slider-element.js.map +1 -0
  774. package/package.json +89 -40
  775. package/dist/button-Bu1mGG-F.js +0 -63
  776. package/dist/button-Bu1mGG-F.js.map +0 -1
  777. package/dist/component-factory-C0cl1nrL.js +0 -73
  778. package/dist/component-factory-C0cl1nrL.js.map +0 -1
  779. package/dist/current-time-display-DpoDrQu9.js +0 -46
  780. package/dist/current-time-display-DpoDrQu9.js.map +0 -1
  781. package/dist/custom-element-3bDlB2XO.js +0 -10
  782. package/dist/custom-element-3bDlB2XO.js.map +0 -1
  783. package/dist/define/index.d.ts +0 -12
  784. package/dist/define/index.js +0 -27
  785. package/dist/define/media-container.d.ts +0 -1
  786. package/dist/define/media-container.js +0 -3
  787. package/dist/define/media-current-time-display.d.ts +0 -1
  788. package/dist/define/media-current-time-display.js +0 -4
  789. package/dist/define/media-duration-display.d.ts +0 -1
  790. package/dist/define/media-duration-display.js +0 -4
  791. package/dist/define/media-fullscreen-button.d.ts +0 -1
  792. package/dist/define/media-fullscreen-button.js +0 -5
  793. package/dist/define/media-mute-button.d.ts +0 -1
  794. package/dist/define/media-mute-button.js +0 -5
  795. package/dist/define/media-play-button.d.ts +0 -1
  796. package/dist/define/media-play-button.js +0 -5
  797. package/dist/define/media-popover.d.ts +0 -1
  798. package/dist/define/media-popover.js +0 -3
  799. package/dist/define/media-preview-time-display.d.ts +0 -1
  800. package/dist/define/media-preview-time-display.js +0 -4
  801. package/dist/define/media-time-slider.d.ts +0 -1
  802. package/dist/define/media-time-slider.js +0 -4
  803. package/dist/define/media-tooltip.d.ts +0 -1
  804. package/dist/define/media-tooltip.js +0 -3
  805. package/dist/define/media-volume-slider.d.ts +0 -1
  806. package/dist/define/media-volume-slider.js +0 -4
  807. package/dist/define/video-provider.d.ts +0 -1
  808. package/dist/define/video-provider.js +0 -3
  809. package/dist/duration-display-BFRQmaOz.js +0 -48
  810. package/dist/duration-display-BFRQmaOz.js.map +0 -1
  811. package/dist/fullscreen-button-B0R9K3GV.js +0 -47
  812. package/dist/fullscreen-button-B0R9K3GV.js.map +0 -1
  813. package/dist/icons-CuxuONCk.js +0 -209
  814. package/dist/icons-CuxuONCk.js.map +0 -1
  815. package/dist/icons.d.ts +0 -1
  816. package/dist/icons.js +0 -2
  817. package/dist/index.d.ts +0 -146
  818. package/dist/index.d.ts.map +0 -1
  819. package/dist/index.js +0 -17
  820. package/dist/media-container-BOL0PKuG.js +0 -80
  821. package/dist/media-container-BOL0PKuG.js.map +0 -1
  822. package/dist/media-container-ChS9lZvf.d.ts +0 -1
  823. package/dist/media-container-DwKSOa1h.js +0 -8
  824. package/dist/media-container-DwKSOa1h.js.map +0 -1
  825. package/dist/media-current-time-display-Cd0rPAuj.d.ts +0 -1
  826. package/dist/media-current-time-display-DVCqNt7c.js +0 -8
  827. package/dist/media-current-time-display-DVCqNt7c.js.map +0 -1
  828. package/dist/media-duration-display-qvm6YX-q.d.ts +0 -1
  829. package/dist/media-duration-display-tzVLafRm.js +0 -8
  830. package/dist/media-duration-display-tzVLafRm.js.map +0 -1
  831. package/dist/media-fullscreen-button-BgUK3lgu.d.ts +0 -1
  832. package/dist/media-fullscreen-button-DDQ6EdLz.js +0 -8
  833. package/dist/media-fullscreen-button-DDQ6EdLz.js.map +0 -1
  834. package/dist/media-mute-button-NVJF2EEW.d.ts +0 -1
  835. package/dist/media-mute-button-Uy18NpPx.js +0 -8
  836. package/dist/media-mute-button-Uy18NpPx.js.map +0 -1
  837. package/dist/media-play-button-CDBZrhmx.js +0 -8
  838. package/dist/media-play-button-CDBZrhmx.js.map +0 -1
  839. package/dist/media-play-button-oq8yDlxe.d.ts +0 -1
  840. package/dist/media-popover-BtJmPv0E.d.ts +0 -1
  841. package/dist/media-popover-Cw9d_Bh3.js +0 -8
  842. package/dist/media-popover-Cw9d_Bh3.js.map +0 -1
  843. package/dist/media-preview-time-display-4YX5Rics.d.ts +0 -1
  844. package/dist/media-preview-time-display-ufqXiNXg.js +0 -8
  845. package/dist/media-preview-time-display-ufqXiNXg.js.map +0 -1
  846. package/dist/media-skin-CxnuHwhu.js +0 -36
  847. package/dist/media-skin-CxnuHwhu.js.map +0 -1
  848. package/dist/media-skin-Di3vSHvS.d.ts +0 -11
  849. package/dist/media-skin-Di3vSHvS.d.ts.map +0 -1
  850. package/dist/media-time-slider-BOdJr4QE.js +0 -12
  851. package/dist/media-time-slider-BOdJr4QE.js.map +0 -1
  852. package/dist/media-time-slider-DvMnfYXZ.d.ts +0 -1
  853. package/dist/media-tooltip-BqV17mdM.d.ts +0 -1
  854. package/dist/media-tooltip-CMRN_X4D.js +0 -8
  855. package/dist/media-tooltip-CMRN_X4D.js.map +0 -1
  856. package/dist/media-volume-slider-BB6GhrzS.js +0 -11
  857. package/dist/media-volume-slider-BB6GhrzS.js.map +0 -1
  858. package/dist/media-volume-slider-DP47VLVi.d.ts +0 -1
  859. package/dist/mute-button-C7XQB6iK.js +0 -49
  860. package/dist/mute-button-C7XQB6iK.js.map +0 -1
  861. package/dist/play-button-DFbxwrrq.js +0 -47
  862. package/dist/play-button-DFbxwrrq.js.map +0 -1
  863. package/dist/popover-BUCVOjnO.js +0 -167
  864. package/dist/popover-BUCVOjnO.js.map +0 -1
  865. package/dist/preview-time-display-CtA58pCS.js +0 -43
  866. package/dist/preview-time-display-CtA58pCS.js.map +0 -1
  867. package/dist/skins/frosted.d.ts +0 -23
  868. package/dist/skins/frosted.d.ts.map +0 -1
  869. package/dist/skins/frosted.js +0 -145
  870. package/dist/skins/frosted.js.map +0 -1
  871. package/dist/skins/minimal.d.ts +0 -23
  872. package/dist/skins/minimal.d.ts.map +0 -1
  873. package/dist/skins/minimal.js +0 -150
  874. package/dist/skins/minimal.js.map +0 -1
  875. package/dist/store.d.ts +0 -1
  876. package/dist/time-slider-DHpKPCI1.js +0 -165
  877. package/dist/time-slider-DHpKPCI1.js.map +0 -1
  878. package/dist/tooltip-B-glki2f.js +0 -171
  879. package/dist/tooltip-B-glki2f.js.map +0 -1
  880. package/dist/video-provider-BKDqoKFf.js +0 -17
  881. package/dist/video-provider-BKDqoKFf.js.map +0 -1
  882. package/dist/video-provider-BPPI5e47.js +0 -8
  883. package/dist/video-provider-BPPI5e47.js.map +0 -1
  884. package/dist/video-provider-nSCfwA7l.d.ts +0 -1
  885. package/dist/volume-slider-CUyfwehe.js +0 -140
  886. package/dist/volume-slider-CUyfwehe.js.map +0 -1
  887. /package/dist/{store.js → default/define/feature/video.js} +0 -0
  888. /package/dist/{index-LKrIp3Oo.d.ts → dev/define/feature/video.d.ts} +0 -0
package/README.md CHANGED
@@ -2,11 +2,13 @@
2
2
 
3
3
  [![package-badge]][package]
4
4
 
5
- > **⚠️ Technical Preview - SUBJECT TO CHANGE** Not recommended for production use.
5
+ > **⚠️ Alpha - SUBJECT TO CHANGE** Not recommended for production use.
6
6
 
7
7
  ## Overview
8
8
 
9
- `@videojs/html` is a comprehensive library for building media players with vanilla JavaScript and Web Components. It provides a complete set of UI components, state management, and utilities for creating feature-rich, accessible video and audio players.
9
+ `@videojs/html` is a comprehensive library for building media players with vanilla JavaScript and
10
+ Web Components. It provides a complete set of Custom Elements, state management, controllers,
11
+ and utilities for creating feature-rich, accessible video and audio players.
10
12
 
11
13
  ## Community
12
14
 
@@ -0,0 +1,6 @@
1
+ //#region inline-css:src/define/audio/minimal-skin.js
2
+ var minimal_skin_default = "/* ==========================================================================\n Icon State Visibility for Audio Skins\n\n Data-attribute-driven visibility rules for multi-state icon buttons.\n Uses :is() with both element selectors (for HTML custom element wrappers)\n and class selectors (for React rendered SVG elements).\n ========================================================================== */\n\n/* --- All icons hidden by default --- */\n\n.media-button--play .media-icon--restart,\n.media-button--play .media-icon--play,\n.media-button--play .media-icon--pause,\n.media-button--mute .media-icon--volume-off,\n.media-button--mute .media-icon--volume-low,\n.media-button--mute .media-icon--volume-high {\n display: none;\n opacity: 0;\n}\n\n/* --- Active icon per state --- */\n\n/* Play: ended → restart */\n.media-button--play[data-ended] .media-icon--restart,\n/* Play: paused (not ended) → play */\n.media-button--play:not([data-ended])[data-paused] .media-icon--play,\n/* Play: playing (not paused, not ended) → pause */\n.media-button--play:not([data-paused]):not([data-ended]) .media-icon--pause,\n/* Mute: muted → volume off */\n.media-button--mute[data-muted] .media-icon--volume-off,\n/* Mute: volume low (not muted) → volume low */\n.media-button--mute:not([data-muted])[data-volume-level=\"low\"] .media-icon--volume-low,\n/* Mute: volume high (not muted, not low) → volume high */\n.media-button--mute:not([data-muted]):not([data-volume-level=\"low\"]) .media-icon--volume-high {\n display: block;\n opacity: 1;\n}\n\n/* ==========================================================================\n Tooltip Label State Visibility for Audio Skins\n\n Data-attribute-driven visibility rules for multi-state tooltip labels.\n Uses adjacent sibling selectors to match button state → tooltip content.\n ========================================================================== */\n\n/* --- All multi-state labels hidden by default --- */\n\n.media-tooltip-label {\n display: none;\n}\n\n/* --- Active label per state --- */\n\n/* Play: ended → replay */\n.media-button--play[data-ended] + .media-tooltip .media-tooltip-label--replay,\n/* Play: paused (not ended) → play */\n .media-button--play:not([data-ended])[data-paused] + .media-tooltip\n .media-tooltip-label--play,\n/* Play: playing (not paused, not ended) → pause */\n .media-button--play:not([data-paused]):not([data-ended]) + .media-tooltip\n .media-tooltip-label--pause {\n display: block;\n}\n\n/* ==========================================================================\n Reset\n ========================================================================== */\n\n.media-minimal-skin *,\n.media-minimal-skin *::before,\n.media-minimal-skin *::after {\n box-sizing: border-box;\n margin: 0;\n}\n.media-minimal-skin img,\n.media-minimal-skin video,\n.media-minimal-skin svg {\n display: block;\n max-width: 100%;\n}\n.media-minimal-skin button {\n font: inherit;\n}\n@media (prefers-reduced-motion: no-preference) {\n .media-minimal-skin {\n interpolate-size: allow-keywords;\n }\n}\n\n/* ==========================================================================\n Root Container\n ========================================================================== */\n\n.media-minimal-skin {\n position: relative;\n isolation: isolate;\n display: block;\n container: media-root / inline-size;\n border-radius: var(--media-border-radius, 0.75rem);\n font-family:\n Inter Variable,\n Inter,\n ui-sans-serif,\n system-ui,\n sans-serif;\n font-size: 0.8125rem;\n line-height: 1.5;\n letter-spacing: normal;\n -webkit-font-smoothing: auto;\n -moz-osx-font-smoothing: auto;\n}\n\n/* ==========================================================================\n Buffering Indicator\n ========================================================================== */\n\n.media-minimal-skin .media-buffering-indicator {\n position: absolute;\n inset: 0;\n display: none;\n align-items: center;\n justify-content: center;\n color: oklch(1 0 0);\n pointer-events: none;\n\n &[data-visible] {\n display: flex;\n }\n}\n\n/* ==========================================================================\n Error Dialog\n ========================================================================== */\n\n.media-minimal-skin .media-error {\n position: absolute;\n inset: 0;\n z-index: 20;\n display: flex;\n align-items: center;\n justify-content: center;\n pointer-events: none;\n}\n\n.media-minimal-skin .media-error__dialog {\n display: flex;\n flex-direction: column;\n gap: 0.75rem;\n max-width: 16rem;\n padding: 1rem;\n color: oklch(1 0 0);\n font-size: 0.875rem;\n text-shadow: 0 1px 0 oklch(0 0 0 / 0.5);\n transition-property: opacity, transform;\n transition-duration: 500ms;\n transition-delay: 100ms;\n transition-timing-function: linear(\n 0,\n 0.034 1.5%,\n 0.763 9.7%,\n 1.066 13.9%,\n 1.198 19.9%,\n 1.184 21.8%,\n 0.963 37.5%,\n 0.997 50.9%,\n 1\n );\n\n /* Simple, fast transition for reduced motion users */\n @media (prefers-reduced-motion: reduce) {\n transition-duration: 100ms;\n transition-delay: 0ms;\n transition-timing-function: ease-out;\n }\n}\n\n.media-minimal-skin .media-error[data-starting-style] .media-error__dialog,\n.media-minimal-skin .media-error[data-ending-style] .media-error__dialog {\n opacity: 0;\n transform: scale(0.5);\n}\n\n.media-minimal-skin .media-error__content {\n display: flex;\n flex-direction: column;\n gap: 0.5rem;\n padding: 0.375rem 0;\n}\n\n.media-minimal-skin .media-error__title {\n font-weight: 600;\n line-height: 1.25;\n}\n\n.media-minimal-skin .media-error__description {\n opacity: 0.7;\n}\n\n.media-minimal-skin .media-error__actions {\n display: flex;\n gap: 0.5rem;\n\n & > * {\n flex: 1;\n }\n}\n\n/* ==========================================================================\n Controls\n ========================================================================== */\n\n.media-minimal-skin .media-controls {\n container: media-controls / inline-size;\n display: flex;\n align-items: center;\n --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.25));\n --media-controls-current-shadow-color-subtle: oklch(\n from var(--media-controls-current-shadow-color) l c h /\n calc(alpha * 0.4)\n );\n text-shadow: 0 0 1px var(--media-controls-current-shadow-color);\n}\n\n/* ==========================================================================\n Time Controls & Display\n ========================================================================== */\n\n.media-minimal-skin .media-time-controls {\n display: flex;\n flex-direction: row-reverse;\n align-items: center;\n flex: 1;\n gap: 0.75rem;\n}\n.media-minimal-skin .media-time {\n display: flex;\n align-items: center;\n gap: 0.25rem;\n}\n.media-minimal-skin .media-time__value {\n font-variant-numeric: tabular-nums;\n}\n.media-minimal-skin .media-time__value--current,\n.media-minimal-skin .media-time__separator {\n display: none;\n}\n@container media-controls (width > 28rem) {\n .media-minimal-skin .media-time-controls {\n flex-direction: row;\n }\n .media-minimal-skin .media-time__value--duration,\n .media-minimal-skin .media-time__separator {\n color: oklch(from currentColor l c h / 0.6);\n }\n .media-minimal-skin .media-time__value--current,\n .media-minimal-skin .media-time__separator {\n display: inline;\n }\n}\n\n/* ==========================================================================\n Button Groups\n ========================================================================== */\n\n.media-minimal-skin .media-button-group {\n display: flex;\n align-items: center;\n gap: 0.075rem;\n\n @container media-root (width > 40rem) {\n gap: 0.125rem;\n }\n}\n\n/* ==========================================================================\n Buttons\n ========================================================================== */\n\n/* Base button */\n.media-minimal-skin .media-button {\n display: flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n padding: 0.5rem 1rem;\n background: oklch(1 0 0);\n border: none;\n border-radius: 0.5rem;\n outline: 2px solid transparent;\n outline-offset: -2px;\n color: oklch(0 0 0);\n font-weight: 500;\n text-align: center;\n text-shadow: inherit;\n transition-property: background-color, color, outline-offset, transform;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n cursor: pointer;\n user-select: none;\n\n &:focus-visible {\n outline-color: currentColor;\n outline-offset: 2px;\n }\n\n &[disabled] {\n opacity: 0.5;\n filter: grayscale(1);\n cursor: not-allowed;\n }\n\n &[data-availability=\"unavailable\"] {\n display: none;\n }\n}\n\n/* Icon button variant */\n.media-minimal-skin .media-button--icon {\n display: grid;\n width: 2.375rem;\n padding: 0;\n aspect-ratio: 1;\n background: transparent;\n color: inherit;\n\n &:hover,\n &:focus-visible,\n &[aria-expanded=\"true\"] {\n color: oklch(from currentColor l c h / 0.8);\n text-decoration: none;\n }\n\n &:active {\n transform: scale(0.9);\n }\n\n & .media-icon {\n filter: drop-shadow(0 1px 0 var(--media-controls-current-shadow-color, oklch(0 0 0 / 0.25)));\n }\n}\n\n/* Seek button */\n.media-minimal-skin .media-button--seek {\n & .media-icon__label {\n position: absolute;\n right: -1px;\n bottom: -3px;\n font-size: 0.75em;\n font-weight: 480;\n font-variant-numeric: tabular-nums;\n }\n\n &:has(.media-icon--flipped) .media-icon__label {\n right: unset;\n left: -1px;\n }\n\n @container media-controls (width < 28rem) {\n display: none;\n }\n}\n\n/* Playback rate button */\n.media-minimal-skin .media-button--playback-rate {\n padding: 0;\n\n &::after {\n content: attr(data-rate) \"\\00D7\";\n width: 4ch;\n font-variant-numeric: tabular-nums;\n }\n}\n\n/* ==========================================================================\n Icons\n ========================================================================== */\n\n.media-minimal-skin .media-icon__container {\n position: relative;\n}\n.media-minimal-skin .media-icon {\n display: block;\n flex-shrink: 0;\n grid-area: 1 / 1;\n width: 18px;\n height: 18px;\n transition-behavior: allow-discrete;\n transition-property: display, opacity;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n}\n.media-minimal-skin .media-icon--flipped {\n scale: -1 1;\n}\n\n/* ==========================================================================\n Slider\n ========================================================================== */\n\n.media-minimal-skin .media-slider {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n flex: 1;\n border-radius: calc(infinity * 1px);\n outline: none;\n\n &[data-orientation=\"horizontal\"] {\n min-width: 5rem;\n width: 100%;\n height: 1.25rem;\n }\n\n &[data-orientation=\"vertical\"] {\n width: 1.25rem;\n height: 4.5rem;\n }\n}\n\n/* Track */\n.media-minimal-skin .media-slider__track {\n position: relative;\n isolation: isolate;\n overflow: hidden;\n border-radius: inherit;\n user-select: none;\n background-color: oklch(from currentColor l c h / 0.2);\n\n &[data-orientation=\"horizontal\"] {\n width: 100%;\n height: 0.1875rem;\n }\n\n &[data-orientation=\"vertical\"] {\n width: 0.1875rem;\n height: 100%;\n }\n}\n\n/* Thumb */\n.media-minimal-skin .media-slider__thumb {\n position: absolute;\n transform: translate(-50%, -50%);\n z-index: 10;\n width: 0.75rem;\n height: 0.75rem;\n background-color: currentColor;\n border-radius: calc(infinity * 1px);\n box-shadow:\n 0 0 0 1px var(--media-controls-current-shadow-color-subtle, oklch(0 0 0 / 0.1)),\n 0 1px 3px 0 oklch(0 0 0 / 0.15),\n 0 1px 2px -1px oklch(0 0 0 / 0.15);\n opacity: 0;\n scale: 0.7;\n transform-origin: center;\n transition-property: opacity, scale, outline-offset;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n user-select: none;\n outline: 2px solid transparent;\n outline-offset: -2px;\n\n &[data-orientation=\"horizontal\"] {\n top: 50%;\n left: var(--media-slider-fill);\n }\n\n &[data-orientation=\"vertical\"] {\n left: 50%;\n top: calc(100% - var(--media-slider-fill));\n }\n\n &:focus-visible {\n outline-color: currentColor;\n outline-offset: 2px;\n }\n}\n\n.media-minimal-skin .media-slider:hover .media-slider__thumb,\n.media-minimal-skin .media-slider:focus-within .media-slider__thumb,\n.media-minimal-skin .media-slider__thumb--persistent {\n opacity: 1;\n scale: 1;\n}\n\n/* Shared track fills */\n.media-minimal-skin .media-slider__buffer,\n.media-minimal-skin .media-slider__fill {\n position: absolute;\n border-radius: inherit;\n pointer-events: none;\n}\n\n.media-minimal-skin .media-slider__buffer[data-orientation=\"horizontal\"],\n.media-minimal-skin .media-slider__fill[data-orientation=\"horizontal\"] {\n inset-block: 0;\n left: 0;\n}\n\n.media-minimal-skin .media-slider__buffer[data-orientation=\"vertical\"],\n.media-minimal-skin .media-slider__fill[data-orientation=\"vertical\"] {\n inset-inline: 0;\n bottom: 0;\n}\n\n/* Buffer */\n.media-minimal-skin .media-slider__buffer {\n background-color: oklch(from currentColor l c h / 0.2);\n transition-duration: 0.25s;\n transition-timing-function: ease-out;\n\n &[data-orientation=\"horizontal\"] {\n width: var(--media-slider-buffer);\n transition-property: width;\n }\n\n &[data-orientation=\"vertical\"] {\n height: var(--media-slider-buffer);\n transition-property: height;\n }\n}\n\n/* Fill */\n.media-minimal-skin .media-slider__fill {\n background-color: currentColor;\n\n &[data-orientation=\"horizontal\"] {\n width: var(--media-slider-fill);\n }\n\n &[data-orientation=\"vertical\"] {\n height: var(--media-slider-fill);\n }\n}\n\n/* Time display within slider */\n.media-minimal-skin .media-slider__time-display {\n font-variant-numeric: tabular-nums;\n}\n\n/* ==========================================================================\n Popups & Animations\n ========================================================================== */\n\n.media-minimal-skin .media-popover,\n.media-minimal-skin .media-tooltip {\n margin: 0;\n border: 0;\n color: inherit;\n overflow: visible;\n transition-property: transform, scale, opacity, filter;\n transition-duration: 200ms;\n\n &[data-starting-style],\n &[data-ending-style] {\n opacity: 0;\n transform: scale(0);\n filter: blur(8px);\n }\n\n &[data-instant] {\n transition-duration: 0ms;\n }\n\n &[data-side=\"top\"] {\n transform-origin: bottom;\n }\n &[data-side=\"bottom\"] {\n transform-origin: top;\n }\n &[data-side=\"left\"] {\n transform-origin: right;\n }\n &[data-side=\"right\"] {\n transform-origin: left;\n }\n}\n\n.media-minimal-skin .media-tooltip {\n padding: 0.25rem 0.5rem;\n border-radius: 0.25rem;\n background-color: oklch(1 0 0 / 0.1);\n backdrop-filter: blur(64px) brightness(0.9) saturate(1.5);\n box-shadow:\n 0 4px 6px -1px oklch(0 0 0 / 0.1),\n 0 2px 4px -2px oklch(0 0 0 / 0.1);\n font-size: 0.75rem;\n white-space: nowrap;\n --media-tooltip-side-offset: 0.5rem;\n\n @media (prefers-reduced-transparency: reduce) {\n background-color: oklch(0 0 0 / 0.7);\n }\n\n @media (prefers-contrast: more) {\n background-color: oklch(0 0 0 / 0.9);\n }\n}\n\n\n/* ==========================================================================\n Controls\n ========================================================================== */\n\n.media-minimal-skin--audio {\n --media-controls-background-color: oklch(1 0 0);\n --media-controls-border-color: oklch(0 0 0 / 0.1);\n --media-controls-text-color: oklch(0 0 0);\n\n @media (prefers-color-scheme: dark) {\n --media-controls-background-color: oklch(0 0 0);\n --media-controls-border-color: oklch(1 0 0 / 0.1);\n --media-controls-text-color: oklch(1 0 0);\n }\n}\n.media-minimal-skin--audio .media-controls {\n gap: 0.5rem;\n padding: 0.375rem;\n background-color: var(--media-controls-background-color);\n backdrop-filter: blur(8px) brightness(0.98) saturate(1.2);\n border-radius: var(--media-border-radius, 0.75rem);\n color: var(--media-controls-text-color);\n box-shadow: 0 0 0 1px var(--media-controls-border-color);\n}\n\n/* ==========================================================================\n Popups & Animations\n ========================================================================== */\n\n.media-minimal-skin--audio .media-popover--volume {\n background: linear-gradient(to left, var(--media-controls-background-color) 80%, transparent 100%);\n padding: 0.5rem 0 0.5rem 4rem;\n --media-popover-side-offset: 0.75rem;\n}\n\n";
3
+
4
+ //#endregion
5
+ export { minimal_skin_default as default };
6
+ //# sourceMappingURL=minimal-skin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"minimal-skin.js","names":[],"sources":["../../../../../../inline-css:src/define/audio/minimal-skin.js"],"sourcesContent":["export default \"/* ==========================================================================\\n Icon State Visibility for Audio Skins\\n\\n Data-attribute-driven visibility rules for multi-state icon buttons.\\n Uses :is() with both element selectors (for HTML custom element wrappers)\\n and class selectors (for React rendered SVG elements).\\n ========================================================================== */\\n\\n/* --- All icons hidden by default --- */\\n\\n.media-button--play .media-icon--restart,\\n.media-button--play .media-icon--play,\\n.media-button--play .media-icon--pause,\\n.media-button--mute .media-icon--volume-off,\\n.media-button--mute .media-icon--volume-low,\\n.media-button--mute .media-icon--volume-high {\\n display: none;\\n opacity: 0;\\n}\\n\\n/* --- Active icon per state --- */\\n\\n/* Play: ended → restart */\\n.media-button--play[data-ended] .media-icon--restart,\\n/* Play: paused (not ended) → play */\\n.media-button--play:not([data-ended])[data-paused] .media-icon--play,\\n/* Play: playing (not paused, not ended) → pause */\\n.media-button--play:not([data-paused]):not([data-ended]) .media-icon--pause,\\n/* Mute: muted → volume off */\\n.media-button--mute[data-muted] .media-icon--volume-off,\\n/* Mute: volume low (not muted) → volume low */\\n.media-button--mute:not([data-muted])[data-volume-level=\\\"low\\\"] .media-icon--volume-low,\\n/* Mute: volume high (not muted, not low) → volume high */\\n.media-button--mute:not([data-muted]):not([data-volume-level=\\\"low\\\"]) .media-icon--volume-high {\\n display: block;\\n opacity: 1;\\n}\\n\\n/* ==========================================================================\\n Tooltip Label State Visibility for Audio Skins\\n\\n Data-attribute-driven visibility rules for multi-state tooltip labels.\\n Uses adjacent sibling selectors to match button state → tooltip content.\\n ========================================================================== */\\n\\n/* --- All multi-state labels hidden by default --- */\\n\\n.media-tooltip-label {\\n display: none;\\n}\\n\\n/* --- Active label per state --- */\\n\\n/* Play: ended → replay */\\n.media-button--play[data-ended] + .media-tooltip .media-tooltip-label--replay,\\n/* Play: paused (not ended) → play */\\n .media-button--play:not([data-ended])[data-paused] + .media-tooltip\\n .media-tooltip-label--play,\\n/* Play: playing (not paused, not ended) → pause */\\n .media-button--play:not([data-paused]):not([data-ended]) + .media-tooltip\\n .media-tooltip-label--pause {\\n display: block;\\n}\\n\\n/* ==========================================================================\\n Reset\\n ========================================================================== */\\n\\n.media-minimal-skin *,\\n.media-minimal-skin *::before,\\n.media-minimal-skin *::after {\\n box-sizing: border-box;\\n margin: 0;\\n}\\n.media-minimal-skin img,\\n.media-minimal-skin video,\\n.media-minimal-skin svg {\\n display: block;\\n max-width: 100%;\\n}\\n.media-minimal-skin button {\\n font: inherit;\\n}\\n@media (prefers-reduced-motion: no-preference) {\\n .media-minimal-skin {\\n interpolate-size: allow-keywords;\\n }\\n}\\n\\n/* ==========================================================================\\n Root Container\\n ========================================================================== */\\n\\n.media-minimal-skin {\\n position: relative;\\n isolation: isolate;\\n display: block;\\n container: media-root / inline-size;\\n border-radius: var(--media-border-radius, 0.75rem);\\n font-family:\\n Inter Variable,\\n Inter,\\n ui-sans-serif,\\n system-ui,\\n sans-serif;\\n font-size: 0.8125rem;\\n line-height: 1.5;\\n letter-spacing: normal;\\n -webkit-font-smoothing: auto;\\n -moz-osx-font-smoothing: auto;\\n}\\n\\n/* ==========================================================================\\n Buffering Indicator\\n ========================================================================== */\\n\\n.media-minimal-skin .media-buffering-indicator {\\n position: absolute;\\n inset: 0;\\n display: none;\\n align-items: center;\\n justify-content: center;\\n color: oklch(1 0 0);\\n pointer-events: none;\\n\\n &[data-visible] {\\n display: flex;\\n }\\n}\\n\\n/* ==========================================================================\\n Error Dialog\\n ========================================================================== */\\n\\n.media-minimal-skin .media-error {\\n position: absolute;\\n inset: 0;\\n z-index: 20;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n pointer-events: none;\\n}\\n\\n.media-minimal-skin .media-error__dialog {\\n display: flex;\\n flex-direction: column;\\n gap: 0.75rem;\\n max-width: 16rem;\\n padding: 1rem;\\n color: oklch(1 0 0);\\n font-size: 0.875rem;\\n text-shadow: 0 1px 0 oklch(0 0 0 / 0.5);\\n transition-property: opacity, transform;\\n transition-duration: 500ms;\\n transition-delay: 100ms;\\n transition-timing-function: linear(\\n 0,\\n 0.034 1.5%,\\n 0.763 9.7%,\\n 1.066 13.9%,\\n 1.198 19.9%,\\n 1.184 21.8%,\\n 0.963 37.5%,\\n 0.997 50.9%,\\n 1\\n );\\n\\n /* Simple, fast transition for reduced motion users */\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n transition-delay: 0ms;\\n transition-timing-function: ease-out;\\n }\\n}\\n\\n.media-minimal-skin .media-error[data-starting-style] .media-error__dialog,\\n.media-minimal-skin .media-error[data-ending-style] .media-error__dialog {\\n opacity: 0;\\n transform: scale(0.5);\\n}\\n\\n.media-minimal-skin .media-error__content {\\n display: flex;\\n flex-direction: column;\\n gap: 0.5rem;\\n padding: 0.375rem 0;\\n}\\n\\n.media-minimal-skin .media-error__title {\\n font-weight: 600;\\n line-height: 1.25;\\n}\\n\\n.media-minimal-skin .media-error__description {\\n opacity: 0.7;\\n}\\n\\n.media-minimal-skin .media-error__actions {\\n display: flex;\\n gap: 0.5rem;\\n\\n & > * {\\n flex: 1;\\n }\\n}\\n\\n/* ==========================================================================\\n Controls\\n ========================================================================== */\\n\\n.media-minimal-skin .media-controls {\\n container: media-controls / inline-size;\\n display: flex;\\n align-items: center;\\n --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.25));\\n --media-controls-current-shadow-color-subtle: oklch(\\n from var(--media-controls-current-shadow-color) l c h /\\n calc(alpha * 0.4)\\n );\\n text-shadow: 0 0 1px var(--media-controls-current-shadow-color);\\n}\\n\\n/* ==========================================================================\\n Time Controls & Display\\n ========================================================================== */\\n\\n.media-minimal-skin .media-time-controls {\\n display: flex;\\n flex-direction: row-reverse;\\n align-items: center;\\n flex: 1;\\n gap: 0.75rem;\\n}\\n.media-minimal-skin .media-time {\\n display: flex;\\n align-items: center;\\n gap: 0.25rem;\\n}\\n.media-minimal-skin .media-time__value {\\n font-variant-numeric: tabular-nums;\\n}\\n.media-minimal-skin .media-time__value--current,\\n.media-minimal-skin .media-time__separator {\\n display: none;\\n}\\n@container media-controls (width > 28rem) {\\n .media-minimal-skin .media-time-controls {\\n flex-direction: row;\\n }\\n .media-minimal-skin .media-time__value--duration,\\n .media-minimal-skin .media-time__separator {\\n color: oklch(from currentColor l c h / 0.6);\\n }\\n .media-minimal-skin .media-time__value--current,\\n .media-minimal-skin .media-time__separator {\\n display: inline;\\n }\\n}\\n\\n/* ==========================================================================\\n Button Groups\\n ========================================================================== */\\n\\n.media-minimal-skin .media-button-group {\\n display: flex;\\n align-items: center;\\n gap: 0.075rem;\\n\\n @container media-root (width > 40rem) {\\n gap: 0.125rem;\\n }\\n}\\n\\n/* ==========================================================================\\n Buttons\\n ========================================================================== */\\n\\n/* Base button */\\n.media-minimal-skin .media-button {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-shrink: 0;\\n padding: 0.5rem 1rem;\\n background: oklch(1 0 0);\\n border: none;\\n border-radius: 0.5rem;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n color: oklch(0 0 0);\\n font-weight: 500;\\n text-align: center;\\n text-shadow: inherit;\\n transition-property: background-color, color, outline-offset, transform;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n cursor: pointer;\\n user-select: none;\\n\\n &:focus-visible {\\n outline-color: currentColor;\\n outline-offset: 2px;\\n }\\n\\n &[disabled] {\\n opacity: 0.5;\\n filter: grayscale(1);\\n cursor: not-allowed;\\n }\\n\\n &[data-availability=\\\"unavailable\\\"] {\\n display: none;\\n }\\n}\\n\\n/* Icon button variant */\\n.media-minimal-skin .media-button--icon {\\n display: grid;\\n width: 2.375rem;\\n padding: 0;\\n aspect-ratio: 1;\\n background: transparent;\\n color: inherit;\\n\\n &:hover,\\n &:focus-visible,\\n &[aria-expanded=\\\"true\\\"] {\\n color: oklch(from currentColor l c h / 0.8);\\n text-decoration: none;\\n }\\n\\n &:active {\\n transform: scale(0.9);\\n }\\n\\n & .media-icon {\\n filter: drop-shadow(0 1px 0 var(--media-controls-current-shadow-color, oklch(0 0 0 / 0.25)));\\n }\\n}\\n\\n/* Seek button */\\n.media-minimal-skin .media-button--seek {\\n & .media-icon__label {\\n position: absolute;\\n right: -1px;\\n bottom: -3px;\\n font-size: 0.75em;\\n font-weight: 480;\\n font-variant-numeric: tabular-nums;\\n }\\n\\n &:has(.media-icon--flipped) .media-icon__label {\\n right: unset;\\n left: -1px;\\n }\\n\\n @container media-controls (width < 28rem) {\\n display: none;\\n }\\n}\\n\\n/* Playback rate button */\\n.media-minimal-skin .media-button--playback-rate {\\n padding: 0;\\n\\n &::after {\\n content: attr(data-rate) \\\"\\\\00D7\\\";\\n width: 4ch;\\n font-variant-numeric: tabular-nums;\\n }\\n}\\n\\n/* ==========================================================================\\n Icons\\n ========================================================================== */\\n\\n.media-minimal-skin .media-icon__container {\\n position: relative;\\n}\\n.media-minimal-skin .media-icon {\\n display: block;\\n flex-shrink: 0;\\n grid-area: 1 / 1;\\n width: 18px;\\n height: 18px;\\n transition-behavior: allow-discrete;\\n transition-property: display, opacity;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n}\\n.media-minimal-skin .media-icon--flipped {\\n scale: -1 1;\\n}\\n\\n/* ==========================================================================\\n Slider\\n ========================================================================== */\\n\\n.media-minimal-skin .media-slider {\\n position: relative;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex: 1;\\n border-radius: calc(infinity * 1px);\\n outline: none;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n min-width: 5rem;\\n width: 100%;\\n height: 1.25rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 1.25rem;\\n height: 4.5rem;\\n }\\n}\\n\\n/* Track */\\n.media-minimal-skin .media-slider__track {\\n position: relative;\\n isolation: isolate;\\n overflow: hidden;\\n border-radius: inherit;\\n user-select: none;\\n background-color: oklch(from currentColor l c h / 0.2);\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: 100%;\\n height: 0.1875rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 0.1875rem;\\n height: 100%;\\n }\\n}\\n\\n/* Thumb */\\n.media-minimal-skin .media-slider__thumb {\\n position: absolute;\\n transform: translate(-50%, -50%);\\n z-index: 10;\\n width: 0.75rem;\\n height: 0.75rem;\\n background-color: currentColor;\\n border-radius: calc(infinity * 1px);\\n box-shadow:\\n 0 0 0 1px var(--media-controls-current-shadow-color-subtle, oklch(0 0 0 / 0.1)),\\n 0 1px 3px 0 oklch(0 0 0 / 0.15),\\n 0 1px 2px -1px oklch(0 0 0 / 0.15);\\n opacity: 0;\\n scale: 0.7;\\n transform-origin: center;\\n transition-property: opacity, scale, outline-offset;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n user-select: none;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n top: 50%;\\n left: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n left: 50%;\\n top: calc(100% - var(--media-slider-fill));\\n }\\n\\n &:focus-visible {\\n outline-color: currentColor;\\n outline-offset: 2px;\\n }\\n}\\n\\n.media-minimal-skin .media-slider:hover .media-slider__thumb,\\n.media-minimal-skin .media-slider:focus-within .media-slider__thumb,\\n.media-minimal-skin .media-slider__thumb--persistent {\\n opacity: 1;\\n scale: 1;\\n}\\n\\n/* Shared track fills */\\n.media-minimal-skin .media-slider__buffer,\\n.media-minimal-skin .media-slider__fill {\\n position: absolute;\\n border-radius: inherit;\\n pointer-events: none;\\n}\\n\\n.media-minimal-skin .media-slider__buffer[data-orientation=\\\"horizontal\\\"],\\n.media-minimal-skin .media-slider__fill[data-orientation=\\\"horizontal\\\"] {\\n inset-block: 0;\\n left: 0;\\n}\\n\\n.media-minimal-skin .media-slider__buffer[data-orientation=\\\"vertical\\\"],\\n.media-minimal-skin .media-slider__fill[data-orientation=\\\"vertical\\\"] {\\n inset-inline: 0;\\n bottom: 0;\\n}\\n\\n/* Buffer */\\n.media-minimal-skin .media-slider__buffer {\\n background-color: oklch(from currentColor l c h / 0.2);\\n transition-duration: 0.25s;\\n transition-timing-function: ease-out;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-buffer);\\n transition-property: width;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-buffer);\\n transition-property: height;\\n }\\n}\\n\\n/* Fill */\\n.media-minimal-skin .media-slider__fill {\\n background-color: currentColor;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-fill);\\n }\\n}\\n\\n/* Time display within slider */\\n.media-minimal-skin .media-slider__time-display {\\n font-variant-numeric: tabular-nums;\\n}\\n\\n/* ==========================================================================\\n Popups & Animations\\n ========================================================================== */\\n\\n.media-minimal-skin .media-popover,\\n.media-minimal-skin .media-tooltip {\\n margin: 0;\\n border: 0;\\n color: inherit;\\n overflow: visible;\\n transition-property: transform, scale, opacity, filter;\\n transition-duration: 200ms;\\n\\n &[data-starting-style],\\n &[data-ending-style] {\\n opacity: 0;\\n transform: scale(0);\\n filter: blur(8px);\\n }\\n\\n &[data-instant] {\\n transition-duration: 0ms;\\n }\\n\\n &[data-side=\\\"top\\\"] {\\n transform-origin: bottom;\\n }\\n &[data-side=\\\"bottom\\\"] {\\n transform-origin: top;\\n }\\n &[data-side=\\\"left\\\"] {\\n transform-origin: right;\\n }\\n &[data-side=\\\"right\\\"] {\\n transform-origin: left;\\n }\\n}\\n\\n.media-minimal-skin .media-tooltip {\\n padding: 0.25rem 0.5rem;\\n border-radius: 0.25rem;\\n background-color: oklch(1 0 0 / 0.1);\\n backdrop-filter: blur(64px) brightness(0.9) saturate(1.5);\\n box-shadow:\\n 0 4px 6px -1px oklch(0 0 0 / 0.1),\\n 0 2px 4px -2px oklch(0 0 0 / 0.1);\\n font-size: 0.75rem;\\n white-space: nowrap;\\n --media-tooltip-side-offset: 0.5rem;\\n\\n @media (prefers-reduced-transparency: reduce) {\\n background-color: oklch(0 0 0 / 0.7);\\n }\\n\\n @media (prefers-contrast: more) {\\n background-color: oklch(0 0 0 / 0.9);\\n }\\n}\\n\\n\\n/* ==========================================================================\\n Controls\\n ========================================================================== */\\n\\n.media-minimal-skin--audio {\\n --media-controls-background-color: oklch(1 0 0);\\n --media-controls-border-color: oklch(0 0 0 / 0.1);\\n --media-controls-text-color: oklch(0 0 0);\\n\\n @media (prefers-color-scheme: dark) {\\n --media-controls-background-color: oklch(0 0 0);\\n --media-controls-border-color: oklch(1 0 0 / 0.1);\\n --media-controls-text-color: oklch(1 0 0);\\n }\\n}\\n.media-minimal-skin--audio .media-controls {\\n gap: 0.5rem;\\n padding: 0.375rem;\\n background-color: var(--media-controls-background-color);\\n backdrop-filter: blur(8px) brightness(0.98) saturate(1.2);\\n border-radius: var(--media-border-radius, 0.75rem);\\n color: var(--media-controls-text-color);\\n box-shadow: 0 0 0 1px var(--media-controls-border-color);\\n}\\n\\n/* ==========================================================================\\n Popups & Animations\\n ========================================================================== */\\n\\n.media-minimal-skin--audio .media-popover--volume {\\n background: linear-gradient(to left, var(--media-controls-background-color) 80%, transparent 100%);\\n padding: 0.5rem 0 0.5rem 4rem;\\n --media-popover-side-offset: 0.75rem;\\n}\\n\\n\";"],"mappings":";AAAA,2BAAe"}
@@ -0,0 +1,6 @@
1
+ //#region inline-css:src/define/audio/skin.js
2
+ var skin_default = "/* ==========================================================================\n Icon State Visibility for Audio Skins\n\n Data-attribute-driven visibility rules for multi-state icon buttons.\n Uses :is() with both element selectors (for HTML custom element wrappers)\n and class selectors (for React rendered SVG elements).\n ========================================================================== */\n\n/* --- All icons hidden by default --- */\n\n.media-button--play .media-icon--restart,\n.media-button--play .media-icon--play,\n.media-button--play .media-icon--pause,\n.media-button--mute .media-icon--volume-off,\n.media-button--mute .media-icon--volume-low,\n.media-button--mute .media-icon--volume-high {\n display: none;\n opacity: 0;\n}\n\n/* --- Active icon per state --- */\n\n/* Play: ended → restart */\n.media-button--play[data-ended] .media-icon--restart,\n/* Play: paused (not ended) → play */\n.media-button--play:not([data-ended])[data-paused] .media-icon--play,\n/* Play: playing (not paused, not ended) → pause */\n.media-button--play:not([data-paused]):not([data-ended]) .media-icon--pause,\n/* Mute: muted → volume off */\n.media-button--mute[data-muted] .media-icon--volume-off,\n/* Mute: volume low (not muted) → volume low */\n.media-button--mute:not([data-muted])[data-volume-level=\"low\"] .media-icon--volume-low,\n/* Mute: volume high (not muted, not low) → volume high */\n.media-button--mute:not([data-muted]):not([data-volume-level=\"low\"]) .media-icon--volume-high {\n display: block;\n opacity: 1;\n}\n\n/* ==========================================================================\n Tooltip Label State Visibility for Audio Skins\n\n Data-attribute-driven visibility rules for multi-state tooltip labels.\n Uses adjacent sibling selectors to match button state → tooltip content.\n ========================================================================== */\n\n/* --- All multi-state labels hidden by default --- */\n\n.media-tooltip-label {\n display: none;\n}\n\n/* --- Active label per state --- */\n\n/* Play: ended → replay */\n.media-button--play[data-ended] + .media-tooltip .media-tooltip-label--replay,\n/* Play: paused (not ended) → play */\n .media-button--play:not([data-ended])[data-paused] + .media-tooltip\n .media-tooltip-label--play,\n/* Play: playing (not paused, not ended) → pause */\n .media-button--play:not([data-paused]):not([data-ended]) + .media-tooltip\n .media-tooltip-label--pause {\n display: block;\n}\n\n/* ==========================================================================\n Reset\n ========================================================================== */\n\n.media-default-skin *,\n.media-default-skin *::before,\n.media-default-skin *::after {\n box-sizing: border-box;\n margin: 0;\n}\n.media-default-skin img,\n.media-default-skin video,\n.media-default-skin svg {\n display: block;\n max-width: 100%;\n}\n.media-default-skin button {\n font: inherit;\n}\n@media (prefers-reduced-motion: no-preference) {\n .media-default-skin {\n interpolate-size: allow-keywords;\n }\n}\n\n/* ==========================================================================\n Root Container\n ========================================================================== */\n\n.media-default-skin {\n position: relative;\n isolation: isolate;\n display: block;\n container: media-root / inline-size;\n border-radius: var(--media-border-radius, 2rem);\n font-family:\n Inter Variable,\n Inter,\n ui-sans-serif,\n system-ui,\n sans-serif;\n font-size: 0.8125rem;\n line-height: 1.5;\n letter-spacing: normal;\n -webkit-font-smoothing: auto;\n -moz-osx-font-smoothing: auto;\n\n &:fullscreen {\n border-radius: 0;\n }\n}\n\n/* ==========================================================================\n Surface (shared glass effect for tooltips, popovers, controls)\n ========================================================================== */\n\n.media-default-skin .media-surface {\n background-color: var(--media-surface-background-color);\n backdrop-filter: var(--media-surface-backdrop-filter);\n box-shadow:\n inset 0 0 0 1px var(--media-surface-inner-border-color),\n 0 1px 3px 0 var(--media-surface-shadow-color),\n 0 1px 2px -1px var(--media-surface-shadow-color);\n\n /* Inner border ring */\n &::after {\n content: \"\";\n position: absolute;\n inset: 0;\n z-index: 10;\n border-radius: inherit;\n box-shadow: 0 0 0 1px var(--media-surface-outer-border-color);\n pointer-events: none;\n }\n\n @media (prefers-reduced-transparency: reduce) {\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.7);\n }\n\n @media (prefers-contrast: more) {\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.9);\n }\n}\n\n/* ==========================================================================\n Buffering Indicator\n ========================================================================== */\n\n.media-default-skin .media-buffering-indicator {\n position: absolute;\n inset: 0;\n display: none;\n align-items: center;\n justify-content: center;\n color: oklch(1 0 0);\n pointer-events: none;\n\n &[data-visible] {\n display: flex;\n }\n\n .media-surface {\n padding: 0.25rem;\n border-radius: 100%;\n }\n}\n\n/* ==========================================================================\n Error Dialog\n ========================================================================== */\n\n.media-default-skin .media-error {\n position: absolute;\n inset: 0;\n z-index: 20;\n display: flex;\n align-items: center;\n justify-content: center;\n}\n\n.media-default-skin .media-error__dialog {\n display: flex;\n flex-direction: column;\n gap: 0.75rem;\n max-width: 18rem;\n padding: 0.75rem;\n border-radius: 1.75rem;\n color: oklch(1 0 0);\n font-size: 0.875rem;\n transition-property: opacity, transform;\n transition-duration: 500ms;\n transition-delay: 100ms;\n transition-timing-function: linear(\n 0,\n 0.034 1.5%,\n 0.763 9.7%,\n 1.066 13.9%,\n 1.198 19.9%,\n 1.184 21.8%,\n 0.963 37.5%,\n 0.997 50.9%,\n 1\n );\n\n /* Simple, fast transition for reduced motion users */\n @media (prefers-reduced-motion: reduce) {\n transition-duration: 100ms;\n transition-delay: 0ms;\n transition-timing-function: ease-out;\n }\n}\n\n.media-default-skin .media-error[data-starting-style] .media-error__dialog,\n.media-default-skin .media-error[data-ending-style] .media-error__dialog {\n opacity: 0;\n transform: scale(0.5);\n}\n\n.media-default-skin .media-error__content {\n display: flex;\n flex-direction: column;\n gap: 0.5rem;\n padding: 0.5rem 0.5rem 0.375rem;\n}\n\n.media-default-skin .media-error__title {\n font-weight: 600;\n line-height: 1.25;\n}\n\n.media-default-skin .media-error__description {\n opacity: 0.7;\n}\n\n.media-default-skin .media-error__actions {\n display: flex;\n gap: 0.5rem;\n\n & > * {\n flex: 1;\n }\n}\n\n/* ==========================================================================\n Controls\n ========================================================================== */\n\n.media-default-skin .media-controls {\n container: media-controls / inline-size;\n display: flex;\n align-items: center;\n gap: 0.075rem;\n padding: 0.175rem;\n border-radius: calc(infinity * 1px);\n --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.25));\n --media-controls-current-shadow-color-subtle: oklch(\n from var(--media-controls-current-shadow-color) l c h /\n calc(alpha * 0.4)\n );\n text-shadow: 0 0 1px var(--media-controls-current-shadow-color);\n\n @container media-root (width > 40rem) {\n gap: 0.125rem;\n padding: 0.25rem;\n }\n}\n\n/* ==========================================================================\n Time Display\n ========================================================================== */\n\n.media-default-skin .media-time {\n container: media-time / inline-size;\n display: flex;\n align-items: center;\n flex: 1;\n gap: 0.75rem;\n padding-inline: 0.5rem;\n\n & .media-time__value:first-child {\n display: none;\n\n @container media-time (width > 18rem) {\n display: block;\n }\n }\n}\n\n.media-default-skin .media-time__value {\n font-variant-numeric: tabular-nums;\n}\n\n/* ==========================================================================\n Buttons\n ========================================================================== */\n\n/* Base button */\n.media-default-skin .media-button {\n display: flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n padding: 0.5rem 1rem;\n background: oklch(1 0 0);\n border: none;\n border-radius: calc(infinity * 1px);\n outline: 2px solid transparent;\n outline-offset: -2px;\n color: oklch(0 0 0);\n font-weight: 500;\n text-align: center;\n transition-property: background-color, color, outline-offset, transform;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n cursor: pointer;\n user-select: none;\n\n &:focus-visible {\n outline-color: oklch(62.3% 0.214 259.815);\n outline-offset: 2px;\n }\n\n &[disabled] {\n opacity: 0.5;\n filter: grayscale(1);\n cursor: not-allowed;\n }\n\n &[data-availability=\"unavailable\"] {\n display: none;\n }\n}\n\n/* Icon button variant */\n.media-default-skin .media-button--icon {\n display: grid;\n width: 2.125rem;\n padding: 0;\n aspect-ratio: 1;\n background: transparent;\n color: inherit;\n text-shadow: inherit;\n\n &:hover,\n &:focus-visible,\n &[aria-expanded=\"true\"] {\n background-color: oklch(from currentColor l c h / 0.1);\n text-decoration: none;\n }\n\n &:active {\n transform: scale(0.9);\n }\n\n & .media-icon {\n filter: drop-shadow(0 1px 0 var(--media-controls-current-shadow-color, oklch(0 0 0 / 0.25)));\n }\n}\n\n/* Seek button */\n.media-default-skin .media-button--seek {\n & .media-icon__label {\n position: absolute;\n right: -1px;\n bottom: -3px;\n font-size: 0.75em;\n font-weight: 480;\n font-variant-numeric: tabular-nums;\n }\n\n &:has(.media-icon--flipped) .media-icon__label {\n right: unset;\n left: -1px;\n }\n\n @container media-controls (width < 28rem) {\n display: none;\n }\n}\n\n/* Playback rate button */\n.media-default-skin .media-button--playback-rate {\n padding: 0;\n\n &::after {\n content: attr(data-rate) \"\\00D7\";\n width: 4ch;\n font-variant-numeric: tabular-nums;\n }\n}\n\n/* ==========================================================================\n Icons\n ========================================================================== */\n\n.media-default-skin .media-icon__container {\n position: relative;\n}\n.media-default-skin .media-icon {\n display: block;\n flex-shrink: 0;\n grid-area: 1 / 1;\n width: 18px;\n height: 18px;\n transition-behavior: allow-discrete;\n transition-property: display, opacity;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n}\n.media-default-skin .media-icon--flipped {\n scale: -1 1;\n}\n\n/* ==========================================================================\n Slider\n ========================================================================== */\n\n.media-default-skin .media-slider {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n flex: 1;\n border-radius: calc(infinity * 1px);\n outline: none;\n\n &[data-orientation=\"horizontal\"] {\n min-width: 5rem;\n width: 100%;\n height: 1.25rem;\n }\n\n &[data-orientation=\"vertical\"] {\n width: 1.25rem;\n height: 5rem;\n }\n}\n\n/* Track */\n.media-default-skin .media-slider__track {\n position: relative;\n isolation: isolate;\n overflow: hidden;\n border-radius: inherit;\n user-select: none;\n\n &[data-orientation=\"horizontal\"] {\n width: 100%;\n height: 0.25rem;\n }\n\n &[data-orientation=\"vertical\"] {\n width: 0.25rem;\n height: 100%;\n }\n}\n\n/* Thumb */\n.media-default-skin .media-slider__thumb {\n z-index: 10;\n position: absolute;\n transform: translate(-50%, -50%);\n width: 0.625rem;\n height: 0.625rem;\n background-color: currentColor;\n border-radius: calc(infinity * 1px);\n box-shadow:\n 0 0 0 1px var(--media-controls-current-shadow-color-subtle, oklch(0 0 0 / 0.1)),\n 0 1px 3px 0 oklch(0 0 0 / 0.15),\n 0 1px 2px -1px oklch(0 0 0 / 0.15);\n opacity: 0;\n transition-property: opacity, height, width, outline-offset;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n user-select: none;\n outline: 4px solid transparent;\n outline-offset: -4px;\n\n &[data-orientation=\"horizontal\"] {\n top: 50%;\n left: var(--media-slider-fill);\n }\n\n &[data-orientation=\"vertical\"] {\n left: 50%;\n top: calc(100% - var(--media-slider-fill));\n }\n\n &:hover,\n &:focus {\n outline-color: oklch(from currentColor l c h / 0.25);\n outline-offset: 0;\n }\n}\n\n.media-default-skin .media-slider:active .media-slider__thumb,\n.media-default-skin .media-slider__thumb--persistent {\n width: 0.75rem;\n height: 0.75rem;\n}\n\n.media-default-skin .media-slider:hover .media-slider__thumb,\n.media-default-skin .media-slider__thumb:focus-visible,\n.media-default-skin .media-slider__thumb--persistent {\n opacity: 1;\n}\n\n/* Shared track fills */\n.media-default-skin .media-slider__buffer,\n.media-default-skin .media-slider__fill {\n position: absolute;\n border-radius: inherit;\n pointer-events: none;\n}\n\n.media-default-skin .media-slider__buffer[data-orientation=\"horizontal\"],\n.media-default-skin .media-slider__fill[data-orientation=\"horizontal\"] {\n inset-block: 0;\n left: 0;\n}\n\n.media-default-skin .media-slider__buffer[data-orientation=\"vertical\"],\n.media-default-skin .media-slider__fill[data-orientation=\"vertical\"] {\n inset-inline: 0;\n bottom: 0;\n}\n\n/* Buffer */\n.media-default-skin .media-slider__buffer {\n background-color: oklch(from currentColor l c h / 0.2);\n transition-duration: 0.25s;\n transition-timing-function: ease-out;\n\n &[data-orientation=\"horizontal\"] {\n width: var(--media-slider-buffer);\n transition-property: width;\n }\n\n &[data-orientation=\"vertical\"] {\n height: var(--media-slider-buffer);\n transition-property: height;\n }\n}\n\n/* Fill */\n.media-default-skin .media-slider__fill {\n background-color: currentColor;\n\n &[data-orientation=\"horizontal\"] {\n width: var(--media-slider-fill);\n }\n\n &[data-orientation=\"vertical\"] {\n height: var(--media-slider-fill);\n }\n}\n\n/* Time display within slider */\n.media-default-skin .media-slider__time-display {\n font-variant-numeric: tabular-nums;\n}\n\n/* ==========================================================================\n Popups & Tooltips\n ========================================================================== */\n\n.media-default-skin .media-popover,\n.media-default-skin .media-tooltip {\n margin: 0;\n border: 0;\n color: inherit;\n overflow: visible;\n transition-property: transform, scale, opacity, filter;\n transition-duration: 200ms;\n\n &[data-starting-style],\n &[data-ending-style] {\n opacity: 0;\n transform: scale(0);\n filter: blur(8px);\n }\n\n &[data-instant] {\n transition-duration: 0ms;\n }\n\n &[data-side=\"top\"] {\n transform-origin: bottom;\n }\n &[data-side=\"bottom\"] {\n transform-origin: top;\n }\n &[data-side=\"left\"] {\n transform-origin: right;\n }\n &[data-side=\"right\"] {\n transform-origin: left;\n }\n}\n\n.media-default-skin .media-popover {\n --media-popover-side-offset: 0.5rem;\n}\n.media-default-skin .media-popover--volume {\n padding: 0.625rem 0.25rem;\n border-radius: calc(infinity * 1px);\n}\n\n.media-default-skin .media-tooltip {\n padding: 0.25rem 0.625rem;\n border-radius: calc(infinity * 1px);\n font-size: 0.75rem;\n white-space: nowrap;\n --media-tooltip-side-offset: 0.5rem;\n}\n\n\n/* ==========================================================================\n Root\n ========================================================================== */\n\n.media-default-skin--audio {\n --media-border-color: oklch(0 0 0 / 0.1);\n --media-surface-background-color: oklch(1 0 0 / 0.5);\n --media-surface-inner-border-color: oklch(1 0 0 / 0.1);\n --media-surface-outer-border-color: oklch(0 0 0 / 0.05);\n --media-surface-shadow-color: oklch(0 0 0 / 0.15);\n --media-surface-backdrop-filter: blur(8px) brightness(0.98) saturate(1.2);\n\n @media (prefers-color-scheme: dark) {\n --media-border-color: oklch(1 0 0 / 0.1);\n --media-surface-background-color: oklch(0 0 0 / 0.4);\n }\n}\n\n/* ==========================================================================\n Controls\n ========================================================================== */\n\n.media-default-skin--audio .media-controls {\n @media (prefers-color-scheme: dark) {\n color: oklch(1 0 0);\n }\n}\n\n/* ==========================================================================\n Sliders\n ========================================================================== */\n.media-default-skin--audio .media-slider__track {\n background-color: oklch(0 0 0 / 0.1);\n\n @media (prefers-color-scheme: dark) {\n background-color: oklch(1 0 0 / 0.2);\n box-shadow: 0 0 0 1px oklch(0 0 0 / 0.05);\n }\n}\n\n";
3
+
4
+ //#endregion
5
+ export { skin_default as default };
6
+ //# sourceMappingURL=skin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skin.js","names":[],"sources":["../../../../../../inline-css:src/define/audio/skin.js"],"sourcesContent":["export default \"/* ==========================================================================\\n Icon State Visibility for Audio Skins\\n\\n Data-attribute-driven visibility rules for multi-state icon buttons.\\n Uses :is() with both element selectors (for HTML custom element wrappers)\\n and class selectors (for React rendered SVG elements).\\n ========================================================================== */\\n\\n/* --- All icons hidden by default --- */\\n\\n.media-button--play .media-icon--restart,\\n.media-button--play .media-icon--play,\\n.media-button--play .media-icon--pause,\\n.media-button--mute .media-icon--volume-off,\\n.media-button--mute .media-icon--volume-low,\\n.media-button--mute .media-icon--volume-high {\\n display: none;\\n opacity: 0;\\n}\\n\\n/* --- Active icon per state --- */\\n\\n/* Play: ended → restart */\\n.media-button--play[data-ended] .media-icon--restart,\\n/* Play: paused (not ended) → play */\\n.media-button--play:not([data-ended])[data-paused] .media-icon--play,\\n/* Play: playing (not paused, not ended) → pause */\\n.media-button--play:not([data-paused]):not([data-ended]) .media-icon--pause,\\n/* Mute: muted → volume off */\\n.media-button--mute[data-muted] .media-icon--volume-off,\\n/* Mute: volume low (not muted) → volume low */\\n.media-button--mute:not([data-muted])[data-volume-level=\\\"low\\\"] .media-icon--volume-low,\\n/* Mute: volume high (not muted, not low) → volume high */\\n.media-button--mute:not([data-muted]):not([data-volume-level=\\\"low\\\"]) .media-icon--volume-high {\\n display: block;\\n opacity: 1;\\n}\\n\\n/* ==========================================================================\\n Tooltip Label State Visibility for Audio Skins\\n\\n Data-attribute-driven visibility rules for multi-state tooltip labels.\\n Uses adjacent sibling selectors to match button state → tooltip content.\\n ========================================================================== */\\n\\n/* --- All multi-state labels hidden by default --- */\\n\\n.media-tooltip-label {\\n display: none;\\n}\\n\\n/* --- Active label per state --- */\\n\\n/* Play: ended → replay */\\n.media-button--play[data-ended] + .media-tooltip .media-tooltip-label--replay,\\n/* Play: paused (not ended) → play */\\n .media-button--play:not([data-ended])[data-paused] + .media-tooltip\\n .media-tooltip-label--play,\\n/* Play: playing (not paused, not ended) → pause */\\n .media-button--play:not([data-paused]):not([data-ended]) + .media-tooltip\\n .media-tooltip-label--pause {\\n display: block;\\n}\\n\\n/* ==========================================================================\\n Reset\\n ========================================================================== */\\n\\n.media-default-skin *,\\n.media-default-skin *::before,\\n.media-default-skin *::after {\\n box-sizing: border-box;\\n margin: 0;\\n}\\n.media-default-skin img,\\n.media-default-skin video,\\n.media-default-skin svg {\\n display: block;\\n max-width: 100%;\\n}\\n.media-default-skin button {\\n font: inherit;\\n}\\n@media (prefers-reduced-motion: no-preference) {\\n .media-default-skin {\\n interpolate-size: allow-keywords;\\n }\\n}\\n\\n/* ==========================================================================\\n Root Container\\n ========================================================================== */\\n\\n.media-default-skin {\\n position: relative;\\n isolation: isolate;\\n display: block;\\n container: media-root / inline-size;\\n border-radius: var(--media-border-radius, 2rem);\\n font-family:\\n Inter Variable,\\n Inter,\\n ui-sans-serif,\\n system-ui,\\n sans-serif;\\n font-size: 0.8125rem;\\n line-height: 1.5;\\n letter-spacing: normal;\\n -webkit-font-smoothing: auto;\\n -moz-osx-font-smoothing: auto;\\n\\n &:fullscreen {\\n border-radius: 0;\\n }\\n}\\n\\n/* ==========================================================================\\n Surface (shared glass effect for tooltips, popovers, controls)\\n ========================================================================== */\\n\\n.media-default-skin .media-surface {\\n background-color: var(--media-surface-background-color);\\n backdrop-filter: var(--media-surface-backdrop-filter);\\n box-shadow:\\n inset 0 0 0 1px var(--media-surface-inner-border-color),\\n 0 1px 3px 0 var(--media-surface-shadow-color),\\n 0 1px 2px -1px var(--media-surface-shadow-color);\\n\\n /* Inner border ring */\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n z-index: 10;\\n border-radius: inherit;\\n box-shadow: 0 0 0 1px var(--media-surface-outer-border-color);\\n pointer-events: none;\\n }\\n\\n @media (prefers-reduced-transparency: reduce) {\\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.7);\\n }\\n\\n @media (prefers-contrast: more) {\\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.9);\\n }\\n}\\n\\n/* ==========================================================================\\n Buffering Indicator\\n ========================================================================== */\\n\\n.media-default-skin .media-buffering-indicator {\\n position: absolute;\\n inset: 0;\\n display: none;\\n align-items: center;\\n justify-content: center;\\n color: oklch(1 0 0);\\n pointer-events: none;\\n\\n &[data-visible] {\\n display: flex;\\n }\\n\\n .media-surface {\\n padding: 0.25rem;\\n border-radius: 100%;\\n }\\n}\\n\\n/* ==========================================================================\\n Error Dialog\\n ========================================================================== */\\n\\n.media-default-skin .media-error {\\n position: absolute;\\n inset: 0;\\n z-index: 20;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n}\\n\\n.media-default-skin .media-error__dialog {\\n display: flex;\\n flex-direction: column;\\n gap: 0.75rem;\\n max-width: 18rem;\\n padding: 0.75rem;\\n border-radius: 1.75rem;\\n color: oklch(1 0 0);\\n font-size: 0.875rem;\\n transition-property: opacity, transform;\\n transition-duration: 500ms;\\n transition-delay: 100ms;\\n transition-timing-function: linear(\\n 0,\\n 0.034 1.5%,\\n 0.763 9.7%,\\n 1.066 13.9%,\\n 1.198 19.9%,\\n 1.184 21.8%,\\n 0.963 37.5%,\\n 0.997 50.9%,\\n 1\\n );\\n\\n /* Simple, fast transition for reduced motion users */\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n transition-delay: 0ms;\\n transition-timing-function: ease-out;\\n }\\n}\\n\\n.media-default-skin .media-error[data-starting-style] .media-error__dialog,\\n.media-default-skin .media-error[data-ending-style] .media-error__dialog {\\n opacity: 0;\\n transform: scale(0.5);\\n}\\n\\n.media-default-skin .media-error__content {\\n display: flex;\\n flex-direction: column;\\n gap: 0.5rem;\\n padding: 0.5rem 0.5rem 0.375rem;\\n}\\n\\n.media-default-skin .media-error__title {\\n font-weight: 600;\\n line-height: 1.25;\\n}\\n\\n.media-default-skin .media-error__description {\\n opacity: 0.7;\\n}\\n\\n.media-default-skin .media-error__actions {\\n display: flex;\\n gap: 0.5rem;\\n\\n & > * {\\n flex: 1;\\n }\\n}\\n\\n/* ==========================================================================\\n Controls\\n ========================================================================== */\\n\\n.media-default-skin .media-controls {\\n container: media-controls / inline-size;\\n display: flex;\\n align-items: center;\\n gap: 0.075rem;\\n padding: 0.175rem;\\n border-radius: calc(infinity * 1px);\\n --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.25));\\n --media-controls-current-shadow-color-subtle: oklch(\\n from var(--media-controls-current-shadow-color) l c h /\\n calc(alpha * 0.4)\\n );\\n text-shadow: 0 0 1px var(--media-controls-current-shadow-color);\\n\\n @container media-root (width > 40rem) {\\n gap: 0.125rem;\\n padding: 0.25rem;\\n }\\n}\\n\\n/* ==========================================================================\\n Time Display\\n ========================================================================== */\\n\\n.media-default-skin .media-time {\\n container: media-time / inline-size;\\n display: flex;\\n align-items: center;\\n flex: 1;\\n gap: 0.75rem;\\n padding-inline: 0.5rem;\\n\\n & .media-time__value:first-child {\\n display: none;\\n\\n @container media-time (width > 18rem) {\\n display: block;\\n }\\n }\\n}\\n\\n.media-default-skin .media-time__value {\\n font-variant-numeric: tabular-nums;\\n}\\n\\n/* ==========================================================================\\n Buttons\\n ========================================================================== */\\n\\n/* Base button */\\n.media-default-skin .media-button {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-shrink: 0;\\n padding: 0.5rem 1rem;\\n background: oklch(1 0 0);\\n border: none;\\n border-radius: calc(infinity * 1px);\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n color: oklch(0 0 0);\\n font-weight: 500;\\n text-align: center;\\n transition-property: background-color, color, outline-offset, transform;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n cursor: pointer;\\n user-select: none;\\n\\n &:focus-visible {\\n outline-color: oklch(62.3% 0.214 259.815);\\n outline-offset: 2px;\\n }\\n\\n &[disabled] {\\n opacity: 0.5;\\n filter: grayscale(1);\\n cursor: not-allowed;\\n }\\n\\n &[data-availability=\\\"unavailable\\\"] {\\n display: none;\\n }\\n}\\n\\n/* Icon button variant */\\n.media-default-skin .media-button--icon {\\n display: grid;\\n width: 2.125rem;\\n padding: 0;\\n aspect-ratio: 1;\\n background: transparent;\\n color: inherit;\\n text-shadow: inherit;\\n\\n &:hover,\\n &:focus-visible,\\n &[aria-expanded=\\\"true\\\"] {\\n background-color: oklch(from currentColor l c h / 0.1);\\n text-decoration: none;\\n }\\n\\n &:active {\\n transform: scale(0.9);\\n }\\n\\n & .media-icon {\\n filter: drop-shadow(0 1px 0 var(--media-controls-current-shadow-color, oklch(0 0 0 / 0.25)));\\n }\\n}\\n\\n/* Seek button */\\n.media-default-skin .media-button--seek {\\n & .media-icon__label {\\n position: absolute;\\n right: -1px;\\n bottom: -3px;\\n font-size: 0.75em;\\n font-weight: 480;\\n font-variant-numeric: tabular-nums;\\n }\\n\\n &:has(.media-icon--flipped) .media-icon__label {\\n right: unset;\\n left: -1px;\\n }\\n\\n @container media-controls (width < 28rem) {\\n display: none;\\n }\\n}\\n\\n/* Playback rate button */\\n.media-default-skin .media-button--playback-rate {\\n padding: 0;\\n\\n &::after {\\n content: attr(data-rate) \\\"\\\\00D7\\\";\\n width: 4ch;\\n font-variant-numeric: tabular-nums;\\n }\\n}\\n\\n/* ==========================================================================\\n Icons\\n ========================================================================== */\\n\\n.media-default-skin .media-icon__container {\\n position: relative;\\n}\\n.media-default-skin .media-icon {\\n display: block;\\n flex-shrink: 0;\\n grid-area: 1 / 1;\\n width: 18px;\\n height: 18px;\\n transition-behavior: allow-discrete;\\n transition-property: display, opacity;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n}\\n.media-default-skin .media-icon--flipped {\\n scale: -1 1;\\n}\\n\\n/* ==========================================================================\\n Slider\\n ========================================================================== */\\n\\n.media-default-skin .media-slider {\\n position: relative;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex: 1;\\n border-radius: calc(infinity * 1px);\\n outline: none;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n min-width: 5rem;\\n width: 100%;\\n height: 1.25rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 1.25rem;\\n height: 5rem;\\n }\\n}\\n\\n/* Track */\\n.media-default-skin .media-slider__track {\\n position: relative;\\n isolation: isolate;\\n overflow: hidden;\\n border-radius: inherit;\\n user-select: none;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: 100%;\\n height: 0.25rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 0.25rem;\\n height: 100%;\\n }\\n}\\n\\n/* Thumb */\\n.media-default-skin .media-slider__thumb {\\n z-index: 10;\\n position: absolute;\\n transform: translate(-50%, -50%);\\n width: 0.625rem;\\n height: 0.625rem;\\n background-color: currentColor;\\n border-radius: calc(infinity * 1px);\\n box-shadow:\\n 0 0 0 1px var(--media-controls-current-shadow-color-subtle, oklch(0 0 0 / 0.1)),\\n 0 1px 3px 0 oklch(0 0 0 / 0.15),\\n 0 1px 2px -1px oklch(0 0 0 / 0.15);\\n opacity: 0;\\n transition-property: opacity, height, width, outline-offset;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n user-select: none;\\n outline: 4px solid transparent;\\n outline-offset: -4px;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n top: 50%;\\n left: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n left: 50%;\\n top: calc(100% - var(--media-slider-fill));\\n }\\n\\n &:hover,\\n &:focus {\\n outline-color: oklch(from currentColor l c h / 0.25);\\n outline-offset: 0;\\n }\\n}\\n\\n.media-default-skin .media-slider:active .media-slider__thumb,\\n.media-default-skin .media-slider__thumb--persistent {\\n width: 0.75rem;\\n height: 0.75rem;\\n}\\n\\n.media-default-skin .media-slider:hover .media-slider__thumb,\\n.media-default-skin .media-slider__thumb:focus-visible,\\n.media-default-skin .media-slider__thumb--persistent {\\n opacity: 1;\\n}\\n\\n/* Shared track fills */\\n.media-default-skin .media-slider__buffer,\\n.media-default-skin .media-slider__fill {\\n position: absolute;\\n border-radius: inherit;\\n pointer-events: none;\\n}\\n\\n.media-default-skin .media-slider__buffer[data-orientation=\\\"horizontal\\\"],\\n.media-default-skin .media-slider__fill[data-orientation=\\\"horizontal\\\"] {\\n inset-block: 0;\\n left: 0;\\n}\\n\\n.media-default-skin .media-slider__buffer[data-orientation=\\\"vertical\\\"],\\n.media-default-skin .media-slider__fill[data-orientation=\\\"vertical\\\"] {\\n inset-inline: 0;\\n bottom: 0;\\n}\\n\\n/* Buffer */\\n.media-default-skin .media-slider__buffer {\\n background-color: oklch(from currentColor l c h / 0.2);\\n transition-duration: 0.25s;\\n transition-timing-function: ease-out;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-buffer);\\n transition-property: width;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-buffer);\\n transition-property: height;\\n }\\n}\\n\\n/* Fill */\\n.media-default-skin .media-slider__fill {\\n background-color: currentColor;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-fill);\\n }\\n}\\n\\n/* Time display within slider */\\n.media-default-skin .media-slider__time-display {\\n font-variant-numeric: tabular-nums;\\n}\\n\\n/* ==========================================================================\\n Popups & Tooltips\\n ========================================================================== */\\n\\n.media-default-skin .media-popover,\\n.media-default-skin .media-tooltip {\\n margin: 0;\\n border: 0;\\n color: inherit;\\n overflow: visible;\\n transition-property: transform, scale, opacity, filter;\\n transition-duration: 200ms;\\n\\n &[data-starting-style],\\n &[data-ending-style] {\\n opacity: 0;\\n transform: scale(0);\\n filter: blur(8px);\\n }\\n\\n &[data-instant] {\\n transition-duration: 0ms;\\n }\\n\\n &[data-side=\\\"top\\\"] {\\n transform-origin: bottom;\\n }\\n &[data-side=\\\"bottom\\\"] {\\n transform-origin: top;\\n }\\n &[data-side=\\\"left\\\"] {\\n transform-origin: right;\\n }\\n &[data-side=\\\"right\\\"] {\\n transform-origin: left;\\n }\\n}\\n\\n.media-default-skin .media-popover {\\n --media-popover-side-offset: 0.5rem;\\n}\\n.media-default-skin .media-popover--volume {\\n padding: 0.625rem 0.25rem;\\n border-radius: calc(infinity * 1px);\\n}\\n\\n.media-default-skin .media-tooltip {\\n padding: 0.25rem 0.625rem;\\n border-radius: calc(infinity * 1px);\\n font-size: 0.75rem;\\n white-space: nowrap;\\n --media-tooltip-side-offset: 0.5rem;\\n}\\n\\n\\n/* ==========================================================================\\n Root\\n ========================================================================== */\\n\\n.media-default-skin--audio {\\n --media-border-color: oklch(0 0 0 / 0.1);\\n --media-surface-background-color: oklch(1 0 0 / 0.5);\\n --media-surface-inner-border-color: oklch(1 0 0 / 0.1);\\n --media-surface-outer-border-color: oklch(0 0 0 / 0.05);\\n --media-surface-shadow-color: oklch(0 0 0 / 0.15);\\n --media-surface-backdrop-filter: blur(8px) brightness(0.98) saturate(1.2);\\n\\n @media (prefers-color-scheme: dark) {\\n --media-border-color: oklch(1 0 0 / 0.1);\\n --media-surface-background-color: oklch(0 0 0 / 0.4);\\n }\\n}\\n\\n/* ==========================================================================\\n Controls\\n ========================================================================== */\\n\\n.media-default-skin--audio .media-controls {\\n @media (prefers-color-scheme: dark) {\\n color: oklch(1 0 0);\\n }\\n}\\n\\n/* ==========================================================================\\n Sliders\\n ========================================================================== */\\n.media-default-skin--audio .media-slider__track {\\n background-color: oklch(0 0 0 / 0.1);\\n\\n @media (prefers-color-scheme: dark) {\\n background-color: oklch(1 0 0 / 0.2);\\n box-shadow: 0 0 0 1px oklch(0 0 0 / 0.05);\\n }\\n}\\n\\n\";"],"mappings":";AAAA,mBAAe"}
@@ -0,0 +1,6 @@
1
+ //#region inline-css:src/define/video/minimal-skin.js
2
+ var minimal_skin_default = "/* ==========================================================================\n Icon State Visibility for Video Skins\n\n Data-attribute-driven visibility rules for multi-state icon buttons.\n Uses :is() with both element selectors (for HTML custom element wrappers)\n and class selectors (for React rendered SVG elements).\n ========================================================================== */\n\n/* --- All icons hidden by default --- */\n\n.media-button--play .media-icon--restart,\n.media-button--play .media-icon--play,\n.media-button--play .media-icon--pause,\n.media-button--mute .media-icon--volume-off,\n.media-button--mute .media-icon--volume-low,\n.media-button--mute .media-icon--volume-high,\n.media-button--fullscreen .media-icon--fullscreen-enter,\n.media-button--fullscreen .media-icon--fullscreen-exit,\n.media-button--captions .media-icon--captions-off,\n.media-button--captions .media-icon--captions-on {\n display: none;\n opacity: 0;\n}\n\n/* --- Active icon per state --- */\n\n/* Play: ended → restart */\n.media-button--play[data-ended] .media-icon--restart,\n/* Play: paused (not ended) → play */\n.media-button--play:not([data-ended])[data-paused] .media-icon--play,\n/* Play: playing (not paused, not ended) → pause */\n.media-button--play:not([data-paused]):not([data-ended]) .media-icon--pause,\n/* Mute: muted → volume off */\n.media-button--mute[data-muted] .media-icon--volume-off,\n/* Mute: volume low (not muted) → volume low */\n.media-button--mute:not([data-muted])[data-volume-level=\"low\"] .media-icon--volume-low,\n/* Mute: volume high (not muted, not low) → volume high */\n.media-button--mute:not([data-muted]):not([data-volume-level=\"low\"]) .media-icon--volume-high,\n/* Fullscreen: not fullscreen → enter */\n.media-button--fullscreen:not([data-fullscreen]) .media-icon--fullscreen-enter,\n/* Fullscreen: fullscreen → exit */\n.media-button--fullscreen[data-fullscreen] .media-icon--fullscreen-exit,\n/* Captions: not active → captions off */\n.media-button--captions:not([data-active]) .media-icon--captions-off,\n/* Captions: active → captions on */\n.media-button--captions[data-active] .media-icon--captions-on {\n display: block;\n opacity: 1;\n}\n\n/* ==========================================================================\n Tooltip Label State Visibility for Video Skins\n\n Data-attribute-driven visibility rules for multi-state tooltip labels.\n Uses adjacent sibling selectors to match button state → tooltip content.\n ========================================================================== */\n\n/* --- All multi-state labels hidden by default --- */\n\n.media-tooltip-label {\n display: none;\n}\n\n/* --- Active label per state --- */\n\n/* Play: ended → replay */\n.media-button--play[data-ended] + .media-tooltip .media-tooltip-label--replay,\n/* Play: paused (not ended) → play */\n .media-button--play:not([data-ended])[data-paused] + .media-tooltip\n .media-tooltip-label--play,\n/* Play: playing (not paused, not ended) → pause */\n .media-button--play:not([data-paused]):not([data-ended]) + .media-tooltip\n .media-tooltip-label--pause,\n/* Fullscreen: not fullscreen → enter */\n .media-button--fullscreen:not([data-fullscreen]) + .media-tooltip\n .media-tooltip-label--enter-fullscreen,\n/* Fullscreen: fullscreen → exit */\n .media-button--fullscreen[data-fullscreen] + .media-tooltip\n .media-tooltip-label--exit-fullscreen,\n/* Captions: not active → enable */\n .media-button--captions:not([data-active]) + .media-tooltip\n .media-tooltip-label--enable-captions,\n/* Captions: active → disable */\n .media-button--captions[data-active] + .media-tooltip\n .media-tooltip-label--disable-captions,\n/* PiP: not in pip → enter */\n .media-button--pip:not([data-pip]) + .media-tooltip\n .media-tooltip-label--enter-pip,\n/* PiP: in pip → exit */\n .media-button--pip[data-pip] + .media-tooltip\n .media-tooltip-label--exit-pip {\n display: block;\n}\n\n/* ==========================================================================\n Reset\n ========================================================================== */\n\n.media-minimal-skin *,\n.media-minimal-skin *::before,\n.media-minimal-skin *::after {\n box-sizing: border-box;\n margin: 0;\n}\n.media-minimal-skin img,\n.media-minimal-skin video,\n.media-minimal-skin svg {\n display: block;\n max-width: 100%;\n}\n.media-minimal-skin button {\n font: inherit;\n}\n@media (prefers-reduced-motion: no-preference) {\n .media-minimal-skin {\n interpolate-size: allow-keywords;\n }\n}\n\n/* ==========================================================================\n Root Container\n ========================================================================== */\n\n.media-minimal-skin {\n position: relative;\n isolation: isolate;\n display: block;\n container: media-root / inline-size;\n border-radius: var(--media-border-radius, 0.75rem);\n font-family:\n Inter Variable,\n Inter,\n ui-sans-serif,\n system-ui,\n sans-serif;\n font-size: 0.8125rem;\n line-height: 1.5;\n letter-spacing: normal;\n -webkit-font-smoothing: auto;\n -moz-osx-font-smoothing: auto;\n}\n\n/* ==========================================================================\n Media Element\n ========================================================================== */\n\n.media-minimal-skin ::slotted(video),\n.media-minimal-skin video {\n display: block;\n width: 100%;\n height: 100%;\n border-radius: var(--media-border-radius, 0.75rem);\n}\n\n/* ==========================================================================\n Poster Image\n ========================================================================== */\n\n.media-minimal-skin > img {\n position: absolute;\n inset: 0;\n width: 100%;\n height: 100%;\n border-radius: inherit;\n object-fit: cover;\n transition: opacity 0.25s;\n pointer-events: none;\n\n &:not([data-visible]) {\n opacity: 0;\n }\n}\n\n/* ==========================================================================\n Overlay / Scrim\n ========================================================================== */\n\n.media-minimal-skin .media-overlay {\n position: absolute;\n inset: 0;\n border-radius: inherit;\n background-image: linear-gradient(to top, oklch(0 0 0 / 0.7), oklch(0 0 0 / 0.5) 7.5rem, oklch(0 0 0 / 0));\n backdrop-filter: blur(0) saturate(1.2) brightness(0.9);\n opacity: 0;\n transition-property: opacity, backdrop-filter;\n transition-duration: 500ms;\n transition-delay: 500ms;\n transition-timing-function: ease-out;\n pointer-events: none;\n\n @media (prefers-reduced-motion: reduce) {\n transition-duration: 100ms;\n }\n}\n\n.media-minimal-skin .media-controls[data-visible] ~ .media-overlay,\n.media-minimal-skin .media-error[data-open] ~ .media-overlay {\n opacity: 1;\n transition-duration: 150ms;\n transition-delay: 0ms;\n}\n\n.media-minimal-skin .media-error[data-open] ~ .media-overlay {\n backdrop-filter: blur(8px) saturate(1.2) brightness(0.9);\n}\n\n/* ==========================================================================\n Buffering Indicator\n ========================================================================== */\n\n.media-minimal-skin .media-buffering-indicator {\n position: absolute;\n inset: 0;\n display: none;\n align-items: center;\n justify-content: center;\n color: oklch(1 0 0);\n pointer-events: none;\n\n &[data-visible] {\n display: flex;\n }\n}\n\n/* ==========================================================================\n Error Dialog\n ========================================================================== */\n\n.media-minimal-skin .media-error {\n position: absolute;\n inset: 0;\n z-index: 20;\n display: flex;\n align-items: center;\n justify-content: center;\n pointer-events: none;\n}\n\n.media-minimal-skin .media-error__dialog {\n display: flex;\n flex-direction: column;\n gap: 0.75rem;\n max-width: 16rem;\n padding: 1rem;\n color: oklch(1 0 0);\n font-size: 0.875rem;\n text-shadow: 0 1px 0 oklch(0 0 0 / 0.5);\n transition-property: opacity, transform;\n transition-duration: 500ms;\n transition-delay: 100ms;\n transition-timing-function: linear(\n 0,\n 0.034 1.5%,\n 0.763 9.7%,\n 1.066 13.9%,\n 1.198 19.9%,\n 1.184 21.8%,\n 0.963 37.5%,\n 0.997 50.9%,\n 1\n );\n\n /* Simple, fast transition for reduced motion users */\n @media (prefers-reduced-motion: reduce) {\n transition-duration: 100ms;\n transition-delay: 0ms;\n transition-timing-function: ease-out;\n }\n}\n\n.media-minimal-skin .media-error[data-starting-style] .media-error__dialog,\n.media-minimal-skin .media-error[data-ending-style] .media-error__dialog {\n opacity: 0;\n transform: scale(0.5);\n}\n\n.media-minimal-skin .media-error__content {\n display: flex;\n flex-direction: column;\n gap: 0.5rem;\n padding: 0.375rem 0;\n}\n\n.media-minimal-skin .media-error__title {\n font-weight: 600;\n line-height: 1.25;\n}\n\n.media-minimal-skin .media-error__description {\n opacity: 0.7;\n}\n\n.media-minimal-skin .media-error__actions {\n display: flex;\n gap: 0.5rem;\n\n & > * {\n flex: 1;\n }\n}\n\n/* ==========================================================================\n Controls\n ========================================================================== */\n\n.media-minimal-skin .media-controls {\n container: media-controls / inline-size;\n display: flex;\n align-items: center;\n --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.25));\n --media-controls-current-shadow-color-subtle: oklch(\n from var(--media-controls-current-shadow-color) l c h /\n calc(alpha * 0.4)\n );\n text-shadow: 0 0 1px var(--media-controls-current-shadow-color);\n}\n\n/* ==========================================================================\n Time Controls & Display\n ========================================================================== */\n\n.media-minimal-skin .media-time-controls {\n display: flex;\n flex-direction: row-reverse;\n align-items: center;\n flex: 1;\n gap: 0.75rem;\n}\n.media-minimal-skin .media-time {\n display: flex;\n align-items: center;\n gap: 0.25rem;\n}\n.media-minimal-skin .media-time__value {\n font-variant-numeric: tabular-nums;\n}\n.media-minimal-skin .media-time__value--current,\n.media-minimal-skin .media-time__separator {\n display: none;\n}\n@container media-controls (width > 28rem) {\n .media-minimal-skin .media-time-controls {\n flex-direction: row;\n }\n .media-minimal-skin .media-time__value--duration,\n .media-minimal-skin .media-time__separator {\n color: oklch(from currentColor l c h / 0.6);\n }\n .media-minimal-skin .media-time__value--current,\n .media-minimal-skin .media-time__separator {\n display: inline;\n }\n}\n\n/* ==========================================================================\n Button Groups\n ========================================================================== */\n\n.media-minimal-skin .media-button-group {\n display: flex;\n align-items: center;\n gap: 0.075rem;\n\n @container media-root (width > 40rem) {\n gap: 0.125rem;\n }\n}\n\n/* ==========================================================================\n Buttons\n ========================================================================== */\n\n/* Base button */\n.media-minimal-skin .media-button {\n display: flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n padding: 0.5rem 1rem;\n background: oklch(1 0 0);\n border: none;\n border-radius: 0.5rem;\n outline: 2px solid transparent;\n outline-offset: -2px;\n color: oklch(0 0 0);\n font-weight: 500;\n text-align: center;\n text-shadow: inherit;\n transition-property: background-color, color, outline-offset, transform;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n cursor: pointer;\n user-select: none;\n\n &:focus-visible {\n outline-color: currentColor;\n outline-offset: 2px;\n }\n\n &[disabled] {\n opacity: 0.5;\n filter: grayscale(1);\n cursor: not-allowed;\n }\n\n &[data-availability=\"unavailable\"] {\n display: none;\n }\n}\n\n/* Icon button variant */\n.media-minimal-skin .media-button--icon {\n display: grid;\n width: 2.375rem;\n padding: 0;\n aspect-ratio: 1;\n background: transparent;\n color: inherit;\n\n &:hover,\n &:focus-visible,\n &[aria-expanded=\"true\"] {\n color: oklch(from currentColor l c h / 0.8);\n text-decoration: none;\n }\n\n &:active {\n transform: scale(0.9);\n }\n\n & .media-icon {\n filter: drop-shadow(0 1px 0 var(--media-controls-current-shadow-color, oklch(0 0 0 / 0.25)));\n }\n}\n\n/* Seek button */\n.media-minimal-skin .media-button--seek {\n & .media-icon__label {\n position: absolute;\n right: -1px;\n bottom: -3px;\n font-size: 0.75em;\n font-weight: 480;\n font-variant-numeric: tabular-nums;\n }\n\n &:has(.media-icon--flipped) .media-icon__label {\n right: unset;\n left: -1px;\n }\n\n @container media-controls (width < 28rem) {\n display: none;\n }\n}\n\n/* Playback rate button */\n.media-minimal-skin .media-button--playback-rate {\n padding: 0;\n\n &::after {\n content: attr(data-rate) \"\\00D7\";\n width: 4ch;\n font-variant-numeric: tabular-nums;\n }\n}\n\n/* ==========================================================================\n Icons\n ========================================================================== */\n\n.media-minimal-skin .media-icon__container {\n position: relative;\n}\n.media-minimal-skin .media-icon {\n display: block;\n flex-shrink: 0;\n grid-area: 1 / 1;\n width: 18px;\n height: 18px;\n transition-behavior: allow-discrete;\n transition-property: display, opacity;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n}\n.media-minimal-skin .media-icon--flipped {\n scale: -1 1;\n}\n\n/* ==========================================================================\n Slider\n ========================================================================== */\n\n.media-minimal-skin .media-slider {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n flex: 1;\n border-radius: calc(infinity * 1px);\n outline: none;\n\n &[data-orientation=\"horizontal\"] {\n min-width: 5rem;\n width: 100%;\n height: 1.25rem;\n }\n\n &[data-orientation=\"vertical\"] {\n width: 1.25rem;\n height: 4.5rem;\n }\n}\n\n/* Track */\n.media-minimal-skin .media-slider__track {\n position: relative;\n isolation: isolate;\n overflow: hidden;\n border-radius: inherit;\n user-select: none;\n background-color: oklch(from currentColor l c h / 0.2);\n\n &[data-orientation=\"horizontal\"] {\n width: 100%;\n height: 0.1875rem;\n }\n\n &[data-orientation=\"vertical\"] {\n width: 0.1875rem;\n height: 100%;\n }\n}\n\n/* Thumb */\n.media-minimal-skin .media-slider__thumb {\n position: absolute;\n transform: translate(-50%, -50%);\n z-index: 10;\n width: 0.75rem;\n height: 0.75rem;\n background-color: currentColor;\n border-radius: calc(infinity * 1px);\n box-shadow:\n 0 0 0 1px var(--media-controls-current-shadow-color-subtle, oklch(0 0 0 / 0.1)),\n 0 1px 3px 0 oklch(0 0 0 / 0.15),\n 0 1px 2px -1px oklch(0 0 0 / 0.15);\n opacity: 0;\n scale: 0.7;\n transform-origin: center;\n transition-property: opacity, scale, outline-offset;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n user-select: none;\n outline: 2px solid transparent;\n outline-offset: -2px;\n\n &[data-orientation=\"horizontal\"] {\n top: 50%;\n left: var(--media-slider-fill);\n }\n\n &[data-orientation=\"vertical\"] {\n left: 50%;\n top: calc(100% - var(--media-slider-fill));\n }\n\n &:focus-visible {\n outline-color: currentColor;\n outline-offset: 2px;\n }\n}\n\n.media-minimal-skin .media-slider:hover .media-slider__thumb,\n.media-minimal-skin .media-slider:focus-within .media-slider__thumb,\n.media-minimal-skin .media-slider__thumb--persistent {\n opacity: 1;\n scale: 1;\n}\n\n/* Shared track fills */\n.media-minimal-skin .media-slider__buffer,\n.media-minimal-skin .media-slider__fill {\n position: absolute;\n border-radius: inherit;\n pointer-events: none;\n}\n\n.media-minimal-skin .media-slider__buffer[data-orientation=\"horizontal\"],\n.media-minimal-skin .media-slider__fill[data-orientation=\"horizontal\"] {\n inset-block: 0;\n left: 0;\n}\n\n.media-minimal-skin .media-slider__buffer[data-orientation=\"vertical\"],\n.media-minimal-skin .media-slider__fill[data-orientation=\"vertical\"] {\n inset-inline: 0;\n bottom: 0;\n}\n\n/* Buffer */\n.media-minimal-skin .media-slider__buffer {\n background-color: oklch(from currentColor l c h / 0.2);\n transition-duration: 0.25s;\n transition-timing-function: ease-out;\n\n &[data-orientation=\"horizontal\"] {\n width: var(--media-slider-buffer);\n transition-property: width;\n }\n\n &[data-orientation=\"vertical\"] {\n height: var(--media-slider-buffer);\n transition-property: height;\n }\n}\n\n/* Fill */\n.media-minimal-skin .media-slider__fill {\n background-color: currentColor;\n\n &[data-orientation=\"horizontal\"] {\n width: var(--media-slider-fill);\n }\n\n &[data-orientation=\"vertical\"] {\n height: var(--media-slider-fill);\n }\n}\n\n/* Time display within slider */\n.media-minimal-skin .media-slider__time-display {\n font-variant-numeric: tabular-nums;\n}\n\n/* ==========================================================================\n Popups & Animations\n ========================================================================== */\n\n.media-minimal-skin .media-popover,\n.media-minimal-skin .media-tooltip {\n margin: 0;\n border: 0;\n color: inherit;\n overflow: visible;\n transition-property: transform, scale, opacity, filter;\n transition-duration: 200ms;\n\n &[data-starting-style],\n &[data-ending-style] {\n opacity: 0;\n transform: scale(0);\n filter: blur(8px);\n }\n\n &[data-instant] {\n transition-duration: 0ms;\n }\n\n &[data-side=\"top\"] {\n transform-origin: bottom;\n }\n &[data-side=\"bottom\"] {\n transform-origin: top;\n }\n &[data-side=\"left\"] {\n transform-origin: right;\n }\n &[data-side=\"right\"] {\n transform-origin: left;\n }\n}\n\n.media-minimal-skin .media-tooltip {\n padding: 0.25rem 0.5rem;\n border-radius: 0.25rem;\n background-color: oklch(1 0 0 / 0.1);\n backdrop-filter: blur(64px) brightness(0.9) saturate(1.5);\n box-shadow:\n 0 4px 6px -1px oklch(0 0 0 / 0.1),\n 0 2px 4px -2px oklch(0 0 0 / 0.1);\n font-size: 0.75rem;\n white-space: nowrap;\n --media-tooltip-side-offset: 0.5rem;\n\n @media (prefers-reduced-transparency: reduce) {\n background-color: oklch(0 0 0 / 0.7);\n }\n\n @media (prefers-contrast: more) {\n background-color: oklch(0 0 0 / 0.9);\n }\n}\n\n/* ==========================================================================\n Captions\n ========================================================================== */\n\n.media-minimal-skin .media-captions {\n position: absolute;\n inset: auto 1rem 1.5rem 1rem;\n z-index: 20;\n font-size: 1rem;\n text-wrap: balance;\n pointer-events: none;\n\n @container media-root (width > 20rem) {\n font-size: 1.5rem;\n }\n\n @container media-root (width > 48rem) {\n font-size: 1.875rem;\n }\n\n @container media-root (width > 80rem) {\n font-size: 2.25rem;\n }\n}\n\n.media-minimal-skin .media-captions__container {\n display: flex;\n flex-direction: column;\n align-items: center;\n max-width: 42ch;\n margin: 0 auto;\n text-align: center;\n}\n\n.media-minimal-skin .media-captions__text {\n display: block;\n padding: 0.125rem 0.5rem;\n color: oklch(1 0 0);\n text-shadow:\n 0 0 1px oklch(0 0 0 / 0.7),\n 0 0 8px oklch(0 0 0 / 0.7);\n text-align: center;\n white-space: pre-wrap;\n line-height: 1.2;\n\n @media (prefers-contrast: more) {\n background: oklch(0 0 0 / 0.7);\n text-shadow: none;\n box-decoration-break: clone;\n }\n\n & > * {\n display: inline;\n }\n}\n\n/* Caption shifting styles (custom and native) */\n.media-minimal-skin {\n --media-caption-track-delay: 600ms;\n --media-caption-track-y: -0.5rem;\n\n &:has(.media-controls[data-visible]) {\n --media-caption-track-delay: 25ms;\n --media-caption-track-y: -3rem;\n }\n}\n\n.media-minimal-skin .media-captions,\n.media-minimal-skin video::-webkit-media-text-track-container {\n /* NOTE: The delay must account for the controls delay/duration */\n transition: transform 150ms ease-out;\n transition-delay: var(--media-caption-track-delay);\n}\n\n.media-minimal-skin video::-webkit-media-text-track-container {\n transform: translateY(var(--media-caption-track-y)) scale(0.98);\n z-index: 1;\n font-family: inherit;\n}\n\n/* When controls are visible, shift captions up to avoid overlap */\n.media-minimal-skin .media-controls[data-visible] ~ .media-captions {\n transform: translateY(calc(var(--media-caption-track-y) - 0.5rem));\n}\n\n@media (prefers-reduced-motion: reduce) {\n .media-minimal-skin .media-captions,\n .media-minimal-skin video::-webkit-media-text-track-container {\n transition-duration: 50ms;\n }\n}\n\n\n/* ==========================================================================\n Root\n ========================================================================== */\n\n.media-minimal-skin--video {\n background: oklch(0 0 0);\n\n /* Border ring */\n &::after {\n content: \"\";\n position: absolute;\n inset: 0;\n z-index: 10;\n border-radius: inherit;\n box-shadow: inset 0 0 0 1px oklch(0 0 0 / 0.15);\n pointer-events: none;\n\n @media (prefers-color-scheme: dark) {\n box-shadow: inset 0 0 0 1px oklch(1 0 0 / 0.15);\n }\n }\n\n /* Fullscreen */\n &:fullscreen {\n border-radius: 0;\n }\n}\n\n/* ==========================================================================\n Controls (hide/show behavior)\n ========================================================================== */\n\n.media-minimal-skin--video .media-controls {\n position: absolute;\n bottom: 0;\n inset-inline: 0;\n z-index: 10;\n gap: 0.5rem;\n padding: 2rem 0.375rem 0.375rem 0.375rem;\n will-change: transform, filter, opacity;\n transition-property: transform, filter, opacity;\n transition-duration: 75ms;\n transition-delay: 0ms;\n transition-timing-function: ease-out;\n color: oklch(1 0 0);\n\n @container media-root (width > 40rem) {\n gap: 0.875rem;\n padding: 2.5rem 0.75rem 0.75rem 0.75rem;\n }\n\n &:not([data-visible]) {\n opacity: 0;\n transform: translateY(100%);\n filter: blur(8px);\n transition-duration: 500ms;\n transition-delay: 500ms;\n pointer-events: none;\n\n @media (prefers-reduced-motion: reduce) {\n scale: 1;\n transform: translateY(0);\n filter: blur(0);\n transition-duration: 100ms;\n }\n }\n}\n\n/* ==========================================================================\n Sliders\n ========================================================================== */\n\n.media-minimal-skin--video .media-slider__track {\n box-shadow: 0 0 0 1px oklch(0 0 0 / 0.05);\n}\n\n/* ==========================================================================\n Popups & Animations\n ========================================================================== */\n\n.media-minimal-skin--video .media-popover--volume {\n --media-popover-side-offset: 0.5rem;\n background: transparent;\n padding: 0.25rem;\n}\n\n";
3
+
4
+ //#endregion
5
+ export { minimal_skin_default as default };
6
+ //# sourceMappingURL=minimal-skin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"minimal-skin.js","names":[],"sources":["../../../../../../inline-css:src/define/video/minimal-skin.js"],"sourcesContent":["export default \"/* ==========================================================================\\n Icon State Visibility for Video Skins\\n\\n Data-attribute-driven visibility rules for multi-state icon buttons.\\n Uses :is() with both element selectors (for HTML custom element wrappers)\\n and class selectors (for React rendered SVG elements).\\n ========================================================================== */\\n\\n/* --- All icons hidden by default --- */\\n\\n.media-button--play .media-icon--restart,\\n.media-button--play .media-icon--play,\\n.media-button--play .media-icon--pause,\\n.media-button--mute .media-icon--volume-off,\\n.media-button--mute .media-icon--volume-low,\\n.media-button--mute .media-icon--volume-high,\\n.media-button--fullscreen .media-icon--fullscreen-enter,\\n.media-button--fullscreen .media-icon--fullscreen-exit,\\n.media-button--captions .media-icon--captions-off,\\n.media-button--captions .media-icon--captions-on {\\n display: none;\\n opacity: 0;\\n}\\n\\n/* --- Active icon per state --- */\\n\\n/* Play: ended → restart */\\n.media-button--play[data-ended] .media-icon--restart,\\n/* Play: paused (not ended) → play */\\n.media-button--play:not([data-ended])[data-paused] .media-icon--play,\\n/* Play: playing (not paused, not ended) → pause */\\n.media-button--play:not([data-paused]):not([data-ended]) .media-icon--pause,\\n/* Mute: muted → volume off */\\n.media-button--mute[data-muted] .media-icon--volume-off,\\n/* Mute: volume low (not muted) → volume low */\\n.media-button--mute:not([data-muted])[data-volume-level=\\\"low\\\"] .media-icon--volume-low,\\n/* Mute: volume high (not muted, not low) → volume high */\\n.media-button--mute:not([data-muted]):not([data-volume-level=\\\"low\\\"]) .media-icon--volume-high,\\n/* Fullscreen: not fullscreen → enter */\\n.media-button--fullscreen:not([data-fullscreen]) .media-icon--fullscreen-enter,\\n/* Fullscreen: fullscreen → exit */\\n.media-button--fullscreen[data-fullscreen] .media-icon--fullscreen-exit,\\n/* Captions: not active → captions off */\\n.media-button--captions:not([data-active]) .media-icon--captions-off,\\n/* Captions: active → captions on */\\n.media-button--captions[data-active] .media-icon--captions-on {\\n display: block;\\n opacity: 1;\\n}\\n\\n/* ==========================================================================\\n Tooltip Label State Visibility for Video Skins\\n\\n Data-attribute-driven visibility rules for multi-state tooltip labels.\\n Uses adjacent sibling selectors to match button state → tooltip content.\\n ========================================================================== */\\n\\n/* --- All multi-state labels hidden by default --- */\\n\\n.media-tooltip-label {\\n display: none;\\n}\\n\\n/* --- Active label per state --- */\\n\\n/* Play: ended → replay */\\n.media-button--play[data-ended] + .media-tooltip .media-tooltip-label--replay,\\n/* Play: paused (not ended) → play */\\n .media-button--play:not([data-ended])[data-paused] + .media-tooltip\\n .media-tooltip-label--play,\\n/* Play: playing (not paused, not ended) → pause */\\n .media-button--play:not([data-paused]):not([data-ended]) + .media-tooltip\\n .media-tooltip-label--pause,\\n/* Fullscreen: not fullscreen → enter */\\n .media-button--fullscreen:not([data-fullscreen]) + .media-tooltip\\n .media-tooltip-label--enter-fullscreen,\\n/* Fullscreen: fullscreen → exit */\\n .media-button--fullscreen[data-fullscreen] + .media-tooltip\\n .media-tooltip-label--exit-fullscreen,\\n/* Captions: not active → enable */\\n .media-button--captions:not([data-active]) + .media-tooltip\\n .media-tooltip-label--enable-captions,\\n/* Captions: active → disable */\\n .media-button--captions[data-active] + .media-tooltip\\n .media-tooltip-label--disable-captions,\\n/* PiP: not in pip → enter */\\n .media-button--pip:not([data-pip]) + .media-tooltip\\n .media-tooltip-label--enter-pip,\\n/* PiP: in pip → exit */\\n .media-button--pip[data-pip] + .media-tooltip\\n .media-tooltip-label--exit-pip {\\n display: block;\\n}\\n\\n/* ==========================================================================\\n Reset\\n ========================================================================== */\\n\\n.media-minimal-skin *,\\n.media-minimal-skin *::before,\\n.media-minimal-skin *::after {\\n box-sizing: border-box;\\n margin: 0;\\n}\\n.media-minimal-skin img,\\n.media-minimal-skin video,\\n.media-minimal-skin svg {\\n display: block;\\n max-width: 100%;\\n}\\n.media-minimal-skin button {\\n font: inherit;\\n}\\n@media (prefers-reduced-motion: no-preference) {\\n .media-minimal-skin {\\n interpolate-size: allow-keywords;\\n }\\n}\\n\\n/* ==========================================================================\\n Root Container\\n ========================================================================== */\\n\\n.media-minimal-skin {\\n position: relative;\\n isolation: isolate;\\n display: block;\\n container: media-root / inline-size;\\n border-radius: var(--media-border-radius, 0.75rem);\\n font-family:\\n Inter Variable,\\n Inter,\\n ui-sans-serif,\\n system-ui,\\n sans-serif;\\n font-size: 0.8125rem;\\n line-height: 1.5;\\n letter-spacing: normal;\\n -webkit-font-smoothing: auto;\\n -moz-osx-font-smoothing: auto;\\n}\\n\\n/* ==========================================================================\\n Media Element\\n ========================================================================== */\\n\\n.media-minimal-skin ::slotted(video),\\n.media-minimal-skin video {\\n display: block;\\n width: 100%;\\n height: 100%;\\n border-radius: var(--media-border-radius, 0.75rem);\\n}\\n\\n/* ==========================================================================\\n Poster Image\\n ========================================================================== */\\n\\n.media-minimal-skin > img {\\n position: absolute;\\n inset: 0;\\n width: 100%;\\n height: 100%;\\n border-radius: inherit;\\n object-fit: cover;\\n transition: opacity 0.25s;\\n pointer-events: none;\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n }\\n}\\n\\n/* ==========================================================================\\n Overlay / Scrim\\n ========================================================================== */\\n\\n.media-minimal-skin .media-overlay {\\n position: absolute;\\n inset: 0;\\n border-radius: inherit;\\n background-image: linear-gradient(to top, oklch(0 0 0 / 0.7), oklch(0 0 0 / 0.5) 7.5rem, oklch(0 0 0 / 0));\\n backdrop-filter: blur(0) saturate(1.2) brightness(0.9);\\n opacity: 0;\\n transition-property: opacity, backdrop-filter;\\n transition-duration: 500ms;\\n transition-delay: 500ms;\\n transition-timing-function: ease-out;\\n pointer-events: none;\\n\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n }\\n}\\n\\n.media-minimal-skin .media-controls[data-visible] ~ .media-overlay,\\n.media-minimal-skin .media-error[data-open] ~ .media-overlay {\\n opacity: 1;\\n transition-duration: 150ms;\\n transition-delay: 0ms;\\n}\\n\\n.media-minimal-skin .media-error[data-open] ~ .media-overlay {\\n backdrop-filter: blur(8px) saturate(1.2) brightness(0.9);\\n}\\n\\n/* ==========================================================================\\n Buffering Indicator\\n ========================================================================== */\\n\\n.media-minimal-skin .media-buffering-indicator {\\n position: absolute;\\n inset: 0;\\n display: none;\\n align-items: center;\\n justify-content: center;\\n color: oklch(1 0 0);\\n pointer-events: none;\\n\\n &[data-visible] {\\n display: flex;\\n }\\n}\\n\\n/* ==========================================================================\\n Error Dialog\\n ========================================================================== */\\n\\n.media-minimal-skin .media-error {\\n position: absolute;\\n inset: 0;\\n z-index: 20;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n pointer-events: none;\\n}\\n\\n.media-minimal-skin .media-error__dialog {\\n display: flex;\\n flex-direction: column;\\n gap: 0.75rem;\\n max-width: 16rem;\\n padding: 1rem;\\n color: oklch(1 0 0);\\n font-size: 0.875rem;\\n text-shadow: 0 1px 0 oklch(0 0 0 / 0.5);\\n transition-property: opacity, transform;\\n transition-duration: 500ms;\\n transition-delay: 100ms;\\n transition-timing-function: linear(\\n 0,\\n 0.034 1.5%,\\n 0.763 9.7%,\\n 1.066 13.9%,\\n 1.198 19.9%,\\n 1.184 21.8%,\\n 0.963 37.5%,\\n 0.997 50.9%,\\n 1\\n );\\n\\n /* Simple, fast transition for reduced motion users */\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n transition-delay: 0ms;\\n transition-timing-function: ease-out;\\n }\\n}\\n\\n.media-minimal-skin .media-error[data-starting-style] .media-error__dialog,\\n.media-minimal-skin .media-error[data-ending-style] .media-error__dialog {\\n opacity: 0;\\n transform: scale(0.5);\\n}\\n\\n.media-minimal-skin .media-error__content {\\n display: flex;\\n flex-direction: column;\\n gap: 0.5rem;\\n padding: 0.375rem 0;\\n}\\n\\n.media-minimal-skin .media-error__title {\\n font-weight: 600;\\n line-height: 1.25;\\n}\\n\\n.media-minimal-skin .media-error__description {\\n opacity: 0.7;\\n}\\n\\n.media-minimal-skin .media-error__actions {\\n display: flex;\\n gap: 0.5rem;\\n\\n & > * {\\n flex: 1;\\n }\\n}\\n\\n/* ==========================================================================\\n Controls\\n ========================================================================== */\\n\\n.media-minimal-skin .media-controls {\\n container: media-controls / inline-size;\\n display: flex;\\n align-items: center;\\n --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.25));\\n --media-controls-current-shadow-color-subtle: oklch(\\n from var(--media-controls-current-shadow-color) l c h /\\n calc(alpha * 0.4)\\n );\\n text-shadow: 0 0 1px var(--media-controls-current-shadow-color);\\n}\\n\\n/* ==========================================================================\\n Time Controls & Display\\n ========================================================================== */\\n\\n.media-minimal-skin .media-time-controls {\\n display: flex;\\n flex-direction: row-reverse;\\n align-items: center;\\n flex: 1;\\n gap: 0.75rem;\\n}\\n.media-minimal-skin .media-time {\\n display: flex;\\n align-items: center;\\n gap: 0.25rem;\\n}\\n.media-minimal-skin .media-time__value {\\n font-variant-numeric: tabular-nums;\\n}\\n.media-minimal-skin .media-time__value--current,\\n.media-minimal-skin .media-time__separator {\\n display: none;\\n}\\n@container media-controls (width > 28rem) {\\n .media-minimal-skin .media-time-controls {\\n flex-direction: row;\\n }\\n .media-minimal-skin .media-time__value--duration,\\n .media-minimal-skin .media-time__separator {\\n color: oklch(from currentColor l c h / 0.6);\\n }\\n .media-minimal-skin .media-time__value--current,\\n .media-minimal-skin .media-time__separator {\\n display: inline;\\n }\\n}\\n\\n/* ==========================================================================\\n Button Groups\\n ========================================================================== */\\n\\n.media-minimal-skin .media-button-group {\\n display: flex;\\n align-items: center;\\n gap: 0.075rem;\\n\\n @container media-root (width > 40rem) {\\n gap: 0.125rem;\\n }\\n}\\n\\n/* ==========================================================================\\n Buttons\\n ========================================================================== */\\n\\n/* Base button */\\n.media-minimal-skin .media-button {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-shrink: 0;\\n padding: 0.5rem 1rem;\\n background: oklch(1 0 0);\\n border: none;\\n border-radius: 0.5rem;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n color: oklch(0 0 0);\\n font-weight: 500;\\n text-align: center;\\n text-shadow: inherit;\\n transition-property: background-color, color, outline-offset, transform;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n cursor: pointer;\\n user-select: none;\\n\\n &:focus-visible {\\n outline-color: currentColor;\\n outline-offset: 2px;\\n }\\n\\n &[disabled] {\\n opacity: 0.5;\\n filter: grayscale(1);\\n cursor: not-allowed;\\n }\\n\\n &[data-availability=\\\"unavailable\\\"] {\\n display: none;\\n }\\n}\\n\\n/* Icon button variant */\\n.media-minimal-skin .media-button--icon {\\n display: grid;\\n width: 2.375rem;\\n padding: 0;\\n aspect-ratio: 1;\\n background: transparent;\\n color: inherit;\\n\\n &:hover,\\n &:focus-visible,\\n &[aria-expanded=\\\"true\\\"] {\\n color: oklch(from currentColor l c h / 0.8);\\n text-decoration: none;\\n }\\n\\n &:active {\\n transform: scale(0.9);\\n }\\n\\n & .media-icon {\\n filter: drop-shadow(0 1px 0 var(--media-controls-current-shadow-color, oklch(0 0 0 / 0.25)));\\n }\\n}\\n\\n/* Seek button */\\n.media-minimal-skin .media-button--seek {\\n & .media-icon__label {\\n position: absolute;\\n right: -1px;\\n bottom: -3px;\\n font-size: 0.75em;\\n font-weight: 480;\\n font-variant-numeric: tabular-nums;\\n }\\n\\n &:has(.media-icon--flipped) .media-icon__label {\\n right: unset;\\n left: -1px;\\n }\\n\\n @container media-controls (width < 28rem) {\\n display: none;\\n }\\n}\\n\\n/* Playback rate button */\\n.media-minimal-skin .media-button--playback-rate {\\n padding: 0;\\n\\n &::after {\\n content: attr(data-rate) \\\"\\\\00D7\\\";\\n width: 4ch;\\n font-variant-numeric: tabular-nums;\\n }\\n}\\n\\n/* ==========================================================================\\n Icons\\n ========================================================================== */\\n\\n.media-minimal-skin .media-icon__container {\\n position: relative;\\n}\\n.media-minimal-skin .media-icon {\\n display: block;\\n flex-shrink: 0;\\n grid-area: 1 / 1;\\n width: 18px;\\n height: 18px;\\n transition-behavior: allow-discrete;\\n transition-property: display, opacity;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n}\\n.media-minimal-skin .media-icon--flipped {\\n scale: -1 1;\\n}\\n\\n/* ==========================================================================\\n Slider\\n ========================================================================== */\\n\\n.media-minimal-skin .media-slider {\\n position: relative;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex: 1;\\n border-radius: calc(infinity * 1px);\\n outline: none;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n min-width: 5rem;\\n width: 100%;\\n height: 1.25rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 1.25rem;\\n height: 4.5rem;\\n }\\n}\\n\\n/* Track */\\n.media-minimal-skin .media-slider__track {\\n position: relative;\\n isolation: isolate;\\n overflow: hidden;\\n border-radius: inherit;\\n user-select: none;\\n background-color: oklch(from currentColor l c h / 0.2);\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: 100%;\\n height: 0.1875rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 0.1875rem;\\n height: 100%;\\n }\\n}\\n\\n/* Thumb */\\n.media-minimal-skin .media-slider__thumb {\\n position: absolute;\\n transform: translate(-50%, -50%);\\n z-index: 10;\\n width: 0.75rem;\\n height: 0.75rem;\\n background-color: currentColor;\\n border-radius: calc(infinity * 1px);\\n box-shadow:\\n 0 0 0 1px var(--media-controls-current-shadow-color-subtle, oklch(0 0 0 / 0.1)),\\n 0 1px 3px 0 oklch(0 0 0 / 0.15),\\n 0 1px 2px -1px oklch(0 0 0 / 0.15);\\n opacity: 0;\\n scale: 0.7;\\n transform-origin: center;\\n transition-property: opacity, scale, outline-offset;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n user-select: none;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n top: 50%;\\n left: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n left: 50%;\\n top: calc(100% - var(--media-slider-fill));\\n }\\n\\n &:focus-visible {\\n outline-color: currentColor;\\n outline-offset: 2px;\\n }\\n}\\n\\n.media-minimal-skin .media-slider:hover .media-slider__thumb,\\n.media-minimal-skin .media-slider:focus-within .media-slider__thumb,\\n.media-minimal-skin .media-slider__thumb--persistent {\\n opacity: 1;\\n scale: 1;\\n}\\n\\n/* Shared track fills */\\n.media-minimal-skin .media-slider__buffer,\\n.media-minimal-skin .media-slider__fill {\\n position: absolute;\\n border-radius: inherit;\\n pointer-events: none;\\n}\\n\\n.media-minimal-skin .media-slider__buffer[data-orientation=\\\"horizontal\\\"],\\n.media-minimal-skin .media-slider__fill[data-orientation=\\\"horizontal\\\"] {\\n inset-block: 0;\\n left: 0;\\n}\\n\\n.media-minimal-skin .media-slider__buffer[data-orientation=\\\"vertical\\\"],\\n.media-minimal-skin .media-slider__fill[data-orientation=\\\"vertical\\\"] {\\n inset-inline: 0;\\n bottom: 0;\\n}\\n\\n/* Buffer */\\n.media-minimal-skin .media-slider__buffer {\\n background-color: oklch(from currentColor l c h / 0.2);\\n transition-duration: 0.25s;\\n transition-timing-function: ease-out;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-buffer);\\n transition-property: width;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-buffer);\\n transition-property: height;\\n }\\n}\\n\\n/* Fill */\\n.media-minimal-skin .media-slider__fill {\\n background-color: currentColor;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-fill);\\n }\\n}\\n\\n/* Time display within slider */\\n.media-minimal-skin .media-slider__time-display {\\n font-variant-numeric: tabular-nums;\\n}\\n\\n/* ==========================================================================\\n Popups & Animations\\n ========================================================================== */\\n\\n.media-minimal-skin .media-popover,\\n.media-minimal-skin .media-tooltip {\\n margin: 0;\\n border: 0;\\n color: inherit;\\n overflow: visible;\\n transition-property: transform, scale, opacity, filter;\\n transition-duration: 200ms;\\n\\n &[data-starting-style],\\n &[data-ending-style] {\\n opacity: 0;\\n transform: scale(0);\\n filter: blur(8px);\\n }\\n\\n &[data-instant] {\\n transition-duration: 0ms;\\n }\\n\\n &[data-side=\\\"top\\\"] {\\n transform-origin: bottom;\\n }\\n &[data-side=\\\"bottom\\\"] {\\n transform-origin: top;\\n }\\n &[data-side=\\\"left\\\"] {\\n transform-origin: right;\\n }\\n &[data-side=\\\"right\\\"] {\\n transform-origin: left;\\n }\\n}\\n\\n.media-minimal-skin .media-tooltip {\\n padding: 0.25rem 0.5rem;\\n border-radius: 0.25rem;\\n background-color: oklch(1 0 0 / 0.1);\\n backdrop-filter: blur(64px) brightness(0.9) saturate(1.5);\\n box-shadow:\\n 0 4px 6px -1px oklch(0 0 0 / 0.1),\\n 0 2px 4px -2px oklch(0 0 0 / 0.1);\\n font-size: 0.75rem;\\n white-space: nowrap;\\n --media-tooltip-side-offset: 0.5rem;\\n\\n @media (prefers-reduced-transparency: reduce) {\\n background-color: oklch(0 0 0 / 0.7);\\n }\\n\\n @media (prefers-contrast: more) {\\n background-color: oklch(0 0 0 / 0.9);\\n }\\n}\\n\\n/* ==========================================================================\\n Captions\\n ========================================================================== */\\n\\n.media-minimal-skin .media-captions {\\n position: absolute;\\n inset: auto 1rem 1.5rem 1rem;\\n z-index: 20;\\n font-size: 1rem;\\n text-wrap: balance;\\n pointer-events: none;\\n\\n @container media-root (width > 20rem) {\\n font-size: 1.5rem;\\n }\\n\\n @container media-root (width > 48rem) {\\n font-size: 1.875rem;\\n }\\n\\n @container media-root (width > 80rem) {\\n font-size: 2.25rem;\\n }\\n}\\n\\n.media-minimal-skin .media-captions__container {\\n display: flex;\\n flex-direction: column;\\n align-items: center;\\n max-width: 42ch;\\n margin: 0 auto;\\n text-align: center;\\n}\\n\\n.media-minimal-skin .media-captions__text {\\n display: block;\\n padding: 0.125rem 0.5rem;\\n color: oklch(1 0 0);\\n text-shadow:\\n 0 0 1px oklch(0 0 0 / 0.7),\\n 0 0 8px oklch(0 0 0 / 0.7);\\n text-align: center;\\n white-space: pre-wrap;\\n line-height: 1.2;\\n\\n @media (prefers-contrast: more) {\\n background: oklch(0 0 0 / 0.7);\\n text-shadow: none;\\n box-decoration-break: clone;\\n }\\n\\n & > * {\\n display: inline;\\n }\\n}\\n\\n/* Caption shifting styles (custom and native) */\\n.media-minimal-skin {\\n --media-caption-track-delay: 600ms;\\n --media-caption-track-y: -0.5rem;\\n\\n &:has(.media-controls[data-visible]) {\\n --media-caption-track-delay: 25ms;\\n --media-caption-track-y: -3rem;\\n }\\n}\\n\\n.media-minimal-skin .media-captions,\\n.media-minimal-skin video::-webkit-media-text-track-container {\\n /* NOTE: The delay must account for the controls delay/duration */\\n transition: transform 150ms ease-out;\\n transition-delay: var(--media-caption-track-delay);\\n}\\n\\n.media-minimal-skin video::-webkit-media-text-track-container {\\n transform: translateY(var(--media-caption-track-y)) scale(0.98);\\n z-index: 1;\\n font-family: inherit;\\n}\\n\\n/* When controls are visible, shift captions up to avoid overlap */\\n.media-minimal-skin .media-controls[data-visible] ~ .media-captions {\\n transform: translateY(calc(var(--media-caption-track-y) - 0.5rem));\\n}\\n\\n@media (prefers-reduced-motion: reduce) {\\n .media-minimal-skin .media-captions,\\n .media-minimal-skin video::-webkit-media-text-track-container {\\n transition-duration: 50ms;\\n }\\n}\\n\\n\\n/* ==========================================================================\\n Root\\n ========================================================================== */\\n\\n.media-minimal-skin--video {\\n background: oklch(0 0 0);\\n\\n /* Border ring */\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n z-index: 10;\\n border-radius: inherit;\\n box-shadow: inset 0 0 0 1px oklch(0 0 0 / 0.15);\\n pointer-events: none;\\n\\n @media (prefers-color-scheme: dark) {\\n box-shadow: inset 0 0 0 1px oklch(1 0 0 / 0.15);\\n }\\n }\\n\\n /* Fullscreen */\\n &:fullscreen {\\n border-radius: 0;\\n }\\n}\\n\\n/* ==========================================================================\\n Controls (hide/show behavior)\\n ========================================================================== */\\n\\n.media-minimal-skin--video .media-controls {\\n position: absolute;\\n bottom: 0;\\n inset-inline: 0;\\n z-index: 10;\\n gap: 0.5rem;\\n padding: 2rem 0.375rem 0.375rem 0.375rem;\\n will-change: transform, filter, opacity;\\n transition-property: transform, filter, opacity;\\n transition-duration: 75ms;\\n transition-delay: 0ms;\\n transition-timing-function: ease-out;\\n color: oklch(1 0 0);\\n\\n @container media-root (width > 40rem) {\\n gap: 0.875rem;\\n padding: 2.5rem 0.75rem 0.75rem 0.75rem;\\n }\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n transform: translateY(100%);\\n filter: blur(8px);\\n transition-duration: 500ms;\\n transition-delay: 500ms;\\n pointer-events: none;\\n\\n @media (prefers-reduced-motion: reduce) {\\n scale: 1;\\n transform: translateY(0);\\n filter: blur(0);\\n transition-duration: 100ms;\\n }\\n }\\n}\\n\\n/* ==========================================================================\\n Sliders\\n ========================================================================== */\\n\\n.media-minimal-skin--video .media-slider__track {\\n box-shadow: 0 0 0 1px oklch(0 0 0 / 0.05);\\n}\\n\\n/* ==========================================================================\\n Popups & Animations\\n ========================================================================== */\\n\\n.media-minimal-skin--video .media-popover--volume {\\n --media-popover-side-offset: 0.5rem;\\n background: transparent;\\n padding: 0.25rem;\\n}\\n\\n\";"],"mappings":";AAAA,2BAAe"}
@@ -0,0 +1,6 @@
1
+ //#region inline-css:src/define/video/skin.js
2
+ var skin_default = "/* ==========================================================================\n Icon State Visibility for Video Skins\n\n Data-attribute-driven visibility rules for multi-state icon buttons.\n Uses :is() with both element selectors (for HTML custom element wrappers)\n and class selectors (for React rendered SVG elements).\n ========================================================================== */\n\n/* --- All icons hidden by default --- */\n\n.media-button--play .media-icon--restart,\n.media-button--play .media-icon--play,\n.media-button--play .media-icon--pause,\n.media-button--mute .media-icon--volume-off,\n.media-button--mute .media-icon--volume-low,\n.media-button--mute .media-icon--volume-high,\n.media-button--fullscreen .media-icon--fullscreen-enter,\n.media-button--fullscreen .media-icon--fullscreen-exit,\n.media-button--captions .media-icon--captions-off,\n.media-button--captions .media-icon--captions-on {\n display: none;\n opacity: 0;\n}\n\n/* --- Active icon per state --- */\n\n/* Play: ended → restart */\n.media-button--play[data-ended] .media-icon--restart,\n/* Play: paused (not ended) → play */\n.media-button--play:not([data-ended])[data-paused] .media-icon--play,\n/* Play: playing (not paused, not ended) → pause */\n.media-button--play:not([data-paused]):not([data-ended]) .media-icon--pause,\n/* Mute: muted → volume off */\n.media-button--mute[data-muted] .media-icon--volume-off,\n/* Mute: volume low (not muted) → volume low */\n.media-button--mute:not([data-muted])[data-volume-level=\"low\"] .media-icon--volume-low,\n/* Mute: volume high (not muted, not low) → volume high */\n.media-button--mute:not([data-muted]):not([data-volume-level=\"low\"]) .media-icon--volume-high,\n/* Fullscreen: not fullscreen → enter */\n.media-button--fullscreen:not([data-fullscreen]) .media-icon--fullscreen-enter,\n/* Fullscreen: fullscreen → exit */\n.media-button--fullscreen[data-fullscreen] .media-icon--fullscreen-exit,\n/* Captions: not active → captions off */\n.media-button--captions:not([data-active]) .media-icon--captions-off,\n/* Captions: active → captions on */\n.media-button--captions[data-active] .media-icon--captions-on {\n display: block;\n opacity: 1;\n}\n\n/* ==========================================================================\n Tooltip Label State Visibility for Video Skins\n\n Data-attribute-driven visibility rules for multi-state tooltip labels.\n Uses adjacent sibling selectors to match button state → tooltip content.\n ========================================================================== */\n\n/* --- All multi-state labels hidden by default --- */\n\n.media-tooltip-label {\n display: none;\n}\n\n/* --- Active label per state --- */\n\n/* Play: ended → replay */\n.media-button--play[data-ended] + .media-tooltip .media-tooltip-label--replay,\n/* Play: paused (not ended) → play */\n .media-button--play:not([data-ended])[data-paused] + .media-tooltip\n .media-tooltip-label--play,\n/* Play: playing (not paused, not ended) → pause */\n .media-button--play:not([data-paused]):not([data-ended]) + .media-tooltip\n .media-tooltip-label--pause,\n/* Fullscreen: not fullscreen → enter */\n .media-button--fullscreen:not([data-fullscreen]) + .media-tooltip\n .media-tooltip-label--enter-fullscreen,\n/* Fullscreen: fullscreen → exit */\n .media-button--fullscreen[data-fullscreen] + .media-tooltip\n .media-tooltip-label--exit-fullscreen,\n/* Captions: not active → enable */\n .media-button--captions:not([data-active]) + .media-tooltip\n .media-tooltip-label--enable-captions,\n/* Captions: active → disable */\n .media-button--captions[data-active] + .media-tooltip\n .media-tooltip-label--disable-captions,\n/* PiP: not in pip → enter */\n .media-button--pip:not([data-pip]) + .media-tooltip\n .media-tooltip-label--enter-pip,\n/* PiP: in pip → exit */\n .media-button--pip[data-pip] + .media-tooltip\n .media-tooltip-label--exit-pip {\n display: block;\n}\n\n/* ==========================================================================\n Reset\n ========================================================================== */\n\n.media-default-skin *,\n.media-default-skin *::before,\n.media-default-skin *::after {\n box-sizing: border-box;\n margin: 0;\n}\n.media-default-skin img,\n.media-default-skin video,\n.media-default-skin svg {\n display: block;\n max-width: 100%;\n}\n.media-default-skin button {\n font: inherit;\n}\n@media (prefers-reduced-motion: no-preference) {\n .media-default-skin {\n interpolate-size: allow-keywords;\n }\n}\n\n/* ==========================================================================\n Root Container\n ========================================================================== */\n\n.media-default-skin {\n position: relative;\n isolation: isolate;\n display: block;\n container: media-root / inline-size;\n border-radius: var(--media-border-radius, 2rem);\n font-family:\n Inter Variable,\n Inter,\n ui-sans-serif,\n system-ui,\n sans-serif;\n font-size: 0.8125rem;\n line-height: 1.5;\n letter-spacing: normal;\n -webkit-font-smoothing: auto;\n -moz-osx-font-smoothing: auto;\n\n &:fullscreen {\n border-radius: 0;\n }\n}\n\n/* ==========================================================================\n Surface (shared glass effect for tooltips, popovers, controls)\n ========================================================================== */\n\n.media-default-skin .media-surface {\n background-color: var(--media-surface-background-color);\n backdrop-filter: var(--media-surface-backdrop-filter);\n box-shadow:\n inset 0 0 0 1px var(--media-surface-inner-border-color),\n 0 1px 3px 0 var(--media-surface-shadow-color),\n 0 1px 2px -1px var(--media-surface-shadow-color);\n\n /* Inner border ring */\n &::after {\n content: \"\";\n position: absolute;\n inset: 0;\n z-index: 10;\n border-radius: inherit;\n box-shadow: 0 0 0 1px var(--media-surface-outer-border-color);\n pointer-events: none;\n }\n\n @media (prefers-reduced-transparency: reduce) {\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.7);\n }\n\n @media (prefers-contrast: more) {\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.9);\n }\n}\n\n/* ==========================================================================\n Media Element\n ========================================================================== */\n\n.media-default-skin ::slotted(video),\n.media-default-skin video {\n display: block;\n width: 100%;\n height: 100%;\n border-radius: var(--media-border-radius, 2rem);\n}\n\n/* ==========================================================================\n Poster Image\n ========================================================================== */\n\n.media-default-skin > img {\n position: absolute;\n inset: 0;\n width: 100%;\n height: 100%;\n border-radius: inherit;\n object-fit: cover;\n transition: opacity 0.25s;\n pointer-events: none;\n\n &:not([data-visible]) {\n opacity: 0;\n }\n}\n\n/* ==========================================================================\n Overlay / Scrim\n ========================================================================== */\n\n.media-default-skin .media-overlay {\n position: absolute;\n inset: 0;\n border-radius: inherit;\n background-image: linear-gradient(to top, oklch(0 0 0 / 0.5), oklch(0 0 0 / 0.3), oklch(0 0 0 / 0));\n backdrop-filter: blur(0) saturate(1.2) brightness(0.9);\n opacity: 0;\n transition-property: opacity, backdrop-filter;\n transition-duration: 300ms;\n transition-delay: 500ms;\n transition-timing-function: ease-out;\n pointer-events: none;\n\n @media (prefers-reduced-motion: reduce) {\n transition-duration: 100ms;\n }\n}\n\n.media-default-skin .media-controls[data-visible] ~ .media-overlay,\n.media-default-skin .media-error[data-open] ~ .media-overlay {\n opacity: 1;\n transition-duration: 150ms;\n transition-delay: 0ms;\n}\n\n.media-default-skin .media-error[data-open] ~ .media-overlay {\n backdrop-filter: blur(8px) saturate(1.2) brightness(0.9);\n}\n\n/* ==========================================================================\n Buffering Indicator\n ========================================================================== */\n\n.media-default-skin .media-buffering-indicator {\n position: absolute;\n inset: 0;\n display: none;\n align-items: center;\n justify-content: center;\n color: oklch(1 0 0);\n pointer-events: none;\n\n &[data-visible] {\n display: flex;\n }\n\n .media-surface {\n padding: 0.25rem;\n border-radius: 100%;\n }\n}\n\n/* ==========================================================================\n Error Dialog\n ========================================================================== */\n\n.media-default-skin .media-error {\n position: absolute;\n inset: 0;\n z-index: 20;\n display: flex;\n align-items: center;\n justify-content: center;\n}\n\n.media-default-skin .media-error__dialog {\n display: flex;\n flex-direction: column;\n gap: 0.75rem;\n max-width: 18rem;\n padding: 0.75rem;\n border-radius: 1.75rem;\n color: oklch(1 0 0);\n font-size: 0.875rem;\n transition-property: opacity, transform;\n transition-duration: 500ms;\n transition-delay: 100ms;\n transition-timing-function: linear(\n 0,\n 0.034 1.5%,\n 0.763 9.7%,\n 1.066 13.9%,\n 1.198 19.9%,\n 1.184 21.8%,\n 0.963 37.5%,\n 0.997 50.9%,\n 1\n );\n\n /* Simple, fast transition for reduced motion users */\n @media (prefers-reduced-motion: reduce) {\n transition-duration: 100ms;\n transition-delay: 0ms;\n transition-timing-function: ease-out;\n }\n}\n\n.media-default-skin .media-error[data-starting-style] .media-error__dialog,\n.media-default-skin .media-error[data-ending-style] .media-error__dialog {\n opacity: 0;\n transform: scale(0.5);\n}\n\n.media-default-skin .media-error__content {\n display: flex;\n flex-direction: column;\n gap: 0.5rem;\n padding: 0.5rem 0.5rem 0.375rem;\n}\n\n.media-default-skin .media-error__title {\n font-weight: 600;\n line-height: 1.25;\n}\n\n.media-default-skin .media-error__description {\n opacity: 0.7;\n}\n\n.media-default-skin .media-error__actions {\n display: flex;\n gap: 0.5rem;\n\n & > * {\n flex: 1;\n }\n}\n\n/* ==========================================================================\n Controls\n ========================================================================== */\n\n.media-default-skin .media-controls {\n container: media-controls / inline-size;\n display: flex;\n align-items: center;\n gap: 0.075rem;\n padding: 0.175rem;\n border-radius: calc(infinity * 1px);\n --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.25));\n --media-controls-current-shadow-color-subtle: oklch(\n from var(--media-controls-current-shadow-color) l c h /\n calc(alpha * 0.4)\n );\n text-shadow: 0 0 1px var(--media-controls-current-shadow-color);\n\n @container media-root (width > 40rem) {\n gap: 0.125rem;\n padding: 0.25rem;\n }\n}\n\n/* ==========================================================================\n Time Display\n ========================================================================== */\n\n.media-default-skin .media-time {\n container: media-time / inline-size;\n display: flex;\n align-items: center;\n flex: 1;\n gap: 0.75rem;\n padding-inline: 0.5rem;\n\n & .media-time__value:first-child {\n display: none;\n\n @container media-time (width > 18rem) {\n display: block;\n }\n }\n}\n\n.media-default-skin .media-time__value {\n font-variant-numeric: tabular-nums;\n}\n\n/* ==========================================================================\n Buttons\n ========================================================================== */\n\n/* Base button */\n.media-default-skin .media-button {\n display: flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n padding: 0.5rem 1rem;\n background: oklch(1 0 0);\n border: none;\n border-radius: calc(infinity * 1px);\n outline: 2px solid transparent;\n outline-offset: -2px;\n color: oklch(0 0 0);\n font-weight: 500;\n text-align: center;\n transition-property: background-color, color, outline-offset, transform;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n cursor: pointer;\n user-select: none;\n\n &:focus-visible {\n outline-color: oklch(62.3% 0.214 259.815);\n outline-offset: 2px;\n }\n\n &[disabled] {\n opacity: 0.5;\n filter: grayscale(1);\n cursor: not-allowed;\n }\n\n &[data-availability=\"unavailable\"] {\n display: none;\n }\n}\n\n/* Icon button variant */\n.media-default-skin .media-button--icon {\n display: grid;\n width: 2.125rem;\n padding: 0;\n aspect-ratio: 1;\n background: transparent;\n color: inherit;\n text-shadow: inherit;\n\n &:hover,\n &:focus-visible,\n &[aria-expanded=\"true\"] {\n background-color: oklch(from currentColor l c h / 0.1);\n text-decoration: none;\n }\n\n &:active {\n transform: scale(0.9);\n }\n\n & .media-icon {\n filter: drop-shadow(0 1px 0 var(--media-controls-current-shadow-color, oklch(0 0 0 / 0.25)));\n }\n}\n\n/* Seek button */\n.media-default-skin .media-button--seek {\n & .media-icon__label {\n position: absolute;\n right: -1px;\n bottom: -3px;\n font-size: 0.75em;\n font-weight: 480;\n font-variant-numeric: tabular-nums;\n }\n\n &:has(.media-icon--flipped) .media-icon__label {\n right: unset;\n left: -1px;\n }\n\n @container media-controls (width < 28rem) {\n display: none;\n }\n}\n\n/* Playback rate button */\n.media-default-skin .media-button--playback-rate {\n padding: 0;\n\n &::after {\n content: attr(data-rate) \"\\00D7\";\n width: 4ch;\n font-variant-numeric: tabular-nums;\n }\n}\n\n/* ==========================================================================\n Icons\n ========================================================================== */\n\n.media-default-skin .media-icon__container {\n position: relative;\n}\n.media-default-skin .media-icon {\n display: block;\n flex-shrink: 0;\n grid-area: 1 / 1;\n width: 18px;\n height: 18px;\n transition-behavior: allow-discrete;\n transition-property: display, opacity;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n}\n.media-default-skin .media-icon--flipped {\n scale: -1 1;\n}\n\n/* ==========================================================================\n Slider\n ========================================================================== */\n\n.media-default-skin .media-slider {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n flex: 1;\n border-radius: calc(infinity * 1px);\n outline: none;\n\n &[data-orientation=\"horizontal\"] {\n min-width: 5rem;\n width: 100%;\n height: 1.25rem;\n }\n\n &[data-orientation=\"vertical\"] {\n width: 1.25rem;\n height: 5rem;\n }\n}\n\n/* Track */\n.media-default-skin .media-slider__track {\n position: relative;\n isolation: isolate;\n overflow: hidden;\n border-radius: inherit;\n user-select: none;\n\n &[data-orientation=\"horizontal\"] {\n width: 100%;\n height: 0.25rem;\n }\n\n &[data-orientation=\"vertical\"] {\n width: 0.25rem;\n height: 100%;\n }\n}\n\n/* Thumb */\n.media-default-skin .media-slider__thumb {\n z-index: 10;\n position: absolute;\n transform: translate(-50%, -50%);\n width: 0.625rem;\n height: 0.625rem;\n background-color: currentColor;\n border-radius: calc(infinity * 1px);\n box-shadow:\n 0 0 0 1px var(--media-controls-current-shadow-color-subtle, oklch(0 0 0 / 0.1)),\n 0 1px 3px 0 oklch(0 0 0 / 0.15),\n 0 1px 2px -1px oklch(0 0 0 / 0.15);\n opacity: 0;\n transition-property: opacity, height, width, outline-offset;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n user-select: none;\n outline: 4px solid transparent;\n outline-offset: -4px;\n\n &[data-orientation=\"horizontal\"] {\n top: 50%;\n left: var(--media-slider-fill);\n }\n\n &[data-orientation=\"vertical\"] {\n left: 50%;\n top: calc(100% - var(--media-slider-fill));\n }\n\n &:hover,\n &:focus {\n outline-color: oklch(from currentColor l c h / 0.25);\n outline-offset: 0;\n }\n}\n\n.media-default-skin .media-slider:active .media-slider__thumb,\n.media-default-skin .media-slider__thumb--persistent {\n width: 0.75rem;\n height: 0.75rem;\n}\n\n.media-default-skin .media-slider:hover .media-slider__thumb,\n.media-default-skin .media-slider__thumb:focus-visible,\n.media-default-skin .media-slider__thumb--persistent {\n opacity: 1;\n}\n\n/* Shared track fills */\n.media-default-skin .media-slider__buffer,\n.media-default-skin .media-slider__fill {\n position: absolute;\n border-radius: inherit;\n pointer-events: none;\n}\n\n.media-default-skin .media-slider__buffer[data-orientation=\"horizontal\"],\n.media-default-skin .media-slider__fill[data-orientation=\"horizontal\"] {\n inset-block: 0;\n left: 0;\n}\n\n.media-default-skin .media-slider__buffer[data-orientation=\"vertical\"],\n.media-default-skin .media-slider__fill[data-orientation=\"vertical\"] {\n inset-inline: 0;\n bottom: 0;\n}\n\n/* Buffer */\n.media-default-skin .media-slider__buffer {\n background-color: oklch(from currentColor l c h / 0.2);\n transition-duration: 0.25s;\n transition-timing-function: ease-out;\n\n &[data-orientation=\"horizontal\"] {\n width: var(--media-slider-buffer);\n transition-property: width;\n }\n\n &[data-orientation=\"vertical\"] {\n height: var(--media-slider-buffer);\n transition-property: height;\n }\n}\n\n/* Fill */\n.media-default-skin .media-slider__fill {\n background-color: currentColor;\n\n &[data-orientation=\"horizontal\"] {\n width: var(--media-slider-fill);\n }\n\n &[data-orientation=\"vertical\"] {\n height: var(--media-slider-fill);\n }\n}\n\n/* Time display within slider */\n.media-default-skin .media-slider__time-display {\n font-variant-numeric: tabular-nums;\n}\n\n/* ==========================================================================\n Popups & Tooltips\n ========================================================================== */\n\n.media-default-skin .media-popover,\n.media-default-skin .media-tooltip {\n margin: 0;\n border: 0;\n color: inherit;\n overflow: visible;\n transition-property: transform, scale, opacity, filter;\n transition-duration: 200ms;\n\n &[data-starting-style],\n &[data-ending-style] {\n opacity: 0;\n transform: scale(0);\n filter: blur(8px);\n }\n\n &[data-instant] {\n transition-duration: 0ms;\n }\n\n &[data-side=\"top\"] {\n transform-origin: bottom;\n }\n &[data-side=\"bottom\"] {\n transform-origin: top;\n }\n &[data-side=\"left\"] {\n transform-origin: right;\n }\n &[data-side=\"right\"] {\n transform-origin: left;\n }\n}\n\n.media-default-skin .media-popover {\n --media-popover-side-offset: 0.5rem;\n}\n.media-default-skin .media-popover--volume {\n padding: 0.625rem 0.25rem;\n border-radius: calc(infinity * 1px);\n}\n\n.media-default-skin .media-tooltip {\n padding: 0.25rem 0.625rem;\n border-radius: calc(infinity * 1px);\n font-size: 0.75rem;\n white-space: nowrap;\n --media-tooltip-side-offset: 0.5rem;\n}\n\n/* ==========================================================================\n Captions\n ========================================================================== */\n\n.media-default-skin .media-captions {\n position: absolute;\n inset: auto 1rem 1.5rem 1rem;\n z-index: 20;\n font-size: 1rem;\n text-wrap: balance;\n pointer-events: none;\n\n @container media-root (width > 20rem) {\n font-size: 1.5rem;\n }\n\n @container media-root (width > 48rem) {\n font-size: 1.875rem;\n }\n\n @container media-root (width > 80rem) {\n font-size: 2.25rem;\n }\n}\n\n.media-default-skin .media-captions__container {\n display: flex;\n flex-direction: column;\n align-items: center;\n max-width: 42ch;\n margin: 0 auto;\n text-align: center;\n}\n\n.media-default-skin .media-captions__text {\n display: block;\n padding: 0.125rem 0.5rem;\n color: oklch(1 0 0);\n text-shadow:\n 0 0 1px oklch(0 0 0 / 0.7),\n 0 0 8px oklch(0 0 0 / 0.7);\n text-align: center;\n white-space: pre-wrap;\n line-height: 1.2;\n\n @media (prefers-contrast: more) {\n background: oklch(0 0 0 / 0.7);\n text-shadow: none;\n box-decoration-break: clone;\n }\n\n & > * {\n display: inline;\n }\n}\n\n/* Caption shifting styles (custom and native) */\n.media-default-skin {\n --media-caption-track-delay: 600ms;\n --media-caption-track-y: -0.5rem;\n\n &:has(.media-controls[data-visible]) {\n --media-caption-track-delay: 25ms;\n --media-caption-track-y: -3.5rem;\n }\n}\n\n.media-default-skin .media-captions,\n.media-default-skin video::-webkit-media-text-track-container {\n /* NOTE: The delay must account for the controls delay/duration */\n transition: transform 150ms ease-out;\n transition-delay: var(--media-caption-track-delay);\n}\n\n.media-default-skin video::-webkit-media-text-track-container {\n transform: translateY(var(--media-caption-track-y)) scale(0.98);\n z-index: 1;\n font-family: inherit;\n}\n\n/* When controls are visible, shift captions up to avoid overlap */\n.media-default-skin .media-controls[data-visible] ~ .media-captions {\n transform: translateY(calc(var(--media-caption-track-y) - 0.5rem));\n}\n\n@media (prefers-reduced-motion: reduce) {\n .media-default-skin .media-captions,\n .media-default-skin video::-webkit-media-text-track-container {\n transition-duration: 50ms;\n }\n}\n\n\n/* ==========================================================================\n Root\n ========================================================================== */\n\n.media-default-skin--video {\n background: oklch(0 0 0);\n --media-border-color: oklch(0 0 0 / 0.1);\n --media-surface-background-color: oklch(1 0 0 / 0.1);\n --media-surface-inner-border-color: oklch(1 0 0 / 0.05);\n --media-surface-outer-border-color: oklch(0 0 0 / 0.1);\n --media-surface-shadow-color: oklch(0 0 0 / 0.15);\n --media-surface-backdrop-filter: blur(64px) brightness(0.9) saturate(1.5);\n\n @media (prefers-color-scheme: dark) {\n --media-border-color: oklch(1 0 0 / 0.1);\n }\n\n /* Inner border ring */\n &::after {\n content: \"\";\n position: absolute;\n inset: 0;\n z-index: 10;\n border-radius: inherit;\n box-shadow: inset 0 0 0 1px var(--media-border-color);\n pointer-events: none;\n }\n}\n\n/* ==========================================================================\n Controls (hide/show behavior)\n ========================================================================== */\n\n.media-default-skin--video .media-controls {\n position: absolute;\n bottom: 0.75rem;\n inset-inline: 0.75rem;\n z-index: 10;\n will-change: scale, transform, filter, opacity;\n transition-property: scale, transform, filter, opacity;\n transition-duration: 100ms;\n transition-delay: 0ms;\n transition-timing-function: ease-out;\n transform-origin: bottom;\n color: oklch(1 0 0);\n\n &:not([data-visible]) {\n opacity: 0;\n scale: 0.9;\n filter: blur(8px);\n transition-duration: 300ms;\n transition-delay: 500ms;\n pointer-events: none;\n\n @media (prefers-reduced-motion: reduce) {\n scale: 1;\n filter: blur(0);\n transition-duration: 100ms;\n }\n }\n}\n\n/* ==========================================================================\n Sliders\n ========================================================================== */\n\n.media-default-skin--video .media-slider__track {\n background-color: oklch(1 0 0 / 0.2);\n box-shadow: 0 0 0 1px oklch(0 0 0 / 0.05);\n}\n\n";
3
+
4
+ //#endregion
5
+ export { skin_default as default };
6
+ //# sourceMappingURL=skin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skin.js","names":[],"sources":["../../../../../../inline-css:src/define/video/skin.js"],"sourcesContent":["export default \"/* ==========================================================================\\n Icon State Visibility for Video Skins\\n\\n Data-attribute-driven visibility rules for multi-state icon buttons.\\n Uses :is() with both element selectors (for HTML custom element wrappers)\\n and class selectors (for React rendered SVG elements).\\n ========================================================================== */\\n\\n/* --- All icons hidden by default --- */\\n\\n.media-button--play .media-icon--restart,\\n.media-button--play .media-icon--play,\\n.media-button--play .media-icon--pause,\\n.media-button--mute .media-icon--volume-off,\\n.media-button--mute .media-icon--volume-low,\\n.media-button--mute .media-icon--volume-high,\\n.media-button--fullscreen .media-icon--fullscreen-enter,\\n.media-button--fullscreen .media-icon--fullscreen-exit,\\n.media-button--captions .media-icon--captions-off,\\n.media-button--captions .media-icon--captions-on {\\n display: none;\\n opacity: 0;\\n}\\n\\n/* --- Active icon per state --- */\\n\\n/* Play: ended → restart */\\n.media-button--play[data-ended] .media-icon--restart,\\n/* Play: paused (not ended) → play */\\n.media-button--play:not([data-ended])[data-paused] .media-icon--play,\\n/* Play: playing (not paused, not ended) → pause */\\n.media-button--play:not([data-paused]):not([data-ended]) .media-icon--pause,\\n/* Mute: muted → volume off */\\n.media-button--mute[data-muted] .media-icon--volume-off,\\n/* Mute: volume low (not muted) → volume low */\\n.media-button--mute:not([data-muted])[data-volume-level=\\\"low\\\"] .media-icon--volume-low,\\n/* Mute: volume high (not muted, not low) → volume high */\\n.media-button--mute:not([data-muted]):not([data-volume-level=\\\"low\\\"]) .media-icon--volume-high,\\n/* Fullscreen: not fullscreen → enter */\\n.media-button--fullscreen:not([data-fullscreen]) .media-icon--fullscreen-enter,\\n/* Fullscreen: fullscreen → exit */\\n.media-button--fullscreen[data-fullscreen] .media-icon--fullscreen-exit,\\n/* Captions: not active → captions off */\\n.media-button--captions:not([data-active]) .media-icon--captions-off,\\n/* Captions: active → captions on */\\n.media-button--captions[data-active] .media-icon--captions-on {\\n display: block;\\n opacity: 1;\\n}\\n\\n/* ==========================================================================\\n Tooltip Label State Visibility for Video Skins\\n\\n Data-attribute-driven visibility rules for multi-state tooltip labels.\\n Uses adjacent sibling selectors to match button state → tooltip content.\\n ========================================================================== */\\n\\n/* --- All multi-state labels hidden by default --- */\\n\\n.media-tooltip-label {\\n display: none;\\n}\\n\\n/* --- Active label per state --- */\\n\\n/* Play: ended → replay */\\n.media-button--play[data-ended] + .media-tooltip .media-tooltip-label--replay,\\n/* Play: paused (not ended) → play */\\n .media-button--play:not([data-ended])[data-paused] + .media-tooltip\\n .media-tooltip-label--play,\\n/* Play: playing (not paused, not ended) → pause */\\n .media-button--play:not([data-paused]):not([data-ended]) + .media-tooltip\\n .media-tooltip-label--pause,\\n/* Fullscreen: not fullscreen → enter */\\n .media-button--fullscreen:not([data-fullscreen]) + .media-tooltip\\n .media-tooltip-label--enter-fullscreen,\\n/* Fullscreen: fullscreen → exit */\\n .media-button--fullscreen[data-fullscreen] + .media-tooltip\\n .media-tooltip-label--exit-fullscreen,\\n/* Captions: not active → enable */\\n .media-button--captions:not([data-active]) + .media-tooltip\\n .media-tooltip-label--enable-captions,\\n/* Captions: active → disable */\\n .media-button--captions[data-active] + .media-tooltip\\n .media-tooltip-label--disable-captions,\\n/* PiP: not in pip → enter */\\n .media-button--pip:not([data-pip]) + .media-tooltip\\n .media-tooltip-label--enter-pip,\\n/* PiP: in pip → exit */\\n .media-button--pip[data-pip] + .media-tooltip\\n .media-tooltip-label--exit-pip {\\n display: block;\\n}\\n\\n/* ==========================================================================\\n Reset\\n ========================================================================== */\\n\\n.media-default-skin *,\\n.media-default-skin *::before,\\n.media-default-skin *::after {\\n box-sizing: border-box;\\n margin: 0;\\n}\\n.media-default-skin img,\\n.media-default-skin video,\\n.media-default-skin svg {\\n display: block;\\n max-width: 100%;\\n}\\n.media-default-skin button {\\n font: inherit;\\n}\\n@media (prefers-reduced-motion: no-preference) {\\n .media-default-skin {\\n interpolate-size: allow-keywords;\\n }\\n}\\n\\n/* ==========================================================================\\n Root Container\\n ========================================================================== */\\n\\n.media-default-skin {\\n position: relative;\\n isolation: isolate;\\n display: block;\\n container: media-root / inline-size;\\n border-radius: var(--media-border-radius, 2rem);\\n font-family:\\n Inter Variable,\\n Inter,\\n ui-sans-serif,\\n system-ui,\\n sans-serif;\\n font-size: 0.8125rem;\\n line-height: 1.5;\\n letter-spacing: normal;\\n -webkit-font-smoothing: auto;\\n -moz-osx-font-smoothing: auto;\\n\\n &:fullscreen {\\n border-radius: 0;\\n }\\n}\\n\\n/* ==========================================================================\\n Surface (shared glass effect for tooltips, popovers, controls)\\n ========================================================================== */\\n\\n.media-default-skin .media-surface {\\n background-color: var(--media-surface-background-color);\\n backdrop-filter: var(--media-surface-backdrop-filter);\\n box-shadow:\\n inset 0 0 0 1px var(--media-surface-inner-border-color),\\n 0 1px 3px 0 var(--media-surface-shadow-color),\\n 0 1px 2px -1px var(--media-surface-shadow-color);\\n\\n /* Inner border ring */\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n z-index: 10;\\n border-radius: inherit;\\n box-shadow: 0 0 0 1px var(--media-surface-outer-border-color);\\n pointer-events: none;\\n }\\n\\n @media (prefers-reduced-transparency: reduce) {\\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.7);\\n }\\n\\n @media (prefers-contrast: more) {\\n background-color: oklch(from var(--media-surface-background-color) l c h / 0.9);\\n }\\n}\\n\\n/* ==========================================================================\\n Media Element\\n ========================================================================== */\\n\\n.media-default-skin ::slotted(video),\\n.media-default-skin video {\\n display: block;\\n width: 100%;\\n height: 100%;\\n border-radius: var(--media-border-radius, 2rem);\\n}\\n\\n/* ==========================================================================\\n Poster Image\\n ========================================================================== */\\n\\n.media-default-skin > img {\\n position: absolute;\\n inset: 0;\\n width: 100%;\\n height: 100%;\\n border-radius: inherit;\\n object-fit: cover;\\n transition: opacity 0.25s;\\n pointer-events: none;\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n }\\n}\\n\\n/* ==========================================================================\\n Overlay / Scrim\\n ========================================================================== */\\n\\n.media-default-skin .media-overlay {\\n position: absolute;\\n inset: 0;\\n border-radius: inherit;\\n background-image: linear-gradient(to top, oklch(0 0 0 / 0.5), oklch(0 0 0 / 0.3), oklch(0 0 0 / 0));\\n backdrop-filter: blur(0) saturate(1.2) brightness(0.9);\\n opacity: 0;\\n transition-property: opacity, backdrop-filter;\\n transition-duration: 300ms;\\n transition-delay: 500ms;\\n transition-timing-function: ease-out;\\n pointer-events: none;\\n\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n }\\n}\\n\\n.media-default-skin .media-controls[data-visible] ~ .media-overlay,\\n.media-default-skin .media-error[data-open] ~ .media-overlay {\\n opacity: 1;\\n transition-duration: 150ms;\\n transition-delay: 0ms;\\n}\\n\\n.media-default-skin .media-error[data-open] ~ .media-overlay {\\n backdrop-filter: blur(8px) saturate(1.2) brightness(0.9);\\n}\\n\\n/* ==========================================================================\\n Buffering Indicator\\n ========================================================================== */\\n\\n.media-default-skin .media-buffering-indicator {\\n position: absolute;\\n inset: 0;\\n display: none;\\n align-items: center;\\n justify-content: center;\\n color: oklch(1 0 0);\\n pointer-events: none;\\n\\n &[data-visible] {\\n display: flex;\\n }\\n\\n .media-surface {\\n padding: 0.25rem;\\n border-radius: 100%;\\n }\\n}\\n\\n/* ==========================================================================\\n Error Dialog\\n ========================================================================== */\\n\\n.media-default-skin .media-error {\\n position: absolute;\\n inset: 0;\\n z-index: 20;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n}\\n\\n.media-default-skin .media-error__dialog {\\n display: flex;\\n flex-direction: column;\\n gap: 0.75rem;\\n max-width: 18rem;\\n padding: 0.75rem;\\n border-radius: 1.75rem;\\n color: oklch(1 0 0);\\n font-size: 0.875rem;\\n transition-property: opacity, transform;\\n transition-duration: 500ms;\\n transition-delay: 100ms;\\n transition-timing-function: linear(\\n 0,\\n 0.034 1.5%,\\n 0.763 9.7%,\\n 1.066 13.9%,\\n 1.198 19.9%,\\n 1.184 21.8%,\\n 0.963 37.5%,\\n 0.997 50.9%,\\n 1\\n );\\n\\n /* Simple, fast transition for reduced motion users */\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n transition-delay: 0ms;\\n transition-timing-function: ease-out;\\n }\\n}\\n\\n.media-default-skin .media-error[data-starting-style] .media-error__dialog,\\n.media-default-skin .media-error[data-ending-style] .media-error__dialog {\\n opacity: 0;\\n transform: scale(0.5);\\n}\\n\\n.media-default-skin .media-error__content {\\n display: flex;\\n flex-direction: column;\\n gap: 0.5rem;\\n padding: 0.5rem 0.5rem 0.375rem;\\n}\\n\\n.media-default-skin .media-error__title {\\n font-weight: 600;\\n line-height: 1.25;\\n}\\n\\n.media-default-skin .media-error__description {\\n opacity: 0.7;\\n}\\n\\n.media-default-skin .media-error__actions {\\n display: flex;\\n gap: 0.5rem;\\n\\n & > * {\\n flex: 1;\\n }\\n}\\n\\n/* ==========================================================================\\n Controls\\n ========================================================================== */\\n\\n.media-default-skin .media-controls {\\n container: media-controls / inline-size;\\n display: flex;\\n align-items: center;\\n gap: 0.075rem;\\n padding: 0.175rem;\\n border-radius: calc(infinity * 1px);\\n --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.25));\\n --media-controls-current-shadow-color-subtle: oklch(\\n from var(--media-controls-current-shadow-color) l c h /\\n calc(alpha * 0.4)\\n );\\n text-shadow: 0 0 1px var(--media-controls-current-shadow-color);\\n\\n @container media-root (width > 40rem) {\\n gap: 0.125rem;\\n padding: 0.25rem;\\n }\\n}\\n\\n/* ==========================================================================\\n Time Display\\n ========================================================================== */\\n\\n.media-default-skin .media-time {\\n container: media-time / inline-size;\\n display: flex;\\n align-items: center;\\n flex: 1;\\n gap: 0.75rem;\\n padding-inline: 0.5rem;\\n\\n & .media-time__value:first-child {\\n display: none;\\n\\n @container media-time (width > 18rem) {\\n display: block;\\n }\\n }\\n}\\n\\n.media-default-skin .media-time__value {\\n font-variant-numeric: tabular-nums;\\n}\\n\\n/* ==========================================================================\\n Buttons\\n ========================================================================== */\\n\\n/* Base button */\\n.media-default-skin .media-button {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-shrink: 0;\\n padding: 0.5rem 1rem;\\n background: oklch(1 0 0);\\n border: none;\\n border-radius: calc(infinity * 1px);\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n color: oklch(0 0 0);\\n font-weight: 500;\\n text-align: center;\\n transition-property: background-color, color, outline-offset, transform;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n cursor: pointer;\\n user-select: none;\\n\\n &:focus-visible {\\n outline-color: oklch(62.3% 0.214 259.815);\\n outline-offset: 2px;\\n }\\n\\n &[disabled] {\\n opacity: 0.5;\\n filter: grayscale(1);\\n cursor: not-allowed;\\n }\\n\\n &[data-availability=\\\"unavailable\\\"] {\\n display: none;\\n }\\n}\\n\\n/* Icon button variant */\\n.media-default-skin .media-button--icon {\\n display: grid;\\n width: 2.125rem;\\n padding: 0;\\n aspect-ratio: 1;\\n background: transparent;\\n color: inherit;\\n text-shadow: inherit;\\n\\n &:hover,\\n &:focus-visible,\\n &[aria-expanded=\\\"true\\\"] {\\n background-color: oklch(from currentColor l c h / 0.1);\\n text-decoration: none;\\n }\\n\\n &:active {\\n transform: scale(0.9);\\n }\\n\\n & .media-icon {\\n filter: drop-shadow(0 1px 0 var(--media-controls-current-shadow-color, oklch(0 0 0 / 0.25)));\\n }\\n}\\n\\n/* Seek button */\\n.media-default-skin .media-button--seek {\\n & .media-icon__label {\\n position: absolute;\\n right: -1px;\\n bottom: -3px;\\n font-size: 0.75em;\\n font-weight: 480;\\n font-variant-numeric: tabular-nums;\\n }\\n\\n &:has(.media-icon--flipped) .media-icon__label {\\n right: unset;\\n left: -1px;\\n }\\n\\n @container media-controls (width < 28rem) {\\n display: none;\\n }\\n}\\n\\n/* Playback rate button */\\n.media-default-skin .media-button--playback-rate {\\n padding: 0;\\n\\n &::after {\\n content: attr(data-rate) \\\"\\\\00D7\\\";\\n width: 4ch;\\n font-variant-numeric: tabular-nums;\\n }\\n}\\n\\n/* ==========================================================================\\n Icons\\n ========================================================================== */\\n\\n.media-default-skin .media-icon__container {\\n position: relative;\\n}\\n.media-default-skin .media-icon {\\n display: block;\\n flex-shrink: 0;\\n grid-area: 1 / 1;\\n width: 18px;\\n height: 18px;\\n transition-behavior: allow-discrete;\\n transition-property: display, opacity;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n}\\n.media-default-skin .media-icon--flipped {\\n scale: -1 1;\\n}\\n\\n/* ==========================================================================\\n Slider\\n ========================================================================== */\\n\\n.media-default-skin .media-slider {\\n position: relative;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex: 1;\\n border-radius: calc(infinity * 1px);\\n outline: none;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n min-width: 5rem;\\n width: 100%;\\n height: 1.25rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 1.25rem;\\n height: 5rem;\\n }\\n}\\n\\n/* Track */\\n.media-default-skin .media-slider__track {\\n position: relative;\\n isolation: isolate;\\n overflow: hidden;\\n border-radius: inherit;\\n user-select: none;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: 100%;\\n height: 0.25rem;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n width: 0.25rem;\\n height: 100%;\\n }\\n}\\n\\n/* Thumb */\\n.media-default-skin .media-slider__thumb {\\n z-index: 10;\\n position: absolute;\\n transform: translate(-50%, -50%);\\n width: 0.625rem;\\n height: 0.625rem;\\n background-color: currentColor;\\n border-radius: calc(infinity * 1px);\\n box-shadow:\\n 0 0 0 1px var(--media-controls-current-shadow-color-subtle, oklch(0 0 0 / 0.1)),\\n 0 1px 3px 0 oklch(0 0 0 / 0.15),\\n 0 1px 2px -1px oklch(0 0 0 / 0.15);\\n opacity: 0;\\n transition-property: opacity, height, width, outline-offset;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n user-select: none;\\n outline: 4px solid transparent;\\n outline-offset: -4px;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n top: 50%;\\n left: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n left: 50%;\\n top: calc(100% - var(--media-slider-fill));\\n }\\n\\n &:hover,\\n &:focus {\\n outline-color: oklch(from currentColor l c h / 0.25);\\n outline-offset: 0;\\n }\\n}\\n\\n.media-default-skin .media-slider:active .media-slider__thumb,\\n.media-default-skin .media-slider__thumb--persistent {\\n width: 0.75rem;\\n height: 0.75rem;\\n}\\n\\n.media-default-skin .media-slider:hover .media-slider__thumb,\\n.media-default-skin .media-slider__thumb:focus-visible,\\n.media-default-skin .media-slider__thumb--persistent {\\n opacity: 1;\\n}\\n\\n/* Shared track fills */\\n.media-default-skin .media-slider__buffer,\\n.media-default-skin .media-slider__fill {\\n position: absolute;\\n border-radius: inherit;\\n pointer-events: none;\\n}\\n\\n.media-default-skin .media-slider__buffer[data-orientation=\\\"horizontal\\\"],\\n.media-default-skin .media-slider__fill[data-orientation=\\\"horizontal\\\"] {\\n inset-block: 0;\\n left: 0;\\n}\\n\\n.media-default-skin .media-slider__buffer[data-orientation=\\\"vertical\\\"],\\n.media-default-skin .media-slider__fill[data-orientation=\\\"vertical\\\"] {\\n inset-inline: 0;\\n bottom: 0;\\n}\\n\\n/* Buffer */\\n.media-default-skin .media-slider__buffer {\\n background-color: oklch(from currentColor l c h / 0.2);\\n transition-duration: 0.25s;\\n transition-timing-function: ease-out;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-buffer);\\n transition-property: width;\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-buffer);\\n transition-property: height;\\n }\\n}\\n\\n/* Fill */\\n.media-default-skin .media-slider__fill {\\n background-color: currentColor;\\n\\n &[data-orientation=\\\"horizontal\\\"] {\\n width: var(--media-slider-fill);\\n }\\n\\n &[data-orientation=\\\"vertical\\\"] {\\n height: var(--media-slider-fill);\\n }\\n}\\n\\n/* Time display within slider */\\n.media-default-skin .media-slider__time-display {\\n font-variant-numeric: tabular-nums;\\n}\\n\\n/* ==========================================================================\\n Popups & Tooltips\\n ========================================================================== */\\n\\n.media-default-skin .media-popover,\\n.media-default-skin .media-tooltip {\\n margin: 0;\\n border: 0;\\n color: inherit;\\n overflow: visible;\\n transition-property: transform, scale, opacity, filter;\\n transition-duration: 200ms;\\n\\n &[data-starting-style],\\n &[data-ending-style] {\\n opacity: 0;\\n transform: scale(0);\\n filter: blur(8px);\\n }\\n\\n &[data-instant] {\\n transition-duration: 0ms;\\n }\\n\\n &[data-side=\\\"top\\\"] {\\n transform-origin: bottom;\\n }\\n &[data-side=\\\"bottom\\\"] {\\n transform-origin: top;\\n }\\n &[data-side=\\\"left\\\"] {\\n transform-origin: right;\\n }\\n &[data-side=\\\"right\\\"] {\\n transform-origin: left;\\n }\\n}\\n\\n.media-default-skin .media-popover {\\n --media-popover-side-offset: 0.5rem;\\n}\\n.media-default-skin .media-popover--volume {\\n padding: 0.625rem 0.25rem;\\n border-radius: calc(infinity * 1px);\\n}\\n\\n.media-default-skin .media-tooltip {\\n padding: 0.25rem 0.625rem;\\n border-radius: calc(infinity * 1px);\\n font-size: 0.75rem;\\n white-space: nowrap;\\n --media-tooltip-side-offset: 0.5rem;\\n}\\n\\n/* ==========================================================================\\n Captions\\n ========================================================================== */\\n\\n.media-default-skin .media-captions {\\n position: absolute;\\n inset: auto 1rem 1.5rem 1rem;\\n z-index: 20;\\n font-size: 1rem;\\n text-wrap: balance;\\n pointer-events: none;\\n\\n @container media-root (width > 20rem) {\\n font-size: 1.5rem;\\n }\\n\\n @container media-root (width > 48rem) {\\n font-size: 1.875rem;\\n }\\n\\n @container media-root (width > 80rem) {\\n font-size: 2.25rem;\\n }\\n}\\n\\n.media-default-skin .media-captions__container {\\n display: flex;\\n flex-direction: column;\\n align-items: center;\\n max-width: 42ch;\\n margin: 0 auto;\\n text-align: center;\\n}\\n\\n.media-default-skin .media-captions__text {\\n display: block;\\n padding: 0.125rem 0.5rem;\\n color: oklch(1 0 0);\\n text-shadow:\\n 0 0 1px oklch(0 0 0 / 0.7),\\n 0 0 8px oklch(0 0 0 / 0.7);\\n text-align: center;\\n white-space: pre-wrap;\\n line-height: 1.2;\\n\\n @media (prefers-contrast: more) {\\n background: oklch(0 0 0 / 0.7);\\n text-shadow: none;\\n box-decoration-break: clone;\\n }\\n\\n & > * {\\n display: inline;\\n }\\n}\\n\\n/* Caption shifting styles (custom and native) */\\n.media-default-skin {\\n --media-caption-track-delay: 600ms;\\n --media-caption-track-y: -0.5rem;\\n\\n &:has(.media-controls[data-visible]) {\\n --media-caption-track-delay: 25ms;\\n --media-caption-track-y: -3.5rem;\\n }\\n}\\n\\n.media-default-skin .media-captions,\\n.media-default-skin video::-webkit-media-text-track-container {\\n /* NOTE: The delay must account for the controls delay/duration */\\n transition: transform 150ms ease-out;\\n transition-delay: var(--media-caption-track-delay);\\n}\\n\\n.media-default-skin video::-webkit-media-text-track-container {\\n transform: translateY(var(--media-caption-track-y)) scale(0.98);\\n z-index: 1;\\n font-family: inherit;\\n}\\n\\n/* When controls are visible, shift captions up to avoid overlap */\\n.media-default-skin .media-controls[data-visible] ~ .media-captions {\\n transform: translateY(calc(var(--media-caption-track-y) - 0.5rem));\\n}\\n\\n@media (prefers-reduced-motion: reduce) {\\n .media-default-skin .media-captions,\\n .media-default-skin video::-webkit-media-text-track-container {\\n transition-duration: 50ms;\\n }\\n}\\n\\n\\n/* ==========================================================================\\n Root\\n ========================================================================== */\\n\\n.media-default-skin--video {\\n background: oklch(0 0 0);\\n --media-border-color: oklch(0 0 0 / 0.1);\\n --media-surface-background-color: oklch(1 0 0 / 0.1);\\n --media-surface-inner-border-color: oklch(1 0 0 / 0.05);\\n --media-surface-outer-border-color: oklch(0 0 0 / 0.1);\\n --media-surface-shadow-color: oklch(0 0 0 / 0.15);\\n --media-surface-backdrop-filter: blur(64px) brightness(0.9) saturate(1.5);\\n\\n @media (prefers-color-scheme: dark) {\\n --media-border-color: oklch(1 0 0 / 0.1);\\n }\\n\\n /* Inner border ring */\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n z-index: 10;\\n border-radius: inherit;\\n box-shadow: inset 0 0 0 1px var(--media-border-color);\\n pointer-events: none;\\n }\\n}\\n\\n/* ==========================================================================\\n Controls (hide/show behavior)\\n ========================================================================== */\\n\\n.media-default-skin--video .media-controls {\\n position: absolute;\\n bottom: 0.75rem;\\n inset-inline: 0.75rem;\\n z-index: 10;\\n will-change: scale, transform, filter, opacity;\\n transition-property: scale, transform, filter, opacity;\\n transition-duration: 100ms;\\n transition-delay: 0ms;\\n transition-timing-function: ease-out;\\n transform-origin: bottom;\\n color: oklch(1 0 0);\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n scale: 0.9;\\n filter: blur(8px);\\n transition-duration: 300ms;\\n transition-delay: 500ms;\\n pointer-events: none;\\n\\n @media (prefers-reduced-motion: reduce) {\\n scale: 1;\\n filter: blur(0);\\n transition-duration: 100ms;\\n }\\n }\\n}\\n\\n/* ==========================================================================\\n Sliders\\n ========================================================================== */\\n\\n.media-default-skin--video .media-slider__track {\\n background-color: oklch(1 0 0 / 0.2);\\n box-shadow: 0 0 0 1px oklch(0 0 0 / 0.05);\\n}\\n\\n\";"],"mappings":";AAAA,mBAAe"}