/* ════════════════════════════════════════════════════════
   PIVOT410 외대점 · 정규·취미 클래스 · styles.css
   톤: 편집/매거진 — 크림 베이스 + 굵은 검정 + 빨강 포인트
   구조: 큰 숫자 인덱스 + 비대칭 레이아웃 (세로 스크롤, 모바일 안전)
   커서: 자석 효과 (PC 전용)
   ════════════════════════════════════════════════════════ */
:root {
  --cream:#F5F2EA; --cream-2:#EAE5D8; --paper:#FFFFFF; --ink:#16131E; --ink-2:#2C2738;
  --red:#E23B3B; --red-deep:#C42A2A; --gold:#E0A93B;
  --text:#16131E; --text-sub:rgba(22,19,30,0.6); --text-dim:rgba(22,19,30,0.36);
  --line:#16131E; --line-soft:rgba(22,19,30,0.13);
  --font-sans:'Pretendard Variable','Pretendard',-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',monospace; --font-display:'Archivo','Inter',var(--font-sans);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;}
body{background:var(--cream);color:var(--text);font-family:var(--font-sans);font-weight:400;letter-spacing:-0.01em;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
@media (hover:hover) and (pointer:fine){.cursor-on,.cursor-on *{cursor:none !important;}}

/* 자석 커서 (PC) */
.mag-cursor{position:fixed;top:0;left:0;width:14px;height:14px;border-radius:50%;background:var(--red);pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s,border-radius .2s;mix-blend-mode:normal;}
.mag-ring{position:fixed;top:0;left:0;width:42px;height:42px;border:2px solid var(--ink);border-radius:50%;pointer-events:none;z-index:99998;transform:translate(-50%,-50%);transition:width .25s cubic-bezier(.16,1,.3,1),height .25s cubic-bezier(.16,1,.3,1),border-color .2s,opacity .2s;}
.mag-cursor.hot{width:8px;height:8px;background:var(--ink);}
.mag-ring.hot{width:64px;height:64px;border-color:var(--red);}

/* 헤더 */
.site-header{position:sticky;top:0;z-index:100;background:rgba(245,242,234,0.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:2px solid transparent;transition:border-color .25s;}
.site-header.scrolled{border-bottom-color:var(--ink);}
.header-inner{max-width:1240px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand-logo{height:34px;filter:brightness(0);}
.brand-text{display:flex;flex-direction:column;gap:1px;line-height:1.05;}
.brand-ko{font-size:15px;font-weight:800;letter-spacing:-0.02em;}
.brand-branch{font-size:10.5px;font-weight:700;letter-spacing:0.08em;font-family:var(--font-mono);color:var(--text-sub);}
.header-cta{display:inline-flex;align-items:center;gap:6px;background:var(--ink);color:var(--cream);padding:10px 18px;font-size:13px;font-weight:800;transition:background .18s;}
.header-cta:hover{background:var(--red);}

/* 공통 컨테이너 */
.container{max-width:1240px;margin:0 auto;padding:0 28px;}

/* ═══ 매거진 섹션 공통 ═══ */
.mag{position:relative;border-top:2px solid var(--ink);}
.mag-inner{max-width:1240px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:160px 1fr;gap:40px;}
@media(max-width:820px){.mag-inner{grid-template-columns:1fr;gap:0;}}
/* 왼쪽: 큰 숫자 + 라벨 (스티키) */
.mag-index{padding:64px 0;position:sticky;top:64px;align-self:start;}
@media(max-width:820px){.mag-index{position:static;padding:48px 0 0;display:flex;align-items:baseline;gap:16px;}}
.mag-num{font-family:var(--font-display);font-size:clamp(64px,9vw,128px);font-weight:900;line-height:0.8;letter-spacing:-0.05em;color:var(--ink);}
.mag-num .slash{color:var(--red);}
.mag-eyebrow{font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:0.16em;color:var(--text-sub);margin-top:14px;text-transform:uppercase;}
@media(max-width:820px){.mag-num{font-size:60px;}.mag-eyebrow{margin-top:0;}}
/* 오른쪽: 콘텐츠 */
.mag-body{padding:64px 0;min-width:0;}
@media(max-width:820px){.mag-body{padding:24px 0 56px;}}
.mag-title{font-size:clamp(28px,4.2vw,52px);font-weight:900;letter-spacing:-0.04em;line-height:1.05;margin-bottom:18px;}
.mag-lead{font-size:17px;font-weight:500;color:var(--text-sub);line-height:1.7;max-width:52ch;margin-bottom:8px;}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.reveal.in{opacity:1;transform:translateY(0);}
.hl{background:var(--red);color:#fff;padding:0 7px;font-weight:900;}
.hl-ink{background:var(--ink);color:var(--cream);padding:0 7px;font-weight:900;}

/* ─ HERO (매거진 표지) ─ */
.hero{position:relative;padding:60px 0 64px;overflow:hidden;border-bottom:2px solid var(--ink);}
.hero-inner{max-width:1240px;margin:0 auto;padding:0 28px;}
.hero-meta{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:0.1em;color:var(--text-sub);padding-bottom:24px;border-bottom:1px solid var(--line-soft);margin-bottom:40px;text-transform:uppercase;}
.hero-meta .red{color:var(--red);}
.hero-headline{font-size:clamp(48px,9.5vw,128px);font-weight:900;letter-spacing:-0.055em;line-height:0.92;margin-bottom:32px;}
.hero-headline .l{display:block;overflow:hidden;}
.hero-headline .w{display:inline-block;transform:translateY(110%);transition:transform .85s cubic-bezier(.16,1,.3,1);}
.hero-headline .w.in{transform:translateY(0);}
.hero-headline .boxed{background:var(--red);color:#fff;padding:0 16px;}
.hero-foot{display:grid;grid-template-columns:1fr auto;gap:32px;align-items:end;}
@media(max-width:680px){.hero-foot{grid-template-columns:1fr;gap:24px;}}
.hero-sub{font-size:clamp(16px,2vw,20px);font-weight:600;line-height:1.6;max-width:40ch;opacity:0;transform:translateY(20px);transition:opacity .6s .5s,transform .6s .5s;}
.hero-sub.in{opacity:1;transform:translateY(0);}
.hero-levels{display:flex;flex-wrap:wrap;gap:7px;margin-top:18px;}
.level-tag{border:1.5px solid var(--ink);padding:6px 13px;font-size:13px;font-weight:800;background:var(--paper);}
.level-tag.on{background:var(--ink);color:var(--cream);}
.hero-cta-col{display:flex;flex-direction:column;gap:10px;opacity:0;transform:translateY(20px);transition:opacity .6s .7s,transform .6s .7s;}
.hero-cta-col.in{opacity:1;transform:translateY(0);}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-size:15px;font-weight:800;padding:15px 26px;border:2px solid var(--ink);transition:transform .16s,box-shadow .16s,background .16s;white-space:nowrap;}
.btn-primary{background:var(--red);color:#fff;box-shadow:4px 4px 0 var(--ink);}
.btn-primary:hover{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink);background:var(--red-deep);}
.btn-ghost{background:var(--paper);box-shadow:4px 4px 0 var(--ink);}
.btn-ghost:hover{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink);}
/* 흐르는 띠 */
.hero-marquee{margin-top:48px;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);padding:13px 0;overflow:hidden;white-space:nowrap;}
.hero-marquee-track{display:inline-block;animation:marquee 26s linear infinite;font-family:var(--font-display);font-size:21px;font-weight:900;letter-spacing:0.02em;text-transform:uppercase;}
.hero-marquee-track span{margin:0 11px;}
.hero-marquee-track .dim{color:var(--red);}
@keyframes marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ─ WHY (춤의 좋은 점) — 큰 리스트형 ─ */
.mag-why{background:var(--ink);color:var(--cream);}
.mag-why .mag-num,.mag-why .mag-title{color:var(--cream);}
.mag-why .mag-eyebrow{color:var(--gold);}
.mag-why .mag-lead{color:rgba(245,242,234,0.6);}
.why-list{margin-top:36px;border-top:1px solid rgba(245,242,234,0.2);}
.why-item{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:28px 0;border-bottom:1px solid rgba(245,242,234,0.2);align-items:start;transition:padding-left .25s;}
.why-item:hover{padding-left:12px;}
.why-k{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--red);padding-top:6px;}
.why-c h3{font-size:clamp(22px,3vw,32px);font-weight:900;letter-spacing:-0.03em;margin-bottom:8px;color:var(--cream);}
.why-c p{font-size:15px;line-height:1.65;color:rgba(245,242,234,0.62);max-width:46ch;}
.why-c .tag{display:inline-block;margin-top:10px;font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--gold);border:1px solid var(--gold);padding:3px 9px;letter-spacing:0.04em;}

/* ─ GENRE — 비대칭 리스트 ─ */
.genre-list{margin-top:32px;}
.genre-row{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;padding:22px 0;border-bottom:2px solid var(--ink);transition:background .2s,padding .2s;cursor:default;}
.genre-row:first-child{border-top:2px solid var(--ink);}
.genre-row:hover{background:var(--ink);color:var(--cream);padding-left:16px;padding-right:16px;}
.genre-row:hover .gr-en,.genre-row:hover .gr-desc{color:rgba(245,242,234,0.7);}
.genre-row:hover .gr-name{color:var(--cream);}
.gr-name{font-size:clamp(26px,4vw,40px);font-weight:900;letter-spacing:-0.035em;line-height:1;min-width:0;}
.gr-en{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text-dim);letter-spacing:0.05em;white-space:nowrap;}
.gr-desc{font-size:14px;font-weight:500;color:var(--text-sub);line-height:1.5;max-width:30ch;text-align:right;}
@media(max-width:680px){.genre-row{grid-template-columns:1fr auto;gap:8px 16px;}.gr-desc{grid-column:1/3;text-align:left;max-width:none;}}

/* ─ TRAINER ─ */
.mag-trainer{background:var(--cream-2);}
.trainer-lead{font-size:clamp(22px,3.2vw,34px);font-weight:900;letter-spacing:-0.035em;line-height:1.2;margin-bottom:20px;}
.trainer-lead .red{color:var(--red);}
.trainer-text p{font-size:16px;font-weight:500;color:var(--text-sub);line-height:1.75;margin-bottom:14px;max-width:54ch;}
.trainer-points{list-style:none;margin-top:24px;display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--ink);}
@media(max-width:680px){.trainer-points{grid-template-columns:1fr;}}
.trainer-points li{padding:22px 20px;border-right:2px solid var(--ink);font-size:14px;font-weight:700;line-height:1.45;}
.trainer-points li:last-child{border-right:none;}
@media(max-width:680px){.trainer-points li{border-right:none;border-bottom:2px solid var(--ink);}.trainer-points li:last-child{border-bottom:none;}}
.trainer-points li .pk{display:block;font-family:var(--font-mono);font-size:12px;color:var(--red);margin-bottom:8px;}

/* ─ SCHEDULE ─ */
.sched-legend{display:flex;flex-wrap:wrap;gap:14px;margin:24px 0 18px;}
.sched-legend .li{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;}
.sched-legend .dot{width:11px;height:11px;border:1.5px solid var(--ink);}
.sched-wrap{overflow-x:auto;border:2px solid var(--ink);background:var(--paper);}
.sched-table{width:100%;min-width:600px;border-collapse:collapse;}
.sched-table th{background:var(--ink);color:var(--cream);font-family:var(--font-mono);font-size:13px;font-weight:700;padding:13px 8px;}
.sched-table th.tcol{width:58px;}
.sched-table td{border:1px solid var(--line-soft);padding:4px;height:50px;text-align:center;vertical-align:middle;}
.sched-table td.tcell{background:var(--cream-2);font-family:var(--font-mono);font-size:12px;font-weight:700;}
.cls{padding:6px 4px;font-size:11px;font-weight:800;line-height:1.2;border:1.5px solid var(--ink);}
.cls .ct{font-size:9px;font-weight:600;font-family:var(--font-mono);opacity:.7;}
.cls.kpop{background:#FFD23D;}.cls.street{background:#7BE0B0;}.cls.choreo{background:#C9B0FF;}.cls.etc{background:#FFB0C8;}
.sched-note{margin-top:14px;font-size:13.5px;font-weight:500;color:var(--text-sub);line-height:1.7;}

/* ─ PRICING ─ */
.mag-pricing{background:var(--ink);color:var(--cream);}
.mag-pricing .mag-num,.mag-pricing .mag-title{color:var(--cream);}
.mag-pricing .mag-eyebrow{color:var(--gold);}
.mag-pricing .mag-lead{color:rgba(245,242,234,0.6);}
.price-list{margin-top:30px;}
.price-block{border-top:1px solid rgba(245,242,234,0.22);padding:24px 0;}
.price-block:last-of-type{border-bottom:1px solid rgba(245,242,234,0.22);}
.price-block-head{display:flex;align-items:baseline;gap:14px;margin-bottom:14px;}
.price-block-head .pc{font-size:20px;font-weight:900;letter-spacing:-0.02em;color:var(--cream);}
.price-block-head .pf{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--gold);letter-spacing:0.04em;}
.price-row{display:flex;justify-content:space-between;align-items:baseline;padding:8px 0;}
.price-row .ko{font-size:15px;font-weight:700;color:rgba(245,242,234,0.92);}
.price-row .ko .en{font-family:var(--font-mono);font-size:10.5px;color:rgba(245,242,234,0.4);margin-left:8px;}
.price-row .val{font-family:var(--font-display);font-size:18px;font-weight:900;letter-spacing:-0.02em;white-space:nowrap;}
.price-row.feat .val{color:var(--red);}
.price-row.feat .ko{color:#fff;}
.price-note{margin-top:22px;font-size:13.5px;font-weight:500;color:rgba(245,242,234,0.6);line-height:1.7;}

/* ─ CONTACT ─ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-top:30px;align-items:start;}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr;gap:24px;}}
.contact-info h3{font-size:clamp(24px,3.2vw,38px);font-weight:900;letter-spacing:-0.035em;line-height:1.12;margin-bottom:18px;}
.contact-detail{font-size:16px;font-weight:600;line-height:1.7;margin-bottom:6px;}
.contact-sub{font-size:14px;color:var(--text-sub);font-weight:500;line-height:1.6;margin-bottom:16px;}
.contact-phone{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--red);}
.contact-cta-stack{display:flex;flex-direction:column;gap:12px;}
.kakao-big{background:var(--red);color:#fff;border:2px solid var(--ink);box-shadow:5px 5px 0 var(--ink);padding:28px 26px;transition:transform .16s,box-shadow .16s;}
.kakao-big:hover{transform:translate(3px,3px);box-shadow:2px 2px 0 var(--ink);}
.kakao-big .kt{font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:0.1em;margin-bottom:8px;}
.kakao-big .km{font-size:25px;font-weight:900;letter-spacing:-0.03em;line-height:1.15;}
.kakao-big .ks{font-size:13.5px;font-weight:500;margin-top:8px;opacity:0.88;}
.map-link{display:block;position:relative;border:2px solid var(--ink);box-shadow:5px 5px 0 var(--ink);overflow:hidden;transition:transform .16s,box-shadow .16s;}
.map-link:hover{transform:translate(3px,3px);box-shadow:2px 2px 0 var(--ink);}
.map-link img{width:100%;height:190px;object-fit:cover;}
.map-cta{position:absolute;bottom:0;left:0;right:0;background:var(--ink);color:var(--cream);padding:12px 18px;font-size:14px;font-weight:800;display:flex;justify-content:space-between;}
.space-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:40px;}
@media(max-width:620px){.space-strip{grid-template-columns:repeat(2,1fr);}}
.space-strip figure{position:relative;border:2px solid var(--ink);overflow:hidden;}
.space-strip img{width:100%;height:140px;object-fit:cover;}
.space-strip figcaption{position:absolute;bottom:6px;left:6px;background:var(--ink);color:var(--cream);font-family:var(--font-mono);font-size:10px;font-weight:700;padding:3px 8px;}

/* 푸터 */
.site-footer{background:var(--ink);color:var(--cream);padding:48px 0 28px;border-top:2px solid var(--red);}
.footer-top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-bottom:32px;}
.footer-logo{height:30px;margin-bottom:12px;}
.footer-brand{font-size:13px;font-weight:800;color:var(--gold);margin-bottom:5px;}
.footer-addr{font-family:var(--font-mono);font-size:12px;color:rgba(245,242,234,0.55);}
.footer-links{display:flex;flex-direction:column;gap:8px;text-align:right;}
.footer-links a{font-family:var(--font-mono);font-size:13px;font-weight:700;}
.footer-links a:hover{color:var(--red);}
.footer-divider{height:1px;background:rgba(245,242,234,0.18);margin-bottom:18px;}
.footer-bottom{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:11px;color:rgba(245,242,234,0.4);}

/* 플로팅 */
.floating-cta{position:fixed;bottom:24px;right:24px;z-index:99;display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;padding:15px 24px;font-size:15px;font-weight:800;border:2px solid var(--ink);box-shadow:5px 5px 0 var(--ink);opacity:0;pointer-events:none;transform:translateY(16px);transition:opacity .3s,transform .3s,background .16s;}
.floating-cta.show{opacity:1;pointer-events:auto;transform:translateY(0);}
.floating-cta:hover{background:var(--red-deep);}
@media(max-width:540px){.floating-cta{bottom:16px;right:16px;padding:13px 18px;font-size:13px;}}

@media(max-width:600px){.hero{padding:36px 0 0;}.container,.hero-inner,.header-inner{padding-left:18px;padding-right:18px;}.mag-inner{padding-left:18px;padding-right:18px;}}
@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms !important;transition-duration:.01ms !important;}}
