/*
Theme Name: Z1 Entertainment - RIA
Theme URI: https://z1ent.com
Description: RIA 아티스트 전용 테마
Author: Z1 Entertainment
Version: 1.0.0
Text Domain: z1ent-ria
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* ═══════════════════════════════════════════════════════
   ARTIST TEMPLATE — DESIGN TOKENS
   아티스트별로 --accent, --accent2, --accent-dim 만 교체
   ═══════════════════════════════════════════════════════ */
:root{
  --bg:#08080A;--bg2:#0F0F12;--bg3:#161619;--bg4:#1E1E22;
  --text:#EFEFEF;--dim:#8A8A95;--muted:#55555F;
  /* ▼ 아티스트별 교체 ▼ */
  --accent:#2E6BDB;--accent2:#1D56B8;--accent-dim:rgba(46,107,219,0.12);
  /* ▲ ▲ ▲ */
  --border:#1F1F24;--border2:#2A2A30;
  --kr:'Noto Sans KR',sans-serif;--display:'Bebas Neue',sans-serif;--en:'Outfit',sans-serif;
  --head-h:70px;--max:1180px;--ease:cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
body{font-family:var(--kr);background:var(--bg);color:var(--text);line-height:1.75;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}
::selection{background:var(--accent);color:#fff}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* ═══════════ HEADER ═══════════ */
header{position:fixed;top:0;left:0;right:0;z-index:900;height:var(--head-h);display:flex;align-items:center;justify-content:space-between;padding:0 44px;background:rgba(8,8,10,0.85);backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,0.03);transition:.4s var(--ease)}
header.scrolled{background:rgba(8,8,10,0.96);border-bottom-color:var(--border)}
.artist-logo{font-family:var(--en);font-size:26px;font-weight:700;letter-spacing:2px;cursor:pointer;transition:.3s var(--ease);user-select:none}
.artist-logo:hover{color:var(--accent)}
nav{display:flex;gap:28px}
nav a{font-family:var(--en);font-size:12px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--muted);transition:.3s var(--ease);position:relative}
nav a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--accent);transition:.3s var(--ease)}
nav a:hover,nav a.on{color:var(--text)}
nav a:hover::after,nav a.on::after{width:100%}
.burger{display:none;flex-direction:column;gap:5px;padding:10px;z-index:1001}
.burger s{display:block;width:22px;height:1.5px;background:var(--text);text-decoration:none;transition:.3s var(--ease)}
.burger.open s:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.burger.open s:nth-child(2){opacity:0}
.burger.open s:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}
.mob-nav{display:none;position:fixed;inset:0;z-index:998;background:rgba(8,8,10,0.97);backdrop-filter:blur(30px);flex-direction:column;align-items:center;justify-content:center;gap:24px}
.mob-nav.show{display:flex}
.mob-nav a{font-family:var(--display);font-size:32px;letter-spacing:5px;color:var(--dim);transition:.3s}
.mob-nav a:hover{color:var(--accent)}

/* ═══════════ PAGES ═══════════ */
@keyframes pgIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.page-main{min-height:100vh;padding-top:var(--head-h)}
.home .page-main{padding-top:0}
.wrap{max-width:var(--max);margin:0 auto;padding:0 44px}

/* ═══════════ HERO — 동영상 지원 ═══════════ */
.artist-hero{position:relative;height:100svh;overflow:hidden;background:var(--bg);display:flex;align-items:center;justify-content:center}

/* 배경: 동영상 or 이미지 or 기본 다크 */
.artist-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.3);transition:transform 12s linear}
.artist-hero.loaded .artist-hero-bg{transform:scale(1.08)}
.artist-hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.3);z-index:1}
.artist-hero-poster{transition:opacity .8s var(--ease);z-index:0}
.artist-hero-bg::after,.artist-hero-video-overlay{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,8,10,0.4)0%,rgba(8,8,10,0.15)40%,rgba(8,8,10,0.8)100%);pointer-events:none}
.artist-hero-video-overlay{content:none;display:block}

.artist-hero-content{position:relative;z-index:2;text-align:center;padding:0 44px}
.artist-hero-name{font-family:var(--display);font-size:clamp(64px,12vw,140px);letter-spacing:12px;line-height:1;opacity:0;transform:translateY(30px);animation:fu 1s .3s var(--ease) forwards}
.artist-hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px}
.artist-hero-scroll span{font-family:var(--en);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--muted)}
.scroll-line{width:1px;height:40px;background:var(--border2);position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:1px;height:100%;background:var(--accent);animation:scrollDown 2s ease infinite}
@keyframes scrollDown{0%{top:-100%}100%{top:100%}}
@keyframes fu{to{opacity:1;transform:none}}

/* ═══════════ SECTION COMMON ═══════════ */
.sec{padding:100px 0}
.sec-head{margin-bottom:56px}
.sec-label{font-family:var(--en);font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.sec-title{font-family:var(--display);font-size:clamp(32px,5vw,52px);letter-spacing:2px;line-height:1.1}
.sec-bar{width:36px;height:1px;background:var(--accent);margin-top:18px}
.more{display:inline-flex;align-items:center;gap:8px;font-family:var(--en);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--dim);margin-top:40px;cursor:pointer;transition:.3s}
.more:hover{color:var(--accent);gap:14px}
.more svg{width:16px;height:16px;transition:.3s}

/* ═══════════ NEWS (카테고리 태그 추가) ═══════════ */
.n-list{display:flex;flex-direction:column}
.n-item{display:grid;grid-template-columns:90px 56px 1fr;align-items:center;gap:20px;padding:22px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:.3s var(--ease)}
.n-item:first-child{border-top:1px solid var(--border)}
.n-item:hover{padding-left:10px}
.n-item:hover .n-title{color:var(--accent)}
.n-date{font-family:var(--en);font-size:12.5px;color:var(--muted);letter-spacing:.5px}
.n-cat{font-size:10.5px;letter-spacing:1px;text-align:center;padding:3px 0;border:1px solid var(--border2);color:var(--dim)}
.n-title{font-size:14.5px;transition:.3s}

/* ═══════════ DISCOGRAPHY ═══════════ */
.disc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.disc-card{background:var(--bg2);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:.4s var(--ease)}
.disc-card:hover{border-color:var(--border2);transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.disc-cover{aspect-ratio:1;overflow:hidden;background:var(--bg3)}
.disc-cover .ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:28px;color:var(--muted);letter-spacing:5px;background:linear-gradient(135deg,var(--bg2),var(--bg3));transition:.6s var(--ease)}
.disc-card:hover .disc-cover .ph{transform:scale(1.08)}
.disc-cover img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.disc-card:hover .disc-cover img{transform:scale(1.08)}
.disc-body{padding:18px 20px 22px}
.disc-format{font-family:var(--en);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent);margin-bottom:5px}
.disc-name{font-size:14.5px;font-weight:500;margin-bottom:6px}
.disc-date{font-family:var(--en);font-size:12px;color:var(--muted)}
.disc-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.disc-detail-cover{aspect-ratio:1;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:36px;color:var(--muted);letter-spacing:5px;overflow:hidden}
.disc-detail-cover img{width:100%;height:100%;object-fit:cover}
.disc-detail-info h2{font-size:22px;font-weight:700;margin-bottom:8px}
.disc-detail-meta{font-family:var(--en);font-size:12.5px;color:var(--dim);margin-bottom:28px;display:flex;flex-wrap:wrap;gap:16px}
.tracklist{margin-bottom:32px}
.tracklist h4{font-size:13px;font-weight:600;color:var(--dim);margin-bottom:14px;letter-spacing:1px}
.track{display:flex;gap:14px;padding:10px 0;border-bottom:1px solid var(--border);font-size:14px}
.track-no{font-family:var(--en);font-size:12px;color:var(--muted);min-width:28px}
.stream-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.stream-btn{padding:8px 20px;font-size:12.5px;font-family:var(--en);border:1px solid var(--border);color:var(--dim);transition:.3s;letter-spacing:.5px}
.stream-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ═══════════ SCHEDULE (카테고리별 색상) ═══════════ */
.sched-list{display:flex;flex-direction:column}
.sched-item{display:grid;grid-template-columns:90px 56px 1fr auto;align-items:center;gap:16px;padding:20px 0;border-bottom:1px solid var(--border);transition:.3s var(--ease)}
.sched-item:first-child{border-top:1px solid var(--border)}
.sched-item:hover{padding-left:8px}
.sched-date{font-family:var(--en);font-size:12.5px;color:var(--muted);letter-spacing:.5px}
.sched-cat{font-size:10px;letter-spacing:1.5px;text-align:center;padding:3px 0;border:1px solid var(--border2);color:var(--dim);font-family:var(--en);text-transform:uppercase}
/* 카테고리별 색상 */
.sched-cat[data-cat="TV"]{border-color:rgba(204,0,0,0.4);color:#2E6BDB}
.sched-cat[data-cat="라디오"]{border-color:rgba(78,150,255,0.4);color:#4E96FF}
.sched-cat[data-cat="공연"]{border-color:rgba(204,0,0,0.4);color:#2E6BDB}
.sched-cat[data-cat="이벤트"]{border-color:rgba(201,168,76,0.4);color:#C9A84C}
.sched-cat[data-cat="발매"]{border-color:rgba(76,201,120,0.4);color:#4CC978}
.sched-cat[data-cat="기타"]{border-color:var(--border2);color:var(--dim)}
.sched-content{font-size:14px}
.sched-time{font-family:var(--en);font-size:12px;color:var(--muted);white-space:nowrap}
.sched-month{font-family:var(--display);font-size:24px;letter-spacing:2px;color:var(--accent);margin:48px 0 20px}
.sched-month:first-child{margin-top:0}

/* ═══════════ MEDIA ═══════════ */
.media-tabs{display:flex;gap:8px;margin-bottom:36px}
.media-tab{padding:6px 20px;font-size:12.5px;font-family:var(--en);letter-spacing:1.5px;text-transform:uppercase;border:1px solid var(--border);color:var(--dim);cursor:pointer;transition:.3s}
.media-tab:hover,.media-tab.on{border-color:var(--accent);color:var(--accent)}
.media-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.media-item{aspect-ratio:16/9;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;position:relative;transition:.4s var(--ease)}
.media-item:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.3)}
.media-item .ph{font-family:var(--display);font-size:20px;color:var(--muted);letter-spacing:3px}
.media-item .play-icon{position:absolute;width:56px;height:56px;border-radius:50%;background:rgba(204,0,0,0.9);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:.35s var(--ease)}
.media-item:hover .play-icon{opacity:1;transform:scale(1)}
.play-icon svg{width:20px;height:20px;fill:#fff;margin-left:3px}
.media-item-info{position:absolute;bottom:0;left:0;right:0;padding:14px 16px;background:linear-gradient(transparent,rgba(0,0,0,.7))}
.media-item-title{font-size:13px;font-weight:500}
.media-item-date{font-family:var(--en);font-size:11px;color:var(--muted);margin-top:3px}
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.photo-item{aspect-ratio:1;background:var(--bg3);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:.3s}
.photo-item:hover{border-color:var(--border2);opacity:.85}
.photo-item .ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--muted);text-align:center;padding:8px}

/* ═══════════ VIDEO MODAL ═══════════ */
.video-modal{position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,0.92);display:none;align-items:center;justify-content:center;flex-direction:column}
.video-modal.show{display:flex;animation:pgIn .3s var(--ease)}
.video-modal-close{position:absolute;top:20px;right:28px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--dim);border:1px solid var(--border);transition:.3s;background:transparent;z-index:3001}
.video-modal-close:hover{color:var(--text);border-color:var(--accent)}
.video-modal-content{width:90%;max-width:900px;aspect-ratio:16/9;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px}
.video-modal-content .ph{font-family:var(--display);font-size:28px;color:var(--muted);letter-spacing:4px}
.video-modal-content .note{font-size:13px;color:var(--dim)}
.video-modal-title{margin-top:16px;font-size:15px;font-weight:500;text-align:center}

/* ═══════════ LIVE ═══════════ */
.live-list{display:flex;flex-direction:column;gap:20px}
.live-card{background:var(--bg2);border:1px solid var(--border);padding:28px 32px;transition:.4s var(--ease)}
.live-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.3)}
.live-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:16px}
.live-title{font-size:18px;font-weight:700}
.live-status{font-family:var(--en);font-size:10.5px;letter-spacing:2px;text-transform:uppercase;padding:4px 14px;white-space:nowrap}
.live-status.on-sale{border:1px solid var(--accent);color:var(--accent)}
.live-status.sold-out{border:1px solid var(--muted);color:var(--muted)}
.live-status.upcoming{border:1px solid var(--dim);color:var(--dim)}
.live-status.ended{border:1px solid var(--border);color:var(--muted)}
.live-dates{margin-bottom:16px}
.live-date-row{display:flex;gap:20px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13.5px;align-items:center}
.live-date-row .ld{font-family:var(--en);font-size:13px;color:var(--text);min-width:100px;letter-spacing:.5px}
.live-date-row .lt{font-family:var(--en);font-size:12px;color:var(--muted)}
.live-date-row .lv{color:var(--dim);flex:1}
.live-price{font-size:13px;color:var(--dim);margin-bottom:12px}
.live-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 28px;font-family:var(--en);font-size:12px;letter-spacing:2px;text-transform:uppercase;background:var(--accent);color:#fff;transition:.3s var(--ease)}
.live-btn:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 8px 24px var(--accent-dim)}
.live-btn.disabled{background:var(--bg3);color:var(--muted);pointer-events:none}

/* ═══════════ PROFILE ═══════════ */
.profile-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;padding:48px 0}
.profile-photo{aspect-ratio:3/4;background:var(--bg3);border:1px solid var(--border);overflow:hidden;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:48px;color:var(--muted);letter-spacing:8px}
.profile-photo img{width:100%;height:100%;object-fit:cover}
.profile-info h2{font-family:var(--display);font-size:48px;letter-spacing:4px;margin-bottom:4px}
.profile-info .profile-name-sub{font-size:13px;color:var(--dim);margin-bottom:32px}
.profile-table{width:100%;margin-bottom:36px}
.profile-table tr{border-bottom:1px solid var(--border)}
.profile-table th{text-align:left;padding:14px 24px 14px 0;font-size:12.5px;font-weight:500;color:var(--dim);width:80px;white-space:nowrap;vertical-align:top}
.profile-table td{padding:14px 0;font-size:14.5px}
.profile-bio{margin-bottom:36px}
.profile-bio h3{font-family:var(--display);font-size:22px;letter-spacing:2px;margin-bottom:14px}
.profile-bio p{font-size:14px;color:var(--dim);line-height:1.9}
.profile-bio p+p{margin-top:12px}
.profile-sns{display:flex;gap:16px}
.profile-sns a{display:flex;align-items:center;gap:6px;font-family:var(--en);font-size:12px;letter-spacing:1px;color:var(--dim);transition:.3s}
.profile-sns a:hover{color:var(--accent)}
.profile-sns svg{width:16px;height:16px}

/* ═══════════ DETAIL OVERLAY ═══════════ */
.detail-overlay{position:fixed;inset:0;z-index:2000;background:rgba(8,8,10,0.96);display:none;overflow-y:auto}
.detail-overlay.show{display:block;animation:pgIn .4s var(--ease)}
.detail-inner{max-width:700px;margin:0 auto;padding:100px 44px 80px}
.detail-close{position:fixed;top:22px;right:32px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--dim);border:1px solid var(--border);transition:.3s;z-index:2001;background:var(--bg)}
.detail-close:hover{color:var(--text);border-color:var(--accent)}
.detail-cat{font-size:11px;letter-spacing:2px;color:var(--accent);padding:3px 12px;border:1px solid var(--accent);display:inline-block;margin-bottom:16px}
.detail-date{font-family:var(--en);font-size:12.5px;color:var(--muted);margin-bottom:12px}
.detail-title{font-size:24px;font-weight:700;margin-bottom:24px;line-height:1.5;padding-bottom:24px;border-bottom:1px solid var(--border)}
.detail-body{font-size:15px;line-height:2;color:var(--dim)}
.detail-body p{margin-bottom:20px}

/* ═══════════ PAGE HERO / FILTERS / PAGER ═══════════ */
.pg-hero{padding:80px 0 48px;border-bottom:1px solid var(--border);margin-bottom:48px}
.pg-hero h1{font-family:var(--display);font-size:clamp(42px,7vw,72px);letter-spacing:4px;line-height:1.05}
.filters{display:flex;gap:8px;margin-bottom:36px;flex-wrap:wrap}
.ftag{padding:5px 16px;font-size:12.5px;border:1px solid var(--border);color:var(--dim);cursor:pointer;transition:.3s}
.ftag:hover,.ftag.on{border-color:var(--accent);color:var(--accent)}
.pager{display:flex;gap:8px;margin-top:48px;justify-content:center}
.pager button{width:36px;height:36px;font-family:var(--en);font-size:13px;border:1px solid var(--border);color:var(--dim);display:flex;align-items:center;justify-content:center;transition:.3s}
.pager button.on,.pager button:hover{border-color:var(--accent);color:var(--accent)}

/* ═══════════ FOOTER ═══════════ */
.artist-footer{border-top:1px solid var(--border);padding:40px 44px;max-width:var(--max);margin:0 auto}
.foot-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}
.foot-sns{display:flex;gap:16px}
.foot-sns a{color:var(--muted);transition:.3s;display:flex}
.foot-sns a:hover{color:var(--accent)}
.foot-sns svg{width:18px;height:18px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding-top:20px;border-top:1px solid var(--border);margin:0 -44px;padding-left:44px;padding-right:44px}
.foot-copy{font-size:12px;color:var(--muted)}
.foot-links{display:flex;gap:20px}
.foot-links a{font-size:12px;color:var(--dim);transition:.3s}
.foot-links a:hover{color:var(--accent)}

/* ═══════════ RESPONSIVE ═══════════ */
@media(max-width:900px){
.disc-grid,.photo-grid{grid-template-columns:repeat(2,1fr)}
.profile-layout,.disc-detail-grid{grid-template-columns:1fr;gap:36px}
.sched-item{grid-template-columns:80px 50px 1fr;gap:12px}
.sched-time{display:none}
}
@media(max-width:768px){
.artist-hero-video,.artist-hero-video-overlay{display:none}
}
@media(max-width:640px){
header{padding:0 20px}
nav{display:none}
.burger{display:flex}
.wrap{padding:0 20px}
.artist-hero-content{padding:0 20px}
.disc-grid{grid-template-columns:1fr 1fr}
.media-grid{grid-template-columns:1fr}
.photo-grid{grid-template-columns:repeat(2,1fr)}
.sched-item{grid-template-columns:1fr;gap:6px}
.n-item{grid-template-columns:70px 48px 1fr;gap:10px}
.sec{padding:64px 0}
.pg-hero{padding:48px 0 32px;margin-bottom:32px}
.artist-footer{padding:32px 20px}
.foot-top,.foot-bottom{flex-direction:column;align-items:flex-start}
.foot-bottom{margin:0 -20px;padding-left:20px;padding-right:20px}
.detail-inner{padding:80px 20px 60px}
.live-card{padding:20px}
.live-date-row{flex-direction:column;gap:6px}
.video-modal-close{top:12px;right:16px}
}

/* ═══════════ REVEAL ═══════════ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.vis{opacity:1;transform:none}
