
:root{
  --bg:#faf5f5;
  --surface:#ffffff;
  --text:#0d1b2a;
  --muted:#5b6b7a;
  --brand:#0a7ea4;
  --accent:#5F1111;
  --accent-active:#363636;
  --accent-focus:#bebebe;
  --accent-hover:#a7a7a7;
  --border:#e6edf5;
  --shadow: 0 10px 30px rgba(13,27,42,.08);
  --nav-cta-gradient: linear-gradient(120deg,#5F1111 0%,#7c1919 55%,#A12C2C 100%);
  --nav-cta-gradient-hover: linear-gradient(120deg,#742020 0%,#8f2727 55%,#bc3d3d 100%);
  --header-height: 84px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: 'Roboto', system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-size:1.125rem;
}

img{max-width:100%;display:block;height:auto;border-radius:12px}

.container{max-width:1140px;margin-inline:auto;padding: clamp(16px, 2vw, 24px)}

.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--border);
}
.nav-cta-mobile{
  display:none;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo{display:flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-weight:700}
.logo-icon{width:auto;height:120px;display:block}
.logo-text{font-family:'Raleway', sans-serif; font-weight:800; letter-spacing:.5px}

.site-nav ul{display:flex;gap:12px;list-style:none;margin:0;padding:0;align-items:center}
.nav-link{display:block;padding:14px 20px;border-radius:10px;text-decoration:none;color:var(--text);font-size:1.05rem;font-weight:500;transition:all .2s ease}
.nav-link:hover{background:var(--accent-hover);color:#fff;transform:translateY(-1px)}
.nav-link.active{background:var(--accent-active);color:#fff}
.nav-link:focus{
  outline:2px solid var(--accent-focus);
  outline-offset:2px;
  background:var(--accent-focus);
}
.nav-cta{
  background:var(--nav-cta-gradient)!important;
  color:#fff!important;
  border-radius:999px;
  padding:14px 24px;
  font-weight:600;
  box-shadow:0 2px 8px rgba(95,17,17,0.2);
  border:none;
}
.nav-cta-mobile-bar{
  display:none;
}
.nav-cta:hover{
  background:var(--nav-cta-gradient-hover)!important;
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(95,17,17,0.25);
}
.nav-cta.active{
  background:var(--nav-cta-gradient-hover)!important;
}
.nav-cta:focus{
  outline:2px solid var(--accent);
  outline-offset:3px;
  background:var(--nav-cta-gradient-hover)!important;
}

.nav-toggle{
  display:none;
  background:transparent;
  border:2px solid var(--accent);
  border-radius:8px;
  padding:10px 12px;
  cursor:pointer;
  position:relative;
  width:44px;
  height:44px;
  transition:all 0.3s ease;
}
.nav-toggle:hover{
  background:var(--accent);
  transform:scale(1.05);
}
.nav-toggle:focus{
  outline:2px solid var(--accent);
  outline-offset:2px;
}
.nav-toggle span,
.nav-toggle span::before,
.nav-toggle span::after{
  content:'';
  display:block;
  width:24px;
  height:2px;
  background:var(--accent);
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  transition:all 0.3s ease;
  border-radius:2px;
}
.nav-toggle:hover span,
.nav-toggle:hover span::before,
.nav-toggle:hover span::after{
  background:#fff;
}
.nav-toggle span{
  top:50%;
  transform:translate(-50%, -50%);
}
.nav-toggle span::before{
  top:-8px;
}
.nav-toggle span::after{
  top:8px;
}
.nav-toggle[aria-expanded="true"] span{
  background:transparent;
}
.nav-toggle[aria-expanded="true"] span::before{
  top:0;
  transform:translate(-50%, -50%) rotate(45deg);
  background:var(--accent);
}
.nav-toggle[aria-expanded="true"] span::after{
  top:0;
  transform:translate(-50%, -50%) rotate(-45deg);
  background:var(--accent);
}
.nav-toggle[aria-expanded="true"]:hover span::before,
.nav-toggle[aria-expanded="true"]:hover span::after{
  background:#fff;
}

.hero{padding: clamp(24px, 4vw, 48px) 0; background: radial-gradient(1200px 500px at 10% -10%, #f5e8e8, transparent) , linear-gradient(180deg,#fff, #faf5f5)}
.hero-inner{display:grid;grid-template-columns: 1.2fr .8fr;gap:32px;align-items:center}
.lede{font-size:1.1rem}
.cta-row{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}

.hero-video-wrapper{
  position:relative;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 15px 40px rgba(13,27,42,.12);
}
.hero-video{
  width:100%;
  height:auto;
  display:block;
  border-radius:12px;
}
.video-mute-toggle{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  width:100%;
  height:100%;
  border-radius:12px;
  background:rgba(0,0,0,0.5);
  backdrop-filter:blur(2px);
  border:1px solid rgba(95,17,17,0.2);
  box-shadow:var(--shadow);
  color:#fff;
  text-shadow:0 2px 8px rgba(0,0,0,0.3);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:120px;
  opacity:0;
  transition:opacity 0.3s ease, background 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  pointer-events:none;
  z-index:10;
}
.hero-video-wrapper:hover .video-mute-toggle{
  opacity:1;
  pointer-events:auto;
}
.video-mute-toggle:hover{
  background:rgba(0,0,0,0.6);
  border-color:rgba(95,17,17,0.4);
  box-shadow:0 10px 40px rgba(95,17,17,0.15);
}
.video-mute-toggle:active{
  background:rgba(0,0,0,0.7);
}
.video-mute-toggle:focus{
  outline:2px solid var(--accent);
  outline-offset:2px;
}

.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:12px;border:1px solid var(--text);text-decoration:none;font-weight:700; font-size:1rem}
.btn-primary{background:var(--accent); color:#fff; border-color:var(--accent)}
.btn-outline{background:transparent;color:var(--text);border-color:var(--text)}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-requested{background:#808080; color:#fff; border-color:#808080; cursor:default}
.btn-requested:hover{transform:none;box-shadow:none;background:#808080}

.link-inline{
  text-decoration:none;
  font-weight:inherit;
}
.link-inline:hover,
.link-inline:focus{
  text-decoration:none;
}

.scroll-to-form-arrow{
  position:fixed;
  bottom:24px;
  left:50%;
  transform:translateX(-50%) translateY(10px) scale(0.9);
  width:64px;
  height:64px;
  border-radius:50%;
  background:var(--accent);
  color:#fff;
  border:none;
  font-size:28px;
  font-weight:bold;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 16px rgba(95,17,17,0.4);
  z-index:999;
  transition:opacity 0.3s ease, transform 0.3s ease, background 0.2s ease;
  opacity:0;
  pointer-events:none;
}
.scroll-to-form-arrow.show{
  opacity:1;
  transform:translateX(-50%) translateY(0) scale(1);
  pointer-events:auto;
}
.scroll-to-form-arrow.show:hover{
  background:var(--accent-active);
  transform:translateX(-50%) translateY(-3px) scale(1);
  box-shadow:0 6px 20px rgba(95,17,17,0.5);
}
.scroll-to-form-arrow.show:active{
  transform:translateX(-50%) translateY(0) scale(1);
}
.scroll-to-form-arrow:focus{
  outline:2px solid var(--accent);
  outline-offset:3px;
}
@media (max-width: 900px){
  .scroll-to-form-arrow{
    bottom:20px;
    width:72px;
    height:72px;
    font-size:32px;
    box-shadow:0 6px 20px rgba(95,17,17,0.5);
  }
}

.artists{padding: 16px 0 8px}
.song-catalog{list-style: none; padding:0; margin:14px 0 0}
.song-catalog li{margin:8px 0}
.song-catalog a{text-decoration:underline}
.who-what-how{padding: 8px 0 8px}
.curriculum{padding: 8px 0 24px}

.accent{font-family:'Raleway', sans-serif; font-weight:800; letter-spacing:.4px}
.muted{color:var(--muted)}
.h-like-h3{font-size:1.25rem;margin:.2rem 0}
.h-like-h4{font-size:1.1rem;margin:.2rem 0}

.grid-3{display:grid;grid-template-columns: repeat(3,1fr); gap:16px}
.grid-2{display:grid;grid-template-columns: repeat(2,1fr); gap:16px}

.card{background:var(--surface);border:1px solid var(--border);padding:18px;border-radius:14px;box-shadow:var(--shadow)}
.pill-list{display:flex;flex-wrap:wrap;gap:10px;padding:0;list-style:none}
.pill-list li{background:#fff;border:1px solid var(--border);border-radius:999px;padding:8px 12px}

.eyebrow{
  font-size:0.82rem;
  text-transform:uppercase;
  letter-spacing:0.16em;
  font-weight:700;
  color:var(--accent);
  margin:0 0 6px;
}

.learn-hero{
  padding: clamp(12px, 3vw, 28px) 0;
  background: radial-gradient(1000px 480px at 10% -20%, rgba(95,17,17,0.08), transparent), linear-gradient(180deg,#fff,#faf5f5);
}
.learn-hero-inner{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:24px;
  align-items:start;
}
.learn-hero-card{
  height:100%;
}
.learn-hero-card ul{
  padding-left:20px;
  margin:0 0 12px;
}
.learn-pillars{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:12px;
  margin-top:clamp(2px, 0.4vw, 6px);
}
.learn-topics{
  padding:6px clamp(16px, 2vw, 24px) 8px;
}
.learn-topics .section-heading{
  margin-bottom:8px;
}
.pillar-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px 16px;
  box-shadow:var(--shadow);
}
.learn-topics .pillar-card h2{
  font-size:1.05rem;
}
.learn-topics .pillar-card p{
  font-size:0.98rem;
  line-height:1.5;
}
.learn-posts-section{
  margin-top:clamp(4px, 1.5vw, 16px);
}
.section-heading{
  margin-bottom:16px;
}
.blog-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:16px;
}
.blog-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:18px;
  padding:20px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  gap:12px;
  transition:transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}
.blog-card--linkable{
  position:relative;
}
.blog-card--linkable:hover,
.blog-card--linkable:focus-within{
  transform:translateY(-4px);
  box-shadow:0 14px 30px rgba(0,0,0,0.12);
  border-color:rgba(95,17,17,0.25);
}
.blog-card--linkable:focus-within{
  outline:2px solid var(--accent);
  outline-offset:2px;
}
.blog-card--linkable a.blog-card-link{
  text-decoration:none;
}
.blog-card--linkable a.blog-card-link:focus{
  outline:2px solid var(--accent);
  outline-offset:2px;
  border-radius:6px;
}
.blog-card-status{
  font-size:0.85rem;
  text-transform:uppercase;
  letter-spacing:0.1em;
  color:var(--muted);
}
.blog-card h3{
  margin:0;
}
.blog-card p{
  margin:0;
}
.blog-card-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  font-size:0.9rem;
  color:var(--muted);
}
.blog-card-meta span{
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.blog-card-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:4px 0 0;
}
.blog-card-tags span{
  background:rgba(95,17,17,0.08);
  color:var(--accent);
  padding:4px 10px;
  border-radius:999px;
  font-size:0.85rem;
}
.blog-card-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:auto;
}
.blog-card details{
  border-top:1px dashed var(--border);
  padding-top:10px;
}
.blog-card details summary{
  cursor:pointer;
  font-weight:600;
  color:var(--accent);
  list-style:none;
}
.blog-card details summary::-webkit-details-marker{
  display:none;
}
.blog-card details[open] summary{
  margin-bottom:8px;
}
.blog-card-preview{
  border-radius:12px;
  border:1px solid var(--border);
  padding:12px;
  background:rgba(250,245,245,0.6);
  max-height:260px;
  overflow:auto;
}
.blog-card-preview article{
  margin:0;
}
.skeleton-line{
  height:14px;
  background:linear-gradient(90deg, rgba(95,17,17,0.1), rgba(95,17,17,0.2), rgba(95,17,17,0.1));
  border-radius:999px;
  animation:skeletonPulse 2s ease-in-out infinite;
}
.skeleton-line.width-80{width:80%}
.skeleton-line.width-60{width:60%}
.skeleton-line.width-40{width:40%}
.stub-note{
  margin-top:8px;
  font-size:0.95rem;
}
.stub-instructions-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:20px;
  box-shadow:var(--shadow);
  padding:24px;
  margin-top:clamp(24px, 4vw, 56px);
}
.stub-instructions-card ol{
  padding-left:22px;
  margin-bottom:12px;
}
.stub-instructions-card li{
  margin-bottom:8px;
}
.blog-card--loading{
  min-height:180px;
  justify-content:center;
}

.learn-post-stub{
  font-size:0.95rem;
  line-height:1.5;
}
.learn-post-stub h1{
  font-size:1.5rem;
}
.learn-post-stub h2{
  font-size:1.2rem;
}
.stub-label{
  font-size:0.85rem;
  color:var(--muted);
  letter-spacing:0.05em;
  text-transform:uppercase;
  margin:0 0 6px;
}
.stub-lede{
  margin-top:8px;
  color:var(--muted);
}

.faq-list{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin:0;
  padding:0;
}
.faq-list details{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:0;
  transition:border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
  overflow:hidden;
}
.faq-list details:hover{
  border-color:rgba(95,17,17,0.3);
  transform:translateY(-1px);
}
.faq-list summary{
  list-style:none;
  font-weight:600;
  font-size:1rem;
  padding:20px 56px 20px 20px;
  position:relative;
  cursor:pointer;
  margin:0;
}
.faq-list summary::-webkit-details-marker{
  display:none;
}
.faq-list summary::after{
  content:'';
  position:absolute;
  right:18px;
  top:50%;
  width:14px;
  height:14px;
  border-right:2px solid var(--accent);
  border-bottom:2px solid var(--accent);
  transform:translateY(-60%) rotate(45deg);
  transition:transform 0.2s ease;
}
.faq-list summary:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:4px;
  border-radius:14px;
}
.faq-list details[open] summary::after{
  transform:translateY(-40%) rotate(-135deg);
}
.faq-list details[open]{
  border-color:rgba(95,17,17,0.4);
  box-shadow:0 16px 30px rgba(13,27,42,0.08);
}
.faq-list p{
  margin:0;
  padding:0 20px 20px;
  color:var(--muted);
}
.faq-card .faq-list details{
  box-shadow:none;
}

.process-preview{padding:24px 0 48px}
.contact-card{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:18px}
.contact-card form{display:grid;gap:10px}
.contact-card input,.contact-card textarea{
  width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:#fff;font:inherit
}
.contact-card textarea{min-height:110px;resize:vertical}
.alt-contact{margin-top:10px}

.page{padding: clamp(24px, 4vw, 48px) 0}
.learn-page{
  padding-top: 0;
}
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center}
.about-split .media img{aspect-ratio: 4/5; object-fit: cover}
.about-split .media figcaption{text-align:right}
.about-split .about-title{grid-column:1}
.about-split .copy{grid-column:1}
.about-split .media{grid-column:2;grid-row:1/3;align-self:start;padding-top:3rem}

.checklist{columns:2;gap:24px}
.checklist li{break-inside:avoid;margin:6px 0;position:relative;padding-left:28px}
.checklist li::before{content:"✓";position:absolute;left:0;top:0;color:var(--brand);font-weight:900}

.steps{margin:0;padding:0 0 0 22px}
.steps.large li{margin:10px 0;padding-left:6px}

.cards-3{display:grid;grid-template-columns: repeat(3,1fr); gap:16px}
.price-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow);display:flex;flex-direction:column}
.price-card ul{flex-grow:1;margin:12px 0}
.price-card .btn{margin-top:auto}
.price{font-weight:900;font-size:1.1rem;color:var(--accent)}

.contact-section form.wide{
  display:grid;
  gap:12px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:16px;
  padding:32px;
  box-shadow:var(--shadow);
  margin-top:24px;
}
.contact-section form.wide h3{
  margin-top:12px!important;
  margin-bottom:8px!important;
}
.contact-section form.wide > div:first-child h3{
  margin-top:0!important;
}
.contact-section .grid-2{
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}
.contact-section label,
.contact-section .label{
  display:block;
  font-weight:600;
  font-size:0.95rem;
  color:var(--text);
  margin-bottom:8px;
  letter-spacing:0.01em;
}
.contact-section input[type="text"],
.contact-section input[type="tel"],
.contact-section input[type="email"],
.contact-section select,
.contact-section textarea{
  width:100%;
  padding:14px 16px;
  border:2px solid var(--border);
  border-radius:10px;
  background:var(--surface);
  font:inherit;
  font-size:1rem;
  color:var(--text);
  transition:all 0.2s ease;
  box-sizing:border-box;
}
.contact-section select{
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%235F1111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 16px center;
  background-size:12px 8px;
  padding-right:40px;
}
.contact-section input[type="text"]:focus,
.contact-section input[type="tel"]:focus,
.contact-section input[type="email"]:focus,
.contact-section select:focus,
.contact-section textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(95,17,17,0.1);
}
.contact-section input[type="text"]:hover,
.contact-section input[type="tel"]:hover,
.contact-section input[type="email"]:hover,
.contact-section select:hover,
.contact-section textarea:hover{
  border-color:rgba(95,17,17,0.3);
}
.contact-section textarea{
  min-height:120px;
  resize:vertical;
  font-family:inherit;
  line-height:1.5;
}
.radio-group{
  display:flex;
  gap:20px;
  align-items:center;
  flex-wrap:wrap;
  margin-top:4px;
}
.radio-group label{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:400;
  cursor:pointer;
  padding:8px 12px;
  border-radius:8px;
  transition:background 0.2s ease;
  margin-bottom:0;
}
.radio-group label:hover{
  background:rgba(95,17,17,0.05);
}
.radio-group input[type="radio"]{
  width:20px;
  height:20px;
  margin:0;
  cursor:pointer;
  accent-color:var(--accent);
  flex-shrink:0;
}
.contact-section button[type="submit"]{
  margin-top:8px;
  width:100%;
  max-width:300px;
  justify-self:start;
}
.contact-section button[type="submit"]:disabled{
  opacity:0.6;
  cursor:not-allowed;
  transform:none;
}
.contact-section button[type="submit"].btn-loading{
  position:relative;
}
.form-status-card{
  background:var(--surface);
  border:2px solid var(--border);
  border-radius:20px;
  padding:24px;
  display:flex;
  gap:18px;
  align-items:flex-start;
  box-shadow:var(--shadow);
  margin-top:24px;
}
.form-status-card .status-icon{
  width:48px;
  height:48px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.5rem;
  font-weight:700;
  flex-shrink:0;
  box-shadow:0 8px 20px rgba(0,0,0,0.08);
}
.form-status-card .status-body{
  flex:1;
}
.form-status-card .status-body h3{
  margin:0 0 8px;
  font-size:1.4rem;
}
.form-status-card .status-body p{
  margin:0 0 16px;
  color:var(--muted);
}
.form-status-card .status-body button{
  margin-top:8px;
}
.form-success-message{
  background:linear-gradient(135deg, rgba(95,17,17,0.05), #fff);
  border-color:rgba(95,17,17,0.25);
}
.form-success-message .status-icon{
  background:var(--accent);
  color:#fff;
}
.form-success-message .status-body h3{
  color:var(--accent);
}
.form-error-message{
  border-color:rgba(179,38,30,0.4);
  background:linear-gradient(135deg, rgba(179,38,30,0.07), #fff);
  margin-top:16px;
}
.form-error-message .status-icon{
  background:#B3261E;
  color:#fff;
}
.form-error-message .status-body h3{
  color:#B3261E;
}
.selected-packages{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  min-height:48px;
  padding:12px;
  border:2px solid var(--border);
  border-radius:10px;
  background:var(--surface);
  align-items:flex-start;
}
.selected-packages:empty::before{
  content:"No packages selected. Click 'Request this package' buttons below to add them.";
  color:var(--muted);
  font-style:italic;
  font-size:0.9rem;
}
.package-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  background:var(--accent);
  color:#fff;
  border-radius:20px;
  font-size:0.9rem;
  font-weight:500;
  border:none;
  cursor:default;
}
.package-item .remove-btn{
  background:rgba(255,255,255,0.2);
  border:none;
  color:#fff;
  width:20px;
  height:20px;
  border-radius:50%;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  line-height:1;
  padding:0;
  transition:background 0.2s ease;
  flex-shrink:0;
}
.package-item .remove-btn:hover{
  background:rgba(255,255,255,0.3);
}
.package-item .remove-btn:active{
  background:rgba(255,255,255,0.4);
}

.embed.video iframe{width:100%;aspect-ratio:16/9;border-radius:12px;border:1px solid var(--border)}

.video-gallery{
  margin-top:clamp(24px,3vw,48px);
}
.video-gallery:first-of-type{
  margin-top:clamp(16px,2vw,32px);
}
.video-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(16px,2vw,32px);
}
.video-grid.video-grid-text{
  gap:clamp(12px,1.5vw,24px);
}
.video-card{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.video-card h2,
.video-card h3{
  margin:0;
  line-height:1.25;
}
.video-card:not(.upcoming) h2{
  min-height:calc(1.25em * 2);
  display:flex;
  align-items:flex-end;
}
.video-card.upcoming{
  padding:16px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fff;
}
.video-card.upcoming p{
  margin:0;
}

@media (min-width: 720px){
  .video-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

#new-students{
  scroll-margin-top: 165px;
}
#latest-posts{
  scroll-margin-top: 165px;
}

#book-introductory-call{
  scroll-margin-top: 180px;
  margin-top: clamp(4px, 1vw, 12px);
}

.site-footer{
  margin-top:32px;
  border-top:1px solid var(--border);
  background:#fff;
  position:relative;
  overflow:hidden;
}
.site-footer::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:rgba(255,255,255,0.85);
  z-index:1;
  pointer-events:none;
}
.footer-video{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 60%;
  z-index:0;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  gap:16px;
  align-items:start;
  position:relative;
  z-index:2;
}
.footer-grid > div:nth-child(2){max-width:400px;justify-self:center}
.footer-grid > div:nth-child(3){text-align:center}
.socials{display:flex;justify-content:center;align-items:flex-start}
.socials a{display:inline-block;color:#FF0000;text-decoration:none;transition:opacity 0.2s ease}
.socials a:hover{opacity:0.7}
.socials a i{font-size:2.5rem}

.legal{
  margin-top:12px;
  position:relative;
  z-index:2;
}
.legal p{margin:0;padding:12px;text-align:center;color:var(--muted)}

@media (max-width: 900px){
  body{font-size:1rem}
  .hero-inner{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .about-split{grid-template-areas:"title" "media" "copy"}
  .about-split .about-title{grid-area:title;grid-column:auto}
  .about-split .copy{grid-area:copy;grid-column:auto}
  .about-split .media{grid-area:media;grid-column:auto;grid-row:auto;align-self:auto;padding-top:0}
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .cards-3{grid-template-columns:1fr}
  .checklist{columns:1}
  .learn-hero-inner{grid-template-columns:1fr}
  .learn-pillars{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .nav-cta-mobile-bar{
    position:sticky;
    top:var(--header-height);
    z-index:940;
    padding:0;
    background:rgba(250,245,245,0.05);
    text-align:center;
    backdrop-filter:saturate(180%) blur(8px);
    display:flex;
    justify-content:center;
    align-items:center;
  }
  .nav-cta-mobile{
    display:flex;
    align-items:center;
    justify-content:center;
    background:var(--nav-cta-gradient);
    color:#fff!important;
    text-decoration:none;
    padding:14px 26px;
    font-weight:600;
    font-size:1rem;
    border-radius:999px;
    box-shadow:0 8px 24px rgba(95,17,17,0.25);
    width:min(420px, calc(100% - 24px));
    margin:6px auto 10px;
    transition:all .2s ease;
    border:none;
    gap:8px;
    letter-spacing:0.02em;
    animation:navCtaPulse 2.8s ease-in-out infinite;
    position:relative;
    z-index:950;
  }
  .nav-cta-mobile:hover{
    background:var(--accent-active);
    transform:none;
    box-shadow:0 4px 12px rgba(95,17,17,0.3);
  }
  .site-nav{display:none;position:absolute;top:calc(100% + 48px);right:16px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);min-width:200px}
  .site-nav ul{flex-direction:column;padding:10px;gap:8px}
  .site-nav .nav-cta{display:none}
  .nav-toggle{display:inline-block}
  .contact-section form.wide{padding:24px}
  .contact-section .grid-2{grid-template-columns:1fr}
  .video-mute-toggle{
    top:auto;
    left:auto;
    bottom:16px;
    right:16px;
    transform:none;
    width:48px;
    height:48px;
    border-radius:50%;
    font-size:20px;
    opacity:1;
    pointer-events:auto;
    background:rgba(0,0,0,0.7);
    border:none;
    box-shadow:0 4px 12px rgba(0,0,0,0.3);
    color:#fff;
    text-shadow:none;
    backdrop-filter:none;
  }
  .hero-video-wrapper:hover .video-mute-toggle{
    opacity:1;
  }
  .video-mute-toggle:hover{
    transform:scale(1.1);
    background:rgba(0,0,0,0.8);
  }
  .video-mute-toggle:active{
    transform:scale(0.95);
  }
  #new-students{
    scroll-margin-top: 218px;
  }
  #latest-posts{
    scroll-margin-top: 218px;
  }
  #book-introductory-call{
    scroll-margin-top: 230px;
    margin-top: 8px;
  }
}

@keyframes navCtaPulse{
  0%{
    box-shadow:0 0 0 0 rgba(95,17,17,0.5);
  }
  70%{
    box-shadow:0 0 0 14px rgba(95,17,17,0);
  }
  100%{
    box-shadow:0 0 0 0 rgba(95,17,17,0);
  }
}

@media (prefers-reduced-motion: reduce){
  .nav-cta-mobile{
    animation:none;
  }
}

.blog-card-tags span,
.skeleton-line{
  display:inline-block;
}

@keyframes skeletonPulse{
  0%{
    opacity:0.4;
  }
  50%{
    opacity:1;
  }
  100%{
    opacity:0.4;
  }
}
