@import"https://fonts.googleapis.com/css2?family=Jersey+15&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:0;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.landing-page{min-height:100vh;background:#f5f5f5;background-image:repeating-linear-gradient(0deg,transparent,transparent 4px,rgba(0,0,0,.02) 4px,rgba(0,0,0,.02) 8px),repeating-linear-gradient(90deg,transparent,transparent 4px,rgba(0,0,0,.02) 4px,rgba(0,0,0,.02) 8px);font-family:"Jersey 15",Courier New,monospace;font-weight:700;overflow-x:hidden}.landing-page *{image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;border-radius:0!important}.section-title{font-size:2.5rem;color:#333;text-align:center;margin-bottom:.5rem;text-shadow:2px 2px 0 rgba(0,0,0,.1);line-height:1.2}.section-subtitle{font-size:1.25rem;color:#666;text-align:center;margin-bottom:3rem}.retro-card{background:#fff;border:4px solid #333;box-shadow:4px 4px #333,8px 8px #0000001a;padding:1.5rem}.retro-btn{display:inline-block;padding:.8rem 1.5rem;background:#333;color:#fff;border:3px solid #333;box-shadow:3px 3px #333,5px 5px #0000001a;font-size:1.1rem;font-weight:700;font-family:"Jersey 15",monospace;text-decoration:none;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .1s ease}.retro-btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px #333,7px 7px #0000001a}.retro-btn:active{transform:translate(3px,3px);box-shadow:0 0 #333,2px 2px #0000001a}.retro-btn--primary{background:#ff5e5b;border-color:#333}.retro-btn--primary:hover{background:#ff4744}.retro-btn--secondary{background:#fff;color:#333}.retro-btn--secondary:hover{background:#f5f5f5}.retro-btn--large{padding:1rem 2rem;font-size:1.3rem}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 2rem;background:transparent;transition:all .3s ease}.navbar--scrolled{background:#f5f5f5f2;border-bottom:3px solid #333;box-shadow:0 4px #0000001a}.navbar__container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.navbar__logo{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:#333;text-decoration:none;text-shadow:2px 2px 0 rgba(0,0,0,.1)}.navbar__logo-icon{width:28px;height:28px}.navbar__links{display:flex;align-items:center;gap:2rem}.navbar__link{background:none;border:none;padding:0;margin:0;font-family:"Jersey 15",monospace;font-size:1.1rem;font-weight:700;color:#333;cursor:pointer;text-decoration:none;transition:color .2s ease;white-space:nowrap}.navbar__link:hover{color:#ff5e5b}.navbar__cta{padding:.5rem 1rem;background:#ff5e5b;color:#fff;border:3px solid #333;box-shadow:2px 2px #333;font-family:"Jersey 15",monospace;font-size:1rem;font-weight:700;text-decoration:none;text-transform:uppercase;transition:all .1s ease}.navbar__cta:hover{transform:translate(-1px,-1px);box-shadow:3px 3px #333}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:6rem 2rem 4rem}.hero__container{max-width:1000px;margin:0 auto;text-align:center}.hero__eyebrow{display:inline-block;padding:.5rem 1rem;background:#333;color:#fff;font-size:1rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:1.5rem}.hero__headline{font-size:3.5rem;color:#333;margin-bottom:1.5rem;line-height:1.1;text-shadow:3px 3px 0 rgba(0,0,0,.1)}.hero__headline--accent{color:#ff5e5b}.hero__subheadline{font-size:1.4rem;color:#666;margin-bottom:2rem;line-height:1.5}.hero__buttons{display:flex;flex-direction:column;align-items:center;gap:1rem;justify-content:center;margin-bottom:3rem}.hero__buttons-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.hero__demo{max-width:800px;margin:0 auto}.hero__demo-container{background:#1e1e1e;border:4px solid #333;box-shadow:8px 8px #333,12px 12px #0000001a;overflow:hidden}.hero__demo-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#2d2d2d;border-bottom:2px solid #333}.hero__demo-dot{width:12px;height:12px;border:2px solid #333}.hero__demo-dot--red{background:#ff5f56}.hero__demo-dot--yellow{background:#ffbd2e}.hero__demo-dot--green{background:#27c93f}.hero__demo-title{margin-left:.5rem;color:#999;font-size:.9rem}.hero__demo-content{position:relative;aspect-ratio:16/9;background:#1e1e1e}.hero__demo-video{width:100%;height:100%;object-fit:cover}.hero__demo-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#666}.hero__demo-placeholder-icon{margin-bottom:1rem}.hero__demo-placeholder-img{width:80px;height:80px}.hero__demo-placeholder-text{font-size:1.5rem;color:#999}.hero__demo-placeholder-subtext{font-size:.9rem;color:#666;margin-top:.5rem}.features{padding:6rem 2rem;background:#fff;border-top:4px solid #333;border-bottom:4px solid #333}.features__container{max-width:1200px;margin:0 auto}.features__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.feature-card{text-align:center;transition:transform .2s ease}.feature-card:hover{transform:translate(-2px,-2px);box-shadow:6px 6px #333,10px 10px #0000001a}.feature-card__icon{width:64px;height:64px;display:block;margin:0 auto 1rem}.feature-card__title{font-size:1.4rem;color:#333;margin-bottom:.5rem}.feature-card__description{font-size:1rem;color:#666;line-height:1.4}.how-it-works{padding:6rem 2rem}.how-it-works__container{max-width:1000px;margin:0 auto}.how-it-works__steps{display:flex;justify-content:space-between;gap:2rem;position:relative}.step{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center}.step__number-container{position:relative;margin-bottom:1rem;width:100%;display:flex;justify-content:center;align-items:center}.step__number{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;background:#ff5e5b;color:#fff;font-size:1.5rem;font-weight:700;border:4px solid #333;box-shadow:3px 3px #333;z-index:1}.step__connector{position:absolute;top:50%;left:calc(50% + 40px);width:calc(100% - 40px);height:4px;background:#333;transform:translateY(-50%)}.step__connector:after{content:"→";position:absolute;right:-10px;top:50%;transform:translateY(-50%);font-size:1.2rem;color:#333}.step__content{width:100%}.step__icon{width:48px;height:48px;display:block;margin:0 auto .75rem}.step__title{font-size:1.3rem;color:#333;margin-bottom:.5rem}.step__description{font-size:.95rem;color:#666;line-height:1.4}.comparison{padding:6rem 2rem;background:#fff;border-top:4px solid #333;border-bottom:4px solid #333}.comparison__container{max-width:1000px;margin:0 auto}.comparison__table-wrapper{overflow-x:auto}.comparison__table{width:100%;border-collapse:collapse;font-size:1rem}.comparison__table th,.comparison__table td{padding:1rem;text-align:center;border:2px solid #333}.comparison__header-cell{background:#333;color:#fff;font-size:1.1rem;font-weight:700}.comparison__header-cell--label{background:#333;color:#ff5e5b;text-transform:uppercase;letter-spacing:2px}.comparison__header-cell--highlight{background:#ff5e5b;color:#fff}.comparison__label-cell{text-align:left;font-weight:700;background:#333;color:#fff}.comparison__value-cell{font-weight:700}.comparison__value-cell--highlight{background:#ff5e5b1a}.comparison__value-cell--good{color:#2e7d32}.comparison__value-cell--okay{color:#ff9800}.comparison__value-cell--bad{color:#f44336}.comparison__status-icon{width:16px;height:16px;margin-right:.5rem;vertical-align:middle}.why-i-made-this{padding:6rem 2rem}.why-i-made-this__container{max-width:800px;margin:0 auto}.why-i-made-this__content{font-size:1.1rem;line-height:1.8;color:#555}.why-i-made-this__content p{margin:0 0 1rem}.why-i-made-this__content p:last-child{margin-bottom:0}.used-in{padding:6rem 0;background:#fff;border-top:4px solid #333;border-bottom:4px solid #333;overflow:hidden}.used-in__container{width:100%}.used-in__container .section-title,.used-in__container .section-subtitle{padding:0 2rem}.used-in__slider{width:100%;overflow:hidden}.used-in__videos{display:flex;gap:2rem;justify-content:center;padding:0 2rem}.used-in__videos--scrollable{justify-content:flex-start;padding:0;width:max-content;animation:scroll-gallery 30s linear infinite}.used-in__slider:hover .used-in__videos--scrollable{animation-play-state:paused}@keyframes scroll-gallery{0%{transform:translate(0)}to{transform:translate(-50%)}}.used-in__video{flex-shrink:0;width:480px}.used-in__video-container{background:#1e1e1e;border:4px solid #333;box-shadow:8px 8px #333,12px 12px #0000001a;overflow:hidden}.used-in__video-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#2d2d2d;border-bottom:2px solid #333}.used-in__video-dot{width:12px;height:12px;border:2px solid #333}.used-in__video-dot--red{background:#ff5f56}.used-in__video-dot--yellow{background:#ffbd2e}.used-in__video-dot--green{background:#27c93f}.used-in__video-title{margin-left:.5rem;color:#999;font-size:.9rem}.used-in__video-content{position:relative;aspect-ratio:16/9;background:#1e1e1e}.used-in__video-content iframe{width:100%;height:100%;display:block}.used-in__video-description{margin-top:.75rem;color:#999;font-size:.9rem;line-height:1.5;text-align:center}@media(max-width:768px){.used-in__video{width:360px}}@media(max-width:480px){.used-in__video{width:300px}}.open-source{padding:6rem 2rem;text-align:center}.open-source__container{max-width:800px;margin:0 auto}.open-source__icon{display:inline-block;color:#333;margin-bottom:1.5rem}.open-source__description{font-size:1.2rem;color:#666;line-height:1.6;margin-bottom:2rem}.open-source__stats{display:flex;justify-content:center;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap}.open-source__stat{min-width:120px;text-align:center}.open-source__stat-value{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1.5rem;color:#333;margin-bottom:.25rem}.open-source__stat-icon{width:24px;height:24px}.open-source__stat-label{font-size:.9rem;color:#666;text-transform:uppercase;letter-spacing:1px}.cta-section{padding:6rem 2rem;background:#333;text-align:center}.cta-section__container{max-width:800px;margin:0 auto}.cta-section__title{font-size:2.5rem;color:#fff;margin-bottom:.5rem;text-shadow:2px 2px 0 rgba(0,0,0,.3)}.cta-section__subtitle{font-size:1.2rem;color:#ccc;margin-bottom:2rem}.footer{padding:2rem;background:#1a1a1a;color:#999}.footer__container{max-width:1200px;margin:0 auto}.footer__top{display:flex;justify-content:space-between;align-items:center;padding-bottom:1.5rem;border-bottom:2px solid #333;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.footer__logo{display:flex;align-items:center;gap:.5rem;font-size:1.3rem;color:#fff;text-decoration:none}.footer__logo-icon{width:24px;height:24px}.footer__heart-icon{width:18px;height:18px;vertical-align:middle}.footer__links{display:flex;gap:1.5rem;flex-wrap:wrap}.footer__link{color:#999;text-decoration:none;font-size:1rem;transition:color .2s ease}.footer__link:hover{color:#ff5e5b}.footer__bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer__copyright,.footer__made-with{font-size:.9rem}.back-to-home{display:inline-block;margin-bottom:1rem;color:#666;text-decoration:none;font-size:1rem;transition:color .2s ease}.downloads{min-height:100vh;padding:8rem 2rem 4rem}.downloads__container{max-width:800px;margin:0 auto}.downloads__grid{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3rem}.download-card{display:flex;align-items:center;gap:1.5rem;text-decoration:none;color:inherit;transition:transform .2s ease;cursor:pointer}.download-card:hover{transform:translate(-2px,-2px);box-shadow:6px 6px #333,10px 10px #0000001a}.download-card__icon{flex-shrink:0;width:64px;height:64px;display:flex;align-items:center;justify-content:center}.download-card__icon img{width:100%;height:100%;object-fit:contain}.download-card__info{flex:1}.download-card__platform{font-size:1.5rem;color:#333;margin:0 0 .25rem}.download-card__arch{font-size:1.1rem;color:#666;margin:0 0 .5rem}.download-card__meta{font-size:.9rem;color:#999;margin:0}.download-card__action{flex-shrink:0}.downloads__more{text-align:center;padding-top:2rem;border-top:4px solid #333}.downloads__more-text{font-size:1.1rem;color:#666;margin-bottom:1.5rem}@media(max-width:768px){.download-card{flex-direction:column;text-align:center}.download-card__icon{margin:0 auto}.download-card__info{text-align:center}}@media(max-width:768px){.navbar__links{display:none}.hero__headline{font-size:2.5rem}.hero__subheadline{font-size:1.2rem}.hero__buttons-row{flex-direction:column;align-items:center}.how-it-works__steps{flex-direction:column;gap:2rem}.step__connector{display:none}.comparison__table{font-size:.85rem}.comparison__table th,.comparison__table td{padding:.5rem}.section-title{font-size:2rem}.footer__top,.footer__bottom{flex-direction:column;text-align:center}}@media(max-width:480px){.hero__headline{font-size:2rem}.features__grid{grid-template-columns:1fr}.open-source__stats{flex-direction:column;align-items:center}}*{margin:0;padding:0;box-sizing:border-box;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;border-radius:0!important}html,body,#root{height:100%;width:100%}.app{min-height:100vh;height:100%;background:#f5f5f5;background-image:repeating-linear-gradient(0deg,transparent,transparent 4px,rgba(0,0,0,.02) 4px,rgba(0,0,0,.02) 8px),repeating-linear-gradient(90deg,transparent,transparent 4px,rgba(0,0,0,.02) 4px,rgba(0,0,0,.02) 8px);padding:1rem;font-family:"Jersey 15",Courier New,monospace;font-weight:700}.back-to-home{display:inline-block;margin-bottom:1rem;color:#666;text-decoration:none;font-size:1rem;font-family:"Jersey 15",Courier New,monospace;transition:color .2s ease}.back-to-home:hover{color:#ff5e5b}.main-layout{display:flex;gap:1rem;max-width:100%;margin:0 auto;width:100%;min-height:calc(100vh - 2rem)}.main-layout.centered{justify-content:center;align-items:center}.container{background:#fff;border:4px solid #333;box-shadow:4px 4px #333,8px 8px #0000001a;padding:2rem;overflow-y:auto;position:relative}.main-layout:not(.centered) .container{flex:1;min-width:500px;max-height:calc(100vh - 2rem)}.main-layout.centered .container{width:100%;max-width:800px;min-width:500px}h1{color:#333;font-size:2.5rem;margin:0 0 .5rem;text-align:center;letter-spacing:1px;font-weight:700;text-shadow:2px 2px 0 rgba(0,0,0,.1)}.subtitle{color:#666;text-align:center;font-size:1.1rem;margin:0 0 2rem;font-weight:700}.submit-section{text-align:center}.footer-links{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-top:1.5rem}.support-btn{display:inline-block;padding:.6rem 1.2rem;line-height:1;background:#ff5e5b;color:#fff;border:3px solid #333;box-shadow:3px 3px #333,5px 5px #0000001a;font-size:1rem;font-weight:700;font-family:"Jersey 15",monospace;text-decoration:none;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .1s ease}.support-btn:hover{background:#ff4744;transform:translate(-2px,-2px);box-shadow:5px 5px #333,7px 7px #0000001a}.support-btn:active{transform:translate(3px,3px);box-shadow:0 0 #333,2px 2px #0000001a}.feedback-btn{display:inline-block;padding:.6rem 1.2rem;background:#3498db;color:#fff;border:3px solid #333;box-shadow:3px 3px #333,5px 5px #0000001a;font-size:1rem;font-weight:700;font-family:"Jersey 15",monospace;text-decoration:none;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .1s ease;line-height:1}.feedback-btn:hover{background:#2980b9;transform:translate(-2px,-2px);box-shadow:5px 5px #333,7px 7px #0000001a}.feedback-btn:active{transform:translate(3px,3px);box-shadow:0 0 #333,2px 2px #0000001a}.form-section{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:3px solid #e0e0e0}.form-section:last-child{border-bottom:none;padding-bottom:0}h2{color:#333;font-size:1.4rem;margin:0 0 1rem;font-weight:700}h3{color:#444;font-size:1.2rem;margin:1.5rem 0 1rem;font-weight:700}.file-upload-wrapper{position:relative;margin-bottom:1rem}#file-upload{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden;z-index:-1}.file-upload-label{display:block;padding:1rem 1.5rem;background:#e63946;color:#fff;border:4px solid #333;box-shadow:4px 4px #333,8px 8px #00000026;cursor:pointer;text-align:center;transition:all .1s ease;font-size:1.2rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}.file-upload-label:hover{background:#d62839;transform:translate(-2px,-2px);box-shadow:6px 6px #333,10px 10px #00000026}.file-upload-label:active{transform:translate(4px,4px);box-shadow:0 0 #333,4px 4px #00000026}.file-info{color:#2a9d8f;font-weight:700;margin:.5rem 0 0;font-size:1.05rem}.line-range{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.input-group{display:flex;flex-direction:column}.input-group label{color:#333;font-weight:700;margin-bottom:.5rem;font-size:1.05rem}.input-group input[type=number]{padding:.75rem;border:3px solid #333;background:#fff;color:#333;font-size:1.15rem;font-family:"Jersey 15",monospace;font-weight:700;transition:all .2s ease;box-shadow:3px 3px #0000001a}.input-group input[type=number]:focus{outline:none;border-color:#e63946;box-shadow:3px 3px #e6394633}.checkbox-label{display:flex;align-items:center;cursor:pointer;font-size:1.1rem}.checkbox-label input[type=checkbox]{width:24px;height:24px;margin-right:.75rem;cursor:pointer;accent-color:#e63946;border:3px solid #333}.checkbox-label span{color:#333;font-weight:700}.help-text{color:#666;font-size:1rem;margin:.5rem 0;line-height:1.6;font-weight:700}.help-text.example{color:#888;font-style:normal;font-family:"Jersey 15",monospace;font-weight:700}.line-group-input{display:flex;gap:1rem;margin-bottom:1.5rem}.line-group-input input[type=text]{flex:1;padding:.75rem;border:3px solid #333;background:#fff;color:#333;font-size:1.1rem;font-family:"Jersey 15",monospace;font-weight:700;transition:all .2s ease;box-shadow:3px 3px #0000001a}.line-group-input input[type=text]:focus{outline:none;border-color:#e63946;box-shadow:3px 3px #e6394633}.btn-add{padding:.75rem 1.5rem;background:#2a9d8f;color:#fff;border:3px solid #333;box-shadow:4px 4px #333,6px 6px #0000001a;font-size:1.05rem;font-weight:700;font-family:"Jersey 15",monospace;cursor:pointer;transition:all .1s ease;white-space:nowrap;text-transform:uppercase;letter-spacing:1px}.btn-add:hover{background:#238276;transform:translate(-2px,-2px);box-shadow:6px 6px #333,8px 8px #0000001a}.btn-add:active{transform:translate(4px,4px);box-shadow:0 0 #333,2px 2px #0000001a}.btn-split{padding:.75rem 1.5rem;background:#f4a261;color:#fff;border:3px solid #333;box-shadow:4px 4px #333,6px 6px #0000001a;font-size:1.05rem;font-weight:700;font-family:"Jersey 15",monospace;cursor:pointer;transition:all .1s ease;white-space:nowrap;text-transform:uppercase;letter-spacing:1px}.btn-split:hover{background:#e08d4a;transform:translate(-2px,-2px);box-shadow:6px 6px #333,8px 8px #0000001a}.btn-split:active{transform:translate(4px,4px);box-shadow:0 0 #333,2px 2px #0000001a}.line-groups-list{background:#fafafa;border:3px solid #e0e0e0;padding:1.5rem}.line-group-item{display:flex;align-items:center;padding:1rem;background:#fff;border:3px solid #333;margin-bottom:.75rem;box-shadow:3px 3px #0000001a}.line-group-item:last-child{margin-bottom:0}.group-number{color:#e63946;font-weight:700;margin-right:1rem;min-width:100px;font-size:1.05rem}.group-lines{flex:1;color:#333;font-family:"Jersey 15",monospace;font-size:1.05rem;font-weight:700}.group-lines.split-group{color:#f4a261;font-style:italic}.btn-remove{padding:.5rem .75rem;background:#e63946;color:#fff;border:3px solid #333;box-shadow:3px 3px #333,4px 4px #0000001a;cursor:pointer;transition:all .1s ease;font-size:1.1rem;line-height:1;font-family:"Jersey 15",monospace;font-weight:700}.btn-remove:hover{background:#d62839;transform:translate(-1px,-1px);box-shadow:4px 4px #333,5px 5px #0000001a}.btn-remove:active{transform:translate(3px,3px);box-shadow:0 0 #333,1px 1px #0000001a}.btn-submit{width:100%;padding:1.25rem;background:#e63946;color:#fff;border:4px solid #333;box-shadow:6px 6px #333,10px 10px #00000026;font-size:1.3rem;font-weight:700;font-family:"Jersey 15",monospace;cursor:pointer;transition:all .1s ease;text-transform:uppercase;letter-spacing:1px}.btn-submit:hover{background:#d62839;transform:translate(-2px,-2px);box-shadow:8px 8px #333,12px 12px #00000026}.btn-submit:active{transform:translate(6px,6px);box-shadow:0 0 #333,4px 4px #00000026}.btn-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.preview-panel{flex:1.2;min-width:600px;background:#fff;border:4px solid #333;box-shadow:4px 4px #333,8px 8px #0000001a;overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 2rem)}.preview-header{padding:1.5rem 2rem;background:#e63946;color:#fff;border-bottom:4px solid #333}.preview-header h2{color:#fff;margin:0 0 .5rem;font-size:1.5rem;font-weight:700}.preview-filename{font-size:1rem;color:#ffffffe6;font-family:"Jersey 15",monospace;font-weight:700}.preview-content{flex:1;overflow-y:auto;background:#2b2b2b}.code-preview{margin:0;padding:1rem 0;font-family:"Jersey 15",Courier New,monospace;font-size:1rem;line-height:1.8;color:#d4d4d4;font-weight:700}.code-line{display:flex;padding:.2rem 0;transition:background-color .1s ease}.code-line:hover{background:#ffffff0d}.code-line.in-range{background:#e6394626;border-left:4px solid #e63946}.code-line.in-range:hover{background:#e6394640}.code-line.in-group{background:#2a9d8f33;border-left:4px solid #2a9d8f}.code-line.in-group:hover{background:#2a9d8f4d}.line-number{display:inline-block;min-width:60px;padding:0 1rem;color:#858585;text-align:right;-webkit-user-select:none;user-select:none;flex-shrink:0}.line-group-indicator{display:inline-block;min-width:80px;padding:0 .75rem 0 .5rem;color:#e63946;font-weight:700;text-align:right;flex-shrink:0}.line-content{padding-right:1rem;white-space:pre;flex:1;color:#d4d4d4}.loading-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loading-modal{background:#fff;border:4px solid #333;box-shadow:8px 8px #333,12px 12px #0003;width:90%;max-width:500px;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.loading-header{background:#e63946;color:#fff;padding:1rem 1.5rem;border-bottom:4px solid #333;display:flex;justify-content:space-between;align-items:center}.loading-title{font-size:1.3rem;font-weight:700;font-family:"Jersey 15",monospace;text-transform:uppercase;letter-spacing:1px}.loading-body{padding:2.5rem 2rem;text-align:center}.loading-icon{margin-bottom:1rem;animation:pulse 1.5s ease-in-out infinite}.loading-icon img{width:76px;height:76px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.loading-text{color:#333;font-size:1.5rem;margin:0 0 .75rem;font-weight:700;font-family:"Jersey 15",monospace}.loading-subtext{color:#666;font-size:1.05rem;margin:0 0 2rem;font-weight:700;font-family:"Jersey 15",monospace}.progress-bar-container{margin-top:1.5rem}.progress-status{color:#333;font-size:1.1rem;font-weight:700;font-family:"Jersey 15",monospace;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:1px}.progress-bar-bg{width:100%;height:40px;background:#f5f5f5;border:4px solid #333;position:relative;overflow:hidden;box-shadow:inset 3px 3px #0000001a}.progress-bar-fill{height:100%;background:#e63946;background-image:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(255,255,255,.1) 10px,rgba(255,255,255,.1) 20px);transition:width .3s ease;position:relative;box-shadow:inset 0 2px 4px #ffffff4d;animation:barberPole 1s linear infinite}@keyframes barberPole{0%{background-position:0 0}to{background-position:28px 0}}.progress-text{display:block;margin-top:.75rem;font-size:1.2rem;font-weight:700;color:#e63946;font-family:"Jersey 15",monospace}@media(max-width:1200px){.main-layout{flex-direction:column}.preview-panel{max-width:100%;max-height:500px}h1{font-size:1.6rem}.subtitle{font-size:.8rem}}@media(max-width:768px){.container{padding:1.5rem 1rem}h1{font-size:1.3rem}h2{font-size:.95rem}.subtitle{font-size:.75rem}.line-range{grid-template-columns:1fr;gap:1rem}.line-group-input{flex-direction:column}.btn-add{width:100%}.line-group-item{flex-wrap:wrap}.group-number{min-width:auto;width:100%;margin-bottom:.5rem}.group-lines{width:calc(100% - 60px);margin-right:.5rem}.preview-panel{max-height:400px;min-width:100%}.code-preview{font-size:.75rem}.line-number{min-width:50px;padding:0 .5rem}.file-upload-label,.btn-add,.btn-submit{font-size:.85rem}.loading-modal{width:95%;max-width:none}.loading-body{padding:1.5rem 1rem}.loading-icon{font-size:3rem}.loading-text{font-size:1.2rem}.loading-subtext{font-size:.9rem}.progress-bar-bg{height:32px}.progress-text{font-size:1rem}}.split-modal{background:#fff;border:4px solid #333;box-shadow:8px 8px #333,12px 12px #0003;width:90%;max-width:450px}.split-header{background:#f4a261;color:#fff;padding:1rem 1.5rem;border-bottom:4px solid #333;display:flex;justify-content:space-between;align-items:center}.split-title{font-size:1.3rem;font-weight:700;font-family:"Jersey 15",monospace;text-transform:uppercase;letter-spacing:1px}.btn-close{background:transparent;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0;line-height:1;font-family:"Jersey 15",monospace;transition:transform .1s ease}.btn-close:hover{transform:scale(1.2)}.split-body{padding:2rem}.split-description{color:#666;font-size:1rem;margin:0 0 1.5rem;line-height:1.6;font-weight:700}.split-input-group{margin-bottom:1.5rem}.split-input-group label{display:block;color:#333;font-weight:700;margin-bottom:.5rem;font-size:1.05rem}.split-input-group input{width:100%;padding:.75rem;border:3px solid #333;background:#fff;color:#333;font-size:1.15rem;font-family:"Jersey 15",monospace;font-weight:700;box-shadow:3px 3px #0000001a}.split-input-group input:focus{outline:none;border-color:#f4a261;box-shadow:3px 3px #f4a26133}.split-buttons{display:flex;gap:1rem;justify-content:flex-end}.btn-cancel{padding:.75rem 1.5rem;background:#999;color:#fff;border:3px solid #333;box-shadow:3px 3px #333,4px 4px #0000001a;font-size:1rem;font-weight:700;font-family:"Jersey 15",monospace;cursor:pointer;transition:all .1s ease;text-transform:uppercase;letter-spacing:1px}.btn-cancel:hover{background:#888;transform:translate(-1px,-1px);box-shadow:4px 4px #333,5px 5px #0000001a}.btn-cancel:active{transform:translate(3px,3px);box-shadow:0 0 #333,1px 1px #0000001a}.btn-confirm{padding:.75rem 1.5rem;background:#f4a261;color:#fff;border:3px solid #333;box-shadow:3px 3px #333,4px 4px #0000001a;font-size:1rem;font-weight:700;font-family:"Jersey 15",monospace;cursor:pointer;transition:all .1s ease;text-transform:uppercase;letter-spacing:1px}.btn-confirm:hover{background:#e08d4a;transform:translate(-1px,-1px);box-shadow:4px 4px #333,5px 5px #0000001a}.btn-confirm:active{transform:translate(3px,3px);box-shadow:0 0 #333,1px 1px #0000001a}.color-preview-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.color-preview-chip{padding:.4rem .8rem;border:3px solid #333;box-shadow:2px 2px #0000001a;display:flex;align-items:center;justify-content:center}.color-preview-label{font-size:.85rem;font-weight:700;text-transform:capitalize;color:#fff;text-shadow:1px 1px 0 rgba(0,0,0,.5)}.btn-colors{padding:.75rem 1.5rem;background:#9b59b6;color:#fff;border:3px solid #333;box-shadow:4px 4px #333,6px 6px #0000001a;font-size:1.05rem;font-weight:700;font-family:"Jersey 15",monospace;cursor:pointer;transition:all .1s ease;text-transform:uppercase;letter-spacing:1px}.btn-colors:hover{background:#8e44ad;transform:translate(-2px,-2px);box-shadow:6px 6px #333,8px 8px #0000001a}.btn-colors:active{transform:translate(4px,4px);box-shadow:0 0 #333,2px 2px #0000001a}.orientation-toggle{display:flex;gap:1rem;margin-top:1rem}.orientation-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.2rem 1rem;background:#fff;border:4px solid #333;color:#333;cursor:pointer;font-family:"Jersey 15",monospace;font-weight:700;transition:all .1s ease;box-shadow:4px 4px #333,6px 6px #0000001a}.orientation-btn:hover{background:#f0f0f0}.orientation-btn:not(.active){color:#333!important}.orientation-btn.active{background:#2a9d8f;color:#fff;border-color:#333}.orientation-btn:active{transform:translate(2px,2px);box-shadow:2px 2px #333,4px 4px #0000001a}.orientation-icon{display:block;border:3px solid currentColor;background:#0000001a}.landscape-icon{width:48px;height:28px}.portrait-icon{width:28px;height:48px}.orientation-btn.active .orientation-icon{background:#fff3}.orientation-label{font-size:1.1rem;text-transform:uppercase;letter-spacing:1px}.orientation-size{font-size:.9rem;opacity:.7}.quality-toggle{display:flex;gap:1rem;margin-top:1rem}.quality-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:1rem .75rem;background:#fff;border:4px solid #333;color:#333;cursor:pointer;font-family:"Jersey 15",monospace;font-weight:700;transition:all .1s ease;box-shadow:4px 4px #333,6px 6px #0000001a}.quality-btn:hover{background:#f0f0f0}.quality-btn:not(.active){color:#333!important}.quality-btn.active{background:#e63946;color:#fff;border-color:#333}.quality-btn:active{transform:translate(2px,2px);box-shadow:2px 2px #333,4px 4px #0000001a}.quality-label{font-size:1.1rem;text-transform:uppercase;letter-spacing:1px}.quality-size{font-size:.85rem;opacity:.7}@media(max-width:768px){.quality-toggle{flex-direction:column}.quality-btn{padding:.75rem}}.color-modal{background:#fff;border:4px solid #333;box-shadow:8px 8px #333,12px 12px #0003;width:90%;max-width:550px;max-height:90vh;overflow-y:auto}.color-modal-header{background:#9b59b6;color:#fff;padding:1rem 1.5rem;border-bottom:4px solid #333;display:flex;justify-content:space-between;align-items:center}.color-modal-title{font-size:1.3rem;font-weight:700;font-family:"Jersey 15",monospace;text-transform:uppercase;letter-spacing:1px}.color-modal-body{padding:1.5rem}.color-modal-description{color:#666;font-size:1rem;margin:0 0 1.5rem;line-height:1.6;font-weight:700}.color-inputs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.color-input-group{display:flex;flex-direction:column;gap:.5rem}.color-input-group label{color:#333;font-weight:700;font-size:1rem;text-transform:capitalize}.color-input-wrapper{display:flex;gap:.5rem;align-items:center}.color-input-wrapper input[type=color]{width:50px;height:40px;padding:0;border:3px solid #333;cursor:pointer;background:transparent}.color-input-wrapper input[type=color]::-webkit-color-swatch-wrapper{padding:2px}.color-input-wrapper input[type=color]::-webkit-color-swatch{border:none}.color-input-wrapper input[type=text]{flex:1;padding:.5rem;border:3px solid #333;background:#fff;color:#333;font-size:1rem;font-family:"Jersey 15",monospace;font-weight:700;box-shadow:2px 2px #0000001a;text-transform:uppercase}.color-input-wrapper input[type=text]:focus{outline:none;border-color:#9b59b6;box-shadow:2px 2px #9b59b633}.color-modal-buttons{display:flex;gap:1rem;justify-content:space-between}.btn-reset{padding:.75rem 1.5rem;background:#95a5a6;color:#fff;border:3px solid #333;box-shadow:3px 3px #333,4px 4px #0000001a;font-size:1rem;font-weight:700;font-family:"Jersey 15",monospace;cursor:pointer;transition:all .1s ease;text-transform:uppercase;letter-spacing:1px}.btn-reset:hover{background:#7f8c8d;transform:translate(-1px,-1px);box-shadow:4px 4px #333,5px 5px #0000001a}.btn-reset:active{transform:translate(3px,3px);box-shadow:0 0 #333,1px 1px #0000001a}@media(max-width:768px){.color-inputs-grid{grid-template-columns:1fr}.color-preview-row{justify-content:center}.color-modal-buttons{flex-direction:column}.btn-reset,.btn-confirm{width:100%}}.preview-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.btn-preview-colors{padding:.5rem 1rem;background:#2a9d8f;color:#fff;border:3px solid #333;box-shadow:3px 3px #333,4px 4px #0000001a;font-size:.9rem;font-weight:700;font-family:"Jersey 15",monospace;cursor:pointer;transition:all .1s ease;text-transform:uppercase;letter-spacing:1px}.btn-preview-colors:hover{background:#238276;transform:translate(-1px,-1px);box-shadow:4px 4px #333,5px 5px #0000001a}.btn-preview-colors:active{transform:translate(3px,3px);box-shadow:0 0 #333,1px 1px #0000001a}.syntax-preview-modal{background:#fff;border:4px solid #333;box-shadow:8px 8px #333,12px 12px #0003;width:90%;max-width:900px;max-height:90vh;display:flex;flex-direction:column}.syntax-preview-header{background:#2a9d8f;color:#fff;padding:1rem 1.5rem;border-bottom:4px solid #333;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.syntax-preview-title{font-size:1.3rem;font-weight:700;font-family:"Jersey 15",monospace;text-transform:uppercase;letter-spacing:1px}.syntax-preview-body{padding:1.5rem;display:flex;flex-direction:column;overflow:hidden;flex:1}.syntax-preview-description{color:#666;font-size:1rem;margin:0 0 1rem;line-height:1.6;font-weight:700;flex-shrink:0}.syntax-preview-code-container{flex:1;overflow-y:auto;background:#1e1e1e;border:4px solid #333;margin-bottom:1rem;min-height:200px;max-height:400px}.syntax-preview-code{margin:0;padding:1rem;font-family:Courier New,monospace;font-size:.95rem;line-height:1.6}.syntax-preview-line{display:flex;padding:.1rem 0}.syntax-preview-line-num{display:inline-block;min-width:50px;padding-right:1rem;color:#6a737d;text-align:right;-webkit-user-select:none;user-select:none;flex-shrink:0}.syntax-preview-line-content{white-space:pre;flex:1}.syntax-preview-legend{background:#fafafa;border:3px solid #e0e0e0;padding:1rem;margin-bottom:1rem;flex-shrink:0}.legend-title{font-weight:700;color:#333;margin-right:1rem;font-size:1rem}.legend-items{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.5rem}.legend-item{display:flex;align-items:center;gap:.4rem}.legend-color{width:16px;height:16px;border:2px solid #333}.legend-label{font-size:.9rem;font-weight:700;color:#555;text-transform:capitalize}.syntax-preview-buttons{display:flex;gap:1rem;justify-content:flex-end;flex-shrink:0}.btn-edit-colors{padding:.75rem 1.5rem;background:#9b59b6;color:#fff;border:3px solid #333;box-shadow:3px 3px #333,4px 4px #0000001a;font-size:1rem;font-weight:700;font-family:"Jersey 15",monospace;cursor:pointer;transition:all .1s ease;text-transform:uppercase;letter-spacing:1px}.btn-edit-colors:hover{background:#8e44ad;transform:translate(-1px,-1px);box-shadow:4px 4px #333,5px 5px #0000001a}.btn-edit-colors:active{transform:translate(3px,3px);box-shadow:0 0 #333,1px 1px #0000001a}@media(max-width:768px){.syntax-preview-modal{max-width:100%}.syntax-preview-code-container{max-height:250px}.preview-header-top{flex-direction:column;align-items:flex-start;gap:.5rem}.btn-preview-colors{width:100%}.syntax-preview-buttons{flex-direction:column}.btn-edit-colors,.syntax-preview-buttons .btn-confirm{width:100%}.legend-items{gap:.5rem}}.groups-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.groups-header h3{margin:0}.btn-clear-all{padding:.5rem 1rem;background:#e63946;color:#fff;border:3px solid #333;box-shadow:3px 3px #333,4px 4px #0000001a;font-size:.9rem;font-weight:700;font-family:"Jersey 15",monospace;cursor:pointer;transition:all .1s ease;text-transform:uppercase;letter-spacing:1px}.btn-clear-all:hover{background:#d62839;transform:translate(-1px,-1px);box-shadow:4px 4px #333,5px 5px #0000001a}.btn-clear-all:active{transform:translate(3px,3px);box-shadow:0 0 #333,1px 1px #0000001a}.upload-another-modal{background:#fff;border:4px solid #333;box-shadow:8px 8px #333,12px 12px #0003;width:90%;max-width:500px}.upload-another-header{background:#2a9d8f;color:#fff;padding:1rem 1.5rem;border-bottom:4px solid #333;display:flex;justify-content:center;align-items:center}.upload-another-title{font-size:1.3rem;font-weight:700;font-family:"Jersey 15",monospace;text-transform:uppercase;letter-spacing:1px}.upload-another-body{padding:2.5rem 2rem;text-align:center}.upload-another-icon{margin-bottom:1rem}.upload-another-icon img{width:76px;height:76px}.upload-another-text{color:#333;font-size:1.5rem;margin:0 0 .75rem;font-weight:700;font-family:"Jersey 15",monospace}.upload-another-subtext{color:#666;font-size:1.05rem;margin:0 0 2rem;font-weight:700;font-family:"Jersey 15",monospace}.upload-another-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.video-complete-modal{max-width:800px}.video-preview-container{margin-bottom:1.5rem;border:4px solid #333;background:#000;box-shadow:4px 4px #0003}.video-preview{width:100%;max-height:450px;display:block}.timing-inputs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.timing-input-group{display:flex;flex-direction:column;gap:.5rem}.timing-input-group label{color:#333;font-weight:700;font-size:.95rem}.timing-input-group input{padding:.5rem;border:3px solid #333;background:#fff;color:#333;font-size:1rem;font-family:"Jersey 15",monospace;font-weight:700;box-shadow:2px 2px #0000001a}.timing-input-group input:focus{outline:none;border-color:#e63946;box-shadow:2px 2px #e6394633}.timing-input-group .input-suffix{font-size:.85rem;color:#666;margin-top:.25rem}.timing-actions{display:flex;justify-content:flex-end;margin-top:.75rem}@media(max-width:768px){.timing-inputs-grid{grid-template-columns:1fr}.upload-another-buttons{flex-direction:column}.upload-another-buttons .btn-cancel,.upload-another-buttons .btn-confirm{width:100%}}.api-status-banner{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 1rem;margin-bottom:1rem;border:3px solid #333;font-size:1rem;overflow:hidden}.api-status-banner.checking,.api-status-banner.waking{background:#fff3cd;color:#856404;border-color:#856404}.api-status-banner.error{background:#f8d7da;color:#721c24;border-color:#721c24}.status-spinner{width:16px;height:16px;border:3px solid currentColor;border-right-color:transparent;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.retry-btn{background:#721c24;color:#fff;border:2px solid #333;padding:.25rem .75rem;font-family:"Jersey 15",monospace;font-weight:700;cursor:pointer;box-shadow:2px 2px #0003}.retry-btn:hover{background:#a71d2a}.retry-btn:active{transform:translate(1px,1px);box-shadow:1px 1px #0003}.btn-submit:disabled{background:#ccc;color:#666;cursor:not-allowed;box-shadow:2px 2px #0000001a}.btn-submit:disabled:hover{background:#ccc;transform:none}
