:root{--violet: #5B21B6;--violet-light: #8B5CF6;--violet-dark: #3B0764;--pink: #9D174D;--pink-light: #EC4899;--pink-dark: #831843;--amber: #D97706;--amber-light: #FDE68A;--amber-dark: #92400E;--teal: #0F766E;--teal-light: #5EEAD4;--emerald: #059669;--emerald-light: #A7F3D0;--rose: #DC2626;--rose-light: #FECACA;--sky: #2563EB;--sky-light: #BFDBFE;--bg: #F5F5F7;--surface: #FFFFFF;--surface-2: #F9F9FB;--border: rgba(0,0,0,.1);--border-soft: rgba(0,0,0,.06);--text-primary: #1A1A2E;--text-secondary: #5A5040;--text-muted: #9A9080;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 1px 3px rgba(0,0,0,.05);--shadow-lg: 0 8px 24px rgba(0,0,0,.1), 0 2px 6px rgba(0,0,0,.06);--shadow-glow-v: 0 4px 14px rgba(91,33,182,.28);--shadow-glow-p: 0 4px 14px rgba(157,23,77,.25);--shadow-glow-t: 0 4px 14px rgba(15,118,110,.25);--shadow-glow-a: 0 4px 14px rgba(217,119,6,.25);--nb-desk: #D4C9B0;--nb-paper: #FAF7F0;--nb-ink: #1A1A2E;--nb-staff: rgba(200,192,176,.28);--nb-correction: #B91C1C;--nb-tab-bg: #E2D9C5;--nb-spine: rgba(200,192,176,.55);--font-handwritten: "Caveat", cursive;--font-editorial: "Libre Baskerville", Georgia, serif}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.7}}@keyframes bounce{0%,to{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes nbPageEnter{0%{opacity:0;transform:translate(28px)}to{opacity:1;transform:translate(0)}}@keyframes nbPageLeave{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-20px)}}.nb-tab-content{display:flex;flex:1;min-width:0;position:relative;z-index:2;animation:nbPageEnter .28s cubic-bezier(.22,.8,.3,1) both}.nb-tab-content--leaving{animation:nbPageLeave .18s ease both;pointer-events:none}*,*:before,*:after{box-sizing:border-box}body{font-family:var(--font-editorial);background:var(--nb-desk);color:var(--nb-ink);margin:0;line-height:1.5;font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.desk-bg{min-height:100vh;background:radial-gradient(ellipse at 20% 20%,rgba(160,90,30,.3) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(50,20,5,.4) 0%,transparent 50%),radial-gradient(ellipse at 55% 40%,rgba(120,65,20,.18) 0%,transparent 45%),linear-gradient(155deg,#5a3018,#3d200e 40%,#4a2910 65%,#3a1d0c);display:flex;align-items:flex-start;justify-content:center;padding:3rem 5rem 5rem 2rem;overflow-x:hidden}.notebook{position:relative;display:flex;width:100%;max-width:1440px;min-height:calc(100vh - 8rem);box-shadow:0 60px 120px -20px #000000d9,0 30px 60px -10px #0009,0 8px 24px #0006,inset 0 0 0 1px #ffffff0f;border-radius:14px}.nb-page{position:relative;flex:1;background-color:var(--nb-paper);padding:2.5rem 2.5rem 3rem;background-image:linear-gradient(var(--nb-staff) 1px,transparent 1px);background-size:100% 1.5rem;overflow-y:auto}.nb-page--left{flex:0 0 36%;border-radius:14px 0 0 14px;border-right:1px solid rgba(0,0,0,.07);display:flex;flex-direction:column}.nb-page--left:after{content:"";position:absolute;top:0;right:0;bottom:0;width:40px;background:linear-gradient(to right,transparent,rgba(200,192,176,.45));pointer-events:none;z-index:1}.nb-page--right{flex:0 0 64%;border-radius:0 14px 14px 0}.nb-page--right:before{content:"";position:absolute;top:0;left:0;bottom:0;width:40px;background:linear-gradient(to left,transparent,rgba(200,192,176,.45));pointer-events:none;z-index:1}.nb-page--nav{display:flex;flex-direction:column}.nb-page--full-content{overflow-y:auto}.nb-tab{position:absolute;right:-52px;width:60px;height:150px;background-color:var(--nb-tab-bg);writing-mode:vertical-rl;text-orientation:mixed;display:flex;align-items:center;justify-content:center;font-family:var(--font-editorial);font-size:.65rem;font-weight:400;text-transform:uppercase;letter-spacing:.12em;border-radius:0 8px 8px 0;box-shadow:2px 1px 6px #0000001c;cursor:pointer;color:#ffffffeb;transition:transform .18s ease,filter .18s ease,box-shadow .18s ease;z-index:1;-webkit-user-select:none;user-select:none}.nb-tab:hover:not(.active){transform:translate(5px);filter:brightness(1.18);box-shadow:4px 2px 12px #00000059}.nb-tab.active{background:var(--nb-paper)!important;right:-47px;font-weight:700;color:var(--nb-ink);transform:none;filter:none;box-shadow:3px 0 10px #00000021}.nb-tab-1{top:30px;background:#1d4ed8}.nb-tab-2{top:190px;background:#b91c1c}.nb-tab-3{top:350px;background:#b45309}.nb-tab-4{top:510px;background:#047857}.nb-header{display:flex;align-items:center;gap:12px;margin-bottom:2rem}.nb-clef{font-size:2.6rem;line-height:1;color:var(--nb-ink);opacity:.8}.nb-title{font-family:var(--font-handwritten);font-size:2.5rem;font-weight:700;color:var(--nb-ink);margin:0;line-height:1.1;position:relative}.nb-title:after{content:"";position:absolute;bottom:-5px;left:0;width:100%;height:8px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 20' preserveAspectRatio='none'%3E%3Cpath d='M0 10 Q 25 20 50 10 T 100 10' stroke='%23B91C1C' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-size:100% 100%}.nb-meta{font-family:var(--font-handwritten);font-size:1.3rem;display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem;color:var(--nb-ink)}.nb-meta-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.nb-input{font-family:var(--font-handwritten);font-size:1.25rem;background:transparent;border:none;border-bottom:2px solid var(--nb-ink);padding:1px 8px;color:var(--nb-ink);outline:none;transform:rotate(-.4deg);transition:border-color .2s}.nb-input:focus{border-bottom-color:var(--nb-correction)}.nb-input--short{width:3.5rem;text-align:center}.nb-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:24px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%231A1A2E'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;background-size:8px}.nb-placeholder-text{color:#1a1a2e59;font-style:italic;font-size:1rem}.nb-stamp-row{display:flex;justify-content:center;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid rgba(200,192,176,.55)}.nb-stamp{background:transparent;border:3px solid var(--nb-correction);color:var(--nb-correction);font-family:var(--font-handwritten);font-weight:700;font-size:1.65rem;padding:.45rem 2rem;transform:rotate(-3deg);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;text-transform:uppercase;letter-spacing:.08em;line-height:1}.nb-stamp:hover:not(:disabled){transform:rotate(-3deg) scale(1.07);box-shadow:3px 3px #b91c1c38}.nb-stamp:disabled{opacity:.32;cursor:not-allowed}.nb-results-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;padding-bottom:.5rem}.nb-results-title{font-family:var(--font-editorial);font-style:italic;font-size:.88rem;color:#1a1a2e80;margin:0;font-weight:400}.nb-grade{font-family:var(--font-handwritten);font-size:2rem;color:var(--nb-correction);line-height:1}.nb-score-area{position:relative;margin-bottom:.75rem}.nb-score-placeholder{padding:2rem 0 2.5rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem;border-top:1px solid rgba(200,192,176,.4);border-bottom:1px solid rgba(200,192,176,.4)}.nb-staff-lines{display:flex;flex-direction:column;gap:7px;opacity:.4}.nb-staff-line{width:15rem;height:1px;background:var(--nb-ink)}.nb-score-placeholder p{font-family:var(--font-editorial);font-style:italic;font-size:.82rem;color:#1a1a2e73;text-align:center;margin:0;padding:0 2rem}.nb-error-annotations{margin-top:.75rem;border-top:1px dashed rgba(200,192,176,.55);padding-top:.75rem}.nb-download-row{display:flex;justify-content:flex-end;margin-top:.5rem}.nb-footnote{margin-top:auto;padding-top:1.5rem;font-style:italic;font-size:.7rem;color:#1a1a2e47;text-align:center}.nb-section-desc{margin-top:2rem;padding:1.5rem;border:1px dashed rgba(200,192,176,.6);display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem}.nb-section-icon{font-size:2.2rem;opacity:.65}.nb-section-title{font-family:var(--font-handwritten);font-size:1.5rem;color:var(--nb-ink);margin:0;font-weight:700}.nb-section-text{font-family:var(--font-editorial);font-style:italic;font-size:.82rem;color:#1a1a2e8c;margin:0;line-height:1.65}.nb-page--right .score-panel{background:transparent;border:none;box-shadow:none;border-radius:0;overflow:visible}.nb-page--right .score-panel-header{background:transparent;border-bottom:1px solid rgba(200,192,176,.5);padding:0 0 8px}.nb-page--right .score-panel-header h2{font-family:var(--font-editorial);font-style:italic;font-weight:400;color:#1a1a2e80}.nb-page--right .score-tabs{background:#c8c0b02e;border-radius:6px}.nb-page--right .score-tab{color:#1a1a2e99}.nb-page--right .score-tab:hover{background:#c8c0b040;color:var(--nb-ink)}.nb-page--right .score-tab.active{background:#c8c0b059;color:var(--nb-ink);font-weight:600;box-shadow:none}.nb-page--right .error-panel{background:transparent;border:none;box-shadow:none;border-radius:0}.nb-page--right .error-panel-header{background:transparent;border-bottom:1px solid rgba(200,192,176,.5);font-family:var(--font-editorial);font-style:italic;font-weight:400;color:#1a1a2e8c;font-size:.8rem}.nb-page--right .error-description{font-family:var(--font-handwritten);font-size:1rem;color:var(--nb-correction)}.nb-page--right .error-meta{color:#1a1a2e73}.nb-page--right .summary-box.correct{background:transparent;border:2px solid #4A7A4A;color:#2a4a2a;font-family:var(--font-handwritten);font-size:1rem}.nb-page--right .summary-box.incorrect{background:transparent;border:2px solid var(--nb-correction);color:var(--nb-correction);font-family:var(--font-handwritten);font-size:1rem}.nb-page--left .file-upload-wrapper{flex:0 0 auto}.nb-page--left .file-upload-label{font-family:var(--font-handwritten);font-size:1rem;font-weight:400;letter-spacing:.01em;text-transform:none;color:#1a1a2e80;margin-bottom:.2rem}.nb-page--left .file-upload-dropzone{border-color:var(--nb-correction);border-style:dashed;border-width:2px;background:transparent;min-height:120px}.nb-page--left .file-upload-dropzone:hover{background:#b91c1c06;border-color:var(--nb-correction);box-shadow:none;transform:none}.nb-page--left .file-upload-dropzone.drag-over{background:#b91c1c0d;border-color:var(--nb-correction);box-shadow:none}.nb-page--left .file-upload-dropzone.has-file{border-color:#4a7a4a;background:#4a7a4a06}.nb-page--left .file-upload-content p{font-family:var(--font-editorial);font-style:italic;font-size:.8rem;color:#1a1a2e73}.nb-page--full-content .theory-layout{min-height:unset;height:auto}.nb-page--full-content .theory-section{animation:none}.nb-page--full-content .theory-sidebar{position:relative;max-height:unset;top:0}.nb-page--theory-nav{display:flex;flex-direction:column;overflow:hidden}.nb-page--theory-nav .nb-footnote{margin-top:auto}.theory-sidebar--page{flex:1 1 0;overflow-y:auto;border:none;border-radius:0;background:transparent;background-image:repeating-linear-gradient(to bottom,transparent,transparent 27px,rgba(92,74,58,.08) 27px,rgba(92,74,58,.08) 28px);padding:0 4px;margin-top:10px;position:static;max-height:unset;top:unset}.theory-main--full{padding:28px 38px 52px;max-width:100%;background:var(--nb-paper);overflow-y:auto;height:100%;box-sizing:border-box}.nb-page--full-content .theory-section{height:100%;display:flex;flex-direction:column}.nb-page--full-content .theory-main--full{flex:1 1 0}.nb-page--left .file-upload-button{background:transparent;color:var(--nb-correction);border:2px solid var(--nb-correction);font-family:var(--font-handwritten);font-size:1rem;font-weight:700;padding:5px 16px;border-radius:3px;box-shadow:none;letter-spacing:.04em;transition:transform .1s ease,box-shadow .1s ease}.nb-page--left .file-upload-button:hover{background:#b91c1c0d;box-shadow:2px 2px #b91c1c33;transform:translateY(-1px)}.nb-page--left .file-upload-button:active{transform:translateY(0)}.nb-page--left .file-upload-text strong{font-family:var(--font-editorial);font-weight:700;font-size:.88rem;color:#1a1a2e99}.nb-page--left .file-upload-icon{font-size:2rem;opacity:.45}.nb-page--left .file-upload-hint{font-family:var(--font-editorial);font-style:italic;font-size:.72rem;color:#1a1a2e66}.nb-page--left .file-upload-or{color:#1a1a2e59;font-size:.78rem}.nb-page--left .file-upload-filename{font-family:var(--font-handwritten);font-size:1.05rem;color:var(--nb-ink);font-weight:700}.nb-page--left .file-upload-subtext{font-family:var(--font-editorial);font-style:italic;font-size:.75rem;color:#1a1a2e73}.nb-page--right .error-dot.error{background:var(--nb-correction)}.nb-page--right .error-dot.warning{background:#c47a0c}.nb-page--right .error-dot.info{background:#2563eb}.nb-page--right .error-voice-badge{background:#b91c1c1a;color:var(--nb-correction);font-family:var(--font-handwritten);font-size:.8rem}.nb-key-badge{font-family:var(--font-handwritten);font-size:1.1rem;color:var(--nb-correction);font-weight:700}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#d4c9b0b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;gap:18px}.spinner{width:48px;height:48px;border:4px solid rgba(26,26,46,.15);border-top-color:var(--nb-correction);border-radius:50%;animation:spin .8s linear infinite}.loading-text{font-family:var(--font-handwritten);font-size:1.4rem;font-weight:700;color:var(--nb-ink);animation:shimmer 1.4s ease-in-out infinite}.alert{margin:.75rem 0 0;padding:10px 16px;border-radius:var(--radius-md);font-size:.88rem;font-weight:500;animation:fadeSlideIn .3s ease}.alert-error{background:#b91c1c12;border:1.5px solid rgba(185,28,28,.3);color:var(--nb-correction);font-family:var(--font-handwritten);font-size:1rem}.controls-bar{display:flex;align-items:flex-end;gap:14px;padding:14px 20px;background:#ffffffd1;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);flex-wrap:wrap;animation:fadeSlideIn .25s ease}.control-group{display:flex;flex-direction:column;gap:5px}.control-group label{font-size:.67rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.control-group select,.control-group input[type=text],.control-group input[type=number]{padding:9px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:.9rem;background:var(--bg);color:var(--text-primary);transition:border-color .2s,box-shadow .2s;outline:none}.control-group select:focus,.control-group input:focus{border-color:var(--violet);box-shadow:0 0 0 3px #7c3aed1f}.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;border:none;border-radius:10px;font-family:inherit;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .18s ease;white-space:nowrap;letter-spacing:.01em}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn:not(:disabled):hover{transform:translateY(-1px)}.btn:not(:disabled):active{transform:translateY(0)}.btn-primary{background:var(--violet-light);color:#fff;box-shadow:0 1px 3px #5b21b640}.btn-primary:not(:disabled):hover{background:var(--violet);box-shadow:var(--shadow-glow-v)}.btn-parse{background:var(--teal);color:#fff;box-shadow:0 1px 3px #0f766e40}.btn-parse:not(:disabled):hover{box-shadow:var(--shadow-glow-t)}.btn-secondary{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:not(:disabled):hover{background:var(--surface-2);color:var(--text-primary);border-color:#0000002e;box-shadow:var(--shadow-md)}.main-content{display:grid;grid-template-columns:1fr 360px;gap:16px;padding:16px;align-items:start;animation:tabFadeIn .3s ease}.score-panel{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;border:1px solid var(--border)}.score-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-soft);background:var(--surface-2);gap:12px;flex-wrap:wrap}.score-panel-header h2{margin:0;font-size:.875rem;font-weight:600;color:var(--text-secondary)}.score-tabs{display:flex;gap:2px;background:#00000012;padding:3px;border-radius:8px}.score-tab{padding:5px 14px;border:none;border-radius:6px;font-family:inherit;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s ease;background:transparent;color:var(--text-secondary)}.score-tab:hover{background:#0000000d;color:var(--text-primary)}.score-tab.active{background:var(--surface);color:var(--text-primary);font-weight:600;box-shadow:var(--shadow-sm)}.key-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;background:linear-gradient(135deg,#ede9fe,#fce7f3);border-radius:50px;font-size:.8rem;font-weight:700;color:var(--violet-dark);border:1.5px solid var(--violet-light);white-space:nowrap}.score-container{min-height:260px;padding:12px;position:relative}.score-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:240px;gap:12px;color:var(--text-muted);font-size:.95rem;font-weight:500}.score-placeholder:before{content:"🎼";font-size:3.5rem;opacity:.4;animation:shimmer 2.5s ease-in-out infinite}.file-upload-wrapper{display:flex;flex-direction:column;gap:5px}.file-upload-label{font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary)}.file-upload-box{display:flex;align-items:center;gap:10px;padding:9px 14px;border:2px dashed var(--violet-light);border-radius:var(--radius-sm);background:#f5f3ff;cursor:pointer;transition:all .2s ease;min-width:200px}.file-upload-box:hover{border-color:var(--violet);background:#ede9fe;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.file-upload-box input[type=file]{display:none}.file-upload-box .file-icon{font-size:1.2rem}.file-upload-box .file-name{font-size:.85rem;font-weight:600;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.file-upload-box .file-name.selected{color:var(--violet-dark)}.error-panel{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border);overflow:hidden;animation:fadeSlideIn .25s ease}.error-panel-header{padding:12px 16px;font-size:.82rem;font-weight:600;color:var(--text-secondary);background:var(--surface-2);border-bottom:1px solid var(--border-soft);display:flex;align-items:center;gap:8px}.summary-box{margin:14px;padding:16px 18px;border-radius:var(--radius-md);font-weight:600;display:flex;align-items:flex-start;gap:12px;font-size:.95rem;animation:fadeSlideIn .4s ease}.summary-box.correct{background:#f0fdf4;border:1px solid #BBF7D0;color:#14532d}.summary-box.incorrect{background:#fff1f2;border:1px solid #FECDD3;color:#881337}.summary-icon{font-size:1.8rem}.summary-title{font-size:1rem;font-weight:800}.summary-counts{margin-top:4px;font-size:.82rem;font-weight:500;opacity:.8}.error-list{padding:8px 14px 14px;display:flex;flex-direction:column;gap:8px;max-height:480px;overflow-y:auto}.error-measure-group{animation:slideInLeft .3s ease both}.error-measure-label{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);padding:8px 4px 4px;border-bottom:1.5px solid var(--border-soft);margin-bottom:4px}.error-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);transition:background .15s ease;cursor:default}.error-item:hover{background:var(--bg)}.error-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:5px}.error-dot.error{background:var(--rose)}.error-dot.warning{background:var(--amber)}.error-dot.info{background:var(--sky)}.error-text{flex:1}.error-description{font-size:.87rem;font-weight:600;color:var(--text-primary);line-height:1.4}.error-meta{font-size:.76rem;color:var(--text-muted);margin-top:3px;font-weight:500}.error-voices{display:inline-flex;gap:4px;flex-wrap:wrap;margin-top:4px}.error-voice-badge{padding:1px 8px;border-radius:50px;font-size:.7rem;font-weight:700;background:#ede9fe;color:var(--violet-dark)}.nh-toggle{display:flex;align-items:center;gap:8px;padding:10px 14px;margin:4px 14px 14px;border-radius:var(--radius-sm);background:#eff6ff;border:1.5px solid #BFDBFE;color:#1d4ed8;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s;border:none}.nh-toggle:hover{background:#dbeafe}.no-errors{padding:32px 20px;text-align:center;color:var(--text-muted);font-size:.9rem;font-weight:500}.rn-chip{position:absolute;display:flex;flex-direction:column;align-items:center;gap:2px;z-index:10}.rn-chip-label{font-family:Times New Roman,serif;font-size:.7rem;color:var(--text-muted);line-height:1}.rn-input{width:48px;padding:3px 4px;border:2px solid var(--border);border-radius:6px;font-family:Times New Roman,serif;font-size:.85rem;text-align:center;background:#ffffffe6;color:var(--text-primary);transition:border-color .15s,box-shadow .15s;outline:none}.rn-input:focus{border-color:var(--violet);box-shadow:0 0 0 3px #7c3aed26}.rn-input.correct{border-color:var(--emerald);background:#ecfdf5;color:#064e3b}.rn-input.incorrect{border-color:var(--rose);background:#fff1f2;color:#9b1c1c}.rn-correct-label{font-size:.65rem;color:var(--emerald);font-weight:700}.rn-incorrect-label{font-size:.65rem;color:var(--rose);font-weight:700}.feature-section{padding:28px;animation:tabFadeIn .3s ease;max-width:1100px;margin:0 auto;width:100%}.feature-section-header{margin-bottom:24px}.feature-section-header h2{font-size:1.7rem;font-weight:800;margin:0 0 8px;letter-spacing:-.02em}.feature-section-header p{color:var(--text-secondary);font-size:.97rem;margin:0}.feature-section.validator-section .feature-section-header h2{color:var(--teal)}.feature-section.generator-section .feature-section-header h2{color:var(--amber-dark)}.rn-val-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin:20px 0}.rn-val-stat{background:var(--surface);border-radius:var(--radius-md);padding:18px 16px;text-align:center;box-shadow:var(--shadow-sm);border:1.5px solid var(--border);transition:transform .2s,box-shadow .2s}.rn-val-stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.rn-val-stat .stat-value{font-size:2.2rem;font-weight:800;line-height:1;margin-bottom:4px}.rn-val-stat .stat-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.rn-val-stat.correct .stat-value{color:var(--emerald)}.rn-val-stat.incorrect .stat-value{color:var(--rose)}.rn-val-stat.missing .stat-value{color:var(--amber)}.rn-val-stat.total .stat-value{color:var(--violet)}.rn-val-table{width:100%;border-collapse:separate;border-spacing:0 6px;font-size:.88rem}.rn-val-table th{text-align:left;padding:8px 14px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.rn-val-row{animation:fadeSlideIn .3s ease both}.rn-val-row td{padding:11px 14px;background:var(--surface)}.rn-val-row td:first-child{border-left:4px solid transparent;border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.rn-val-row td:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.rn-val-row--correct td:first-child{border-left-color:var(--emerald)}.rn-val-row--incorrect td:first-child{border-left-color:var(--rose)}.rn-val-row--missing td:first-child{border-left-color:var(--amber)}.rn-val-row--correct td{background:#f0fdf4}.rn-val-row--incorrect td{background:#fff1f2}.rn-val-row--missing td{background:#fffbeb}.rn-val-icon{font-size:1.1rem}.rn-val-icon.correct{color:var(--emerald)}.rn-val-icon.incorrect{color:var(--rose)}.rn-val-icon.missing{color:var(--amber)}.rn-chip-auto{font-family:Times New Roman,serif;font-size:1rem;font-weight:600}.rn-chip-alt{display:inline-block;padding:2px 8px;background:#ede9fe;color:var(--violet-dark);border-radius:50px;font-size:.75rem;font-weight:700}.gen-results{margin-top:24px;animation:fadeSlideIn .35s ease}.gen-results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.gen-results-title{font-size:1.1rem;font-weight:800;color:var(--text-primary)}.gen-progressions{display:flex;flex-direction:column;gap:14px}.gen-prog-card{background:var(--surface);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-sm);border:1.5px solid var(--border);border-left:5px solid var(--amber);transition:all .2s ease;cursor:pointer;animation:fadeSlideIn .35s ease both}.gen-prog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-glow-a);border-left-color:var(--amber-dark)}.gen-prog-card.selected{border-color:var(--amber-dark);background:linear-gradient(135deg,#fff8e7,#fffbf0);box-shadow:var(--shadow-glow-a)}.gen-chord-sequence{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}.gen-chord-pill{display:flex;flex-direction:column;align-items:center;gap:3px}.gen-chord-rn{padding:8px 16px;border-radius:50px;font-family:Times New Roman,serif;font-size:1rem;font-weight:700;transition:transform .15s;cursor:default}.gen-chord-rn:hover{transform:scale(1.08)}.gen-chord-rn.tonic{background:#ede9fe;color:var(--violet-dark);border:2px solid var(--violet-light)}.gen-chord-rn.dominant{background:#ffe4e6;color:var(--pink-dark);border:2px solid var(--pink-light)}.gen-chord-rn.subdominant{background:#d1fae5;color:#065f46;border:2px solid var(--emerald-light)}.gen-chord-rn.default{background:var(--bg);color:var(--text-secondary);border:2px solid var(--border)}.gen-chord-label{font-size:.68rem;font-weight:600;color:var(--text-muted);text-align:center}.gen-chord-arrow{color:var(--text-muted);font-size:1rem;margin-top:-4px}.gen-prog-description{font-size:.85rem;color:var(--text-secondary);font-weight:500}.gen-prog-cadence{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;background:#fef3c7;border-radius:50px;font-size:.75rem;font-weight:700;color:var(--amber-dark);margin-top:8px;border:1.5px solid var(--amber-light)}.chord-picker{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.chord-pick-btn{padding:5px 12px;border-radius:50px;border:2px solid var(--border);background:var(--bg);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:Times New Roman,serif}.chord-pick-btn:hover{border-color:var(--amber);background:#fef3c7}.chord-pick-btn.selected{background:var(--amber);border-color:var(--amber-dark);color:#fff}.theory-section{--th-ink: #2B1D0E;--th-ink2: #5A4A3A;--th-red: #B91C1C;--th-amber: #92400E;--th-green: #065F46;--th-line: rgba(140,120,90,.18);animation:tabFadeIn .3s ease;flex:1}.theory-layout{display:grid;grid-template-columns:248px 1fr;min-height:100vh;height:100vh}.theory-sidebar{background:var(--nb-paper);background-image:repeating-linear-gradient(transparent,transparent 27px,rgba(140,120,90,.1) 27px,rgba(140,120,90,.1) 28px);border-right:1px solid rgba(140,120,90,.22);padding:16px 10px;overflow-y:auto;position:sticky;top:0;max-height:100vh}.theory-sidebar-header{padding:0 8px 12px;margin-bottom:8px;border-bottom:1.5px solid rgba(140,120,90,.28)}.theory-sidebar-title{font-family:var(--font-handwritten);font-size:1.2rem;font-weight:700;color:var(--th-ink)}.theory-module-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1px}.theory-module-item{border-radius:2px}.theory-module-btn{width:100%;display:flex;align-items:center;gap:8px;padding:9px 10px;border:none;border-left:3px solid transparent;border-radius:0 3px 3px 0;background:transparent;text-align:left;cursor:pointer;transition:all .18s ease;font-family:var(--font-handwritten);color:var(--th-ink2);font-size:.95rem;font-weight:600;margin-bottom:1px}.theory-module-btn:hover{background:#8c785a1a;border-left-color:var(--th-amber);color:var(--th-ink)}.theory-module-btn--active{background:#b91c1c12!important;border-left-color:var(--th-red)!important;color:var(--th-ink)!important}.theory-mod-icon{font-size:1rem;flex-shrink:0;opacity:.75}.theory-mod-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.theory-mod-number{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--th-amber);font-family:var(--font-editorial)}.theory-mod-title{font-size:.88rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.theory-mod-level{font-size:.58rem;font-weight:700;padding:1px 5px;border-radius:2px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border:1.5px solid currentColor;font-family:var(--font-editorial);opacity:.65;flex-shrink:0}.theory-mod-level--beginner{color:var(--th-green)}.theory-mod-level--elementary{color:#1e3a8a}.theory-mod-level--intermediate{color:var(--th-amber)}.theory-mod-level--advanced{color:var(--th-red)}.theory-mod-progress{height:2px;background:#8c785a2e;border-radius:50px;margin:2px 10px 5px;overflow:hidden}.theory-mod-progress-fill{height:100%;background:var(--th-amber);border-radius:50px;transition:width .5s ease}.theory-lesson-list{margin:2px 0 5px 20px;display:flex;flex-direction:column;gap:0;list-style:none;padding:0;border-left:1.5px dashed rgba(140,120,90,.32)}.theory-lesson-btn{padding:6px 10px 6px 12px;border:none;border-radius:0 3px 3px 0;background:transparent;text-align:left;cursor:pointer;font-family:var(--font-editorial);font-size:.78rem;font-weight:400;font-style:italic;color:var(--th-ink2);transition:all .15s;display:flex;align-items:baseline;gap:6px;width:100%;line-height:1.35}.theory-lesson-btn:hover{background:#b91c1c0d;color:var(--th-red)}.theory-lesson-btn--active{color:var(--th-red);font-weight:700;font-style:normal;background:#b91c1c12}.theory-lesson-btn--visited .theory-lesson-name:before{content:"✓ ";color:var(--th-green);font-style:normal}.theory-lesson-number{font-size:.68rem;font-family:var(--font-handwritten);color:var(--th-amber);flex-shrink:0;font-style:normal}.theory-lesson-name{flex:1;min-width:0}.theory-lesson-ex-badge{font-size:.6rem;font-weight:700;font-style:normal;padding:1px 4px;border-radius:2px;border:1px solid rgba(140,120,90,.3);color:var(--th-ink2);background:#8c785a0f;white-space:nowrap;font-family:var(--font-editorial);flex-shrink:0}.theory-lesson-ex-badge--done{border-color:var(--th-green);color:var(--th-green);background:#065f460d}.theory-sidebar-toggle{display:none}.theory-main{padding:28px 38px 52px;max-width:820px;background:var(--nb-paper);background-image:repeating-linear-gradient(transparent,transparent 31px,rgba(140,120,90,.09) 31px,rgba(140,120,90,.09) 32px);overflow-y:auto}.theory-lesson-header{margin-bottom:32px;padding-bottom:18px;border-bottom:1.5px solid rgba(140,120,90,.22)}.theory-lesson-module-label{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border:1.5px solid var(--th-amber);color:var(--th-amber);border-radius:2px;font-size:.68rem;font-weight:700;margin-bottom:12px;font-family:var(--font-editorial);text-transform:uppercase;letter-spacing:.07em}.theory-lesson-title{font-family:var(--font-handwritten);font-size:2.1rem;font-weight:700;color:var(--th-ink);margin:0 0 10px;line-height:1.15;text-decoration:underline;text-decoration-color:var(--th-red);text-decoration-thickness:2px;text-underline-offset:6px}.theory-lesson-time{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-editorial);font-size:.75rem;color:var(--th-ink2);font-style:italic}.theory-lesson-body{display:flex;flex-direction:column;gap:18px}.theory-h2{font-family:var(--font-handwritten);font-size:1.55rem;font-weight:700;color:var(--th-ink);margin:12px 0 4px;padding-bottom:3px;border-bottom:2px solid var(--th-red);display:inline-block}.theory-h3{font-family:var(--font-editorial);font-size:.98rem;font-weight:700;font-style:italic;color:var(--th-amber);margin:8px 0 2px}.theory-text{font-family:var(--font-editorial);font-size:.93rem;color:var(--th-ink2);line-height:1.82}.theory-text strong{color:var(--th-ink);font-weight:700}.theory-definition{display:flex;gap:14px;padding:13px 18px;background:#92400e0d;border-left:3px solid var(--th-amber);border-radius:0 3px 3px 0}.theory-definition-term{font-family:var(--font-handwritten);font-weight:700;color:var(--th-amber);min-width:95px;font-size:1rem;flex-shrink:0}.theory-definition-body{font-family:var(--font-editorial);font-size:.9rem;color:var(--th-ink2);line-height:1.65;font-style:italic}.theory-tip{display:flex;flex-direction:column;gap:5px;padding:13px 18px;border-radius:0 3px 3px 0;font-family:var(--font-editorial);font-size:.9rem;line-height:1.7;animation:fadeSlideIn .3s ease}.theory-tip-title{font-family:var(--font-handwritten);font-size:1rem;font-weight:700;margin-bottom:2px}.theory-tip--tip{background:#5b21b60d;border-left:3px solid #7C3AED;color:#3b0764}.theory-tip--info{background:#2563eb0d;border-left:3px solid #2563EB;color:#1e3a8a}.theory-tip--warning{background:#92400e12;border-left:3px solid var(--th-amber);color:var(--th-amber)}.theory-tip--example{background:#065f460d;border-left:3px solid #059669;color:var(--th-green)}.theory-list{display:flex;flex-direction:column;gap:8px;padding-left:4px;list-style:none;margin:0}.theory-list li{display:flex;align-items:flex-start;gap:10px;font-family:var(--font-editorial);font-size:.93rem;color:var(--th-ink2);line-height:1.62}.theory-list li:before{content:"♪";color:var(--th-amber);flex-shrink:0;margin-top:1px;font-size:.85rem}.theory-table-wrap{margin:0}.theory-table-scroll{overflow-x:auto}.theory-table{width:100%;border-collapse:collapse;font-family:var(--font-editorial);font-size:.85rem;border:1.5px solid rgba(140,120,90,.35)}.theory-table th{background:#8c785a24;color:var(--th-ink);padding:9px 14px;text-align:left;font-weight:700;font-size:.77rem;letter-spacing:.05em;text-transform:uppercase;border-bottom:2px solid rgba(140,120,90,.38)}.theory-table td{padding:9px 14px;border-bottom:1px solid rgba(140,120,90,.16);color:var(--th-ink2)}.theory-table tr:nth-child(2n) td{background:#8c785a0a}.theory-table tr:last-child td{border-bottom:none}.theory-table tr:hover td{background:#b91c1c0a;transition:background .15s}.theory-table-caption{font-family:var(--font-editorial);font-size:.78rem;font-style:italic;color:var(--th-ink2);margin-top:6px;text-align:center}.theory-score-example{background:var(--nb-paper);border:1.5px solid rgba(140,120,90,.32);border-radius:3px;overflow:hidden}.theory-score-title{padding:8px 14px;background:#8c785a17;font-family:var(--font-handwritten);font-size:1rem;color:var(--th-ink);border-bottom:1px solid rgba(140,120,90,.22)}.theory-score-caption{padding:6px 14px;font-family:var(--font-editorial);font-size:.78rem;color:var(--th-ink2);border-top:1px solid rgba(140,120,90,.14);font-style:italic}.exercise-card{background:var(--nb-paper);border-radius:3px;padding:20px;border:1.5px solid rgba(140,120,90,.28);transition:border-color .2s;animation:fadeSlideIn .35s ease;position:relative}.exercise-card:before{content:"";position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 18px 18px 0;border-color:transparent rgba(140,120,90,.22) transparent transparent}.exercise-card--correct{border-color:#065f4661}.exercise-card--incorrect{border-color:#b91c1c52}.exercise-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.exercise-icon{font-size:1.1rem}.exercise-difficulty{font-family:var(--font-editorial);font-size:.63rem;font-weight:700;padding:2px 6px;border-radius:2px;border:1px solid currentColor;text-transform:uppercase;letter-spacing:.05em}.exercise-difficulty--beginner{color:var(--th-green)}.exercise-difficulty--intermediate{color:var(--th-amber)}.exercise-difficulty--advanced{color:var(--th-red)}.exercise-question{font-family:var(--font-handwritten);font-size:1.08rem;font-weight:700;color:var(--th-ink);line-height:1.5;margin-bottom:16px}.exercise-options{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}.exercise-option{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:3px;border:1.5px solid rgba(140,120,90,.28);background:transparent;cursor:pointer;transition:all .15s ease;font-family:var(--font-editorial);font-size:.88rem;color:var(--th-ink2);width:100%;text-align:left}.exercise-option:hover:not([class*=correct]):not([class*=wrong]){border-color:var(--th-amber);background:#92400e0d;transform:translate(3px)}.exercise-option--selected{border-color:var(--th-ink);background:#2b1d0e0a}.exercise-option--correct{border-color:#065f468c;background:#065f460d;color:var(--th-green)}.exercise-option--wrong{border-color:#b91c1c7a;background:#b91c1c0d;color:var(--th-red)}.exercise-option-marker{width:22px;height:22px;border-radius:50%;border:1.5px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;flex-shrink:0;font-family:var(--font-editorial)}.exercise-option--selected .exercise-option-marker{background:var(--th-ink);color:var(--nb-paper);border-color:var(--th-ink)}.exercise-option--correct .exercise-option-marker{background:#059669;color:#fff;border-color:#059669}.exercise-option--wrong .exercise-option-marker{background:var(--th-red);color:#fff;border-color:var(--th-red)}.exercise-text-input{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.exercise-text-input input{width:100%;padding:9px 13px;border:1.5px solid rgba(140,120,90,.35);border-radius:3px;font-family:var(--font-handwritten);font-size:1rem;color:var(--th-ink);background:transparent;outline:none;transition:border-color .15s;box-sizing:border-box}.exercise-text-input input:focus{border-color:var(--th-amber)}.exercise-text-input input.text-input--correct{border-color:#059669}.exercise-text-input input.text-input--wrong{border-color:var(--th-red)}.exercise-actions{display:flex;gap:8px}.btn-exercise-submit{background:var(--th-ink);color:var(--nb-paper);padding:8px 22px;border:none;border-radius:3px;font-family:var(--font-handwritten);font-size:1rem;font-weight:700;cursor:pointer;transition:all .18s;letter-spacing:.02em}.btn-exercise-submit:hover:not(:disabled){background:var(--th-red)}.btn-exercise-submit:disabled{opacity:.35;cursor:not-allowed}.btn-exercise-reset{background:transparent;border:1.5px solid rgba(140,120,90,.38);border-radius:3px;padding:8px 16px;font-family:var(--font-editorial);font-size:.85rem;font-weight:600;cursor:pointer;color:var(--th-ink2);transition:all .15s}.btn-exercise-reset:hover{border-color:var(--th-amber);color:var(--th-amber)}.exercise-explanation{margin-top:14px;padding:12px 16px;border-radius:0 3px 3px 0;font-family:var(--font-editorial);font-size:.88rem;line-height:1.65;animation:fadeSlideIn .3s ease}.exercise-explanation--correct{background:#065f4612;border-left:3px solid #059669;color:var(--th-green)}.exercise-explanation--incorrect{background:#b91c1c0d;border-left:3px solid var(--th-red);color:#7f1d1d}.exercise-mastered{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border:1.5px solid var(--th-green);color:var(--th-green);border-radius:2px;font-size:.75rem;font-weight:700;margin-top:12px;font-family:var(--font-editorial);text-transform:uppercase;letter-spacing:.05em}.theory-lesson-footer{display:flex;align-items:center;justify-content:space-between;margin-top:44px;padding-top:18px;border-top:1.5px solid rgba(140,120,90,.22);gap:12px}.btn-lesson-nav{display:flex;align-items:center;gap:8px;padding:9px 20px;border:1.5px solid rgba(140,120,90,.35);border-radius:3px;background:transparent;font-family:var(--font-handwritten);font-size:1rem;font-weight:700;cursor:pointer;transition:all .18s;color:var(--th-ink2);letter-spacing:.02em}.btn-lesson-nav:hover{border-color:var(--th-red);color:var(--th-red);transform:translateY(-1px)}.theory-empty{padding:48px;font-family:var(--font-editorial);font-style:italic;color:var(--th-ink2);text-align:center}.chip-correct{display:inline-block;padding:2px 9px;border-radius:50px;background:#ecfdf5;color:#065f46;border:1.5px solid var(--emerald-light);font-size:.78rem;font-weight:700}.chip-incorrect{display:inline-block;padding:2px 9px;border-radius:50px;background:#fff1f2;color:#9b1c1c;border:1.5px solid var(--rose-light);font-size:.78rem;font-weight:700}.chip-missing{display:inline-block;padding:2px 9px;border-radius:50px;background:#fffbeb;color:#92400e;border:1.5px solid var(--amber-light);font-size:.78rem;font-weight:700}.file-upload-wrapper{display:flex;flex-direction:column;gap:8px}.file-upload-label{font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.file-upload-dropzone{display:flex;align-items:center;justify-content:center;min-height:140px;border:2px dashed var(--border);border-radius:var(--radius-md);background:var(--surface);transition:all .2s ease;cursor:pointer;padding:24px 20px;position:relative}.file-upload-dropzone:hover{border-color:var(--violet-light);background:var(--surface-2);box-shadow:var(--shadow-sm)}.file-upload-dropzone.drag-over{border-color:var(--violet-light);background:linear-gradient(135deg,#8b5cf60d,#9d174d08);box-shadow:inset 0 0 0 1px var(--violet-light),var(--shadow-md);transform:scale(1.01)}.file-upload-dropzone.has-file{border-color:var(--emerald);background:linear-gradient(135deg,#0596690a,#05966905)}.file-upload-content{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;width:100%}.file-upload-icon{font-size:2.8rem;opacity:.7;transition:all .2s ease}.file-upload-dropzone.drag-over .file-upload-icon{font-size:3.2rem;opacity:1;transform:scale(1.15)}.file-upload-dropzone.has-file .file-upload-icon{font-size:2rem;opacity:1;color:var(--emerald)}.file-upload-text{display:flex;flex-direction:column;gap:6px}.file-upload-text strong{font-size:.95rem;font-weight:600;color:var(--text-primary);letter-spacing:-.2px}.file-upload-or{font-size:.75rem;color:var(--text-secondary);font-weight:500}.file-upload-button{background:var(--violet-light);color:#fff;border:none;padding:8px 20px;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 3px #5b21b64d}.file-upload-button:hover{background:var(--violet);box-shadow:0 4px 12px #5b21b659;transform:translateY(-1px)}.file-upload-button:active{transform:translateY(0)}.file-upload-hint{font-size:.75rem;color:var(--text-muted);margin-top:4px}.file-upload-filename{font-size:.9rem;font-weight:600;color:var(--text-primary);word-break:break-word;max-width:100%;padding:0 8px}.file-upload-subtext{font-size:.75rem;color:var(--text-secondary);margin-top:4px}@media (max-width: 1024px){.main-content{grid-template-columns:1fr 300px}.theory-main{padding:24px}}@media (max-width: 900px){.app-layout,.app-wrapper{grid-template-columns:1fr;grid-template-rows:auto 1fr}.app-sidebar{width:100%;height:auto;position:sticky;top:0;flex-direction:row;align-items:center;padding:8px 12px;border-right:none;border-bottom:1px solid var(--border);box-shadow:0 2px 8px #0000000f;z-index:200}.sidebar-logo{border-bottom:none;padding:6px 8px;flex-shrink:0}.sidebar-logo-sub,.sidebar-footer{display:none}.sidebar-nav{flex-direction:row;gap:4px;padding:0;flex:1;justify-content:flex-start;overflow-x:auto;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.app-nav-tab{padding:8px 10px;font-size:.78rem;white-space:nowrap;width:auto}.main-content{grid-template-columns:1fr}.theory-layout{grid-template-columns:1fr;height:auto;min-height:auto}.theory-sidebar{position:static;max-height:none;border-right:none;border-bottom:2px solid #E9D5FF}}@media (max-width: 600px){.sidebar-logo-name{font-size:.95rem}.app-nav-tab{padding:8px 10px;font-size:.78rem}.nav-tab-icon{display:none}.controls-bar{flex-direction:column;align-items:stretch}.score-tabs{flex-wrap:wrap}.theory-lesson-title{font-size:1.4rem}.rn-val-summary{grid-template-columns:repeat(2,1fr)}.feature-section{padding:18px}}@keyframes lp-gradient-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes lp-float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(4deg)}}@keyframes lp-marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes lp-scan{0%{top:0%}to{top:100%}}@keyframes lp-fall{to{transform:translateY(100vh) rotate(360deg)}}@keyframes lp-drift{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}@keyframes lp-staff-move{0%{transform:translate(0)}to{transform:translate(-50%)}}.lp-root{font-family:Inter,-apple-system,sans-serif;background-color:#07070f;color:#fff;overflow-x:hidden;min-height:100vh}.lp-cursor{position:fixed;width:20px;height:20px;background:#8b5cf6;border-radius:50%;pointer-events:none;z-index:9999;filter:blur(8px);opacity:.6;transition:transform .08s linear}.lp-mesh{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background:radial-gradient(circle at 20% 30%,#1e1b4b 0%,transparent 40%),radial-gradient(circle at 80% 70%,#4c1d95 0%,transparent 40%),radial-gradient(circle at 50% 50%,#07070f 0%,transparent 100%);pointer-events:none}.lp-glass{background:#ffffff0a;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1)}.lp-gradient-text{background:linear-gradient(135deg,#8b5cf6,#f43f5e,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-size:200% 200%;animation:lp-gradient-shift 5s ease infinite}.lp-nav{position:fixed;top:0;width:100%;z-index:50;background:#ffffff0a;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,.05);padding:16px 24px}.lp-nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.lp-nav-logo{font-family:Inter,sans-serif;font-size:1.4rem;font-weight:900;letter-spacing:-.04em;display:flex;align-items:center;gap:8px;color:#fff}.lp-nav-links{display:flex;gap:32px;font-size:.875rem;font-weight:500;color:#ffffffb3}.lp-nav-links a{text-decoration:none;transition:color .15s}.lp-nav-links a:hover{color:#fff}.lp-nav-btn{background:#ffffff0a;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(139,92,246,.3);padding:8px 24px;border-radius:999px;font-size:.875rem;font-weight:700;color:#fff;cursor:pointer;transition:background .15s}.lp-nav-btn:hover{background:#8b5cf61a}.lp-hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:80px;overflow:hidden;z-index:1}.lp-staff-wrap{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;opacity:.25;overflow:hidden}.lp-staff-line{position:absolute;height:1px;width:200%;left:-50%;background:linear-gradient(90deg,transparent,rgba(139,92,246,.25),transparent);animation:lp-staff-move linear infinite}.lp-drift{position:absolute;color:#f59e0b4d;pointer-events:none;font-size:1.6rem;animation:lp-drift 5s ease-in-out infinite}.lp-drift-1{top:28%;left:22%;animation-delay:0s}.lp-drift-2{top:52%;right:20%;animation-delay:1.5s}.lp-drift-3{bottom:28%;left:36%;animation-delay:3s}.lp-hero-content{position:relative;z-index:1;text-align:center;max-width:1000px;padding:0 1.5rem}.lp-hero-title{font-size:clamp(3.5rem,12vw,9rem);font-weight:900;letter-spacing:-.05em;line-height:1;margin:0 0 1.5rem}.lp-hero-sub{font-size:clamp(1.1rem,3vw,1.75rem);font-weight:300;color:#fffc;max-width:640px;margin:0 auto 2.5rem;line-height:1.5}.lp-hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.lp-btn-primary{background:linear-gradient(135deg,#4c1d95,#7c3aed,#9d174d,#be185d);background-size:200% 200%;animation:lp-gradient-shift 6s ease infinite;padding:16px 32px;border-radius:12px;font-size:1.1rem;font-weight:700;border:none;color:#fff;cursor:pointer;box-shadow:0 0 20px #8b5cf666;transition:transform .15s,box-shadow .15s}.lp-btn-primary:hover{transform:scale(1.05);box-shadow:0 0 30px #8b5cf699}.lp-btn-glass{background:#ffffff0a;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);padding:16px 32px;border-radius:12px;font-size:1.1rem;font-weight:700;color:#fff;cursor:pointer;transition:background .15s,transform .15s}.lp-btn-glass:hover{background:#ffffff1a;transform:scale(1.03)}.lp-mockup-wrap{position:relative;margin-top:5rem;width:100%;max-width:860px;padding:0 1.5rem;z-index:1}.lp-mockup{background:#ffffff0a;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.18);border-radius:20px;overflow:hidden;box-shadow:0 40px 80px #00000080;animation:lp-float 7s ease-in-out infinite;position:relative}.lp-mockup-scan{position:absolute;left:0;width:100%;height:2px;background:#f43f5e80;animation:lp-scan 4s linear infinite;z-index:2}.lp-mockup-inner{padding:0}.lp-mockup-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.08)}.lp-mockup-dot{width:11px;height:11px;border-radius:50%}.lp-mockup-dot--red{background:#ef4444}.lp-mockup-dot--yellow{background:#eab308}.lp-mockup-dot--green{background:#22c55e}.lp-mockup-filename{font-size:.75rem;font-family:monospace;color:#fff6;margin-left:8px}.lp-mockup-score{position:relative;height:160px;background:#ffffff05;overflow:hidden}.lp-score-staff-line{position:absolute;left:0;width:100%;height:1px;background:#ffffff1f}.lp-score-note{position:absolute;font-size:2rem;-webkit-user-select:none;user-select:none}.lp-mockup-badge{margin:0 16px 16px;background:#ffffff0a;border:1px solid rgba(245,158,11,.5);border-radius:8px;padding:10px 14px;font-size:.72rem;font-family:monospace;color:#f59e0b}.lp-section{padding:8rem 1.5rem;max-width:1280px;margin:0 auto;position:relative;z-index:1}.lp-section--dark{max-width:100%;background:#0006;padding:8rem 1.5rem}.lp-section--dark>*{max-width:1280px;margin-left:auto;margin-right:auto}.lp-section-title{font-size:clamp(2rem,6vw,5rem);font-weight:900;letter-spacing:-.05em;text-align:center;margin:0 0 5rem}.lp-hook{background:#ffffff0a;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:48px;padding:5rem 4rem;text-align:center;position:relative;overflow:hidden}.lp-hook-glow{position:absolute;top:-100px;left:-100px;width:260px;height:260px;background:#8b5cf633;border-radius:50%;filter:blur(100px);pointer-events:none}.lp-hook-title{font-size:clamp(1.4rem,3.5vw,2.6rem);font-weight:700;letter-spacing:-.04em;line-height:1.25;margin:0 0 2rem}.lp-hook-divider{width:120px;height:1px;background:linear-gradient(90deg,transparent,#F43F5E,transparent);margin:0 auto 2rem}.lp-hook-body{font-size:clamp(1rem,2.5vw,1.4rem);color:#fff9;font-weight:300;line-height:1.6;margin:0}.lp-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px}.lp-feature-card{background:#ffffff0a;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.05);border-radius:24px;padding:2.5rem;transition:transform .4s cubic-bezier(.22,.8,.3,1),border-color .3s}.lp-feature-card:hover{transform:translateY(-16px);border-color:var(--lp-card-color, rgba(255,255,255,.2))}.lp-feature-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;margin-bottom:2rem;transition:transform .3s}.lp-feature-card:hover .lp-feature-icon{transform:scale(1.12)}.lp-feature-title{font-size:1.25rem;font-weight:700;letter-spacing:-.03em;margin:0 0 1rem}.lp-feature-body{font-size:.95rem;color:#fff9;line-height:1.6;margin:0}.lp-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:64px;position:relative;max-width:1000px;margin:0 auto}.lp-step{text-align:center;position:relative}.lp-step-bg-num{font-size:8rem;font-weight:900;color:#ffffff0a;line-height:1;position:absolute;top:-40px;left:50%;transform:translate(-50%);-webkit-user-select:none;user-select:none}.lp-step-circle{width:80px;height:80px;background:#ffffff0a;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin:2.5rem auto 1.5rem}.lp-step-label{font-size:1.1rem;font-weight:700;margin:0 0 .75rem}.lp-step-body{font-size:.9rem;color:#ffffff80;line-height:1.6;margin:0}.lp-preview-card{background:#ffffff0a;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:32px;overflow:hidden;box-shadow:0 40px 80px #0006}.lp-preview-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.05)}.lp-preview-tabs{display:flex;gap:8px}.lp-preview-tab{padding:8px 20px;border-radius:8px;font-size:.875rem;font-weight:600;border:none;background:transparent;color:#ffffff80;cursor:pointer;transition:all .15s}.lp-preview-tab:hover{background:#ffffff0d;color:#fff}.lp-preview-tab--active{background:#ffffff1a;color:#fff}.lp-preview-dots{display:flex;gap:6px}.lp-preview-dot{width:12px;height:12px;border-radius:50%}.lp-preview-body{position:relative;min-height:280px;padding:2rem;overflow:hidden}.lp-preview-staff{position:absolute;left:2rem;right:2rem;height:1px;background:#ffffff1a}.lp-preview-note{position:absolute;font-size:2.2rem;color:#ffffffa6;-webkit-user-select:none;user-select:none}.lp-preview-fade{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#07070F 0%,transparent 60%);pointer-events:none}.lp-flip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-top:2.5rem}.lp-flip{height:190px;perspective:1000px;cursor:pointer}.lp-flip-inner{position:relative;width:100%;height:100%;transition:transform .55s;transform-style:preserve-3d}.lp-flip:hover .lp-flip-inner{transform:rotateY(180deg)}.lp-flip-front,.lp-flip-back{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;border-radius:20px;padding:20px;backface-visibility:hidden;-webkit-backface-visibility:hidden;font-size:1rem;font-weight:700;text-align:center}.lp-flip-front{background:#ffffff0a;border:1px solid rgba(255,255,255,.1)}.lp-flip-back{transform:rotateY(180deg);font-size:.88rem;font-weight:600}.lp-marquee-wrap{padding:4rem 0;overflow:hidden;position:relative;z-index:1}.lp-marquee{display:flex;gap:24px;animation:lp-marquee 28s linear infinite;white-space:nowrap;width:max-content}.lp-marquee-pill{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:18px 44px;border-radius:999px;font-size:1.1rem;font-weight:700;flex-shrink:0}.lp-cta-section{position:relative;min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 1.5rem;overflow:hidden;z-index:1}.lp-falling-notes{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;opacity:.18;pointer-events:none;overflow:hidden}.lp-falling-note{position:absolute;color:#8b5cf6;animation:lp-fall linear infinite;top:-60px}.lp-cta-title{position:relative;z-index:1;font-size:clamp(2.5rem,10vw,10rem);font-weight:900;letter-spacing:-.05em;line-height:.95;margin:0 0 3rem}.lp-cta-btn{position:relative;z-index:1;background:linear-gradient(135deg,#4c1d95,#7c3aed,#9d174d,#be185d);background-size:200% 200%;animation:lp-gradient-shift 6s ease infinite;padding:24px 56px;border-radius:20px;font-size:clamp(1.2rem,4vw,2.2rem);font-weight:900;border:none;color:#fff;cursor:pointer;box-shadow:0 0 30px #8b5cf680;transition:transform .15s,box-shadow .15s;letter-spacing:-.02em}.lp-cta-btn:hover{transform:scale(1.08);box-shadow:0 0 50px #8b5cf6a6}.lp-cta-arrow{display:inline-block;transition:transform .2s;margin-left:6px}.lp-cta-btn:hover .lp-cta-arrow{transform:translate(6px)}.lp-cta-sub{position:relative;z-index:1;margin-top:3rem;color:#ffffff59;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;font-family:monospace}.lp-footer{border-top:1px solid rgba(255,255,255,.05);background:#ffffff05;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:3rem 1.5rem;margin-top:4rem;position:relative;z-index:1}.lp-footer-inner{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center}@media (min-width: 768px){.lp-footer-inner{flex-direction:row;justify-content:space-between;text-align:left}}.lp-footer-logo{font-size:1.2rem;font-weight:900;letter-spacing:-.04em}.lp-footer-links{display:flex;gap:28px}.lp-footer-links a{font-size:.875rem;color:#ffffff80;text-decoration:none;transition:color .15s}.lp-footer-links a:hover{color:#fff}.lp-footer-copy{font-size:.75rem;color:#ffffff40}.lp-demo-section{padding-block:80px 64px}.lp-demo-header{text-align:center;margin-bottom:32px}.lp-demo-subtitle{color:#ffffff8c;font-size:1rem;margin-top:8px;font-family:Libre Baskerville,Georgia,serif;font-style:italic}.lp-demo-card{max-width:900px;margin-inline:auto;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 32px 80px #00000073}.lp-demo-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.08);background:#0003}.lp-demo-tab{flex:1;padding:14px 12px;background:none;border:none;color:#ffffff73;font-size:.85rem;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:color .2s,background .2s;display:flex;align-items:center;justify-content:center;gap:7px;position:relative}.lp-demo-tab:hover:not(:disabled){color:#fffc;background:#ffffff0a}.lp-demo-tab.active{color:#fff;background:#ffffff0f}.lp-demo-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:linear-gradient(90deg,#8b5cf6,#f43f5e);border-radius:2px 2px 0 0}.lp-demo-tab:disabled{opacity:.3;cursor:not-allowed}.lp-demo-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;border-radius:10px;font-size:.72rem;font-weight:700;background:#f43f5e;color:#fff}.lp-demo-badge--green{background:#22c55e}.lp-demo-score-area{position:relative;background:#fff8e8f7;min-height:280px;overflow:hidden;display:flex;align-items:stretch}.lp-demo-osmd{width:100%;padding:12px 16px 6px;box-sizing:border-box}.lp-demo-osmd svg{max-height:320px;width:100%!important}.lp-demo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#0e0602bf;color:#ffffffb3;font-size:.95rem;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.lp-demo-overlay--offline{background:#0e0602d9}.lp-demo-overlay--light{background:#fff8e8b3;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.lp-demo-offline-icon{font-size:2.5rem;opacity:.4}.lp-demo-overlay--offline code{background:#ffffff1a;padding:4px 12px;border-radius:6px;font-size:.8rem;color:#ffffff80}.lp-demo-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.15);border-top-color:#8b5cf6;border-radius:50%;animation:lp-spin .8s linear infinite}.lp-demo-spinner--dark{border-color:#2d1f0e26;border-top-color:#8b5cf6}@keyframes lp-spin{to{transform:rotate(360deg)}}.lp-demo-err-list{border-top:1px solid rgba(255,255,255,.07);padding:16px 20px;display:flex;flex-direction:column;gap:8px}.lp-demo-err-header{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ffffff59;margin-bottom:4px}.lp-demo-err-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);font-size:.84rem}.lp-demo-err--error{border-left:3px solid #F43F5E}.lp-demo-err--warning{border-left:3px solid #F59E0B}.lp-demo-err-pill{background:#f43f5e26;color:#f43f5e;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:700;white-space:nowrap;flex-shrink:0}.lp-demo-err--warning .lp-demo-err-pill{background:#f59e0b26;color:#f59e0b}.lp-demo-err-desc{flex:1;color:#ffffffa6}.lp-demo-err-loc{font-size:.75rem;color:#ffffff4d;white-space:nowrap;flex-shrink:0}.lp-demo-alt-note{border-top:1px solid rgba(255,255,255,.07);padding:14px 20px;display:flex;align-items:center;gap:10px;color:#ffffff8c;font-size:.85rem;font-style:italic}.lp-demo-alt-icon{font-size:1.2rem;color:#22c55e;flex-shrink:0}.lp-demo-clean{border-top:1px solid rgba(255,255,255,.07);padding:14px 20px;color:#22c55e;font-size:.9rem;font-weight:600}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e0f05a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto;animation:fadeSlideIn .2s ease both}@media (min-height: 700px){.auth-overlay{align-items:center}}.auth-card{background:#faf7f0;border-radius:16px;width:100%;max-width:440px;box-shadow:0 24px 60px #00000080,0 8px 20px #00000040,inset 0 0 0 1px #fff9;overflow:visible;padding-bottom:1.5rem}.auth-card-header{display:flex;align-items:center;gap:12px;padding:1.8rem 2rem 1.2rem;border-bottom:1px solid rgba(200,192,176,.4)}.auth-clef{font-size:2.2rem;color:var(--nb-ink);line-height:1}.auth-title{font-family:var(--font-handwritten);font-size:1.8rem;font-weight:700;color:var(--nb-ink);margin:0}.auth-tabs{display:flex;border-bottom:1px solid rgba(200,192,176,.4)}.auth-tab{flex:1;padding:12px;background:transparent;border:none;font-family:var(--font-editorial);font-size:.88rem;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;transition:all .15s ease}.auth-tab:hover{color:var(--nb-ink);background:#c8c0b01f}.auth-tab.active{color:var(--nb-ink);font-weight:700;border-bottom-color:var(--violet-light)}.auth-error{margin:12px 2rem 0;padding:10px 14px;background:#fff1f2;border:1px solid #FECDD3;border-radius:8px;color:#881337;font-size:.85rem;font-family:var(--font-editorial)}.auth-form{display:flex;flex-direction:column;gap:14px;padding:1.4rem 2rem 2rem}.auth-label{display:flex;flex-direction:column;gap:5px;font-family:var(--font-editorial);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.auth-optional{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-muted)}.auth-input{padding:10px 12px;border:1.5px solid rgba(200,192,176,.6);border-radius:8px;background:#fff;font-family:var(--font-editorial);font-size:.9rem;color:var(--nb-ink);transition:border-color .15s ease,box-shadow .15s ease}.auth-input:focus{outline:none;border-color:var(--violet-light);box-shadow:0 0 0 3px #8b5cf626}.auth-submit{margin-top:6px;padding:13px;background:var(--violet-light);color:#fff;border:none;border-radius:10px;font-family:var(--font-editorial);font-size:.95rem;font-weight:700;cursor:pointer;box-shadow:0 2px 8px #5b21b64d;transition:background .15s ease,transform .12s ease,box-shadow .15s ease}.auth-submit:hover:not(:disabled){background:var(--violet);transform:translateY(-1px);box-shadow:0 6px 16px #5b21b666}.auth-submit:disabled{opacity:.65;cursor:not-allowed}.auth-google-wrap{padding:0 24px;display:flex;justify-content:center}.auth-google-wrap>div,.auth-google-wrap iframe{width:100%!important}.auth-divider{display:flex;align-items:center;gap:12px;padding:0 24px;color:#503c2859;font-size:.8rem;font-family:var(--font-ui);letter-spacing:.05em}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#503c2826}.nb-user-badge{display:flex;align-items:center;gap:8px;margin-left:auto}.nb-user-name{font-family:var(--font-editorial);font-size:.82rem;color:var(--text-secondary);font-style:italic}.nb-logout-btn{font-family:var(--font-editorial);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:5px 12px;background:transparent;border:1.5px solid rgba(200,192,176,.7);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.nb-logout-btn:hover{background:#b91c1c14;border-color:#b91c1c4d;color:#b91c1c}.nb-plan-row{display:flex;align-items:center;gap:8px;margin:6px 0 10px}.nb-plan-badge{font-family:var(--font-editorial);font-size:.72rem;font-weight:700;letter-spacing:.03em;padding:3px 10px;border-radius:20px;border:1.5px solid currentColor;cursor:pointer;transition:opacity .15s;background:transparent}.nb-plan-badge:hover{opacity:.75}.nb-plan-badge--free{color:#1a1a2e73}.nb-plan-badge--pro{color:#92400e}.nb-plan-badge--conservatorio{color:#065f46}.nb-corrections-left{font-family:var(--font-editorial);font-size:.7rem;font-style:italic;color:#1a1a2e66}.checkout-toast{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;padding:12px 24px;border-radius:8px;font-family:var(--font-editorial);font-size:.9rem;font-weight:600;box-shadow:0 4px 24px #00000026;animation:toast-in .3s ease}.checkout-toast--success{background:#065f46;color:#fff}.checkout-toast--cancel{background:#1e293b;color:#cbd5e1}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(-12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.pricing-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:16px;overflow-y:auto}.pricing-modal{background:#0f172a;border-radius:20px;padding:32px 24px 40px;max-width:960px;width:100%;position:relative;max-height:90vh;overflow-y:auto}.pricing-modal-close{position:absolute;top:16px;right:20px;background:transparent;border:none;color:#ffffff80;font-size:1.2rem;cursor:pointer;transition:color .15s}.pricing-modal-close:hover{color:#fff}.pricing-section{padding:80px 24px 64px;background:#0a0f1e}.pricing-header{text-align:center;margin-bottom:48px}.pricing-title{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;color:#f1f5f9;margin-bottom:12px;letter-spacing:-.02em}.pricing-accent{background:linear-gradient(90deg,#a78bfa,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pricing-subtitle{color:#f1f5f980;font-size:1rem}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;max-width:960px;margin:0 auto}.pricing-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:28px 24px 24px;display:flex;flex-direction:column;position:relative;transition:transform .2s ease,box-shadow .2s ease}.pricing-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #0000004d}.pricing-card--featured{background:#8b5cf61f;border-color:#8b5cf666;box-shadow:0 0 40px #8b5cf626}.pricing-card--current{border-color:#22c55e66;box-shadow:0 0 24px #22c55e1a}.pricing-badge,.pricing-current-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);padding:4px 14px;border-radius:20px;font-size:.72rem;font-weight:700;letter-spacing:.04em;white-space:nowrap}.pricing-badge{background:linear-gradient(90deg,#a78bfa,#f472b6);color:#fff}.pricing-current-badge{background:#22c55e;color:#fff}.pricing-card-header{margin-bottom:20px}.pricing-plan-name{font-size:1.2rem;font-weight:700;color:#f1f5f9;margin-bottom:10px}.pricing-price-row{display:flex;align-items:baseline;gap:3px}.pricing-currency{font-size:1.1rem;color:#a78bfa;font-weight:600}.pricing-price{font-size:2.4rem;font-weight:800;color:#f1f5f9;line-height:1}.pricing-interval{font-size:.85rem;color:#f1f5f973}.pricing-features{list-style:none;padding:0;margin:0 0 24px;flex:1;display:flex;flex-direction:column;gap:10px}.pricing-feature{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;color:#f1f5f9b3;line-height:1.45}.pricing-check{color:#a78bfa;font-weight:700;flex-shrink:0;margin-top:1px}.pricing-card-footer{margin-top:auto}.pricing-btn{display:block;width:100%;padding:11px;border-radius:8px;font-size:.9rem;font-weight:600;text-align:center;cursor:pointer;border:none;transition:filter .15s,transform .1s}.pricing-btn:hover{filter:brightness(1.12);transform:translateY(-1px)}.pricing-btn:active{transform:translateY(0)}.pricing-btn:disabled{opacity:.6;cursor:default;transform:none}.pricing-btn--primary{background:linear-gradient(135deg,#a78bfa,#f472b6);color:#fff}.pricing-btn--secondary{background:#ffffff12;color:#f1f5f9;border:1px solid rgba(255,255,255,.12)}.pricing-btn--current,.pricing-btn--free{background:transparent;color:#f1f5f966;border:1px solid rgba(255,255,255,.1);cursor:default;pointer-events:none}.pricing-btn--manage{background:#22c55e1f;color:#4ade80;border:1px solid rgba(34,197,94,.25)}.pricing-note{text-align:center;color:#f1f5f94d;font-size:.78rem;margin-top:28px}.pricing-error{max-width:500px;margin:0 auto 24px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:8px;color:#fca5a5;font-size:.88rem;text-align:center}.theory-module-btn--locked{opacity:.5;cursor:not-allowed}.theory-mod-level--locked{background:linear-gradient(90deg,#a78bfa,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;border-color:transparent}.theory-locked-toast{margin:4px 8px 12px;padding:8px 12px;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:8px;font-size:.78rem;color:#c4b5fd;font-family:var(--font-editorial);line-height:1.4}.auth-forgot-desc{font-size:.88rem;color:#503c2899;text-align:center;padding:0 2rem;margin:0 0 16px;line-height:1.5}.auth-success{background:#22c55e1f;border:1px solid rgba(34,197,94,.4);color:#166534;border-radius:8px;padding:10px 14px;font-size:.85rem;margin-bottom:12px;text-align:center;line-height:1.4}.auth-link-btn{background:none;border:none;color:#503c2880;font-size:.82rem;cursor:pointer;padding:8px 0 0;text-align:center;width:100%;transition:color .2s}.auth-link-btn:hover{color:#503c28d9}.legal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0502b8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1100;padding:1.5rem 1rem;animation:fadeSlideIn .2s ease both}.legal-card{background:#faf7f0;border-radius:16px;width:100%;max-width:680px;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 32px 80px #0000008c,inset 0 0 0 1px #fff9;position:relative;overflow:hidden}.legal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:1.1rem;color:#503c2873;cursor:pointer;line-height:1;padding:4px 8px;border-radius:6px;transition:color .15s,background .15s;z-index:1}.legal-close:hover{color:#503c28e6;background:#503c2814}.legal-header{padding:1.8rem 2.4rem 1.2rem;border-bottom:1px solid rgba(200,192,176,.4);flex-shrink:0}.legal-title{font-family:var(--font-display, serif);font-size:1.35rem;color:#2d1f0f;margin:0 0 4px;padding-right:2rem}.legal-updated{font-size:.78rem;color:#503c2873;margin:0}.legal-body{overflow-y:auto;flex:1;padding:1.6rem 2.4rem;scroll-behavior:smooth}.legal-body::-webkit-scrollbar{width:6px}.legal-body::-webkit-scrollbar-track{background:transparent}.legal-body::-webkit-scrollbar-thumb{background:#503c2833;border-radius:3px}.legal-section{margin-bottom:1.6rem}.legal-section-heading{font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#503c2899;margin:0 0 8px}.legal-section-body{font-size:.875rem;color:#2d1f0fd1;line-height:1.7;margin:0 0 6px}.legal-footer{padding:1rem 2.4rem 1.4rem;border-top:1px solid rgba(200,192,176,.4);display:flex;justify-content:flex-end;flex-shrink:0}.legal-accept-btn{padding:10px 28px;background:var(--violet-light, #7C3AED);color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s,transform .12s}.legal-accept-btn:hover{background:var(--violet, #6D28D9);transform:translateY(-1px)}.lp-footer-links button{background:none;border:none;color:inherit;font:inherit;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:3px;opacity:.7;transition:opacity .15s}.lp-footer-links button:hover{opacity:1}@media (max-width: 768px){.lp-nav{padding:12px 16px}.lp-nav-links{display:none}.lp-hero-title{font-size:clamp(2.8rem,14vw,5rem)}.lp-hero-sub{font-size:1rem;padding:0 1rem}.lp-hero-cta{flex-direction:column;gap:12px}.lp-hero-cta-btn,.lp-hero-demo-btn{width:100%;max-width:320px;text-align:center}.lp-section{padding:60px 1rem}.lp-section-title{font-size:clamp(1.6rem,8vw,2.4rem)}.pricing-section{padding:48px 1rem}.desk-bg{padding:0 0 2rem;align-items:stretch}.notebook{border-radius:0;min-height:100vh;flex-direction:column;padding-top:48px}.nb-tab{position:absolute!important;top:0!important;right:auto!important;width:25%!important;height:48px;writing-mode:horizontal-tb;text-orientation:mixed;border-radius:0!important;font-size:.58rem;letter-spacing:.06em;box-shadow:none}.nb-tab:hover:not(.active){transform:none}.nb-tab.active{right:auto!important;transform:none;box-shadow:inset 0 -3px #00000026}.nb-tab-1{left:0%;border-radius:0!important}.nb-tab-2{left:25%}.nb-tab-3{left:50%}.nb-tab-4{left:75%}.nb-tab-content{flex-direction:column;animation-duration:1ms}.nb-page{flex:0 0 auto;min-height:auto;padding:1.5rem 1rem 2rem}.nb-page--left{flex:0 0 auto;width:100%;border-radius:0;border-right:none;border-bottom:2px solid rgba(0,0,0,.08)}.nb-page--right{flex:1;width:100%;border-radius:0}.nb-tab.active{background:var(--nb-paper)!important}.nb-tab-1.active,.nb-tab-2.active,.nb-tab-3.active,.nb-tab-4.active{color:var(--nb-ink)}.nb-header{margin-bottom:1.2rem;gap:8px}.nb-clef{font-size:2rem}.nb-title{font-size:1.3rem}.nb-user-badge{gap:6px}.score-tabs{flex-wrap:wrap;gap:4px}.score-tab{font-size:.72rem;padding:5px 10px}.nb-page--theory-nav{border-bottom:2px solid rgba(0,0,0,.08)}.nb-page--full-content .theory-layout{flex-direction:column}.auth-card{max-width:100%;border-radius:12px}.legal-card{padding:0;max-height:96vh}.legal-header{padding:1.2rem 1rem .6rem}.legal-body{padding:0 1rem 1rem}.legal-footer{padding:.8rem 1rem}}
