style.css 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396
  1. @import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&display=swap');
  2. :root {
  3. --bg: #091724;
  4. --panel: rgba(12, 32, 48, 0.82);
  5. --line: rgba(129, 181, 191, 0.35);
  6. --text: #e9f6f9;
  7. --muted: #9bc0c6;
  8. --mic1: #32b3ff;
  9. --mic2: #50d27a;
  10. --beam: #ff6d5a;
  11. --accent: #f4c34f;
  12. --danger: #ff4c55;
  13. }
  14. * {
  15. box-sizing: border-box;
  16. }
  17. body {
  18. margin: 0;
  19. min-height: 100vh;
  20. color: var(--text);
  21. background: radial-gradient(circle at 12% 14%, #20435c 0%, #0d2738 30%, #08131f 100%);
  22. font-family: "Space Grotesk", "Segoe UI", sans-serif;
  23. position: relative;
  24. overflow-x: hidden;
  25. }
  26. .bg-glow {
  27. position: fixed;
  28. z-index: 0;
  29. border-radius: 999px;
  30. filter: blur(80px);
  31. opacity: 0.22;
  32. pointer-events: none;
  33. }
  34. .bg-glow-a {
  35. width: 300px;
  36. height: 300px;
  37. background: #00d5ff;
  38. top: -80px;
  39. left: -80px;
  40. }
  41. .bg-glow-b {
  42. width: 340px;
  43. height: 340px;
  44. background: #ff8a4d;
  45. right: -120px;
  46. bottom: -120px;
  47. }
  48. .layout {
  49. max-width: 1200px;
  50. margin: 0 auto;
  51. padding: 20px;
  52. display: grid;
  53. gap: 16px;
  54. position: relative;
  55. z-index: 1;
  56. }
  57. .card {
  58. background: var(--panel);
  59. border: 1px solid var(--line);
  60. border-radius: 16px;
  61. backdrop-filter: blur(10px);
  62. box-shadow: 0 14px 34px rgba(3, 8, 13, 0.35);
  63. padding: 16px;
  64. }
  65. .header {
  66. display: flex;
  67. justify-content: space-between;
  68. align-items: center;
  69. gap: 16px;
  70. }
  71. h1,
  72. h2 {
  73. margin: 0;
  74. }
  75. h1 {
  76. font-size: 1.7rem;
  77. }
  78. h2 {
  79. font-size: 1.1rem;
  80. margin-bottom: 12px;
  81. }
  82. p {
  83. margin: 8px 0 0;
  84. color: var(--muted);
  85. }
  86. .status-block {
  87. display: flex;
  88. flex-wrap: wrap;
  89. gap: 8px;
  90. }
  91. .pill {
  92. border: 1px solid var(--line);
  93. border-radius: 999px;
  94. padding: 6px 10px;
  95. font-size: 0.85rem;
  96. background: rgba(8, 20, 30, 0.7);
  97. }
  98. .wave-grid {
  99. display: grid;
  100. grid-template-columns: repeat(3, minmax(0, 1fr));
  101. gap: 12px;
  102. }
  103. .wave-item {
  104. border: 1px solid rgba(116, 162, 170, 0.3);
  105. border-radius: 12px;
  106. padding: 10px;
  107. background: rgba(9, 25, 36, 0.8);
  108. }
  109. .wave-title {
  110. font-weight: 600;
  111. margin-bottom: 8px;
  112. }
  113. canvas {
  114. width: 100%;
  115. height: 160px;
  116. border: 1px solid rgba(97, 154, 163, 0.35);
  117. border-radius: 10px;
  118. background: linear-gradient(180deg, rgba(5, 16, 24, 0.95), rgba(7, 21, 31, 0.82));
  119. }
  120. .vu-wrap {
  121. margin-top: 8px;
  122. display: flex;
  123. align-items: center;
  124. gap: 8px;
  125. }
  126. .vu-label {
  127. min-width: 24px;
  128. color: var(--muted);
  129. font-size: 0.85rem;
  130. }
  131. .vu-track {
  132. height: 12px;
  133. flex: 1;
  134. border-radius: 999px;
  135. border: 1px solid rgba(125, 169, 176, 0.4);
  136. background: rgba(7, 19, 29, 0.85);
  137. overflow: hidden;
  138. }
  139. .vu-fill {
  140. height: 100%;
  141. width: 0%;
  142. transition: width 0.1s linear;
  143. }
  144. .vu-fill.mic1 {
  145. background: linear-gradient(90deg, #58c8ff, #1f8ef2);
  146. }
  147. .vu-fill.mic2 {
  148. background: linear-gradient(90deg, #74ef98, #22b455);
  149. }
  150. .vu-fill.beam {
  151. background: linear-gradient(90deg, #ff9569, #ff5948);
  152. }
  153. .group {
  154. margin-bottom: 12px;
  155. }
  156. .group label {
  157. display: block;
  158. margin-bottom: 6px;
  159. }
  160. input[type="range"],
  161. input[type="number"],
  162. select {
  163. width: 100%;
  164. }
  165. select,
  166. input[type="range"] {
  167. accent-color: var(--accent);
  168. }
  169. .radio-row {
  170. display: grid;
  171. gap: 6px;
  172. }
  173. .row.two-col {
  174. display: grid;
  175. grid-template-columns: repeat(2, minmax(0, 1fr));
  176. gap: 10px;
  177. }
  178. .hidden {
  179. display: none;
  180. }
  181. .record-row {
  182. display: flex;
  183. align-items: center;
  184. gap: 12px;
  185. margin-bottom: 12px;
  186. }
  187. .record-btn {
  188. border: none;
  189. border-radius: 999px;
  190. font-size: 1rem;
  191. font-weight: 700;
  192. letter-spacing: 0.05em;
  193. color: #fff;
  194. background: linear-gradient(135deg, #f15444, #e92e42);
  195. padding: 12px 24px;
  196. cursor: pointer;
  197. transition: transform 0.2s ease, box-shadow 0.2s ease;
  198. }
  199. .record-btn:hover {
  200. transform: translateY(-1px);
  201. box-shadow: 0 10px 22px rgba(226, 54, 70, 0.35);
  202. }
  203. .record-btn.recording {
  204. animation: pulse 1s infinite;
  205. background: linear-gradient(135deg, #ff7f66, #ff304a);
  206. }
  207. .timer {
  208. font-variant-numeric: tabular-nums;
  209. font-size: 1.1rem;
  210. font-weight: 600;
  211. }
  212. .table-wrap {
  213. overflow-x: auto;
  214. }
  215. table {
  216. width: 100%;
  217. border-collapse: collapse;
  218. }
  219. th,
  220. td {
  221. padding: 8px;
  222. border-bottom: 1px solid rgba(123, 171, 179, 0.25);
  223. text-align: left;
  224. white-space: nowrap;
  225. }
  226. .actions {
  227. display: flex;
  228. gap: 8px;
  229. }
  230. .btn-small {
  231. border: 1px solid rgba(123, 173, 181, 0.45);
  232. border-radius: 8px;
  233. background: rgba(9, 22, 33, 0.85);
  234. color: var(--text);
  235. padding: 4px 8px;
  236. cursor: pointer;
  237. }
  238. .btn-small.danger {
  239. border-color: rgba(255, 93, 109, 0.6);
  240. color: #ffcdd2;
  241. }
  242. @keyframes pulse {
  243. 0% {
  244. transform: scale(1);
  245. box-shadow: 0 0 0 0 rgba(255, 87, 92, 0.45);
  246. }
  247. 70% {
  248. transform: scale(1.02);
  249. box-shadow: 0 0 0 12px rgba(255, 87, 92, 0);
  250. }
  251. 100% {
  252. transform: scale(1);
  253. box-shadow: 0 0 0 0 rgba(255, 87, 92, 0);
  254. }
  255. }
  256. @media (max-width: 960px) {
  257. .wave-grid {
  258. grid-template-columns: 1fr;
  259. }
  260. .row.two-col {
  261. grid-template-columns: 1fr;
  262. }
  263. .header {
  264. flex-direction: column;
  265. align-items: flex-start;
  266. }
  267. }
  268. /* ── STT Panel ── */
  269. .stt-panel .stt-output {
  270. max-height: 400px;
  271. overflow-y: auto;
  272. padding: 0.8rem;
  273. background: rgba(0, 0, 0, 0.25);
  274. border-radius: 8px;
  275. margin-top: 0.8rem;
  276. font-size: 0.92rem;
  277. line-height: 1.6;
  278. min-height: 60px;
  279. }
  280. .stt-output:empty::after {
  281. content: "Transkrypcja pojawi sie tutaj...";
  282. color: rgba(255,255,255,0.25);
  283. font-style: italic;
  284. }
  285. .stt-segment {
  286. margin-bottom: 0.6rem;
  287. padding: 0.4rem 0;
  288. border-bottom: 1px solid rgba(255,255,255,0.06);
  289. }
  290. .stt-segment:last-child {
  291. border-bottom: none;
  292. }
  293. .stt-segment.partial {
  294. opacity: 0.6;
  295. font-style: italic;
  296. }
  297. .stt-speaker {
  298. display: inline-block;
  299. padding: 0.1rem 0.5rem;
  300. border-radius: 4px;
  301. font-size: 0.78rem;
  302. font-weight: 600;
  303. margin-right: 0.4rem;
  304. color: #fff;
  305. }
  306. .stt-speaker-0 { background: #4a9eff; }
  307. .stt-speaker-1 { background: #ff6b6b; }
  308. .stt-speaker-2 { background: #51cf66; }
  309. .stt-speaker-3 { background: #ffd43b; color: #333; }
  310. .stt-speaker-4 { background: #cc5de8; }
  311. .stt-speaker-5 { background: #ff922b; }
  312. .stt-speaker-6 { background: #20c997; }
  313. .stt-speaker-7 { background: #f06595; }
  314. .stt-timestamp {
  315. color: rgba(255,255,255,0.35);
  316. font-size: 0.75rem;
  317. margin-right: 0.4rem;
  318. font-variant-numeric: tabular-nums;
  319. }
  320. .stt-confidence {
  321. color: rgba(255,255,255,0.3);
  322. font-size: 0.72rem;
  323. margin-left: 0.3rem;
  324. }
  325. .stt-emotion {
  326. font-size: 0.72rem;
  327. margin-left: 0.4rem;
  328. padding: 0.05rem 0.35rem;
  329. border-radius: 3px;
  330. background: rgba(255,255,255,0.08);
  331. }
  332. .stt-word {
  333. transition: background 0.15s;
  334. }
  335. .stt-word.conf-high { }
  336. .stt-word.conf-mid { color: #ffd43b; }
  337. .stt-word.conf-low { color: #ff6b6b; }