@font-face{font-family:GSTFont;src:url(/fonts/GSTFont-VF.ttf) format("truetype");font-weight:400;font-style:normal}@tailwind base;@keyframes glow-pulse{0%{background-position:0% 50%;text-shadow:0 0 20px rgba(99,102,241,0)}50%{background-position:100% 50%;text-shadow:0 0 40px rgba(99,102,241,.4)}to{background-position:0% 50%;text-shadow:0 0 20px rgba(99,102,241,0)}}.animate-glow-pulse{animation:glow-pulse 6s ease infinite}@tailwind components;@tailwind utilities;body,div,button,input,select,textarea,span,p,h1,h2,h3,h4,h5,h6,[class^=text-]{font-family:GSTFont,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.rich-text-editor,.rich-text-display,.rich-text-editor *,.rich-text-display *{font-family:"GSTFont",inherit!important}.abcjs-gchord,.abcjs-text,.abcjs-vocal,.abcjs-title,.abcjs-subtitle,.abcjs-composer,.abcjs-caption{font-family:GSTFont!important}body{margin:0;padding:0;background-color:#0c0a09}@media print{html,body,#root,.app-main-content,main,.h-full{height:auto!important;overflow:visible!important;background:#fff!important;padding:0!important;margin:0!important;display:block!important;flex:none!important}body>:not(#root){display:none!important}#jazz-left-panel,#jazz-right-panel,.no-print,nav,header,footer,aside,button,select,label{display:none!important}.print-container{display:block!important;width:100%!important;padding:0!important;margin:0!important}.print-header{display:block!important;text-align:center!important;margin-bottom:2rem!important;border-bottom:2px solid #000!important;padding-bottom:1rem!important}.print-header h1{font-size:28pt!important;margin:0!important;font-family:serif!important;font-weight:800!important;color:#000!important}.grid-container{display:grid!important;grid-template-columns:repeat(5,1fr)!important;gap:15pt!important;width:100%!important;page-break-inside:avoid!important}.chord-column{display:flex!important;flex-direction:column!important;gap:10pt!important}.chord-card{border:none!important;box-shadow:none!important;padding:0!important;background:transparent!important}svg{width:100%!important;height:auto!important;max-width:140pt!important}.printable-routine{font-family:Georgia,Times New Roman,serif!important;color:#000!important;background:#fff!important}.journal-header{border-bottom:1px solid #000;border-top:4px solid #000;padding:1.5rem 0;margin-bottom:3rem}.timeline-item{display:flex;align-items:flex-start;gap:1.5rem;padding:1rem 0;border-bottom:.5pt solid #eee;page-break-inside:avoid}.timeline-bullet{width:10pt;height:10pt;border-radius:50%;margin-top:4pt;-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-only{display:block!important;height:auto!important;overflow:visible!important}.rich-text-display,.prose{color:#000!important;font-size:11pt!important}.prose *{color:#000!important}.rich-text-display img{border:none!important;box-shadow:none!important}.page-break{display:block!important;height:auto!important;min-height:0!important;overflow:visible!important}.page-break:not(:last-child){page-break-after:always!important}.page-break-before-always{page-break-before:always!important}@page{size:A4 portrait;margin:.5cm}}#print-mount{display:none!important}@media screen and (max-width:1024px)and (orientation:portrait){.landscape-prompt{display:flex!important}.app-main-content{display:none!important}}.landscape-prompt{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0c0a09;z-index:9999;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;padding:2rem}.print-only{display:none}.rich-text-display ul{list-style-type:disc!important;padding-left:16px!important;margin:4px 0!important}.rich-text-display li{display:list-item!important;margin-bottom:2px!important}.rich-text-display b,.rich-text-display strong{font-weight:900!important}.rich-text-display i,.rich-text-display em{font-style:italic!important}.scrollbar-hide::-webkit-scrollbar{display:none}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.abcjs-highlight{fill:#ef4444!important}@keyframes metronome-swing{0%{transform:rotate(-25deg)}to{transform:rotate(25deg)}}.animate-metronome-swing{animation:metronome-swing .5s ease-in-out infinite alternate}.perspective-2000{perspective:2000px}.transform-3d{transform-style:preserve-3d}.backface-hidden{backface-visibility:hidden;-webkit-backface-visibility:hidden}.rotate-y-180{transform:rotateY(180deg)}.rotate-x-180{transform:rotateX(180deg)}.custom-scroll::-webkit-scrollbar{width:6px}.custom-scroll::-webkit-scrollbar-track{background:#0000000d}.custom-scroll::-webkit-scrollbar-thumb{background:#0003;border-radius:10px}.custom-scroll:hover::-webkit-scrollbar-thumb{background:#0000004d}.dark .custom-scroll::-webkit-scrollbar-track{background:#ffffff0d}.dark .custom-scroll::-webkit-scrollbar-thumb{background:#fff3}.dark .custom-scroll:hover::-webkit-scrollbar-thumb{background:#ffffff4d}.rich-text-editor,.rich-text-display{font-family:inherit;line-height:1.6;color:#1e293b}.rich-text-editor h1,.rich-text-display h1{font-size:2.25rem;font-weight:900;margin-bottom:1rem;color:#0f172a;line-height:1.1}.rich-text-editor h2,.rich-text-display h2{font-size:1.875rem;font-weight:800;margin-bottom:.75rem;color:#1e293b;line-height:1.2}.rich-text-editor h3,.rich-text-display h3{font-size:1.5rem;font-weight:700;margin-bottom:.5rem;color:#334155;line-height:1.3}.rich-text-editor p,.rich-text-display p{margin-bottom:1.25rem}.rich-text-editor ul,.rich-text-display ul{list-style-type:disc!important;padding-left:1.75rem!important;margin-bottom:1.25rem!important}.rich-text-editor ol,.rich-text-display ol{list-style-type:decimal!important;padding-left:1.75rem!important;margin-bottom:1.25rem!important}.rich-text-editor li,.rich-text-display li{margin-bottom:.5rem!important;display:list-item!important}.rich-text-editor blockquote,.rich-text-display blockquote{border-left:4px solid #e2e8f0;padding-left:1.25rem;font-style:italic;color:#64748b;margin-bottom:1.25rem}.rich-text-editor pre,.rich-text-display pre{background:#f1f5f9;padding:1.25rem;border-radius:.75rem;overflow-x:auto;margin-bottom:1.25rem;font-family:monospace}.rich-text-editor b,.rich-text-editor strong,.rich-text-display b,.rich-text-display strong{font-weight:900!important}.rich-text-editor i,.rich-text-editor em,.rich-text-display i,.rich-text-display em{font-style:italic!important}.rich-text-editor u,.rich-text-display u{text-decoration:underline!important}.rich-text-editor img{transition:all .2s;border:4px solid transparent}.rich-text-editor img:hover{border-color:#a5b4fc}.rich-text-editor img.selected-img{border-color:#6366f1!important;box-shadow:0 0 20px #6366f133}.bg-corkboard{background-color:#bc8a5f;background-image:radial-gradient(circle at 1px 1px,rgba(0,0,0,.1) 1px,transparent 0);background-size:4px 4px;position:relative}.bg-corkboard:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,transparent 60%,rgba(0,0,0,.2) 100%);pointer-events:none}.paper-lines{background-image:repeating-linear-gradient(transparent,transparent 33px,rgba(0,0,0,.05) 33px,rgba(0,0,0,.05) 34px);background-size:100% 34px;line-height:34px!important}.paper-margin{position:relative}.paper-margin:before{content:"";position:absolute;left:40px;top:0;bottom:0;width:2px;background-color:#ff00001a}@keyframes reveal{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.reveal{animation:reveal .8s cubic-bezier(.2,.8,.2,1) forwards}@keyframes glow-pulse{0%,to{opacity:.3;filter:blur(40px)}50%{opacity:.6;filter:blur(60px)}}.glow-overlay{position:absolute;border-radius:50%;filter:blur(40px);animation:glow-pulse 10s ease-in-out infinite}.glass-morphism{background:#ffffff08;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0000005e}.hero-gradient{background:radial-gradient(circle at top center,rgba(79,70,229,.15) 0%,transparent 70%)}.text-gradient{background:linear-gradient(to bottom right,#fff 30%,#ffffff80);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}
