
:root{
  --purple-950:#17081f; --purple-900:#241034; --purple-800:#39155b; --purple-700:#58238f;
  --purple-600:#7e35c8; --purple-500:#a855f7; --purple-300:#d9b7ff; --cream:#fbf5ee;
  --cream-2:#f3e8dc; --brown:#5c3c27; --gold:#d69b62; --ink:#25152f; --muted:#735f7e;
  --card:#fffaf5; --line:rgba(80,45,105,.16); --shadow:0 28px 70px rgba(35,10,55,.16);
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;background:linear-gradient(180deg,#fff8f2,#f8eefb 45%,#fff8f2);color:var(--ink);font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;line-height:1.55;}
img{max-width:100%;display:block} a{text-decoration:none;color:inherit} .site-header{height:88px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(22px,4vw,54px);position:sticky;top:0;z-index:50;background:rgba(255,247,240,.86);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:14px;min-width:max-content}
.brand-mark{
  width:46px;height:46px;display:inline-grid;place-items:center;position:relative;
  border-radius:50%;background:radial-gradient(circle at 35% 25%,#ffffff 0 10%,transparent 11%),linear-gradient(135deg,var(--purple-700),var(--purple-300));
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.45),0 12px 28px rgba(88,35,143,.22);
  overflow:hidden;flex:0 0 auto;
}
.brand-mark:before{
  content:"SD";font-weight:1000;font-size:16px;letter-spacing:-.08em;color:white;
  text-shadow:0 2px 9px rgba(0,0,0,.28);z-index:2;
}
.brand-mark:after{
  content:"";position:absolute;width:60px;height:18px;left:-7px;bottom:7px;
  background:rgba(255,255,255,.16);transform:rotate(-16deg);border-top:1px solid rgba(255,255,255,.25);
}
.brand-mark i,.brand-mark b,.brand-mark em{
  position:absolute;display:block;border-radius:999px;background:rgba(255,255,255,.65);
}
.brand-mark i{width:18px;height:3px;right:6px;top:12px;transform:rotate(25deg)}
.brand-mark b{width:14px;height:3px;left:7px;bottom:12px;transform:rotate(-18deg)}
.brand-mark em{width:5px;height:5px;right:10px;bottom:10px}
.brand strong{display:block;font-size:26px;line-height:.9;letter-spacing:.02em;color:var(--purple-900)}
.brand small{display:block;text-transform:uppercase;font-size:11px;letter-spacing:.24em;color:var(--brown);font-weight:800;margin-top:5px}
.main-nav{display:flex;align-items:center;gap:clamp(14px,2.2vw,30px);font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.main-nav a{position:relative;padding:34px 0}.main-nav a:after{content:"";position:absolute;left:0;right:0;bottom:24px;height:2px;transform:scaleX(0);transform-origin:left;background:var(--purple-600);transition:.25s}.main-nav a:hover:after{transform:scaleX(1)}.menu-toggle{display:none;border:0;background:var(--purple-800);color:white;border-radius:12px;padding:9px 12px;font-size:20px}
.hero{min-height:680px;position:relative;overflow:hidden;display:grid;align-items:center}.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.hero-shade{position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,5,35,.9) 0%,rgba(40,10,65,.66) 31%,rgba(40,10,65,.1) 62%,rgba(20,5,35,.2));}.hero-content{position:relative;z-index:2;width:min(620px,90vw);margin-left:clamp(28px,5vw,70px);color:white}.eyebrow,.section-heading span,.about-text span,.newsletter span{font-weight:900;text-transform:uppercase;letter-spacing:.22em;color:var(--purple-300);font-size:13px}.hero h1{font-size:clamp(62px,9vw,118px);line-height:.86;margin:26px 0 20px;letter-spacing:-.075em;text-transform:uppercase}.hero h1 span{display:block;color:var(--purple-300);font-family:Georgia,serif;font-style:italic;text-transform:none;letter-spacing:-.06em}.hero p{font-size:20px;max-width:500px;color:rgba(255,255,255,.9)}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:999px;padding:14px 24px;font-size:13px;font-weight:950;text-transform:uppercase;letter-spacing:.05em;transition:.25s;border:1px solid transparent}.btn:hover{transform:translateY(-2px)}.btn.primary{background:linear-gradient(135deg,var(--purple-600),var(--purple-500));color:white;box-shadow:0 15px 35px rgba(126,53,200,.32)}.btn.ghost{border-color:rgba(255,255,255,.45);color:white;background:rgba(255,255,255,.06)}.btn.outline{border-color:var(--purple-600);color:var(--purple-700);background:transparent}.hero-dots{display:flex;gap:12px;margin-top:36px}.hero-dots span{width:8px;height:8px;border-radius:50%;background:#fff}.hero-dots span:first-child{background:var(--purple-300)}
.section{padding:46px clamp(22px,4vw,54px)}.section.compact{padding-top:32px}.section-heading{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:22px}.section-heading h2{font-size:clamp(32px,5vw,56px);line-height:.95;margin:0;letter-spacing:-.055em;color:var(--purple-900)}.section-heading a{font-weight:900;color:var(--purple-700);font-size:13px}.section-heading.mini{margin-bottom:16px}.section-heading.mini span{font-size:18px;letter-spacing:.02em;color:var(--purple-900)}.cards{display:grid;gap:20px}.cards.three{grid-template-columns:repeat(3,1fr)}.feature-card,.latest,.army-card,.member,.newsletter,.gallery-grid img{background:var(--card);border:1px solid var(--line);box-shadow:0 18px 48px rgba(55,20,80,.08)}.feature-card{border-radius:18px;overflow:hidden}.media{position:relative;overflow:hidden}.media img{width:100%;height:220px;object-fit:cover;transition:.4s}.feature-card:hover .media img{transform:scale(1.04)}.media button{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:58px;height:58px;border-radius:50%;border:0;background:rgba(126,53,200,.88);color:white;font-size:20px}.card-body{padding:18px 20px 20px}.card-body h3{font-size:24px;margin:0 0 2px;letter-spacing:-.03em}.card-body p{margin:0;color:var(--muted)}.card-body span{float:right;margin-top:-28px;background:#ead7ff;color:var(--purple-800);font-size:12px;font-weight:900;border-radius:999px;padding:6px 11px}
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:stretch}.latest{border-radius:20px;padding:24px}.latest article{display:grid;grid-template-columns:110px 1fr;gap:16px;padding:12px 0;border-bottom:1px solid var(--line)}.latest article:last-child{border-bottom:0}.latest img{height:76px;width:110px;object-fit:cover;border-radius:11px}.latest h3{font-size:18px;margin:0 0 4px}.latest p{margin:0;color:var(--muted);font-size:14px}.army-card{border-radius:20px;overflow:hidden;display:grid;grid-template-columns:1fr;position:relative;min-height:360px;background:var(--purple-900);color:white}.army-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;opacity:.8}.army-card:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(36,16,52,.92),rgba(36,16,52,.35))}.army-card div{position:relative;z-index:2;align-self:center;padding:36px}.army-card h2{font-size:36px;margin:0 0 10px}.army-card p{max-width:320px;color:rgba(255,255,255,.88)}
.about{display:grid;grid-template-columns:.94fr 1.06fr;gap:30px;align-items:center;padding:42px clamp(22px,4vw,54px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,250,245,.65)}.about-text h2{font-size:clamp(38px,5vw,68px);line-height:.92;letter-spacing:-.06em;margin:10px 0 18px;color:var(--purple-900)}.about-text p{font-size:18px;color:var(--muted);max-width:620px}.about-img{border-radius:22px;box-shadow:var(--shadow);width:100%;height:420px;object-fit:cover}.member-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:18px}.member{border-radius:999px 999px 24px 24px;padding:8px 8px 16px;text-align:center}.member img{aspect-ratio:1/1;object-fit:cover;border-radius:50%;border:6px solid #ead7ff}.member h3{margin:10px 0 0;font-size:16px}.timeline-line{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;padding:30px 10px;background:rgba(255,250,245,.76);border:1px solid var(--line);border-radius:20px}.timeline-line:before{content:"";position:absolute;left:6%;right:6%;top:50px;height:2px;background:linear-gradient(90deg,var(--purple-600),var(--gold))}.timeline-line div{position:relative;text-align:center;z-index:2}.timeline-line div:before{content:"";display:block;width:15px;height:15px;border-radius:50%;background:var(--purple-600);border:4px solid #fff;margin:0 auto 16px;box-shadow:0 0 0 1px var(--line)}.timeline-line b{display:block;color:var(--purple-900)}.timeline-line span{font-size:13px;color:var(--muted)}.gallery-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}.gallery-grid img{border-radius:16px;height:175px;width:100%;object-fit:cover}.quote-band{margin-top:28px;padding:48px clamp(22px,4vw,54px);background:radial-gradient(circle at 70% 30%,rgba(168,85,247,.35),transparent 36%),linear-gradient(135deg,var(--purple-900),var(--purple-800));color:white;display:flex;align-items:center;justify-content:space-between;gap:28px}.quote-band blockquote{font-family:Georgia,serif;font-size:clamp(22px,3vw,34px);line-height:1.35;margin:0;max-width:780px}.quote-band cite{color:var(--purple-300);font-style:normal}.socials{display:flex;gap:12px}.socials a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;border:1px solid rgba(255,255,255,.28)}.newsletter{margin:44px clamp(22px,4vw,54px);border-radius:28px;padding:36px;display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center}.newsletter h2{font-size:clamp(30px,4vw,54px);margin:8px 0 8px;line-height:.96;color:var(--purple-900);letter-spacing:-.05em}.newsletter p{color:var(--muted);margin:0}.signup{display:grid;grid-template-columns:1fr auto;gap:10px}.signup input{height:54px;border:1px solid var(--line);border-radius:999px;padding:0 18px;background:#fff;font-size:16px}.signup button{border:0;border-radius:999px;background:var(--purple-700);color:white;font-weight:900;text-transform:uppercase;padding:0 24px}.signup small{grid-column:1/-1;color:var(--purple-700);font-weight:700}
.dmca-section{
  margin:44px clamp(22px,4vw,54px);
  padding:34px;
  border-radius:28px;
  background:linear-gradient(135deg,#fffaf5,#f3e8ff);
  border:1px solid var(--line);
  box-shadow:0 18px 48px rgba(55,20,80,.08);
}
.dmca-section span{
  display:block;
  color:var(--purple-700);
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:12px;
  margin-bottom:8px;
}
.dmca-section h2{
  margin:0 0 12px;
  font-size:clamp(28px,4vw,46px);
  line-height:1;
  letter-spacing:-.045em;
  color:var(--purple-900);
}
.dmca-section p{
  color:var(--muted);
  max-width:980px;
  margin:0 0 12px;
}
.dmca-section a{
  color:var(--purple-700);
  font-weight:900;
  text-decoration:underline;
  text-underline-offset:3px;
}

.footer{padding:36px clamp(22px,4vw,54px) 42px;background:#fff8f2;border-top:1px solid var(--line);display:grid;gap:18px;text-align:center;justify-items:center}.footer-brand .brand-mark{width:28px;height:36px}.footer nav{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;text-transform:uppercase;font-size:12px;font-weight:900;color:var(--purple-800)}.footer p{margin:0;color:var(--muted);font-size:13px}.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease, transform .7s ease}.reveal.visible{opacity:1;transform:none}
@media(max-width:1060px){.main-nav{position:absolute;display:none;flex-direction:column;align-items:flex-start;right:18px;top:78px;background:#fff8f2;padding:22px;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);width:min(330px,90vw)}.main-nav.open{display:flex}.main-nav a{padding:8px 0}.main-nav a:after{display:none}.menu-toggle{display:block}.cards.three,.split,.about,.newsletter{grid-template-columns:1fr}.member-grid{grid-template-columns:repeat(4,1fr)}.gallery-grid{grid-template-columns:repeat(3,1fr)}.hero{min-height:620px}.hero-shade{background:linear-gradient(90deg,rgba(20,5,35,.9),rgba(20,5,35,.42))}}
@media(max-width:640px){.site-header{height:76px}.brand strong{font-size:20px}.brand small{font-size:8px}.hero{min-height:570px}.hero-content{margin-left:22px}.hero h1{font-size:55px}.hero p{font-size:17px}.cards.three,.member-grid,.gallery-grid,.timeline-line{grid-template-columns:1fr}.timeline-line:before{display:none}.quote-band{display:grid}.signup{grid-template-columns:1fr}.signup button{height:52px}.about-img{height:310px}.latest article{grid-template-columns:84px 1fr}.latest img{width:84px;height:70px}}


.seo-dance-section,.keyword-cloud-section,.faq-section{
  margin:44px clamp(22px,4vw,54px);
  padding:clamp(28px,4vw,46px);
  border-radius:34px;
  background:rgba(255,255,255,.76);
  border:1px solid var(--line);
  box-shadow:0 22px 60px rgba(55,20,80,.08);
}
.wide-copy{
  max-width:1020px;
  color:var(--muted);
  font-size:18px;
}
.seo-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  margin-top:26px;
}
.seo-grid article{
  background:linear-gradient(135deg,#fff,#f7efff);
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px;
}
.seo-grid h3{
  margin:0 0 10px;
  color:var(--purple-900);
  font-size:24px;
  letter-spacing:-.03em;
}
.seo-grid p{color:var(--muted)}
.seo-grid ul{
  margin:16px 0 0;
  padding-left:20px;
  color:var(--brown);
  font-weight:800;
}
.keyword-cloud{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.keyword-cloud span{
  padding:10px 14px;
  border-radius:999px;
  background:#f2e6ff;
  border:1px solid rgba(88,35,143,.16);
  color:var(--purple-800);
  font-weight:900;
  font-size:14px;
}
.faq-section details{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:18px 20px;
  margin-top:12px;
}
.faq-section summary{
  cursor:pointer;
  font-weight:950;
  color:var(--purple-900);
  font-size:18px;
}
.faq-section p{
  color:var(--muted);
  margin-bottom:0;
}
@media(max-width:900px){
  .seo-grid{grid-template-columns:1fr}
}



/* Fix: top hero/banner text overcrowding */
.hero,
.hero-section,
.hero-wrap,
header.hero{
  overflow:hidden;
}

.hero .wrap,
.hero-inner,
.hero-grid,
.hero-content-wrap{
  align-items:center;
}

.hero-grid,
.hero .hero-grid,
.hero-inner{
  gap:clamp(34px,5vw,78px);
}

.hero-copy,
.hero-text,
.hero-content,
.hero .content,
.hero h1,
header h1{
  max-width:760px;
}

.hero h1,
header.hero h1,
.hero-title{
  font-size:clamp(42px,6.8vw,86px) !important;
  line-height:.94 !important;
  letter-spacing:-.055em !important;
  margin-bottom:clamp(18px,2.2vw,28px) !important;
  text-wrap:balance;
}

.hero p,
header.hero p,
.hero-subtitle,
.hero-lead,
.lead{
  max-width:660px !important;
  font-size:clamp(17px,1.55vw,22px) !important;
  line-height:1.55 !important;
  margin-bottom:clamp(18px,2.2vw,28px) !important;
}

.hero .cta,
.hero-actions,
.hero-buttons,
.cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px 14px;
  margin-top:clamp(20px,2.4vw,34px);
  align-items:center;
}

.hero .btn,
.hero-actions a,
.hero-buttons a{
  white-space:normal;
  line-height:1.15;
  text-align:center;
}

.hero-card,
.hero-image,
.hero-visual,
.hero-media{
  min-width:0;
  max-width:100%;
}

.hero-card img,
.hero-image img,
.hero-visual img,
.hero-media img{
  width:100%;
  height:auto;
  object-fit:cover;
}

@media(max-width:980px){
  .hero-grid,
  .hero .hero-grid,
  .hero-inner{
    grid-template-columns:1fr !important;
    gap:30px !important;
  }
  .hero-copy,
  .hero-text,
  .hero-content,
  .hero .content{
    max-width:100%;
  }
  .hero h1,
  header.hero h1,
  .hero-title{
    font-size:clamp(40px,10vw,68px) !important;
    max-width:900px;
  }
}

@media(max-width:620px){
  .hero,
  header.hero{
    padding-top:34px !important;
  }
  .hero h1,
  header.hero h1,
  .hero-title{
    font-size:clamp(36px,11.5vw,54px) !important;
    line-height:1 !important;
    letter-spacing:-.045em !important;
  }
  .hero p,
  header.hero p,
  .hero-subtitle,
  .hero-lead,
  .lead{
    font-size:16px !important;
  }
  .hero .btn,
  .hero-actions a,
  .hero-buttons a{
    width:100%;
    justify-content:center;
  }
}



/* Fix: simplified top navigation */
.main-nav{
  gap:clamp(18px,2.8vw,34px) !important;
}
.main-nav a{
  white-space:nowrap;
}
@media(max-width:920px){
  .main-nav{
    gap:18px !important;
    font-size:12px;
  }
}



/* Dance/movement-focused top navigation */
.anchor-offset{
  display:block;
  height:1px;
  scroll-margin-top:110px;
}
.main-nav{
  gap:clamp(18px,2.6vw,32px) !important;
}
.main-nav a{
  white-space:nowrap;
  letter-spacing:.075em;
}
@media(max-width:860px){
  .main-nav{
    gap:14px !important;
    font-size:11px !important;
  }
}



/* Editorial article: BTS dance influences and fan-cam moments */
.dance-article-section,.fancam-section{
  margin:44px clamp(22px,4vw,54px);
  padding:clamp(28px,4vw,50px);
  border-radius:36px;
  background:linear-gradient(135deg,rgba(255,255,255,.86),rgba(246,236,255,.82));
  border:1px solid var(--line);
  box-shadow:0 24px 70px rgba(55,20,80,.09);
}
.article-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:clamp(24px,4vw,46px);
  align-items:start;
}
.feature-article{
  max-width:900px;
}
.article-kicker{
  display:inline-flex;
  padding:9px 13px;
  border-radius:999px;
  background:#f0e2ff;
  color:var(--purple-800);
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:12px;
  margin-bottom:14px;
}
.feature-article h2,.fancam-section h2{
  margin:0 0 18px;
  color:var(--purple-900);
  font-size:clamp(34px,5vw,64px);
  line-height:.96;
  letter-spacing:-.055em;
}
.article-lead{
  font-size:clamp(18px,2vw,23px);
  line-height:1.55;
  color:var(--muted);
  margin-bottom:28px;
}
.feature-article h3{
  color:var(--purple-800);
  font-size:26px;
  margin:28px 0 8px;
  letter-spacing:-.035em;
}
.feature-article p{
  color:var(--muted);
  font-size:17px;
}
.article-sidebar{
  display:grid;
  gap:16px;
}
.sidebar-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:22px;
}
.sidebar-card span{
  display:block;
  font-weight:950;
  color:var(--purple-800);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:12px;
  margin-bottom:12px;
}
.sidebar-card ul{
  margin:0;
  padding-left:18px;
  color:var(--brown);
  font-weight:800;
}
.sidebar-card li{
  margin:8px 0;
}
.fancam-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  margin-top:26px;
}
.fancam-grid article{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:24px;
  min-height:230px;
}
.fancam-number{
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:linear-gradient(135deg,var(--purple-700),var(--purple-300));
  color:#fff;
  font-weight:950;
  margin-bottom:18px;
}
.fancam-grid h3{
  margin:0 0 10px;
  color:var(--purple-900);
  font-size:23px;
  letter-spacing:-.035em;
}
.fancam-grid p{
  color:var(--muted);
}
.editor-note{
  margin-top:24px;
  padding:18px 20px;
  border-radius:22px;
  background:#fff8ef;
  color:var(--brown);
  border:1px solid rgba(126,82,48,.16);
}
@media(max-width:980px){
  .article-layout{grid-template-columns:1fr}
  .fancam-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:620px){
  .fancam-grid{grid-template-columns:1fr}
}











/* Option 2 applied: clean 4 + 3 member layout */
#members.option-2-members{
  padding-top: 10px;
}

#members.option-2-members .section-heading{
  margin-bottom: 26px;
  align-items: end;
}

#members.option-2-members .section-heading h2{
  font-size: clamp(40px, 5vw, 68px);
  line-height: .96;
  letter-spacing: -.055em;
}

#members.option-2-members .member-grid{
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 22px;
  align-items: start;
}

#members.option-2-members .member{
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(249,242,255,.92));
  border: 1px solid var(--line);
  border-radius: 30px;
  padding: 18px 18px 20px;
  text-align: center;
  box-shadow: 0 18px 44px rgba(55,20,80,.07);
  overflow: visible;
  min-height: 290px;
  transition: transform .18s ease, box-shadow .18s ease;
}

#members.option-2-members .member:hover{
  transform: translateY(-4px);
  box-shadow: 0 24px 52px rgba(55,20,80,.10);
}

#members.option-2-members .member:nth-child(1),
#members.option-2-members .member:nth-child(2),
#members.option-2-members .member:nth-child(3),
#members.option-2-members .member:nth-child(4){
  grid-column: span 3;
}

#members.option-2-members .member:nth-child(5){
  grid-column: 2 / span 3;
}
#members.option-2-members .member:nth-child(6){
  grid-column: 5 / span 3;
}
#members.option-2-members .member:nth-child(7){
  grid-column: 8 / span 3;
}

#members.option-2-members .member img,
#members.option-2-members .member-portrait-img{
  display: block;
  width: 140px;
  height: 140px;
  margin: 4px auto 16px;
  aspect-ratio: 1/1;
  object-fit: cover;
  object-position: center center;
  border-radius: 50%;
  border: 7px solid #ead7ff;
  background: #f7efff;
  box-shadow: 0 10px 22px rgba(88,35,143,.10);
}

#members.option-2-members .member h3{
  margin: 10px 0 0;
  font-size: 22px;
  line-height: 1.15;
  color: var(--purple-900);
}

#members.option-2-members .section-heading a{
  white-space: nowrap;
}

@media (max-width: 1200px){
  #members.option-2-members .member-grid{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  #members.option-2-members .member{
    grid-column: auto !important;
    min-height: 270px;
  }
}

@media (max-width: 760px){
  #members.option-2-members .member-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }
  #members.option-2-members .member{
    min-height: 235px;
    padding: 14px 12px 16px;
    border-radius: 24px;
  }
  #members.option-2-members .member img,
  #members.option-2-members .member-portrait-img{
    width: 110px;
    height: 110px;
  }
  #members.option-2-members .member h3{
    font-size: 18px;
  }
}


/* Header navigation refinement */
.site-header .container{
  gap: 28px;
}

.brand{
  flex: 0 0 auto;
}

.main-nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex: 1 1 auto;
  gap: clamp(16px, 1.7vw, 28px) !important;
  flex-wrap: nowrap;
  white-space: nowrap;
}

.main-nav a{
  font-size: 12px !important;
  letter-spacing: .08em !important;
  line-height: 1.1;
  white-space: nowrap;
}

@media (max-width: 1240px){
  .main-nav{
    gap: 16px !important;
  }
  .main-nav a{
    font-size: 11px !important;
    letter-spacing: .06em !important;
  }
}

@media (max-width: 980px){
  .site-header .container{
    gap: 18px;
  }
  .main-nav{
    gap: 12px !important;
  }
  .main-nav a{
    font-size: 10.5px !important;
  }
}


/* Member portrait polish */
#members.option-2-members .member img,
#members.option-2-members .member-portrait-img{
  width: 150px;
  height: 150px;
  margin: 2px auto 16px;
  border: 7px solid #e7d2ff;
  box-shadow: 0 14px 28px rgba(88,35,143,.12);
}

#members.option-2-members .member{
  min-height: 300px;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,239,255,.96));
}

@media (max-width: 760px){
  #members.option-2-members .member img,
  #members.option-2-members .member-portrait-img{
    width: 118px;
    height: 118px;
  }
}



/* Premium member section upgrade */
#members.option-2-members{
  margin: 34px clamp(22px, 4vw, 54px);
  padding: 34px clamp(18px, 2.8vw, 34px) 40px;
  border-radius: 40px;
  background:
    radial-gradient(circle at 12% 10%, rgba(208,176,255,.35), transparent 28%),
    radial-gradient(circle at 88% 16%, rgba(246,229,255,.8), transparent 26%),
    linear-gradient(135deg, rgba(255,255,255,.82), rgba(247,239,255,.94));
  border: 1px solid rgba(207, 190, 225, .85);
  box-shadow: 0 26px 74px rgba(55,20,80,.09);
}

#members.option-2-members .section-heading{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 24px;
  margin-bottom: 30px;
}

#members.option-2-members .section-heading-copy{
  max-width: 980px;
}

#members.option-2-members .section-heading span{
  display:inline-block;
  margin-bottom: 8px;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 950;
  font-size: 12px;
  color: var(--purple-700);
}

#members.option-2-members .section-heading h2{
  margin: 0 0 10px;
  font-size: clamp(42px, 5vw, 70px);
  line-height: .95;
  letter-spacing: -.055em;
}

#members.option-2-members .section-heading p{
  margin: 0;
  max-width: 760px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.55;
}

#members.option-2-members .section-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 132px;
  padding: 15px 22px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--purple-700), #9a6aff);
  color: #fff;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 16px 30px rgba(88,35,143,.18);
  white-space: nowrap;
}

#members.option-2-members .member-grid{
  row-gap: 24px;
  column-gap: 22px;
}

#members.option-2-members .member{
  position: relative;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,242,255,.96));
  border: 1px solid rgba(219, 204, 235, .96);
  border-radius: 34px;
  padding: 20px 18px 22px;
  text-align: center;
  box-shadow: 0 18px 44px rgba(55,20,80,.07);
  min-height: 340px;
  overflow: hidden;
  transition: transform .22s ease, box-shadow .22s ease;
}

#members.option-2-members .member:before{
  content:"";
  position:absolute;
  inset: 0 0 auto 0;
  height: 110px;
  background: linear-gradient(180deg, rgba(235,223,255,.75), rgba(255,255,255,0));
  pointer-events: none;
}

#members.option-2-members .member:hover{
  transform: translateY(-6px);
  box-shadow: 0 26px 54px rgba(55,20,80,.12);
}

#members.option-2-members .member img,
#members.option-2-members .member-portrait-img{
  position: relative;
  z-index: 1;
  width: 158px;
  height: 158px;
  margin: 2px auto 16px;
  object-fit: cover;
  object-position: center center;
  border-radius: 50%;
  border: 8px solid #ead7ff;
  background: #f7efff;
  box-shadow: 0 16px 30px rgba(88,35,143,.14);
}

#members.option-2-members .member h3{
  position: relative;
  z-index: 1;
  margin: 10px 0 8px;
  font-size: 23px;
  line-height: 1.12;
  color: var(--purple-900);
}

#members.option-2-members .member-role{
  position: relative;
  z-index: 1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin: 0 auto;
  padding: 8px 14px;
  border-radius: 999px;
  background: #f2e8ff;
  color: var(--purple-800);
  font-size: 13px;
  line-height: 1.2;
  font-weight: 900;
  letter-spacing: .02em;
  border: 1px solid rgba(164,128,214,.18);
}

@media (max-width: 1200px){
  #members.option-2-members{
    padding: 28px 22px 34px;
  }
  #members.option-2-members .section-heading{
    align-items:flex-start;
    flex-direction:column;
  }
  #members.option-2-members .section-cta{
    align-self:flex-start;
  }
  #members.option-2-members .member{
    min-height: 320px;
  }
}

@media (max-width: 760px){
  #members.option-2-members{
    margin: 26px 18px;
    padding: 22px 14px 24px;
    border-radius: 28px;
  }
  #members.option-2-members .section-heading h2{
    font-size: clamp(34px, 10vw, 54px);
  }
  #members.option-2-members .section-heading p{
    font-size: 16px;
  }
  #members.option-2-members .member{
    min-height: 282px;
    padding: 16px 12px 18px;
    border-radius: 24px;
  }
  #members.option-2-members .member img,
  #members.option-2-members .member-portrait-img{
    width: 118px;
    height: 118px;
  }
  #members.option-2-members .member h3{
    font-size: 18px;
  }
  #members.option-2-members .member-role{
    font-size: 12px;
    padding: 7px 11px;
  }
}



/* Premium header + hero upgrade */
.site-header{
  position: sticky;
  top: 18px;
  z-index: 40;
  width: min(1520px, calc(100% - 36px));
  margin: 18px auto 0;
  padding: 16px 22px;
  border-radius: 28px;
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(224,210,236,.95);
  box-shadow: 0 20px 54px rgba(50,24,78,.08);
}

.hero{
  position: relative;
  margin: 26px clamp(18px, 3vw, 40px) 34px;
  min-height: 620px;
  border-radius: 42px;
  overflow: hidden;
  box-shadow: 0 26px 80px rgba(42,20,76,.12);
  border: 1px solid rgba(220,206,236,.95);
}

.hero-bg{
  width: 100%;
  height: 100%;
  min-height: 620px;
  object-fit: cover;
  object-position: center center;
  transform: scale(1.02);
}

.hero-shade{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 22% 24%, rgba(22,10,34,.12), transparent 26%),
    linear-gradient(90deg, rgba(18,10,26,.70) 0%, rgba(33,18,46,.52) 34%, rgba(33,18,46,.22) 58%, rgba(20,12,28,.16) 100%);
}

.hero-featured-badge{
  position: absolute;
  top: 28px;
  right: 28px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  padding: 12px 18px;
  border-radius: 999px;
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.24);
  backdrop-filter: blur(12px);
  box-shadow: 0 12px 28px rgba(22,10,34,.18);
}

.hero-content.premium-hero-card{
  position: absolute;
  left: clamp(26px, 4vw, 54px);
  bottom: clamp(30px, 4vw, 48px);
  z-index: 2;
  max-width: 650px;
  padding: 30px 30px 28px;
  border-radius: 34px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,.10)),
    rgba(36,18,50,.44);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.20);
  box-shadow: 0 20px 58px rgba(18,10,28,.24);
}

.hero .eyebrow{
  display: inline-flex;
  align-items: center;
  padding: 9px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
  color: #f7efff;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 12px;
}

.hero h1{
  margin: 18px 0 14px;
  color: #fff;
  font-size: clamp(48px, 6.8vw, 88px);
  line-height: .92;
  letter-spacing: -.06em;
  text-wrap: balance;
}

.hero h1 span{
  color: #d9b7ff;
}

.hero p{
  margin: 0 0 20px;
  max-width: 560px;
  color: rgba(255,255,255,.88);
  font-size: 19px;
  line-height: 1.6;
}

.hero .hero-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 18px;
}

.hero .btn{
  min-height: 50px;
  padding: 14px 20px;
  border-radius: 999px;
  font-weight: 900;
  box-shadow: none;
}

.hero .btn.primary{
  background: linear-gradient(135deg, var(--purple-700), #9d6bff);
  border: 0;
}

.hero .btn.ghost{
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.22);
  color: #fff;
}

.hero-meta{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 4px;
}

.hero-meta span{
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.92);
  font-size: 13px;
  font-weight: 800;
}

.hero-dots{
  margin-top: 16px;
}

.hero-dots span{
  width: 10px;
  height: 10px;
  background: #d8b6ff;
  box-shadow: 0 0 0 4px rgba(216,182,255,.16);
}

@media (max-width: 1200px){
  .site-header{
    width: min(1520px, calc(100% - 24px));
    top: 12px;
  }
  .hero{
    min-height: 590px;
  }
  .hero-bg{
    min-height: 590px;
  }
  .hero-content.premium-hero-card{
    max-width: 600px;
    padding: 26px 24px 24px;
  }
}

@media (max-width: 820px){
  .site-header{
    border-radius: 22px;
    padding: 14px 16px;
  }
  .hero{
    min-height: 620px;
    margin: 18px 16px 28px;
    border-radius: 28px;
  }
  .hero-bg{
    min-height: 620px;
  }
  .hero-featured-badge{
    top: 18px;
    right: 18px;
    font-size: 11px;
    padding: 10px 14px;
  }
  .hero-content.premium-hero-card{
    left: 16px;
    right: 16px;
    bottom: 16px;
    max-width: none;
    border-radius: 24px;
    padding: 22px 18px 20px;
  }
  .hero h1{
    font-size: clamp(38px, 11vw, 58px);
  }
  .hero p{
    font-size: 16px;
  }
}



/* Tour calendar section */
.tour-calendar-section{
  margin:44px clamp(22px,4vw,54px);
  padding:clamp(28px,4vw,46px);
  border-radius:40px;
  background:
    radial-gradient(circle at 12% 8%, rgba(210,180,255,.38), transparent 30%),
    radial-gradient(circle at 88% 12%, rgba(255,245,229,.85), transparent 27%),
    linear-gradient(135deg, rgba(255,255,255,.90), rgba(247,239,255,.95));
  border:1px solid rgba(220,205,238,.9);
  box-shadow:0 26px 74px rgba(55,20,80,.09);
}
.tour-calendar-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:28px;
  align-items:end;
  margin-bottom:26px;
}
.tour-calendar-head h2{
  margin:8px 0 12px;
  font-size:clamp(38px,5.4vw,72px);
  line-height:.94;
  letter-spacing:-.06em;
  color:var(--purple-900);
}
.tour-calendar-head p{
  max-width:780px;
  color:var(--muted);
  font-size:18px;
  line-height:1.55;
}
.calendar-source-note{
  padding:20px;
  border-radius:26px;
  background:rgba(255,255,255,.72);
  border:1px solid var(--line);
}
.calendar-source-note strong{
  display:block;
  color:var(--purple-800);
  margin-bottom:6px;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:12px;
}
.calendar-source-note p{
  margin:0;
  font-size:14px;
}
.tour-filters{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:0 0 20px;
}
.tour-filters button{
  border:1px solid rgba(140,96,190,.22);
  background:#fff;
  color:var(--purple-800);
  border-radius:999px;
  padding:10px 14px;
  font-weight:900;
  cursor:pointer;
}
.tour-filters button.active{
  background:linear-gradient(135deg,var(--purple-700),#9d6bff);
  color:#fff;
  border-color:transparent;
}
.tour-card-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-bottom:20px;
}
.tour-card-grid article{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:18px 20px;
}
.tour-card-grid strong{
  display:block;
  color:var(--purple-900);
  font-size:28px;
  line-height:1;
}
.tour-card-grid span{
  color:var(--muted);
  font-weight:800;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.tour-table-wrap{
  overflow:auto;
  border-radius:26px;
  border:1px solid var(--line);
  background:#fff;
}
.tour-table{
  width:100%;
  border-collapse:collapse;
  min-width:920px;
}
.tour-table th{
  text-align:left;
  padding:16px 18px;
  background:#f2e8ff;
  color:var(--purple-900);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:12px;
}
.tour-table td{
  padding:16px 18px;
  border-top:1px solid rgba(220,205,238,.75);
  color:var(--muted);
  vertical-align:top;
}
.tour-table td strong{
  display:block;
  color:var(--purple-900);
  font-size:15px;
}
.tour-table td span{
  display:block;
  font-size:12px;
  margin-top:4px;
  color:var(--brown);
  font-weight:800;
}
.tour-mobile-list{
  display:none;
}
.tour-table tr.is-hidden,
.tour-mobile-list article.is-hidden{
  display:none;
}
@media(max-width:980px){
  .tour-calendar-head{
    grid-template-columns:1fr;
    align-items:start;
  }
  .tour-card-grid{
    grid-template-columns:1fr;
  }
  .tour-table-wrap{
    display:none;
  }
  .tour-mobile-list{
    display:grid;
    gap:14px;
  }
  .tour-mobile-list article{
    background:#fff;
    border:1px solid var(--line);
    border-radius:24px;
    padding:18px;
  }
  .tour-mobile-list span{
    color:var(--purple-700);
    font-weight:950;
    font-size:13px;
  }
  .tour-mobile-list h3{
    margin:6px 0;
    color:var(--purple-900);
    font-size:22px;
  }
  .tour-mobile-list p{
    color:var(--muted);
    margin:0 0 8px;
  }
  .tour-mobile-list em{
    color:var(--brown);
    font-style:normal;
    font-weight:800;
    font-size:13px;
  }
}


/* v21: remove large hero overlay and add premium tour button */
.hero{
  min-height: 520px;
}

.hero-bg{
  min-height: 520px;
  object-position: center center;
}

.hero-shade{
  background:
    linear-gradient(90deg, rgba(20,10,30,.08), rgba(20,10,30,.02)),
    linear-gradient(180deg, rgba(20,10,30,.04), rgba(20,10,30,.10));
}

.hero-content,
.hero-content.premium-hero-card,
.hero-featured-badge{
  display:none !important;
}

.main-nav .nav-tour-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height: 38px;
  padding: 0 18px !important;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--purple-700), #9d6bff);
  color: #fff !important;
  box-shadow: 0 14px 28px rgba(88,35,143,.16);
  border: 0;
}

.main-nav .nav-tour-button:after{
  display:none !important;
}

.main-nav .nav-tour-button:hover{
  transform: translateY(-1px);
}

@media(max-width:820px){
  .hero{
    min-height: 430px;
  }
  .hero-bg{
    min-height: 430px;
  }
  .main-nav .nav-tour-button{
    min-height: 34px;
    padding: 0 14px !important;
  }
}



/* Full recommendation package */
.language-switcher{
  display:flex;
  align-items:center;
  gap:6px;
  margin-left:10px;
}
.language-switcher button{
  border:1px solid rgba(120,80,160,.18);
  background:#fff;
  color:var(--purple-800);
  font-size:11px;
  font-weight:950;
  border-radius:999px;
  padding:8px 9px;
  cursor:pointer;
}

.dance-breakdown-section,
.fan-cover-section,
.watch-events-section,
.glossary-section,
.related-pages-section{
  margin:44px clamp(22px,4vw,54px);
  padding:clamp(28px,4vw,46px);
  border-radius:40px;
  background:linear-gradient(135deg,rgba(255,255,255,.90),rgba(247,239,255,.95));
  border:1px solid rgba(220,205,238,.9);
  box-shadow:0 26px 74px rgba(55,20,80,.08);
}
.dance-breakdown-section .section-heading,
.watch-events-section .section-heading,
.glossary-section .section-heading,
.related-pages-section .section-heading{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:24px;
  margin-bottom:26px;
}
.dance-breakdown-section .section-heading h2,
.fan-cover-section h2,
.watch-events-section h2,
.glossary-section h2,
.related-pages-section h2{
  font-size:clamp(38px,5.4vw,70px);
  line-height:.94;
  letter-spacing:-.06em;
  color:var(--purple-900);
  margin:6px 0 10px;
}
.dance-breakdown-section .section-heading p,
.fan-cover-section p,
.watch-events-section p,
.glossary-section p,
.related-pages-section p{
  color:var(--muted);
  font-size:18px;
  line-height:1.55;
  max-width:820px;
}
.breakdown-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:16px;
}
.breakdown-grid article,
.watch-grid article,
.glossary-grid article,
.spotlight-grid article{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:22px;
  box-shadow:0 14px 34px rgba(55,20,80,.05);
}
.breakdown-grid strong,
.watch-grid span{
  display:inline-block;
  color:var(--purple-700);
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:11px;
  font-weight:950;
  margin-bottom:10px;
}
.breakdown-grid h3,
.watch-grid h3,
.spotlight-grid h3{
  margin:0 0 10px;
  color:var(--purple-900);
  font-size:23px;
  letter-spacing:-.035em;
}
.difficulty{
  height:8px;
  background:#efe5ff;
  border-radius:999px;
  overflow:hidden;
  margin:18px 0 8px;
}
.difficulty span{
  display:block;
  height:100%;
  background:linear-gradient(90deg,var(--purple-700),#c7a0ff);
  border-radius:999px;
}
.breakdown-grid em{
  color:var(--brown);
  font-style:normal;
  font-weight:800;
  font-size:13px;
}
.fan-cover-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:28px;
  align-items:center;
}
.fan-cover-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:20px;
}
.fan-cover-hero aside{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:24px;
}
.fan-cover-hero aside strong{
  color:var(--purple-900);
  font-size:20px;
}
.fan-cover-hero aside ul{
  color:var(--muted);
  font-weight:800;
  padding-left:20px;
}
.spotlight-grid,
.watch-grid,
.glossary-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:22px;
}
.glossary-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.glossary-grid strong{
  display:block;
  color:var(--purple-900);
  font-size:22px;
  margin-bottom:8px;
}
.live-popup-card{
  background:linear-gradient(135deg,#fff,#f1e4ff) !important;
  border-color:rgba(148,96,210,.35) !important;
}
.video-open{
  margin-top:16px;
  border:0;
  border-radius:999px;
  padding:12px 16px;
  background:linear-gradient(135deg,var(--purple-700),#9d6bff);
  color:#fff;
  font-weight:900;
  cursor:pointer;
}
.video-modal{
  position:fixed;
  inset:0;
  z-index:999;
  display:none;
  place-items:center;
  padding:22px;
  background:rgba(18,10,28,.72);
  backdrop-filter:blur(10px);
}
.video-modal.is-open{
  display:grid;
}
.video-modal-card{
  position:relative;
  width:min(760px,96vw);
  border-radius:34px;
  background:#fff;
  padding:34px;
  box-shadow:0 30px 100px rgba(0,0,0,.35);
}
.video-close{
  position:absolute;
  top:18px;
  right:18px;
  border:0;
  background:#f1e4ff;
  color:var(--purple-900);
  width:38px;
  height:38px;
  border-radius:50%;
  font-size:24px;
  cursor:pointer;
}
.video-modal-card span{
  color:var(--purple-700);
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:12px;
}
.video-modal-card h2{
  color:var(--purple-900);
  font-size:42px;
  letter-spacing:-.05em;
  margin:12px 0;
}
.video-placeholder-box{
  margin-top:20px;
  height:260px;
  border-radius:24px;
  display:grid;
  place-items:center;
  color:#fff;
  font-weight:950;
  background:linear-gradient(135deg,#2b173f,#8b55d7);
}
.tour-tools{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:0 0 16px;
}
.tour-tools input{
  flex:1 1 280px;
  border:1px solid var(--line);
  border-radius:999px;
  padding:13px 16px;
  font:inherit;
}
.tour-calendar-download,
.tour-notify{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:13px 16px;
  font-weight:900;
}
.tour-calendar-download{
  background:var(--purple-900);
  color:#fff;
}
.tour-notify{
  background:#fff;
  color:var(--purple-800);
  border:1px solid var(--line);
}
.newsletter-options{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px 12px;
  margin:12px 0;
  color:var(--muted);
  font-size:13px;
  font-weight:800;
}
.newsletter-options label{
  display:flex;
  gap:7px;
  align-items:center;
}
.related-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:14px;
}
.related-grid a{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:20px;
  color:var(--purple-900);
  font-weight:950;
  min-height:98px;
  display:flex;
  align-items:center;
}
.footer-upgrade{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1.4fr;
  gap:24px;
  margin-top:28px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.16);
}
.footer-upgrade h3,
.footer-upgrade h4{
  margin:0 0 10px;
  color:inherit;
}
.footer-upgrade a{
  display:block;
  margin:8px 0;
  color:inherit;
  opacity:.85;
}
.footer-upgrade p{
  opacity:.76;
  margin:0;
}
@media(max-width:1100px){
  .breakdown-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .fan-cover-hero{grid-template-columns:1fr}
  .related-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .footer-upgrade{grid-template-columns:1fr 1fr}
  .language-switcher{display:none}
}
@media(max-width:760px){
  .dance-breakdown-section .section-heading,
  .watch-events-section .section-heading,
  .glossary-section .section-heading,
  .related-pages-section .section-heading{
    align-items:flex-start;
    flex-direction:column;
  }
  .breakdown-grid,
  .watch-grid,
  .glossary-grid,
  .spotlight-grid,
  .related-grid{
    grid-template-columns:1fr;
  }
  .newsletter-options{
    grid-template-columns:1fr;
  }
  .footer-upgrade{
    grid-template-columns:1fr;
  }
}


/* v23 fixes: show all member specialties + larger newsletter subscribe button */
#members.option-2-members .member{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
}
#members.option-2-members .member h3{
  margin-bottom:10px;
}
#members.option-2-members .member-role{
  display:inline-flex !important;
  visibility:visible !important;
  opacity:1 !important;
  margin-top:0;
  margin-bottom:0;
  max-width:86%;
  text-align:center;
  white-space:normal;
}

.newsletter{
  align-items:start;
}
.newsletter .signup{
  display:grid;
  grid-template-columns:minmax(260px,1fr) 1fr;
  gap:14px 16px;
  align-items:start;
}
.newsletter .signup input{
  grid-column:1/2;
  height:62px;
  padding:0 22px;
  font-size:17px;
}
.newsletter .newsletter-options{
  grid-column:2/3;
  margin:0;
  padding:12px 4px 4px;
  align-self:center;
}
.newsletter .signup button{
  grid-column:1 / -1;
  justify-self:start;
  min-width:280px;
  height:58px;
  padding:0 34px;
  font-size:14px;
  letter-spacing:.08em;
  box-shadow:0 14px 30px rgba(88,35,143,.16);
}
.newsletter .signup small{
  grid-column:1 / -1;
}
@media(max-width:980px){
  .newsletter{
    grid-template-columns:1fr;
  }
  .newsletter .signup{
    grid-template-columns:1fr;
  }
  .newsletter .signup input,
  .newsletter .newsletter-options,
  .newsletter .signup button,
  .newsletter .signup small{
    grid-column:auto;
  }
  .newsletter .newsletter-options{
    padding:2px 0 0;
  }
  .newsletter .signup button{
    width:100%;
    min-width:0;
    justify-self:stretch;
  }
}



/* v24 typography refinement: cleaner magazine-style headings */
:root{
  --headline-tracking: -.055em;
}

.hero h1,
#members.option-2-members .section-heading h2,
.dance-breakdown-section .section-heading h2,
.fan-cover-section h2,
.watch-events-section h2,
.glossary-section h2,
.related-pages-section h2,
.tour-calendar-head h2,
.newsletter h2,
.about-text h2,
.section h2{
  text-transform: uppercase;
  letter-spacing: var(--headline-tracking);
  line-height: .90;
  font-weight: 950;
}

.breakdown-grid h3,
.watch-grid h3,
.spotlight-grid h3,
.glossary-grid strong,
.related-grid a,
.tour-mobile-list h3,
.tour-table td strong,
.calendar-source-note strong,
.fan-cover-hero aside strong{
  text-transform: uppercase;
  letter-spacing: -.035em;
  line-height: .98;
}

.watch-events-section h2{
  max-width: 1100px;
  font-size: clamp(42px, 5vw, 74px);
}

.dance-breakdown-section .section-heading h2,
.fan-cover-section h2,
.glossary-section h2,
.related-pages-section h2,
.tour-calendar-head h2,
.newsletter h2{
  font-size: clamp(38px, 4.9vw, 68px);
}

.spotlight-grid h3,
.breakdown-grid h3,
.watch-grid h3{
  font-size: 24px;
}

.newsletter h2{
  max-width: 700px;
}

.about-text h2{
  font-size: clamp(38px, 4.8vw, 66px);
}

@media (max-width: 760px){
  .hero h1,
  #members.option-2-members .section-heading h2,
  .dance-breakdown-section .section-heading h2,
  .fan-cover-section h2,
  .watch-events-section h2,
  .glossary-section h2,
  .related-pages-section h2,
  .tour-calendar-head h2,
  .newsletter h2,
  .about-text h2{
    line-height: .94;
  }

  .breakdown-grid h3,
  .watch-grid h3,
  .spotlight-grid h3{
    font-size: 20px;
  }
}



/* v25 symmetry fix: cleaner card alignment in Dance Breakdown */
.dance-breakdown-section .section-heading{
  align-items:flex-start;
}

.dance-breakdown-section .section-heading > div{
  max-width: 980px;
}

.dance-breakdown-section .section-heading p{
  max-width: 860px;
  margin-top: 10px;
}

.dance-breakdown-section .section-cta{
  margin-top: 4px;
  align-self: flex-start;
}

.breakdown-grid{
  align-items: stretch;
}

.breakdown-grid article{
  display: flex;
  flex-direction: column;
  min-height: 430px;
  padding: 24px 24px 22px;
}

.breakdown-grid article strong{
  margin-bottom: 12px;
}

.breakdown-grid article h3{
  min-height: 112px;
  margin: 0 0 14px;
  display: flex;
  align-items: flex-start;
}

.breakdown-grid article p{
  flex: 1 1 auto;
  margin: 0 0 18px;
  min-height: 146px;
}

.breakdown-grid .difficulty{
  margin-top: auto;
  margin-bottom: 10px;
  width: 100%;
}

.breakdown-grid em{
  display: block;
  min-height: 20px;
  margin-top: 0;
}

@media (max-width: 1200px){
  .breakdown-grid article{
    min-height: 390px;
  }
  .breakdown-grid article h3{
    min-height: 92px;
  }
  .breakdown-grid article p{
    min-height: 118px;
  }
}

@media (max-width: 760px){
  .dance-breakdown-section .section-heading p{
    max-width: none;
  }

  .breakdown-grid article{
    min-height: auto;
    padding: 22px 20px;
  }

  .breakdown-grid article h3,
  .breakdown-grid article p,
  .breakdown-grid em{
    min-height: 0;
  }
}



/* v26 cleanup: remove instruction feel and tighten section intro spacing */
.dance-breakdown-section .section-heading p:empty,
.fan-cover-section p:empty,
.watch-events-section .section-heading p:empty,
.tour-calendar-head p:empty{
  display:none;
}

.dance-breakdown-section .section-heading,
.watch-events-section .section-heading{
  margin-bottom:22px;
}

.fan-cover-section .fan-cover-hero p,
.watch-events-section .section-heading p,
.tour-calendar-head p,
.newsletter p{
  max-width:760px;
}

.tour-calendar-section{
  scroll-margin-top:120px;
}



/* v27 section order cleanup */
#tour-calendar,
#about,
#members,
#fancams,
#seo-dance{
  scroll-margin-top:120px;
}



/* v28: noticeable fan-page notice styling */
.calendar-source-note,
.fan-page-notice,
.notice-card{
  background: linear-gradient(135deg, #fff1c9, #ffd8ef) !important;
  border: 2px solid #ff9f6b !important;
  box-shadow: 0 18px 40px rgba(255, 146, 84, .18) !important;
}

.calendar-source-note strong,
.fan-page-notice strong,
.notice-card strong{
  color: #9d3a00 !important;
}

.calendar-source-note p,
.fan-page-notice p,
.notice-card p{
  color: #6a3b22 !important;
  font-weight: 700;
}

/* if the notice is in the DMCA/legal/footer area, make it stand out there too */
.dmca-section .notice-card,
.dmca-section .fan-page-notice,
.footer .notice-card{
  border-radius: 26px;
  padding: 20px;
}



/* v30 calendar date cleanup */
.tour-updated-note{
  margin: -4px 0 16px;
  padding: 12px 16px;
  border-radius: 18px;
  background: #f3e8ff;
  color: var(--purple-800);
  font-weight: 900;
  border: 1px solid rgba(130,80,180,.18);
}



/* v31 order: About BTS, Dance & Music Timeline, BTS Members */
#about,
#timeline,
#members{
  scroll-margin-top:120px;
}



/* v33 mobile menu redesign: compact dropdown instead of large blocking panel */
@media (max-width: 1060px){
  .site-header{
    position: sticky;
    top: 0;
    min-height: 76px;
    height: auto;
    padding-top: 12px;
    padding-bottom: 12px;
  }

  .language-switcher{
    display: none !important;
  }

  .menu-toggle{
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 54px;
    height: 54px;
    border-radius: 18px;
    padding: 0;
    font-size: 22px;
    flex: 0 0 auto;
    box-shadow: 0 14px 28px rgba(88,35,143,.18);
  }

  .main-nav{
    display: none !important;
    position: absolute !important;
    right: 18px;
    top: calc(100% + 8px);
    width: min(340px, calc(100vw - 36px));
    padding: 16px;
    border-radius: 26px !important;
    background: rgba(255,248,242,.98) !important;
    border: 1px solid rgba(95,60,130,.14) !important;
    box-shadow: 0 26px 64px rgba(32,14,49,.18) !important;
    backdrop-filter: blur(16px);
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    align-items: stretch !important;
    z-index: 200;
  }

  .main-nav.open{
    display: grid !important;
  }

  .main-nav a{
    padding: 12px 12px !important;
    min-height: 52px;
    border-radius: 16px;
    background: #fff;
    border: 1px solid rgba(95,60,130,.10);
    box-shadow: 0 8px 20px rgba(55,20,80,.05);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    white-space: normal !important;
    line-height: 1.15;
    font-size: 12px !important;
    letter-spacing: .07em;
  }

  .main-nav a:after{
    display: none !important;
  }

  .main-nav .nav-tour-button{
    grid-column: 1 / -1;
    min-height: 54px !important;
    padding: 0 18px !important;
    background: linear-gradient(135deg,var(--purple-700),#9d6bff) !important;
    color: #fff !important;
    border: 0 !important;
  }

  .main-nav a:hover{
    transform: none;
  }
}

@media (max-width: 640px){
  .main-nav{
    grid-template-columns: 1fr;
    width: min(320px, calc(100vw - 28px));
    right: 14px;
    top: calc(100% + 6px);
    padding: 14px;
  }

  .main-nav a{
    justify-content: flex-start;
    text-align: left;
    padding: 13px 14px !important;
  }

  .main-nav .nav-tour-button{
    justify-content: center;
  }
}



/* v34 broad K-pop SEO landing content */
.broad-kpop-seo-section{margin:44px clamp(22px,4vw,54px);padding:clamp(28px,4vw,46px);border-radius:40px;background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(247,239,255,.96));border:1px solid rgba(220,205,238,.9);box-shadow:0 26px 74px rgba(55,20,80,.08)}
.broad-kpop-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:24px}
.broad-kpop-grid article{background:#fff;border:1px solid var(--line);border-radius:30px;padding:24px;box-shadow:0 14px 34px rgba(55,20,80,.05)}
.broad-kpop-grid h3{margin:0 0 12px;color:var(--purple-900);font-size:26px;line-height:.98;letter-spacing:-.04em;text-transform:uppercase}
.broad-kpop-grid p{color:var(--muted);font-size:16px}
.broad-kpop-grid a{display:inline-flex;margin-top:14px;border-radius:999px;padding:12px 16px;background:linear-gradient(135deg,var(--purple-700),#9d6bff);color:#fff;font-weight:900;text-transform:uppercase;font-size:12px;letter-spacing:.06em}
@media(max-width:980px){.broad-kpop-grid{grid-template-columns:1fr}}


/* v36 illustrations */
.section-illustration{margin:24px 0 28px;border-radius:30px;overflow:hidden;border:1px solid rgba(89,58,128,.12);box-shadow:0 18px 46px rgba(51,20,79,.10);background:#fff}
.section-illustration img{display:block;width:100%;height:auto}
.article-illustration{margin-top:0;margin-bottom:26px}
@media (min-width: 900px){
  .dance-article-section .article-illustration{max-width:880px}
}



/* v37 illustration path fix visual safety */
.section-illustration img{
  min-height: 180px;
  object-fit: cover;
  background: linear-gradient(135deg,#f5eaff,#fff8f2);
}
