@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap";.vvp-container{--vvp-primary:#3390EC;--vvp-primary-light:rgba(51,144,236,.1);--vvp-bg:#FFF;--vvp-button-bg:#F0F0F0;display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--vvp-bg);border-radius:20px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,sans-serif;overflow:hidden;-webkit-user-select:none;user-select:none;width:100%;min-width:0;box-sizing:border-box}@media (max-width:360px){.vvp-container{gap:8px;padding:8px 10px}}.vvp-play-button{flex-shrink:0;align-self:center;width:42px;height:42px;border-radius:50%;border:2px solid var(--vvp-primary);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .15s;padding:0;color:var(--vvp-primary);-webkit-tap-highlight-color:transparent;outline:none}.vvp-play-button:hover{background:var(--vvp-primary-light)}.vvp-play-button:disabled{cursor:default;opacity:.6}.vvp-icon{width:20px;height:20px;flex-shrink:0}.vvp-icon-play{transform:translate(1px)}.vvp-spinner{width:20px;height:20px;animation:vvp-spin 1s linear infinite}@keyframes vvp-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.vvp-waveform-section{flex:1;min-width:0;overflow:hidden;display:flex;flex-direction:column;justify-content:center;gap:6px}.vvp-waveform{display:block;height:24px;width:100%;cursor:pointer;touch-action:none}.vvp-waveform.is-loading{cursor:default;pointer-events:none}.vvp-canvas{display:block;width:100%;max-width:100%;height:24px;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;image-rendering:pixelated}.vvp-time-row{display:flex;justify-content:space-between;align-items:center;padding:0 2px}.vvp-time{font-size:11px;font-weight:500;color:var(--vvp-primary);line-height:1}.vvp-time-total{opacity:.5}.vvp-rate-btn{flex-shrink:0;align-self:center;padding:5px 10px;border-radius:12px;background:var(--vvp-button-bg);border:none;font-size:12px;font-weight:600;color:var(--vvp-primary);cursor:pointer;transition:background-color .15s;font-family:inherit;line-height:1}.vvp-rate-btn:hover{background:#e5e5e5}:root{--bg:#17212B;--surface:#232E3C;--surface-2:#2B3A4D;--border:#3D4D5F;--text:#FFF;--text-2:#D8DEE4;--text-3:#8B9BA8;--accent:#3390EC;--accent-soft:rgba(51,144,236,.15);--accent-hover:#4EA4F6;--green:#4CAF50;--mono:"SF Mono","Menlo","Monaco",monospace;--sans:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",Roboto,sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--sans);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.7;font-size:15px;-webkit-font-smoothing:antialiased}.demo-app{max-width:720px;margin:0 auto;padding:80px 24px}@media (max-width:540px){.demo-app{padding:40px 16px}}.header{margin-bottom:48px}.header-title{display:flex;align-items:center;gap:16px}.header-links{display:flex;gap:12px}.header-link{color:var(--text-3);text-decoration:none;transition:color .15s}.header-link:hover{color:var(--text-2)}.header-link svg{width:22px;height:22px}.header h1{font-size:2.25rem;font-weight:600;letter-spacing:-.03em;color:var(--text)}@media (max-width:540px){.header h1{font-size:1.75rem}.subtitle{font-size:1rem}}.subtitle{font-size:1.1rem;color:var(--text-2);margin-bottom:24px;max-width:480px}.badges{display:flex;flex-wrap:wrap;gap:8px}.badge{padding:6px 14px;background:var(--surface);border:1px solid var(--border);font-size:13px;color:var(--text-2);font-family:var(--mono)}.badge-link{text-decoration:none;transition:all .15s}.badge-link:hover{color:var(--accent-hover);border-color:var(--accent);background:var(--accent-soft)}.lang-switcher{margin-bottom:32px;font-size:14px}.lang-switcher a{color:var(--text-3);text-decoration:none;transition:color .15s}.lang-switcher a:hover{color:var(--text-2)}.lang-switcher a.active{color:var(--accent);font-weight:500}.lang-sep{color:var(--text-3);margin:0 8px}.section{margin-bottom:64px;scroll-margin-top:24px}.section h2{font-size:1.25rem;font-weight:600;margin-bottom:24px;color:var(--text);padding-bottom:12px;border-bottom:1px solid var(--border)}.section h2 a{color:inherit;text-decoration:none;display:flex;align-items:center;gap:8px}.section h2 a:hover{color:var(--accent)}.section h2 .hash{color:var(--text-3);font-weight:400;opacity:0;transition:opacity .15s}.section h2 a:hover .hash{opacity:1}.section h3{font-size:1rem;font-weight:500;margin:32px 0 16px;color:var(--text)}.section-subtitle{margin-top:32px;scroll-margin-top:24px}.section-subtitle a{color:inherit;text-decoration:none;display:flex;align-items:center;gap:6px}.section-subtitle a:hover{color:var(--accent)}.section-subtitle .hash{color:var(--text-3);font-weight:400;opacity:0;transition:opacity .15s}.section-subtitle a:hover .hash{opacity:1}.note{font-size:13px;color:var(--text-2);margin:12px 0 24px;padding:12px 16px;background:var(--surface);border-radius:8px;border-left:3px solid var(--accent)}.note code{background:var(--bg);padding:2px 6px;border-radius:4px;font-family:var(--mono);font-size:12px}.demo-grid{display:grid;grid-template-columns:1fr;gap:12px}@media (min-width:540px){.demo-grid{grid-template-columns:repeat(2,1fr)}}.demo-item{display:flex;flex-direction:column;gap:8px}.demo-label{font-size:12px;color:var(--text-3);font-family:var(--mono)}.demo-card{background:#e7e8ea;padding:16px;min-height:88px;display:flex;align-items:center;border-radius:16px;overflow:hidden}.demo-card>*{width:100%;min-width:0}.demo-card.dark{background:var(--surface)}@media (max-width:540px){.demo-card{padding:12px;min-height:76px}}.code-wrapper{position:relative}.code-block{background:var(--surface);border:1px solid var(--border);padding:20px 56px 20px 24px;overflow-x:auto;font-family:var(--mono);font-size:13px;line-height:1.6;color:var(--text-2);border-radius:12px}.code-block code{white-space:pre}.copy-btn{position:absolute;top:12px;right:12px;width:32px;height:32px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0}.copy-btn svg{width:16px;height:16px}.copy-btn:hover{background:var(--border);color:var(--text)}.copy-btn.copied{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}@media (max-width:540px){.code-block{padding:16px 48px 16px 16px;font-size:12px}}.table-wrapper{overflow-x:auto;margin-bottom:20px;border:1px solid var(--border)}.props-table{width:100%;border-collapse:collapse;font-size:14px}.props-table th,.props-table td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--border)}.props-table th{background:var(--surface);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3)}.props-table td{color:var(--text-2)}.props-table tr:last-child td{border-bottom:none}.props-table code{background:var(--surface-2);padding:3px 8px;font-family:var(--mono);font-size:13px;color:var(--accent)}.footer{display:flex;justify-content:space-between;align-items:center;padding-top:32px;margin-top:32px;border-top:1px solid var(--border);font-size:13px;color:var(--text-3)}.footer-right{color:var(--text-3);text-decoration:none;transition:color .15s}.footer-right:hover{color:var(--accent-hover)}@media (max-width:540px){.footer{flex-direction:column;gap:12px;text-align:center}}.demo-card.dark :deep(.vvp-time-total){color:var(--text-3)}.custom-play-btn{width:40px;height:40px;border-radius:50%;border:none;background:#3390ec;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s}.custom-play-btn:hover{opacity:.85}.custom-time{display:flex;align-items:center;justify-content:space-between;font-family:var(--sans);font-size:11px;font-weight:500;line-height:1;padding:0 2px}.custom-time-current{color:#3390ec;font-variant-numeric:tabular-nums}.methods-demo{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin-top:20px}.demo-player{padding:20px;background:#e7e8ea;border-radius:16px 16px 0 0}.methods-panel{padding:24px;display:flex;flex-direction:column;gap:20px}.panel-section{display:flex;flex-direction:column;gap:10px}.panel-section.state{padding-top:20px;border-top:1px solid var(--border);gap:8px}.panel-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);font-weight:500}.panel-buttons{display:flex;gap:8px;flex-wrap:wrap}.method-btn{padding:10px 16px;background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:13px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:8px}.method-btn:hover{background:var(--border)}.method-btn.play{background:#16a34a26;border-color:#16a34a4d;color:var(--green)}.method-btn.play:hover{background:#16a34a40}.method-btn.pause{background:var(--accent-soft);border-color:#c2410c4d;color:var(--accent)}.method-btn.pause:hover{background:#c2410c33}.method-btn.stop{background:#ef444426;border-color:#ef44444d;color:#ef4444}.method-btn.stop:hover{background:#ef444440}.btn-icon{font-size:12px}.state-row{display:flex;justify-content:space-between;align-items:center}.state-label{font-family:var(--mono);font-size:13px;color:var(--text-3)}.state-value{font-family:var(--mono);font-size:13px;color:var(--text-2);background:var(--surface-2);padding:6px 12px;min-width:80px;text-align:right}.state-value.active{color:var(--green);background:#16a34a1a}
