@videojs/html 10.0.0-beta.6 → 10.0.0-beta.8

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 (330) hide show
  1. package/cdn/audio-minimal.dev.d.ts +1 -0
  2. package/cdn/audio-minimal.dev.js +9 -5336
  3. package/cdn/audio-minimal.dev.js.map +1 -1
  4. package/cdn/audio-minimal.js +1 -24
  5. package/cdn/audio-minimal.js.map +1 -1
  6. package/cdn/audio.dev.d.ts +1 -0
  7. package/cdn/audio.dev.js +9 -5336
  8. package/cdn/audio.dev.js.map +1 -1
  9. package/cdn/audio.js +1 -24
  10. package/cdn/audio.js.map +1 -1
  11. package/cdn/background.dev.d.ts +1 -0
  12. package/cdn/background.dev.js +112 -2025
  13. package/cdn/background.dev.js.map +1 -1
  14. package/cdn/background.js +1 -18
  15. package/cdn/background.js.map +1 -1
  16. package/cdn/context-C_e06fGU.js +13 -0
  17. package/cdn/context-C_e06fGU.js.map +1 -0
  18. package/cdn/context-DTY0nOpS.js +98 -0
  19. package/cdn/context-DTY0nOpS.js.map +1 -0
  20. package/cdn/create-player-Dv7K1Ezk.js +3214 -0
  21. package/cdn/create-player-Dv7K1Ezk.js.map +1 -0
  22. package/cdn/create-player-QjiNZlh7.js +7 -0
  23. package/cdn/create-player-QjiNZlh7.js.map +1 -0
  24. package/cdn/default-GgKND7a8.js +2 -0
  25. package/cdn/default-GgKND7a8.js.map +1 -0
  26. package/cdn/default-cLso8BHO.js +28 -0
  27. package/cdn/default-cLso8BHO.js.map +1 -0
  28. package/cdn/listen-BXAYCbZA.js +9 -0
  29. package/cdn/listen-BXAYCbZA.js.map +1 -0
  30. package/cdn/listen-DX5vU4s4.js +2 -0
  31. package/cdn/listen-DX5vU4s4.js.map +1 -0
  32. package/cdn/media/dash-video.dev.d.ts +1 -0
  33. package/cdn/media/dash-video.dev.js +39165 -0
  34. package/cdn/media/dash-video.dev.js.map +1 -0
  35. package/cdn/media/dash-video.js +21 -0
  36. package/cdn/media/dash-video.js.map +1 -0
  37. package/cdn/media/hls-video.dev.d.ts +1 -0
  38. package/cdn/media/hls-video.dev.js +6 -378
  39. package/cdn/media/hls-video.dev.js.map +1 -1
  40. package/cdn/media/hls-video.js +21 -65
  41. package/cdn/media/hls-video.js.map +1 -1
  42. package/cdn/media/simple-hls-video.dev.d.ts +1 -0
  43. package/cdn/media/simple-hls-video.dev.js +6 -377
  44. package/cdn/media/simple-hls-video.dev.js.map +1 -1
  45. package/cdn/media/simple-hls-video.js +1 -45
  46. package/cdn/media/simple-hls-video.js.map +1 -1
  47. package/cdn/media-attach-mixin-ChyNp2eK.js +44 -0
  48. package/cdn/media-attach-mixin-ChyNp2eK.js.map +1 -0
  49. package/cdn/media-attach-mixin-tFNcHnvo.js +2 -0
  50. package/cdn/media-attach-mixin-tFNcHnvo.js.map +1 -0
  51. package/cdn/minimal-BJfleQcQ.js +2 -0
  52. package/cdn/minimal-BJfleQcQ.js.map +1 -0
  53. package/cdn/minimal-DBMdC_0I.js +28 -0
  54. package/cdn/minimal-DBMdC_0I.js.map +1 -0
  55. package/cdn/player-CztIlNio.js +2 -0
  56. package/cdn/player-CztIlNio.js.map +1 -0
  57. package/cdn/player-Dvj38jlr.js +15 -0
  58. package/cdn/player-Dvj38jlr.js.map +1 -0
  59. package/cdn/poster-C4WHg3BH.js +2 -0
  60. package/cdn/poster-C4WHg3BH.js.map +1 -0
  61. package/cdn/poster-O0SI05LC.js +195 -0
  62. package/cdn/poster-O0SI05LC.js.map +1 -0
  63. package/cdn/predicate-BG-dj_kF.js +26 -0
  64. package/cdn/predicate-BG-dj_kF.js.map +1 -0
  65. package/cdn/predicate-Y9jDHLpX.js +2 -0
  66. package/cdn/predicate-Y9jDHLpX.js.map +1 -0
  67. package/cdn/proxy-2oO2ph3m.js +47 -0
  68. package/cdn/proxy-2oO2ph3m.js.map +1 -0
  69. package/cdn/proxy-6KS6wy69.js +2 -0
  70. package/cdn/proxy-6KS6wy69.js.map +1 -0
  71. package/cdn/proxy-XzDf9gyk.js +66 -0
  72. package/cdn/proxy-XzDf9gyk.js.map +1 -0
  73. package/cdn/proxy-dR7IDk37.js +349 -0
  74. package/cdn/proxy-dR7IDk37.js.map +1 -0
  75. package/cdn/safe-define-B8lHgj_K.js +9 -0
  76. package/cdn/safe-define-B8lHgj_K.js.map +1 -0
  77. package/cdn/safe-define-GrHW3P9e.js +2 -0
  78. package/cdn/safe-define-GrHW3P9e.js.map +1 -0
  79. package/cdn/video-minimal.dev.d.ts +1 -0
  80. package/cdn/video-minimal.dev.js +16 -5650
  81. package/cdn/video-minimal.dev.js.map +1 -1
  82. package/cdn/video-minimal.js +1 -24
  83. package/cdn/video-minimal.js.map +1 -1
  84. package/cdn/video.dev.d.ts +1 -0
  85. package/cdn/video.dev.js +24 -5709
  86. package/cdn/video.dev.js.map +1 -1
  87. package/cdn/video.js +1 -24
  88. package/cdn/video.js.map +1 -1
  89. package/cdn/volume-slider-BqzTytgB.js +8 -0
  90. package/cdn/volume-slider-BqzTytgB.js.map +1 -0
  91. package/cdn/volume-slider-CfhOO9RM.js +2453 -0
  92. package/cdn/volume-slider-CfhOO9RM.js.map +1 -0
  93. package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js +1 -1
  94. package/dist/default/_virtual/inline-css_src/define/audio/minimal-skin.js.map +1 -1
  95. package/dist/default/_virtual/inline-css_src/define/audio/skin.js +1 -1
  96. package/dist/default/_virtual/inline-css_src/define/audio/skin.js.map +1 -1
  97. package/dist/default/_virtual/inline-css_src/define/background/skin.js +6 -0
  98. package/dist/default/_virtual/inline-css_src/define/background/skin.js.map +1 -0
  99. package/dist/default/_virtual/inline-css_src/define/base.js +1 -1
  100. package/dist/default/_virtual/inline-css_src/define/base.js.map +1 -1
  101. package/dist/default/_virtual/inline-css_src/define/shared.js +6 -0
  102. package/dist/default/_virtual/inline-css_src/define/shared.js.map +1 -0
  103. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js +1 -1
  104. package/dist/default/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -1
  105. package/dist/default/_virtual/inline-css_src/define/video/skin.js +1 -1
  106. package/dist/default/_virtual/inline-css_src/define/video/skin.js.map +1 -1
  107. package/dist/default/define/audio/minimal-skin.css +22 -20
  108. package/dist/default/define/audio/minimal-skin.js +1 -1
  109. package/dist/default/define/audio/minimal-skin.js.map +1 -1
  110. package/dist/default/define/audio/minimal-skin.tailwind.js +1 -1
  111. package/dist/default/define/audio/minimal-skin.tailwind.js.map +1 -1
  112. package/dist/default/define/audio/skin.css +19 -22
  113. package/dist/default/define/audio/skin.js +1 -1
  114. package/dist/default/define/audio/skin.js.map +1 -1
  115. package/dist/default/define/audio/skin.tailwind.js +3 -4
  116. package/dist/default/define/audio/skin.tailwind.js.map +1 -1
  117. package/dist/default/define/background/skin.css +1 -1
  118. package/dist/default/define/background/skin.js +11 -1
  119. package/dist/default/define/background/skin.js.map +1 -1
  120. package/dist/default/define/base.css +7 -7
  121. package/dist/default/define/media/dash-video.js +14 -0
  122. package/dist/default/define/media/dash-video.js.map +1 -0
  123. package/dist/default/define/shared.css +6 -0
  124. package/dist/default/define/skin-mixin.js +8 -3
  125. package/dist/default/define/skin-mixin.js.map +1 -1
  126. package/dist/default/define/video/minimal-skin.css +101 -71
  127. package/dist/default/define/video/minimal-skin.js +2 -1
  128. package/dist/default/define/video/minimal-skin.js.map +1 -1
  129. package/dist/default/define/video/minimal-skin.tailwind.js +4 -2
  130. package/dist/default/define/video/minimal-skin.tailwind.js.map +1 -1
  131. package/dist/default/define/video/skin.css +98 -72
  132. package/dist/default/define/video/skin.js +2 -1
  133. package/dist/default/define/video/skin.js.map +1 -1
  134. package/dist/default/define/video/skin.tailwind.js +4 -2
  135. package/dist/default/define/video/skin.tailwind.js.map +1 -1
  136. package/dist/default/icons/dist/render/default/index.js +2 -1
  137. package/dist/default/icons/dist/render/default/index.js.map +1 -1
  138. package/dist/default/icons/dist/render/minimal/index.js +2 -1
  139. package/dist/default/icons/dist/render/minimal/index.js.map +1 -1
  140. package/dist/default/index.js +3 -2
  141. package/dist/default/media/background-video/index.js +5 -1
  142. package/dist/default/media/background-video/index.js.map +1 -1
  143. package/dist/default/media/container-element.js +5 -2
  144. package/dist/default/media/container-element.js.map +1 -1
  145. package/dist/default/media/dash-video/index.js +26 -0
  146. package/dist/default/media/dash-video/index.js.map +1 -0
  147. package/dist/default/media/hls-video/index.js +2 -1
  148. package/dist/default/media/hls-video/index.js.map +1 -1
  149. package/dist/default/media/simple-hls-video/index.js +2 -1
  150. package/dist/default/media/simple-hls-video/index.js.map +1 -1
  151. package/dist/default/player/context.js +6 -2
  152. package/dist/default/player/context.js.map +1 -1
  153. package/dist/default/player/create-player.js +11 -3
  154. package/dist/default/player/create-player.js.map +1 -1
  155. package/dist/default/skins/dist/default/default/tailwind/audio.tailwind.js +6 -5
  156. package/dist/default/skins/dist/default/default/tailwind/audio.tailwind.js.map +1 -1
  157. package/dist/default/skins/dist/default/default/tailwind/components/controls.js +1 -1
  158. package/dist/default/skins/dist/default/default/tailwind/components/controls.js.map +1 -1
  159. package/dist/default/skins/dist/default/default/tailwind/components/error.js +1 -1
  160. package/dist/default/skins/dist/default/default/tailwind/components/error.js.map +1 -1
  161. package/dist/default/skins/dist/default/default/tailwind/components/poster.js +16 -0
  162. package/dist/default/skins/dist/default/default/tailwind/components/poster.js.map +1 -0
  163. package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js +6 -5
  164. package/dist/default/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -1
  165. package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js +1 -1
  166. package/dist/default/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -1
  167. package/dist/default/skins/dist/default/minimal/tailwind/components/controls.js +1 -1
  168. package/dist/default/skins/dist/default/minimal/tailwind/components/controls.js.map +1 -1
  169. package/dist/default/skins/dist/default/minimal/tailwind/components/playback-rate.js +6 -0
  170. package/dist/default/skins/dist/default/minimal/tailwind/components/playback-rate.js.map +1 -0
  171. package/dist/default/skins/dist/default/minimal/tailwind/components/poster.js +16 -0
  172. package/dist/default/skins/dist/default/minimal/tailwind/components/poster.js.map +1 -0
  173. package/dist/default/skins/dist/default/minimal/tailwind/components/time.js +1 -1
  174. package/dist/default/skins/dist/default/minimal/tailwind/components/time.js.map +1 -1
  175. package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js +6 -4
  176. package/dist/default/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -1
  177. package/dist/default/skins/dist/default/shared/tailwind/icon-state.js +5 -0
  178. package/dist/default/skins/dist/default/shared/tailwind/icon-state.js.map +1 -1
  179. package/dist/default/store/container-mixin.js +16 -72
  180. package/dist/default/store/container-mixin.js.map +1 -1
  181. package/dist/default/store/media-attach-mixin.js +45 -0
  182. package/dist/default/store/media-attach-mixin.js.map +1 -0
  183. package/dist/default/store/provider-mixin.js +99 -9
  184. package/dist/default/store/provider-mixin.js.map +1 -1
  185. package/dist/default/ui/popover/popover-element.js +54 -3
  186. package/dist/default/ui/popover/popover-element.js.map +1 -1
  187. package/dist/default/ui/time-slider/time-slider-element.js +1 -1
  188. package/dist/default/ui/time-slider/time-slider-element.js.map +1 -1
  189. package/dist/default/ui/tooltip/tooltip-element.js +53 -3
  190. package/dist/default/ui/tooltip/tooltip-element.js.map +1 -1
  191. package/dist/default/ui/volume-slider/volume-slider-element.js +3 -3
  192. package/dist/default/ui/volume-slider/volume-slider-element.js.map +1 -1
  193. package/dist/dev/_virtual/inline-css_src/define/audio/minimal-skin.js +1 -1
  194. package/dist/dev/_virtual/inline-css_src/define/audio/minimal-skin.js.map +1 -1
  195. package/dist/dev/_virtual/inline-css_src/define/audio/skin.js +1 -1
  196. package/dist/dev/_virtual/inline-css_src/define/audio/skin.js.map +1 -1
  197. package/dist/dev/_virtual/inline-css_src/define/background/skin.js +6 -0
  198. package/dist/dev/_virtual/inline-css_src/define/background/skin.js.map +1 -0
  199. package/dist/dev/_virtual/inline-css_src/define/base.js +1 -1
  200. package/dist/dev/_virtual/inline-css_src/define/base.js.map +1 -1
  201. package/dist/dev/_virtual/inline-css_src/define/shared.js +6 -0
  202. package/dist/dev/_virtual/inline-css_src/define/shared.js.map +1 -0
  203. package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js +1 -1
  204. package/dist/dev/_virtual/inline-css_src/define/video/minimal-skin.js.map +1 -1
  205. package/dist/dev/_virtual/inline-css_src/define/video/skin.js +1 -1
  206. package/dist/dev/_virtual/inline-css_src/define/video/skin.js.map +1 -1
  207. package/dist/dev/define/audio/minimal-skin.css +22 -20
  208. package/dist/dev/define/audio/minimal-skin.d.ts.map +1 -1
  209. package/dist/dev/define/audio/minimal-skin.js +2 -0
  210. package/dist/dev/define/audio/minimal-skin.js.map +1 -1
  211. package/dist/dev/define/audio/minimal-skin.tailwind.d.ts.map +1 -1
  212. package/dist/dev/define/audio/minimal-skin.tailwind.js +3 -1
  213. package/dist/dev/define/audio/minimal-skin.tailwind.js.map +1 -1
  214. package/dist/dev/define/audio/skin.css +19 -22
  215. package/dist/dev/define/audio/skin.d.ts.map +1 -1
  216. package/dist/dev/define/audio/skin.js +2 -0
  217. package/dist/dev/define/audio/skin.js.map +1 -1
  218. package/dist/dev/define/audio/skin.tailwind.d.ts.map +1 -1
  219. package/dist/dev/define/audio/skin.tailwind.js +5 -4
  220. package/dist/dev/define/audio/skin.tailwind.js.map +1 -1
  221. package/dist/dev/define/background/skin.css +1 -1
  222. package/dist/dev/define/background/skin.d.ts.map +1 -1
  223. package/dist/dev/define/background/skin.js +13 -1
  224. package/dist/dev/define/background/skin.js.map +1 -1
  225. package/dist/dev/define/base.css +7 -7
  226. package/dist/dev/define/media/dash-video.d.ts +14 -0
  227. package/dist/dev/define/media/dash-video.d.ts.map +1 -0
  228. package/dist/dev/define/media/dash-video.js +14 -0
  229. package/dist/dev/define/media/dash-video.js.map +1 -0
  230. package/dist/dev/define/shared.css +6 -0
  231. package/dist/dev/define/skin-mixin.d.ts.map +1 -1
  232. package/dist/dev/define/skin-mixin.js +8 -3
  233. package/dist/dev/define/skin-mixin.js.map +1 -1
  234. package/dist/dev/define/video/minimal-skin.css +101 -71
  235. package/dist/dev/define/video/minimal-skin.d.ts.map +1 -1
  236. package/dist/dev/define/video/minimal-skin.js +10 -2
  237. package/dist/dev/define/video/minimal-skin.js.map +1 -1
  238. package/dist/dev/define/video/minimal-skin.tailwind.d.ts.map +1 -1
  239. package/dist/dev/define/video/minimal-skin.tailwind.js +13 -4
  240. package/dist/dev/define/video/minimal-skin.tailwind.js.map +1 -1
  241. package/dist/dev/define/video/skin.css +98 -72
  242. package/dist/dev/define/video/skin.d.ts.map +1 -1
  243. package/dist/dev/define/video/skin.js +9 -1
  244. package/dist/dev/define/video/skin.js.map +1 -1
  245. package/dist/dev/define/video/skin.tailwind.d.ts.map +1 -1
  246. package/dist/dev/define/video/skin.tailwind.js +13 -4
  247. package/dist/dev/define/video/skin.tailwind.js.map +1 -1
  248. package/dist/dev/icons/dist/render/default/index.js +2 -1
  249. package/dist/dev/icons/dist/render/default/index.js.map +1 -1
  250. package/dist/dev/icons/dist/render/minimal/index.js +2 -1
  251. package/dist/dev/icons/dist/render/minimal/index.js.map +1 -1
  252. package/dist/dev/index.d.ts +5 -4
  253. package/dist/dev/index.js +3 -2
  254. package/dist/dev/media/background-video/index.d.ts +8 -1
  255. package/dist/dev/media/background-video/index.d.ts.map +1 -1
  256. package/dist/dev/media/background-video/index.js +5 -1
  257. package/dist/dev/media/background-video/index.js.map +1 -1
  258. package/dist/dev/media/container-element.js +5 -2
  259. package/dist/dev/media/container-element.js.map +1 -1
  260. package/dist/dev/media/dash-video/index.d.ts +13 -0
  261. package/dist/dev/media/dash-video/index.d.ts.map +1 -0
  262. package/dist/dev/media/dash-video/index.js +26 -0
  263. package/dist/dev/media/dash-video/index.js.map +1 -0
  264. package/dist/dev/media/hls-video/index.d.ts +2 -1
  265. package/dist/dev/media/hls-video/index.d.ts.map +1 -1
  266. package/dist/dev/media/hls-video/index.js +2 -1
  267. package/dist/dev/media/hls-video/index.js.map +1 -1
  268. package/dist/dev/media/simple-hls-video/index.d.ts +2 -1
  269. package/dist/dev/media/simple-hls-video/index.d.ts.map +1 -1
  270. package/dist/dev/media/simple-hls-video/index.js +2 -1
  271. package/dist/dev/media/simple-hls-video/index.js.map +1 -1
  272. package/dist/dev/player/context.d.ts +16 -2
  273. package/dist/dev/player/context.d.ts.map +1 -1
  274. package/dist/dev/player/context.js +6 -2
  275. package/dist/dev/player/context.js.map +1 -1
  276. package/dist/dev/player/create-player.d.ts +1 -1
  277. package/dist/dev/player/create-player.js +11 -3
  278. package/dist/dev/player/create-player.js.map +1 -1
  279. package/dist/dev/skins/dist/default/default/tailwind/audio.tailwind.js +6 -5
  280. package/dist/dev/skins/dist/default/default/tailwind/audio.tailwind.js.map +1 -1
  281. package/dist/dev/skins/dist/default/default/tailwind/components/controls.js +1 -1
  282. package/dist/dev/skins/dist/default/default/tailwind/components/controls.js.map +1 -1
  283. package/dist/dev/skins/dist/default/default/tailwind/components/error.js +1 -1
  284. package/dist/dev/skins/dist/default/default/tailwind/components/error.js.map +1 -1
  285. package/dist/dev/skins/dist/default/default/tailwind/components/poster.js +16 -0
  286. package/dist/dev/skins/dist/default/default/tailwind/components/poster.js.map +1 -0
  287. package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js +6 -5
  288. package/dist/dev/skins/dist/default/default/tailwind/video.tailwind.js.map +1 -1
  289. package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js +1 -1
  290. package/dist/dev/skins/dist/default/minimal/tailwind/audio.tailwind.js.map +1 -1
  291. package/dist/dev/skins/dist/default/minimal/tailwind/components/controls.js +1 -1
  292. package/dist/dev/skins/dist/default/minimal/tailwind/components/controls.js.map +1 -1
  293. package/dist/dev/skins/dist/default/minimal/tailwind/components/playback-rate.js +6 -0
  294. package/dist/dev/skins/dist/default/minimal/tailwind/components/playback-rate.js.map +1 -0
  295. package/dist/dev/skins/dist/default/minimal/tailwind/components/poster.js +16 -0
  296. package/dist/dev/skins/dist/default/minimal/tailwind/components/poster.js.map +1 -0
  297. package/dist/dev/skins/dist/default/minimal/tailwind/components/time.js +1 -1
  298. package/dist/dev/skins/dist/default/minimal/tailwind/components/time.js.map +1 -1
  299. package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js +6 -4
  300. package/dist/dev/skins/dist/default/minimal/tailwind/video.tailwind.js.map +1 -1
  301. package/dist/dev/skins/dist/default/shared/tailwind/icon-state.js +5 -0
  302. package/dist/dev/skins/dist/default/shared/tailwind/icon-state.js.map +1 -1
  303. package/dist/dev/store/container-mixin.d.ts +10 -5
  304. package/dist/dev/store/container-mixin.d.ts.map +1 -1
  305. package/dist/dev/store/container-mixin.js +16 -72
  306. package/dist/dev/store/container-mixin.js.map +1 -1
  307. package/dist/dev/store/media-attach-mixin.d.ts +19 -0
  308. package/dist/dev/store/media-attach-mixin.d.ts.map +1 -0
  309. package/dist/dev/store/media-attach-mixin.js +45 -0
  310. package/dist/dev/store/media-attach-mixin.js.map +1 -0
  311. package/dist/dev/store/provider-mixin.d.ts +19 -6
  312. package/dist/dev/store/provider-mixin.d.ts.map +1 -1
  313. package/dist/dev/store/provider-mixin.js +99 -9
  314. package/dist/dev/store/provider-mixin.js.map +1 -1
  315. package/dist/dev/ui/popover/popover-element.d.ts.map +1 -1
  316. package/dist/dev/ui/popover/popover-element.js +54 -3
  317. package/dist/dev/ui/popover/popover-element.js.map +1 -1
  318. package/dist/dev/ui/time-slider/time-slider-element.js +1 -1
  319. package/dist/dev/ui/time-slider/time-slider-element.js.map +1 -1
  320. package/dist/dev/ui/tooltip/tooltip-element.d.ts.map +1 -1
  321. package/dist/dev/ui/tooltip/tooltip-element.js +53 -3
  322. package/dist/dev/ui/tooltip/tooltip-element.js.map +1 -1
  323. package/dist/dev/ui/volume-slider/volume-slider-element.js +3 -3
  324. package/dist/dev/ui/volume-slider/volume-slider-element.js.map +1 -1
  325. package/package.json +21 -10
  326. package/cdn/audio-minimal.css +0 -1
  327. package/cdn/audio.css +0 -1
  328. package/cdn/background.css +0 -1
  329. package/cdn/video-minimal.css +0 -1
  330. package/cdn/video.css +0 -1
@@ -1 +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}\\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 height: 100%;\\n width: 100%;\\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 object-fit: var(--media-object-fit, contain);\\n object-position: var(--media-object-position, center);\\n}\\n.media-minimal-skin ::slotted(video) {\\n border-radius: var(--media-video-border-radius);\\n}\\n.media-minimal-skin video {\\n border-radius: inherit;\\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 object-fit: var(--media-object-fit, contain);\\n object-position: var(--media-object-position, center);\\n transition: opacity 0.25s;\\n pointer-events: none;\\n border-radius: inherit;\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n }\\n}\\n\\n/* ==========================================================================\\n Fullscreen\\n ========================================================================== */\\n\\n.media-minimal-skin:fullscreen ::slotted(video),\\n.media-minimal-skin:fullscreen video {\\n object-fit: contain;\\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.5);\\n opacity: 0;\\n pointer-events: none;\\n\\n @media (pointer: fine) {\\n transition-property: opacity, backdrop-filter;\\n transition-duration: 500ms;\\n transition-delay: 500ms;\\n transition-timing-function: ease-out;\\n\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n }\\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\\n @media (pointer: fine) {\\n transition-duration: 150ms;\\n transition-delay: 0ms;\\n }\\n}\\n\\n.media-minimal-skin .media-error[data-open] ~ .media-overlay {\\n backdrop-filter: blur(16px) saturate(1.5);\\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 touch-action: manipulation;\\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 Media preview\\n ========================================================================== */\\n.media-minimal-skin .media-preview {\\n & .media-preview__thumbnail-wrapper {\\n position: relative;\\n border-radius: 0.5rem;\\n background-color: oklch(0 0 0 / 0.9);\\n }\\n & .media-preview__thumbnail {\\n display: block;\\n border-radius: inherit;\\n }\\n\\n & .media-preview__timestamp {\\n display: block;\\n font-variant-numeric: tabular-nums;\\n text-align: center;\\n margin-top: 0.5rem;\\n }\\n\\n & .media-overlay {\\n opacity: 1;\\n }\\n\\n & .media-preview__spinner {\\n position: absolute;\\n top: 50%;\\n left: 50%;\\n transform: translate(-50%, -50%);\\n opacity: 0;\\n }\\n\\n & .media-preview__thumbnail,\\n & .media-preview__spinner {\\n transition: opacity 150ms ease-out;\\n }\\n\\n &:has(.media-preview__thumbnail[data-loading]) {\\n & .media-preview__thumbnail {\\n opacity: 0;\\n }\\n & .media-preview__spinner {\\n opacity: 1;\\n }\\n }\\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 cursor: pointer;\\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/* ==========================================================================\\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: 150ms;\\n\\n &[data-starting-style],\\n &[data-ending-style] {\\n opacity: 0;\\n transform: scale(0.5);\\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 /* Safe area between trigger and popup */\\n &::before {\\n content: \\\"\\\";\\n position: absolute;\\n pointer-events: inherit;\\n }\\n\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n width: 100%;\\n inset-inline: 0;\\n }\\n &[data-side=\\\"top\\\"]::before {\\n top: 100%;\\n }\\n &[data-side=\\\"bottom\\\"]::before {\\n bottom: 100%;\\n }\\n\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n height: 100%;\\n inset-block: 0;\\n }\\n &[data-side=\\\"left\\\"]::before {\\n left: 100%;\\n }\\n &[data-side=\\\"right\\\"]::before {\\n right: 100%;\\n }\\n}\\n\\n.media-minimal-skin .media-popover {\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n height: var(--media-popover-side-offset);\\n }\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n width: var(--media-popover-side-offset);\\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(16px) 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.75rem;\\n\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n height: var(--media-tooltip-side-offset);\\n }\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n width: var(--media-tooltip-side-offset);\\n }\\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 Native Caption Track\\n ========================================================================== */\\n\\n.media-minimal-skin {\\n --media-caption-track-duration: 150ms;\\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 @media (prefers-reduced-motion: reduce) {\\n --media-caption-track-duration: 50ms;\\n }\\n}\\n\\n.media-minimal-skin video::-webkit-media-text-track-container {\\n /* NOTE: The delay must account for the controls delay/duration */\\n transition: transform var(--media-caption-track-duration) ease-out;\\n transition-delay: var(--media-caption-track-delay);\\n transform: translateY(var(--media-caption-track-y)) scale(0.98);\\n z-index: 1;\\n font-family: inherit;\\n}\\n\\n\\n/* ==========================================================================\\n Root\\n ========================================================================== */\\n\\n.media-minimal-skin--video {\\n background: oklch(0 0 0);\\n --media-border-color: oklch(0 0 0 / 0.15);\\n --media-video-border-radius: var(--media-border-radius, 0.75rem);\\n\\n @media (prefers-color-scheme: dark) {\\n --media-border-color: oklch(1 0 0 / 0.15);\\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 /* Fullscreen */\\n &:fullscreen {\\n --media-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 color: oklch(1 0 0);\\n\\n @media (pointer: fine) {\\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 }\\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 pointer-events: none;\\n\\n @media (pointer: fine) {\\n transform: translateY(100%);\\n filter: blur(8px);\\n transition-duration: 500ms;\\n transition-delay: 500ms;\\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/* Hide cursor when controls are hidden in fullscreen */\\n.media-minimal-skin--video:fullscreen:has(.media-controls:not([data-visible])) {\\n cursor: none;\\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/* ==========================================================================\\n Slider preview\\n ========================================================================== */\\n\\n.media-minimal-skin .media-slider__preview {\\n position: absolute;\\n left: var(--media-slider-pointer);\\n bottom: calc(100% + 0.5rem);\\n translate: -50%;\\n opacity: 0;\\n scale: 0.8;\\n filter: blur(8px);\\n transition-property: scale, opacity, filter;\\n transition-duration: 150ms;\\n transform-origin: bottom;\\n\\n & .media-preview__thumbnail-wrapper {\\n position: relative;\\n\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n border-radius: inherit;\\n box-shadow:\\n 0 0 0 1px oklch(0 0 0 / 0.05),\\n 0 1px 3px 0 oklch(0 0 0 / 0.2),\\n 0 1px 2px -1px oklch(0 0 0 / 0.2);\\n }\\n }\\n\\n & .media-preview__thumbnail {\\n max-width: 11rem;\\n }\\n\\n &:has(.media-preview__thumbnail[data-loading]) {\\n max-height: 6rem;\\n }\\n}\\n.media-minimal-skin .media-slider[data-pointing] .media-slider__preview:has([role=\\\"img\\\"]:not([data-hidden])) {\\n opacity: 1;\\n scale: 1;\\n filter: blur(0);\\n}\\n\\nmedia-tooltip-group {\\n display: contents;\\n}\\n\\n:host {\\n display: grid;\\n}\\n\\n\";"],"mappings":";AAAA,2BAAe"}
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--pip .media-icon--pip-enter,\\n.media-button--pip .media-icon--pip-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/* Picture-in-Picture: not active → enter */\\n.media-button--pip:not([data-pip]) .media-icon--pip-enter,\\n/* Picture-in-Picture: active → exit */\\n.media-button--pip[data-pip] .media-icon--pip-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}\\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 height: 100%;\\n width: 100%;\\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 object-fit: var(--media-object-fit, contain);\\n object-position: var(--media-object-position, center);\\n}\\n.media-minimal-skin ::slotted(video) {\\n border-radius: var(--media-video-border-radius);\\n}\\n.media-minimal-skin video {\\n border-radius: inherit;\\n}\\n\\n.media-minimal-skin:fullscreen ::slotted(video),\\n.media-minimal-skin:fullscreen video {\\n object-fit: contain;\\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.5);\\n opacity: 0;\\n pointer-events: none;\\n\\n @media (pointer: fine) {\\n transition-property: opacity, backdrop-filter;\\n transition-duration: 500ms;\\n transition-delay: 500ms;\\n transition-timing-function: ease-out;\\n\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n }\\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\\n @media (pointer: fine) {\\n transition-duration: 150ms;\\n transition-delay: 0ms;\\n }\\n}\\n\\n.media-minimal-skin .media-error[data-open] ~ .media-overlay {\\n backdrop-filter: blur(16px) saturate(1.5);\\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, scale;\\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 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 overflow-wrap: anywhere;\\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.15));\\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 1px 0 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, scale;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n cursor: pointer;\\n user-select: none;\\n touch-action: manipulation;\\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 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 Poster Image\\n ========================================================================== */\\n\\n.media-minimal-skin media-poster,\\n.media-minimal-skin > img {\\n position: absolute;\\n inset: 0;\\n width: 100%;\\n height: 100%;\\n transition: opacity 0.25s;\\n pointer-events: none;\\n}\\n.media-minimal-skin media-poster:not([data-visible]),\\n.media-minimal-skin > img:not([data-visible]) {\\n opacity: 0;\\n}\\n.media-minimal-skin media-poster ::slotted(img) {\\n position: absolute;\\n inset: 0;\\n width: 100%;\\n height: 100%;\\n object-fit: var(--media-object-fit, contain);\\n object-position: var(--media-object-position, center);\\n border-radius: var(--media-video-border-radius);\\n}\\n.media-minimal-skin > img {\\n object-fit: var(--media-object-fit, contain);\\n object-position: var(--media-object-position, center);\\n border-radius: inherit;\\n}\\n\\n.media-minimal-skin:fullscreen media-poster ::slotted(img),\\n.media-minimal-skin:fullscreen > img {\\n object-fit: contain;\\n}\\n\\n/* ==========================================================================\\n Media preview\\n ========================================================================== */\\n.media-minimal-skin .media-preview {\\n & .media-preview__thumbnail-wrapper {\\n position: relative;\\n border-radius: 0.5rem;\\n background-color: oklch(0 0 0 / 0.9);\\n }\\n & .media-preview__thumbnail {\\n display: block;\\n border-radius: inherit;\\n }\\n\\n & .media-preview__timestamp {\\n display: block;\\n font-variant-numeric: tabular-nums;\\n text-align: center;\\n margin-top: 0.5rem;\\n }\\n\\n & .media-overlay {\\n opacity: 1;\\n }\\n\\n & .media-preview__spinner {\\n position: absolute;\\n top: 50%;\\n left: 50%;\\n translate: -50% -50%;\\n opacity: 0;\\n }\\n\\n & .media-preview__thumbnail,\\n & .media-preview__spinner {\\n transition: opacity 150ms ease-out;\\n }\\n\\n &:has(.media-preview__thumbnail[data-loading]) {\\n & .media-preview__thumbnail {\\n opacity: 0;\\n }\\n & .media-preview__spinner {\\n opacity: 1;\\n }\\n }\\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 cursor: pointer;\\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 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/* ==========================================================================\\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: scale, opacity, filter;\\n transition-duration: 150ms;\\n\\n &[data-starting-style],\\n &[data-ending-style] {\\n opacity: 0;\\n scale: 0.5;\\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 /* Safe area between trigger and popup */\\n &::before {\\n content: \\\"\\\";\\n position: absolute;\\n pointer-events: inherit;\\n }\\n\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n width: 100%;\\n inset-inline: 0;\\n }\\n &[data-side=\\\"top\\\"]::before {\\n top: 100%;\\n }\\n &[data-side=\\\"bottom\\\"]::before {\\n bottom: 100%;\\n }\\n\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n height: 100%;\\n inset-block: 0;\\n }\\n &[data-side=\\\"left\\\"]::before {\\n left: 100%;\\n }\\n &[data-side=\\\"right\\\"]::before {\\n right: 100%;\\n }\\n}\\n\\n.media-minimal-skin .media-popover {\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n height: var(--media-popover-side-offset);\\n }\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n width: var(--media-popover-side-offset);\\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(16px) 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.75rem;\\n\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n height: var(--media-tooltip-side-offset);\\n }\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n width: var(--media-tooltip-side-offset);\\n }\\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.media-minimal-skin .media-popover--volume:has(media-volume-slider[data-availability=\\\"unsupported\\\"]) {\\n display: none;\\n}\\n\\n/* ==========================================================================\\n Native Caption Track\\n ========================================================================== */\\n\\n.media-minimal-skin {\\n --media-caption-track-duration: var(--media-controls-transition-duration);\\n --media-caption-track-delay: calc(var(--media-controls-transition-delay) + 25ms);\\n --media-caption-track-y: -0.5rem;\\n\\n &:has(.media-controls[data-visible]) {\\n --media-caption-track-y: -3rem;\\n }\\n}\\n\\n.media-minimal-skin video::-webkit-media-text-track-container {\\n transition: translate var(--media-caption-track-duration) ease-out;\\n transition-delay: var(--media-caption-track-delay);\\n translate: 0 var(--media-caption-track-y);\\n scale: 0.98;\\n z-index: 1;\\n font-family: inherit;\\n}\\n\\n\\n/* ==========================================================================\\n Root\\n ========================================================================== */\\n\\n.media-minimal-skin--video {\\n overflow: clip;\\n background: oklch(0 0 0);\\n --media-border-color: oklch(0 0 0 / 0.15);\\n --media-video-border-radius: var(--media-border-radius, 0.75rem);\\n --media-controls-transition-duration: 100ms;\\n --media-controls-transition-delay: 0ms;\\n\\n @media (prefers-color-scheme: dark) {\\n --media-border-color: oklch(1 0 0 / 0.15);\\n }\\n\\n &:has(.media-controls:not([data-visible])) {\\n /* Slight delay to hide controls on non-touch devices after interaction */\\n @media (pointer: fine) {\\n --media-controls-transition-delay: 500ms;\\n --media-controls-transition-duration: 300ms;\\n }\\n @media (pointer: coarse) {\\n --media-controls-transition-duration: 150ms;\\n }\\n @media (prefers-reduced-motion: reduce) {\\n --media-controls-transition-duration: 100ms;\\n }\\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 /* Fullscreen */\\n &:fullscreen {\\n --media-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 color: var(--media-color-primary, oklch(1 0 0));\\n transition-duration: var(--media-controls-transition-duration);\\n transition-delay: var(--media-controls-transition-delay);\\n transition-timing-function: ease-out;\\n\\n @media (pointer: fine) {\\n will-change: translate, filter, opacity;\\n transition-property: translate, filter, opacity;\\n }\\n\\n @media (pointer: coarse) {\\n will-change: translate, opacity;\\n transition-property: translate, opacity;\\n }\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n pointer-events: none;\\n translate: 0 100%;\\n\\n @media (pointer: fine) {\\n filter: blur(8px);\\n }\\n\\n @media (prefers-reduced-motion: reduce) {\\n translate: 0 0;\\n filter: blur(0);\\n }\\n }\\n\\n @container media-root (width > 40rem) {\\n gap: 0.875rem;\\n padding: 2.5rem 0.75rem 0.75rem 0.75rem;\\n }\\n}\\n\\n/* Hide cursor when controls are hidden in fullscreen */\\n.media-minimal-skin--video:fullscreen:has(.media-controls:not([data-visible])) {\\n cursor: none;\\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/* ==========================================================================\\n Slider preview\\n ========================================================================== */\\n\\n.media-minimal-skin .media-slider__preview {\\n position: absolute;\\n left: var(--media-slider-pointer);\\n bottom: calc(100% + 0.5rem);\\n translate: -50%;\\n opacity: 0;\\n scale: 0.8;\\n filter: blur(8px);\\n transition-property: scale, opacity, filter;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n transform-origin: bottom;\\n\\n & .media-preview__thumbnail-wrapper {\\n position: relative;\\n\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n border-radius: inherit;\\n box-shadow:\\n 0 0 0 1px oklch(0 0 0 / 0.05),\\n 0 1px 3px 0 oklch(0 0 0 / 0.2),\\n 0 1px 2px -1px oklch(0 0 0 / 0.2);\\n }\\n }\\n\\n & .media-preview__thumbnail {\\n max-width: 11rem;\\n }\\n\\n &:has(.media-preview__thumbnail[data-loading]) {\\n max-height: 6rem;\\n }\\n}\\n.media-minimal-skin .media-slider[data-pointing] .media-slider__preview:has([role=\\\"img\\\"]:not([data-hidden])) {\\n opacity: 1;\\n scale: 1;\\n filter: blur(0);\\n}\\n\\n\";"],"mappings":";AAAA,2BAAe"}
@@ -1,5 +1,5 @@
1
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}\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 height: 100%;\n width: 100%;\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\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 0 0 0 1px var(--media-surface-outer-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: inset 0 0 0 1px var(--media-surface-inner-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 object-fit: var(--media-object-fit, contain);\n object-position: var(--media-object-position, center);\n}\n.media-default-skin ::slotted(video) {\n border-radius: var(--media-video-border-radius);\n}\n.media-default-skin video {\n border-radius: inherit;\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 object-fit: var(--media-object-fit, contain);\n object-position: var(--media-object-position, center);\n transition: opacity 0.25s;\n pointer-events: none;\n border-radius: inherit;\n\n &:not([data-visible]) {\n opacity: 0;\n }\n}\n\n/* ==========================================================================\n Fullscreen\n ========================================================================== */\n\n.media-default-skin:fullscreen ::slotted(video),\n.media-default-skin:fullscreen video {\n object-fit: contain;\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.5);\n opacity: 0;\n pointer-events: none;\n\n @media (pointer: fine) {\n transition-property: opacity, backdrop-filter;\n transition-duration: 300ms;\n transition-delay: 500ms;\n transition-timing-function: ease-out;\n\n @media (prefers-reduced-motion: reduce) {\n transition-duration: 100ms;\n }\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\n @media (pointer: fine) {\n transition-duration: 150ms;\n transition-delay: 0ms;\n }\n}\n\n.media-default-skin .media-error[data-open] ~ .media-overlay {\n backdrop-filter: blur(16px) saturate(1.5);\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 touch-action: manipulation;\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 Media preview\n ========================================================================== */\n.media-default-skin .media-preview {\n background-color: oklch(0 0 0 / 0.9);\n border-radius: 0.75rem;\n\n & .media-preview__thumbnail {\n display: block;\n position: relative;\n border-radius: inherit;\n overflow: clip;\n\n &::after {\n content: \"\";\n position: absolute;\n inset: 0;\n border-radius: inherit;\n background-image: linear-gradient(to top, oklch(0 0 0 / 0.8), oklch(0 0 0 / 0.3), oklch(0 0 0 / 0));\n }\n }\n\n & .media-preview__timestamp {\n position: absolute;\n bottom: 0.5rem;\n inset-inline: 0;\n text-align: center;\n font-variant-numeric: tabular-nums;\n }\n\n & .media-overlay {\n opacity: 1;\n }\n\n & .media-preview__spinner {\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n opacity: 0;\n }\n\n & .media-preview__thumbnail,\n & .media-preview__spinner {\n transition: opacity 150ms ease-out;\n }\n\n &:has(.media-preview__thumbnail[data-loading]) {\n & .media-preview__thumbnail {\n opacity: 0;\n }\n & .media-preview__spinner {\n opacity: 1;\n }\n }\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 cursor: pointer;\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/* ==========================================================================\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: 150ms;\n\n &[data-starting-style],\n &[data-ending-style] {\n opacity: 0;\n transform: scale(0.5);\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 /* Safe area between trigger and popup */\n &::before {\n content: \"\";\n position: absolute;\n pointer-events: inherit;\n }\n\n &[data-side=\"top\"]::before,\n &[data-side=\"bottom\"]::before {\n width: 100%;\n inset-inline: 0;\n }\n &[data-side=\"top\"]::before {\n top: 100%;\n }\n &[data-side=\"bottom\"]::before {\n bottom: 100%;\n }\n\n &[data-side=\"left\"]::before,\n &[data-side=\"right\"]::before {\n height: 100%;\n inset-block: 0;\n }\n &[data-side=\"left\"]::before {\n left: 100%;\n }\n &[data-side=\"right\"]::before {\n right: 100%;\n }\n}\n\n.media-default-skin .media-popover {\n --media-popover-side-offset: 0.5rem;\n\n &[data-side=\"top\"]::before,\n &[data-side=\"bottom\"]::before {\n height: var(--media-popover-side-offset);\n }\n &[data-side=\"left\"]::before,\n &[data-side=\"right\"]::before {\n width: var(--media-popover-side-offset);\n }\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.75rem;\n\n &[data-side=\"top\"]::before,\n &[data-side=\"bottom\"]::before {\n height: var(--media-tooltip-side-offset);\n }\n &[data-side=\"left\"]::before,\n &[data-side=\"right\"]::before {\n width: var(--media-tooltip-side-offset);\n }\n}\n\n/* ==========================================================================\n Native Caption Track\n ========================================================================== */\n\n.media-default-skin {\n --media-caption-track-duration: 150ms;\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 @media (prefers-reduced-motion: reduce) {\n --media-caption-track-duration: 50ms;\n }\n}\n\n.media-default-skin video::-webkit-media-text-track-container {\n /* NOTE: The delay must account for the controls delay/duration */\n transition: transform var(--media-caption-track-duration) ease-out;\n transition-delay: var(--media-caption-track-delay);\n transform: translateY(var(--media-caption-track-y)) scale(0.98);\n z-index: 1;\n font-family: inherit;\n}\n\n@media (prefers-reduced-motion: reduce) {\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(16px) saturate(1.5);\n --media-video-border-radius: var(--media-border-radius, 2rem);\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 &:fullscreen {\n --media-border-radius: 0;\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 color: oklch(1 0 0);\n\n will-change: scale, transform, filter, opacity;\n transition-timing-function: ease-out;\n transform-origin: bottom;\n\n @media (pointer: fine) {\n transition-property: scale, transform, filter, opacity;\n transition-duration: 100ms;\n transition-delay: 0ms;\n }\n\n &:not([data-visible]) {\n opacity: 0;\n pointer-events: none;\n scale: 0.9;\n filter: blur(8px);\n\n @media (pointer: fine) {\n transition-duration: 300ms;\n transition-delay: 500ms;\n\n @media (prefers-reduced-motion: reduce) {\n transition-duration: 100ms;\n }\n }\n\n @media (prefers-reduced-motion: reduce) {\n scale: 1;\n filter: blur(0);\n }\n }\n}\n\n/* Hide cursor when controls are hidden in fullscreen */\n.media-default-skin--video:fullscreen:has(.media-controls:not([data-visible])) {\n cursor: none;\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.media-default-skin .media-slider__preview {\n position: absolute;\n left: var(--media-slider-pointer);\n bottom: calc(100% + 1.2rem);\n translate: -50%;\n opacity: 0;\n scale: 0.8;\n filter: blur(8px);\n transition-property: scale, opacity, filter;\n transition-duration: 150ms;\n transform-origin: bottom;\n\n & .media-preview__thumbnail {\n max-width: 11rem;\n }\n\n &:has(.media-preview__thumbnail[data-loading]) {\n max-height: 6rem;\n }\n}\n.media-default-skin .media-slider[data-pointing] .media-slider__preview:has([role=\"img\"]:not([data-hidden])) {\n opacity: 1;\n scale: 1;\n filter: blur(0);\n}\n\nmedia-tooltip-group {\n display: contents;\n}\n\n:host {\n display: grid;\n}\n\n";
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--pip .media-icon--pip-enter,\n.media-button--pip .media-icon--pip-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/* Picture-in-Picture: not active → enter */\n.media-button--pip:not([data-pip]) .media-icon--pip-enter,\n/* Picture-in-Picture: active → exit */\n.media-button--pip[data-pip] .media-icon--pip-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}\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 height: 100%;\n width: 100%;\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\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 0 0 0 1px var(--media-surface-outer-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: inset 0 0 0 1px var(--media-surface-inner-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 object-fit: var(--media-object-fit, contain);\n object-position: var(--media-object-position, center);\n}\n.media-default-skin ::slotted(video) {\n border-radius: var(--media-video-border-radius);\n}\n.media-default-skin video {\n border-radius: inherit;\n}\n\n.media-default-skin:fullscreen ::slotted(video),\n.media-default-skin:fullscreen video {\n object-fit: contain;\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.5);\n opacity: 0;\n pointer-events: none;\n\n @media (pointer: fine) {\n transition-property: opacity, backdrop-filter;\n transition-duration: 300ms;\n transition-delay: 500ms;\n transition-timing-function: ease-out;\n\n @media (prefers-reduced-motion: reduce) {\n transition-duration: 100ms;\n }\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\n @media (pointer: fine) {\n transition-duration: 150ms;\n transition-delay: 0ms;\n }\n}\n\n.media-default-skin .media-error[data-open] ~ .media-overlay {\n backdrop-filter: blur(16px) saturate(1.5);\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, scale;\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 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 overflow-wrap: anywhere;\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.15));\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 1px 0 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, scale;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n cursor: pointer;\n user-select: none;\n touch-action: manipulation;\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 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 Poster Image\n ========================================================================== */\n\n.media-default-skin media-poster,\n.media-default-skin > img {\n position: absolute;\n inset: 0;\n width: 100%;\n height: 100%;\n transition: opacity 0.25s;\n pointer-events: none;\n}\n.media-default-skin media-poster:not([data-visible]),\n.media-default-skin > img:not([data-visible]) {\n opacity: 0;\n}\n.media-default-skin media-poster ::slotted(img) {\n position: absolute;\n inset: 0;\n width: 100%;\n height: 100%;\n object-fit: var(--media-object-fit, contain);\n object-position: var(--media-object-position, center);\n border-radius: var(--media-video-border-radius);\n}\n.media-default-skin > img {\n object-fit: var(--media-object-fit, contain);\n object-position: var(--media-object-position, center);\n border-radius: inherit;\n}\n\n.media-default-skin:fullscreen media-poster ::slotted(img),\n.media-default-skin:fullscreen > img {\n object-fit: contain;\n}\n\n/* ==========================================================================\n Media preview\n ========================================================================== */\n.media-default-skin .media-preview {\n background-color: oklch(0 0 0 / 0.9);\n border-radius: 0.75rem;\n\n & .media-preview__thumbnail {\n display: block;\n position: relative;\n border-radius: inherit;\n overflow: clip;\n\n &::after {\n content: \"\";\n position: absolute;\n inset: 0;\n border-radius: inherit;\n background-image: linear-gradient(to top, oklch(0 0 0 / 0.8), oklch(0 0 0 / 0.3), oklch(0 0 0 / 0));\n }\n }\n\n & .media-preview__timestamp {\n position: absolute;\n bottom: 0.5rem;\n inset-inline: 0;\n text-align: center;\n font-variant-numeric: tabular-nums;\n }\n\n & .media-overlay {\n opacity: 1;\n }\n\n & .media-preview__spinner {\n position: absolute;\n top: 50%;\n left: 50%;\n translate: -50% -50%;\n opacity: 0;\n }\n\n & .media-preview__thumbnail,\n & .media-preview__spinner {\n transition: opacity 150ms ease-out;\n }\n\n &:has(.media-preview__thumbnail[data-loading]) {\n & .media-preview__thumbnail {\n opacity: 0;\n }\n & .media-preview__spinner {\n opacity: 1;\n }\n }\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 cursor: pointer;\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 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/* ==========================================================================\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: scale, opacity, filter;\n transition-duration: 150ms;\n\n &[data-starting-style],\n &[data-ending-style] {\n opacity: 0;\n scale: 0.5;\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 /* Safe area between trigger and popup */\n &::before {\n content: \"\";\n position: absolute;\n pointer-events: inherit;\n }\n\n &[data-side=\"top\"]::before,\n &[data-side=\"bottom\"]::before {\n width: 100%;\n inset-inline: 0;\n }\n &[data-side=\"top\"]::before {\n top: 100%;\n }\n &[data-side=\"bottom\"]::before {\n bottom: 100%;\n }\n\n &[data-side=\"left\"]::before,\n &[data-side=\"right\"]::before {\n height: 100%;\n inset-block: 0;\n }\n &[data-side=\"left\"]::before {\n left: 100%;\n }\n &[data-side=\"right\"]::before {\n right: 100%;\n }\n}\n\n.media-default-skin .media-popover {\n --media-popover-side-offset: 0.5rem;\n\n &[data-side=\"top\"]::before,\n &[data-side=\"bottom\"]::before {\n height: var(--media-popover-side-offset);\n }\n &[data-side=\"left\"]::before,\n &[data-side=\"right\"]::before {\n width: var(--media-popover-side-offset);\n }\n}\n.media-default-skin .media-popover--volume {\n padding: 0.625rem 0.25rem;\n border-radius: calc(infinity * 1px);\n\n &:has(media-volume-slider[data-availability=\"unsupported\"]) {\n display: none;\n }\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.75rem;\n\n &[data-side=\"top\"]::before,\n &[data-side=\"bottom\"]::before {\n height: var(--media-tooltip-side-offset);\n }\n &[data-side=\"left\"]::before,\n &[data-side=\"right\"]::before {\n width: var(--media-tooltip-side-offset);\n }\n}\n\n/* ==========================================================================\n Native Caption Track\n ========================================================================== */\n\n.media-default-skin {\n --media-caption-track-duration: var(--media-controls-transition-duration);\n --media-caption-track-delay: calc(var(--media-controls-transition-delay) + 25ms);\n --media-caption-track-y: -0.5rem;\n\n &:has(.media-controls[data-visible]) {\n --media-caption-track-y: -3.5rem;\n }\n}\n\n.media-default-skin video::-webkit-media-text-track-container {\n transition: translate var(--media-caption-track-duration) ease-out;\n transition-delay: var(--media-caption-track-delay);\n translate: 0 var(--media-caption-track-y);\n scale: 0.98;\n z-index: 1;\n font-family: inherit;\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(16px) saturate(1.5);\n --media-video-border-radius: var(--media-border-radius, 2rem);\n --media-controls-transition-duration: 100ms;\n --media-controls-transition-delay: 0ms;\n\n @media (prefers-color-scheme: dark) {\n --media-border-color: oklch(1 0 0 / 0.15);\n }\n\n &:has(.media-controls:not([data-visible])) {\n /* Slight delay to hide controls on non-touch devices after interaction */\n @media (pointer: fine) {\n --media-controls-transition-delay: 500ms;\n --media-controls-transition-duration: 300ms;\n }\n @media (pointer: coarse) {\n --media-controls-transition-duration: 150ms;\n }\n @media (prefers-reduced-motion: reduce) {\n --media-controls-transition-duration: 100ms;\n }\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 &:fullscreen {\n --media-border-radius: 0;\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 color: var(--media-color-primary, oklch(1 0 0));\n transition-timing-function: ease-out;\n transition-duration: var(--media-controls-transition-duration);\n transition-delay: var(--media-controls-transition-delay);\n transform-origin: bottom;\n\n @media (pointer: fine) {\n will-change: scale, filter, opacity;\n transition-property: scale, filter, opacity;\n }\n\n @media (pointer: coarse) {\n will-change: scale, opacity;\n transition-property: scale, opacity;\n }\n\n &:not([data-visible]) {\n opacity: 0;\n pointer-events: none;\n scale: 0.9;\n\n @media (pointer: fine) {\n filter: blur(8px);\n\n @media (prefers-reduced-motion: reduce) {\n filter: blur(0);\n }\n }\n\n @media (prefers-reduced-motion: reduce) {\n scale: 1;\n }\n }\n}\n\n/* Hide cursor when controls are hidden in fullscreen */\n@media (pointer: fine) {\n .media-default-skin--video:fullscreen:has(.media-controls:not([data-visible])) {\n cursor: none;\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.media-default-skin .media-slider__preview {\n position: absolute;\n left: var(--media-slider-pointer);\n bottom: calc(100% + 1.2rem);\n translate: -50%;\n opacity: 0;\n scale: 0.8;\n filter: blur(8px);\n transition-property: scale, opacity, filter;\n transition-duration: 150ms;\n transition-timing-function: ease-out;\n transform-origin: bottom;\n pointer-events: none;\n\n & .media-preview__thumbnail {\n max-width: 11rem;\n }\n\n &:has(.media-preview__thumbnail[data-loading]) {\n max-height: 6rem;\n }\n}\n.media-default-skin .media-slider[data-pointing] .media-slider__preview:has([role=\"img\"]:not([data-hidden])) {\n opacity: 1;\n scale: 1;\n filter: blur(0);\n}\n\n";
3
3
 
4
4
  //#endregion
5
5
  export { skin_default as default };
@@ -1 +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}\\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 height: 100%;\\n width: 100%;\\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\\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 0 0 0 1px var(--media-surface-outer-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: inset 0 0 0 1px var(--media-surface-inner-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 object-fit: var(--media-object-fit, contain);\\n object-position: var(--media-object-position, center);\\n}\\n.media-default-skin ::slotted(video) {\\n border-radius: var(--media-video-border-radius);\\n}\\n.media-default-skin video {\\n border-radius: inherit;\\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 object-fit: var(--media-object-fit, contain);\\n object-position: var(--media-object-position, center);\\n transition: opacity 0.25s;\\n pointer-events: none;\\n border-radius: inherit;\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n }\\n}\\n\\n/* ==========================================================================\\n Fullscreen\\n ========================================================================== */\\n\\n.media-default-skin:fullscreen ::slotted(video),\\n.media-default-skin:fullscreen video {\\n object-fit: contain;\\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.5);\\n opacity: 0;\\n pointer-events: none;\\n\\n @media (pointer: fine) {\\n transition-property: opacity, backdrop-filter;\\n transition-duration: 300ms;\\n transition-delay: 500ms;\\n transition-timing-function: ease-out;\\n\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n }\\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\\n @media (pointer: fine) {\\n transition-duration: 150ms;\\n transition-delay: 0ms;\\n }\\n}\\n\\n.media-default-skin .media-error[data-open] ~ .media-overlay {\\n backdrop-filter: blur(16px) saturate(1.5);\\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 touch-action: manipulation;\\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 Media preview\\n ========================================================================== */\\n.media-default-skin .media-preview {\\n background-color: oklch(0 0 0 / 0.9);\\n border-radius: 0.75rem;\\n\\n & .media-preview__thumbnail {\\n display: block;\\n position: relative;\\n border-radius: inherit;\\n overflow: clip;\\n\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n border-radius: inherit;\\n background-image: linear-gradient(to top, oklch(0 0 0 / 0.8), oklch(0 0 0 / 0.3), oklch(0 0 0 / 0));\\n }\\n }\\n\\n & .media-preview__timestamp {\\n position: absolute;\\n bottom: 0.5rem;\\n inset-inline: 0;\\n text-align: center;\\n font-variant-numeric: tabular-nums;\\n }\\n\\n & .media-overlay {\\n opacity: 1;\\n }\\n\\n & .media-preview__spinner {\\n position: absolute;\\n top: 50%;\\n left: 50%;\\n transform: translate(-50%, -50%);\\n opacity: 0;\\n }\\n\\n & .media-preview__thumbnail,\\n & .media-preview__spinner {\\n transition: opacity 150ms ease-out;\\n }\\n\\n &:has(.media-preview__thumbnail[data-loading]) {\\n & .media-preview__thumbnail {\\n opacity: 0;\\n }\\n & .media-preview__spinner {\\n opacity: 1;\\n }\\n }\\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 cursor: pointer;\\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/* ==========================================================================\\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: 150ms;\\n\\n &[data-starting-style],\\n &[data-ending-style] {\\n opacity: 0;\\n transform: scale(0.5);\\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 /* Safe area between trigger and popup */\\n &::before {\\n content: \\\"\\\";\\n position: absolute;\\n pointer-events: inherit;\\n }\\n\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n width: 100%;\\n inset-inline: 0;\\n }\\n &[data-side=\\\"top\\\"]::before {\\n top: 100%;\\n }\\n &[data-side=\\\"bottom\\\"]::before {\\n bottom: 100%;\\n }\\n\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n height: 100%;\\n inset-block: 0;\\n }\\n &[data-side=\\\"left\\\"]::before {\\n left: 100%;\\n }\\n &[data-side=\\\"right\\\"]::before {\\n right: 100%;\\n }\\n}\\n\\n.media-default-skin .media-popover {\\n --media-popover-side-offset: 0.5rem;\\n\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n height: var(--media-popover-side-offset);\\n }\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n width: var(--media-popover-side-offset);\\n }\\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.75rem;\\n\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n height: var(--media-tooltip-side-offset);\\n }\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n width: var(--media-tooltip-side-offset);\\n }\\n}\\n\\n/* ==========================================================================\\n Native Caption Track\\n ========================================================================== */\\n\\n.media-default-skin {\\n --media-caption-track-duration: 150ms;\\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 @media (prefers-reduced-motion: reduce) {\\n --media-caption-track-duration: 50ms;\\n }\\n}\\n\\n.media-default-skin video::-webkit-media-text-track-container {\\n /* NOTE: The delay must account for the controls delay/duration */\\n transition: transform var(--media-caption-track-duration) ease-out;\\n transition-delay: var(--media-caption-track-delay);\\n transform: translateY(var(--media-caption-track-y)) scale(0.98);\\n z-index: 1;\\n font-family: inherit;\\n}\\n\\n@media (prefers-reduced-motion: reduce) {\\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(16px) saturate(1.5);\\n --media-video-border-radius: var(--media-border-radius, 2rem);\\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 &:fullscreen {\\n --media-border-radius: 0;\\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 color: oklch(1 0 0);\\n\\n will-change: scale, transform, filter, opacity;\\n transition-timing-function: ease-out;\\n transform-origin: bottom;\\n\\n @media (pointer: fine) {\\n transition-property: scale, transform, filter, opacity;\\n transition-duration: 100ms;\\n transition-delay: 0ms;\\n }\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n pointer-events: none;\\n scale: 0.9;\\n filter: blur(8px);\\n\\n @media (pointer: fine) {\\n transition-duration: 300ms;\\n transition-delay: 500ms;\\n\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n }\\n }\\n\\n @media (prefers-reduced-motion: reduce) {\\n scale: 1;\\n filter: blur(0);\\n }\\n }\\n}\\n\\n/* Hide cursor when controls are hidden in fullscreen */\\n.media-default-skin--video:fullscreen:has(.media-controls:not([data-visible])) {\\n cursor: none;\\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.media-default-skin .media-slider__preview {\\n position: absolute;\\n left: var(--media-slider-pointer);\\n bottom: calc(100% + 1.2rem);\\n translate: -50%;\\n opacity: 0;\\n scale: 0.8;\\n filter: blur(8px);\\n transition-property: scale, opacity, filter;\\n transition-duration: 150ms;\\n transform-origin: bottom;\\n\\n & .media-preview__thumbnail {\\n max-width: 11rem;\\n }\\n\\n &:has(.media-preview__thumbnail[data-loading]) {\\n max-height: 6rem;\\n }\\n}\\n.media-default-skin .media-slider[data-pointing] .media-slider__preview:has([role=\\\"img\\\"]:not([data-hidden])) {\\n opacity: 1;\\n scale: 1;\\n filter: blur(0);\\n}\\n\\nmedia-tooltip-group {\\n display: contents;\\n}\\n\\n:host {\\n display: grid;\\n}\\n\\n\";"],"mappings":";AAAA,mBAAe"}
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--pip .media-icon--pip-enter,\\n.media-button--pip .media-icon--pip-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/* Picture-in-Picture: not active → enter */\\n.media-button--pip:not([data-pip]) .media-icon--pip-enter,\\n/* Picture-in-Picture: active → exit */\\n.media-button--pip[data-pip] .media-icon--pip-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}\\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 height: 100%;\\n width: 100%;\\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\\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 0 0 0 1px var(--media-surface-outer-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: inset 0 0 0 1px var(--media-surface-inner-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 object-fit: var(--media-object-fit, contain);\\n object-position: var(--media-object-position, center);\\n}\\n.media-default-skin ::slotted(video) {\\n border-radius: var(--media-video-border-radius);\\n}\\n.media-default-skin video {\\n border-radius: inherit;\\n}\\n\\n.media-default-skin:fullscreen ::slotted(video),\\n.media-default-skin:fullscreen video {\\n object-fit: contain;\\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.5);\\n opacity: 0;\\n pointer-events: none;\\n\\n @media (pointer: fine) {\\n transition-property: opacity, backdrop-filter;\\n transition-duration: 300ms;\\n transition-delay: 500ms;\\n transition-timing-function: ease-out;\\n\\n @media (prefers-reduced-motion: reduce) {\\n transition-duration: 100ms;\\n }\\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\\n @media (pointer: fine) {\\n transition-duration: 150ms;\\n transition-delay: 0ms;\\n }\\n}\\n\\n.media-default-skin .media-error[data-open] ~ .media-overlay {\\n backdrop-filter: blur(16px) saturate(1.5);\\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, scale;\\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 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 overflow-wrap: anywhere;\\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.15));\\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 1px 0 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, scale;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n cursor: pointer;\\n user-select: none;\\n touch-action: manipulation;\\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 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 Poster Image\\n ========================================================================== */\\n\\n.media-default-skin media-poster,\\n.media-default-skin > img {\\n position: absolute;\\n inset: 0;\\n width: 100%;\\n height: 100%;\\n transition: opacity 0.25s;\\n pointer-events: none;\\n}\\n.media-default-skin media-poster:not([data-visible]),\\n.media-default-skin > img:not([data-visible]) {\\n opacity: 0;\\n}\\n.media-default-skin media-poster ::slotted(img) {\\n position: absolute;\\n inset: 0;\\n width: 100%;\\n height: 100%;\\n object-fit: var(--media-object-fit, contain);\\n object-position: var(--media-object-position, center);\\n border-radius: var(--media-video-border-radius);\\n}\\n.media-default-skin > img {\\n object-fit: var(--media-object-fit, contain);\\n object-position: var(--media-object-position, center);\\n border-radius: inherit;\\n}\\n\\n.media-default-skin:fullscreen media-poster ::slotted(img),\\n.media-default-skin:fullscreen > img {\\n object-fit: contain;\\n}\\n\\n/* ==========================================================================\\n Media preview\\n ========================================================================== */\\n.media-default-skin .media-preview {\\n background-color: oklch(0 0 0 / 0.9);\\n border-radius: 0.75rem;\\n\\n & .media-preview__thumbnail {\\n display: block;\\n position: relative;\\n border-radius: inherit;\\n overflow: clip;\\n\\n &::after {\\n content: \\\"\\\";\\n position: absolute;\\n inset: 0;\\n border-radius: inherit;\\n background-image: linear-gradient(to top, oklch(0 0 0 / 0.8), oklch(0 0 0 / 0.3), oklch(0 0 0 / 0));\\n }\\n }\\n\\n & .media-preview__timestamp {\\n position: absolute;\\n bottom: 0.5rem;\\n inset-inline: 0;\\n text-align: center;\\n font-variant-numeric: tabular-nums;\\n }\\n\\n & .media-overlay {\\n opacity: 1;\\n }\\n\\n & .media-preview__spinner {\\n position: absolute;\\n top: 50%;\\n left: 50%;\\n translate: -50% -50%;\\n opacity: 0;\\n }\\n\\n & .media-preview__thumbnail,\\n & .media-preview__spinner {\\n transition: opacity 150ms ease-out;\\n }\\n\\n &:has(.media-preview__thumbnail[data-loading]) {\\n & .media-preview__thumbnail {\\n opacity: 0;\\n }\\n & .media-preview__spinner {\\n opacity: 1;\\n }\\n }\\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 cursor: pointer;\\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 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/* ==========================================================================\\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: scale, opacity, filter;\\n transition-duration: 150ms;\\n\\n &[data-starting-style],\\n &[data-ending-style] {\\n opacity: 0;\\n scale: 0.5;\\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 /* Safe area between trigger and popup */\\n &::before {\\n content: \\\"\\\";\\n position: absolute;\\n pointer-events: inherit;\\n }\\n\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n width: 100%;\\n inset-inline: 0;\\n }\\n &[data-side=\\\"top\\\"]::before {\\n top: 100%;\\n }\\n &[data-side=\\\"bottom\\\"]::before {\\n bottom: 100%;\\n }\\n\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n height: 100%;\\n inset-block: 0;\\n }\\n &[data-side=\\\"left\\\"]::before {\\n left: 100%;\\n }\\n &[data-side=\\\"right\\\"]::before {\\n right: 100%;\\n }\\n}\\n\\n.media-default-skin .media-popover {\\n --media-popover-side-offset: 0.5rem;\\n\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n height: var(--media-popover-side-offset);\\n }\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n width: var(--media-popover-side-offset);\\n }\\n}\\n.media-default-skin .media-popover--volume {\\n padding: 0.625rem 0.25rem;\\n border-radius: calc(infinity * 1px);\\n\\n &:has(media-volume-slider[data-availability=\\\"unsupported\\\"]) {\\n display: none;\\n }\\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.75rem;\\n\\n &[data-side=\\\"top\\\"]::before,\\n &[data-side=\\\"bottom\\\"]::before {\\n height: var(--media-tooltip-side-offset);\\n }\\n &[data-side=\\\"left\\\"]::before,\\n &[data-side=\\\"right\\\"]::before {\\n width: var(--media-tooltip-side-offset);\\n }\\n}\\n\\n/* ==========================================================================\\n Native Caption Track\\n ========================================================================== */\\n\\n.media-default-skin {\\n --media-caption-track-duration: var(--media-controls-transition-duration);\\n --media-caption-track-delay: calc(var(--media-controls-transition-delay) + 25ms);\\n --media-caption-track-y: -0.5rem;\\n\\n &:has(.media-controls[data-visible]) {\\n --media-caption-track-y: -3.5rem;\\n }\\n}\\n\\n.media-default-skin video::-webkit-media-text-track-container {\\n transition: translate var(--media-caption-track-duration) ease-out;\\n transition-delay: var(--media-caption-track-delay);\\n translate: 0 var(--media-caption-track-y);\\n scale: 0.98;\\n z-index: 1;\\n font-family: inherit;\\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(16px) saturate(1.5);\\n --media-video-border-radius: var(--media-border-radius, 2rem);\\n --media-controls-transition-duration: 100ms;\\n --media-controls-transition-delay: 0ms;\\n\\n @media (prefers-color-scheme: dark) {\\n --media-border-color: oklch(1 0 0 / 0.15);\\n }\\n\\n &:has(.media-controls:not([data-visible])) {\\n /* Slight delay to hide controls on non-touch devices after interaction */\\n @media (pointer: fine) {\\n --media-controls-transition-delay: 500ms;\\n --media-controls-transition-duration: 300ms;\\n }\\n @media (pointer: coarse) {\\n --media-controls-transition-duration: 150ms;\\n }\\n @media (prefers-reduced-motion: reduce) {\\n --media-controls-transition-duration: 100ms;\\n }\\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 &:fullscreen {\\n --media-border-radius: 0;\\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 color: var(--media-color-primary, oklch(1 0 0));\\n transition-timing-function: ease-out;\\n transition-duration: var(--media-controls-transition-duration);\\n transition-delay: var(--media-controls-transition-delay);\\n transform-origin: bottom;\\n\\n @media (pointer: fine) {\\n will-change: scale, filter, opacity;\\n transition-property: scale, filter, opacity;\\n }\\n\\n @media (pointer: coarse) {\\n will-change: scale, opacity;\\n transition-property: scale, opacity;\\n }\\n\\n &:not([data-visible]) {\\n opacity: 0;\\n pointer-events: none;\\n scale: 0.9;\\n\\n @media (pointer: fine) {\\n filter: blur(8px);\\n\\n @media (prefers-reduced-motion: reduce) {\\n filter: blur(0);\\n }\\n }\\n\\n @media (prefers-reduced-motion: reduce) {\\n scale: 1;\\n }\\n }\\n}\\n\\n/* Hide cursor when controls are hidden in fullscreen */\\n@media (pointer: fine) {\\n .media-default-skin--video:fullscreen:has(.media-controls:not([data-visible])) {\\n cursor: none;\\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.media-default-skin .media-slider__preview {\\n position: absolute;\\n left: var(--media-slider-pointer);\\n bottom: calc(100% + 1.2rem);\\n translate: -50%;\\n opacity: 0;\\n scale: 0.8;\\n filter: blur(8px);\\n transition-property: scale, opacity, filter;\\n transition-duration: 150ms;\\n transition-timing-function: ease-out;\\n transform-origin: bottom;\\n pointer-events: none;\\n\\n & .media-preview__thumbnail {\\n max-width: 11rem;\\n }\\n\\n &:has(.media-preview__thumbnail[data-loading]) {\\n max-height: 6rem;\\n }\\n}\\n.media-default-skin .media-slider[data-pointing] .media-slider__preview:has([role=\\\"img\\\"]:not([data-hidden])) {\\n opacity: 1;\\n scale: 1;\\n filter: blur(0);\\n}\\n\\n\";"],"mappings":";AAAA,mBAAe"}
@@ -152,7 +152,7 @@
152
152
  color: oklch(1 0 0);
153
153
  font-size: 0.875rem;
154
154
  text-shadow: 0 1px 0 oklch(0 0 0 / 0.5);
155
- transition-property: opacity, transform;
155
+ transition-property: opacity, scale;
156
156
  transition-duration: 500ms;
157
157
  transition-delay: 100ms;
158
158
  transition-timing-function: linear(
@@ -178,7 +178,7 @@
178
178
  .media-minimal-skin .media-error[data-starting-style] .media-error__dialog,
179
179
  .media-minimal-skin .media-error[data-ending-style] .media-error__dialog {
180
180
  opacity: 0;
181
- transform: scale(0.5);
181
+ scale: 0.5;
182
182
  }
183
183
 
184
184
  .media-minimal-skin .media-error__content {
@@ -195,6 +195,7 @@
195
195
 
196
196
  .media-minimal-skin .media-error__description {
197
197
  opacity: 0.7;
198
+ overflow-wrap: anywhere;
198
199
  }
199
200
 
200
201
  .media-minimal-skin .media-error__actions {
@@ -214,12 +215,12 @@
214
215
  container: media-controls / inline-size;
215
216
  display: flex;
216
217
  align-items: center;
217
- --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.25));
218
+ --media-controls-current-shadow-color: oklch(from currentColor 0 0 0 / clamp(0, calc((l - 0.5) * 0.5), 0.15));
218
219
  --media-controls-current-shadow-color-subtle: oklch(
219
220
  from var(--media-controls-current-shadow-color) l c h /
220
221
  calc(alpha * 0.4)
221
222
  );
222
- text-shadow: 0 0 1px var(--media-controls-current-shadow-color);
223
+ text-shadow: 0 1px 0 var(--media-controls-current-shadow-color);
223
224
  }
224
225
 
225
226
  /* ==========================================================================
@@ -293,7 +294,7 @@
293
294
  font-weight: 500;
294
295
  text-align: center;
295
296
  text-shadow: inherit;
296
- transition-property: background-color, color, outline-offset, transform;
297
+ transition-property: background-color, color, outline-offset, scale;
297
298
  transition-duration: 150ms;
298
299
  transition-timing-function: ease-out;
299
300
  cursor: pointer;
@@ -333,7 +334,7 @@
333
334
  }
334
335
 
335
336
  &:active {
336
- transform: scale(0.9);
337
+ scale: 0.9;
337
338
  }
338
339
 
339
340
  & .media-icon {
@@ -444,7 +445,7 @@
444
445
  /* Thumb */
445
446
  .media-minimal-skin .media-slider__thumb {
446
447
  position: absolute;
447
- transform: translate(-50%, -50%);
448
+ translate: -50% -50%;
448
449
  z-index: 10;
449
450
  width: 0.75rem;
450
451
  height: 0.75rem;
@@ -547,13 +548,13 @@
547
548
  border: 0;
548
549
  color: inherit;
549
550
  overflow: visible;
550
- transition-property: transform, scale, opacity, filter;
551
+ transition-property: scale, opacity, filter;
551
552
  transition-duration: 150ms;
552
553
 
553
554
  &[data-starting-style],
554
555
  &[data-ending-style] {
555
556
  opacity: 0;
556
- transform: scale(0.5);
557
+ scale: 0.5;
557
558
  filter: blur(8px);
558
559
  }
559
560
 
@@ -647,22 +648,31 @@
647
648
  }
648
649
  }
649
650
 
651
+ .media-minimal-skin .media-popover--volume:has(media-volume-slider[data-availability="unsupported"]) {
652
+ display: none;
653
+ }
654
+
650
655
 
651
656
  /* ==========================================================================
652
- Controls
657
+ Root
653
658
  ========================================================================== */
654
659
 
655
660
  .media-minimal-skin--audio {
656
661
  --media-controls-background-color: oklch(1 0 0);
657
662
  --media-controls-border-color: oklch(0 0 0 / 0.1);
658
- --media-controls-text-color: oklch(0 0 0);
663
+ --media-controls-text-color: var(--media-color-primary, oklch(0 0 0));
659
664
 
660
665
  @media (prefers-color-scheme: dark) {
661
666
  --media-controls-background-color: oklch(0 0 0);
662
667
  --media-controls-border-color: oklch(1 0 0 / 0.1);
663
- --media-controls-text-color: oklch(1 0 0);
668
+ --media-controls-text-color: var(--media-color-primary, oklch(1 0 0));
664
669
  }
665
670
  }
671
+
672
+ /* ==========================================================================
673
+ Controls
674
+ ========================================================================== */
675
+
666
676
  .media-minimal-skin--audio .media-controls {
667
677
  gap: 0.5rem;
668
678
  padding: 0.375rem;
@@ -683,11 +693,3 @@
683
693
  --media-popover-side-offset: 0.75rem;
684
694
  }
685
695
 
686
- media-tooltip-group {
687
- display: contents;
688
- }
689
-
690
- :host {
691
- display: grid;
692
- }
693
-
@@ -1 +1 @@
1
- {"version":3,"file":"minimal-skin.d.ts","names":[],"sources":["../../../../src/define/audio/minimal-skin.ts"],"mappings":";;;iBAoBS,eAAA,CAAA;AAAA,cAAe,4BAAA;;;;cAoFX,uBAAA,SAAgC,4BAAA;EAAA,gBAC3B,OAAA;EAAA,OACT,MAAA,EAAM,aAAA;EAAA,OACN,eAAA,SAAe,eAAA;AAAA;AAAA,QAKhB,MAAA;EAAA,UACI,qBAAA;IAAA,CACP,uBAAA,CAAwB,OAAA,GAAU,uBAAA;EAAA;AAAA"}
1
+ {"version":3,"file":"minimal-skin.d.ts","names":[],"sources":["../../../../src/define/audio/minimal-skin.ts"],"mappings":";;;iBAoBS,eAAA,CAAA;AAAA,cAAe,4BAAA;;;;cAsFX,uBAAA,SAAgC,4BAAA;EAAA,gBAC3B,OAAA;EAAA,OACT,MAAA,EAAM,aAAA;EAAA,OACN,eAAA,SAAe,eAAA;AAAA;AAAA,QAKhB,MAAA;EAAA,UACI,qBAAA;IAAA,CACP,uBAAA,CAAwB,OAAA,GAAU,uBAAA;EAAA;AAAA"}
@@ -19,7 +19,9 @@ const SEEK_TIME = 10;
19
19
  function getTemplateHTML() {
20
20
  return `
21
21
  <media-container class="media-minimal-skin media-minimal-skin--audio">
22
+ <!-- @deprecated slot="media" is no longer required, use the default slot instead -->
22
23
  <slot name="media"></slot>
24
+ <slot></slot>
23
25
 
24
26
  <div class="media-controls">
25
27
  <media-tooltip-group>
@@ -1 +1 @@
1
- {"version":3,"file":"minimal-skin.js","names":["styles"],"sources":["../../../../src/define/audio/minimal-skin.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { renderIcon } from '@videojs/icons/render/minimal';\nimport { createStyles, SkinMixin } from '../skin-mixin';\nimport styles from './minimal-skin.css?inline';\n\n// Side-effect imports: register all custom elements used in the template.\nimport '../media/container';\nimport '../ui/mute-button';\nimport '../ui/play-button';\nimport '../ui/playback-rate-button';\nimport '../ui/popover';\nimport '../ui/seek-button';\nimport '../ui/time';\nimport '../ui/time-slider';\nimport '../ui/tooltip';\nimport '../ui/tooltip-group';\nimport '../ui/volume-slider';\n\nconst SEEK_TIME = 10;\n\nfunction getTemplateHTML() {\n return /*html*/ `\n <media-container class=\"media-minimal-skin media-minimal-skin--audio\">\n <slot name=\"media\"></slot>\n\n <div class=\"media-controls\">\n <media-tooltip-group>\n <div class=\"media-button-group\">\n <media-play-button commandfor=\"play-tooltip\" class=\"media-button media-button--icon media-button--play\">\n ${renderIcon('restart', { class: 'media-icon media-icon--restart' })}\n ${renderIcon('play', { class: 'media-icon media-icon--play' })}\n ${renderIcon('pause', { class: 'media-icon media-icon--pause' })}\n </media-play-button>\n <media-tooltip id=\"play-tooltip\" side=\"top\" class=\"media-tooltip\">\n <span class=\"media-tooltip-label media-tooltip-label--replay\">Replay</span>\n <span class=\"media-tooltip-label media-tooltip-label--play\">Play</span>\n <span class=\"media-tooltip-label media-tooltip-label--pause\">Pause</span>\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-backward-tooltip\" seconds=\"${-SEEK_TIME}\" class=\"media-button media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon media-icon--seek media-icon--flipped' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-backward-tooltip\" side=\"top\" class=\"media-tooltip\">\n Seek backward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-forward-tooltip\" seconds=\"${SEEK_TIME}\" class=\"media-button media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon media-icon--seek' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-forward-tooltip\" side=\"top\" class=\"media-tooltip\">\n Seek forward ${SEEK_TIME} seconds\n </media-tooltip>\n </div>\n\n <div class=\"media-time-controls\">\n <media-time-group class=\"media-time\">\n <media-time type=\"current\" class=\"media-time__value media-time__value--current\"></media-time>\n <media-time-separator class=\"media-time__separator\"></media-time-separator>\n <media-time type=\"duration\" class=\"media-time__value media-time__value--duration\"></media-time>\n </media-time-group>\n\n <media-time-slider class=\"media-slider\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n <media-slider-buffer class=\"media-slider__buffer\"></media-slider-buffer>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb\"></media-slider-thumb>\n </media-time-slider>\n </div>\n\n <div class=\"media-button-group\">\n <media-playback-rate-button commandfor=\"playback-rate-tooltip\" class=\"media-button media-button--icon media-button--playback-rate\">\n </media-playback-rate-button>\n <media-tooltip id=\"playback-rate-tooltip\" side=\"top\" class=\"media-tooltip\">\n Toggle playback rate\n </media-tooltip>\n\n <media-mute-button commandfor=\"audio-volume-popover\" class=\"media-button media-button--icon media-button--mute\">\n ${renderIcon('volume-off', { class: 'media-icon media-icon--volume-off' })}\n ${renderIcon('volume-low', { class: 'media-icon media-icon--volume-low' })}\n ${renderIcon('volume-high', { class: 'media-icon media-icon--volume-high' })}\n </media-mute-button>\n\n <media-popover id=\"audio-volume-popover\" open-on-hover delay=\"200\" close-delay=\"100\" side=\"left\" class=\"media-popover media-popover--volume\">\n <media-volume-slider class=\"media-slider\" orientation=\"horizontal\" thumb-alignment=\"edge\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb media-slider__thumb--persistent\"></media-slider-thumb>\n </media-volume-slider>\n </media-popover>\n </div>\n </media-tooltip-group>\n </div>\n </media-container>\n `;\n}\n\nexport class MinimalAudioSkinElement extends SkinMixin(ReactiveElement) {\n static readonly tagName = 'audio-minimal-skin';\n static styles = createStyles(styles);\n static getTemplateHTML = getTemplateHTML;\n}\n\ncustomElements.define(MinimalAudioSkinElement.tagName, MinimalAudioSkinElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [MinimalAudioSkinElement.tagName]: MinimalAudioSkinElement;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAkBA,MAAM,YAAY;AAElB,SAAS,kBAAkB;AACzB,QAAgB;;;;;;;;gBAQF,WAAW,WAAW,EAAE,OAAO,kCAAkC,CAAC,CAAC;gBACnE,WAAW,QAAQ,EAAE,OAAO,+BAA+B,CAAC,CAAC;gBAC7D,WAAW,SAAS,EAAE,OAAO,gCAAgC,CAAC,CAAC;;;;;;;;6EAQF,CAAC,UAAU;;kBAEtE,WAAW,QAAQ,EAAE,OAAO,mDAAmD,CAAC,CAAC;kDACjD,UAAU;;;;8BAI9B,UAAU;;;4EAGoC,UAAU;;kBAEpE,WAAW,QAAQ,EAAE,OAAO,+BAA+B,CAAC,CAAC;kDAC7B,UAAU;;;;6BAI/B,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBA4BvB,WAAW,cAAc,EAAE,OAAO,qCAAqC,CAAC,CAAC;gBACzE,WAAW,cAAc,EAAE,OAAO,qCAAqC,CAAC,CAAC;gBACzE,WAAW,eAAe,EAAE,OAAO,sCAAsC,CAAC,CAAC;;;;;;;;;;;;;;;;;AAkB3F,IAAa,0BAAb,cAA6C,UAAU,gBAAgB,CAAC;;iBAC5C;;;gBACV,aAAaA,qBAAO;;;yBACX;;;AAG3B,eAAe,OAAO,wBAAwB,SAAS,wBAAwB"}
1
+ {"version":3,"file":"minimal-skin.js","names":["styles"],"sources":["../../../../src/define/audio/minimal-skin.ts"],"sourcesContent":["import { ReactiveElement } from '@videojs/element';\nimport { renderIcon } from '@videojs/icons/render/minimal';\nimport { createStyles, SkinMixin } from '../skin-mixin';\nimport styles from './minimal-skin.css?inline';\n\n// Side-effect imports: register all custom elements used in the template.\nimport '../media/container';\nimport '../ui/mute-button';\nimport '../ui/play-button';\nimport '../ui/playback-rate-button';\nimport '../ui/popover';\nimport '../ui/seek-button';\nimport '../ui/time';\nimport '../ui/time-slider';\nimport '../ui/tooltip';\nimport '../ui/tooltip-group';\nimport '../ui/volume-slider';\n\nconst SEEK_TIME = 10;\n\nfunction getTemplateHTML() {\n return /*html*/ `\n <media-container class=\"media-minimal-skin media-minimal-skin--audio\">\n <!-- @deprecated slot=\"media\" is no longer required, use the default slot instead -->\n <slot name=\"media\"></slot>\n <slot></slot>\n\n <div class=\"media-controls\">\n <media-tooltip-group>\n <div class=\"media-button-group\">\n <media-play-button commandfor=\"play-tooltip\" class=\"media-button media-button--icon media-button--play\">\n ${renderIcon('restart', { class: 'media-icon media-icon--restart' })}\n ${renderIcon('play', { class: 'media-icon media-icon--play' })}\n ${renderIcon('pause', { class: 'media-icon media-icon--pause' })}\n </media-play-button>\n <media-tooltip id=\"play-tooltip\" side=\"top\" class=\"media-tooltip\">\n <span class=\"media-tooltip-label media-tooltip-label--replay\">Replay</span>\n <span class=\"media-tooltip-label media-tooltip-label--play\">Play</span>\n <span class=\"media-tooltip-label media-tooltip-label--pause\">Pause</span>\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-backward-tooltip\" seconds=\"${-SEEK_TIME}\" class=\"media-button media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon media-icon--seek media-icon--flipped' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-backward-tooltip\" side=\"top\" class=\"media-tooltip\">\n Seek backward ${SEEK_TIME} seconds\n </media-tooltip>\n\n <media-seek-button commandfor=\"seek-forward-tooltip\" seconds=\"${SEEK_TIME}\" class=\"media-button media-button--icon media-button--seek\">\n <span class=\"media-icon__container\">\n ${renderIcon('seek', { class: 'media-icon media-icon--seek' })}\n <span class=\"media-icon__label\">${SEEK_TIME}</span>\n </span>\n </media-seek-button>\n <media-tooltip id=\"seek-forward-tooltip\" side=\"top\" class=\"media-tooltip\">\n Seek forward ${SEEK_TIME} seconds\n </media-tooltip>\n </div>\n\n <div class=\"media-time-controls\">\n <media-time-group class=\"media-time\">\n <media-time type=\"current\" class=\"media-time__value media-time__value--current\"></media-time>\n <media-time-separator class=\"media-time__separator\"></media-time-separator>\n <media-time type=\"duration\" class=\"media-time__value media-time__value--duration\"></media-time>\n </media-time-group>\n\n <media-time-slider class=\"media-slider\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n <media-slider-buffer class=\"media-slider__buffer\"></media-slider-buffer>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb\"></media-slider-thumb>\n </media-time-slider>\n </div>\n\n <div class=\"media-button-group\">\n <media-playback-rate-button commandfor=\"playback-rate-tooltip\" class=\"media-button media-button--icon media-button--playback-rate\">\n </media-playback-rate-button>\n <media-tooltip id=\"playback-rate-tooltip\" side=\"top\" class=\"media-tooltip\">\n Toggle playback rate\n </media-tooltip>\n\n <media-mute-button commandfor=\"audio-volume-popover\" class=\"media-button media-button--icon media-button--mute\">\n ${renderIcon('volume-off', { class: 'media-icon media-icon--volume-off' })}\n ${renderIcon('volume-low', { class: 'media-icon media-icon--volume-low' })}\n ${renderIcon('volume-high', { class: 'media-icon media-icon--volume-high' })}\n </media-mute-button>\n\n <media-popover id=\"audio-volume-popover\" open-on-hover delay=\"200\" close-delay=\"100\" side=\"left\" class=\"media-popover media-popover--volume\">\n <media-volume-slider class=\"media-slider\" orientation=\"horizontal\" thumb-alignment=\"edge\">\n <media-slider-track class=\"media-slider__track\">\n <media-slider-fill class=\"media-slider__fill\"></media-slider-fill>\n </media-slider-track>\n <media-slider-thumb class=\"media-slider__thumb media-slider__thumb--persistent\"></media-slider-thumb>\n </media-volume-slider>\n </media-popover>\n </div>\n </media-tooltip-group>\n </div>\n </media-container>\n `;\n}\n\nexport class MinimalAudioSkinElement extends SkinMixin(ReactiveElement) {\n static readonly tagName = 'audio-minimal-skin';\n static styles = createStyles(styles);\n static getTemplateHTML = getTemplateHTML;\n}\n\ncustomElements.define(MinimalAudioSkinElement.tagName, MinimalAudioSkinElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [MinimalAudioSkinElement.tagName]: MinimalAudioSkinElement;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAkBA,MAAM,YAAY;AAElB,SAAS,kBAAkB;AACzB,QAAgB;;;;;;;;;;gBAUF,WAAW,WAAW,EAAE,OAAO,kCAAkC,CAAC,CAAC;gBACnE,WAAW,QAAQ,EAAE,OAAO,+BAA+B,CAAC,CAAC;gBAC7D,WAAW,SAAS,EAAE,OAAO,gCAAgC,CAAC,CAAC;;;;;;;;6EAQF,CAAC,UAAU;;kBAEtE,WAAW,QAAQ,EAAE,OAAO,mDAAmD,CAAC,CAAC;kDACjD,UAAU;;;;8BAI9B,UAAU;;;4EAGoC,UAAU;;kBAEpE,WAAW,QAAQ,EAAE,OAAO,+BAA+B,CAAC,CAAC;kDAC7B,UAAU;;;;6BAI/B,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBA4BvB,WAAW,cAAc,EAAE,OAAO,qCAAqC,CAAC,CAAC;gBACzE,WAAW,cAAc,EAAE,OAAO,qCAAqC,CAAC,CAAC;gBACzE,WAAW,eAAe,EAAE,OAAO,sCAAsC,CAAC,CAAC;;;;;;;;;;;;;;;;;AAkB3F,IAAa,0BAAb,cAA6C,UAAU,gBAAgB,CAAC;;iBAC5C;;;gBACV,aAAaA,qBAAO;;;yBACX;;;AAG3B,eAAe,OAAO,wBAAwB,SAAS,wBAAwB"}