@charset "UTF-8";
:root{--c-primary:#5DADE2;--c-primary_hover:#3498DB;--c-primary_light:#D6EAF8;--c-primary_glow:rgba(93,173,226,0.25);--c-heading:#2C3E50;--c-body:#475569;--c-subtle:#94A3B8;--c-bg:#FFFFFF;--c-surface:#FAFAFA;--c-surface_alt:#EBF5FB;--c-border:#E2E8F0;--c-success:#10B981;--c-white:#FFFFFF;--f-heading:"Cormorant Garamond",Georgia,serif;--f-body:"Josefin Sans",system-ui,sans-serif}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
/* === UNIVERSAL RESPONSIVE SAFETY NET (May 2026) ===
   Prevents any element from breaking layout at narrow viewports. Applied site-wide. */
html,body{overflow-x:hidden;max-width:100vw}
img,video,iframe,svg,canvas{max-width:100%;height:auto;display:block}
table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
pre,code{max-width:100%;overflow-x:auto;word-wrap:break-word;white-space:pre-wrap}
/* Touch target minimum -- 44x44px tap area for any clickable element */
button,a.soul-btn,a.btn,input[type="submit"],input[type="button"]{min-height:44px}
/* === END RESPONSIVE SAFETY NET === */
html{scroll-behavior:smooth}body{font-family:var(--f-body);color:var(--c-body);background:var(--c-bg);line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased}

/* === GLOBAL TYPOGRAPHY (May 6 2026 -- Cormorant Garamond headings + Josefin Sans body, 17px base) ===
   Applied site-wide. Individual page templates may override but inherit these defaults. */
h1,h2,h3,h4,h5,h6{font-family:var(--f-heading);color:var(--c-heading);line-height:1.15}
h1{font-size:clamp(2.4rem,4.5vw,3.4rem);font-weight:700;letter-spacing:-0.3px;line-height:1.1}
h2{font-size:clamp(1.9rem,3vw,2.5rem);font-weight:700}
h3{font-size:clamp(1.35rem,2vw,1.75rem);font-weight:700;line-height:1.2}
h4{font-size:1.25rem;font-weight:700}
p,li,td{font-family:var(--f-body);font-size:17px;line-height:1.7}
.nav-link{font-family:var(--f-body);font-size:15px;font-weight:500;letter-spacing:0.1px}
/* Note: removed `nav a` from above selector — it was matching .soul-nav-link inside <nav class="soul-nav"> and overriding the larger nav font. Scoped now to explicit .nav-link only. */
button,.soul-btn,input[type="submit"]{font-family:var(--f-body);font-weight:600;letter-spacing:0.2px}
input,select,textarea{font-family:var(--f-body);font-size:16px}
label,.form-label{font-family:var(--f-body);font-size:12px;font-weight:600;letter-spacing:0.5px}
.eyebrow,.section-eyebrow,.home-section-eyebrow,.ab-eyebrow,.cof-eyebrow,.tt-eyebrow,.md-eyebrow,.sr-eyebrow,.hw-eyebrow,.ol-eyebrow,.sp-card-tag{font-family:var(--f-body);font-weight:600;text-transform:uppercase;letter-spacing:1.5px}
@media(max-width:768px){body{font-size:16px}p,li,td{font-size:16px}}
img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}
.soul-container{width:100%;max-width:1400px;margin:0 auto;padding:0 32px}
/* Top announcement banner -- FIXED above the fixed header so they don't overlap.
   Dismissible, remembers dismissal in localStorage.
   JS in header.php sets --soul-banner-h on <html> to the banner's actual height,
   then CSS uses that variable to offset the header below it. */
.soul-top-banner{position:fixed;top:0;left:0;right:0;z-index:1001;background:#EFF6FF;border-bottom:1px solid rgba(93,173,226,.25);font-size:13px;color:#1A202C}
.soul-top-banner-inner{max-width:1400px;margin:0 auto;padding:8px 32px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.soul-top-banner-msg{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;line-height:1.4}
.soul-top-banner-pill{display:inline-block;background:#7C3AED;color:#fff;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:2px 7px;border-radius:4px}
.soul-top-banner-link{color:#1F6FB2;font-weight:600;text-decoration:none;margin-left:4px}
.soul-top-banner-link:hover{text-decoration:underline;text-underline-offset:2px}
.soul-top-banner-close{background:transparent;border:none;cursor:pointer;color:#64748B;font-size:20px;line-height:1;padding:0 4px;min-width:24px;border-radius:4px;transition:background .15s,color .15s}
.soul-top-banner-close:hover{background:rgba(0,0,0,.05);color:#1A202C}
@media(max-width:600px){
    .soul-top-banner-inner{padding:8px 16px;gap:8px}
    .soul-top-banner-msg{font-size:12px}
}

/* Header background bumped a notch darker (was #F8F9FA / .95) so the nav reads as a defined surface against the white page body. */
.soul-header{position:fixed;top:var(--soul-banner-h,0px);left:0;right:0;z-index:1000;background:rgba(228,234,243,.96);backdrop-filter:blur(12px);transition:top .2s ease,background .35s ease,box-shadow .35s ease;border-bottom:1px solid rgba(15,23,42,.06)}

/* "More resources for {instrument} students" footer -- appears on every instrument page.
   Responsive: 4 cols desktop -> 2 cols tablet -> 1 col mobile (was 4 cols at all widths, broke mobile). */
.inst-related{background:#FAFBFD;border-top:1px solid #E5E7EB;padding:48px 0}
.inst-related-title{font-family:var(--f-heading);font-size:1.4rem;color:#1A202C;text-align:center;margin:0 0 28px;font-weight:700}
.inst-related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:1100px;margin:0 auto}
.inst-related-card{display:flex;flex-direction:column;gap:6px;padding:18px;background:#fff;border:1px solid #E5E7EB;border-radius:10px;text-decoration:none;color:inherit;transition:transform .15s,border-color .15s}
.inst-related-card:hover{transform:translateY(-2px);border-color:#5DADE2}
.inst-related-card strong{color:#1F6FB2;font-size:.95rem}
.inst-related-card span{color:#64748B;font-size:.85rem;line-height:1.45}
@media(max-width:900px){.inst-related-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.inst-related-grid{grid-template-columns:1fr}}

/* Breadcrumbs -- universal, rendered at top of every non-homepage page */
.soul-breadcrumbs{background:#FAFBFD;border-bottom:1px solid #E5E7EB;font-size:13px;color:#64748B}
.soul-breadcrumbs-inner{max-width:1400px;margin:0 auto;padding:10px 32px}
.soul-breadcrumbs ol{list-style:none;padding:0;margin:0;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.soul-breadcrumbs li{display:inline-flex;align-items:center;gap:6px}
.soul-breadcrumbs a{color:#1F6FB2;text-decoration:none;transition:color .15s}
.soul-breadcrumbs a:hover{color:#2C3E50;text-decoration:underline;text-underline-offset:2px}
.soul-breadcrumbs span[aria-current]{color:#1A202C;font-weight:500}
.soul-breadcrumb-sep{color:#CBD5E1;font-size:14px;line-height:1}
@media(max-width:600px){
    .soul-breadcrumbs-inner{padding:8px 16px}
    .soul-breadcrumbs{font-size:12px}
}
.soul-header.scrolled{background:#E4EAF3;box-shadow:0 2px 12px rgba(0,0,0,.08)}
.soul-header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;padding:0 32px;height:84px}
/* Logo restyle (May 2026): italic Cormorant for "Soul" + uppercase Josefin Sans for "Music Lessons" */
.soul-logo{display:inline-flex;align-items:baseline;gap:8px;color:#2C3E50;white-space:nowrap}
.soul-logo:hover{opacity:.85}
.soul-logo .logo-accent{font-family:var(--f-heading);font-style:italic;font-weight:600;color:#5DADE2;font-size:1.7rem;letter-spacing:-0.3px;line-height:1}
.soul-logo .logo-rest{font-family:var(--f-body);font-weight:500;color:#2C3E50;font-size:1.05rem;letter-spacing:1.2px;text-transform:uppercase;line-height:1}
.soul-nav{display:flex;align-items:center;gap:8px}
.soul-nav>a,.soul-nav .dropdown-trigger{color:#1A202C;font-size:1.18rem;font-weight:500;padding:12px 22px;border-radius:8px;transition:all .2s;cursor:pointer;display:inline-flex;align-items:center;gap:5px;background:none;border:none;font-family:var(--f-body);white-space:nowrap;letter-spacing:-.005em}
.soul-nav>a:hover,.soul-nav .dropdown-trigger:hover{color:#3498DB;background:rgba(93,173,226,.08)}
.dropdown{position:relative}
.dropdown-menu{display:none;position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%);min-width:230px;background:#F8F9FA;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:8px;box-shadow:0 16px 48px rgba(0,0,0,.45);z-index:1001;opacity:0;transition:opacity .2s}
.dropdown.open>.dropdown-menu{display:block;opacity:1}
.dropdown-menu a{display:flex;align-items:center;gap:8px;padding:9px 14px;border-radius:8px;font-size:.9rem;color:#555;transition:all .15s}
.dropdown-menu a:hover{background:#EBF5FB;color:#3498DB}
.dd-icon{font-size:1.1rem}.dd-divider{height:1px;background:#E9ECEF;margin:6px 0}.dd-label{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:#999;padding:6px 14px 2px;font-weight:600}
.soul-header-right{display:flex;align-items:center;gap:12px}
.soul-header-phone{color:#1A202C;font-size:1.08rem;font-weight:600;white-space:nowrap}.soul-header-phone:hover{color:#3498DB}
.soul-header-login{color:#1A202C;font-size:1.05rem;font-weight:500;padding:11px 20px;border:1.5px solid #ccc;border-radius:8px;transition:all .2s;white-space:nowrap}
.soul-header-login:hover{background:rgba(93,173,226,.08);border-color:#5DADE2;color:#3498DB}
.soul-header-cta{background:var(--c-primary);color:#fff!important;padding:13px 26px;border-radius:10px;font-weight:600;font-size:1.05rem;transition:all .25s;white-space:nowrap}
.soul-header-cta:hover{background:var(--c-primary_hover);transform:translateY(-1px);box-shadow:0 4px 16px var(--c-primary_glow)}
.soul-header.scrolled .soul-header-cta{background:#5DADE2;border:none}
.soul-menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:1002}
.soul-menu-toggle span{width:24px;height:2px;background:#333;border-radius:2px;transition:all .3s}
.soul-hero{position:relative;width:100%;overflow:hidden}
.soul-hero-bg{position:absolute;inset:0;z-index:0;background:linear-gradient(135deg,#AED6F1 0%,#5DADE2 40%,#3498DB 100%)}
.soul-hero-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 40%,rgba(133,193,233,.2) 0%,transparent 70%)}
.soul-hero-grid{position:relative;z-index:1;width:100%;max-width:1400px;margin:0 auto;padding:76px 32px 40px;display:grid;grid-template-columns:minmax(360px,460px) 1fr;gap:36px;align-items:start}
.soul-hero-form{background:#fff;border-radius:14px;padding:16px 18px 14px;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.form-headline{font-family:var(--f-heading);font-size:1.35rem;font-weight:700;color:var(--c-heading);margin-bottom:10px;text-align:center;line-height:1.3}
.form-note{font-size:.72rem;color:var(--c-subtle);margin-top:8px;padding-top:8px;border-top:1px solid var(--c-border);line-height:1.4}
.soul-hero-form .wpforms-container{margin:0!important;padding:0!important}
.soul-hero-form .wpforms-container .wpforms-form{margin:0!important;padding:0!important}
.wpforms-container .wpforms-form .wpforms-field-label{font-family:var(--f-body)!important;font-size:.85rem!important;font-weight:600!important;color:var(--c-heading)!important;margin:0 0 1px!important;padding:0!important;line-height:1.2!important}
.wpforms-container .wpforms-form .wpforms-field{margin:0 0 5px!important;padding:0!important}
.wpforms-container .wpforms-form .wpforms-field-sublabel,.wpforms-container .wpforms-form .wpforms-field-description{display:none!important}
.wpforms-container .wpforms-form input[type=text],.wpforms-container .wpforms-form input[type=email],.wpforms-container .wpforms-form input[type=tel],.wpforms-container .wpforms-form select,.wpforms-container .wpforms-form textarea{border:1.5px solid var(--c-border)!important;border-radius:6px!important;padding:5px 9px!important;font-family:var(--f-body)!important;font-size:.9rem!important;width:100%!important;background:#fff!important;height:38px!important;line-height:38px!important;transition:border-color .2s,box-shadow .2s!important}
.wpforms-container .wpforms-form select{height:38px!important;padding:4px 12px!important}
.wpforms-container .wpforms-form input:focus,.wpforms-container .wpforms-form select:focus,.wpforms-container .wpforms-form textarea:focus{border-color:var(--c-primary)!important;outline:none!important;box-shadow:0 0 0 3px var(--c-primary_light)!important}
.wpforms-container .wpforms-form textarea{min-height:28px!important;max-height:100px;resize:none;overflow:hidden;height:auto!important;line-height:1.3!important}
.wpforms-container .wpforms-submit-container{margin:6px 0 0!important;padding:0!important}
.wpforms-container .wpforms-submit-container button[type=submit]{background:var(--c-primary)!important;border:none!important;border-radius:8px!important;font-family:var(--f-body)!important;font-weight:600!important;font-size:.95rem!important;padding:11px 24px!important;cursor:pointer!important;transition:all .25s!important;width:100%;color:#fff!important}
.wpforms-container .wpforms-submit-container button[type=submit]:hover{background:var(--c-primary_hover)!important;transform:translateY(-1px)!important;box-shadow:0 4px 16px var(--c-primary_glow)!important}
.wpforms-container .wpforms-required-label{color:#ef4444!important}
.soul-hero-right{display:flex;flex-direction:column;gap:16px}
.soul-hero-image-wrap{width:100%;flex:1;min-height:280px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.placeholder-text{color:rgba(255,255,255,.35);font-size:1rem;font-weight:500}
.soul-eval-card{background:#fff;border-radius:14px;box-shadow:0 16px 48px rgba(0,0,0,.18);overflow:hidden}
.eval-card-top{display:flex;align-items:center;gap:14px;padding:18px 18px 12px}
.eval-card-content{flex:1}
.eval-heading{font-family:var(--f-heading);font-size:1.1rem;font-weight:700;color:var(--c-heading);margin-bottom:6px;line-height:1.3}
.eval-text{font-size:.9rem;color:var(--c-body);line-height:1.5}
.eval-badge{flex-shrink:0}.eval-badge svg{display:block}
.eval-card-bottom{padding:10px 18px 14px;border-top:1px solid var(--c-border);text-align:center}
.eval-card-bottom p{font-size:.84rem;color:var(--c-body);margin-bottom:2px}
.eval-card-bottom a{color:var(--c-primary);font-weight:600}.eval-card-bottom a:hover{color:var(--c-primary_hover)}
.eval-enroll-btn{display:inline-block;background:var(--c-primary);color:#fff!important;padding:12px 56px;border-radius:10px;font-weight:700;font-size:1.05rem;transition:all .25s;margin-top:8px}
.eval-enroll-btn:hover{background:var(--c-primary_hover);transform:translateY(-1px);box-shadow:0 4px 16px var(--c-primary_glow)}
.soul-instruments-section{padding:80px 0}
.inst-group-label{font-family:var(--f-heading);font-size:1.3rem;font-weight:600;color:var(--c-heading);margin:40px 0 20px;padding-bottom:8px;border-bottom:2px solid var(--c-primary_light)}
.inst-group-label:first-of-type{margin-top:0}
.instrument-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:16px;align-items:stretch}
.instrument-card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:14px;overflow:hidden;transition:all .3s;display:flex;flex-direction:column;height:100%}
.instrument-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(93,173,226,.12);border-color:var(--c-primary_light)}
.inst-image-link{display:block;height:160px;overflow:hidden;background:var(--c-surface)}
.inst-image-link img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.instrument-card:hover .inst-image-link img{transform:scale(1.05)}
.inst-image-placeholder{height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--c-primary_light),var(--c-surface))}
.inst-image-placeholder span{font-size:3rem}
.inst-card-body{padding:14px 14px 10px;flex:1;display:flex;flex-direction:column}
.inst-card-body h4{font-family:var(--f-heading);font-size:.95rem;font-weight:600;color:var(--c-heading);margin-bottom:8px}
.inst-card-body h4 a{color:inherit;transition:color .2s}.inst-card-body h4 a:hover{color:var(--c-primary)}
.inst-bullets{list-style:none;padding:0;margin:0}
.inst-bullets li{font-size:.78rem;color:var(--c-body);line-height:1.45;padding:2px 0 2px 14px;position:relative}
.inst-bullets li::before{content:"\2713";position:absolute;left:0;color:var(--c-primary);font-weight:700;font-size:.7rem}
.inst-badges{display:flex;gap:0;margin-top:auto}
.inst-badges .badge{flex:1;text-align:center;padding:10px 8px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .2s;text-decoration:none;display:block}
.badge-private{background:#c0392b;color:#fff;border-radius:0 0 0 14px}
.badge-private:hover{background:#e74c3c}
.badge-group{background:#2980b9;color:#fff;border-radius:0 0 14px 0}
.badge-group:hover{background:#3498db}
.badge-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;display:flex;align-items:center;justify-content:center}
.badge-modal-content{background:#fff;border-radius:16px;padding:32px;max-width:480px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.3);position:relative}
.badge-modal-content h3{font-family:var(--f-heading);font-size:1.3rem;margin-bottom:12px;color:var(--c-heading)}
.badge-modal-content p{font-size:.9rem;color:var(--c-body);line-height:1.6;margin-bottom:8px}
.badge-modal-close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--c-subtle)}
.section-heading{font-family:var(--f-heading);font-size:2.2rem;font-weight:700;color:var(--c-heading);text-align:center;margin-bottom:8px}
.section-sub{text-align:center;color:var(--c-subtle);font-size:1.05rem;max-width:600px;margin:0 auto 48px;line-height:1.6}
.soul-steps-section{padding:80px 0;background:var(--c-surface_alt)}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.step-card{text-align:center;padding:40px 28px;background:var(--c-bg);border-radius:16px;border:1px solid var(--c-border);position:relative}
.step-num{position:absolute;top:-14px;left:50%;transform:translateX(-50%);width:32px;height:32px;border-radius:50%;background:var(--c-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700}
.step-icon{font-size:2.2rem;display:block;margin:12px 0 14px}
.step-card h4{font-family:var(--f-heading);font-size:1.1rem;font-weight:600;color:var(--c-heading);margin-bottom:8px}
.step-card p{font-size:.88rem;color:var(--c-body);line-height:1.55}
.soul-trial-section{padding:80px 0}
.trial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.trial-card{text-align:center;padding:36px 28px;border-radius:16px;background:var(--c-surface);border:1px solid var(--c-border)}
.trial-icon{font-size:2.4rem;display:block;margin-bottom:14px}
.trial-card h4{font-family:var(--f-heading);font-size:1.1rem;font-weight:600;color:var(--c-heading);margin-bottom:8px}
.trial-card p{font-size:.92rem;color:var(--c-body);line-height:1.55}
.soul-cta-section{padding:80px 0;background:linear-gradient(135deg,#5DADE2,#2E86C1);text-align:center}
.soul-cta-inner h2{font-family:var(--f-heading);font-size:2.2rem;font-weight:700;color:#fff;margin-bottom:12px}
.soul-cta-inner p{font-size:1.05rem;color:rgba(255,255,255,.8);margin-bottom:28px}.soul-cta-inner p a{color:#85C1E9;text-decoration:underline}
.soul-cta-btn{display:inline-block;background:#fff;color:var(--c-primary);padding:14px 36px;border-radius:12px;font-weight:700;font-size:1rem;transition:all .25s}.soul-cta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.soul-footer{background:#1B2838;padding:60px 0 0;color:rgba(255,255,255,.7)}
.soul-footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.soul-footer h4{font-family:var(--f-heading);color:#fff;font-size:1rem;font-weight:600;margin-bottom:16px}
.soul-footer p{font-size:.88rem;line-height:1.6;margin-bottom:8px}
.footer-links{list-style:none}.footer-links li{margin-bottom:8px}.footer-links a{color:rgba(255,255,255,.65);font-size:.88rem;transition:color .2s}.footer-links a:hover{color:#fff}
.soul-footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:20px 0;font-size:.8rem;color:rgba(255,255,255,.4)}
body:not(.home) .site-content{padding-top:calc(72px + var(--soul-banner-h,0px))}
@media(max-width:1100px){.soul-hero-grid{grid-template-columns:1fr;gap:24px;padding-top:80px}.soul-hero-right{order:-1}.soul-eval-card,.soul-hero-form{max-width:520px;margin:0 auto}.instrument-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:1100px){.soul-nav{display:none;flex-direction:column;position:fixed;top:68px;left:0;right:0;background:#fff;padding:16px;box-shadow:0 8px 20px rgba(0,0,0,.1);z-index:999}.soul-nav.open{display:flex}.soul-menu-toggle{display:flex}.soul-header-phone,.soul-header-cta{display:none}.dropdown-menu{position:static;transform:none;box-shadow:none;border:none;padding-left:16px;background:transparent;min-width:0}.steps-grid,.trial-grid{grid-template-columns:1fr}.instrument-grid{grid-template-columns:repeat(2,1fr)}.soul-footer-grid{grid-template-columns:1fr}}
@media(max-width:600px){.soul-container{padding:0 20px}.soul-hero-grid{padding:76px 20px 30px}.instrument-grid{grid-template-columns:1fr}.section-heading{font-size:1.7rem}.soul-cta-inner h2{font-size:1.7rem}.eval-card-top{flex-direction:column;text-align:center}}

/* === 5-COLUMN FOOTER === */
.soul-footer-grid-5{display:grid;grid-template-columns:1fr 1fr 1fr 1.2fr 1fr;gap:32px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.soul-footer-grid-5 .footer-col h4{font-family:var(--f-heading);color:#fff;font-size:.95rem;font-weight:600;margin-bottom:12px}
.soul-footer-grid-5 .footer-links{list-style:none;padding:0;margin:0}
.soul-footer-grid-5 .footer-links li{margin-bottom:4px}
.soul-footer-grid-5 .footer-links a{color:rgba(255,255,255,.6);font-size:.78rem;transition:color .2s;line-height:1.4}
.soul-footer-grid-5 .footer-links a:hover{color:#fff}
.soul-footer-grid-5 .footer-col p{font-size:.82rem;margin-bottom:4px}
.soul-footer-grid-5 .footer-col p a{color:rgba(255,255,255,.7)}.soul-footer-grid-5 .footer-col p a:hover{color:#fff}
.soul-footer .footer-cities{font-size:.78rem;line-height:1.7;color:rgba(255,255,255,.5);margin:0}
.soul-footer .footer-cities a{color:rgba(255,255,255,.7);transition:color .15s}
.soul-footer .footer-cities a:hover{color:#fff}
@media(max-width:1100px){.soul-footer-grid-5{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.soul-footer-grid-5{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.soul-footer-grid-5{grid-template-columns:1fr}}
@media(max-width:1300px){.soul-header-cta{font-size:.92rem;padding:10px 16px}.soul-nav>a,.soul-nav .dropdown-trigger{font-size:.95rem;padding:8px 12px}.soul-header-phone{font-size:.92rem}.soul-header-login{font-size:.92rem;padding:7px 14px}}
@media(max-width:1100px){.soul-header-cta{font-size:.85rem;padding:9px 14px}.soul-nav>a,.soul-nav .dropdown-trigger{font-size:.88rem;padding:7px 10px}.soul-header-phone{display:none}.soul-header-login{font-size:.85rem;padding:6px 12px}}
/* Tablet and below — hide Student Login, shrink CTA */
@media(max-width:900px){
    .soul-header-login{display:none}
    .soul-header-inner{padding:0 18px;height:62px}
    .soul-header-cta{padding:8px 14px;font-size:.85rem}
    .soul-logo .logo-accent{font-size:1.4rem}
    .soul-logo .logo-rest{font-size:.86rem;letter-spacing:.8px}
    .soul-logo{gap:6px}
}
/* Small phones — keep logo readable, shrink everything proportionally */
@media(max-width:640px){
    .soul-header-inner{padding:0 14px;height:54px}
    .soul-logo .logo-accent{font-size:1.3rem}
    .soul-logo .logo-rest{font-size:.74rem;letter-spacing:.5px}
    .soul-logo{gap:4px}
    .soul-header-cta{padding:7px 12px;font-size:.78rem}
}
/* Tightest phones (iPhone SE, ≤400px) — drop "MUSIC LESSONS" text entirely
   so "Soul" + Book a Lesson + hamburger fit comfortably */
@media(max-width:400px){
    .soul-logo .logo-rest{display:none}
    .soul-logo .logo-accent{font-size:1.4rem}
    .soul-header-cta{padding:7px 11px;font-size:.78rem}
    .soul-header-inner{padding:0 12px;height:50px}
}
.soul-nav-mobile-cta{display:none}
@media(max-width:900px){.soul-nav-mobile-cta{display:block!important;text-align:center;padding:12px 16px;margin-top:10px;border-radius:10px;font-weight:700;font-size:.95rem;background:var(--c-primary);color:#fff!important}}

/* === READABILITY OVERHAUL (WCAG AA) === */
body{font-size:17px;line-height:1.7;color:#1A202C}
h1{font-size:40px;line-height:1.2}
h2{font-size:28px;line-height:1.3}
h3{font-size:20px;line-height:1.4}
.muted,.text-muted{color:#4A5568}
/* Prose width -- article/post containers only; homepage hero/grids stay full width */
.entry-content,.post-content,article.post .entry-content,article.page .entry-content,.prose{max-width:680px;margin-left:auto;margin-right:auto}
/* Min 44px touch targets on buttons and CTA-style links (NOT inline body or footer links) */
button,input[type=submit],input[type=button],.soul-cta-btn,.soul-header-cta,.soul-header-login,.eval-enroll-btn,.soul-nav-mobile-cta,.soul-menu-toggle{min-height:44px}
button,input[type=submit],input[type=button],.soul-cta-btn,.soul-header-cta,.soul-header-login,.eval-enroll-btn,.soul-nav-mobile-cta{display:inline-flex;align-items:center;justify-content:center}
/* Card padding */
.step-card,.trial-card,.badge-modal-content{padding:24px}
/* Section spacing -- desktop 80 (already in place); mobile 64 below */
.soul-instruments-section,.soul-steps-section,.soul-trial-section,.soul-cta-section{padding-top:80px;padding-bottom:80px}
@media(max-width:600px){
  h1{font-size:32px}
  .soul-instruments-section,.soul-steps-section,.soul-trial-section,.soul-cta-section{padding-top:64px;padding-bottom:64px}
}

/* === EVAL CARD -- readability + contrast fix (WCAG AA) === */
.eval-card-top{padding:24px;gap:20px;align-items:flex-start}
.eval-heading{font-size:1.5rem;line-height:1.3;color:#1A202C;font-weight:700;margin-bottom:10px}
.eval-text{font-size:1rem;line-height:1.6;color:#1A202C}
.eval-card-bottom{padding:20px 24px 24px}
.eval-card-bottom p{font-size:1rem;color:#1A202C;margin-bottom:8px;line-height:1.5}
.eval-card-bottom a:not(.eval-enroll-btn){color:#1F6FB2;font-weight:700;text-decoration:underline;text-underline-offset:3px}
.eval-card-bottom a:not(.eval-enroll-btn):hover{color:#154A75}
.eval-enroll-btn{background:#1F6FB2;color:#fff!important;padding:14px 64px;border-radius:10px;font-weight:700;font-size:1.1rem;min-height:48px;display:inline-flex;align-items:center;justify-content:center;margin-top:16px;letter-spacing:.3px;text-decoration:none}
.eval-enroll-btn:hover{background:#154A75;transform:translateY(-1px);box-shadow:0 6px 20px rgba(31,111,178,.35);color:#fff!important;text-decoration:none}

/* Mobile eval card -- center badge under text instead of left-aligning */
@media(max-width:600px){.eval-card-top{align-items:center}}

/* How It Works grid -- 4 cols desktop, 2x2 tablet, 1 col mobile */
.steps-grid{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.steps-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.steps-grid{grid-template-columns:1fr}}

/* === CUSTOM MOBILE NAV (bypasses Mega Menu plugin) === */
.soul-mobile-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;box-shadow:0 12px 24px rgba(15,23,42,.12);border-top:3px solid #1F6FB2;z-index:9998;max-height:80vh;overflow-y:auto}
.soul-mobile-nav.open{display:block}
.mobile-nav-list{list-style:none;padding:0;margin:0}
.mobile-nav-list>li{border-bottom:1px solid var(--c-border)}
.mobile-nav-list>li:last-child{border-bottom:none}
.mobile-nav-list>li>a{display:block;padding:14px 24px;color:#1A202C;font-size:1rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;min-height:44px;line-height:1.4}
.mobile-nav-list>li>a:hover{background:#F5F9FE;color:#1F6FB2}
.mobile-nav-section{padding:14px 24px 8px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1.4px;color:#64748B;background:#F5F9FE;border-bottom:1px solid var(--c-border)!important}

/* PART 1G: mobile nav family accordions (uses native <details>/<summary>) */
.mobile-nav-accordion>details{margin:0}
.mobile-nav-accordion>details>summary{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;color:#1A202C;font-size:1rem;font-weight:500;cursor:pointer;list-style:none;min-height:44px;line-height:1.4}
.mobile-nav-accordion>details>summary::-webkit-details-marker{display:none}
.mobile-nav-accordion>details>summary::after{content:'+';color:#1F6FB2;font-size:1.3rem;font-weight:300;transition:transform .2s}
.mobile-nav-accordion>details[open]>summary::after{content:'\2212'}
.mobile-nav-accordion>details>summary:hover{background:#F5F9FE;color:#1F6FB2}
.mobile-nav-sublist{list-style:none;padding:0;margin:0;background:#FAFBFD}
.mobile-nav-sublist li{border-top:1px solid var(--c-border)}
.mobile-nav-sublist li a{display:block;padding:12px 24px 12px 40px;color:#475569;font-size:.95rem;font-weight:400;text-decoration:none;min-height:44px;line-height:1.4;transition:background .15s,color .15s}
.mobile-nav-sublist li a:hover{background:#F5F9FE;color:#1F6FB2}
.mobile-nav-phone{font-weight:700!important;color:#1F6FB2!important;font-size:1.05rem!important}
.mobile-nav-cta-wrap{padding:14px 16px 20px;border-bottom:none!important}
.mobile-nav-cta{display:block!important;background:#1F6FB2;color:#fff!important;text-align:center;padding:14px 16px!important;border-radius:10px;font-weight:700!important;font-size:1rem!important;text-decoration:none;min-height:48px;display:flex!important;align-items:center;justify-content:center;transition:background .2s}
.mobile-nav-cta:hover{background:#154A75!important}
/* Mobile nav "Online Lessons" footer note (mirrors desktop Lessons mega-menu footer). */
.mobile-nav-online>a{display:flex!important;align-items:center;gap:10px;padding:12px 24px!important;background:linear-gradient(135deg,#FAF5FF,#F5F9FE);color:#1A202C!important;font-size:.92rem!important;font-weight:500;line-height:1.4;border-top:1px solid #DDD6FE;border-bottom:1px solid #DDD6FE}
.mobile-nav-online>a:hover{background:linear-gradient(135deg,#EDE9FE,#DBEAFE);color:#7C3AED!important}
.mobile-nav-online-pill{display:inline-block;background:#7C3AED;color:#fff;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:2px 7px;border-radius:4px}
@media(min-width:1101px){.soul-mobile-nav{display:none!important}}

/* === FAMILY CARDS (Variant A -- 5 instrument families) === */
.families-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;margin:0 0 56px}
.family-card{display:flex;flex-direction:column;background:#FFFFFF;border:1.5px solid var(--c-border);border-radius:16px;padding:28px 22px 22px;text-decoration:none;color:inherit;transition:transform .25s,box-shadow .25s,border-color .25s;position:relative;overflow:hidden;min-height:280px}
.family-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--family-color,#1F6FB2)}
.family-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(15,23,42,.10);border-color:var(--family-color,#1F6FB2);text-decoration:none;color:inherit}
.family-card .family-icon{font-size:2.4rem;line-height:1;margin-bottom:14px}
.family-card h3{font-family:var(--f-heading);font-size:1.35rem;font-weight:700;color:#1A202C;margin:0 0 8px;line-height:1.25}
.family-card .family-blurb{font-size:.95rem;color:#4A5568;line-height:1.5;margin:0 0 14px}
.family-card .family-list{list-style:none;padding:0;margin:0 0 18px;flex:1}
.family-card .family-list li{font-size:.92rem;color:#1A202C;padding:5px 0 5px 16px;position:relative;line-height:1.4}
.family-card .family-list li::before{content:"";position:absolute;left:0;top:11px;width:6px;height:6px;border-radius:50%;background:var(--family-color,#1F6FB2)}
.family-card .family-list li.family-more{color:#4A5568;font-size:.85rem;font-style:italic}
.family-card .family-list li.family-more::before{display:none}
.family-card .family-link{display:inline-flex;align-items:center;gap:6px;color:var(--family-color,#1F6FB2);font-weight:700;font-size:.95rem;margin-top:auto;transition:gap .2s}
.family-card:hover .family-link{gap:10px}

/* Family colors per CLAUDE.md Variant A */
.family-strings{--family-color:#7C3AED}
.family-piano{--family-color:#1F6FB2}
.family-guitar{--family-color:#D97706}
.family-theory{--family-color:#059669}
.family-specialist{--family-color:#E11D48}

/* Detailed family sections (anchor targets) */
.family-detail{scroll-margin-top:88px;margin-top:48px}
.family-detail:first-of-type{margin-top:24px}
.family-detail .inst-group-label{margin-top:0}

@media(max-width:1100px){.families-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.families-grid{grid-template-columns:repeat(2,1fr);gap:16px}.family-card{padding:24px 20px 20px;min-height:0}.family-card h3{font-size:1.2rem}}
@media(max-width:480px){.families-grid{grid-template-columns:1fr}}

/* === INSTRUMENT DETAIL PAGES === */
/* single-instrument.php uses these -- none were defined previously */
.soul-instrument-hero{padding:96px 0 56px;background:linear-gradient(180deg,#F5F9FE 0%,#FFFFFF 100%);text-align:center}
.soul-instrument-hero .inst-icon{font-size:3.5rem;display:inline-block;margin-bottom:8px}
.soul-instrument-hero h1{font-family:var(--f-heading);font-size:40px;font-weight:700;color:#1A202C;margin-bottom:14px}
.soul-instrument-hero p{font-size:1.125rem;color:#4A5568;line-height:1.6;max-width:680px;margin:0 auto 22px}
.inst-hero-badges{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
/* Instrument-page hero badges. Now anchor tags -- they all link somewhere, so they should LOOK clickable.
   Refined palette: softer pastels with deeper text + a subtle hairline border for definition.
   Hover state lifts slightly and saturates the background for clear feedback. */
.soul-badge{display:inline-flex;align-items:center;padding:7px 16px;border-radius:50px;font-size:.85rem;font-weight:600;letter-spacing:.2px;text-decoration:none;position:relative;border:1px solid transparent;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease;line-height:1.3;min-height:32px}
.soul-badge:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(15,23,42,.08)}
/* Private -- slate/blue (anchors as the canonical default lesson type) */
.soul-badge-private{background:#EFF6FF;color:#1E3A8A!important;border-color:#BFDBFE}
.soul-badge-private:hover{background:#DBEAFE;border-color:#93C5FD}
/* Group -- teal (a complementary partner color to the blue, evokes ensemble play) */
.soul-badge-group{background:#ECFDF5;color:#065F46!important;border-color:#A7F3D0}
.soul-badge-group:hover{background:#D1FAE5;border-color:#6EE7B7}
/* Specialist -- amber (signals premium, outsourced instructor) */
.soul-badge-outsourced{background:#FFFBEB;color:#92400E!important;border-color:#FDE68A}
.soul-badge-outsourced:hover{background:#FEF3C7;border-color:#FCD34D}
/* Online badge -- purple gradient, links to /online-lessons/, with red NEW corner */
/* Online -- keeps the violet gradient (matches the NEW pill + Online Lessons brand color), stays the visual standout among the badges */
.soul-badge-online{background:linear-gradient(135deg,#F5F3FF,#EDE9FE);color:#6D28D9!important;border-color:#C4B5FD;font-weight:700}
.soul-badge-online:hover{background:linear-gradient(135deg,#EDE9FE,#DDD6FE);border-color:#A78BFA;box-shadow:0 4px 12px rgba(124,58,237,.18)}
.soul-badge-new{display:inline-block;background:#E11D48;color:#fff;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:1px 6px;border-radius:3px;margin-left:6px;vertical-align:middle;line-height:1.4}

/* ===== Lesson-type info popup (fires from instrument hero badges) ===== */
.soul-popup-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:center;justify-content:center;z-index:9999;padding:16px;opacity:0;transition:opacity .18s ease}
.soul-popup-overlay.is-open{display:flex;opacity:1}
.soul-popup{background:#fff;border-radius:14px;max-width:480px;width:100%;padding:28px 28px 24px;box-shadow:0 18px 60px rgba(15,23,42,.28);position:relative;transform:translateY(8px);transition:transform .2s ease}
.soul-popup-overlay.is-open .soul-popup{transform:translateY(0)}
.soul-popup-close{position:absolute;top:10px;right:12px;background:transparent;border:0;font-size:26px;line-height:1;color:#64748B;cursor:pointer;padding:6px 10px;border-radius:6px;transition:background .15s ease,color .15s ease}
.soul-popup-close:hover{background:#F1F5F9;color:#1A202C}
.soul-popup-eyebrow{display:inline-block;font-family:var(--f-sans,'Josefin Sans',sans-serif);font-size:11px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:#64748B;margin-bottom:6px}
.soul-popup-title{font-family:var(--f-heading,'Cormorant Garamond',serif);font-size:26px;font-weight:700;color:#1A202C;margin:0 0 12px;line-height:1.2}
.soul-popup-summary{font-size:15.5px;line-height:1.65;color:#334155;margin:0 0 18px}
.soul-popup-cta{display:inline-flex;align-items:center;gap:6px;background:#0066CC;color:#fff!important;padding:11px 20px;border-radius:8px;text-decoration:none;font-weight:600;font-size:14.5px;transition:background .15s ease,transform .12s ease}
.soul-popup-cta:hover{background:#0052A3;transform:translateY(-1px)}
.soul-popup[data-popup-kind="private"] .soul-popup-eyebrow{color:#1E3A8A}
.soul-popup[data-popup-kind="group"]   .soul-popup-eyebrow{color:#065F46}
.soul-popup[data-popup-kind="online"]  .soul-popup-eyebrow{color:#6D28D9}
.soul-popup[data-popup-kind="online"]  .soul-popup-cta{background:#6D28D9}
.soul-popup[data-popup-kind="online"]  .soul-popup-cta:hover{background:#5B21B6}
.soul-popup[data-popup-kind="group"]   .soul-popup-cta{background:#059669}
.soul-popup[data-popup-kind="group"]   .soul-popup-cta:hover{background:#047857}
@media(max-width:600px){
  .soul-popup{padding:24px 22px 20px;border-radius:12px}
  .soul-popup-title{font-size:22px}
  .soul-popup-summary{font-size:15px}
}

/* ===== Lesson-type landing pages (/private-lessons/, /group-lessons/) ===== */
.lt-container{max-width:920px;margin:0 auto;padding:0 24px}
.lt-hero{padding:72px 0 56px;background:linear-gradient(180deg,#F5F9FE 0%,#FFFFFF 100%)}
.lt-hero-private{background:linear-gradient(180deg,#EFF6FF 0%,#FFFFFF 100%)}
.lt-hero-group{background:linear-gradient(180deg,#ECFDF5 0%,#FFFFFF 100%)}
.lt-eyebrow{display:inline-block;font-family:var(--f-sans,'Josefin Sans',sans-serif);font-size:12px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;color:#64748B;margin-bottom:12px}
.lt-hero-private .lt-eyebrow{color:#1E3A8A}
.lt-hero-group .lt-eyebrow{color:#065F46}
.lt-title{font-family:var(--f-heading,'Cormorant Garamond',serif);font-size:48px;font-weight:700;color:#1A202C;margin:0 0 16px;line-height:1.15}
.lt-lead{font-size:18px;line-height:1.7;color:#334155;max-width:680px;margin:0 0 28px}
.lt-hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.lt-btn{display:inline-flex;align-items:center;justify-content:center;padding:13px 24px;border-radius:8px;text-decoration:none;font-weight:600;font-size:15px;transition:transform .12s ease,background .15s ease,box-shadow .15s ease;min-height:44px}
.lt-btn-primary{background:#0066CC;color:#fff!important}
.lt-btn-primary:hover{background:#0052A3;transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,102,204,.25)}
.lt-btn-ghost{background:#fff;color:#0066CC!important;border:1px solid #BFDBFE}
.lt-btn-ghost:hover{background:#F0F7FF}
.lt-btn-large{padding:16px 32px;font-size:16px}
.lt-section{padding:56px 0}
.lt-section-alt{background:#F5F9FE}
.lt-section h2{font-family:var(--f-heading,'Cormorant Garamond',serif);font-size:32px;font-weight:700;color:#1A202C;margin:0 0 12px;line-height:1.2}
.lt-section-lead{font-size:17px;line-height:1.7;color:#334155;max-width:680px;margin:0 0 36px}
.lt-paths{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px}
.lt-path{background:#fff;border:1px solid #E2E8F0;border-radius:12px;padding:28px 24px 24px;position:relative}
.lt-section-alt .lt-path{background:#fff}
.lt-path-num{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#0066CC;color:#fff;font-weight:700;font-size:15px;margin-bottom:14px}
.lt-hero-private + .lt-section .lt-path-num,.lt-hero-private ~ .lt-section .lt-path-num{background:#1E3A8A}
.lt-hero-group + .lt-section .lt-path-num,.lt-hero-group ~ .lt-section .lt-path-num{background:#059669}
.lt-path h3{font-family:var(--f-heading,'Cormorant Garamond',serif);font-size:21px;font-weight:700;color:#1A202C;margin:0 0 10px;line-height:1.25}
.lt-path p{font-size:15px;line-height:1.65;color:#334155;margin:0}
.lt-bullets{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:14px}
.lt-bullets li{padding-left:28px;position:relative;font-size:16px;line-height:1.65;color:#334155}
.lt-bullets li::before{content:"";position:absolute;left:0;top:9px;width:14px;height:14px;border-radius:50%;background:#DBEAFE;border:3px solid #0066CC}
.lt-honest{font-size:16px;color:#64748B;font-style:italic;margin:8px 0 12px}
.lt-logistics{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:24px}
.lt-log-item{background:#fff;border:1px solid #E2E8F0;border-radius:10px;padding:16px 18px;font-size:15px;line-height:1.55;color:#334155}
.lt-section-alt .lt-log-item{background:#fff}
.lt-log-item strong{color:#1A202C}
.lt-cta-section{padding:64px 0;background:linear-gradient(135deg,#0066CC 0%,#0052A3 100%);color:#fff;text-align:center}
.lt-cta-inner h2{font-family:var(--f-heading,'Cormorant Garamond',serif);font-size:34px;font-weight:700;color:#fff;margin:0 0 14px}
.lt-cta-inner p{font-size:17px;line-height:1.6;color:#E0F2FE;max-width:560px;margin:0 auto 24px}
.lt-cta-section .lt-btn-primary{background:#fff;color:#0066CC!important}
.lt-cta-section .lt-btn-primary:hover{background:#F0F7FF}
@media(max-width:900px){
  .lt-paths{grid-template-columns:1fr;gap:18px}
}
@media(max-width:600px){
  .lt-title{font-size:36px}
  .lt-section h2{font-size:26px}
  .lt-cta-inner h2{font-size:28px}
  .lt-hero{padding:48px 0 40px}
  .lt-section{padding:40px 0}
}

.soul-section{padding:80px 0}
.soul-section-alt{padding:80px 0;background:#F5F9FE}
.soul-section-header{text-align:center;margin-bottom:40px}
.soul-section-header h2{font-family:var(--f-heading);font-size:28px;font-weight:700;color:#1A202C}

.inst-content-grid{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:start}
.inst-main{min-width:0}
.inst-main h2{font-family:var(--f-heading);font-size:28px;font-weight:700;color:#1A202C;margin:32px 0 16px}
.inst-main h2:first-child{margin-top:0}
.inst-main p{font-size:17px;line-height:1.7;color:#1A202C;margin-bottom:16px;max-width:680px}
.inst-approach{margin-top:8px}
.inst-private-note{background:#F5F9FE;border-left:4px solid #1F6FB2;padding:20px 24px;border-radius:8px;margin-top:32px;font-size:1rem;line-height:1.7;color:#1A202C}
.inst-private-note strong{color:#0A1F3D}

.soul-benefits-list{list-style:none;padding:0;margin:0 0 16px}
.soul-benefits-list li{position:relative;padding:10px 0 10px 32px;font-size:17px;line-height:1.6;color:#1A202C;border-bottom:1px solid var(--c-border)}
.soul-benefits-list li::before{content:"\2713";position:absolute;left:8px;top:10px;color:#1F6FB2;font-weight:700;font-size:1rem}
.soul-benefits-list li:last-child{border-bottom:none}

.inst-sidebar{display:flex;flex-direction:column;gap:20px;position:sticky;top:88px}
.inst-sidebar-card{background:#FFFFFF;border:1px solid var(--c-border);border-radius:14px;padding:24px;box-shadow:0 4px 16px rgba(15,23,42,.04)}
.inst-sidebar-card h3{font-family:var(--f-heading);font-size:1.25rem;font-weight:700;color:#1A202C;margin-bottom:14px}
.inst-sidebar-card p{font-size:.95rem;color:#4A5568;line-height:1.6;margin-bottom:16px}
.inst-detail{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--c-border);font-size:.95rem;color:#1A202C;gap:12px}
.inst-detail:last-of-type{border-bottom:none}
.detail-label{font-weight:600;color:#4A5568}
.inst-detail a{color:#1F6FB2;font-weight:600;text-decoration:underline;text-underline-offset:3px}
.inst-detail a:hover{color:#154A75}

/* === BUTTON SYSTEM (WCAG AA) === */
.soul-btn,a.soul-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:10px;font-family:var(--f-body);font-size:1rem;font-weight:700;line-height:1.2;text-decoration:none!important;cursor:pointer;transition:all .2s;min-height:44px;border:1.5px solid transparent}
a.soul-btn-primary,.soul-btn-primary{background:#1F6FB2;color:#FFFFFF!important;border-color:#1F6FB2;text-decoration:none!important}
a.soul-btn-primary:hover,.soul-btn-primary:hover{background:#154A75;border-color:#154A75;transform:translateY(-1px);box-shadow:0 6px 16px rgba(31,111,178,.3);color:#FFFFFF!important}
a.soul-btn-outline,.soul-btn-outline{background:#FFFFFF;color:#1F6FB2!important;border-color:#1F6FB2;text-decoration:none!important}
a.soul-btn-outline:hover,.soul-btn-outline:hover{background:#F5F9FE;color:#154A75!important;border-color:#154A75}

/* === RELATED INSTRUMENTS GRID === */
.soul-instruments-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.soul-instrument-card{background:#FFFFFF;border:1px solid var(--c-border);border-radius:14px;padding:24px;text-decoration:none;color:inherit;transition:all .25s;display:block}
.soul-instrument-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(31,111,178,.1);border-color:#1F6FB2}
.soul-instrument-card .card-icon{font-size:2.4rem;margin-bottom:12px;display:block}
.soul-instrument-card h3{font-family:var(--f-heading);font-size:1.1rem;font-weight:700;color:#1A202C;margin-bottom:8px}
.soul-instrument-card p{font-size:.92rem;color:#4A5568;line-height:1.55}

@media(max-width:1100px){
  .inst-content-grid{grid-template-columns:1fr;gap:32px}
  .inst-sidebar{position:static}
  .soul-instruments-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .soul-instrument-hero{padding:72px 0 40px}
  .soul-instrument-hero h1{font-size:32px}
  .soul-section,.soul-section-alt{padding:64px 0}
  .soul-instruments-grid{grid-template-columns:1fr}
}

/* === BLOG POST + ARCHIVE === */
.soul-single-post,.soul-archive{max-width:680px;margin:0 auto;padding:96px 24px 80px}
.soul-single-post .post-header{margin-bottom:32px}
.soul-single-post .post-header h1{font-family:var(--f-heading);font-size:40px;line-height:1.2;color:#1A202C;font-weight:700;margin-bottom:14px}
.soul-single-post .post-meta{color:#4A5568;font-size:.95rem;margin-bottom:0}
.soul-single-post .post-meta a{color:#1F6FB2;font-weight:600;text-decoration:none}
.soul-single-post .post-meta a:hover{color:#154A75;text-decoration:underline}
.soul-single-post .entry-content{font-size:17px;line-height:1.7;color:#1A202C}
.soul-single-post .entry-content p{margin-bottom:18px}
.soul-single-post .entry-content h2{font-size:28px;margin:36px 0 14px;color:#1A202C;font-family:var(--f-heading)}
.soul-single-post .entry-content h3{font-size:20px;margin:28px 0 12px;color:#1A202C;font-family:var(--f-heading)}
.soul-single-post .entry-content a{color:#1F6FB2;text-decoration:underline;text-underline-offset:3px;font-weight:600}
.soul-single-post .entry-content a:hover{color:#154A75}
.soul-single-post .entry-content ul,.soul-single-post .entry-content ol{margin:0 0 18px 24px}
.soul-single-post .entry-content li{margin-bottom:6px}
.soul-single-post .post-nav{margin-top:48px;padding-top:24px;border-top:1px solid var(--c-border);display:flex;justify-content:space-between;gap:20px;font-size:.95rem}
.soul-single-post .post-nav a{color:#1F6FB2;font-weight:600;text-decoration:none}
.soul-single-post .post-nav a:hover{color:#154A75;text-decoration:underline}
.soul-back-link{display:inline-block;margin-top:32px;color:#1F6FB2;font-weight:700;text-decoration:none}
.soul-back-link:hover{color:#154A75;text-decoration:underline}

.soul-archive header{margin-bottom:32px}
.soul-archive header h1{font-family:var(--f-heading);font-size:40px;color:#1A202C;font-weight:700;line-height:1.2}
.soul-archive header p{color:#4A5568;font-size:1.05rem;margin-top:10px;line-height:1.6}
.soul-archive article{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--c-border)}
.soul-archive article h2{font-family:var(--f-heading);font-size:24px;margin-bottom:8px;line-height:1.3}
.soul-archive article h2 a{color:#1A202C;text-decoration:none}
.soul-archive article h2 a:hover{color:#1F6FB2}
.soul-archive .archive-meta{color:#4A5568;font-size:.92rem;margin-bottom:12px}
.soul-archive article p{color:#1A202C;font-size:1rem;line-height:1.7;margin-bottom:10px}
.soul-archive .read-more{color:#1F6FB2;font-weight:700;font-size:.95rem;text-decoration:none}
.soul-archive .read-more:hover{color:#154A75;text-decoration:underline}

/* === SHEET MUSIC PREVIEW PAGE (Phase 4) === */
.sm-preview-section{padding:48px 0 80px}
.sm-back-link{margin-bottom:14px}
.sm-back-link a{color:#1F6FB2;font-weight:600;text-decoration:none;font-size:.95rem}
.sm-back-link a:hover{color:#154A75;text-decoration:underline}
.sm-preview-title{font-family:var(--f-heading);font-size:40px;line-height:1.15;color:#1A202C;font-weight:700;margin-bottom:8px;max-width:900px}
.sm-preview-meta{color:#4A5568;font-size:1.1rem;margin-bottom:32px}

.sm-preview-layout{display:grid;grid-template-columns:1fr 360px;gap:40px;align-items:start}
.sm-preview-main{min-width:0}
.sm-preview-sidebar{display:flex;flex-direction:column;gap:18px;position:sticky;top:88px}

.sm-pdf-preview{margin-bottom:18px;border:1px solid var(--c-border);border-radius:10px;overflow:hidden;background:#FFFFFF;box-shadow:0 8px 28px rgba(15,23,42,.08)}
.sm-pdf-preview-image{display:block;width:100%;height:auto;background:#FFFFFF}
.sm-pdf-note{margin:8px 0 0;color:#4A5568;font-size:.9rem;font-style:italic}

.sm-no-pdf{background:#F5F9FE;border:1px solid var(--c-border);border-radius:12px;padding:32px;text-align:center;color:#4A5568;margin-bottom:18px}
.sm-no-pdf p{margin:0}

.sm-action-bar{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:32px}

.sm-description{font-size:17px;line-height:1.7;color:#1A202C;max-width:680px}
.sm-description h2{font-family:var(--f-heading);font-size:28px;color:#1A202C;font-weight:700;margin:32px 0 14px;line-height:1.3}
.sm-description h3{font-family:var(--f-heading);font-size:20px;color:#1A202C;font-weight:700;margin:24px 0 10px;line-height:1.4}
.sm-description p{margin-bottom:16px}
.sm-description ul,.sm-description ol{margin:0 0 16px 24px}
.sm-description li{margin-bottom:6px}
.sm-description a{color:#1F6FB2;text-decoration:underline;font-weight:600}
.sm-description a:hover{color:#154A75}

/* Sidebar cards */
.sm-card{background:#FFFFFF;border:1px solid var(--c-border);border-radius:14px;padding:20px;box-shadow:0 4px 12px rgba(15,23,42,.04)}
.sm-card h3{font-family:var(--f-heading);font-size:1.2rem;color:#1A202C;font-weight:700;margin:0 0 8px;line-height:1.3}
.sm-card h4{font-family:var(--f-heading);font-size:1.05rem;color:#1A202C;font-weight:700;margin:0 0 8px;line-height:1.3}
.sm-card p{font-size:.95rem;color:#1A202C;line-height:1.55;margin:0 0 12px}
.sm-card p:last-of-type{margin-bottom:0}
.sm-card a:not(.soul-btn){color:#1F6FB2!important;text-decoration:none;font-weight:600}
.sm-card a:not(.soul-btn):hover{color:#154A75!important;text-decoration:underline;text-underline-offset:3px}
.sm-card-btn{width:100%}

.sm-cta-card{background:linear-gradient(135deg,#F5F9FE 0%,#FFFFFF 100%);border:2px solid #1F6FB2;box-shadow:0 8px 24px rgba(31,111,178,.12)}
.sm-cta-icon{font-size:2rem;margin-bottom:8px;line-height:1}

.sm-contact-card .sm-hours{color:#4A5568;font-size:.85rem;margin-bottom:10px;font-weight:500}
.sm-contact-card p{margin-bottom:6px}

.sm-tools-list{list-style:none;padding:0;margin:0}
.sm-tools-list li{border-bottom:1px solid var(--c-border)}
.sm-tools-list li:last-child{border-bottom:none}
.sm-tools-list a{display:flex;align-items:center;gap:10px;padding:10px 0;font-size:.95rem;color:#1A202C!important;font-weight:500!important;text-decoration:none!important;transition:color .15s,padding-left .15s}
.sm-tools-list a:hover{color:#1F6FB2!important;padding-left:4px}
.sm-tools-list a span{font-size:1.1rem;line-height:1}

.sm-testimonial-card blockquote{margin:0 0 10px;color:#1A202C;font-size:.95rem;line-height:1.6;font-style:italic;padding-left:14px;border-left:3px solid #1F6FB2}
.sm-testimonial-card cite{color:#4A5568;font-size:.88rem;font-style:normal;font-weight:600;display:block;margin-bottom:14px}
.sm-testimonial-card .sm-more-stories{margin:0}

@media(max-width:1100px){
    .sm-preview-layout{grid-template-columns:1fr;gap:32px}
    .sm-preview-sidebar{position:static}
}
@media(max-width:600px){
    .sm-preview-section{padding:32px 0 64px}
    .sm-preview-title{font-size:32px}
    .sm-card{padding:18px}
}

/* === SHEET MUSIC ARCHIVE TABLE (Excel-style) === */
.sheet-archive-section{padding:48px 0 80px}
.sheet-archive-section .archive-header{margin-bottom:24px}
.sheet-archive-section .archive-header h1{font-family:var(--f-heading);font-size:40px;line-height:1.2;color:#1A202C;font-weight:700;margin-bottom:10px}
.sheet-archive-section .archive-header p{color:#4A5568;font-size:1.05rem;line-height:1.6;max-width:780px;margin:0}

.archive-filters{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;align-items:center}
.archive-filters input[type="search"],.archive-filters select{padding:10px 14px;font-size:1rem;border:1.5px solid var(--c-border);border-radius:8px;background:#FFFFFF;color:#1A202C;font-family:var(--f-body);min-height:44px;transition:border-color .15s,box-shadow .15s}
.archive-filters input[type="search"]{flex:1;min-width:240px;max-width:380px}
.archive-filters select{min-width:160px}
.archive-filters input[type="search"]:focus,.archive-filters select:focus{outline:none;border-color:#1F6FB2;box-shadow:0 0 0 3px rgba(31,111,178,.15)}
.archive-count{color:#4A5568;font-size:.95rem;margin-left:auto;font-weight:500}

.archive-table-wrap{overflow-x:auto;border:1px solid var(--c-border);border-radius:12px;background:#FFFFFF}
.archive-table{width:100%;border-collapse:collapse;font-size:.93rem;line-height:1.35}
.archive-table thead th{text-align:left;padding:8px 14px;background:#F5F9FE;font-family:var(--f-body);font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:1px;color:#4A5568;border-bottom:1px solid var(--c-border);white-space:nowrap}
.archive-table thead th.col-toggle,.archive-table thead th.col-actions{width:42px}
.archive-table tbody tr.archive-row{border-bottom:1px solid var(--c-border);transition:background .15s}
.archive-table tbody tr.archive-row:hover{background:#FAFBFD}
.archive-table tbody tr.archive-row:last-child{border-bottom:none}
.archive-table td{padding:7px 14px;color:#1A202C;vertical-align:middle}
.archive-table .col-title{font-weight:600}
.archive-table .col-title a{color:#1A202C;text-decoration:none;transition:color .15s}
.archive-table .col-title a:hover{color:#1F6FB2;text-decoration:underline;text-underline-offset:3px}
.archive-table .col-composer,.archive-table .col-instrument,.archive-table .col-level{color:#4A5568;font-size:.9rem}

.archive-table .toggle-expand{width:26px;height:26px;border-radius:5px;border:1.5px solid var(--c-border);background:#FFFFFF;color:#1F6FB2;font-size:1.05rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;line-height:1;padding:0}
.archive-table .toggle-expand:hover{background:#1F6FB2;color:#FFFFFF;border-color:#1F6FB2}
.archive-table .toggle-expand[aria-expanded="true"]{background:#1F6FB2;color:#FFFFFF;border-color:#1F6FB2}

.archive-table .row-download{color:#1F6FB2;font-size:1.1rem;text-decoration:none;display:inline-flex;width:30px;height:30px;align-items:center;justify-content:center;border-radius:5px;transition:background .15s}
.archive-table .row-download:hover{background:#F5F9FE}

.archive-row-detail td{padding:0;background:#F8FAFC;border-bottom:1px solid var(--c-border)}
.row-detail-inner{padding:12px 18px}
.row-excerpt{margin:0 0 8px;color:#1A202C;line-height:1.5;font-size:.9rem;max-width:680px}
.row-actions-inline{display:flex;gap:8px;flex-wrap:wrap}

/* === Admin-only inline row controls (edit/trash) === */
/* Use absolute positioning so the icons don't disrupt the level cell's
   vertical baseline (float:right was bumping the level text up). */
.archive-table .col-level{position:relative;padding-right:64px}
.row-admin-actions{position:absolute;top:50%;right:14px;transform:translateY(-50%);display:inline-flex;gap:4px;align-items:center}
.row-admin-icon{width:24px;height:24px;padding:4px;border:none;background:transparent;color:#94A3B8;cursor:pointer;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;transition:color .15s,background .15s;text-decoration:none;line-height:0}
.row-admin-icon svg{width:16px;height:16px;display:block}
.row-admin-edit:hover{color:#1F6FB2;background:rgba(31,111,178,.1)}
.row-admin-delete:hover{color:#DC2626;background:rgba(220,38,38,.1)}
.row-admin-icon:focus-visible{outline:2px solid #1F6FB2;outline-offset:1px}
.row-admin-icon:disabled{opacity:.5;cursor:wait}

.archive-empty,.archive-empty-initial{text-align:center;color:#4A5568;font-size:1.05rem;padding:40px 20px;background:#F5F9FE;border:1px solid var(--c-border);border-radius:12px;margin-top:24px}
.archive-empty-initial p{margin:0 0 6px}
.archive-empty-initial p:last-child{margin:0;color:#4A5568;font-size:.95rem}

/* Mobile inline meta under title -- surfaces composer + instrument when the dedicated columns are hidden at narrow widths. */
.archive-table .col-title-meta{display:none}
@media(max-width:900px){
    .archive-table th.col-composer,.archive-table td.col-composer{display:none}
    .archive-table .col-title-meta{display:block;font-size:.78rem;color:#4A5568;font-weight:400;margin-top:3px;line-height:1.35}
}
@media(max-width:600px){
    .archive-table th.col-instrument,.archive-table td.col-instrument{display:none}
    .archive-filters input[type="search"]{max-width:100%;flex:1 1 100%}
    .archive-filters select{flex:1;min-width:0}
    .archive-count{flex:1 1 100%;margin-left:0;text-align:center}
    .sheet-archive-section .archive-header h1{font-size:32px}
}

/* === GENERIC PAGE CONTENT WRAPPER === */
.soul-page-content{max-width:680px;margin:0 auto;font-size:17px;line-height:1.7;color:#1A202C}
.soul-page-content p{margin-bottom:18px}
.soul-page-content h2{font-size:28px;margin:36px 0 14px;color:#1A202C;font-family:var(--f-heading)}
.soul-page-content h3{font-size:20px;margin:28px 0 12px;color:#1A202C;font-family:var(--f-heading)}
.soul-page-content a{color:#1F6FB2;text-decoration:underline;font-weight:600}
.soul-page-content a:hover{color:#154A75}
.soul-page-content ul,.soul-page-content ol{margin:0 0 18px 24px}
.soul-page-content li{margin-bottom:6px}

/* ================================================================
   PRIMARY NAV -- config-driven mega menu (column layout)
   Driven by SOUL_NAV_* constants in inc/config.php
   Replaces Max Mega Menu plugin output.
   ================================================================ */

.soul-nav-links{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:2px}
.soul-nav-item{position:relative}
.soul-nav-link{display:inline-flex!important;align-items:center;gap:5px;padding:14px 22px!important;border-radius:8px;color:#1A202C!important;font-size:1.22rem!important;font-weight:500!important;text-decoration:none;transition:all .15s;font-family:var(--f-body);white-space:nowrap;background:transparent;border:none;cursor:pointer;letter-spacing:-.005em;line-height:1.2}
.soul-nav-link:hover{color:#3498DB;background:rgba(93,173,226,.08)}
.soul-nav-caret{font-size:.65rem;opacity:.6;transition:transform .2s;line-height:1}
.soul-nav-item.has-mm:hover .soul-nav-link,.soul-nav-item.has-mm:focus-within .soul-nav-link{color:#2C3E50;background:#F0F9FF;font-weight:600}
.soul-nav-item.has-mm:hover .soul-nav-caret,.soul-nav-item.has-mm:focus-within .soul-nav-caret{transform:rotate(180deg)}
/* Dropdown trigger button -- looks like a link, but doesn't navigate */
button.soul-nav-link{cursor:default}

/* Invisible hover-bridge: extends .soul-nav-item hit area downward to cover
   the gap between link text and the top of the fixed-position dropdown panel. */
.soul-nav-item.has-mm::after{content:'';position:absolute;top:100%;left:0;right:0;height:24px;pointer-events:auto}
.soul-nav-item.has-mm:not(:hover):not(:focus-within)::after{pointer-events:none}

/* Mega panel -- fixed, hover-triggered. Width adapts to column count. */
.soul-mm-panel{position:fixed;top:68px;left:50%;transform:translateX(-50%) translateY(-8px);background:#fff;border-top:3px solid var(--c-primary);border-radius:0 0 16px 16px;box-shadow:0 16px 48px rgba(15,23,42,0.12);width:calc(100vw - 32px);padding:28px 24px;opacity:0;visibility:hidden;transition:opacity .15s ease,transform .15s ease,visibility 0s linear .15s;z-index:1001;pointer-events:none}
.soul-mm-panel.cols-5{max-width:1100px}
.soul-mm-panel.cols-4{max-width:920px}
.soul-mm-panel.cols-3{max-width:720px}
.soul-mm-panel.cols-2{max-width:520px}
.soul-nav-item.has-mm:hover .soul-mm-panel,.soul-nav-item.has-mm:focus-within .soul-mm-panel{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);pointer-events:auto;transition:opacity .15s ease,transform .15s ease,visibility 0s linear 0s}

/* Columns -- grid adapts via .cols-N class */
.soul-mm-cols{display:grid;gap:18px}
.soul-mm-panel.cols-5 .soul-mm-cols{grid-template-columns:repeat(5,1fr)}
.soul-mm-panel.cols-4 .soul-mm-cols{grid-template-columns:repeat(4,1fr)}
.soul-mm-panel.cols-3 .soul-mm-cols{grid-template-columns:repeat(3,1fr)}
.soul-mm-panel.cols-2 .soul-mm-cols{grid-template-columns:repeat(2,1fr)}

/* Column header */
.soul-mm-header{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:#2C3E50;padding-left:12px;border-left:4px solid var(--mm-color,var(--c-primary));margin:0 0 12px;line-height:1.2;font-family:var(--f-body)}

/* List */
.soul-mm-list{list-style:none;margin:0;padding:0}
.soul-mm-list li{margin-bottom:2px}
.soul-mm-list li.soul-mm-li-sep{margin-top:10px;padding-top:10px;border-top:1px solid #E5E7EB}
/* PART 2E: footer strip at the bottom of the Lessons mega menu */
.soul-mm-footer{margin-top:18px;padding:12px 16px;background:linear-gradient(135deg,#FAF5FF,#F5F9FE);border:1px solid #E5E7EB;border-radius:8px;font-size:13px;color:#475569;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.soul-mm-footer-pill{display:inline-block;background:#7C3AED;color:#fff;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:2px 7px;border-radius:4px}
.soul-mm-footer a{color:#1F6FB2;font-weight:600;text-decoration:none}
.soul-mm-footer a:hover{text-decoration:underline;text-underline-offset:2px}
.soul-mm-item{display:flex;flex-direction:column;padding:8px 12px;border-radius:8px;color:inherit;text-decoration:none;transition:background .15s,padding-left .15s}
.soul-mm-item:hover{background:#F5F9FE;padding-left:16px}
.soul-mm-name{font-size:14px;font-weight:600;color:#2C3E50;line-height:1.3}
.soul-mm-desc{font-size:12px;color:#94A3B8;line-height:1.4;margin-top:2px}
.soul-mm-badge{display:inline-block;font-size:.55rem;font-weight:800;background:#16A34A;color:#fff;padding:1px 5px;border-radius:4px;letter-spacing:.5px;margin-left:4px;vertical-align:middle;line-height:1.2}

/* Tighten link padding at narrower widths so all 6 nav items fit */
@media(max-width:1300px){
    .soul-nav-link{font-size:1.05rem;padding:10px 16px}
}
@media(max-width:1200px){
    .soul-nav-link{font-size:1rem;padding:9px 13px}
}

/* Hide entire mega menu under 1100px -- mobile nav takes over */
@media(max-width:1100px){
    .soul-nav{display:none}
    .soul-mm-panel{display:none}
}

/* ============================================================
   VIOLIN PAGE + REUSABLE INSTRUMENT-ARTICLE COMPONENTS (May 6 2026)
   --------------------------------------------------------------
   These component classes drive the new /violin/ long-form article
   template (page-violin.php) and are designed to be reused for any
   future per-instrument page-{slug}.php template:
     .vp-page / .vp-container / .vp-hero / .vp-breadcrumb / .vp-badge*
     .photo-full / .photo-caption
     .callout / .callout-title / .callout-purple / .callout-green
     .profiles / .profile / .profile-icon / .profile-title / .profile-desc
     .techniques-grid / .tech-item / .tech-dot
     .doors-grid / .door-card / .door-accent / .door-name / .door-desc
     .tools-strip / .tools-strip-title / .tools-strip-sub / .tools-row / .tool-link
     .faq-item / .faq-q / .faq-a
     .lesson-details / .detail-row / .detail-label / .detail-val
     .cta-block / .cta-buttons / .btn-primary / .btn-secondary
     .about-resource
   ============================================================ */

.vp-page{padding:0 0 60px}
.vp-container{max-width:860px;margin:0 auto;padding:0 28px}
.vp-hero{padding:64px 0 48px;border-bottom:1px solid #F1F5F9}
.vp-breadcrumb{font-size:12px;color:#94A3B8;margin-bottom:20px;letter-spacing:0.3px}
.vp-breadcrumb a{color:#5DADE2;text-decoration:none}
.vp-breadcrumb a:hover{text-decoration:underline}
.vp-hero h1{font-family:var(--f-heading);font-size:clamp(2.4rem,5vw,3.4rem);font-weight:600;color:#1B2838;line-height:1.1;margin-bottom:16px;letter-spacing:-0.5px}
.vp-hero h1 em{font-style:italic;color:#5DADE2;font-weight:400}
.vp-hero .vp-intro{font-family:var(--f-body);font-size:18px;color:#475569;line-height:1.7;max-width:680px;margin-bottom:24px}
.vp-badge-row{display:flex;gap:6px;flex-wrap:wrap;margin:14px 0}
/* Article-page format badges — same checkmark-pill design as the homepage
   .cs-fmt-on indicators. All filled blue (signals "yes, available"); the
   text already says which format. Consistent visual language site-wide. */
.vp-badge{
    display:inline-flex;align-items:center;gap:5px;
    padding:5px 12px;border-radius:50px;
    font-size:.78rem;font-weight:600;letter-spacing:.01em;
    font-family:var(--f-body);text-decoration:none;cursor:pointer;
    background:var(--c-primary,#1F6FB2);
    color:#fff!important;
    border:1.5px solid var(--c-primary,#1F6FB2);
    line-height:1.2;
    transition:all .2s ease;
}
.vp-badge::before{
    content:"\2713";font-size:.68rem;line-height:1;font-weight:700;
}
.vp-badge:hover{
    background:#fff;color:var(--c-primary-dk,#154A75)!important;
    transform:translateY(-1px);box-shadow:0 3px 8px rgba(15,23,42,.12);
    text-decoration:none;
}
.vp-badge:focus-visible{outline:2px solid #0066CC;outline-offset:2px}
/* Specific accent colors per format — kept for subtle differentiation but
   unified design */
.vp-badge-private{background:#1F6FB2;border-color:#1F6FB2}
.vp-badge-group{background:#0891B2;border-color:#0891B2}
.vp-badge-online{background:#7C3AED;border-color:#7C3AED}

.vp-content{padding:52px 0}
.vp-content h2{font-family:var(--f-heading);font-size:clamp(1.6rem,3vw,2.1rem);font-weight:600;color:#1B2838;margin:52px 0 18px;line-height:1.2;letter-spacing:-0.3px}
.vp-content h2:first-child{margin-top:0}
.vp-content h3{font-family:var(--f-heading);font-size:1.3rem;font-weight:600;color:#2C3E50;margin:32px 0 12px}
.vp-content p{margin-bottom:22px;color:#3D5166;font-family:var(--f-body)}
.vp-content > a,.vp-content p a{color:#5DADE2;text-decoration:none;border-bottom:1px solid rgba(93,173,226,0.3);transition:border-color 0.2s}
.vp-content > a:hover,.vp-content p a:hover{border-color:#5DADE2}
.vp-content ul{margin:0 0 22px 0;padding-left:0;list-style:none}
.vp-content ul li{padding:8px 0 8px 24px;position:relative;color:#3D5166;border-bottom:0.5px solid #F8FAFC}
.vp-content ul li:last-child{border-bottom:none}
.vp-content ul li::before{content:'\2192';position:absolute;left:0;color:#5DADE2;font-size:13px;top:9px}

/* === Photo block (full-width within container) ===
   Soft-edged photos: a CSS mask fades all four edges to transparent so each
   image blends into whatever section background it sits on (white, soft white,
   or any color). No hard rectangular cut-off. Works in Chrome, Safari, Firefox. */
.photo-full{margin:36px 0;border-radius:14px}
.photo-full img{
    width:100%;height:320px;object-fit:cover;display:block;
    border-radius:inherit;
    /* Subtle edge-softening only — barely-noticeable 1.5% fade so the photo
       doesn't punch a hard rectangle into the page, but stays sharp. */
    -webkit-mask-image:
        linear-gradient(to right, transparent 0%, #000 1.5%, #000 98.5%, transparent 100%),
        linear-gradient(to bottom, transparent 0%, #000 2%, #000 98%, transparent 100%);
    -webkit-mask-composite: source-in;
    mask-image:
        linear-gradient(to right, transparent 0%, #000 1.5%, #000 98.5%, transparent 100%),
        linear-gradient(to bottom, transparent 0%, #000 2%, #000 98%, transparent 100%);
    mask-composite: intersect;
}
.photo-caption{font-size:12px;color:#94A3B8;margin-top:8px;letter-spacing:0.2px;padding:0 4px;font-family:var(--f-body);text-align:center}

/* === Photo placeholder (grey box, shown until real photo provided) ===
   Used on instrument article templates that haven't received final photo URLs yet.
   The data-search attribute hints at the search terms used to source the image. */
.photo-placeholder{background:linear-gradient(135deg,#F1F5F9,#E2E8F0);min-height:320px;display:flex;align-items:center;justify-content:center;border:1px dashed #CBD5E1;border-radius:14px}
.photo-placeholder-inner{padding:32px 28px;text-align:center;max-width:600px}
.photo-placeholder-label{font-family:var(--f-body);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.4px;color:#64748B;margin-bottom:14px;display:inline-block;padding:4px 12px;background:rgba(255,255,255,.7);border-radius:4px}
.photo-placeholder-alt{font-family:var(--f-heading);font-size:18px;font-weight:600;color:#334155;line-height:1.35;margin-bottom:10px}
.photo-placeholder-search{font-family:var(--f-body);font-size:13px;color:#64748B;font-style:italic;line-height:1.5}

/* === Per-page accent color (set on the .vp-page wrapper via inline style) ===
   Each instrument page sets --vp-accent to its theme color (purple, red, green, amber, blue, etc.).
   Components that should pick up the accent reference var(--vp-accent), with fallback to the
   default violin blue. Overrides cascade naturally when a parent sets the var. */
.vp-page{--vp-accent:#5DADE2}
.vp-page .vp-hero h1 em{color:var(--vp-accent)}
.vp-page .vp-breadcrumb a{color:var(--vp-accent)}
.vp-page .photo-placeholder-label{color:var(--vp-accent)}

/* === Numbered stage cards (used in jazz article + audition-prep timeline) ===
   Each card has a numbered/marker badge + heading + body text. Single-column flow on the
   article page (max-width 860px container). On mobile, the marker collapses inline. */
.vp-stages{display:flex;flex-direction:column;gap:18px;margin:28px 0}
.vp-stage{background:#FAFBFD;border:1px solid #E5E7EB;border-radius:12px;padding:24px 28px;display:grid;grid-template-columns:48px 1fr;gap:22px;align-items:start}
.vp-stage-marker{width:36px;height:36px;border-radius:50%;background:var(--vp-accent);color:#fff;font-weight:700;font-size:15px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--f-body);line-height:1}
.vp-stage-body h3{font-family:var(--f-heading);font-size:1.2rem;font-weight:600;color:#1B2838;margin:0 0 8px;line-height:1.25}
.vp-stage-body p{font-family:var(--f-body);font-size:15px;line-height:1.65;color:#3D5166;margin:0 0 8px}
.vp-stage-body p:last-child{margin-bottom:0}
.vp-stage-body p a{color:var(--vp-accent);text-decoration:none;border-bottom:1px solid currentColor;opacity:.8}
.vp-stage-body p a:hover{opacity:1}
@media(max-width:680px){
  .vp-stage{grid-template-columns:1fr;gap:14px;padding:20px 22px}
  .vp-stage-marker{margin-bottom:4px}
}

/* === Per-page CTA-block accent (override default dark gradient when accent matches a "branded" color) ===
   Pages can opt into a colored CTA by adding .cta-block-accent. Otherwise the default dark
   gradient style applies (matches violin). Background is the per-page accent.   */
.cta-block.cta-block-accent{background:linear-gradient(135deg,var(--vp-accent),color-mix(in srgb,var(--vp-accent) 70%,#1B2838))}
.cta-block.cta-block-accent h3{color:#fff}
.cta-block.cta-block-accent p{color:rgba(255,255,255,.85)}
.cta-block.cta-block-accent .btn-primary{background:#fff;color:var(--vp-accent) !important}
.cta-block.cta-block-accent .btn-primary:hover{background:#F0F7FF}
.cta-block.cta-block-accent .btn-secondary{border-color:rgba(255,255,255,.4);color:#fff}

/* === Callout (highlighted note box) === */
.callout{background:linear-gradient(135deg,#F0F9FF,#E0F2FE);border-left:4px solid #5DADE2;border-radius:0 12px 12px 0;padding:24px 28px;margin:36px 0}
.callout-title{font-family:var(--f-heading);font-size:1.2rem;font-weight:600;color:#1B2838;margin-bottom:10px}
.callout p{margin:0;color:#1E40AF;font-size:15px;line-height:1.65;font-family:var(--f-body)}
.callout p a{color:inherit;border-bottom:1px solid currentColor;text-decoration:none;opacity:.9}
.callout p a:hover{opacity:1}
.callout-purple{background:linear-gradient(135deg,#F5F3FF,#EDE9FE);border-left-color:#7C3AED}
.callout-purple p{color:#5B21B6}
.callout-purple .callout-title{color:#3B0764}
.callout-green{background:linear-gradient(135deg,#F0FDF4,#DCFCE7);border-left-color:#059669}
.callout-green p{color:#166534}
.callout-green .callout-title{color:#14532D}

/* === Profile cards (3-up student-type breakdown) === */
.profiles{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:28px 0}
.profile{background:#FAFBFD;border:1px solid #E5E7EB;border-radius:12px;padding:20px}
.profile-icon{font-size:26px;margin-bottom:10px}
.profile-icon svg{display:block}
.profile-title{font-family:var(--f-heading);font-size:1.1rem;font-weight:600;color:#1B2838;margin-bottom:6px}
.profile-desc{font-size:13px;color:#64748B;line-height:1.55;font-family:var(--f-body)}

/* === Techniques grid (2-column bullet style) === */
.techniques-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:20px 0}
.tech-item{background:#F8FAFC;border:1px solid #E5E7EB;border-radius:8px;padding:12px 14px;font-size:13px;color:#2C3E50;display:flex;align-items:flex-start;gap:10px;font-family:var(--f-body);line-height:1.5}
.tech-item a{color:#5DADE2;text-decoration:none;border-bottom:1px solid rgba(93,173,226,.3)}
.tech-dot{width:6px;height:6px;border-radius:50%;background:#5DADE2;flex-shrink:0;margin-top:5px}

/* === Doors grid (3-up "where this leads" cards) === */
.doors-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:24px 0}
.door-card{border:1px solid #E5E7EB;border-radius:12px;padding:18px 16px;text-decoration:none;transition:all 0.2s;display:block;color:inherit}
.door-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,0.07);border-color:var(--c)}
.door-accent{height:3px;border-radius:2px;margin-bottom:12px}
.door-name{font-family:var(--f-heading);font-size:1.05rem;font-weight:600;color:#1B2838;margin-bottom:4px}
.door-desc{font-size:12px;color:#64748B;line-height:1.5;font-family:var(--f-body)}

/* === Tools strip (free practice tools row) === */
.tools-strip{background:#F8FAFC;border:1px solid #E5E7EB;border-radius:14px;padding:24px;margin:36px 0}
.tools-strip-title{font-family:var(--f-heading);font-size:1.1rem;font-weight:600;color:#1B2838;margin-bottom:4px}
.tools-strip-sub{font-size:13px;color:#64748B;margin-bottom:18px;font-family:var(--f-body)}
.tools-row{display:flex;gap:10px;flex-wrap:wrap}
.tool-link{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;border:1px solid #E5E7EB;border-radius:8px;font-size:13px;color:#2C3E50;text-decoration:none;transition:all 0.15s;font-family:var(--f-body)}
.tool-link:hover{border-color:#5DADE2;color:#5DADE2}
.tool-link .ti{font-size:14px}

/* === FAQ items === */
.faq-item{border-bottom:1px solid #F1F5F9;padding:20px 0}
.faq-q{font-family:var(--f-heading);font-size:1.15rem;font-weight:600;color:#1B2838;margin-bottom:10px}
.faq-a{color:#475569;font-size:15px;line-height:1.7;font-family:var(--f-body)}
.faq-a a{color:#5DADE2;text-decoration:none;border-bottom:1px solid rgba(93,173,226,0.3)}

/* === Lesson details box === */
.lesson-details{background:#FAFBFD;border:1px solid #E5E7EB;border-radius:14px;padding:28px;margin:40px 0}
.lesson-details h3{font-family:var(--f-heading);font-size:1.3rem;color:#1B2838;margin:0 0 20px}
.detail-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:0.5px solid #F1F5F9;font-size:14px;font-family:var(--f-body)}
.detail-row:last-child{border-bottom:none}
.detail-label{color:#94A3B8;font-weight:500}
.detail-label a{color:#5DADE2;text-decoration:none;border-bottom:1px solid rgba(93,173,226,.3);transition:border-color .15s ease}
.detail-label a:hover{border-color:#5DADE2}
.detail-val{color:#2C3E50;font-weight:600;text-align:right}

/* === CTA block (dark gradient bottom-of-page CTA) === */
.cta-block{background:linear-gradient(135deg,#1B2838,#2C3E50);border-radius:16px;padding:40px;margin:48px 0;text-align:center}
.cta-block h3{font-family:var(--f-heading);font-size:1.8rem;color:#fff;margin:0 0 10px}
.cta-block p{color:rgba(255,255,255,0.75);font-size:15px;margin:0 0 28px;font-family:var(--f-body)}
.cta-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.cta-block .btn-primary{background:#5DADE2;color:#fff;padding:14px 28px;border-radius:10px;text-decoration:none;font-weight:600;font-size:14px;font-family:var(--f-body);transition:background .15s,transform .12s}
.cta-block .btn-primary:hover{background:#3498DB;transform:translateY(-1px)}
.cta-block .btn-secondary{background:transparent;color:#fff;padding:13px 28px;border-radius:10px;text-decoration:none;font-weight:500;font-size:14px;border:1px solid rgba(255,255,255,0.3);font-family:var(--f-body);transition:background .15s}
.cta-block .btn-secondary:hover{background:rgba(255,255,255,.1)}

/* === About / location resource block (footer of article) === */
.about-resource{background:#F8FAFC;border-radius:10px;padding:20px 24px;margin-top:48px;font-size:13px;color:#64748B;line-height:1.6;border:1px solid #F1F5F9;font-family:var(--f-body)}
.about-resource a{color:#5DADE2;text-decoration:none;border-bottom:1px solid rgba(93,173,226,0.3)}

/* === Mobile responsive for the whole article === */
@media(max-width:680px){
  .vp-container{padding:0 20px}
  .vp-hero{padding:48px 0 36px}
  .photo-full img{height:240px}
  .profiles,.techniques-grid,.doors-grid{grid-template-columns:1fr}
  .cta-block{padding:32px 24px}
  .cta-buttons{flex-direction:column;align-items:stretch}
  .cta-block .btn-primary,.cta-block .btn-secondary{width:100%}
  .tools-row{gap:8px}
  .lesson-details{padding:22px 20px}
  .detail-row{flex-direction:column;gap:4px}
  .detail-val{text-align:left;font-size:15px}
}