:root{--cream:#faf7f2;--cream-dark:#f3ede4;--cream-darker:#e8e2d9;--ink:#2c2418;--ink-light:#6b5f4e;--ink-lighter:#8a7e6b;--ink-faint:#b5ac9e;--terracotta:#c8553d;--terracotta-light:#d4715c;--terracotta-dark:#a8432f;--white:#fff;--font-display:"Playfair Display", Georgia, serif;--font-body:"DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius-sm:8px;--radius-md:12px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--ink);background-color:var(--cream);font-weight:400;line-height:1.6}h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;line-height:1.2}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{font-family:var(--font-body);cursor:pointer;border:none;outline:none}input,select,textarea{font-family:var(--font-body);font-size:1rem}.fade-in{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(24px)}.fade-in.visible{opacity:1;transform:translateY(0)}.section-padding{padding:96px 24px}.container{max-width:1080px;margin:0 auto}.btn{border-radius:var(--radius-sm);letter-spacing:.01em;justify-content:center;align-items:center;padding:14px 28px;font-size:.95rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background-color:var(--ink);color:var(--cream)}.btn-primary:hover{background-color:#3d3528;transform:translateY(-1px)}.btn-cta{background-color:var(--terracotta);color:var(--white)}.btn-cta:hover{background-color:var(--terracotta-light);transform:translateY(-1px)}.btn-cta:active{background-color:var(--terracotta-dark)}.btn-secondary{color:var(--ink);border:1.5px solid var(--ink);background-color:#0000}.btn-secondary:hover{background-color:var(--ink);color:var(--cream);transform:translateY(-1px)}.section-label{font-family:var(--font-body);letter-spacing:.15em;text-transform:uppercase;color:var(--ink-lighter);margin-bottom:16px;font-size:.75rem;font-weight:500}.section-title{margin-bottom:16px;font-size:2rem}.section-subtitle{color:var(--ink-light);max-width:540px;font-size:1.05rem}.navbar{z-index:100;border-bottom:1px solid #0000;justify-content:center;align-items:center;height:64px;padding:0 24px;transition:background-color .3s,border-color .3s;display:flex;position:fixed;top:0;left:0;right:0}.navbar.scrolled{-webkit-backdrop-filter:blur(12px);border-bottom-color:var(--cream-darker);background-color:#faf7f2d9}.navbar-inner{justify-content:space-between;align-items:center;width:100%;max-width:1080px;display:flex}.navbar-brand{font-family:var(--font-display);color:var(--ink);font-size:1.15rem;font-weight:500}.navbar-links{gap:32px;list-style:none;display:flex}.navbar-links a{color:var(--ink-light);font-size:.9rem;font-weight:500;transition:color .2s}.navbar-links a:hover{color:var(--ink)}.navbar-hamburger{background:0 0;flex-direction:column;gap:5px;padding:4px;display:none}.navbar-hamburger span{background-color:var(--ink);border-radius:2px;width:22px;height:2px;transition:all .3s;display:block}.navbar-hamburger.open span:first-child{transform:rotate(45deg)translate(5px,5px)}.navbar-hamburger.open span:nth-child(2){opacity:0}.navbar-hamburger.open span:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}.mobile-menu{z-index:99;background-color:var(--cream);opacity:0;flex-direction:column;justify-content:center;align-items:center;gap:36px;transition:opacity .3s;display:none;position:fixed;inset:0}.mobile-menu.open{opacity:1;display:flex}.mobile-menu a{font-family:var(--font-display);color:var(--ink);font-size:1.6rem;transition:color .2s}.mobile-menu a:hover{color:var(--terracotta)}@media (width<=768px){.navbar-links{display:none}.navbar-hamburger{display:flex}}.hero{background-color:var(--cream);padding:160px 24px 96px;position:relative;overflow:hidden}.hero-decorative{background-color:var(--cream-dark);border-radius:50%;position:absolute}.hero-circle-1{opacity:.6;width:500px;height:500px;top:-120px;right:-100px}.hero-circle-2{opacity:.4;width:350px;height:350px;bottom:-80px;left:-60px}.hero-circle-3{opacity:.3;width:200px;height:200px;top:40%;right:20%}.hero-content{max-width:1080px;margin:0 auto;position:relative}.hero-pill{background-color:var(--cream-dark);border-radius:20px;align-items:center;gap:8px;margin-bottom:24px;padding:6px 16px;display:inline-flex}.hero-pill-dot{background-color:var(--terracotta);border-radius:50%;width:8px;height:8px}.hero-pill-text{letter-spacing:.15em;text-transform:uppercase;color:var(--ink-lighter);font-size:.72rem;font-weight:500}.hero h1{max-width:600px;color:var(--ink);margin-bottom:20px;font-size:3rem}.hero-sub{color:var(--ink-light);max-width:520px;margin-bottom:36px;font-size:1.1rem;line-height:1.7}.hero-buttons{flex-wrap:wrap;gap:16px;display:flex}.hero-content .fade-in:first-child{transition-delay:0s}.hero-content .fade-in:nth-child(2){transition-delay:.12s}.hero-content .fade-in:nth-child(3){transition-delay:.24s}.hero-content .fade-in:nth-child(4){transition-delay:.36s}@media (width<=768px){.hero{padding:130px 24px 72px}.hero h1{font-size:2.2rem}.hero-circle-1{width:300px;height:300px}.hero-circle-2{width:200px;height:200px}}.value-props{background-color:var(--cream);padding:96px 24px}.value-props-grid{grid-template-columns:repeat(3,1fr);gap:32px;max-width:1080px;margin:0 auto;display:grid}.value-card{background-color:var(--white);border:.5px solid var(--cream-darker);border-radius:var(--radius-md);padding:36px 28px;transition:transform .2s}.value-card:hover{transform:translateY(-2px)}.value-icon{background-color:var(--cream-dark);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:20px;display:flex}.value-icon svg{width:22px;height:22px;stroke:var(--ink);fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.value-card h3{margin-bottom:10px;font-size:1.15rem}.value-card p{color:var(--ink-light);font-size:.95rem;line-height:1.6}@media (width<=768px){.value-props-grid{grid-template-columns:1fr;gap:20px}}.teachers{background-color:var(--cream);padding:96px 24px}.teachers-header{text-align:center;margin-bottom:56px}.teachers-header .section-subtitle{margin:0 auto}.teachers-grid{grid-template-columns:repeat(2,1fr);gap:32px;max-width:1080px;margin:0 auto;display:grid}.teacher-card{background-color:var(--white);border:.5px solid var(--cream-darker);border-radius:var(--radius-md);padding:36px;transition:transform .2s}.teacher-card:hover{transform:translateY(-2px)}.teacher-top{align-items:center;gap:16px;margin-bottom:20px;display:flex}.teacher-avatar{background-color:var(--ink);border-radius:var(--radius-sm);width:56px;height:56px;color:var(--white);font-family:var(--font-display);flex-shrink:0;justify-content:center;align-items:center;font-size:1.3rem;font-weight:500;display:flex}.teacher-info h3{margin-bottom:2px;font-size:1.15rem}.teacher-tag{letter-spacing:.08em;text-transform:uppercase;color:var(--white);background-color:var(--ink-lighter);vertical-align:middle;border-radius:4px;margin-left:8px;padding:2px 8px;font-size:.72rem;font-weight:500;display:inline-block}.teacher-instrument{color:var(--terracotta);font-size:.9rem;font-weight:500}.teacher-card p{color:var(--ink-light);font-size:.95rem;line-height:1.7}@media (width<=768px){.teachers-grid{grid-template-columns:1fr}}.pricing{background-color:var(--ink);color:var(--cream);padding:96px 24px}.pricing-header{text-align:center;margin-bottom:56px}.pricing-header .section-label{color:var(--ink-faint)}.pricing-header .section-title{color:var(--cream)}.pricing-grid{grid-template-columns:repeat(3,1fr);gap:24px;max-width:800px;margin:0 auto 40px;display:grid}.pricing-card{border-radius:var(--radius-md);text-align:center;background-color:#ffffff0f;border:1px solid #ffffff1a;padding:36px 28px;transition:transform .2s}.pricing-card:hover{transform:translateY(-2px)}.pricing-card.highlight{border-color:var(--terracotta);box-shadow:0 0 40px #c8553d1f}.pricing-card-label{color:var(--ink-faint);margin-bottom:12px;font-size:.85rem;font-weight:500}.pricing-card-price{font-family:var(--font-display);color:var(--cream);margin-bottom:4px;font-size:2.5rem}.pricing-card-per{color:var(--ink-faint);font-size:.85rem}.pricing-note{text-align:center;color:var(--ink-faint);font-size:.95rem}@media (width<=768px){.pricing-grid{grid-template-columns:1fr;max-width:320px}}.service-area{background-color:var(--cream);padding:96px 24px}.service-area-inner{text-align:center;max-width:1080px;margin:0 auto}.service-area-icon{background-color:var(--cream-dark);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 24px;display:flex}.service-area-icon svg{width:26px;height:26px;stroke:var(--ink);fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.service-area h2{margin-bottom:20px;font-size:2rem}.service-area-cities{color:var(--ink-light);margin-bottom:12px;font-size:1.05rem;line-height:1.8}.service-area-note{color:var(--ink-lighter);font-size:.95rem}.how-it-works{background-color:var(--cream-dark);padding:96px 24px}.how-it-works-header{text-align:center;margin-bottom:56px}.how-it-works-header .section-subtitle{margin:0 auto}.steps-grid{grid-template-columns:repeat(3,1fr);gap:32px;max-width:1080px;margin:0 auto;display:grid}.step{text-align:center}.step-number{background-color:var(--ink);width:44px;height:44px;color:var(--cream);font-family:var(--font-display);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;font-size:1.1rem;display:flex}.step h3{margin-bottom:10px;font-size:1.15rem}.step p{color:var(--ink-light);max-width:280px;margin:0 auto;font-size:.95rem;line-height:1.6}@media (width<=768px){.steps-grid{grid-template-columns:1fr;gap:40px}}.contact{background-color:var(--cream-dark);padding:96px 24px}.contact-inner{max-width:600px;margin:0 auto}.contact-header{text-align:center;margin-bottom:40px}.contact-header .section-subtitle{margin:0 auto}.contact-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--ink-lighter);letter-spacing:.02em;font-size:.85rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--cream-darker);border-radius:var(--radius-sm);background-color:var(--white);color:var(--ink);outline:none;padding:12px 16px;font-size:.95rem;transition:border-color .2s}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--ink-faint)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--ink-lighter)}.form-group textarea{resize:vertical;min-height:100px}.form-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=768px){.form-row{grid-template-columns:1fr}}.contact-form .btn-cta{align-self:flex-start;padding:14px 36px}.contact-success{text-align:center;max-width:480px;margin:0 auto;padding:64px 24px}.contact-success .success-icon{margin-bottom:24px}.contact-success h3{font-family:var(--font-display);color:var(--ink);margin-bottom:12px;font-size:1.5rem}.contact-success .success-subtext{color:var(--ink-light);margin-bottom:28px;font-size:.95rem}.contact-success .btn-secondary{display:inline-block}.footer{background-color:var(--ink);color:var(--cream);padding:56px 24px}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:32px;max-width:1080px;margin:0 auto;display:flex}.footer-brand h3{color:var(--cream);margin-bottom:6px;font-size:1.15rem}.footer-brand p{color:var(--ink-faint);font-size:.9rem}.footer-links{gap:28px;list-style:none;display:flex}.footer-links a{color:var(--ink-faint);font-size:.9rem;transition:color .2s}.footer-links a:hover{color:var(--cream)}.footer-bottom{width:100%;color:var(--ink-faint);border-top:1px solid #ffffff14;margin-top:32px;padding-top:24px;font-size:.8rem}@media (width<=768px){.footer-inner{text-align:center;flex-direction:column;align-items:center}.footer-bottom{text-align:center}}.auth-page{background-color:var(--cream);justify-content:center;align-items:center;min-height:100vh;padding:100px 24px 60px;display:flex}.auth-card{background:var(--white);border:.5px solid var(--cream-darker);border-radius:var(--radius-md);width:100%;max-width:420px;padding:48px 36px}.auth-card h1{font-family:var(--font-display);color:var(--ink);margin-bottom:6px;font-size:1.75rem}.auth-subtitle{color:var(--ink-light);margin-bottom:28px;font-size:.95rem}.auth-form{flex-direction:column;gap:18px;display:flex}.auth-submit{width:100%;margin-top:4px}.auth-error{color:#b91c1c;border-radius:var(--radius-sm);background-color:#fef2f2;border:1px solid #fecaca;margin-bottom:12px;padding:10px 14px;font-size:.875rem}.auth-success{color:#166534;border-radius:var(--radius-sm);background-color:#f0fdf4;border:1px solid #bbf7d0;margin-bottom:12px;padding:10px 14px;font-size:.875rem}.auth-footer{text-align:center;color:var(--ink-light);margin-top:24px;font-size:.9rem}.auth-footer a{color:var(--terracotta);font-weight:500}.auth-footer a:hover{color:var(--terracotta-dark)}.dashboard-page{background-color:var(--cream);max-width:1080px;min-height:100vh;margin:0 auto;padding:100px 24px 60px}.dash-loading{text-align:center;color:var(--ink-light);padding:80px 0}.dash-header{margin-bottom:36px}.dash-header h1{font-family:var(--font-display);color:var(--ink);margin-bottom:6px;font-size:2rem}.dash-subtitle{color:var(--ink-light);font-size:1rem}.dash-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;display:grid}@media (width<=768px){.dash-grid{grid-template-columns:1fr}}.dash-card{background:var(--white);border:.5px solid var(--cream-darker);border-radius:var(--radius-md);padding:28px}.dash-card h2{font-family:var(--font-display);color:var(--ink);margin-bottom:20px;font-size:1.25rem}.dash-card h3{font-family:var(--font-display);color:var(--ink);font-size:1.05rem}.dash-full-width{grid-column:1/-1;margin-bottom:24px}.dash-card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.dash-card-header h2{margin-bottom:0}.dash-empty{color:var(--ink-faint);padding:16px 0;font-size:.9rem}.slot-form{border-bottom:1px solid var(--cream-darker);margin-bottom:24px;padding-bottom:24px}.slot-form-row{grid-template-columns:1.5fr 1fr 1fr;gap:12px;margin-bottom:12px;display:grid}@media (width<=480px){.slot-form-row{grid-template-columns:1fr}}.slot-list{flex-direction:column;gap:8px;display:flex}.slot-list.compact{margin-top:12px}.slot-item{background:var(--cream);border-radius:var(--radius-sm);text-align:left;cursor:default;border:none;align-items:center;gap:12px;width:100%;padding:10px 14px;font-size:.9rem;display:flex}.slot-selectable{cursor:pointer;border:1px solid #0000;transition:background-color .2s,border-color .2s}.slot-selectable:hover{background:var(--cream-dark)}.slot-selected{border-color:var(--terracotta);background:#faf0ed}.slot-day{color:var(--ink);min-width:90px;font-weight:500}.slot-time{color:var(--ink-light)}.btn-remove{cursor:pointer;color:var(--ink-faint);background:0 0;border:none;border-radius:4px;align-items:center;margin-left:auto;padding:4px;transition:color .2s;display:flex}.btn-remove:hover{color:var(--terracotta)}.slots-heading{margin-top:24px;margin-bottom:12px}.booking-list{flex-direction:column;gap:12px;display:flex}.booking-item{background:var(--cream);border-radius:var(--radius-sm);padding:16px}.booking-top{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.booking-date{color:var(--ink);font-weight:500}.booking-status{text-transform:uppercase;letter-spacing:.04em;border-radius:20px;padding:3px 10px;font-size:.75rem;font-weight:500}.status-pending{color:#92400e;background:#fef3c7}.status-approved{color:#065f46;background:#d1fae5}.status-declined{color:#991b1b;background:#fee2e2}.status-cancelled{background:var(--cream-dark);color:var(--ink-faint)}.status-paid{color:#065f46;background:#d1fae5}.status-unpaid{color:#92400e;background:#fef3c7}.booking-status-group{align-items:center;gap:6px;display:flex}.booking-details{color:var(--ink-light);flex-wrap:wrap;gap:6px 16px;font-size:.875rem;display:flex}.booking-parent{color:var(--ink-lighter);margin-top:6px;font-size:.85rem}.booking-notes{color:var(--ink-lighter);margin-top:4px;font-size:.85rem;font-style:italic}.booking-actions{gap:8px;margin-top:12px;display:flex}.btn-sm{padding:8px 18px;font-size:.825rem}.filter-tabs{gap:4px;display:flex}.filter-tab{border:1px solid var(--cream-darker);color:var(--ink-light);cursor:pointer;background:0 0;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:.825rem;transition:all .2s;display:flex}.filter-tab:hover{border-color:var(--ink-lighter)}.filter-tab.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}.filter-count{background:#0000001a;border-radius:10px;padding:1px 7px;font-size:.75rem}.filter-tab.active .filter-count{background:#fff3}.teacher-select-list{flex-direction:column;gap:8px;margin-bottom:8px;display:flex}.teacher-select-btn{background:var(--cream);border-radius:var(--radius-sm);cursor:pointer;text-align:left;border:1px solid #0000;align-items:center;gap:14px;width:100%;padding:14px 16px;transition:all .2s;display:flex}.teacher-select-btn:hover{background:var(--cream-dark)}.teacher-select-btn.selected{border-color:var(--terracotta);background:#faf0ed}.teacher-select-avatar{border-radius:var(--radius-sm);background:var(--ink);width:40px;height:40px;color:var(--cream);flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:500;display:flex}.teacher-select-instrument{color:var(--ink-lighter);font-size:.825rem;font-weight:400;display:block}.admin-teachers{flex-direction:column;gap:20px;display:flex}.admin-teacher-card{background:var(--cream);border-radius:var(--radius-sm);padding:20px}.admin-teacher-info{align-items:center;gap:14px;display:flex}.duration-toggle{gap:8px;margin-bottom:8px;display:flex}.duration-btn{border:1px solid var(--cream-darker);border-radius:var(--radius-sm);background:var(--cream);color:var(--ink-light);cursor:pointer;flex:1;padding:10px 16px;font-size:.875rem;font-weight:500;transition:all .2s}.duration-btn:hover{border-color:var(--ink-lighter)}.duration-btn.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}.slot-day-group{margin-bottom:16px}.slot-day-label{color:var(--ink-lighter);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:.8rem;font-weight:500}.slot-grid{flex-wrap:wrap;gap:6px;display:flex}.slot-chip{border:1px solid var(--cream-darker);background:var(--white);color:var(--ink-light);cursor:pointer;border-radius:20px;padding:7px 14px;font-size:.825rem;transition:all .2s}.slot-chip:hover{border-color:var(--ink-lighter);background:var(--cream)}.slot-chip.slot-selected{background:var(--ink);color:var(--cream);border-color:var(--ink)}.checkbox-label{color:var(--ink-light);cursor:pointer;align-items:center;gap:10px;font-size:.9rem;display:flex}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--terracotta);cursor:pointer}.policies-page{background:var(--cream);min-height:100vh;padding:120px 24px 80px}.policies-inner{max-width:720px;margin:0 auto}.policies-heading{color:var(--ink);margin-bottom:48px;font-family:Playfair Display,Georgia,serif;font-size:40px;font-weight:500}.policy-section{margin-bottom:40px}.policy-section h2{color:var(--ink);margin-bottom:16px;font-family:Playfair Display,Georgia,serif;font-size:24px;font-weight:500}.policy-section p{color:var(--ink-light);margin-bottom:12px;font-family:DM Sans,-apple-system,sans-serif;font-size:16px;line-height:1.7}.policy-section ul{margin:0 0 16px;padding:0;list-style:none}.policy-section ul li{color:var(--ink-light);padding:6px 0 6px 20px;font-family:DM Sans,-apple-system,sans-serif;font-size:16px;line-height:1.7;position:relative}.policy-section ul li:before{content:"";background:var(--terracotta);border-radius:50%;width:6px;height:6px;position:absolute;top:14px;left:0}.policy-note{background:var(--cream-dark);border:.5px solid var(--cream-darker);border-radius:12px;margin-top:48px;padding:24px}.policy-note p{color:var(--ink-lighter);margin:0;font-family:DM Sans,-apple-system,sans-serif;font-size:15px;line-height:1.7}.policy-note a{color:var(--terracotta);text-decoration:none;transition:color .2s}.policy-note a:hover{color:var(--terracotta-light)}@media (width<=600px){.policies-heading{font-size:32px}.policy-section h2{font-size:20px}}
