*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: #1a1a26;--bg-card-hover: #22222e;--bg-input: #16161f;--border: #2a2a3a;--border-accent: #4f46e5;--text-primary: #e8e8f0;--text-secondary: #8888a0;--text-muted: #55556a;--accent: #6c63ff;--accent-glow: rgba(108, 99, 255, .15);--green: #34d399;--green-bg: rgba(52, 211, 153, .1);--yellow: #fbbf24;--yellow-bg: rgba(251, 191, 36, .1);--red: #f87171;--red-bg: rgba(248, 113, 113, .1)}body{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh}.landing{min-height:100vh;background:var(--bg-primary);overflow-x:hidden}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 3rem;position:fixed;top:0;left:0;right:0;z-index:100;background:#0a0a0fd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.landing-nav-logo{font-size:1.3rem;font-weight:700;letter-spacing:-.02em}.landing-nav-logo span{color:var(--accent)}.landing-nav-links{display:flex;align-items:center;gap:1rem}.nav-link{color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;transition:color .15s}.nav-link:hover{color:var(--text-primary)}.btn-outline{background:transparent;color:var(--text-secondary);border:1px solid var(--border);padding:.45rem 1.2rem;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s}.btn-outline:hover{border-color:var(--text-secondary);color:var(--text-primary)}.btn-cta-small{background:var(--accent);color:#fff;border:none;padding:.45rem 1.2rem;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-cta-small:hover{opacity:.9}.hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:10rem 2rem 4rem;position:relative}.hero:before{content:"";position:absolute;top:-100px;left:50%;transform:translate(-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(108,99,255,.12) 0%,transparent 70%);pointer-events:none}.hero-decor{position:absolute;inset:0;overflow:hidden;pointer-events:none}.geo-shape{position:absolute;border-radius:16px;background:linear-gradient(135deg,#6c63ff26,#6c63ff0a);border:1px solid rgba(108,99,255,.1);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.geo-left-1{width:280px;height:280px;top:15%;left:-4%;transform:rotate(-20deg);animation:geoFloat 10s ease-in-out infinite alternate}.geo-left-2{width:200px;height:200px;top:35%;left:4%;transform:rotate(-35deg);background:linear-gradient(135deg,#6c63ff1a,#6c63ff05);border-color:#6c63ff12;animation:geoFloat 12s ease-in-out infinite alternate-reverse}.geo-right-1{width:260px;height:260px;top:18%;right:-3%;transform:rotate(15deg);animation:geoFloat 11s ease-in-out infinite alternate-reverse}.geo-right-2{width:180px;height:180px;top:40%;right:6%;transform:rotate(30deg);background:linear-gradient(135deg,#6c63ff1a,#6c63ff05);border-color:#6c63ff12;animation:geoFloat 9s ease-in-out infinite alternate}@keyframes geoFloat{0%{transform:rotate(var(--start-rot, -20deg)) translate(0)}to{transform:rotate(var(--start-rot, -20deg)) translate(8px,-12px)}}.geo-left-1{--start-rot: -20deg}.geo-left-2{--start-rot: -35deg}.geo-right-1{--start-rot: 15deg}.geo-right-2{--start-rot: 30deg}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1rem;background:#6c63ff1a;border:1px solid rgba(108,99,255,.25);border-radius:100px;font-size:.8rem;font-weight:500;color:var(--accent);margin-bottom:1.5rem}.hero-badge-icon{font-size:.9rem}.hero-title{font-size:4rem;font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:1.25rem;background:linear-gradient(180deg,var(--text-primary) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.1rem;color:var(--text-secondary);line-height:1.7;max-width:540px;margin-bottom:2rem}.btn-cta{background:var(--accent);color:#fff;border:none;padding:.85rem 2.2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;transition:transform .15s,box-shadow .15s;box-shadow:0 0 30px #6c63ff40}.btn-cta:hover{transform:translateY(-1px);box-shadow:0 0 40px #6c63ff66}.btn-arrow{font-size:1.1rem;transition:transform .15s}.btn-cta:hover .btn-arrow{transform:translate(3px)}.slide-down-1,.slide-down-2,.slide-down-3,.slide-down-4{opacity:0;transform:translateY(-30px);animation:slideDown .7s ease forwards}.slide-down-1{animation-delay:.1s}.slide-down-2{animation-delay:.25s}.slide-down-3{animation-delay:.4s}.slide-down-4{animation-delay:.55s}@keyframes slideDown{to{opacity:1;transform:translateY(0)}}.slide-up{opacity:0;transform:translateY(40px);animation:slideUp .8s ease forwards;animation-delay:.7s}@keyframes slideUp{to{opacity:1;transform:translateY(0)}}.hero-preview{margin-top:3.5rem;width:100%;max-width:680px;perspective:1000px}.preview-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 4px 24px #0000004d,0 0 60px #6c63ff14}.preview-header{display:flex;align-items:center;gap:.4rem;padding:.75rem 1rem;background:var(--bg-card);border-bottom:1px solid var(--border)}.preview-dot{width:10px;height:10px;border-radius:50%}.preview-dot.red{background:#f87171}.preview-dot.yellow{background:#fbbf24}.preview-dot.green{background:#34d399}.preview-title{margin-left:.75rem;font-size:.8rem;font-weight:500;color:var(--text-secondary)}.preview-body{padding:1.25rem}.preview-score-row{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.preview-score{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;color:var(--green);background:var(--green-bg);border:2px solid var(--green);flex-shrink:0}.preview-filename{font-size:.9rem;font-weight:600;margin-bottom:.15rem}.preview-diagnosis{font-size:.8rem;color:var(--text-secondary)}.preview-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem;margin-bottom:1rem;padding:.75rem;background:var(--bg-card);border-radius:8px}.preview-stat{text-align:center}.preview-stat-val{font-size:.95rem;font-weight:700}.preview-stat-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.preview-pillars{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}.preview-pillar{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--bg-card);border-radius:6px;font-size:.8rem;font-weight:500}.pp-good{color:var(--green);font-weight:700}.pp-ok{color:var(--yellow);font-weight:700}.ticker-section{padding:3rem 0 2rem;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden}.ticker-label{text-align:center;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1.25rem}.ticker-track{position:relative;width:100%;overflow:hidden;mask-image:linear-gradient(90deg,transparent 0%,black 10%,black 90%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0%,black 10%,black 90%,transparent 100%)}.ticker-scroll{display:flex;width:max-content;animation:tickerScroll 30s linear infinite}.ticker-set{display:flex;align-items:center;gap:0;flex-shrink:0}.ticker-item{font-size:.95rem;font-weight:500;color:var(--text-secondary);white-space:nowrap;padding:0 1.5rem;transition:color .2s}.ticker-dot{width:4px;height:4px;border-radius:50%;background:var(--text-muted);flex-shrink:0}@keyframes tickerScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.problem{padding:6rem 3rem;max-width:1100px;margin:0 auto}.problem-label{font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.75rem}.problem-heading{font-size:2.4rem;font-weight:700;letter-spacing:-.02em;margin-bottom:3rem;line-height:1.2}.problem-faded{color:var(--text-muted)}.problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.feature-card{position:relative;padding:1.75rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden;opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease,border-color .2s}.feature-card.visible{opacity:1;transform:translateY(0)}.feature-card:nth-child(1){transition-delay:0s}.feature-card:nth-child(2){transition-delay:.1s}.feature-card:nth-child(3){transition-delay:.2s}.feature-card:nth-child(4){transition-delay:.3s}.feature-card:hover{border-color:#ffffff26}.feature-card.visible:hover{transform:translateY(-2px)}.feature-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.feature-step{font-size:.7rem;font-weight:600;letter-spacing:.15em;color:var(--text-muted)}.feature-number{font-size:4rem;font-weight:800;line-height:1;color:#ffffff0a;font-style:italic;font-family:Georgia,Times New Roman,serif;margin-top:-.5rem}.feature-card h3{font-size:1.1rem;font-weight:700;margin-bottom:.6rem;font-style:italic}.feature-card p{font-size:.88rem;color:var(--text-secondary);line-height:1.65}@media(max-width:768px){.problem{padding:4rem 1.5rem}.problem-heading{font-size:1.8rem}.problem-grid{grid-template-columns:1fr}}.how-it-works{padding:6rem 3rem;max-width:1100px;margin:0 auto}.how-header{text-align:center;margin-bottom:5rem}.how-label{font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.75rem}.how-heading{font-size:2.4rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}.steps-container{position:relative;display:flex;flex-direction:column;gap:4rem}.steps-line{position:absolute;left:50%;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent 0%,rgba(255,255,255,.08) 10%,rgba(255,255,255,.08) 90%,transparent 100%);transform:translate(-50%)}.step-block{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative}.step-block-reverse{direction:rtl}.step-block-reverse>*{direction:ltr}.step-text{padding:1rem 0}.step-badge{display:inline-block;font-size:.65rem;font-weight:600;letter-spacing:.15em;padding:.3rem .75rem;border:1px solid rgba(108,99,255,.3);border-radius:100px;color:var(--accent);margin-bottom:1rem}.step-text h3{font-size:1.7rem;font-weight:700;line-height:1.25;letter-spacing:-.01em;margin-bottom:.75rem}.step-accent{color:var(--accent)}.step-text p{font-size:.92rem;color:var(--text-secondary);line-height:1.7}.step-visual{display:flex;justify-content:center}.step-mock{width:100%;max-width:420px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;padding:1.5rem;box-shadow:0 4px 24px #0003}.mock-upload-zone{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:1rem;border:1px dashed rgba(255,255,255,.1);border-radius:10px;margin-bottom:1rem}.mock-icon{width:36px;height:36px;border-radius:8px;background:var(--accent-glow);border:1px solid rgba(108,99,255,.3);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--accent)}.mock-text{font-size:.85rem;font-weight:600}.mock-meta{font-size:.7rem;color:var(--text-muted)}.mock-progress{height:4px;background:#ffffff0d;border-radius:2px;margin-bottom:.5rem;overflow:hidden}.mock-progress-bar{width:65%;height:100%;background:var(--accent);border-radius:2px}.mock-status{font-size:.75rem;color:var(--accent);font-weight:500}.mock-analysis{display:flex;flex-direction:column}.mock-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.04)}.mock-row:last-child{border-bottom:none}.mock-label{font-size:.82rem;color:var(--text-secondary)}.mock-val{font-size:.85rem;font-weight:600}.mock-val.mock-good{color:var(--green)}.mock-val.mock-ok{color:var(--yellow)}.mock-divider{height:1px;background:var(--border);margin:.4rem 0}.mock-report{display:flex;flex-direction:column;gap:1rem}.mock-diagnosis{font-size:.88rem;font-style:italic;color:var(--text-primary);line-height:1.5;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.mock-fixes{display:flex;flex-direction:column;gap:.6rem}.mock-fix-item{display:flex;align-items:flex-start;gap:.6rem;font-size:.82rem;color:var(--accent);line-height:1.4}.mock-fix-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:.35rem}@media(max-width:768px){.how-it-works{padding:4rem 1.5rem}.how-heading{font-size:1.8rem}.step-block,.step-block-reverse{grid-template-columns:1fr;gap:1.5rem;direction:ltr}.steps-line{display:none}.step-text h3{font-size:1.3rem}}.footer-cta{text-align:center;padding:5rem 2rem 6rem}.footer-cta h2{font-size:1.8rem;font-weight:700;margin-bottom:1.5rem;letter-spacing:-.02em}@media(max-width:768px){.landing-nav{padding:1rem 1.5rem}.hero{padding:8rem 1.5rem 3rem}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:.95rem}.hero-subtitle br{display:none}.features{padding:4rem 1.5rem}.features-grid,.preview-stats{grid-template-columns:1fr}}.app-layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border)}.logo{font-size:1.3rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.logo span{color:var(--accent)}.logo-clickable{cursor:pointer;transition:opacity .15s}.logo-clickable:hover{opacity:.8}.sidebar-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:1rem 1.5rem .5rem}.history-list{list-style:none;flex:1;overflow-y:auto;padding:0 .75rem .75rem}.history-item{padding:.6rem .75rem;border-radius:6px;cursor:pointer;transition:background .15s;margin-bottom:2px}.history-item:hover{background:var(--bg-card)}.history-item.active{background:var(--accent-glow);border:1px solid var(--border-accent)}.history-item:not(.active){border:1px solid transparent}.history-item-main{display:flex;justify-content:space-between;align-items:center}.history-filename{font-size:.85rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:65%}.history-rating{font-size:.75rem;font-weight:700;padding:.1rem .45rem;border-radius:4px}.history-rating.good{background:var(--green-bg);color:var(--green)}.history-rating.ok{background:var(--yellow-bg);color:var(--yellow)}.history-rating.bad{background:var(--red-bg);color:var(--red)}.history-item-meta{display:flex;gap:.6rem;font-size:.7rem;color:var(--text-muted);margin-top:.2rem}.history-loading,.history-empty{padding:1.5rem;color:var(--text-muted);font-size:.85rem;text-align:center}.main-content{padding:2.5rem 3rem;max-width:800px;width:100%;margin:0 auto;overflow-y:auto}.page-title{font-size:1.8rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem}.page-subtitle{color:var(--text-secondary);font-size:.9rem;margin-bottom:2rem}.upload-zone{border:2px dashed var(--border);border-radius:10px;padding:2rem;text-align:center;transition:border-color .2s,background .2s;margin-bottom:2rem}.upload-zone:hover{border-color:var(--accent);background:var(--accent-glow)}.upload-label input[type=file]{display:none}.upload-label{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.5rem}.upload-icon{font-size:2rem;opacity:.5}.upload-text{color:var(--text-secondary);font-size:.9rem}.upload-text strong{color:var(--accent)}.upload-formats{font-size:.75rem;color:var(--text-muted)}.upload-selected{margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:1rem}.upload-filename{font-size:.85rem;color:var(--text-primary);font-weight:500}.upload-filename-midi{color:var(--text-muted);font-weight:400}.upload-context{display:flex;align-items:center;gap:.75rem;margin-top:1rem;flex-wrap:wrap;justify-content:center}.genre-select{background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.8rem;padding:.4rem .75rem;cursor:pointer;transition:border-color .15s}.genre-select:hover,.genre-select:focus{border-color:var(--accent);outline:none}.genre-select:disabled{opacity:.5;cursor:not-allowed}.finished-toggle{display:flex;align-items:center;gap:.4rem;cursor:pointer;-webkit-user-select:none;user-select:none}.finished-toggle input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}.finished-toggle-label{font-size:.8rem;color:var(--text-secondary)}.finished-toggle:has(input:checked) .finished-toggle-label{color:var(--accent)}.btn{padding:.5rem 1.5rem;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.error-message{padding:.75rem 1rem;background:var(--red-bg);border:1px solid rgba(248,113,113,.3);border-radius:8px;color:var(--red);font-size:.85rem;margin-bottom:1.5rem}.audio-player{margin-bottom:1.5rem;padding:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px}.audio-player-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.5rem}.audio-player audio{width:100%;height:36px;border-radius:4px}.report{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.report-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.5rem}.overall-score{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:800;flex-shrink:0;border:3px solid}.overall-score.good{border-color:var(--green);color:var(--green);background:var(--green-bg)}.overall-score.ok{border-color:var(--yellow);color:var(--yellow);background:var(--yellow-bg)}.overall-score.bad{border-color:var(--red);color:var(--red);background:var(--red-bg)}.report-header-text{flex:1}.report-filename{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.report-diagnosis{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.pillars{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.5rem}.pillar{padding:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px}.pillar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.pillar-label{font-weight:600;font-size:.85rem}.pillar-rating{font-weight:700;font-size:.8rem;padding:.15rem .5rem;border-radius:4px}.pillar-rating.good{background:var(--green-bg);color:var(--green)}.pillar-rating.ok{background:var(--yellow-bg);color:var(--yellow)}.pillar-rating.bad{background:var(--red-bg);color:var(--red)}.pillar-verdict{font-size:.82rem;color:var(--text-secondary);margin-bottom:.4rem;line-height:1.5}.pillar-fix{font-size:.8rem;color:var(--accent);line-height:1.4}.report-section{margin-bottom:1.25rem}.report-section-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.6rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}.working-list{list-style:none}.working-list li{font-size:.85rem;color:var(--text-secondary);padding:.4rem 0 .4rem 1.2rem;position:relative}.working-list li:before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:700}.improvement{padding:.75rem;margin-bottom:.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:6px}.improvement-where{font-size:.8rem;font-weight:600;color:var(--accent);margin-bottom:.2rem}.improvement-what{font-size:.85rem;color:var(--text-primary);margin-bottom:.2rem}.improvement-why{font-size:.8rem;color:var(--text-muted);font-style:italic}.exercise-text{font-size:.85rem;color:var(--text-secondary);padding:.75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;line-height:1.5}.genre-text{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.confidence-box{padding:.75rem;background:var(--yellow-bg);border:1px solid rgba(251,191,36,.2);border-radius:6px;font-size:.82rem;color:var(--yellow);line-height:1.5}.analysis-details{padding:.75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;margin-bottom:1.5rem}.analysis-details-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem}.analysis-stat{text-align:center}.analysis-stat-value{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.analysis-stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}@media(max-width:768px){.app-layout{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--border);max-height:200px}.main-content{padding:1.5rem}.pillars{grid-template-columns:1fr}}
