:root{--color-primary:#0d6efd;--color-primary-hover:#0b5ed7;--color-primary-soft:#e7f0ff;--color-secondary:#6c757d;--color-secondary-hover:#5c636a;--color-success:#4caf50;--color-success-hover:#45a049;--color-success-bg:#d4edda;--color-success-text:#155724;--color-danger:#f44336;--color-danger-hover:#d32f2f;--color-danger-bg:#fee2e2;--color-danger-text:#dc2626;--color-warning:#ff9800;--color-warning-bg:#ffeeba;--color-warning-text:#856404;--color-action-purple:#6200ea;--color-action-purple-hover:#3700b3;--color-white:#fff;--color-black:#000;--bg-primary:#fff;--bg-secondary:#f8f9fa;--bg-tertiary:#e9ecef;--bg-overlay:#0009;--text-primary:#212529;--text-secondary:#6c757d;--text-light:#f8f9fa;--border-color:#dee2e6;--border-color-dark:#333;--font-heading:"Poppins",sans-serif;--font-body:"Lato",sans-serif}*,:before,:after{box-sizing:border-box}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);margin:0;padding-top:70px}.App{text-align:center}h1,h2,h3{font-family:var(--font-heading);font-weight:600}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.25rem}p{line-height:1.6}.container{max-width:1100px;margin:0 auto;padding:40px 20px}.grid{gap:30px;display:grid}.hero{color:var(--bg-primary);text-align:center;background-image:linear-gradient(#0009,#0009),url(/assets/hd-piano_web-5xZhnLho.jpg);background-position:50%;background-size:cover;padding:150px 20px}.hero-content{max-width:800px;margin:0 auto}.hero h1{color:var(--bg-primary);margin-bottom:.5rem;font-size:3.5rem}.hero p{margin:0 0 40px;font-size:1.2rem;display:none}.btn{font-family:var(--font-body);cursor:pointer;text-transform:uppercase;border-radius:50px;margin:0 10px;padding:12px 30px;font-size:.9rem;font-weight:700;text-decoration:none;transition:all .2s ease-in-out;display:inline-block}.btn-primary{background-color:var(--color-primary);color:#fff;border:none}.btn-primary:hover,.btn-primary:focus{background-color:var(--color-primary-hover);transform:scale(1.02)}.btn-light{background-color:var(--color-white);color:var(--text-primary);border:none}.btn-light:hover,.btn-light:focus{background-color:var(--bg-secondary);transform:scale(1.02)}.btn-secondary{color:var(--color-primary);border:1px solid var(--color-primary);background-color:#0000}.btn-secondary:hover,.btn-secondary:focus{background-color:var(--color-primary-soft)}.btn-dark{background-color:var(--color-black);color:var(--color-white);border:none}.btn-dark:hover,.btn-dark:focus{background-color:#333}.mb-3{margin-bottom:1rem!important}.btn:disabled,.btn[disabled]{opacity:.65;cursor:not-allowed;pointer-events:none}.btn-success{background-color:var(--color-success);color:#fff;border:none}.btn-success:hover,.btn-success:focus{background-color:var(--color-success-hover);transform:scale(1.02)}.btn-danger{color:var(--color-danger);border:1px solid var(--color-danger);background-color:#0000}.btn-danger:hover,.btn-danger:focus{background-color:var(--color-danger-hover);color:#fff;transform:scale(1.02)}.btn-warning{background-color:var(--color-warning);color:#fff;border:none}.btn-warning:hover,.btn-warning:focus{filter:brightness(.9);transform:scale(1.02)}.form-label{color:var(--text-primary);margin-bottom:.5rem;font-weight:600;display:block}.form-control{width:100%;font-family:var(--font-body);color:var(--text-primary);background-color:var(--bg-primary);border:1px solid var(--border-color);background-clip:padding-box;border-radius:6px;padding:.5rem .75rem;font-size:1rem;font-weight:400;line-height:1.5;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;display:block}.form-control:focus{color:var(--text-primary);background-color:var(--bg-primary);border-color:var(--color-primary);outline:0;box-shadow:0 0 0 .25rem #0d6efd40}textarea.form-control{resize:vertical;min-height:100px}.form-select{width:100%;font-family:var(--font-body);color:var(--text-primary);background-color:var(--bg-primary);border:1px solid var(--border-color);appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:16px 12px;border-radius:6px;padding:.5rem 2.25rem .5rem .75rem;font-size:1rem;font-weight:400;line-height:1.5;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;display:block}.form-select:focus{border-color:var(--color-primary);outline:0;box-shadow:0 0 0 .25rem #0d6efd40}.card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:20px;transition:all .2s ease-in-out;box-shadow:0 4px 8px #0000000d}.card:hover{transform:translateY(-4px);box-shadow:0 6px 12px #00000014}.bg-light,.bg-secondary{background-color:var(--bg-secondary)}.trust-builder .grid{text-align:left;grid-template-columns:1fr 2fr;align-items:center}@media (max-width:768px){.trust-builder .grid{text-align:center;grid-template-columns:1fr;gap:20px}}.teacher-headshot{object-fit:cover;border-radius:50%;width:200px;height:200px;margin:0 auto;display:block}.offerings{color:var(--color-white);text-align:center;background-position:50%;background-size:cover;background-attachment:fixed;padding:80px 0}.section-title{color:var(--color-white);text-shadow:0 2px 4px #0003;margin-bottom:40px;font-size:2.5rem}.services-grid{grid-template-columns:1fr 1fr;gap:60px;max-width:1000px;margin-bottom:60px;margin-left:auto;margin-right:auto;display:grid}.service-column{flex-direction:column;gap:40px;display:flex}.service-item{align-items:flex-start;gap:20px;display:flex}.left-align .service-item{text-align:right;justify-content:flex-end}.right-align .service-item{text-align:left;justify-content:flex-start}.service-icon{min-width:40px;margin-top:5px;font-size:2rem}.service-text h3{margin:0 0 10px;font-size:1.2rem;font-weight:700}.service-text p{opacity:.9;margin:0;font-size:.95rem;line-height:1.5}@media (max-width:768px){.services-grid{grid-template-columns:1fr;gap:40px}.left-align .service-item{text-align:left;flex-direction:row-reverse;justify-content:flex-start}.right-align .service-item{text-align:left}.service-text h3{font-size:1.1rem}}.testimonials .testimonial-card{background:var(--bg-secondary);border-left:5px solid var(--color-primary);text-align:left;margin:20px 0;padding:20px}.testimonials blockquote{margin:0;font-style:italic}.testimonials cite{margin-top:10px;font-weight:700;display:block}.final-cta{text-align:center}.main-header{background-color:var(--color-black);border-bottom:1px solid var(--border-color-dark);z-index:1000;flex-direction:column;justify-content:center;width:100%;height:auto;min-height:70px;display:flex;position:fixed;top:0;left:0}.navbar{height:100%}.navbar-container{flex-wrap:nowrap;justify-content:space-between;align-items:center;max-width:1400px;height:100%;margin:0 auto;padding:0 20px;display:flex}.nav-left{align-items:center;gap:30px;display:flex}.navbar-logo-img img{width:auto;height:40px;display:block}.nav-menu-desktop{align-items:center;gap:25px;display:flex}.nav-link{color:var(--color-white);font-size:1rem;font-weight:500;text-decoration:none;transition:color .2s ease-in-out}.nav-link:hover{color:#ccc}.nav-right{flex-wrap:nowrap;align-items:center;display:flex}.user-controls{color:var(--color-white);flex-wrap:nowrap;align-items:center;gap:20px;display:flex}.guest-controls{align-items:center;gap:15px;display:flex}.student-selector{position:relative}.student-select{color:var(--color-white);font-family:var(--font-body);cursor:pointer;background-color:#0000;border:none;outline:none;padding-right:15px;font-size:1rem}.student-select option{background-color:var(--color-black);color:var(--color-white)}.music-bucks-display{align-items:center;gap:5px;font-weight:600;display:flex}.music-note{font-size:1.2rem}.nav-cart{color:var(--color-white);align-items:center;gap:5px;font-weight:600;text-decoration:none;display:flex}.cart-icon{font-size:1.2rem}.user-info{white-space:nowrap;flex-wrap:nowrap;align-items:center;gap:15px;font-size:1rem;font-weight:500;display:flex}.divider{opacity:.3;font-weight:300}.logout-btn{color:var(--color-white);cursor:pointer;font-family:var(--font-body);opacity:1;background:0 0;border:none;padding:0;font-size:1rem;font-weight:500;text-decoration:underline}.logout-btn:hover{opacity:.8}.hamburger{cursor:pointer;display:none}.hamburger .bar{background-color:var(--color-white);width:25px;height:3px;margin:5px 0;transition:all .3s ease-in-out;display:block}.nav-menu-mobile{background-color:var(--color-black);z-index:999;flex-direction:column;gap:20px;width:100%;height:calc(100dvh - 70px);padding:30px 30px 150px;transition:left .3s ease-in-out;display:flex;position:fixed;top:70px;left:-100%;overflow-y:auto}.nav-menu-mobile.active{left:0}.nav-menu-mobile .nav-link{border-bottom:1px solid var(--border-color-dark);padding-bottom:15px;font-size:1.2rem}.mobile-student-selector{flex-direction:column;gap:5px;margin-bottom:20px;display:flex}.mobile-student-selector label{color:#ccc;font-size:.9rem}.mobile-student-select-input{background-color:var(--border-color-dark);color:var(--color-white);border:1px solid #555;border-radius:4px;outline:none;width:100%;padding:10px;font-size:1rem}.mobile-user-actions{margin-top:auto}@media (max-width:992px){.nav-menu-desktop{display:none}.hamburger{display:block}.nav-right{display:none}.hamburger{margin-left:auto;display:block}}@media (min-width:993px){.nav-menu-mobile{display:none}}@media (max-width:768px){h1{font-size:2rem}h2{font-size:1.75rem}}.sece-section{color:var(--color-white);text-align:left;background-position:50%;background-size:cover;background-attachment:fixed;padding:100px 0}.sece-grid{grid-template-columns:1fr 2fr;align-items:center;gap:80px;display:grid}.sece-cta{text-align:center}.sece-cta h2{color:var(--color-white);margin-bottom:10px;font-size:1.5rem}.sece-cta p{margin-bottom:20px;font-size:.9rem}.sece-content h2{color:var(--color-white);margin-bottom:10px;font-size:2rem;line-height:1.2}.sece-content h3{opacity:.9;margin-bottom:5px;font-size:1.2rem;font-weight:400}.sece-content .subtitle{opacity:.8;margin-bottom:20px;font-size:1rem;font-style:italic}.sece-content .description{opacity:.9;margin-bottom:30px;font-size:.95rem;line-height:1.6}.sece-content h4{color:var(--color-white);margin-bottom:15px;font-size:1.1rem;font-weight:700}.feature-list{flex-direction:column;gap:20px;margin-bottom:30px;display:flex}.feature-item{align-items:flex-start;gap:15px;display:flex}.feature-icon{color:var(--color-primary);margin-top:2px;font-size:1.5rem}.feature-text h5{text-transform:uppercase;margin:0 0 5px;font-size:.9rem;font-weight:800}.feature-text p{opacity:.8;margin:0;font-size:.9rem}.trial-info h4{margin-bottom:10px}.trial-info p{opacity:.9;font-size:.9rem}@media (max-width:992px){.sece-grid{text-align:center;grid-template-columns:1fr;gap:40px}.sece-section{text-align:center}.sece-cta{order:2;margin-top:20px}.feature-item{text-align:left;justify-content:flex-start}.sece-content{text-align:left}}.portfolio-section{background-color:var(--bg-secondary);text-align:center;padding:80px 0}.portfolio-section .section-title.text-dark{color:var(--text-primary);text-shadow:none;margin-bottom:30px}.portfolio-filter{flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:40px;display:flex}.filter-btn{border:1px solid var(--border-color);cursor:pointer;font-family:var(--font-body);text-transform:uppercase;color:var(--text-secondary);background:0 0;border-radius:4px;padding:8px 20px;font-size:.8rem;transition:all .3s}.filter-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.filter-btn.active{color:var(--color-white);background-color:#5da4f3;border-color:#5da4f3}.portfolio-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.portfolio-item{aspect-ratio:3/2;background-color:#ddd;border-radius:4px;position:relative;overflow:hidden}.portfolio-item img{object-fit:cover;width:100%;height:100%;transition:transform .3s;display:block}.portfolio-item:hover img{transform:scale(1.05)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.4s ease-out forwards fadeIn}@media (max-width:992px){.portfolio-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.portfolio-grid{grid-template-columns:repeat(2,1fr);gap:15px}}@media (max-width:480px){.portfolio-grid{grid-template-columns:1fr}}.reviews-section{color:#fff;text-align:center;background-position:50%;background-size:cover;background-attachment:fixed;padding:100px 0;position:relative}.reviews-section .section-title{margin-bottom:50px}.review-carousel{justify-content:center;align-items:center;max-width:900px;min-height:200px;margin:0 auto;display:flex;position:relative}.review-content{flex:1;max-width:700px;padding:0 40px}.reviewer-name{text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;font-size:1.1rem;font-weight:700}.stars{justify-content:center;gap:5px;margin-bottom:20px;display:flex}.review-text{opacity:.9;font-size:1.1rem;font-style:italic;line-height:1.8}.nav-btn{color:#ffffff80;cursor:pointer;z-index:2;background:0 0;border:none;padding:10px;font-size:1.5rem;transition:all .3s}.nav-btn:hover{color:#fff;transform:scale(1.2)}.prev-btn{margin-right:20px}.next-btn{margin-left:20px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in-key{animation:.5s ease-out forwards fadeInUp}@media (max-width:768px){.review-carousel{text-align:center;flex-direction:column}.review-content{margin-bottom:20px;padding:0}.nav-btn{margin:0 10px;position:relative}}.calendar-section{background-color:var(--primary-bg);text-align:center;padding:80px 0}.calendar-section .section-title.text-dark{color:var(--primary-text);text-shadow:none;margin-bottom:40px}.calendar-container{background:#fff;border-radius:8px;max-width:900px;margin:0 auto;overflow:hidden;box-shadow:0 4px 12px #0000001a}.main-footer{color:#fff;background-color:#000;margin-top:auto;padding-top:60px;padding-bottom:20px}.main-footer .container.grid{grid-template-columns:repeat(2,1fr);align-items:start}.footer-col{flex-direction:column;gap:20px;display:flex}.footer-col h3{color:#fff;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;font-size:1.2rem}.footer-link{color:#ccc;width:fit-content;font-size:1rem;text-decoration:none;transition:color .2s}.footer-link:hover{color:#fff}.footer-bottom{text-align:center;color:#888;border-top:1px solid #333;margin-top:60px;padding-top:20px;font-size:.9rem}@media (max-width:768px){.main-footer .container.grid{text-align:center;grid-template-columns:1fr;gap:40px}.footer-col{align-items:center}}.user-status-bar{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--bg-secondary);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:10px 15px;font-weight:500;display:flex;box-shadow:0 2px 4px #0000000d}.status-item{gap:5px;display:flex}.status-label{opacity:.8}.status-value{font-weight:700}.nav-center{flex-grow:1;justify-content:center;display:flex}@media (max-width:992px){.navbar-container{grid-template-columns:50px 1fr 60px;align-items:center;width:100%;padding:0 12px;display:grid}.nav-left{justify-content:flex-start}.nav-center{justify-content:center}.nav-right{justify-content:flex-end;display:flex!important}.desktop-controls{display:none}.mobile-cart-icon{display:block}.hamburger{margin-left:0}}@media (min-width:993px){.mobile-cart-icon{display:none}}.cart-icon-container{color:#fff;justify-content:center;align-items:center;padding:8px;text-decoration:none;display:flex;position:relative}.cart-icon-symbol{font-size:1.5rem}.cart-badge{background-color:var(--color-danger,#f44336);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.75rem;font-weight:700;display:flex;position:absolute;top:-5px;right:-8px;box-shadow:0 2px 4px #0003}.cart-badge-mobile{background-color:var(--color-danger,#f44336);color:#fff;border:1px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.75rem;font-weight:700;display:flex;position:absolute;top:-4px;right:-6px}.modal-card.login-modal{max-width:400px}.login-modal h2{text-align:center;color:var(--text-primary);margin-top:0;margin-bottom:1.5rem;font-size:1.75rem}.login-error{background-color:var(--color-danger-bg);color:var(--color-danger-text);text-align:center;border-radius:8px;margin-bottom:1rem;padding:.75rem;font-size:.875rem}.form-group{margin-bottom:1rem}.full-width{justify-content:center;width:100%}.btn-google{background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);margin-top:1rem;font-weight:500}.btn-google:hover{background-color:var(--bg-secondary);border-color:var(--text-secondary)}.divider{color:var(--text-secondary);align-items:center;margin:1.5rem 0;font-size:.875rem;display:flex}.divider:before,.divider:after{content:"";border-top:1px solid var(--border-color);flex:1}.divider span{padding:0 .75rem}.modal-footer{text-align:center;color:var(--text-secondary);margin-top:1.5rem;font-size:.875rem}.link-btn{color:var(--color-primary);cursor:pointer;background:0 0;border:none;margin-left:.25rem;padding:0;font-weight:600}.link-btn:hover{text-decoration:underline}.modal-overlay{background-color:var(--bg-overlay);z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-primary,#fff);border-bottom:1px solid var(--border-color);border-radius:16px;width:90%;max-width:500px;padding:2.5rem;animation:.3s ease-out modalSlideIn;position:relative;box-shadow:0 25px 50px -12px #00000040}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close{cursor:pointer;color:var(--text-secondary,#6c757d);z-index:10;background:0 0;border:none;padding:.5rem;font-size:1.5rem;line-height:1;transition:color .2s;position:absolute;top:1rem;right:1rem}.modal-close:hover{color:var(--text-primary,#212529)}.modal-card img{object-fit:contain;border-radius:12px;width:auto;max-width:100%;height:auto;max-height:200px;margin:0 auto 1rem;display:block}.modal-card h2{color:var(--text-primary,#212529);margin:0 0 .75rem;font-size:1.25rem}.modal-card p{color:var(--text-secondary,#6c757d);margin:0 0 .5rem;font-size:.95rem}.modal-card button:not(.modal-close){margin-top:1rem}@media (max-width:600px){.modal-card{border-radius:12px;width:92%;max-width:none;max-height:85vh;padding:1.5rem;overflow-y:auto}.modal-card img{max-height:150px}.modal-card h2{font-size:1.1rem}.modal-card p{font-size:.9rem}.modal-close{font-size:1.3rem;top:.75rem;right:.75rem}}@media (min-width:601px) and (max-width:900px){.modal-card{max-width:400px;padding:2rem}.modal-card img{max-height:180px}}.review-modal-content{text-align:center}.review-qr-code{max-width:200px;margin:1rem 0}.review-buttons{flex-direction:column;gap:10px;margin-top:1.5rem;display:flex}.modal-footer-text{color:#666;margin-top:1rem;font-size:.9rem}@media (max-width:480px){.review-modal-content{width:95%;padding:1.5rem!important}.review-qr-code,.qr-code-container{display:none}.modal-close{padding:1rem;font-size:2rem;top:.5rem;right:.5rem}.review-buttons{margin-top:1rem}}.loading-spinner-container{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:60vh;display:flex}.loading-spinner{border:4px solid #8b5cf633;border-top-color:#8b5cf6;border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.loading-text{color:var(--text-secondary,#a1a1aa);margin:0;font-size:.875rem}@keyframes spin{to{transform:rotate(360deg)}}
