*{margin:0;padding:0;box-sizing:border-box}body{background:#000;color:#e8e8ec;font-family:Manrope,sans-serif;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}.ascii-spinner{width:20px;height:20px;border:2px solid #222;border-top-color:#666;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app{width:100%;min-height:100vh;display:flex;flex-direction:column;align-items:center;background:#000}.landing{display:flex;width:100%;max-width:1500px;margin:0 auto;flex:1;align-items:flex-start;padding:0 4rem;padding-top:15vh}.landing-demo{flex:1;min-width:0;overflow:hidden;display:flex;align-items:flex-start;justify-content:flex-end}.landing-demo .video-to-ascii{width:90%}.landing-info{flex:0 0 325px;padding:0 0 3rem 2.5rem;display:flex;flex-direction:column;justify-content:flex-start;position:relative;z-index:1}.landing-title{font-family:Gulzar,serif;font-size:2.8rem;font-weight:700;color:#e8e8ec;margin:0;letter-spacing:-.02em;line-height:1}.landing-subtitle{font-family:Manrope,sans-serif;font-size:.95rem;color:#666;font-style:italic;margin-top:.3rem}.gi-link{color:#fff;text-decoration:none;cursor:pointer;background-image:linear-gradient(#fff,#fff);background-size:0% 1px;background-position:left bottom;background-repeat:no-repeat;transition:background-size .4s ease;padding-bottom:2px}.gi-link:hover{background-size:100% 1px}.landing-description{margin-top:1.5rem;display:flex;flex-direction:column;gap:.8rem}.landing-description p{font-family:Alphalyrae,sans-serif;font-size:.92rem;color:#555;line-height:1.65;margin:0}.drop-zone{margin-top:2rem;display:inline-flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border:1px dashed #222;transition:border-color .2s}.drop-zone.drag-over{border-color:#64a0d24d}.drop-hint{font-family:Alphalyrae,sans-serif;font-size:.75rem;color:#444;margin-left:3rem}.upload-error{font-family:Manrope,sans-serif;font-size:.8rem;color:#ff6b6b;margin-top:.5rem}.samples{margin-top:1.5rem;display:flex;flex-direction:column;gap:.6rem}.samples-label{font-family:Alphalyrae,sans-serif;font-size:.75rem;color:#444}.sample-name{font-family:Alphalyrae,sans-serif;font-size:.75rem;color:#555;padding:.3rem 0}.samples-grid{display:flex;gap:.75rem}.sample-card{display:flex;flex-direction:column;align-items:center;gap:.4rem;background:none;border:1px solid #1a1a1e;padding:0;cursor:pointer;transition:border-color .3s ease}.sample-card:hover{border-color:#333}.sample-thumb{width:120px;height:75px;background:#0a0a0a;overflow:hidden;pointer-events:none}.sample-thumb .video-to-ascii,.sample-thumb .video-to-ascii>div{width:100%;height:100%}.sample-thumb canvas{width:100%!important;height:100%!important;min-height:100%!important;object-fit:cover}.generate-btn{display:inline-flex;align-items:center;justify-content:center;padding:.45rem 2rem;background:transparent;border:none;border-radius:0;font-family:Alphalyrae,sans-serif;font-size:.8rem;font-weight:500;color:#888;cursor:pointer;position:relative;transition:color .4s ease}.generate-btn:before,.generate-btn:after{content:"";position:absolute;transition:all .4s ease}.generate-btn:before{top:0;left:0;width:0;height:1px;background:#fff}.generate-btn:after{bottom:0;right:0;width:0;height:1px;background:#fff}.generate-btn .edge-left,.generate-btn .edge-right{position:absolute;width:1px;height:0;background:#fff;transition:all .4s ease}.generate-btn .edge-left{bottom:0;left:0}.generate-btn .edge-right{top:0;right:0}.generate-btn:hover{color:#ccc}.generate-btn:hover:before,.generate-btn:hover:after{width:100%}.generate-btn:hover .edge-left,.generate-btn:hover .edge-right{height:100%}.generate-btn:active{transform:scale(.97)}.player-page{display:flex;width:100%;max-width:1500px;margin:0 auto;align-items:flex-start;padding:0 4rem;padding-top:15vh;box-sizing:border-box}.player-left{flex:1;min-width:0}.player-right{flex:0 0 325px;padding-left:2.5rem}.player-nav{width:100%;display:flex;align-items:center;padding-bottom:.75rem}.back-btn{background:none;border:none;color:#444;cursor:pointer;padding:0;outline:none;transition:color .2s ease;display:flex;align-items:center;justify-content:center}.back-btn:hover{color:#ddd}.player-frame{width:100%;overflow:hidden;background:#000}.player-frame .video-to-ascii{width:100%}.action-bar{width:100%;display:flex;justify-content:flex-end;padding:.75rem 0 0}.copy-icon{box-sizing:border-box;width:26px;height:26px;background:none;color:#444;border:none;cursor:pointer;position:relative;outline:none;padding:0;transition:color .2s ease}.copy-icon:hover{color:#ddd}.copy-icon svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.code-section{width:100%;padding:2rem 0 3rem;display:flex;flex-direction:column;gap:1rem}.code-section-title{font-family:Manrope,sans-serif;font-size:1.1rem;font-weight:600;color:#888;letter-spacing:-.01em;margin:0 0 .25rem}.code-section-note{font-family:Manrope,sans-serif;font-size:.78rem;color:#555;line-height:1.6;margin:0}.code-section-note code{font-family:SF Mono,Fira Code,Fira Mono,monospace;font-size:.72rem;color:#777;background:#111;padding:.1rem .35rem}.code-block{border:1px solid #1a1a1e;background:#0a0a0a;overflow:hidden}.code-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid #1a1a1e}.code-label{font-family:Manrope,sans-serif;font-size:.7rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.05em}.code-pre{margin:0;padding:1rem;overflow-x:auto;font-family:SF Mono,Fira Code,Fira Mono,monospace;font-size:.78rem;line-height:1.55;color:#b0b0b0;tab-size:2}.code-pre code{font-family:inherit}.history{margin-top:1.5rem;padding-top:1.2rem;border-top:1px solid #1a1a1e}.history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.history-label{font-family:Alphalyrae,sans-serif;font-size:.75rem;color:#444}.history-clear{background:none;border:none;font-family:Alphalyrae,sans-serif;font-size:.7rem;color:#444;cursor:pointer;padding:0;transition:color .2s}.history-clear:hover{color:#aaa}.history-list{display:flex;flex-direction:column}.history-row{display:flex;align-items:center;gap:.5rem;padding:.3rem 0}.history-name{flex:1;min-width:0;background:none;border:none;font-family:Alphalyrae,sans-serif;font-size:.78rem;color:#666;cursor:pointer;padding:0;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .2s}.history-name:hover{color:#ccc}.history-time{font-family:Alphalyrae,sans-serif;font-size:.7rem;color:#444;flex-shrink:0}.history-remove{background:none;border:none;font-size:.85rem;color:#444;cursor:pointer;padding:0;line-height:1;transition:color .2s}.history-remove:hover{color:#aaa}.site-footer{width:100%;padding:.75rem 0;text-align:center;font-family:Alphalyrae,sans-serif;font-size:.8rem;color:#444;margin-top:auto}.site-footer a{color:#888;text-decoration:none;cursor:pointer;background-image:linear-gradient(#888,#888);background-size:0% 1px;background-position:left bottom;background-repeat:no-repeat;transition:background-size .4s ease,color .2s;padding-bottom:2px}.site-footer a:hover{color:#fff;background-image:linear-gradient(#fff,#fff);background-size:100% 1px}@media(max-width:768px){.landing{flex-direction:column;padding:0 1.25rem;padding-top:6vh;align-items:flex-start}.landing-demo{width:100%;justify-content:flex-start}.landing-demo .video-to-ascii{width:100%}.landing-info{flex:none;width:100%;padding:1.5rem 0 2rem}.landing-title{font-size:2rem}.drop-zone{width:100%;box-sizing:border-box}.drop-hint{margin-left:1rem}.samples-grid{flex-wrap:wrap}.sample-thumb{width:90px;height:56px}.player-page{flex-direction:column;padding:0 1.25rem;padding-top:4vh}.player-left{width:100%}.player-right{flex:none;width:100%;padding-left:0}}
