@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.grid{display:grid}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}}:root{color-scheme:light;--ink:#17212b;--muted:#5d6875;--paper:#fbfaf7;--line:#d9dde2;--accent:#187f68;--accent-strong:#0f5f4e;--gold:#c58a1f;--rose:#b95b62;--panel:#fff;--shadow:0 24px 80px #17212b1f}*{box-sizing:border-box}body{background:var(--paper);min-width:320px;color:var(--ink);letter-spacing:0;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}.shell{flex-direction:column;min-height:100vh;display:flex}.topbar{border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);z-index:20;background:#fbfaf7eb;justify-content:space-between;align-items:center;height:68px;padding:0 clamp(16px,4vw,48px);display:flex;position:sticky;top:0}.brand{align-items:center;gap:10px;min-width:0;font-weight:800;display:inline-flex}.brand-mark{--logo-black:#000;--logo-white:#fff;filter:drop-shadow(0 6px 14px #17212b1f);flex:none;width:38px;height:38px;display:block}.hero-logo{--logo-black:#000;--logo-white:#fff;filter:drop-shadow(0 18px 32px #17212b24);margin-bottom:20px;display:block}.nav-links{color:var(--muted);align-items:center;gap:10px;font-size:.94rem;display:flex}.nav-links a,.nav-links button{color:inherit;cursor:pointer;background:0 0;border:0;border-radius:8px;padding:9px 10px}.nav-links a:hover,.nav-links button:hover{color:var(--ink);background:#eef1ef}.page{width:min(1180px,100% - 32px);margin:0 auto;padding:36px 0 64px}.hero{grid-template-columns:minmax(0,1fr) minmax(320px,.82fr);align-items:center;gap:clamp(24px,5vw,72px);min-height:calc(100vh - 112px);display:grid}.hero h1,.page-title{max-width:10ch;margin:0;font-size:clamp(2.4rem,8vw,6.7rem);line-height:.94}.lead{color:var(--muted);max-width:64ch;margin:24px 0 0;font-size:clamp(1rem,2vw,1.25rem);line-height:1.7}.actions{flex-wrap:wrap;gap:12px;margin-top:28px;display:flex}.button{border:1px solid var(--ink);background:var(--ink);color:#fff;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:0 16px;font-weight:750;display:inline-flex}.button.secondary{color:var(--ink);background:0 0}.button.ghost{border-color:var(--line);color:var(--ink);background:#fff}.button:disabled{cursor:not-allowed;opacity:.58}.piano-stage{border:1px solid var(--line);min-height:430px;box-shadow:var(--shadow);background:linear-gradient(160deg,#fff,#eef4f1 54%,#f5ead9);border-radius:8px;flex-direction:column;justify-content:flex-end;padding:28px;display:flex;overflow:hidden}.landing-stage{justify-content:center;gap:14px}.preview-topline{justify-content:space-between;align-items:center;gap:12px;display:flex}.preview-topline>strong{min-width:0;color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:1rem;font-weight:850;overflow:hidden}.preview-pills{flex-wrap:wrap;flex:none;justify-content:flex-end;gap:8px;display:flex}.preview-pill{color:#775015;background:#fff8ecd1;border:1px solid #d8c49f;border-radius:8px;flex:none;padding:6px 8px;font-size:.76rem;font-weight:850}.preview-status{grid-template-columns:minmax(0,1fr) 72px 72px;gap:8px;display:grid}.preview-status>div{background:#ffffffc2;border:1px solid #d9dde2e0;border-radius:8px;min-width:0;padding:8px 10px}.preview-status span,.preview-status strong{display:block}.preview-status span{text-transform:uppercase;margin-bottom:2px;font-size:.68rem;font-weight:850}.preview-status strong{text-overflow:ellipsis;white-space:nowrap;font-size:.88rem;overflow:hidden}.keyboard{grid-template-columns:repeat(var(--white-key-count,14),minmax(24px,1fr));background:#171717;border:1px solid #171717;border-radius:8px;gap:1px;height:clamp(168px,24vw,230px);display:grid;position:relative;overflow:hidden}.white-key{color:var(--muted);background:#fffdf8;border:0;border-radius:0 0 6px 6px;justify-content:center;align-items:flex-end;min-width:0;padding-bottom:12px;font-size:.78rem;display:flex;position:relative}.white-key.active{color:var(--accent-strong);background:#cce9dd}.black-key{z-index:2;background:#151515;border:0;border-radius:0 0 5px 5px;height:62%;position:absolute;top:0}.black-key.active{background:var(--gold)}.grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.landing-features{grid-template-columns:repeat(4,minmax(0,1fr))}.landing-footer{border-top:1px solid var(--line);color:var(--muted);justify-content:space-between;align-items:center;gap:18px;margin-top:18px;padding:22px 0 0;display:flex}.landing-footer>div{color:var(--ink);flex:none;align-items:center;gap:10px;font-weight:850;display:inline-flex}.landing-footer svg{--logo-black:#000;--logo-white:#fff;filter:drop-shadow(0 6px 14px #17212b1a);flex:none}.landing-footer p{text-align:right;max-width:62ch;margin:0}.panel,.card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:20px}.ai-panel{background:linear-gradient(135deg,#fff,#f4fbf8 52%,#fff8ec)}.panel h2,.card h3{margin:0 0 10px}.metric{font-size:2rem;font-weight:850}.muted{color:var(--muted)}.auth-layout{flex-direction:column;align-items:stretch;gap:16px;width:min(430px,100% - 32px);margin:0 auto;padding:48px 0;display:flex}.auth-home-action{justify-content:flex-start;display:flex}.auth-card-shell{justify-content:center;width:100%;display:flex}.auth-card-shell>*{width:min(100%,410px)}.form{gap:14px;display:grid}.field{gap:7px;display:grid}.field label{font-size:.9rem;font-weight:750}.field input{border:1px solid var(--line);min-height:46px;color:var(--ink);background:#fff;border-radius:8px;padding:0 12px}.error{color:#9f2f3e;background:#fff0f1;border:1px solid #f2c3c8;border-radius:8px;padding:10px 12px}.lesson-layout,.generator-layout{grid-template-columns:minmax(0,1fr) 330px;align-items:start;gap:18px;display:grid}.intent-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px;display:grid}.intent-option{border:1px solid var(--line);min-height:112px;color:var(--ink);cursor:pointer;text-align:left;background:#fffdf8;border-radius:8px;align-items:flex-start;gap:12px;padding:16px;display:flex}.intent-option.active{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent);background:#edf8f3}.intent-option span,.intent-option strong,.intent-option small{min-width:0;display:block}.intent-option strong{margin-bottom:6px}.intent-option small{color:var(--muted);line-height:1.45}.generator-controls{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px;display:grid}.generator-controls label{gap:7px;min-width:0;display:grid}.generator-controls label>span{font-size:.9rem;font-weight:750}.generator-controls select,.generator-controls textarea{border:1px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:8px}.generator-controls select{min-height:46px;padding:0 12px}.generator-controls textarea{resize:vertical;min-height:104px;padding:12px}.goal-field{grid-column:1/-1}.signal-list,.session-summary{gap:12px;display:grid}.signal-list>div,.session-summary>div{border:1px solid var(--line);background:#fffdf8;border-radius:8px;min-width:0;padding:12px}.signal-list span,.signal-list strong,.session-summary span,.session-summary strong{display:block}.signal-list strong,.session-summary strong{overflow-wrap:anywhere}.instruction-header{align-items:flex-start;gap:12px;display:flex}.instruction-header svg{color:var(--accent);flex:none}.instruction-content{gap:22px;margin-top:24px;display:grid}.instruction-block{border-top:1px solid var(--line);padding-top:22px}.instruction-block h3{margin:0 0 12px;font-size:1.15rem}.instruction-block p,.instruction-step p{color:var(--muted);margin:0 0 12px;line-height:1.7}.instruction-block ul{color:var(--ink);margin:8px 0 0;padding-left:22px;line-height:1.65}.instruction-steps{gap:12px;margin-top:14px;display:grid}.instruction-step{border:1px solid var(--line);background:#fffdf8;border-radius:8px;grid-template-columns:44px minmax(0,1fr);gap:12px;padding:14px;display:grid}.instruction-step>strong{color:var(--accent-strong);font-size:1.2rem}.instruction-step h4{margin:0 0 8px}.practice-staff{border:1px solid var(--line);background:#fffdf8;border-radius:8px;margin:18px 0 16px;overflow:hidden}.practice-staff svg{width:100%;height:auto;display:block}.staff-surface{fill:#fffdf8}.staff-line,.ledger-line{stroke:#25303b;stroke-width:1.8px;stroke-linecap:round}.staff-clef{fill:var(--ink);font-family:Georgia,Times New Roman,serif;font-size:74px;font-weight:700}.note-head{fill:#f7f1e3;stroke:var(--ink);stroke-width:2px}.note-stem{stroke:var(--ink);stroke-width:2.2px;stroke-linecap:round}.duration-guide{stroke:#bcc5cf;stroke-width:5px;stroke-linecap:round;opacity:.7}.accidental{fill:var(--ink);font-size:22px;font-weight:800}.beat-label{fill:var(--muted);text-anchor:middle;font-size:13px;font-weight:800}.staff-note.current .note-head{fill:#fff8e7;stroke:var(--gold)}.staff-note.current .note-stem,.staff-note.current .duration-guide{stroke:var(--gold)}.staff-note.pass .note-head{fill:#dff1df;stroke:#55975b}.staff-note.pass .note-stem,.staff-note.pass .duration-guide{stroke:#55975b}.staff-note.fail .note-head,.staff-note.missed .note-head{fill:#fff0f1;stroke:#b95b62}.staff-note.fail .note-stem,.staff-note.fail .duration-guide,.staff-note.missed .note-stem,.staff-note.missed .duration-guide{stroke:#b95b62}.staff-note.upcoming{opacity:.76}.staff-playhead line{stroke:var(--gold);stroke-width:3px;stroke-linecap:round}.staff-playhead circle{fill:var(--gold);stroke:#8b5d0f;stroke-width:1.5px}.countdown{width:fit-content;min-width:104px;min-height:104px;color:var(--accent-strong);background:#f2faf6;border:1px solid #b9c9c2;border-radius:8px;place-items:center;margin:18px auto 0;padding:12px 18px;display:grid}.countdown span{text-transform:uppercase;font-size:.76rem;font-weight:850}.countdown strong{font-size:3.2rem;line-height:.95}.status-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.progress-list{gap:12px;display:grid}@media(max-width:1100px){.landing-features{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:880px){.hero,.lesson-layout,.generator-layout{grid-template-columns:1fr}.hero{min-height:auto;padding-top:24px}.piano-stage{min-height:330px}.preview-topline{flex-direction:column;align-items:stretch}.preview-pills{justify-content:flex-start}.preview-status{grid-template-columns:1fr}.preview-pill{width:fit-content}.grid,.landing-features,.status-row,.intent-grid,.generator-controls{grid-template-columns:1fr}.landing-footer{flex-direction:column;align-items:flex-start}.landing-footer p{text-align:left}.nav-links{gap:2px;font-size:.86rem}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}
