: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}.notebook--dark{--nb-paper: #1C1914;--nb-ink: #D8CCAF;--nb-staff: rgba(210,185,120,.1);--nb-tab-bg: #2A2318;--nb-spine: rgba(210,185,120,.22);--nb-desk: #B8A88A;transition:background-color .35s ease,color .35s ease}.notebook--dark .nb-page,.notebook--dark .nb-page--left,.notebook--dark .nb-page--right{transition:background-color .35s ease,background-image .35s ease}.notebook--dark .score-nb-wrapper{background:#f5efe4;border-radius:4px;padding:4px}.notebook--dark input[type=file]::file-selector-button,.notebook--dark select,.notebook--dark input[type=text],.notebook--dark input[type=number]{background:#2a2318;color:var(--nb-ink);border-color:#d2b97840}.notebook--dark .nb-tab{background:var(--nb-tab-bg);transition:background .35s ease}.nb-theme-toggle{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;flex-shrink:0}.nb-theme-toggle__track{display:flex;align-items:center;width:2.6rem;height:1.35rem;border-radius:999px;background:#1a1a2e26;border:1.5px solid rgba(26,26,46,.2);padding:.1rem;transition:background .3s ease,border-color .3s ease;position:relative}.nb-theme-toggle--dark .nb-theme-toggle__track{background:#d2b97833;border-color:#d2b97866}.nb-theme-toggle__thumb{width:1.05rem;height:1.05rem;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000040;display:flex;align-items:center;justify-content:center;font-size:.6rem;line-height:1;transition:transform .3s cubic-bezier(.34,1.56,.64,1),background .3s ease;transform:translate(0)}.nb-theme-toggle--dark .nb-theme-toggle__thumb{transform:translate(1.2rem);background:#2a2318}.nb-theme-toggle:hover .nb-theme-toggle__track{border-color:#1a1a2e66}.nb-theme-toggle--dark:hover .nb-theme-toggle__track{border-color:#d2b978a6}@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)}}.nb-tab-content{display:flex;flex:1;min-width:0;position:relative;z-index:2}*,*: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}.notebook--theory{min-height:calc(100vh - 3rem)}.notebook:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:14px;z-index:0;pointer-events:none;background-color:var(--nb-paper);background-image:linear-gradient(var(--nb-staff) 1px,transparent 1px),linear-gradient(to left,rgba(180,165,140,.6) 0px,rgba(180,165,140,.2) 5px,transparent 14px);background-size:100% 1.5rem,100% 100%}.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:visible}.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):not(.nb-tab--soon){transform:translate(5px);filter:brightness(1.18);box-shadow:4px 2px 12px #00000059}.nb-tab--soon{cursor:not-allowed;opacity:.55;filter:grayscale(.4)}.nb-tab--soon:after{content:"✦";display:block;font-size:.55rem;margin-top:2px;opacity:.8}.nb-tab--soon:before{content:"Próximamente";position:absolute;right:calc(100% + 10px);top:50%;transform:translateY(-50%);writing-mode:horizontal-tb;text-orientation:mixed;background:#141414eb;color:#fff;font-size:.72rem;font-weight:600;white-space:nowrap;padding:4px 10px;border-radius:6px;pointer-events:none;opacity:0;transition:opacity .18s ease;z-index:200;box-shadow:0 2px 8px #00000059}.nb-tab--soon:hover:before{opacity:1}.nb-coming-soon{display:flex;align-items:center;justify-content:center;min-height:340px}.nb-coming-soon__content{text-align:center;color:var(--nb-ink);opacity:.5}.nb-coming-soon__icon{font-size:3rem;display:block;margin-bottom:.6rem}.nb-coming-soon__content h2{font-size:1.4rem;font-weight:700;margin:0 0 .3rem}.nb-coming-soon__content p{font-size:1rem;font-style:italic;margin:0}.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-key-override{font-size:.78rem;padding:2px 6px;height:auto;min-width:0;width:auto;border-radius:4px;background:#1a1a2e12;border:1px solid rgba(26,26,46,.18);cursor:pointer}.nb-key-override:focus{border-color:var(--nb-correction);outline:none}.nb-meta-row--key:has(.nb-key-override:not([value=""])) .nb-key-override{border-color:#b4530980;background:#b453090f;color:#b45309;font-weight:600}.gen-form{gap:.55rem!important;font-size:1.05rem!important;margin-bottom:.8rem!important}.gen-form-title-row{justify-content:space-between;margin-bottom:.15rem}.gen-form-key{display:flex;align-items:center}.gen-form-2col{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.gen-form-field{display:flex;flex-direction:column;gap:1px}.gen-form-field label{font-size:.72rem;color:var(--text-muted);font-family:var(--font-handwritten);line-height:1.2}.gen-form-field .nb-input,.gen-form-field .nb-select{font-size:.9rem;width:100%}.gen-form-field--full{grid-column:1 / -1}.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:.9rem;padding-top:.85rem;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-disclaimer{margin-top:1.1rem;padding:.55rem .75rem;background:#b4780a14;border-left:3px solid rgba(180,120,10,.45);border-radius:0 6px 6px 0;font-size:.7rem;color:#1a1a2e8c;line-height:1.45}.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;min-width:0}.error-description-row{display:flex;align-items:flex-start;gap:5px}.error-lesson-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:3px;background:none;border:1px solid transparent;border-radius:4px;padding:1px 5px;cursor:pointer;font-size:.72rem;line-height:1.3;color:var(--violet);font-weight:600;white-space:nowrap;opacity:0;transform:translate(-4px);transition:opacity .18s ease,transform .18s ease,background .15s ease;pointer-events:none}.error-item:hover .error-lesson-btn{opacity:1;transform:translate(0);pointer-events:auto}.error-lesson-btn:hover{background:#5b21b614;border-color:var(--violet-light)}.error-lesson-btn:active{transform:scale(.95)}.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:10px;animation:fadeSlideIn .35s ease}.gen-results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.gen-results-title{font-size:1rem;font-weight:800;color:var(--text-primary)}.gen-progressions{display:flex;flex-direction:column;gap:8px}.gen-prog-card{background:var(--surface);border-radius:var(--radius-md);padding:10px 14px;box-shadow:var(--shadow-sm);border:1.5px solid var(--border);border-left:4px solid var(--amber);transition:all .2s ease;cursor:pointer;animation:fadeSlideIn .35s ease both}.gen-prog-card:hover{transform:translateY(-2px);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-prog-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.gen-prog-number{font-size:.72rem;font-weight:800;color:var(--text-muted);letter-spacing:.02em}.gen-prog-chords{display:flex;align-items:flex-end;gap:3px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.12) transparent}.gen-prog-chords::-webkit-scrollbar{height:3px}.gen-prog-chords::-webkit-scrollbar-thumb{background:#00000026;border-radius:99px}.gen-chord-slot{display:flex;flex-direction:column;align-items:center;gap:2px;flex-shrink:0}.gen-chord-note{font-family:Caveat,cursive;font-size:.65rem;color:var(--text-muted);line-height:1;letter-spacing:.01em}.gen-chord-rn{flex-shrink:0;padding:3px 9px;border-radius:50px;font-family:Times New Roman,serif;font-size:.78rem;font-weight:700;transition:transform .15s;cursor:default;white-space:nowrap;border:1.5px solid transparent}.gen-chord-rn:hover{transform:scale(1.1)}.gen-chord-rn.tonic{background:#ede9fe;color:var(--violet-dark);border-color:var(--violet-light)}.gen-chord-rn.dominant{background:#ffe4e6;color:var(--pink-dark);border-color:var(--pink-light)}.gen-chord-rn.subdominant{background:#d1fae5;color:#065f46;border-color:var(--emerald-light)}.gen-chord-rn.default{background:var(--bg);color:var(--text-secondary);border-color:var(--border)}.gen-loading-notice{margin:6px 0 0;padding:8px 12px;background:#fff8e1;border:1px solid #FFD54F;border-radius:var(--radius-sm);font-size:.75rem;color:#5d4037;line-height:1.5;text-align:center}.gen-prog-expl-toggle{background:none;border:1px solid var(--border);border-radius:99px;padding:2px 8px;font-size:.67rem;color:var(--text-muted);cursor:pointer}.gen-prog-expl-toggle:hover{background:var(--bg)}.gen-prog-transitions{margin-top:8px;display:flex;flex-direction:column;gap:4px;border-top:1px solid var(--border);padding-top:8px}.gen-prog-transition-row{display:flex;align-items:center;gap:6px;font-size:.72rem}.gen-chord-rn--sm{font-size:.72rem!important;padding:1px 6px!important}.gen-prog-transition-exp{color:var(--text-muted);font-style:italic;flex:1}.gen-prog-warnings{margin-top:8px;border-top:1px solid #FDE68A;padding-top:6px}.gen-prog-warning-item{font-size:.71rem;color:#92400e;background:#fef3c7;border-radius:4px;padding:3px 8px;margin-bottom:3px}.gen-chord-label{font-size:.65rem;font-weight:600;color:var(--text-muted);text-align:center}.gen-chord-arrow{flex-shrink:0;color:var(--text-muted);font-size:.7rem;line-height:1;opacity:.6}.gen-prog-description{font-size:.85rem;color:var(--text-secondary);font-weight:500}.gen-prog-cadence{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#fef3c7;border-radius:50px;font-size:.68rem;font-weight:700;color:var(--amber-dark);border:1px solid var(--amber-light)}.chord-ref{margin-top:.5rem;border:1px solid rgba(200,192,176,.45);border-radius:var(--radius-md);background:#fff9;overflow:hidden}.chord-ref-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.55rem .85rem;background:none;border:none;cursor:pointer;font-family:var(--font-editorial);font-size:.8rem;font-weight:600;color:var(--nb-ink);text-align:left;gap:8px}.chord-ref-toggle:hover{background:#c8c0b033}.chord-ref-chevron{font-size:.65rem;opacity:.6;flex-shrink:0}.chord-ref-body{padding:0 .85rem .85rem;border-top:1px solid rgba(200,192,176,.4)}.chord-ref-intro{font-size:.75rem;color:var(--text-secondary);margin:.55rem 0 .7rem;line-height:1.5}.chord-ref-intro code{background:#5b21b61a;color:var(--violet-dark);padding:1px 5px;border-radius:4px;font-size:.75rem}.chord-ref-section{margin-bottom:4px}.chord-ref-section-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.4rem .6rem;background:#faf7f0e6;border:none;border-left:3px solid #ccc;border-radius:0 var(--radius-sm) var(--radius-sm) 0;cursor:pointer;font-family:var(--font-editorial);font-size:.77rem;font-weight:700;color:var(--nb-ink);text-align:left;margin-bottom:2px}.chord-ref-section-header:hover{filter:brightness(.96)}.chord-ref-table{width:100%;border-collapse:collapse;font-size:.75rem;margin-bottom:4px}.chord-ref-table th{text-align:left;padding:4px 8px;border-bottom:1px solid rgba(200,192,176,.5);font-weight:700;color:var(--text-secondary);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.chord-ref-table td{padding:4px 8px;border-bottom:1px solid rgba(200,192,176,.2);color:var(--text-primary);line-height:1.4}.chord-ref-table tr:last-child td{border-bottom:none}.chord-ref-table tr:hover td{background:#c8c0b01f}.chord-ref-code{font-family:Courier New,monospace;font-size:.82rem;font-weight:700;background:#5b21b614;color:var(--violet-dark);padding:2px 7px;border-radius:4px;letter-spacing:.02em;white-space:nowrap}.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-mobile-toggle{display:none}.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-blog-section{padding-top:6rem}.lp-blog-subtitle{text-align:center;color:#ffffff8c;font-size:1.1rem;margin-top:-1.5rem;margin-bottom:3.5rem}.lp-blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;max-width:900px;margin:0 auto}.lp-blog-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-top:3px solid var(--blog-accent, #8B5CF6);border-radius:16px;padding:1.75rem;display:flex;flex-direction:column;gap:1.1rem;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;cursor:default}.lp-blog-card:hover{transform:translateY(-4px);background:#ffffff12;box-shadow:0 20px 50px #00000059}.lp-blog-card__top{display:flex;align-items:center;justify-content:space-between}.lp-blog-card__icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.35rem}.lp-blog-card__tag{font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 10px;border-radius:99px}.lp-blog-card__content{flex:1}.lp-blog-card__title{font-size:1.15rem;font-weight:800;color:#fff;line-height:1.35;margin-bottom:.6rem}.lp-blog-card__excerpt{font-size:.9rem;color:#ffffff94;line-height:1.6}.lp-blog-card__footer{display:flex;align-items:center;justify-content:space-between;padding-top:.8rem;border-top:1px solid rgba(255,255,255,.07)}.lp-blog-card__meta{display:flex;gap:.4rem;font-size:.78rem;color:#ffffff59}.lp-blog-card__dot{opacity:.4}.lp-blog-card__btn{background:none;border:none;font-size:.85rem;font-weight:700;cursor:pointer;padding:0;transition:opacity .15s ease,letter-spacing .15s ease;letter-spacing:.01em}.lp-blog-card__btn:hover{opacity:.75;letter-spacing:.04em}.blog-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9000;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;overflow-y:auto}.blog-modal{background:#0f1018;border:1px solid rgba(255,255,255,.1);border-radius:20px;max-width:720px;width:100%;padding:2.5rem 2.5rem 2rem;position:relative;margin:auto}.blog-modal__close{position:absolute;top:1.25rem;right:1.25rem;background:#ffffff14;border:none;color:#fff9;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:background .15s}.blog-modal__close:hover{background:#ffffff26;color:#fff}.blog-modal__header{border-left:3px solid #8B5CF6;padding-left:1.25rem;margin-bottom:2rem}.blog-modal__tag{font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 10px;border-radius:99px;display:inline-block;margin-bottom:.6rem}.blog-modal__meta{display:flex;gap:.5rem;font-size:.8rem;color:#ffffff59;margin-bottom:.75rem}.blog-modal__title{font-size:clamp(1.3rem,4vw,1.75rem);font-weight:900;color:#fff;line-height:1.25;letter-spacing:-.03em}.blog-article{color:#ffffffbf;font-size:.95rem;line-height:1.75}.blog-article__lead{font-size:1.05rem;color:#ffffffd9;margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.07)}.blog-article h2{font-size:1.1rem;font-weight:800;color:#fff;margin:1.75rem 0 .5rem;letter-spacing:-.02em}.blog-article p{margin-bottom:1rem}.blog-article ul{padding-left:1.4rem;margin-bottom:1rem}.blog-article li{margin-bottom:.4rem}.blog-article strong{color:#ffffffe6;font-weight:700}.blog-article em{color:#fffc}.blog-article code{background:#ffffff14;border-radius:5px;padding:1px 6px;font-family:monospace;font-size:.88em}.blog-article__tip{display:flex;gap:1rem;background:#8b5cf61f;border:1px solid rgba(139,92,246,.25);border-radius:12px;padding:1.1rem 1.25rem;margin-top:1.75rem}.blog-article__tip-icon{font-size:1.3rem;flex-shrink:0;margin-top:2px}.blog-article__tip p{margin:0;color:#fffc}.blog-modal__cta{margin-top:2.5rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08);text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.blog-modal__cta-text{color:#ffffff8c;font-size:.95rem;margin:0}@media (max-width: 640px){.blog-modal{padding:2rem 1.25rem 1.5rem}.blog-modal__title{font-size:1.25rem}.lp-blog-grid{grid-template-columns:1fr}}.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}.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);overflow:visible;min-height:unset;flex-shrink:0}.theory-sidebar--page{flex:0 0 auto;max-height:62px;overflow:hidden;transition:max-height .28s ease}.theory-sidebar--page.theory-sidebar--mobile-open{max-height:320px;overflow-y:auto}.theory-module-list--collapsible{display:none}.theory-sidebar--mobile-open .theory-module-list--collapsible{display:block}.theory-sidebar-mobile-toggle{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-family:var(--font-handwritten);font-size:.82rem;font-weight:700;color:var(--nb-correction);background:transparent;border:1.5px solid var(--nb-correction);border-radius:4px;cursor:pointer;transition:background .12s}.theory-sidebar-mobile-toggle:hover{background:#b91c1c12}.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}}.verify-email-banner{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;background:#fef3c7;border-bottom:2px solid #f59e0b;color:#92400e;font-size:.85rem;padding:10px 20px;text-align:center;z-index:100;position:relative}.verify-email-banner strong{font-weight:700}.verify-email-banner__btn{background:#d97706;color:#fff;border:none;border-radius:6px;padding:5px 14px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.verify-email-banner__btn:hover:not(:disabled){background:#b45309}.verify-email-banner__btn:disabled{opacity:.6;cursor:not-allowed}.verify-email-banner__sent{font-weight:600;color:#065f46}.nb-page--admin{grid-column:1 / -1;padding:0;overflow-y:auto;background:#f5f5f7;min-height:100%}.user-menu{position:fixed;top:1rem;right:1.5rem;z-index:600}.user-menu__trigger{display:flex;align-items:center;gap:7px;background:#1a1a2e;color:#e8e0d0;border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:6px 12px 6px 6px;cursor:pointer;font-size:.78rem;font-weight:600;font-family:var(--font-editorial);letter-spacing:.02em;transition:background .15s,box-shadow .15s;box-shadow:0 2px 8px #00000047}.user-menu__trigger:hover{background:#2d2b4a;box-shadow:0 3px 12px #00000061}.user-menu__avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#5b21b6,#9d174d);color:#fff;font-size:.7rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:0}.user-menu__name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu__chevron{font-size:.6rem;opacity:.55;margin-left:1px}.user-menu__dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:210px;background:#1e1c2e;border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 8px 32px #00000073;overflow:hidden;animation:umDropIn .15s ease}@keyframes umDropIn{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.user-menu__header{padding:14px 16px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px}.user-menu__header-name{font-family:var(--font-editorial);font-size:.88rem;font-weight:700;color:#e8e0d0;font-style:italic}.user-menu__plan-chip{font-family:var(--font-editorial);font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:2px 9px;border-radius:20px;border:1.5px solid currentColor;background:transparent;cursor:pointer;transition:opacity .15s;white-space:nowrap}.user-menu__plan-chip:hover{opacity:.7}.user-menu__plan-chip--free{color:#d2c8b480}.user-menu__plan-chip--pro{color:#fde68a}.user-menu__plan-chip--conservatorio{color:#6ee7b7}.user-menu__divider{height:1px;background:#ffffff12;margin:0}.user-menu__row{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;color:#c8bfae;font-family:var(--font-editorial);font-size:.82rem}.user-menu__row-label{font-style:italic}.user-menu__row--toggle{cursor:default}.user-menu__row--btn{width:100%;background:none;border:none;cursor:pointer;text-align:left;justify-content:flex-start;gap:8px;transition:background .12s}.user-menu__row--btn:hover{background:#ffffff0f;color:#e8e0d0}.user-menu__row--btn.active{color:#c4b5fd}.user-menu__row--danger:hover{background:#b91c1c26;color:#fca5a5}.user-menu__row--contact{display:block;text-decoration:none;color:var(--text-secondary);font-size:.78rem;letter-spacing:.01em}.user-menu__row--contact:hover{background:#8b5cf614;color:var(--violet-dark)}@media (max-width: 768px){.user-menu{top:auto;bottom:1.2rem;right:1rem}.user-menu__name,.user-menu__chevron{display:none}.user-menu__trigger{padding:7px;border-radius:50%;box-shadow:0 3px 12px #00000073}.user-menu__avatar{width:36px;height:36px;font-size:.85rem}.user-menu__dropdown{top:auto;bottom:calc(100% + 8px);right:0}}.adm-root{max-width:1100px;margin:0 auto;padding:1.5rem 1.5rem 3rem;font-family:Segoe UI,system-ui,sans-serif;color:#1a1a2e}.adm-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:1.5rem;border-bottom:2px solid rgba(91,33,182,.15);padding-bottom:1rem}.adm-title{font-size:1.3rem;font-weight:700;color:#3b0764;margin:0}.adm-tabs{display:flex;gap:6px}.adm-tab{padding:7px 18px;border-radius:8px;border:1.5px solid rgba(91,33,182,.2);background:#fff;font-size:.85rem;font-weight:600;cursor:pointer;color:#5b21b6;transition:all .15s}.adm-tab:hover{background:#ede9fe}.adm-tab.active{background:#5b21b6;color:#fff;border-color:#5b21b6}.adm-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 16px;border-radius:7px;border:none;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none}.adm-btn--primary{background:#5b21b6;color:#fff}.adm-btn--primary:hover:not(:disabled){background:#4c1d95}.adm-btn--secondary{background:#fff;color:#5b21b6;border:1.5px solid rgba(91,33,182,.25)}.adm-btn--secondary:hover:not(:disabled){background:#ede9fe}.adm-btn--sm{padding:4px 10px;font-size:.78rem;background:#ede9fe;color:#5b21b6;border-radius:6px}.adm-btn--sm:hover{background:#ddd6fe}.adm-btn:disabled{opacity:.5;cursor:not-allowed}.adm-badge{display:inline-block;padding:2px 9px;border-radius:99px;font-size:.75rem;font-weight:700;letter-spacing:.02em}.adm-badge--free{background:#f3f4f6;color:#6b7280}.adm-badge--basico{background:#dbeafe;color:#1d4ed8}.adm-badge--pro{background:#ede9fe;color:#5b21b6}.adm-badge--conservatorio{background:#fef3c7;color:#92400e}.adm-badge--status-free{background:#f3f4f6;color:#6b7280}.adm-badge--status-active{background:#d1fae5;color:#065f46}.adm-badge--status-cancelled{background:#fee2e2;color:#991b1b}.adm-badge--status-past_due{background:#fef3c7;color:#92400e}.adm-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;margin-bottom:2rem}.adm-stat-card{background:#fff;border-radius:12px;padding:1rem 1.1rem;box-shadow:0 1px 4px #00000012,0 1px 2px #0000000a;display:flex;align-items:flex-start;gap:12px}.adm-stat-icon{font-size:1.5rem;line-height:1}.adm-stat-value{font-size:1.4rem;font-weight:800;color:#1a1a2e}.adm-stat-label{font-size:.78rem;color:#6b7280;font-weight:600;margin-top:2px}.adm-stat-sub{font-size:.72rem;color:#9ca3af;margin-top:2px}.adm-section{margin-bottom:2rem}.adm-section-title{font-size:.95rem;font-weight:700;color:#3b0764;margin:0 0 .8rem;text-transform:uppercase;letter-spacing:.04em}.adm-plan-dist{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.adm-plan-card{background:#fff;border-radius:10px;padding:1rem;box-shadow:0 1px 3px #00000012;display:flex;flex-direction:column;gap:5px}.adm-plan-count{font-size:1.8rem;font-weight:800;color:#1a1a2e}.adm-plan-pct{font-size:.8rem;color:#6b7280}.adm-plan-bar{height:5px;background:#e5e7eb;border-radius:99px;overflow:hidden;margin:4px 0}.adm-plan-bar-fill{height:100%;background:#8b5cf6;border-radius:99px;transition:width .3s}.adm-plan-card--pro .adm-plan-bar-fill{background:#5b21b6}.adm-plan-card--basico .adm-plan-bar-fill{background:#2563eb}.adm-plan-card--conservatorio .adm-plan-bar-fill{background:#d97706}.adm-plan-status-mini{display:flex;flex-direction:column;gap:2px}.adm-plan-status-mini span{font-size:.7rem;color:#9ca3af}.adm-table-wrap{overflow-x:auto;border-radius:10px;box-shadow:0 1px 3px #00000012}.adm-table{width:100%;border-collapse:collapse;font-size:.83rem;background:#fff}.adm-table thead{background:#f5f3ff}.adm-table th{padding:10px 12px;text-align:left;font-weight:700;color:#5b21b6;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.adm-table td{padding:9px 12px;border-top:1px solid #f3f4f6;vertical-align:middle}.adm-table tbody tr:hover{background:#faf5ff}.adm-td-id{color:#9ca3af;font-size:.75rem}.adm-table--users td:nth-child(2){max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.adm-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:.8rem}.adm-input,.adm-select{padding:7px 12px;border-radius:7px;border:1.5px solid rgba(91,33,182,.2);font-size:.83rem;color:#1a1a2e;background:#fff;outline:none;transition:border-color .15s}.adm-input:focus,.adm-select:focus{border-color:#8b5cf6}.adm-input{min-width:220px}.adm-total-row{font-size:.82rem;color:#6b7280;margin-bottom:.6rem}.adm-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:1.2rem;font-size:.83rem;color:#4b5563}.adm-loading{padding:2rem;text-align:center;color:#9ca3af}.adm-error{padding:1rem;color:#991b1b}.adm-refresh-row{display:flex;align-items:center;gap:12px;margin-bottom:1.2rem}.adm-generated-at{font-size:.75rem;color:#9ca3af}.adm-msg{font-size:.82rem;margin-top:6px}.adm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9000;padding:20px}.adm-modal{background:#fff;border-radius:16px;padding:2rem;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 16px 48px #0000002e}.adm-modal--wide{max-width:720px}.adm-modal-close{position:absolute;top:14px;right:14px;background:none;border:none;font-size:1.1rem;color:#9ca3af;cursor:pointer;padding:4px 8px;border-radius:6px}.adm-modal-close:hover{background:#f3f4f6;color:#1a1a2e}.adm-modal-header{display:flex;gap:14px;align-items:flex-start;margin-bottom:1.2rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.adm-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0}.adm-avatar--placeholder{background:#8b5cf6;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:700}.adm-modal-header-text{flex:1;min-width:0}.adm-modal-name{font-weight:700;font-size:1.05rem;display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}.adm-modal-username{font-size:.82rem;color:#9ca3af;font-weight:400}.adm-modal-email{font-size:.83rem;color:#4b5563;margin-top:4px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.adm-modal-meta{font-size:.75rem;color:#9ca3af;margin-top:6px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.adm-badge--verified{background:#d1fae5;color:#065f46;font-size:.7rem;padding:1px 7px;border-radius:10px}.adm-badge--unverified{background:#fef3c7;color:#92400e;font-size:.7rem;padding:1px 7px;border-radius:10px}.adm-modal-stats{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:1.2rem}.adm-modal-stat{display:flex;flex-direction:column;align-items:center;background:#f5f3ff;border-radius:8px;padding:10px 16px;min-width:80px}.adm-modal-stat-val{font-size:1.3rem;font-weight:800;color:#3b0764}.adm-modal-stat-lbl{font-size:.68rem;color:#6b7280;text-align:center;margin-top:2px}.adm-modal-section{margin-bottom:1.2rem}.adm-modal-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#6b7280;margin-bottom:8px}.adm-plan-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.adm-stripe-links{display:flex;gap:8px;flex-wrap:wrap}.adm-fingerprint{font-family:monospace;font-size:.78rem;background:#f3f4f6;padding:5px 10px;border-radius:6px;color:#374151;word-break:break-all}.adm-modal-kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:1.4rem}.adm-kpi{display:flex;flex-direction:column;align-items:center;background:#f5f3ff;border-radius:10px;padding:10px 8px}.adm-kpi-val{font-size:1.35rem;font-weight:800;color:#3b0764;line-height:1}.adm-kpi-lbl{font-size:.65rem;color:#6b7280;text-align:center;margin-top:4px;line-height:1.25}.adm-modal-sections{display:grid;grid-template-columns:1fr 1fr;gap:0 1.5rem}.adm-info-row{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;padding:5px 0;border-bottom:1px solid #f3f4f6;font-size:.8rem}.adm-info-row:last-child{border-bottom:none}.adm-info-label{color:#9ca3af;white-space:nowrap;flex-shrink:0;font-size:.75rem}.adm-info-value{color:#1f2937;text-align:right;word-break:break-all}.adm-info-value--mono{font-family:monospace;font-size:.73rem}.adm-link{color:#7c3aed;text-decoration:underline;text-underline-offset:2px}.adm-link:hover{color:#4c1d95}.adm-newsletter{padding:1.5rem;max-width:780px}.adm-nl-field{display:flex;flex-direction:column;gap:6px;margin-bottom:1.25rem}.adm-nl-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#6b7280}.adm-nl-input,.adm-nl-select{padding:.55rem .75rem;border:1px solid #e5e7eb;border-radius:8px;font-size:.9rem;background:#fff;color:#1a1a2e;outline:none;transition:border-color .15s}.adm-nl-input:focus,.adm-nl-select:focus{border-color:#8b5cf6}.adm-nl-textarea{padding:.65rem .75rem;border:1px solid #e5e7eb;border-radius:8px;font-size:.82rem;font-family:monospace;background:#fafafa;color:#1a1a2e;resize:vertical;outline:none;transition:border-color .15s}.adm-nl-textarea:focus{border-color:#8b5cf6}.adm-nl-preview{border:1px solid #e5e7eb;border-radius:8px;padding:1.25rem 1.5rem;background:#fff;min-height:120px;font-size:.9rem;line-height:1.6;color:#1a1a2e}.adm-nl-send{margin-top:.5rem}.adm-nl-confirm{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-top:.5rem;padding:1rem 1.25rem;background:#fef3c7;border:1px solid #fbbf24;border-radius:10px;font-size:.9rem;color:#78350f}.adm-nl-result{padding:.85rem 1.1rem;border-radius:8px;font-size:.9rem;margin-bottom:1rem}.adm-nl-result--ok{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.adm-nl-result--err{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.adm-nl-hint{font-size:.75rem;color:#9ca3af;margin-top:2px}.cookie-banner{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:9999;display:flex;align-items:center;gap:16px;padding:16px 20px;width:min(720px,calc(100vw - 32px));background:#141026f5;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(139,92,246,.3);border-radius:16px;box-shadow:0 8px 32px #00000073,0 0 0 1px #ffffff0a;animation:cookieFadeIn .35s ease}@keyframes cookieFadeIn{0%{opacity:0;transform:translate(-50%) translateY(16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.cookie-banner__icon{font-size:1.6rem;flex-shrink:0;line-height:1}.cookie-banner__content{flex:1;min-width:0}.cookie-banner__title{margin:0 0 2px;font-size:.85rem;font-weight:700;color:#e5e7eb;letter-spacing:.01em}.cookie-banner__desc{margin:0;font-size:.78rem;color:#9ca3af;line-height:1.5}.cookie-banner__link{background:none;border:none;padding:0;color:#a78bfa;font-size:inherit;cursor:pointer;text-decoration:underline;text-underline-offset:2px;transition:color .15s}.cookie-banner__link:hover{color:#c4b5fd}.cookie-banner__actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.cookie-banner__btn{padding:8px 18px;border-radius:8px;font-size:.78rem;font-weight:600;cursor:pointer;border:none;white-space:nowrap;transition:opacity .15s,transform .1s}.cookie-banner__btn:hover{opacity:.88;transform:translateY(-1px)}.cookie-banner__btn:active{transform:translateY(0)}.cookie-banner__btn--primary{background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;box-shadow:0 2px 8px #5b21b666}.cookie-banner__btn--secondary{background:#ffffff14;color:#d1d5db;border:1px solid rgba(255,255,255,.12)}.cookie-banner__btn--secondary:hover{background:#ffffff21}@media (max-width: 600px){.cookie-banner{flex-direction:column;align-items:flex-start;bottom:16px;gap:12px;padding:14px 16px}.cookie-banner__actions{flex-direction:row;width:100%}.cookie-banner__btn{flex:1;text-align:center}}.cifrado-panel{margin-top:12px;border-top:1.5px dashed rgba(26,26,46,.15);padding-top:10px}.cifrado-panel__header{display:flex;align-items:baseline;gap:10px;margin-bottom:8px}.cifrado-panel__label{font-family:var(--font-editorial);font-size:.82rem;font-weight:700;color:var(--nb-ink);letter-spacing:.01em}.cifrado-panel__hint{font-family:var(--font-handwritten);font-size:.78rem;color:var(--text-muted)}.cifrado-panel__notice{margin:6px 0 4px;padding:6px 10px;background:#f5a6231f;border-left:3px solid #f5a623;border-radius:4px;font-family:var(--font-handwritten);font-size:.8rem;color:#7a5500;line-height:1.4}.cifrado-panel__scroll{display:flex;flex-wrap:wrap;gap:6px 10px;padding-bottom:4px}.cifrado-panel__measure{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 8px;background:#1a1a2e08;border:1px solid rgba(26,26,46,.1);border-radius:6px}.cifrado-panel__mnum{font-family:var(--font-handwritten);font-size:.7rem;color:#1a1a2e73;font-weight:700;line-height:1}.cifrado-panel__beats{display:flex;flex-direction:row;gap:5px}.cifrado-chip{display:flex;flex-direction:column;align-items:center;gap:2px}.cifrado-chip__beat{font-family:var(--font-handwritten);font-size:.62rem;color:#1a1a2e59;line-height:1}.cifrado-chip__input{width:46px;padding:4px 3px;font-family:var(--font-handwritten);font-size:1rem;font-weight:700;text-align:center;background:#faf7f0;border:1.5px solid rgba(26,26,46,.22);border-radius:3px;color:var(--nb-ink);outline:none;transition:border-color .15s,box-shadow .15s}.cifrado-chip__input:focus{border-color:var(--violet);box-shadow:0 0 0 2px #5b21b61f}.cifrado-chip--wrong .cifrado-chip__input{border-color:#b91c1c;background:#fef2f2;color:#b91c1c}.cifrado-chip--ok .cifrado-chip__input{border-color:#166534;background:#f0fdf4;color:#166534}.cifrado-chip__answer{font-family:var(--font-handwritten);font-size:.75rem;line-height:1;white-space:nowrap}.cifrado-chip__answer--wrong{color:#b91c1c;font-weight:700}.cifrado-chip__answer--ok{color:#166534;font-weight:700}.nb-stamp-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.nb-history-btn{font-size:.78rem;padding:6px 14px;border-radius:6px;cursor:pointer}.score-tab--pdf{margin-left:auto;font-size:.76rem;opacity:.85}.score-tab--pdf:hover{opacity:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:3000;display:flex;align-items:center;justify-content:center;padding:16px}.history-modal{background:#fefce8;border:1.5px solid #d4c9a8;border-radius:12px;box-shadow:0 8px 32px #00000047;width:min(860px,96vw);max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.history-modal__header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 12px;border-bottom:1.5px solid #d4c9a8;background:#f5f0e4;flex-shrink:0}.history-modal__title{font-family:var(--font-handwritten, Georgia, serif);font-size:1.05rem;color:#3a3025;font-weight:600}.history-modal__close{background:none;border:none;font-size:1.1rem;cursor:pointer;color:#6b5d4f;padding:2px 6px;border-radius:4px;line-height:1}.history-modal__close:hover{background:#e5dfc8}.history-modal__body{overflow-y:auto;padding:16px 20px 20px;flex:1}.history-modal__status{font-family:var(--font-handwritten, Georgia, serif);font-size:.92rem;color:#6b5d4f;text-align:center;padding:24px 0}.history-modal__status--error{color:#b91c1c}.history-table{width:100%;border-collapse:collapse;font-family:var(--font-handwritten, Georgia, serif);font-size:.84rem;color:#3a3025}.history-table th{text-align:left;border-bottom:2px solid #d4c9a8;padding:6px 10px;font-weight:700;font-size:.78rem;color:#6b5d4f;white-space:nowrap}.history-table td{padding:7px 10px;border-bottom:1px solid #ede8d5;vertical-align:middle}.history-table tr:last-child td{border-bottom:none}.history-table tr:hover td{background:#f5f0e4}.history-table__date{white-space:nowrap;font-size:.8rem;color:#6b5d4f}.history-table__file{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-table__errors--bad{color:#b91c1c;font-weight:700}.history-table__errors--ok{color:#166534;font-weight:700}.history-table__actions{white-space:nowrap;display:flex;gap:6px;align-items:center}.history-btn{border:none;border-radius:5px;padding:4px 10px;font-size:.78rem;cursor:pointer;font-family:inherit;transition:background .15s}.history-btn--load{background:#2563eb;color:#fff}.history-btn--load:hover:not(:disabled){background:#1d4ed8}.history-btn--delete{background:#fee2e2;color:#b91c1c}.history-btn--delete:hover:not(:disabled){background:#fecaca}.history-btn:disabled{opacity:.5;cursor:default}.playback-bar{display:flex;align-items:center;gap:.55rem;padding:.28rem .65rem .28rem .5rem;background:#1a1a2e0f;border:1px solid rgba(26,26,46,.12);border-radius:999px;margin-left:auto;flex-shrink:0}.playback-btn{width:1.85rem;height:1.85rem;border-radius:50%;border:none;background:var(--nb-ink);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .14s ease,background .14s ease,box-shadow .14s ease;box-shadow:0 1px 4px #00000040}.playback-btn:hover:not(:disabled){transform:scale(1.1);box-shadow:0 2px 8px #0000004d}.playback-btn:active:not(:disabled){transform:scale(.93)}.playback-btn--loading{opacity:.55;cursor:wait}.playback-btn--playing{background:#c0392b}@keyframes pb-spin{to{transform:rotate(360deg)}}.pb-spin{animation:pb-spin .9s linear infinite}.playback-tempo-label{font-family:var(--font-editorial);font-size:.68rem;color:var(--nb-ink);white-space:nowrap;min-width:2.8rem;font-variant-numeric:tabular-nums;opacity:.75}.playback-tempo-slider{width:68px;accent-color:var(--nb-ink);cursor:pointer;opacity:.8}.playback-tempo-slider:hover{opacity:1}.osmd-cursor-img,img[class*=cursor]{opacity:.55!important;mix-blend-mode:multiply;transition:left .08s linear;pointer-events:none!important}.tc-root{min-height:100vh;background:#0d0f1a;color:#f0ede4;font-family:Inter,sans-serif;display:flex;flex-direction:column}.tc-topnav{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;background:#0d0f1af2;border-bottom:1px solid rgba(245,166,35,.15);position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tc-topnav-back{background:none;border:1px solid rgba(245,166,35,.3);color:#f5a623;padding:.3rem .85rem;border-radius:6px;font-size:.82rem;cursor:pointer;transition:background .15s,color .15s}.tc-topnav-back:hover{background:#f5a6231f;color:#fbbf24}.tc-topnav-title{font-size:.95rem;font-weight:600;color:#f0ede4b3;letter-spacing:.03em}.tc-hero{text-align:center;padding:3rem 1.5rem 1.5rem}.tc-hero-title{font-family:Libre Baskerville,Georgia,serif;font-size:clamp(1.6rem,4vw,2.5rem);font-weight:700;color:#f5a623;margin:0 0 .75rem;letter-spacing:-.01em}.tc-hero-sub{font-size:1rem;color:#f0ede4a6;max-width:560px;margin:0 auto;line-height:1.6}.tc-controls-bar{position:sticky;top:49px;z-index:40;background:#0d0f1af7;border-bottom:1px solid rgba(245,166,35,.12);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.tc-controls-summary{display:none}.tc-controls-inner{max-width:1280px;margin:0 auto;padding:1rem 1.5rem;display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-start}@media (max-width: 700px){.tc-controls-summary{display:flex;align-items:center;justify-content:space-between;padding:.55rem 1rem;cursor:pointer;gap:.5rem;-webkit-user-select:none;user-select:none}.tc-controls-summary-info{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.tc-controls-summary .tc-selection-key{font-size:.9rem}.tc-controls-summary .tc-selection-scale{font-size:.72rem}.tc-controls-summary .tc-selection-voicing{font-size:.68rem}.tc-controls-toggle-icon{font-size:.7rem;color:#f5a623b3;white-space:nowrap;flex-shrink:0}.tc-controls-inner{display:none;padding:.75rem 1rem 1rem;gap:1rem;border-top:1px solid rgba(245,166,35,.1)}.tc-controls-bar--open .tc-controls-inner{display:flex}}.tc-control-group{display:flex;flex-direction:column;gap:.5rem}.tc-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#f0ede473}.tc-tonic-grid{display:flex;flex-wrap:wrap;gap:5px}.tc-tonic-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:#f0ede4bf;padding:.3rem .65rem;border-radius:6px;font-size:.78rem;cursor:pointer;transition:all .15s;white-space:nowrap}.tc-tonic-btn:hover{background:#f5a62326;border-color:#f5a62366;color:#f5a623}.tc-tonic-btn--active{background:#f5a62333;border-color:#f5a623;color:#f5a623;font-weight:700;box-shadow:0 0 12px #f5a62340}.tc-scale-btns{display:flex;flex-wrap:wrap;gap:5px}.tc-scale-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:#f0ede4bf;padding:.3rem .75rem;border-radius:6px;font-size:.78rem;cursor:pointer;transition:all .15s}.tc-scale-btn:hover{background:#00d4aa1a;border-color:#00d4aa66;color:#00d4aa}.tc-scale-btn--active{background:#00d4aa26;border-color:#00d4aa;color:#00d4aa;font-weight:700;box-shadow:0 0 12px #00d4aa33}.tc-voicing-toggle{display:flex;gap:5px}.tc-voicing-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:#f0ede4bf;padding:.3rem .85rem;border-radius:6px;font-size:.78rem;cursor:pointer;transition:all .15s}.tc-voicing-btn:hover{background:#8b5cf61f;border-color:#8b5cf666;color:#a78bfa}.tc-voicing-btn--active{background:#8b5cf62e;border-color:#8b5cf6;color:#a78bfa;font-weight:700;box-shadow:0 0 12px #8b5cf633}.tc-selection-label{display:flex;align-items:center;gap:.6rem;padding:.5rem 1.5rem;max-width:1280px;margin:0 auto;width:100%;box-sizing:border-box}@media (max-width: 700px){.tc-selection-label{display:none}}.tc-selection-key{font-family:Libre Baskerville,Georgia,serif;font-size:1.15rem;font-weight:700;color:#f5a623}.tc-selection-scale{font-size:.88rem;color:#00d4aa}.tc-selection-voicing{font-size:.78rem;color:#f0ede466;background:#ffffff0d;padding:2px 8px;border-radius:10px}.tc-main{flex:1;max-width:1280px;margin:0 auto;width:100%;padding:0 1rem 2rem;box-sizing:border-box}.tc-play-all-row{display:flex;justify-content:flex-end;margin-bottom:1rem;padding:0 .25rem}.tc-play-all-btn{background:#00d4aa1a;border:1px solid rgba(0,212,170,.35);color:#00d4aa;padding:.45rem 1.1rem;border-radius:8px;font-size:.82rem;cursor:pointer;transition:all .15s}.tc-play-all-btn:hover:not(:disabled){background:#00d4aa33;box-shadow:0 0 16px #00d4aa33}.tc-play-all-btn--active,.tc-play-all-btn:disabled{opacity:.7;cursor:default}.tc-cards-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}@media (max-width: 1100px){.tc-cards-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 700px){.tc-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 400px){.tc-cards-grid{grid-template-columns:1fr}}.tc-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:1rem .85rem;display:flex;flex-direction:column;gap:.5rem;position:relative;transition:transform .18s,box-shadow .18s,border-color .18s,background .18s;cursor:default}.tc-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px #0006;border-color:#f5a62340;background:#ffffff12}.tc-card--major{border-color:#f5a62333}.tc-card--minor{border-color:#60a5fa33}.tc-card--dim{border-color:#fb923c33}.tc-card--aug{border-color:#a78bfa33}.tc-card--dom7{border-color:#f9731640}.tc-card--playing{border-color:#00d4aa!important;box-shadow:0 0 0 2px #00d4aa4d,0 8px 32px #00d4aa33!important;animation:tc-pulse .6s ease-out}@keyframes tc-pulse{0%{box-shadow:0 0 #00d4aa80}70%{box-shadow:0 0 0 12px #00d4aa00}to{box-shadow:0 0 #00d4aa00}}.tc-card-header{display:flex;align-items:baseline;justify-content:space-between}.tc-card-roman{font-family:Libre Baskerville,Georgia,serif;font-size:1.3rem;font-weight:700;color:#f5a623;line-height:1}.tc-card-fn{font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.tc-card-symbol{display:flex;flex-direction:column;gap:1px}.tc-card-symbol-en{font-size:1rem;font-weight:700;color:#f0ede4;line-height:1.2}.tc-card-symbol-es{font-size:.78rem;color:#f0ede480}.tc-card-root{display:flex;flex-direction:column;gap:1px}.tc-card-root-label{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:#f0ede459}.tc-card-root-notes{font-size:.82rem;color:#f0ede4cc}.tc-card-root-notes b{color:#f0ede4}.tc-card-notes{display:flex;flex-direction:column;gap:1px}.tc-card-notes-label{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:#f0ede459}.tc-card-notes-es{font-size:.78rem;color:#f0ede4d9;font-weight:600}.tc-card-notes-en{font-size:.72rem;color:#f0ede473}.tc-card-degreename{font-size:.72rem;color:#f0ede466;font-style:italic}.tc-quality-badge{display:inline-block;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 7px;border-radius:8px}.tc-quality-badge--major,.tc-quality-badge--maj7{background:#f5a62326;color:#f5a623}.tc-quality-badge--minor,.tc-quality-badge--m7,.tc-quality-badge--mMaj7{background:#60a5fa26;color:#60a5fa}.tc-quality-badge--diminished,.tc-quality-badge--m7b5,.tc-quality-badge--dim7{background:#fb923c26;color:#fb923c}.tc-quality-badge--augmented,.tc-quality-badge--augMaj7{background:#a78bfa26;color:#a78bfa}.tc-quality-badge--dom7{background:#f9731626;color:#f97316}.tc-play-btn{position:absolute;bottom:.65rem;right:.65rem;width:28px;height:28px;border-radius:50%;background:#00d4aa26;border:1px solid rgba(0,212,170,.4);color:#00d4aa;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .18s,transform .18s,background .15s}.tc-play-btn--visible,.tc-card:hover .tc-play-btn{opacity:1}.tc-play-btn:hover{background:#00d4aa47;transform:scale(1.12)}.tc-play-btn--playing{opacity:1;background:#00d4aa4d;animation:tc-spin .8s linear infinite}@keyframes tc-spin{0%{transform:rotate(0) scale(1.1)}to{transform:rotate(360deg) scale(1.1)}}.tc-table-wrapper{width:100%}.tc-cta{max-width:1280px;margin:1rem auto;padding:0 1rem;width:100%;box-sizing:border-box}.tc-cta-inner{display:flex;align-items:center;gap:1.25rem;background:linear-gradient(135deg,#8b5cf61f,#f5a62314);border:1px solid rgba(139,92,246,.3);border-radius:14px;padding:1.25rem 1.5rem;flex-wrap:wrap}.tc-cta-icon{font-size:2rem;flex-shrink:0}.tc-cta-text{flex:1;min-width:200px}.tc-cta-title{font-size:1rem;font-weight:700;color:#f0ede4;margin:0 0 .35rem}.tc-cta-desc{font-size:.85rem;color:#f0ede499;margin:0;line-height:1.5}.tc-cta-btn{background:linear-gradient(135deg,#8b5cf6,#6d28d9);border:none;color:#fff;padding:.65rem 1.4rem;border-radius:8px;font-size:.88rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:opacity .15s,transform .15s;flex-shrink:0}.tc-cta-btn:hover{opacity:.88;transform:translateY(-1px)}.tc-seo-content{max-width:860px;margin:2rem auto 1rem;padding:0 1.5rem;border-top:1px solid rgba(255,255,255,.07)}.tc-seo-title{font-family:Libre Baskerville,Georgia,serif;font-size:1.3rem;color:#f5a623;margin:1.5rem 0 .75rem;font-weight:700}.tc-seo-subtitle{font-family:Libre Baskerville,Georgia,serif;font-size:1.05rem;color:#f0ede4d9;margin:1.25rem 0 .5rem}.tc-seo-body p{color:#f0ede4a6;font-size:.9rem;line-height:1.75;margin:0 0 .85rem}.tc-seo-body strong{color:#f0ede4e6}.tc-footer{text-align:center;padding:1.5rem;font-size:.78rem;color:#f0ede44d;border-top:1px solid rgba(255,255,255,.05);margin-top:2rem}.tc-footer-link{color:#f5a62399;text-decoration:none}.tc-footer-link:hover{color:#f5a623}.cad-root{min-height:100vh;background:#0d0f1a;color:#f0ede4;font-family:Inter,sans-serif;display:flex;flex-direction:column}.cad-hero{text-align:center;padding:3rem 1.5rem 1.5rem}.cad-hero-title{font-family:Libre Baskerville,Georgia,serif;font-size:clamp(1.6rem,4vw,2.5rem);font-weight:700;color:#f5a623;margin:0 0 .75rem;letter-spacing:-.01em}.cad-hero-sub{font-size:1rem;color:#f0ede4a6;max-width:600px;margin:0 auto;line-height:1.6}.cad-mode-tabs{display:flex;justify-content:center;gap:.75rem;padding:1rem 1.5rem;border-bottom:1px solid rgba(245,166,35,.1)}.cad-mode-tab{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:#f0ede4b3;padding:.6rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .18s}.cad-mode-tab:hover{background:#f5a6231a;border-color:#f5a6234d;color:#f5a623}.cad-mode-tab--active{background:#f5a6232e;border-color:#f5a623;color:#f5a623;box-shadow:0 0 16px #f5a62333}.cad-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:1.5rem}.cad-reference-layout{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;align-items:start}.cad-cadence-list{background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:1rem;position:sticky;top:65px}.cad-cadence-group{margin-bottom:1rem}.cad-cadence-group:last-child{margin-bottom:0}.cad-cadence-group-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.4rem;padding:0 .25rem}.cad-cadence-item{display:flex;flex-direction:column;align-items:flex-start;width:100%;background:none;border:none;border-left:2px solid transparent;color:#f0ede4a6;padding:.5rem .75rem;border-radius:0 6px 6px 0;cursor:pointer;text-align:left;transition:all .15s;margin-bottom:2px}.cad-cadence-item:hover{background:#ffffff0d;color:#f0ede4;border-left-color:#f5a62366}.cad-cadence-item--active{background:#f5a62314;color:#f5a623;border-left-width:3px}.cad-cadence-item-name{font-size:.88rem;font-weight:600;line-height:1.3}.cad-cadence-item-formula{font-size:.72rem;color:#f0ede466;font-family:Courier New,monospace}.cad-cadence-item--active .cad-cadence-item-formula{color:#f5a62399}.cad-detail-panel{background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:1.75rem;min-height:400px}.cad-detail-header{margin-bottom:1.25rem}.cad-detail-name{font-family:Libre Baskerville,Georgia,serif;font-size:1.5rem;font-weight:700;color:#f5a623;margin:0 0 .2rem}.cad-detail-name-en{font-size:.82rem;color:#f0ede466;margin:0 0 .85rem}.cad-detail-badges{display:flex;flex-wrap:wrap;gap:.5rem}.cad-formula-badge{background:#f5a62326;border:1px solid rgba(245,166,35,.4);color:#f5a623;padding:.25rem .75rem;border-radius:999px;font-size:.85rem;font-weight:700;font-family:Courier New,monospace;letter-spacing:.05em}.cad-category-badge{padding:.25rem .7rem;border-radius:999px;font-size:.78rem;font-weight:600;border:1px solid transparent}.cad-feeling-badge{background:#ffffff12;border:1px solid rgba(255,255,255,.1);color:#f0ede4a6;padding:.25rem .7rem;border-radius:999px;font-size:.78rem}.cad-difficulty-badge{background:#5eead414;border:1px solid rgba(94,234,212,.25);color:#5eead4;padding:.25rem .7rem;border-radius:999px;font-size:.78rem;font-weight:600}.cad-detail-description{color:#f0ede4bf;font-size:.95rem;line-height:1.7;margin:0 0 1.5rem}.cad-detail-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#f0ede459;margin-bottom:.6rem}.cad-detail-variants{margin-bottom:1.5rem}.cad-variants-list{list-style:none;padding:0;margin:0}.cad-variants-list li{padding:.35rem 0 .35rem 1.25rem;position:relative;font-size:.88rem;color:#f0ede4a6;line-height:1.5}.cad-variants-list li:before{content:"→";position:absolute;left:0;color:#f5a62380}.cad-detail-playback{border-top:1px solid rgba(255,255,255,.07);padding-top:1.25rem}.cad-minor-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.cad-mode-toggle-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#f0ede48c;padding:.3rem 1rem;border-radius:6px;font-size:.82rem;cursor:pointer;transition:all .15s}.cad-mode-toggle-btn:hover{background:#00d4aa14;border-color:#00d4aa4d;color:#00d4aa}.cad-mode-toggle-btn.active{background:#00d4aa26;border-color:#00d4aa;color:#00d4aa;font-weight:700}.cad-minor-note{font-size:.82rem;color:#a78bfabf;background:#a78bfa14;border:1px solid rgba(167,139,250,.2);border-radius:6px;padding:.4rem .75rem;margin-bottom:1rem}.cad-play-btn{display:flex;align-items:center;gap:.6rem;background:#0f766e33;border:1px solid rgba(15,118,110,.5);color:#5eead4;padding:.65rem 1.5rem;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .18s;margin:1rem 0 .5rem}.cad-play-btn:hover:not(:disabled){background:#0f766e59;border-color:#5eead4;box-shadow:0 0 18px #5eead440}.cad-play-btn:disabled{opacity:.65;cursor:not-allowed}.cad-play-btn--playing{background:#0f766e4d;border-color:#5eead4}.cad-play-btn-icon{font-size:1rem}.cad-play-btn-icon--pulse{animation:pulse .8s ease-in-out infinite;display:inline-block}.cad-play-hint{font-size:.75rem;color:#f0ede44d;margin:.25rem 0 0}.cad-detail-empty{display:flex;align-items:center;justify-content:center;min-height:300px;color:#f0ede44d;font-size:.95rem}.cad-quiz-container{max-width:680px;margin:0 auto}.cad-quiz-setup{background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:2rem}.cad-quiz-setup-title{font-family:Libre Baskerville,Georgia,serif;font-size:1.35rem;color:#f5a623;margin:0 0 1.75rem}.cad-quiz-option-group{margin-bottom:1.5rem}.cad-quiz-option-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#f0ede466;margin-bottom:.5rem}.cad-quiz-option-btns{display:flex;gap:.5rem;flex-wrap:wrap}.cad-diff-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:#f0ede4b3;padding:.45rem 1.25rem;border-radius:7px;font-size:.88rem;cursor:pointer;transition:all .15s}.cad-diff-btn:hover{background:#f5a6231a;border-color:#f5a62359;color:#f5a623}.cad-diff-btn.active{background:#f5a6232e;border-color:#f5a623;color:#f5a623;font-weight:700}.cad-quiz-option-hint{font-size:.8rem;color:#f0ede466;margin:.4rem 0 0;line-height:1.5}.cad-start-btn{display:block;width:100%;background:linear-gradient(135deg,#f5a62340,#f5a62326);border:1px solid rgba(245,166,35,.5);color:#f5a623;padding:.85rem 2rem;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .18s;text-align:center;margin-top:.5rem}.cad-start-btn:hover{background:linear-gradient(135deg,#f5a62359,#f5a62338);box-shadow:0 0 20px #f5a62340}.cad-progress-wrapper{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.cad-progress-bar{flex:1;height:6px;background:#ffffff12;border-radius:999px;overflow:hidden}.cad-progress-fill{height:100%;background:linear-gradient(90deg,#f5a623,#fbbf24);border-radius:999px;transition:width .35s ease}.cad-progress-label{font-size:.8rem;color:#f0ede466;white-space:nowrap}.cad-question-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1.5rem;text-align:center;margin-bottom:1rem;position:relative}.cad-streak-badge{position:absolute;top:.75rem;right:.75rem;background:#fbbf241f;border:1px solid rgba(251,191,36,.3);color:#fbbf24;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:700}.cad-question-mode-label{font-size:.78rem;color:#f0ede466;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem}.cad-question-formula-display{font-family:Libre Baskerville,Georgia,serif;font-size:clamp(2rem,8vw,3.5rem);font-weight:700;color:#f5a623;letter-spacing:.05em;margin:.5rem 0 1rem}.cad-question-tonic{font-size:.85rem;color:#f0ede480;margin-bottom:.75rem}.cad-question-tonic strong{color:#f0ede4cc}.cad-play-btn--quiz{margin:.5rem auto;justify-content:center}.cad-answers-grid{display:grid;grid-template-columns:1fr 1fr;gap:.65rem;margin-bottom:1rem}.cad-answer-btn{display:flex;flex-direction:column;align-items:flex-start;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:#f0ede4cc;padding:.85rem 1rem;border-radius:10px;cursor:pointer;text-align:left;transition:all .15s;font-size:.88rem}.cad-answer-btn:hover:not(:disabled){background:#f5a6231a;border-color:#f5a62359;color:#f5a623}.cad-answer-btn:disabled{cursor:not-allowed}.cad-answer-btn-name{font-weight:600;font-size:.9rem;line-height:1.3;margin-bottom:.15rem}.cad-answer-btn-formula{font-size:.72rem;color:#f0ede459;font-family:Courier New,monospace}.cad-answer-btn--correct{background:#4ade801f!important;border-color:#4ade80!important;color:#4ade80!important;box-shadow:0 0 14px #4ade8033}.cad-answer-btn--correct .cad-answer-btn-formula{color:#4ade8080!important}.cad-answer-btn--wrong{background:#f871711a!important;border-color:#f87171!important;color:#f87171!important}.cad-answer-btn--wrong .cad-answer-btn-formula{color:#f8717166!important}.cad-feedback-panel{border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.6rem;border:1px solid}.cad-feedback-panel--correct{background:#4ade8012;border-color:#4ade804d}.cad-feedback-panel--wrong{background:#f8717112;border-color:#f871714d}.cad-feedback-icon{font-size:1.5rem;font-weight:700}.cad-feedback-panel--correct .cad-feedback-icon{color:#4ade80}.cad-feedback-panel--wrong .cad-feedback-icon{color:#f87171}.cad-feedback-text{font-size:.95rem;color:#f0ede4d9}.cad-feedback-desc{font-size:.85rem;color:#f0ede48c;line-height:1.6;margin:0}.cad-next-btn{align-self:flex-end;background:#f5a6232e;border:1px solid rgba(245,166,35,.45);color:#f5a623;padding:.5rem 1.5rem;border-radius:7px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .15s;margin-top:.25rem}.cad-next-btn:hover{background:#f5a62347;box-shadow:0 0 14px #f5a62333}.cad-results{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:1.5rem 0}.cad-results-score-circle{display:flex;flex-direction:column;align-items:center;justify-content:center;width:130px;height:130px;border-radius:50%;border:4px solid #f5a623;background:#f5a62314;box-shadow:0 0 30px #f5a62333}.cad-results-pct{font-size:2rem;font-weight:700;color:#f5a623;line-height:1}.cad-results-fraction{font-size:.82rem;color:#f0ede473}.cad-results-label{font-size:1rem;color:#f0ede4bf;text-align:center;margin:0}.cad-results-stats{display:flex;gap:2.5rem}.cad-results-stat{display:flex;flex-direction:column;align-items:center;gap:.15rem}.cad-results-stat-value{font-size:1.5rem;font-weight:700;color:#f5a623}.cad-results-stat-name{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#f0ede459}.cad-results-review{width:100%;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:1rem 1.25rem}.cad-results-review-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#f0ede459;margin-bottom:.75rem}.cad-results-review-item{display:flex;align-items:flex-start;gap:.5rem;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:.85rem}.cad-results-review-item:last-child{border-bottom:none}.cad-results-review-num{color:#f0ede44d;flex-shrink:0}.cad-results-review-icon{flex-shrink:0;font-weight:700}.cad-results-review-item.correct .cad-results-review-icon{color:#4ade80}.cad-results-review-item.wrong .cad-results-review-icon{color:#f87171}.cad-results-review-text{color:#f0ede4b3;line-height:1.5}.cad-results-review-text strong{color:#f5a623}.cad-results-review-text em{font-style:italic;color:#f0ede480}.cad-results-actions{display:flex;flex-direction:column;gap:.6rem;width:100%}.cad-restart-btn{background:none;border:1px solid rgba(255,255,255,.12);color:#f0ede480;padding:.6rem 1.5rem;border-radius:8px;font-size:.88rem;cursor:pointer;transition:all .15s;text-align:center}.cad-restart-btn:hover{border-color:#f5a6234d;color:#f5a623b3}.cad-seo{margin-top:1rem}@media (max-width: 768px){.cad-reference-layout{grid-template-columns:1fr}.cad-cadence-list{position:static;display:flex;flex-wrap:wrap;gap:.25rem;padding:.75rem}.cad-cadence-group{margin-bottom:0}.cad-cadence-group-label{display:none}.cad-cadence-item{flex-direction:row;align-items:center;gap:.4rem;padding:.35rem .65rem;border-left-width:0;border-bottom:2px solid transparent;border-radius:6px}.cad-cadence-item--active{border-bottom-color:#f5a623;border-left-width:0}.cad-cadence-item-name{font-size:.8rem}.cad-cadence-item-formula{font-size:.68rem}.cad-answers-grid{grid-template-columns:1fr}.cad-results-stats{gap:1.5rem}}@media (max-width: 480px){.cad-main{padding:1rem}.cad-detail-panel,.cad-quiz-setup{padding:1.25rem}.cad-mode-tabs{gap:.5rem}.cad-mode-tab{padding:.5rem 1rem;font-size:.9rem}.cad-question-formula-display{font-size:2rem}}.dict-root{min-height:100vh;background:#0d0d1a;color:#f0ede4eb;font-family:var(--font-editorial, "Libre Baskerville", Georgia, serif)}.dict-header{display:flex;align-items:center;gap:1.25rem;padding:1.5rem 2rem 1rem;border-bottom:1px solid rgba(240,237,228,.08)}.dict-back-btn{background:none;border:1px solid rgba(240,237,228,.18);color:#f0ede499;padding:.4rem .9rem;border-radius:6px;cursor:pointer;font-size:.85rem;white-space:nowrap;transition:border-color .15s,color .15s}.dict-back-btn:hover{border-color:#f0ede466;color:#f0ede4e6}.dict-title{font-size:1.6rem;font-weight:700;color:#f0ede4f2;margin:0}.dict-subtitle{font-size:.85rem;color:#f0ede473;margin:.15rem 0 0}.dict-layout{display:flex;gap:0;min-height:calc(100vh - 100px)}.dict-sidebar{width:300px;min-width:260px;background:#ffffff06;border-right:1px solid rgba(240,237,228,.08);padding:1.5rem 1.25rem;display:flex;flex-direction:column;gap:1rem}.dict-main{flex:1;padding:1.75rem 2rem;overflow-x:auto}.dict-config{display:flex;flex-direction:column;gap:1rem}.dict-config-row{display:flex;flex-direction:column;gap:.4rem}.dict-config-row--inline{flex-direction:row;gap:1rem}.dict-config-sub{flex:1;display:flex;flex-direction:column;gap:.4rem}.dict-config-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.07em;color:#f0ede473;font-family:var(--font-handwritten, "Caveat", cursive);font-size:.9rem;text-transform:none;letter-spacing:0}.dict-config-label--inline{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.82rem;color:#f0ede499}.dict-checkbox{accent-color:#f5a623;cursor:pointer}.dict-mode-toggle{display:flex;gap:0;border:1px solid rgba(240,237,228,.15);border-radius:6px;overflow:hidden}.dict-mode-btn{flex:1;background:none;border:none;color:#f0ede480;padding:.4rem .6rem;cursor:pointer;font-size:.82rem;transition:background .15s,color .15s}.dict-mode-btn:hover{background:#f5a62314;color:#f0ede4cc}.dict-mode-btn--active{background:#f5a6232e;color:#f5a623;font-weight:600}.dict-mode-btn:disabled{opacity:.4;cursor:not-allowed}.dict-ts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.3rem}.dict-ts-btn{background:#ffffff0a;border:1px solid rgba(240,237,228,.12);color:#f0ede499;border-radius:5px;padding:.35rem .2rem;font-size:.78rem;cursor:pointer;transition:all .15s}.dict-ts-btn:hover{border-color:#f5a62366;color:#f0ede4e6}.dict-ts-btn--active{background:#f5a6232e;border-color:#f5a623;color:#f5a623;font-weight:700}.dict-ts-btn:disabled{opacity:.4;cursor:not-allowed}.dict-select{background:#ffffff0d;border:1px solid rgba(240,237,228,.15);color:#f0ede4d9;border-radius:6px;padding:.45rem .6rem;font-size:.82rem;cursor:pointer;width:100%}.dict-select:disabled{opacity:.4;cursor:not-allowed}.dict-stepper{display:flex;align-items:center;gap:.5rem}.dict-step-btn{width:28px;height:28px;background:#ffffff0f;border:1px solid rgba(240,237,228,.15);color:#f0ede4b3;border-radius:4px;cursor:pointer;font-size:1rem;line-height:1;transition:background .15s;display:flex;align-items:center;justify-content:center}.dict-step-btn:hover{background:#f5a6231f}.dict-step-btn:disabled{opacity:.3;cursor:not-allowed}.dict-step-val{min-width:24px;text-align:center;font-size:.95rem;color:#f0ede4e6}.dict-range{width:100%;accent-color:#f5a623;cursor:pointer}.dict-range:disabled{opacity:.4;cursor:not-allowed}.dict-tempo-bpm{font-size:.78rem;color:#f5a623cc;margin-left:.4rem}.dict-generate-btn{background:linear-gradient(135deg,#f5a623,#e08b0a);border:none;color:#1a1a2e;font-weight:700;font-size:.95rem;padding:.7rem 1.25rem;border-radius:8px;cursor:pointer;width:100%;transition:opacity .15s,transform .1s}.dict-generate-btn:hover{opacity:.9;transform:translateY(-1px)}.dict-generate-btn:active{transform:translateY(0)}.dict-generate-btn--secondary{background:#ffffff0f;color:#f0ede4b3;border:1px solid rgba(240,237,228,.15)}.dict-generate-btn--secondary:hover{background:#ffffff1a}.dict-generate-btn--small{width:auto;padding:.5rem .9rem;font-size:.85rem}.dict-playback-row{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid rgba(240,237,228,.07)}.dict-playback{display:flex;align-items:center;gap:1rem;flex:1}.dict-playback-controls{display:flex;gap:.5rem}.dict-play-btn,.dict-stop-btn{display:flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;border:none;transition:opacity .15s,transform .1s}.dict-play-btn:active,.dict-stop-btn:active{transform:scale(.97)}.dict-play-btn{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.dict-play-btn:hover{opacity:.88}.dict-play-btn:disabled{opacity:.35;cursor:not-allowed}.dict-stop-btn{background:#ef44442e;border:1px solid rgba(239,68,68,.4);color:#ef4444}.dict-stop-btn:hover{background:#ef444447}.dict-playback-status{display:flex;align-items:center}.dict-status-pill{display:flex;align-items:center;gap:.5rem;font-size:.82rem;padding:.3rem .75rem;border-radius:20px;background:#ffffff0d;border:1px solid rgba(240,237,228,.1);color:#f0ede48c}.dict-status-pill--playing{background:#22c55e1a;border-color:#22c55e4d;color:#22c55e}.dict-status-pill--prep{background:#f5a6231a;border-color:#f5a6234d;color:#f5a623}.dict-status-pill--done{background:#22c55e14;border-color:#22c55e33;color:#22c55ecc}.dict-pulse{width:8px;height:8px;border-radius:50%;background:#f5a623;animation:dict-blink 1s infinite;display:inline-block}.dict-pulse--green{background:#22c55e}@keyframes dict-blink{0%,to{opacity:1}50%{opacity:.25}}.dict-display{display:flex;flex-direction:column;gap:.5rem}.dict-display-empty{color:#f0ede44d;font-size:.9rem;padding:1.5rem;text-align:center}.dict-display-label{font-size:.78rem;color:#f0ede466;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.2rem}.dict-measures-row{display:flex;align-items:center;flex-wrap:wrap;gap:.25rem}.dict-measure{display:flex;align-items:center}.dict-event-block{transition:background .2s,border-color .2s}.dict-event-block--active{box-shadow:0 0 0 2px #f5a623}.dict-practice-display{background:#ffffff08;border:1px solid rgba(240,237,228,.1);border-radius:10px;padding:1.25rem 1.5rem;overflow-x:auto}.dict-section-label{font-size:.8rem;color:#f0ede466;text-transform:uppercase;letter-spacing:.07em;display:block;margin-bottom:.75rem}.dict-dictation-hint{background:#f5a62312;border:1px solid rgba(245,166,35,.2);border-radius:8px;padding:.75rem 1rem;font-size:.88rem;color:#f5a623d9;margin-bottom:1.25rem;text-align:center}.dict-user-input{display:flex;flex-direction:column;gap:1rem}.dict-user-input-header{display:flex;align-items:center;justify-content:space-between}.dict-input-actions{display:flex;gap:.5rem}.dict-input-clear{background:none;border:1px solid rgba(239,68,68,.3);color:#ef4444b3;padding:.3rem .7rem;border-radius:5px;font-size:.78rem;cursor:pointer;transition:all .15s}.dict-input-clear:hover{background:#ef44441a}.dict-input-clear:disabled{opacity:.4;cursor:not-allowed}.dict-user-measures{display:flex;flex-wrap:wrap;gap:.5rem}.dict-user-measure-wrap{position:relative;background:#ffffff08;border:1px solid rgba(240,237,228,.1);border-radius:8px;padding:.5rem .75rem .35rem}.dict-measure-fill-bar{height:3px;background:#f0ede414;border-radius:2px;margin-top:.4rem;overflow:hidden}.dict-measure-fill-bar-inner{height:100%;background:#f5a62380;border-radius:2px;transition:width .2s}.dict-measure-fill-bar-inner--full{background:#22c55e}.dict-backspace-btn{position:absolute;top:4px;right:4px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#ef4444b3;width:20px;height:20px;border-radius:3px;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.dict-backspace-btn:hover{background:#ef444433}.dict-input-hint{font-size:.82rem;color:#22c55ebf;text-align:center;padding:.5rem}.dict-toolbar{background:#ffffff08;border:1px solid rgba(240,237,228,.1);border-radius:10px;padding:.85rem 1rem;display:flex;flex-direction:column;gap:.75rem}.dict-toolbar-group{display:flex;flex-direction:column;gap:.4rem}.dict-toolbar-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:#f0ede459}.dict-toolbar-figures{display:flex;flex-wrap:wrap;gap:.35rem}.dict-fig-btn{width:40px;height:50px;background:#f5a62312;border:1px solid rgba(245,166,35,.2);color:#f5a623;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,transform .1s}.dict-fig-btn:hover{background:#f5a6232e;border-color:#f5a62380;transform:translateY(-1px)}.dict-fig-btn:active{transform:translateY(0)}.dict-fig-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}.dict-fig-btn--rest{background:#00d4aa0f;border-color:#00d4aa33;color:#00d4aa}.dict-fig-btn--rest:hover{background:#00d4aa24;border-color:#00d4aa73}.dict-submit-row{display:flex;align-items:center;gap:1rem;margin-top:.5rem}.dict-submit-btn{background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;color:#fff;font-weight:700;font-size:.95rem;padding:.7rem 1.5rem;border-radius:8px;cursor:pointer;transition:opacity .15s,transform .1s}.dict-submit-btn:hover{opacity:.88;transform:translateY(-1px)}.dict-submit-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}.dict-submit-hint{font-size:.8rem;color:#f0ede459}.dict-correction{display:flex;flex-direction:column;gap:1.25rem}.dict-score-header{display:flex;align-items:center;gap:1.5rem;padding:1.25rem;background:#ffffff08;border:1px solid rgba(240,237,228,.1);border-radius:12px}.dict-score-circle{width:80px;height:80px;border-radius:50%;border:3px solid currentColor;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0}.dict-score-pct{font-size:1.4rem;font-weight:700;line-height:1}.dict-score-label{font-size:.62rem;text-transform:uppercase;letter-spacing:.05em;opacity:.8}.dict-score-breakdown{display:flex;flex-wrap:wrap;gap:.5rem}.dict-score-measure-chip{display:flex;flex-direction:column;align-items:center;background:#ffffff0a;border:1px solid rgba(240,237,228,.1);border-radius:6px;padding:.35rem .6rem}.dict-score-measure-num{font-size:.68rem;color:#f0ede466}.dict-score-measure-pct{font-size:.9rem;font-weight:700}.dict-correction-legend{display:flex;flex-wrap:wrap;gap:.5rem}.dict-legend-chip{font-size:.75rem;padding:.2rem .6rem;border-radius:12px;border:1px solid transparent}.dict-legend-chip--correct{background:#22c55e33;border-color:#22c55e44;color:#22c55e}.dict-legend-chip--wrong{background:#ef444433;border-color:#ef444444;color:#ef4444}.dict-legend-chip--missing{background:#f59e0b33;border-color:#f59e0b44;color:#f59e0b}.dict-legend-chip--extra{background:#a855f733;border-color:#a855f744;color:#a855f7}.dict-correction-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.dict-correction-col{background:#ffffff08;border:1px solid rgba(240,237,228,.1);border-radius:8px;padding:1rem;overflow-x:auto}.dict-correction-col-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.07em;color:#f0ede466;margin-bottom:.75rem}.dict-correction-detail{background:#ffffff08;border:1px solid rgba(240,237,228,.08);border-radius:8px;padding:.85rem 1rem;display:flex;flex-direction:column;gap:.35rem}.dict-detail-row{font-size:.83rem;color:#f0ede4a6;line-height:1.5}.dict-detail-row strong{color:#f0ede4d9}.dict-corrected-actions{display:flex;gap:.75rem;margin-top:.5rem}.dict-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:300px;color:#f0ede44d;text-align:center}.dict-empty-icon{font-size:3.5rem;line-height:1}.dict-seo{margin-top:3rem}@media (max-width: 900px){.dict-layout{flex-direction:column}.dict-sidebar{width:100%;min-width:0;border-right:none;border-bottom:1px solid rgba(240,237,228,.08)}.dict-correction-grid{grid-template-columns:1fr}}@media (max-width: 600px){.dict-header,.dict-main{padding:1rem}.dict-playback-row{flex-wrap:wrap;gap:.75rem}.dict-ts-grid{grid-template-columns:repeat(4,1fr)}}.satb-root{min-height:100vh;background:#0f0e17;color:#e8e4d9;font-family:Libre Baskerville,Georgia,serif}.satb-hero{background:linear-gradient(160deg,#1a1830,#0f0e17 60%);padding:5rem 1.5rem 4rem;text-align:center;border-bottom:1px solid rgba(245,166,35,.15)}.satb-hero-inner{max-width:720px;margin:0 auto}.satb-hero-badge{display:inline-block;background:#f5a6231f;color:#f5a623;border:1px solid rgba(245,166,35,.3);border-radius:20px;padding:.25rem .85rem;font-size:.75rem;font-family:Caveat,cursive;letter-spacing:.04em;margin-bottom:1.25rem;text-transform:uppercase}.satb-hero-title{font-size:clamp(2rem,5vw,3.2rem);font-weight:700;color:#f0ede4;margin:0 0 1rem;line-height:1.15}.satb-hero-desc{font-size:1.1rem;color:#e8e4d9bf;line-height:1.7;margin:0 0 2rem}.satb-hero-cta{display:inline-block;background:#f5a623;color:#0f0e17;border:none;border-radius:8px;padding:.85rem 2.2rem;font-size:1.05rem;font-weight:700;font-family:Libre Baskerville,Georgia,serif;cursor:pointer;transition:opacity .18s,transform .18s;text-decoration:none}.satb-hero-cta:hover{opacity:.88;transform:translateY(-2px)}.satb-hero-note{margin-top:.85rem;font-size:.78rem;color:#e8e4d966;font-family:sans-serif}.satb-section{padding:4rem 1.5rem}.satb-section--alt{background:#ffffff06}.satb-section-inner{max-width:860px;margin:0 auto}.satb-section-title{font-size:1.6rem;font-weight:700;color:#f5a623;margin:0 0 .5rem}.satb-section-sub{color:#e8e4d98c;font-size:.92rem;margin:0 0 2rem;font-family:sans-serif}.satb-prose p{color:#e8e4d9b8;font-size:.97rem;line-height:1.8;margin:0 0 1.1rem}.satb-prose strong{color:#f0ede4}.satb-errors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem;margin-top:2rem}.satb-error-card{display:flex;gap:.85rem;align-items:flex-start;background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:1rem 1.1rem}.satb-error-icon{font-size:1.4rem;flex-shrink:0;margin-top:.05rem}.satb-error-title{font-size:.92rem;font-weight:700;color:#f0ede4;margin-bottom:.2rem}.satb-error-desc{font-size:.83rem;color:#e8e4d980;font-family:sans-serif;line-height:1.5}.satb-steps{display:flex;flex-direction:column;gap:2rem;margin-top:2rem}.satb-step{display:flex;gap:1.5rem;align-items:flex-start}.satb-step-num{flex-shrink:0;width:2.2rem;height:2.2rem;background:#f5a623;color:#0f0e17;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;margin-top:.1rem}.satb-step-title{font-size:1rem;font-weight:700;color:#f0ede4;margin-bottom:.4rem}.satb-step-desc{font-size:.9rem;color:#e8e4d9a6;font-family:sans-serif;line-height:1.7;margin:0}.satb-step-desc strong{color:#f0ede4}.satb-forwhom-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem;margin-top:2rem}.satb-forwhom-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:1.4rem 1.2rem;text-align:center}.satb-forwhom-icon{font-size:2rem;display:block;margin-bottom:.6rem}.satb-forwhom-label{font-size:.9rem;font-weight:700;color:#f0ede4;margin-bottom:.4rem}.satb-forwhom-desc{font-size:.8rem;color:#e8e4d980;font-family:sans-serif;line-height:1.5}.satb-final-cta{padding:5rem 1.5rem;text-align:center;background:linear-gradient(160deg,#1a1830,#0f0e17);border-top:1px solid rgba(245,166,35,.15)}.satb-final-cta-inner{max-width:560px;margin:0 auto}.satb-final-cta-title{font-size:1.8rem;font-weight:700;color:#f0ede4;margin:0 0 .75rem}.satb-final-cta-desc{color:#e8e4d999;font-size:1rem;margin:0 0 2rem;font-family:sans-serif}@media (max-width: 600px){.satb-errors-grid{grid-template-columns:1fr}.satb-forwhom-grid{grid-template-columns:repeat(2,1fr)}.satb-step{flex-direction:column;gap:.75rem}.satb-step-num{width:1.8rem;height:1.8rem;font-size:.9rem}}.tc-intro{background:#f5a6230d;border-top:1px solid rgba(245,166,35,.12);border-bottom:1px solid rgba(245,166,35,.12);padding:.9rem 1.5rem}.tc-intro-inner{max-width:860px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem 1.5rem}.tc-intro-inner p{color:#f0ede4a6;font-size:.88rem;line-height:1.65;margin:0;flex:1 1 400px}.tc-intro-inner strong{color:#f0ede4e0}.tc-intro-link{font-size:.82rem;color:#f5a623;text-decoration:none;white-space:nowrap;opacity:.8;flex-shrink:0}.tc-intro-link:hover{opacity:1;text-decoration:underline}.hw-grid-wrapper{max-width:960px;margin:0 auto;padding:2.5rem 1.5rem 4rem}.hw-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.hw-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1.6rem 1.4rem 1.2rem;text-align:left;cursor:pointer;transition:border-color .18s,transform .18s,background .18s;display:flex;flex-direction:column;gap:.5rem}.hw-card:hover{border-color:#f5a62373;background:#f5a6230d;transform:translateY(-2px)}.hw-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.hw-card-icon{font-size:2rem;line-height:1}.hw-card-badge{font-size:.7rem;font-weight:700;font-family:sans-serif;letter-spacing:.04em;padding:.2rem .6rem;border-radius:20px;border:1px solid;text-transform:uppercase}.hw-card-title{font-family:Libre Baskerville,Georgia,serif;font-size:1.05rem;font-weight:700;color:#f0ede4;margin:0}.hw-card-desc{font-family:sans-serif;font-size:.85rem;color:#f0ede494;line-height:1.6;margin:0;flex:1}.hw-card-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.hw-card-tag{font-size:.72rem;font-family:sans-serif;color:#f0ede473;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:4px;padding:.15rem .5rem}.hw-card-cta{font-size:.82rem;color:#f5a623;font-family:sans-serif;margin-top:.5rem;opacity:.75}.hw-card:hover .hw-card-cta{opacity:1}
