/* ============================================================
   Victoria Ballet — Design System "Editorial Elegance"
   Brand: Misty Rose #FCD8D9 · Ivory · Ink (from 250513 Victoria Logos.ai)
============================================================ */
:root{
  --rose:#FCD8D9;
  --rose-deep:#E8A0A8;
  --rose-text:#C0707B;
  --plum:#E1B0E3;
  --ivory:#FDFBF4;
  --ink:#121214;
  --ink-soft:#3A3A40;
  --gray:#576066;
  --line:rgba(18,18,20,.12);
  --line-dark:rgba(255,255,255,.16);
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
/* 기본 400: Outfit 300은 0.9rem대 본문에서 흐릿함. 가벼운 300은 큰 디스플레이 텍스트에만 선택 적용 */
body{font-family:var(--sans);color:var(--ink);background:var(--ivory);line-height:1.6;font-weight:400;
  -webkit-font-smoothing:antialiased}
img{max-width:100%}
/* 수평 오버플로우 가드 (clip은 sticky를 깨지 않음) */
html,body{overflow-x:clip}
.video-grid>*,.class-grid>*,.paths>*,.track-tiles>*{min-width:0}

/* ---------- announcement bar (회전식) ---------- */
.announce-bar{position:relative;z-index:101;background:var(--ink);color:#fff;font-size:.82rem;letter-spacing:.06em;
  display:flex;align-items:center;justify-content:center;gap:6px;padding:0 64px;height:42px}
.announce-bar .ab-track{position:relative;flex:0 1 auto;min-width:0;height:100%;width:min(720px,100%)}
.announce-bar .ab-item{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:14px;
  opacity:0;visibility:hidden;transition:opacity .45s ease, visibility .45s;padding:0 6px}
.announce-bar .ab-item.active{opacity:1;visibility:visible}
.announce-bar .ab-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.announce-bar .dot{width:6px;height:6px;border-radius:50%;background:var(--rose);flex:none}
.announce-bar a{color:var(--rose);text-decoration:none;border-bottom:1px solid var(--rose);padding-bottom:1px;white-space:nowrap}
.announce-bar a:hover{color:#fff;border-color:#fff}
.announce-bar .ab-nav{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.55);font-size:1.15rem;
  padding:4px 10px;line-height:1;transition:color .2s;flex:none}
.announce-bar .ab-nav:hover{color:var(--rose)}
.announce-bar .close{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:none;
  color:rgba(255,255,255,.55);font-size:1rem;cursor:pointer;padding:4px 8px;line-height:1}
.announce-bar .close:hover{color:#fff}

/* ---------- topbar ---------- */
.topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:0 48px;height:76px;margin-bottom:-76px;
  transition:background .45s ease, color .45s ease, box-shadow .45s ease, height .45s ease}
.topbar .brand{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.topbar .brand img{height:42px;display:block;transition:filter .45s ease, height .45s ease}
.topbar.on-dark .brand img{filter:invert(1)}
.topbar.on-light .brand img,.topbar.on-dark.scrolled .brand img{height:36px}
.topbar.on-light .brand img{filter:none}
.topbar nav{display:flex;gap:32px;align-items:center}
.topbar nav a{text-decoration:none;color:inherit;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:500;transition:color .25s;white-space:nowrap;flex-shrink:0}
/* 일반 링크: 호버 시 로즈 밑줄 슬라이드 + 글자색 전환 */
.topbar nav > a:not(.cta):not(.cta2){position:relative;padding:6px 0}
.topbar nav > a:not(.cta):not(.cta2)::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:1.5px;
  background:var(--rose);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.topbar nav > a:not(.cta):not(.cta2):hover::after{transform:scaleX(1)}
.topbar.on-dark nav > a:not(.cta):not(.cta2):hover{color:var(--rose)}
.topbar.on-light nav > a:not(.cta):not(.cta2)::after{background:var(--rose-text)}
.topbar.on-light nav > a:not(.cta):not(.cta2):hover{color:var(--rose-text)}
/* priority+ nav: 공간이 모자라면 뒤 항목부터 More 드롭다운으로 */
.more-wrap{position:relative;display:none;flex-shrink:0}
.more-btn{background:none;border:none;cursor:pointer;color:inherit;font-family:var(--sans);
  font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;padding:6px 0;white-space:nowrap;
  transition:color .25s}
.topbar.on-dark .more-btn:hover{color:var(--rose)}
.topbar.on-light .more-btn:hover{color:var(--rose-text)}
.more-btn .car{font-size:.6rem;display:inline-block;transition:transform .25s}
.more-wrap.open .more-btn .car{transform:rotate(180deg)}
.more-dd{position:absolute;top:calc(100% + 14px);right:-10px;min-width:210px;padding:10px 0;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .25s ease, transform .25s ease, visibility .25s}
.more-wrap.open .more-dd{opacity:1;visibility:visible;transform:none}
.more-dd a{display:block;padding:11px 24px}
.topbar.on-dark .more-dd{background:rgba(18,18,20,.78);backdrop-filter:blur(20px) saturate(1.5);-webkit-backdrop-filter:blur(20px) saturate(1.5);border:1px solid var(--line-dark)}
.topbar.on-dark .more-dd a:hover{color:var(--rose)}
.topbar.on-light .more-dd{background:#fff;border:1px solid var(--line);box-shadow:0 16px 40px rgba(18,18,20,.12)}
.topbar.on-light .more-dd a:hover{color:var(--rose-text)}
.topbar nav a.cta,.topbar nav a.cta2{opacity:1!important;padding:10px 20px;font-size:.74rem;letter-spacing:.2em;
  text-transform:uppercase;text-decoration:none;transition:all .3s;border:1px solid transparent}
.topbar nav a.cta2{border-color:currentColor}
.topbar nav a.cta{background:var(--rose);color:var(--ink)}
.topbar nav a.cta:hover{background:#fff}
.topbar.on-dark{color:#fff;background:transparent}
.topbar.on-dark.scrolled{background:rgba(18,18,20,.5);backdrop-filter:blur(20px) saturate(1.5);-webkit-backdrop-filter:blur(20px) saturate(1.5);box-shadow:0 1px 0 var(--line-dark);height:64px}
.topbar.on-dark nav a.cta2:hover{border-color:var(--rose);color:var(--rose)}
.topbar.on-light{color:var(--ink);background:rgba(253,251,244,.7);backdrop-filter:blur(20px) saturate(1.5);-webkit-backdrop-filter:blur(20px) saturate(1.5);box-shadow:0 1px 0 var(--line);height:64px}
.topbar.on-light nav a.cta{background:var(--ink);color:#fff}
.topbar.on-light nav a.cta:hover{background:var(--rose-text)}
.topbar.on-light nav a.cta2:hover{background:var(--ink);color:#fff}

/* ---------- mobile hamburger & overlay ---------- */
.burger{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px;position:relative;z-index:230;color:inherit;padding:0}
.burger span{position:absolute;left:9px;right:9px;height:1.5px;background:currentColor;transition:transform .35s ease, top .35s ease}
.burger span:nth-child(1){top:16px}
.burger span:nth-child(2){top:25px}
body.menu-open .burger{color:#fff}
body.menu-open .burger span:nth-child(1){top:20px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){top:20px;transform:rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;z-index:220;background:rgba(14,14,16,.97);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:flex;flex-direction:column;justify-content:center;gap:4px;padding:0 38px;
  opacity:0;visibility:hidden;transition:opacity .4s ease, visibility .4s;overflow-y:auto}
body.menu-open .mobile-menu{opacity:1;visibility:visible}
.mobile-menu a{font-family:var(--serif);font-size:1.8rem;font-weight:400;color:#fff;text-decoration:none;padding:10px 0;
  border-bottom:1px solid var(--line-dark);display:flex;align-items:baseline;gap:16px;
  opacity:0;transform:translateY(14px);transition:opacity .45s ease, transform .45s ease}
body.menu-open .mobile-menu a{opacity:1;transform:none}
.mobile-menu a:nth-child(2){transition-delay:.04s}.mobile-menu a:nth-child(3){transition-delay:.08s}
.mobile-menu a:nth-child(4){transition-delay:.12s}.mobile-menu a:nth-child(5){transition-delay:.16s}
.mobile-menu a:nth-child(6){transition-delay:.2s}.mobile-menu a:nth-child(7){transition-delay:.24s}
.mobile-menu a:nth-child(8){transition-delay:.28s}
.mobile-menu a:nth-child(9){transition-delay:.32s}
@media(max-height:700px){.mobile-menu a{font-size:1.5rem;padding:8px 0}}
.mobile-menu a .no{font-size:.8rem;font-style:italic;color:var(--rose)}
.mobile-menu a:hover{color:var(--rose)}
.mobile-menu .menu-cta{margin-top:26px;border-bottom:none;justify-content:center;
  font-family:var(--sans);font-size:.85rem;letter-spacing:.24em;text-transform:uppercase;
  background:var(--rose);color:var(--ink);padding:16px 0;text-align:center}
.mobile-menu .menu-cta:hover{background:#fff;color:var(--ink)}
body.menu-open .topbar{z-index:230;background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;color:#fff}
body.menu-open .topbar .brand img{filter:invert(1)}
body.menu-open .topbar nav a.cta{background:transparent;border-color:rgba(255,255,255,.55);color:#fff}

/* ---------- buttons ---------- */
.btn{display:inline-block;padding:16px 38px;font-size:.8rem;letter-spacing:.24em;text-transform:uppercase;
  text-decoration:none;transition:all .3s;font-weight:400;border:1px solid transparent}
.btn-rose{background:var(--rose);color:var(--ink)}
.btn-rose:hover{background:#fff}
.btn-ghost-light{border-color:rgba(255,255,255,.55);color:#fff}
.btn-ghost-light:hover{border-color:var(--rose);color:var(--rose)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:var(--rose-text)}
.btn-ghost-dark{border-color:var(--ink);color:var(--ink)}
.btn-ghost-dark:hover{background:var(--ink);color:#fff}

/* ---------- hero (home) ---------- */
/* 공지 bar 높이(--announce-h, JS가 측정)를 뺀 만큼 정확히 화면을 채움 — 하단 흰 띠 방지 */
.hero{position:relative;height:calc(100svh - var(--announce-h, 42px));display:flex;align-items:flex-end;color:#fff;overflow:hidden;background:var(--ink)}
.hero video,.hero .hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55}
/* 플레이스홀더: 비디오 로딩 동안 표시, 준비되면 2초 페이드아웃 (구 사이트 로직 이식) */
.hero .hero-placeholder{position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:.55;transition:opacity 2s ease;z-index:1}
.hero .hero-placeholder.hide{opacity:0}
.hero::after{content:'';position:absolute;inset:0;
  background:linear-gradient(to top, rgba(10,10,12,.85) 0%, rgba(10,10,12,.15) 50%, rgba(10,10,12,.35) 100%)}
.hero-inner{position:relative;z-index:2;padding:0 48px 80px;max-width:1200px}
.eyebrow{font-size:.78rem;letter-spacing:.34em;text-transform:uppercase;color:var(--rose);margin-bottom:22px;font-weight:400}
.hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.8rem,6.5vw,5.6rem);line-height:1.04;letter-spacing:.01em}
.hero h1 em{font-style:italic;color:var(--rose)}
.hero p{margin-top:24px;max-width:540px;font-size:1.05rem;color:rgba(255,255,255,.82);font-weight:300}
.hero-actions{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap}

/* ---------- page hero (subpages) ---------- */
.page-hero{background:var(--ink);color:#fff;padding:176px 48px 84px;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;inset:0;
  background:radial-gradient(90% 120% at 85% 0%, rgba(252,216,217,.14), transparent)}
/* 라이트 모드: 표·텍스트 중심 페이지용 밝은 헤더 */
.page-hero.light{background:linear-gradient(180deg,#fff 0%,var(--ivory) 100%);color:var(--ink);
  border-bottom:1px solid var(--line)}
.page-hero.light::after{background:radial-gradient(90% 130% at 85% 0%, rgba(252,216,217,.4), transparent)}
.page-hero.light h1 em{color:var(--rose-text)}
.page-hero.light p{color:var(--ink-soft)}
.page-hero.light .crumb{color:var(--rose-text)}
.page-hero.light .crumb::before{background:var(--rose-text)}

/* 이미지 배경 모드: 사진 + 베일(위쪽은 topbar 가독성용으로 더 어둡게) */
.page-hero .ph-bg{position:absolute;inset:0;background-size:cover;background-position:center 30%}
.page-hero.has-img::after{background:linear-gradient(to top,
  rgba(10,10,12,.88) 0%, rgba(10,10,12,.55) 45%, rgba(10,10,12,.42) 70%, rgba(10,10,12,.7) 100%)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.4rem,5vw,4rem);line-height:1.08}
.page-hero h1 em{font-style:italic;color:var(--rose)}
.page-hero p{margin-top:20px;max-width:520px;color:rgba(255,255,255,.6);font-size:.98rem}
.crumb{font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;color:var(--rose);margin-bottom:24px;
  display:flex;align-items:center;gap:16px}
.crumb::before{content:'';width:36px;height:1px;background:var(--rose-deep)}
.crumb a{color:inherit;text-decoration:none}
.crumb a:hover{text-decoration:underline}

/* ---------- generic ---------- */
section{padding:100px 48px}
.bg-white{background:#fff}
/* 흰 배경 위에서는 카드 호버가 흰색으로 사라지지 않게 로즈 틴트로 */
.bg-white .studio:hover{background:rgba(252,216,217,.16)}
.wrap{max-width:1200px;margin:0 auto}
.label{font-size:.75rem;letter-spacing:.34em;text-transform:uppercase;color:var(--rose-text);margin-bottom:18px;font-weight:400}
h2{font-family:var(--serif);font-weight:400;font-size:clamp(2.1rem,4vw,3.2rem);line-height:1.12;margin-bottom:24px}
h2 em{font-style:italic;color:var(--rose-text)}
.lead{font-size:1.06rem;color:var(--ink-soft);max-width:640px}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}

/* ---------- notices hybrid (A-4) ---------- */
.notices{background:#fff;border-bottom:1px solid var(--line);padding:64px 48px}
.notices .wrap{max-width:1200px;margin:0 auto}
.notices .zone-head{margin-bottom:34px;display:flex;align-items:baseline;justify-content:space-between;gap:20px;flex-wrap:wrap}
.notices .zone-head .s{font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--rose-text)}
.notices .zone-head .t{font-family:var(--serif);font-style:italic;font-size:1.8rem;font-weight:400;margin-top:4px}
.notices .all-link{font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);
  text-decoration:none;border-bottom:1px solid var(--rose-deep);padding-bottom:5px}
.notices .all-link:hover{color:var(--rose-text)}
.hybrid{display:grid;grid-template-columns:1.5fr 1fr;border:1px solid var(--line)}
.featured{position:relative;min-height:420px;overflow:hidden;background:var(--ink)}
.fcard{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  text-decoration:none;color:#fff;opacity:0;visibility:hidden;transform:scale(1.04);
  transition:opacity .7s ease, visibility .7s, transform 1.1s ease}
.fcard.active{opacity:1;visibility:visible;transform:scale(1);z-index:2}
.fcard .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.fcard .veil{position:absolute;inset:0;background:linear-gradient(to top, rgba(10,10,12,.85) 8%, rgba(10,10,12,.2) 60%, rgba(10,10,12,.05))}
.fcard.plain{color:var(--ink)}
.fcard.plain .bg{background:linear-gradient(135deg, var(--rose) 0%, #FBE4E2 55%, var(--ivory) 100%)}
.fcard.plain .veil{background:none}
.fcard .inner{position:relative;z-index:2;padding:40px 44px}
.fcard .tag{display:inline-block;font-size:.64rem;letter-spacing:.26em;text-transform:uppercase;
  padding:6px 13px;background:var(--rose);color:var(--ink);margin-bottom:16px}
.fcard.plain .tag{background:var(--ink);color:var(--rose)}
.fcard h4{font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);font-weight:500;line-height:1.12}
.fcard .when{font-size:.92rem;margin-top:8px;color:rgba(255,255,255,.75)}
.fcard.plain .when{color:var(--ink-soft)}
.fcard .go{display:inline-block;margin-top:20px;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;
  color:inherit;border-bottom:1px solid var(--rose);padding-bottom:5px}
.fcard.plain .go{border-color:var(--ink)}
.nlist{display:flex;flex-direction:column;border-left:1px solid var(--line);background:var(--ivory)}
.nrow{position:relative;flex:1;display:flex;flex-direction:column;justify-content:center;gap:4px;
  padding:24px 32px;cursor:pointer;background:none;
  appearance:none;-webkit-appearance:none;border:none;border-radius:0;border-bottom:1px solid var(--line);
  text-align:left;font-family:var(--sans);transition:background .3s;overflow:hidden}
.nrow:last-child{border-bottom:none}
.nrow:hover{background:rgba(252,216,217,.18)}
.nrow .rtag{font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--rose-text)}
.nrow .rtitle{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--ink);line-height:1.2}
.nrow .rwhen{font-size:.82rem;color:var(--gray)}
.nrow::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--rose-deep);
  transform:scaleY(0);transition:transform .35s ease}
.nrow.active{background:rgba(252,216,217,.22)}
.nrow.active::before{transform:scaleY(1)}
.nrow .prog{position:absolute;left:0;bottom:0;height:2px;width:100%;background:var(--rose);transform:scaleX(0);transform-origin:left}
.nrow.active .prog{animation:fillrow 5s linear forwards}
.notices.paused .nrow.active .prog{animation-play-state:paused}
@keyframes fillrow{to{transform:scaleX(1)}}
.nrow .rgo{position:absolute;right:26px;top:50%;transform:translateY(-50%);font-size:1.1rem;color:var(--rose-deep);
  opacity:0;transition:opacity .3s}
.nrow.active .rgo{opacity:1}

/* ---------- class cards ---------- */
.track-head{display:flex;align-items:baseline;gap:18px;margin:54px 0 8px;border-bottom:1px solid var(--line);padding-bottom:14px}
.track-head h3{font-family:var(--serif);font-weight:500;font-size:1.6rem}
.track-head .sub{color:var(--gray);font-size:.9rem}
.class-grid{display:grid;grid-template-columns:repeat(3,1fr);margin-top:22px}
.class-card{background:#fff;padding:36px 32px;text-decoration:none;color:var(--ink);
  display:flex;flex-direction:column;transition:box-shadow .3s, border-color .3s;position:relative;
  border:1px solid var(--line);margin:0 -1px -1px 0}
.class-card:hover{border-color:var(--rose-deep);box-shadow:0 14px 36px rgba(192,112,123,.14);z-index:2}

.class-card .ages{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--rose-text);margin-bottom:12px}
.class-card h4{font-family:var(--serif);font-size:1.65rem;font-weight:500;line-height:1.15}
.class-card .tagline{font-style:italic;font-family:var(--serif);color:var(--gray);margin:4px 0 12px}
.class-card p{font-size:.92rem;color:var(--gray);flex:1}
.class-card .go{margin-top:22px;font-size:.78rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  border-bottom:1px solid var(--rose-deep);padding-bottom:5px;align-self:flex-start;transition:color .2s}
.class-card:hover .go{color:var(--rose-text)}

/* ---------- class detail ---------- */
.class-layout{display:grid;grid-template-columns:1.5fr .9fr;gap:70px;align-items:start}
.prose h3{font-family:var(--serif);font-weight:500;font-size:1.5rem;margin:34px 0 12px}
.prose p{margin:14px 0;color:var(--ink-soft)}
.prose ul{margin:14px 0 14px 20px;color:var(--ink-soft)}
.prose li{margin:8px 0}
.prose a{color:var(--rose-text)}
.side-box{border:1px solid var(--line);background:#fff;padding:34px;position:sticky;top:96px}
.side-box .sb-label{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--rose-text);margin:22px 0 10px}
.side-box .sb-label:first-child{margin-top:0}
.side-box table{width:100%;border-collapse:collapse;font-size:.88rem}
.side-box td{padding:8px 0;border-bottom:1px solid var(--line);vertical-align:top;color:var(--ink-soft)}
.side-box td:first-child{font-weight:400;color:var(--ink);padding-right:14px;white-space:nowrap}
.side-box .btn{display:block;text-align:center;margin-top:26px}
.side-box .btn + .btn{margin-top:10px}
.side-box .trial-note{font-size:.8rem;color:var(--gray);margin-top:14px;text-align:center}

/* ---------- tables (schedule / tuition) ---------- */
.data-table{width:100%;border-collapse:collapse;margin-top:34px;background:#fff;border:1px solid var(--line);font-size:.94rem}
.data-table th{font-family:var(--sans);font-weight:400;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--rose-text);text-align:left;padding:16px 20px;border-bottom:1px solid var(--line);background:var(--ivory)}
.data-table td{padding:16px 20px;border-bottom:1px solid var(--line);color:var(--ink-soft);vertical-align:top}
.data-table tr:last-child td{border-bottom:none}
.data-table td.cls{font-family:var(--serif);font-size:1.15rem;font-weight:500;color:var(--ink)}
.data-table tr:hover td{background:rgba(252,216,217,.12)}
.data-table a.reg{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);
  text-decoration:none;border:1px solid var(--ink);padding:8px 16px;white-space:nowrap;transition:all .25s}
.data-table a.reg:hover{background:var(--ink);color:#fff}

/* ---------- schedule: view toggle & class matrix ---------- */
.view-toggle{display:inline-flex;border:1px solid var(--line);background:#fff;margin-bottom:38px}
.vt-btn{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:.78rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;padding:13px 26px;color:var(--gray);transition:all .25s}
.vt-btn.active{background:var(--ink);color:#fff}
.vt-btn:not(.active):hover{color:var(--ink)}
.matrix-wrap{overflow-x:auto;border:1px solid var(--line);background:#fff}
.sched-matrix{width:100%;border-collapse:collapse;font-size:.88rem;min-width:760px}
.sched-matrix thead th{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;font-weight:500;
  color:var(--rose-text);background:var(--ivory);padding:14px 12px;border-bottom:1px solid var(--line);text-align:center}
.sched-matrix thead th.corner{text-align:left;padding-left:20px}
.sched-matrix .cls-head{text-align:left;padding:14px 20px;border-bottom:1px solid var(--line);
  background:var(--ivory);min-width:150px}
.sched-matrix .cls-head a{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--ink);
  text-decoration:none;display:block;line-height:1.2}
.sched-matrix .cls-head a:hover{color:var(--rose-text)}
.sched-matrix .cls-head .ages{display:block;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gray);margin-top:3px}
.sched-matrix td{border-bottom:1px solid var(--line);border-left:1px solid var(--line);
  padding:12px 10px;text-align:center;vertical-align:middle;min-width:96px}
.sched-matrix td.has{background:rgba(252,216,217,.28)}
.sched-matrix td.has b{font-weight:500;color:var(--ink);white-space:nowrap}
.sched-matrix td.has .st{display:block;font-size:.68rem;color:var(--gray);margin-top:1px}
.sched-matrix tr:hover td.has{background:rgba(252,216,217,.5)}

/* ---------- studios ---------- */
.studio-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--line);border:1px solid var(--line);margin-top:50px}
.studio{background:var(--ivory);padding:50px 44px;transition:background .3s}
.studio:hover{background:#fff}
.studio .num{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--rose-deep)}
.studio h3{font-family:var(--serif);font-size:1.9rem;font-weight:500;margin:12px 0 8px}
.studio .addr{color:var(--ink-soft);font-size:.97rem}
.studio .note{color:var(--gray);font-size:.88rem;margin-top:8px}
.studio .map{margin-top:22px;aspect-ratio:16/9;border:1px solid var(--line);overflow:hidden;border-radius:4px}
.studio .map iframe{width:100%;height:100%;border:0;display:block;filter:saturate(.9)}
.studio .links{margin-top:22px;display:flex;gap:22px;flex-wrap:wrap}
.studio .links a{font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink);
  text-decoration:none;border-bottom:1px solid var(--rose-deep);padding-bottom:5px}
.studio .links a:hover{color:var(--rose-text)}

/* ---------- dark section ---------- */
.dark-section{background:var(--ink);color:#fff}
.dark-section .label{color:var(--rose)}
.dark-section .lead{color:rgba(255,255,255,.8)}
.dark-section h2 em{color:var(--rose)}

/* ---------- quote band ---------- */
.quote-band{display:grid;grid-template-columns:280px 1fr;gap:60px;align-items:center;max-width:1040px;margin:0 auto}
.quote-band .photo{width:100%;aspect-ratio:3/4;border-radius:4px;background-size:cover;background-position:center;
  box-shadow:0 18px 44px rgba(18,18,20,.16)}
.quote-band blockquote{font-family:var(--serif);font-size:clamp(1.3rem,2.2vw,1.8rem);font-weight:400;font-style:italic;line-height:1.5}
.quote-band cite{display:block;margin-top:22px;font-style:normal;font-size:.8rem;letter-spacing:.26em;text-transform:uppercase;color:var(--rose-text)}
/* 홈용 슬림 버전 */
.quote-band.compact{grid-template-columns:230px 1fr;gap:52px;max-width:1000px}
.quote-band.compact .photo{border-radius:4px}
.quote-band.compact blockquote{font-size:clamp(1.2rem,1.9vw,1.55rem);line-height:1.5}
.quote-band.compact cite{margin-top:14px;font-size:.74rem}
.quote-band.compact .q-link{display:inline-block;margin-top:16px;font-size:.78rem;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--rose-deep);padding-bottom:4px}
.quote-band.compact .q-link:hover{color:var(--rose-text)}
@media(max-width:760px){.quote-band.compact{grid-template-columns:1fr}.quote-band.compact .photo{max-width:150px}}

/* ---------- faculty ---------- */
.faculty-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px 60px;margin-top:54px}
.fac h3{font-family:var(--serif);font-size:1.6rem;font-weight:500}
.fac .role{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--rose-text);margin:6px 0 12px}
.fac p{font-size:.94rem;color:var(--ink-soft)}
.fac.has-photo{display:grid;grid-template-columns:170px 1fr;gap:26px;align-items:start}
.fac.has-photo .photo{width:100%;aspect-ratio:3/4;border-radius:4px;background-size:cover;background-position:center top;
  box-shadow:0 12px 30px rgba(18,18,20,.14)}
.fac.lead-fac{grid-column:1/-1;display:grid;grid-template-columns:240px 1fr;gap:44px;align-items:center}
.fac.lead-fac .photo{width:100%;aspect-ratio:3/4;border-radius:4px;background-size:cover;background-position:center;
  box-shadow:0 18px 44px rgba(18,18,20,.16)}

/* ---------- home track tiles (programs 요약) ---------- */
.track-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:18px;margin-top:46px}
.track-tile{background:#fff;border:1px solid var(--line);padding:30px 26px;text-decoration:none;color:var(--ink);
  display:flex;flex-direction:column;gap:8px;transition:border-color .3s, box-shadow .3s}
.track-tile:hover{border-color:var(--rose-deep);box-shadow:0 12px 30px rgba(192,112,123,.12)}
.track-tile h3{font-family:var(--serif);font-size:1.35rem;font-weight:500;line-height:1.2}
.track-tile p{font-size:.85rem;color:var(--gray);flex:1}
.track-tile .cnt{font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--rose-text)}

/* ---------- journey paths (intent picker) ---------- */
.paths{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.path-card{border:1px solid var(--line);background:#fff;padding:38px 34px;display:flex;flex-direction:column;
  transition:border-color .3s, box-shadow .3s;position:relative}
.path-card::before{content:'';position:absolute;left:0;top:0;right:0;height:3px;background:var(--rose);
  transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.path-card:hover{border-color:var(--rose-deep);box-shadow:0 14px 36px rgba(192,112,123,.12)}
.path-card:hover::before{transform:scaleX(1)}
.path-card .who{font-size:.72rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--rose-text);margin-bottom:14px}
.path-card h3{font-family:var(--serif);font-size:1.7rem;font-weight:500;line-height:1.15}
.path-card .meta{font-size:.85rem;color:var(--gray);margin:6px 0 14px}
.path-card p{font-size:.93rem;color:var(--ink-soft);flex:1}
.path-card .btn{display:block;text-align:center;margin-top:24px;padding:14px 20px}
.path-card .alt{display:block;text-align:center;margin-top:14px;font-size:.82rem;color:var(--ink);
  text-decoration:none;border-bottom:none}
.path-card .alt span{border-bottom:1px solid var(--rose-deep);padding-bottom:3px;transition:color .2s}
.path-card .alt:hover span{color:var(--rose-text)}
@media(max-width:1000px){.paths{grid-template-columns:1fr}}

/* ---------- youtube videos ---------- */
.video-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:50px}
.vcard{display:flex;flex-direction:column;gap:10px;text-decoration:none;color:var(--ink)}
.vcard .thumb{position:relative;aspect-ratio:16/9;background-size:cover;background-position:center;
  border-radius:4px;overflow:hidden;display:grid;place-items:center}
.vcard .thumb::after{content:'';position:absolute;inset:0;background:rgba(18,18,20,.18);transition:background .3s}
.vcard:hover .thumb::after{background:rgba(18,18,20,0)}
.vcard .play{position:relative;z-index:2;width:48px;height:48px;border-radius:50%;background:rgba(253,251,244,.92);
  color:var(--rose-text);display:grid;place-items:center;font-size:.8rem;padding-left:4px;
  transition:transform .3s, background .3s}
.vcard:hover .play{transform:scale(1.12);background:var(--rose)}
.vcard .vtitle{font-family:var(--serif);font-size:1.08rem;font-weight:500;line-height:1.3}
.vcard .vdate{font-size:.78rem;letter-spacing:.08em;color:var(--gray)}
@media(max-width:1000px){.video-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.video-grid{grid-template-columns:1fr}}

/* ---------- news / awards lists ---------- */
.news-list{margin-top:44px;border-top:1px solid var(--line)}
.news-item{display:grid;grid-template-columns:130px 150px 1fr auto;gap:24px;align-items:baseline;
  padding:28px 0;border-bottom:1px solid var(--line)}
.news-item .date{font-size:.82rem;color:var(--gray)}
.news-item .tag{font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;background:var(--rose);color:var(--ink);
  padding:5px 12px;justify-self:start;white-space:nowrap}
.news-item h3{font-family:var(--serif);font-size:1.4rem;font-weight:500;line-height:1.25}
.news-item p{font-size:.92rem;color:var(--gray);margin-top:6px}
.news-item .go{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);text-decoration:none;
  border-bottom:1px solid var(--rose-deep);padding-bottom:4px;white-space:nowrap}
.news-item .go:hover{color:var(--rose-text)}
.award-year{margin-top:50px}
.award-year .yr{font-family:var(--serif);font-style:italic;font-size:2.2rem;color:var(--rose-deep)}
.award-year h3{font-family:var(--serif);font-size:1.5rem;font-weight:500;margin:6px 0 16px}
.award-year ul{list-style:none}
.award-year li{padding:14px 0;border-bottom:1px solid var(--line);display:grid;grid-template-columns:220px 1fr;gap:20px}
.award-year li b{font-weight:500}
.award-year li span{color:var(--ink-soft);font-size:.95rem}

/* ---------- FAQ ---------- */
.faq-list{margin-top:40px;border-top:1px solid var(--line)}
.faq-list details{border-bottom:1px solid var(--line)}
.faq-list summary{cursor:pointer;padding:22px 0;font-family:var(--serif);font-size:1.25rem;font-weight:500;list-style:none;position:relative;padding-right:40px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:'+';position:absolute;right:6px;top:50%;transform:translateY(-50%);
  color:var(--rose-deep);font-size:1.5rem;font-weight:300;transition:transform .25s}
.faq-list details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq-list .a{padding:0 0 24px;color:var(--ink-soft);font-size:.96rem;max-width:760px}

/* ---------- steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line);border:1px solid var(--line);margin-top:50px}
.step{background:#fff;padding:40px 34px}
.step .n{font-family:var(--serif);font-style:italic;font-size:2.2rem;color:var(--rose-deep)}
.step h3{font-family:var(--serif);font-size:1.45rem;font-weight:500;margin:10px 0 8px}
.step p{font-size:.92rem;color:var(--gray)}

/* ---------- button rows ---------- */
.btn-row{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap}
@media(max-width:760px){
  .btn-row{flex-direction:column}
  .btn-row .btn{width:100%;max-width:340px;text-align:center}
}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(135deg, var(--rose) 0%, #FBE4E2 60%, var(--ivory) 100%);text-align:center;padding:110px 48px}
.cta-band .label{color:var(--ink)}
.cta-band p{color:var(--ink-soft);margin-bottom:38px}

/* ---------- footer ---------- */
footer{background:var(--ink);color:rgba(255,255,255,.65);padding:70px 48px 40px;font-size:.88rem}
footer .cols{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:44px}
footer h5{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--rose);font-weight:400;margin-bottom:16px}
footer a{color:rgba(255,255,255,.65);text-decoration:none}
footer a:hover{color:#fff}
footer li{list-style:none;margin:8px 0}
footer .fbrand img{height:44px;filter:invert(1);margin-bottom:16px}
footer .fbrand p{font-size:.85rem;max-width:280px;color:rgba(255,255,255,.5)}
footer .social-row{display:flex;gap:12px;margin-top:4px}
footer .social-row a{width:38px;height:38px;border:1px solid var(--line-dark);border-radius:50%;
  display:grid;place-items:center;color:rgba(255,255,255,.65);transition:color .25s, border-color .25s}
footer .social-row a:hover{color:var(--rose);border-color:var(--rose)}
footer .social-row svg{width:16px;height:16px;fill:currentColor}
footer .art-note{margin-top:24px;font-size:.78rem;color:rgba(255,255,255,.4)}
footer .art-note .art-links a{color:rgba(255,255,255,.55);border-bottom:1px solid rgba(255,255,255,.25);padding-bottom:1px}
footer .art-note .art-links a:hover{color:var(--rose);border-color:var(--rose)}
footer .legal{max-width:1200px;margin:50px auto 0;padding-top:24px;border-top:1px solid var(--line-dark);
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.78rem;color:rgba(255,255,255,.4)}
footer .legal a{color:inherit}

/* ---------- mobile sticky CTA ---------- */
.sticky-cta{display:none;position:fixed;left:0;right:0;bottom:0;z-index:90;
  grid-template-columns:1fr 1px 1fr;align-items:stretch;
  background:rgba(18,18,20,.78);backdrop-filter:blur(20px) saturate(1.5);-webkit-backdrop-filter:blur(20px) saturate(1.5);
  padding-bottom:env(safe-area-inset-bottom)}
.sticky-cta::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--line-dark)}
.sticky-cta a{padding:17px 0;text-align:center;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  text-decoration:none;transition:background .25s}
.sticky-cta .div{background:var(--line-dark)}
.sticky-cta .t{color:var(--rose)}
.sticky-cta .t:active{background:rgba(252,216,217,.12)}
.sticky-cta .r{color:#fff}
.sticky-cta .r:active{background:rgba(255,255,255,.08)}

/* ---------- class finder wizard ---------- */
.fab{position:fixed;right:26px;bottom:26px;z-index:180;
  display:flex;align-items:center;gap:10px;
  background:var(--ink);color:var(--rose);border:none;cursor:pointer;
  font-family:var(--sans);font-size:.8rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  padding:16px 26px;border-radius:999px;box-shadow:0 12px 34px rgba(18,18,20,.32);
  opacity:0;visibility:hidden;transform:translateY(14px);
  transition:opacity .45s ease, transform .45s ease, visibility .45s, background .25s}
.fab .spark{color:var(--rose);font-size:.9rem;display:inline-block;animation:sparkle 2.6s ease-in-out infinite}
@keyframes sparkle{
  0%,100%{transform:rotate(0deg) scale(1);text-shadow:0 0 3px rgba(252,216,217,.35)}
  50%{transform:rotate(180deg) scale(1.3);text-shadow:0 0 10px rgba(252,216,217,.95),0 0 22px rgba(252,216,217,.55)}
}
@media(prefers-reduced-motion:reduce){.fab .spark{animation:none}}
.fab.show{opacity:1;visibility:visible;transform:none}
.fab:hover{background:#000;box-shadow:0 16px 40px rgba(18,18,20,.4)}
.wiz-overlay{position:fixed;inset:0;z-index:300;background:rgba(14,14,16,.6);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  display:grid;place-items:center;padding:20px;
  opacity:0;visibility:hidden;transition:opacity .3s ease, visibility .3s}
.wiz-overlay.open{opacity:1;visibility:visible}
.wiz-modal{position:relative;width:min(520px,100%);max-height:86svh;overflow-y:auto;
  background:var(--ivory);border-top:3px solid var(--rose);padding:44px 42px 40px;
  transform:translateY(14px);transition:transform .3s ease;box-shadow:0 30px 80px rgba(0,0,0,.35)}
.wiz-overlay.open .wiz-modal{transform:none}
.wiz-close{position:absolute;top:14px;right:14px;background:none;border:none;cursor:pointer;
  font-size:1rem;color:var(--gray);padding:8px}
.wiz-close:hover{color:var(--ink)}
.wiz-label{font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--rose-text);margin-bottom:14px}
.wiz-q{font-family:var(--serif);font-size:1.7rem;font-weight:500;line-height:1.2;margin-bottom:24px}
.wiz-opt{display:block;width:100%;text-align:left;background:#fff;border:1px solid var(--line);
  font-family:var(--sans);font-size:.95rem;color:var(--ink);cursor:pointer;
  padding:16px 20px;margin-bottom:10px;transition:border-color .25s, box-shadow .25s}
.wiz-opt:hover{border-color:var(--rose-deep);box-shadow:0 8px 22px rgba(192,112,123,.12)}
.wiz-opt .hint{display:block;font-size:.8rem;color:var(--gray);margin-top:2px}
.wiz-back{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:.76rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gray);padding:0;margin-top:14px}
.wiz-back:hover{color:var(--ink)}
.wiz-result .rec-ages{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--rose-text)}
.wiz-result h3{font-family:var(--serif);font-size:2rem;font-weight:500;margin:8px 0 2px}
.wiz-result .rec-tag{font-family:var(--serif);font-style:italic;color:var(--gray);margin-bottom:14px}
.wiz-result p{font-size:.95rem;color:var(--ink-soft);margin-bottom:24px}
.wiz-result .btn{display:block;text-align:center;margin-bottom:10px;padding:15px 20px}
.wiz-result .wiz-trial{display:block;text-align:center;font-size:.84rem;color:var(--ink);text-decoration:none;margin-top:14px}
.wiz-result .wiz-trial span{border-bottom:1px solid var(--rose-deep);padding-bottom:3px}
.wiz-result .wiz-trial:hover span{color:var(--rose-text)}
@media(max-width:760px){
  .fab{right:16px;bottom:calc(66px + env(safe-area-inset-bottom) + 12px);padding:14px 22px;font-size:.74rem}
  .wiz-modal{padding:36px 26px 32px}
}

/* ---------- responsive ---------- */
/* 중간 폭: 텍스트 메뉴가 다 안 들어가는 구간 — 링크는 햄버거로, CTA만 남김 */
@media(max-width:1300px){
  .topbar{padding:0 28px}
  .topbar nav{gap:20px}
}
@media(max-width:1000px){
  .class-grid{grid-template-columns:1fr 1fr}
  .class-layout{grid-template-columns:1fr;gap:40px}
  .side-box{position:static}
  footer .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .announce-bar{padding:0 34px 0 0;font-size:.72rem;gap:2px}
  .announce-bar .dot{display:none}
  .announce-bar .ab-item{gap:8px;padding:0 2px}
  .announce-bar .ab-nav{padding:4px 6px;font-size:1rem}
  .announce-bar .close{right:4px;padding:4px 6px}
  .topbar{padding:0 20px}
  .topbar nav{display:none}
  .burger{display:block}
  section{padding:72px 20px}
  .hero-inner{padding:0 20px 64px}
  .page-hero{padding:120px 20px 56px}
  .notices{padding:48px 20px}
  .hybrid{grid-template-columns:1fr}
  .featured{min-height:0;height:min(64vw,380px)}
  .fcard .inner{padding:24px 22px}
  .fcard h4{font-size:1.5rem}
  .nlist{border-left:none;border-top:1px solid var(--line)}
  .nrow{padding:13px 40px 13px 18px;gap:2px}
  .nrow .rtitle{font-size:1.05rem}
  .nrow .rwhen{font-size:.74rem}
  .nrow .rgo{right:18px}
  .class-grid{grid-template-columns:1fr}
  .studio-grid{grid-template-columns:1fr}
  .quote-band{grid-template-columns:1fr;gap:30px}
  .quote-band .photo{max-width:220px}
  .faculty-grid{grid-template-columns:1fr}
  .fac.lead-fac{grid-template-columns:1fr}
  .fac.lead-fac .photo{max-width:220px}
  .steps{grid-template-columns:1fr}
  .news-item{grid-template-columns:1fr;gap:8px}
  .award-year li{grid-template-columns:1fr}
  .data-table{display:block;overflow-x:auto}
  footer .cols{grid-template-columns:1fr}
  footer{padding-bottom:120px}
  .sticky-cta{display:grid}
  body{padding-bottom:0}
}
