  :root{
    /* Monochrome — Black & White 클래식 럭셔리 */
    --bg:        #0A0A0A;         /* 메인 블랙 */
    --bg-2:      #141414;
    --bg-3:      #1A1A1A;
    --line:      #2A2A2A;         /* 라인 */
    --gold:      #FFFFFF;         /* 액센트는 화이트로 */
    --gold-soft: #E5E5E5;
    --gold-dark: #C0C0C0;
    --pink-glow: #FFFFFF;
    --cream:     #FFFFFF;
    --cream-2:   #F0F0F0;
    --ink-1:     #FFFFFF;         /* 메인 본문 - 흰색 */
    --ink-2:     #C8C8C8;         /* 보조 - 라이트 그레이 */
    --ink-3:     #888888;         /* 흐림 - 그레이 */
    --kakao:     #FEE500;         /* 카카오만 노란색 유지 (브랜드 식별성) */
    --kakao-ink: #181600;
    --serif:     "Playfair Display","Cormorant Garamond","Noto Serif KR", serif;
    --sans:      "Pretendard","Noto Sans KR", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
  }
  *{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
  body{
    background:var(--bg);
    color:var(--ink-1);
    font-family:var(--sans);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    overflow-x:hidden;
    word-break:keep-all;
    overflow-wrap:break-word;
    word-wrap:break-word;
  }
  /* 한국어 단어 단위 줄바꿈 - 전체 적용 */
  h1,h2,h3,h4,h5,h6,p,span,a,div,li,td,th,label,button{
    word-break:keep-all;
    overflow-wrap:break-word;
  }
  /* 단, 영문 단어(예: portfolio·email)는 어쩔 수 없을 때만 자르기 */
  input,textarea,select{word-break:normal}
  /* 메인 타이틀 - 핑크+화이트 듀얼 톤 (사진 느낌) */
  h2.section-title{
    color:#FFFFFF;
  }
  h2.section-title em{
    color:var(--gold) !important;
    text-shadow:0 0 30px rgba(255,255,255,.25), 0 0 60px rgba(255,255,255,.12);
  }
  /* nav cta hover */
  .nav-cta:hover{background:#FFFFFF !important;color:#0a0a0a !important}
  /* 카카오톡 버튼은 노란색 유지 (식별성) */
  .btn-kakao{background:var(--kakao);color:var(--kakao-ink)}
  .btn-kakao:hover{background:#FFEC3D;transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(254,229,0,.4)}
  /* 회사소개서 다운로드 버튼 — Hero CTA 핵심 위치 */
  .btn-brochure{
    background:#FFFFFF;color:#0a0a0a;
    border:1px solid #FFFFFF;
    box-shadow:0 14px 32px -10px rgba(255,255,255,.3);
    display:inline-flex;align-items:center;gap:10px;
  }
  .btn-brochure:hover{
    background:transparent;color:#FFFFFF;
    transform:translateY(-2px);
    box-shadow:0 18px 40px -10px rgba(255,255,255,.5);
  }
  .brochure-icon{font-size:18px;line-height:1}
  .brochure-hint{
    color:var(--ink-2);font-size:12px;letter-spacing:.04em;
    margin-top:14px;font-style:italic;font-family:var(--serif);
    opacity:.7;
  }
  /* 골드 → 핑크 글로우 효과 강화 */
  .btn-gold{box-shadow:0 14px 32px -10px rgba(255,255,255,.25)}
  .btn-gold:hover{box-shadow:0 18px 40px -10px rgba(255,255,255,.4) !important}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  ::selection{background:var(--gold);color:#0a0a0a}

  /* ----------- 공통 ----------- */
  .wrap{max-width:1240px;margin:0 auto;padding:0 28px}
  .serif{font-family:var(--serif)}
  .gold{color:var(--gold)}
  .eyebrow{
    font-family:var(--serif);
    font-style:italic;
    font-weight:500;
    color:var(--gold);
    letter-spacing:.04em;
    font-size:14px;
    display:inline-flex;align-items:center;gap:14px;
    margin-bottom:18px;
  }
  .eyebrow::before{content:"";width:42px;height:1px;background:var(--gold);display:inline-block}
  h1,h2,h3,h4{font-family:var(--serif);font-weight:700;letter-spacing:-.01em;color:var(--ink-1)}
  h2.section-title{font-size:clamp(28px,3.4vw,46px);line-height:1.18;margin-bottom:22px}
  h2.section-title em{font-style:italic;color:var(--cream);font-weight:500}
  /* About 섹션은 좁은 2컬럼이라 한 단계 더 작게 */
  .about .section-title{font-size:clamp(24px,2.6vw,36px);line-height:1.25}
  /* Contact 섹션의 'Get In Touch.' 균형 맞춤 */
  .ct-left h2{font-size:clamp(32px,3.8vw,52px) !important;line-height:1.12}
  .section-sub{color:var(--ink-2);font-size:16px;max-width:680px;margin-bottom:64px;line-height:1.75}
  section{padding:130px 0;position:relative}
  section.dark-2{background:linear-gradient(180deg,#0E0E0E 0%, #131313 100%)}
  section.dark-3{background:#101010}

  /* ----------- TOP / NAV ----------- */
  .nav{
    position:fixed;top:0;left:0;right:0;z-index:100;
    padding:18px 28px;
    backdrop-filter:blur(14px);
    background:rgba(10,10,10,.55);
    border-bottom:1px solid rgba(232,169,60,.08);
    transition:all .35s ease;
  }
  .nav.scrolled{background:rgba(10,10,10,.92);padding:14px 28px}
  .nav-inner{max-width:1240px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}
  .logo{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-weight:700;font-size:20px;letter-spacing:.04em}
  .logo b{color:var(--gold);font-size:22px}
  .logo span{color:var(--ink-2);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;font-family:var(--sans);margin-top:2px;display:block}
  .logo-mark{
    width:42px;height:42px;border:1.5px solid var(--gold);
    display:flex;align-items:center;justify-content:center;
    font-family:var(--serif);font-weight:800;color:var(--gold);
    font-size:18px;letter-spacing:-.04em;
  }
  .menu{display:flex;gap:38px;align-items:center}
  .menu a{
    font-size:13px;font-weight:500;letter-spacing:.06em;
    color:var(--ink-2);transition:color .25s;
    position:relative;
  }
  .menu a:hover{color:var(--gold)}
  .menu a::after{
    content:"";position:absolute;bottom:-6px;left:0;width:0;height:1px;
    background:var(--gold);transition:width .3s ease;
  }
  .menu a:hover::after{width:100%}
  .nav-cta{
    background:var(--gold);color:#0a0a0a !important;
    padding:11px 22px;border-radius:0;font-weight:700 !important;
    letter-spacing:.05em;font-size:12px;
    transition:all .25s;
  }
  .nav-cta:hover{background:#fff;color:#0a0a0a !important}
  .nav-cta::after{display:none !important}
  .hamburger{display:none;background:none;border:none;color:var(--gold);cursor:pointer;padding:8px}

  /* ----------- HERO ----------- */
  .hero{
    min-height:100vh;
    display:flex;align-items:center;
    padding:140px 0 100px;
    position:relative;overflow:hidden;
    background:#0A0A0A;
  }
  /* 슬라이드쇼 배경 (4장 fade 자동 전환 + ken-burns 줌) */
  .hero-slides{position:absolute;inset:0;z-index:0;overflow:hidden}
  .hero-slide{
    position:absolute;inset:0;
    background-size:cover;background-position:center;
    opacity:0;transform:scale(1.08);
    transition:opacity 1.6s ease, transform 9s ease-out;
  }
  .hero-slide.active{opacity:1;transform:scale(1.0)}
  /* 글자 가독성 + 핑크 무드 오버레이 */
  .hero-overlay{
    position:absolute;inset:0;z-index:1;pointer-events:none;
    background:
      linear-gradient(180deg, rgba(11,11,16,.72) 0%, rgba(11,11,16,.5) 50%, rgba(11,11,16,.9) 100%),
      radial-gradient(ellipse 70% 50% at 50% 12%, rgba(255,255,255,.08), transparent 60%),
      radial-gradient(ellipse 60% 40% at 80% 80%, rgba(255,255,255,.07), transparent 55%);
  }
  /* 슬라이드 인디케이터 */
  .hero-dots{
    position:absolute;bottom:120px;left:50%;transform:translateX(-50%);
    z-index:5;display:flex;gap:14px;align-items:center;
  }
  .hero-dot{
    width:32px;height:2px;background:rgba(255,255,255,.25);
    cursor:pointer;transition:all .4s;border:none;padding:0;
  }
  .hero-dot.active{background:var(--gold);width:60px;box-shadow:0 0 14px var(--gold)}
  .hero-dot:hover{background:rgba(255,255,255,.4)}
  .hero::before{
    content:"";position:absolute;inset:0;
    background-image:
      linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
    background-size:80px 80px;
    pointer-events:none;
    mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
    -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
  }
  /* 무대 LED 빔 효과 */
  .hero::after{
    content:"";position:absolute;top:-10%;left:50%;transform:translateX(-50%);
    width:140%;height:90%;
    background:
      radial-gradient(ellipse 50% 60% at 50% 0%, rgba(255,255,255,.1), transparent 70%);
    pointer-events:none;
    filter:blur(40px);
  }
  .hero-cross{position:absolute;color:#FFFFFF;opacity:.55;font-size:22px;pointer-events:none;text-shadow:0 0 14px rgba(255,255,255,.4)}
  .hero-cross.c1{top:18%;right:14%}
  .hero-cross.c2{top:32%;right:8%;font-size:14px;opacity:.5}
  .hero-cross.c3{bottom:22%;left:8%;font-size:18px;opacity:.4}
  .hero-cross.c4{top:60%;right:22%;font-size:12px;opacity:.3}

  .hero-inner{position:relative;z-index:2;width:100%}
  .hero-tag{
    display:inline-block;
    border:1px solid rgba(232,169,60,.4);
    color:var(--gold);
    padding:8px 18px;font-size:12px;letter-spacing:.18em;
    margin-bottom:36px;font-weight:500;
  }
  .hero h1{
    font-size:clamp(56px,9vw,128px);
    font-weight:800;
    line-height:.95;letter-spacing:-.02em;
    color:var(--gold);
    margin-bottom:8px;
    text-shadow:
      0 0 28px rgba(255,255,255,.35),
      0 0 60px rgba(255,255,255,.12);
  }
  .hero h1 em{
    display:block;font-style:italic;font-weight:500;
    color:#FFFFFF;
    font-size:clamp(38px,6vw,84px);
    margin-top:8px;
    line-height:1;
    text-shadow:0 2px 24px rgba(255,255,255,.18);
  }
  .hero-line{
    width:120px;height:1px;background:var(--gold);
    margin:42px 0 24px;
  }
  .hero-sub{
    color:var(--ink-2);
    font-size:15px;letter-spacing:.18em;text-transform:uppercase;
    margin-bottom:36px;font-weight:500;
  }
  .hero-desc{
    font-family:var(--serif);font-style:italic;font-weight:400;
    color:var(--ink-1);max-width:620px;
    font-size:19px;line-height:1.7;margin-bottom:56px;
  }
  .hero-cta{display:flex;gap:18px;flex-wrap:wrap}
  .btn{
    display:inline-flex;align-items:center;gap:12px;
    padding:18px 34px;font-size:13px;font-weight:600;letter-spacing:.14em;
    transition:all .3s ease;cursor:pointer;border:none;
    text-transform:uppercase;
  }
  .btn-gold{background:var(--gold);color:#0a0a0a}
  .btn-gold:hover{background:#fff;transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(232,169,60,.4)}
  .btn-ghost{background:transparent;color:var(--gold);border:1px solid var(--gold)}
  .btn-ghost:hover{background:var(--gold);color:#0a0a0a;transform:translateY(-2px)}
  .btn-kakao{background:var(--kakao);color:var(--kakao-ink)}
  .btn-kakao:hover{background:#FFEC3D;transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(254,229,0,.4)}

  .hero-meta{
    position:absolute;bottom:48px;left:28px;right:28px;
    display:flex;justify-content:space-between;align-items:flex-end;
    z-index:3;
  }
  .hero-meta-l{font-family:var(--serif);font-style:italic;color:var(--ink-3);font-size:13px;letter-spacing:.1em}
  .hero-meta-r{display:flex;gap:32px;align-items:center}
  .hero-stat-mini{text-align:center}
  .hero-stat-mini b{
    display:block;font-family:var(--serif);color:var(--gold);
    font-size:30px;font-weight:700;line-height:1;
  }
  .hero-stat-mini span{
    display:block;color:var(--ink-3);font-size:11px;letter-spacing:.18em;
    margin-top:6px;text-transform:uppercase;
  }

  /* ----------- ABOUT ----------- */
  .about{background:var(--bg)}
  .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
  .about-img-block{
    position:relative;
    aspect-ratio:4/5;
    background:
      linear-gradient(180deg, rgba(10,10,10,.25) 0%, rgba(10,10,10,.55) 100%),
      url('images/about-shinhan-stage.jpg') center/cover no-repeat;
    border:1px solid rgba(255,255,255,.18);
    overflow:hidden;
    box-shadow:0 30px 80px -20px rgba(255,255,255,.15);
  }
  .about-img-block::after{
    content:"JJ Entertainment";
    position:absolute;bottom:100px;left:30px;
    font-family:var(--serif);font-style:italic;
    color:#FFFFFF;font-size:28px;font-weight:600;
    text-align:left;letter-spacing:.04em;
    text-shadow:0 0 22px rgba(255,255,255,.4), 0 4px 16px rgba(0,0,0,.7);
  }
  .about-img-block::before{
    content:"+";
    position:absolute;top:22px;right:22px;
    color:#FFFFFF;font-size:22px;opacity:.8;
    text-shadow:0 0 12px var(--gold);
    z-index:3;
  }
  .about-img-frame{
    position:absolute;inset:18px;
    border:1px solid rgba(232,169,60,.2);
    pointer-events:none;
  }
  .about-stats{
    position:absolute;bottom:0;left:0;right:0;
    background:rgba(232,169,60,.92);
    color:#0a0a0a;padding:18px 22px;
    display:flex;gap:24px;justify-content:space-between;
    font-family:var(--serif);
  }
  .about-stat b{font-size:22px;font-weight:700;display:block;line-height:1}
  .about-stat span{font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-family:var(--sans);font-weight:600}

  .about-body p{color:var(--ink-2);font-size:16px;line-height:1.85;margin-bottom:20px}
  .about-body p strong{color:var(--ink-1);font-weight:600}
  .vision-block{
    margin-top:42px;padding:32px 28px;
    border-left:2px solid var(--gold);
    background:rgba(255,255,255,.03);
  }
  .vision-block h4{
    font-size:13px;color:var(--gold);letter-spacing:.2em;font-family:var(--sans);font-weight:600;
    text-transform:uppercase;margin-bottom:14px;
  }
  .vision-block p{
    font-family:var(--serif);font-style:italic;
    color:var(--ink-1);font-size:21px;line-height:1.55;font-weight:500;
  }

  /* ----------- CORE VALUES (TRUE) ----------- */
  .values{background:#0B0B0B;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .values-head{text-align:center;margin-bottom:80px}
  .values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-left:1px solid var(--line)}
  .value{
    padding:0 0 40px;
    border-right:1px solid var(--line);
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
    transition:background .3s;
  }
  .value:hover{background:rgba(255,255,255,.02)}
  .value-img{
    aspect-ratio:4/3;
    background-size:cover;background-position:center;
    margin-bottom:30px;position:relative;
    border-bottom:1px solid var(--line);
    filter:grayscale(100%) contrast(1.05) brightness(.9);
    transition:filter .4s;
  }
  .value:hover .value-img{filter:grayscale(0%) contrast(1.05) brightness(1)}
  .value-img::after{
    content:"";position:absolute;inset:0;
    background:linear-gradient(180deg, transparent 60%, rgba(11,11,16,.9) 100%);
  }
  .value-body{padding:0 36px}
  .value-letter{
    font-family:var(--serif);font-size:80px;font-weight:700;
    line-height:.9;color:var(--gold);margin-bottom:14px;
  }
  .value-letter em{font-style:italic;color:var(--ink-1);font-weight:500}
  .value h3{font-family:var(--serif);font-size:26px;color:var(--ink-1);margin-bottom:6px}
  .value-kr{color:var(--gold);font-size:14px;letter-spacing:.2em;margin-bottom:18px;font-weight:500}
  .value p{color:var(--ink-2);font-size:14px;line-height:1.7}
  .values-foot{
    text-align:center;margin-top:60px;
    font-family:var(--serif);font-style:italic;color:var(--gold);
    font-size:18px;letter-spacing:.1em;
  }

  /* ----------- SERVICES ----------- */
  .services{background:#0E0E0E}
  .svc-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:64px;gap:40px;flex-wrap:wrap}
  .svc-head-r{max-width:420px;color:var(--ink-2);line-height:1.8;font-size:15px}
  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
  .svc{
    background:#101010;
    padding:54px 38px;
    transition:all .35s;
    position:relative;
    min-height:300px;
    display:flex;flex-direction:column;
    cursor:default;
  }
  .svc:hover{background:#1a1a1a;transform:translateY(-4px);box-shadow:0 20px 50px -20px rgba(255,255,255,.12)}
  .svc-num{
    font-family:var(--serif);font-style:italic;color:var(--gold);
    font-size:14px;letter-spacing:.2em;margin-bottom:30px;
  }
  .svc-ico{
    width:54px;height:54px;border:1px solid var(--gold);
    display:flex;align-items:center;justify-content:center;
    color:var(--gold);margin-bottom:28px;
  }
  .svc h3{font-family:var(--serif);font-size:30px;color:var(--ink-1);margin-bottom:6px;letter-spacing:-.01em}
  .svc-en{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:15px;margin-bottom:20px;font-weight:500}
  .svc p{color:var(--ink-2);font-size:14px;line-height:1.75;flex:1}
  .svc-arrow{
    margin-top:24px;color:var(--gold);font-size:22px;
    transition:transform .3s;
  }
  .svc:hover .svc-arrow{transform:translateX(6px)}

  /* ----------- NUMBERS ----------- */
  .numbers{
    background:
      radial-gradient(ellipse 70% 50% at 50% 0%, rgba(255,255,255,.08), transparent 65%),
      linear-gradient(135deg, rgba(255,255,255,.03), transparent 60%),
      #0B0B0B;
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    padding:100px 0;
  }
  .num-head{text-align:center;margin-bottom:70px}
  .num-head p{color:var(--gold);font-family:var(--serif);font-style:italic;font-size:17px;margin-top:14px;letter-spacing:.06em}
  .num-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:980px;margin:0 auto}
  .num{text-align:center;padding:32px 20px;position:relative}
  .num+.num::before{
    content:"";position:absolute;left:0;top:15%;bottom:15%;width:1px;background:var(--line);
  }
  .num b{
    font-family:var(--serif);font-weight:700;
    font-size:clamp(72px,10vw,128px);color:var(--gold);
    line-height:1;display:block;letter-spacing:-.02em;
    text-shadow:0 0 32px rgba(255,255,255,.25);
  }
  .num span{
    display:block;font-family:var(--serif);font-style:italic;
    color:var(--ink-1);font-size:18px;margin-top:8px;
  }
  .num small{
    display:block;color:var(--ink-3);font-size:12px;letter-spacing:.18em;
    text-transform:uppercase;margin-top:6px;
  }
  .num-note{text-align:center;color:var(--ink-3);font-size:12px;letter-spacing:.06em;margin-top:48px;font-style:italic;font-family:var(--serif)}

  /* ----------- PROCESS ----------- */
  .process{background:#0E0E0E}
  .proc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;margin-top:60px}
  .proc-grid::before{
    content:"";position:absolute;left:0;right:0;top:42px;height:1px;background:var(--line);
  }
  .proc-step{padding:0 18px;position:relative;text-align:left}
  .proc-circle{
    width:84px;height:84px;border-radius:50%;
    background:#0E0E0E;border:1px solid var(--gold);
    color:var(--gold);font-family:var(--serif);font-size:30px;font-weight:700;
    display:flex;align-items:center;justify-content:center;
    margin-bottom:30px;position:relative;z-index:2;
    transition:all .3s;
  }
  .proc-step:hover .proc-circle{background:var(--gold);color:#0a0a0a;transform:scale(1.06)}
  .proc-step h4{font-family:var(--serif);font-size:21px;color:var(--ink-1);margin-bottom:12px}
  .proc-step p{color:var(--ink-2);font-size:13px;line-height:1.7}

  /* ----------- PORTFOLIO ----------- */
  .portfolio{background:#0B0B0B;border-top:1px solid var(--line)}
  .pf-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:56px;gap:40px;flex-wrap:wrap}
  .pf-filters{display:flex;gap:8px;flex-wrap:wrap}
  .pf-filter{
    background:transparent;border:1px solid var(--line);color:var(--ink-2);
    padding:9px 18px;font-size:12px;letter-spacing:.08em;cursor:pointer;
    transition:all .25s;font-family:var(--sans);
  }
  .pf-filter:hover,.pf-filter.active{border-color:var(--gold);color:var(--gold);background:rgba(232,169,60,.06)}

  .pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  /* 첫 카드는 2칸 폭으로 확장하여 시각 hierarchy 부여 */
  .pf-grid > .pf-card.feature{grid-column:span 2}
  .pf-grid > .pf-card.feature .pf-thumb{aspect-ratio:16/8}
  .pf-grid > .pf-card.feature .pf-thumb-en{font-size:28px;padding:0 32px 28px}
  .pf-grid > .pf-card.feature .pf-body{padding:32px 32px 36px}
  .pf-grid > .pf-card.feature .pf-body h4{font-size:26px}
  .pf-grid > .pf-card.feature .pf-thumb-cat{font-size:12px;padding:6px 14px}
  .pf-grid > .pf-card.feature::before{
    content:"FEATURED";position:absolute;top:18px;right:80px;z-index:3;
    color:var(--gold);font-size:11px;letter-spacing:.2em;font-weight:700;
    background:rgba(11,11,16,.7);padding:5px 12px;border:1px solid var(--gold);
    text-shadow:0 0 8px var(--gold);
  }
  .pf-card{
    background:#141414;border:1px solid var(--line);
    overflow:hidden;transition:all .4s ease;cursor:pointer;
    position:relative;
  }
  .pf-card:hover{border-color:var(--gold);transform:translateY(-6px);box-shadow:0 30px 60px -20px rgba(0,0,0,.6)}
  .pf-thumb{
    aspect-ratio:16/10;
    background-color:#0a0a0a;
    background-size:cover;background-position:center;
    position:relative;overflow:hidden;
    display:flex;align-items:flex-end;justify-content:flex-start;
    transition:transform .6s ease;
  }
  .pf-card:hover .pf-thumb{transform:scale(1.04)}
  .pf-thumb::before{
    content:"";position:absolute;inset:0;
    background:linear-gradient(180deg, rgba(11,11,16,.1) 30%, rgba(11,11,16,.85) 100%);
    transition:opacity .35s;
  }
  .pf-thumb::after{
    content:"";position:absolute;inset:0;
    background:radial-gradient(ellipse at 70% 30%, rgba(255,255,255,.08), transparent 60%);
    opacity:0;transition:opacity .35s;
  }
  .pf-card:hover .pf-thumb::after{opacity:1}
  .pf-thumb-en{
    position:relative;z-index:2;
    font-family:var(--serif);font-style:italic;
    color:#FFFFFF;font-size:22px;font-weight:500;
    text-align:left;padding:0 24px 24px;
    text-shadow:0 0 22px rgba(255,255,255,.35), 0 4px 12px rgba(0,0,0,.8);
    line-height:1.25;
  }
  .pf-thumb-year{
    position:absolute;top:18px;right:18px;z-index:2;
    color:var(--cream);font-family:var(--serif);font-size:13px;letter-spacing:.12em;
    background:rgba(0,0,0,.5);padding:5px 10px;border:1px solid rgba(232,169,60,.3);
  }
  .pf-thumb-cat{
    position:absolute;top:18px;left:18px;z-index:2;
    color:var(--gold);font-size:11px;letter-spacing:.18em;font-weight:600;
    background:rgba(0,0,0,.6);padding:5px 12px;border:1px solid rgba(232,169,60,.3);
  }
  .pf-body{padding:28px 24px 30px}
  .pf-body h4{
    font-family:var(--serif);font-size:21px;color:var(--ink-1);
    margin-bottom:8px;line-height:1.35;
  }
  .pf-client{color:var(--gold);font-size:13px;font-weight:500;letter-spacing:.05em;margin-bottom:14px;font-family:var(--serif);font-style:italic}
  .pf-info{color:var(--ink-3);font-size:12px;letter-spacing:.06em;border-top:1px solid var(--line);padding-top:14px;margin-top:14px}

  /* ----------- ARTISTS ----------- */
  .artists{background:#0E0E0E;border-top:1px solid var(--line)}
  .art-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:50px}
  .artist{
    background:#141414;border:1px solid var(--line);
    padding:36px 24px;text-align:center;
    transition:all .3s;
  }
  .artist:hover{border-color:var(--gold);background:#1a1408;transform:translateY(-4px)}
  .artist-avatar{
    width:80px;height:80px;border-radius:50%;margin:0 auto 18px;
    background:linear-gradient(135deg, rgba(232,169,60,.25), rgba(232,169,60,.05));
    border:1px solid var(--gold);
    display:flex;align-items:center;justify-content:center;
    font-family:var(--serif);font-size:28px;color:var(--gold);font-weight:600;
  }
  .artist b{font-family:var(--serif);color:var(--ink-1);font-size:18px;display:block;margin-bottom:4px}
  .artist span{color:var(--ink-3);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
  /* 사진 카드 (이니셜 대신 실제 사진) */
  .artist-photo{padding-top:0;overflow:hidden}
  .artist-photo .artist-img{
    width:calc(100% + 48px);height:200px;margin:0 -24px 18px;
    background-size:cover;background-position:center top;
    border-bottom:1px solid var(--gold);
    filter:grayscale(.15);transition:all .4s;
  }
  .artist-photo:hover .artist-img{filter:grayscale(0);transform:scale(1.03)}
  /* 협업 행사 한 줄 (메타 캡션) */
  .artist em{
    display:block;margin-top:12px;padding-top:12px;
    border-top:1px dashed rgba(212,175,55,.18);
    font-family:var(--serif);font-style:italic;
    color:var(--gold);font-size:12px;line-height:1.5;
    word-break:keep-all;
  }

  /* ----------- NEWS ----------- */
  .news{background:#0B0B0B;border-top:1px solid var(--line)}
  .news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
  .news-card{
    background:#101010;padding:42px 32px;
    transition:all .3s;cursor:pointer;
    display:flex;flex-direction:column;
  }
  .news-card:hover{background:#141414}
  .news-tag{
    display:inline-block;color:var(--gold);font-size:11px;letter-spacing:.2em;
    border:1px solid var(--gold);padding:4px 10px;margin-bottom:24px;width:fit-content;font-weight:600;
  }
  .news-card h4{
    font-family:var(--serif);font-size:22px;color:var(--ink-1);
    line-height:1.4;margin-bottom:18px;flex:1;
  }
  .news-card p{color:var(--ink-2);font-size:14px;line-height:1.7;margin-bottom:24px}
  .news-meta{color:var(--ink-3);font-size:12px;letter-spacing:.1em;border-top:1px solid var(--line);padding-top:18px;display:flex;justify-content:space-between}
  .news-meta em{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:13px}

  /* ----------- AUDITION / CAREER ----------- */
  .audition{
    background:
      radial-gradient(ellipse at 80% 20%, rgba(255,255,255,.07), transparent 60%),
      radial-gradient(ellipse at 20% 90%, rgba(255,255,255,.04), transparent 55%),
      #0E0E0E;
    border-top:1px solid var(--line);
  }
  .aud-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
  .aud-card{
    background:#141414;border:1px solid var(--line);
    padding:60px 50px;position:relative;
    transition:all .3s;
  }
  .aud-card:hover{border-color:var(--gold)}
  .aud-card::before{
    content:"";position:absolute;top:0;left:0;width:60px;height:1px;background:var(--gold);
  }
  .aud-eyebrow{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:14px;margin-bottom:18px;letter-spacing:.06em}
  .aud-card h3{font-family:var(--serif);font-size:36px;color:var(--ink-1);margin-bottom:22px;line-height:1.2}
  .aud-card p{color:var(--ink-2);font-size:15px;line-height:1.8;margin-bottom:30px}
  .aud-list{margin-bottom:36px}
  .aud-list li{
    list-style:none;color:var(--ink-2);font-size:14px;
    padding:10px 0 10px 22px;position:relative;border-bottom:1px dashed var(--line);
  }
  .aud-list li::before{
    content:"◢";position:absolute;left:0;color:var(--gold);font-size:9px;top:14px;
  }
  .aud-list li b{color:var(--ink-1);margin-right:10px;font-weight:600}

  /* ----------- CONTACT ----------- */
  .contact{
    background:#0B0B0B;border-top:1px solid var(--line);
    padding:140px 0;
    position:relative;overflow:hidden;
  }
  .contact::before{
    content:"+";position:absolute;top:60px;right:8%;font-size:32px;color:var(--gold);opacity:.4;
  }
  .contact::after{
    content:"+";position:absolute;bottom:80px;left:8%;font-size:22px;color:var(--gold);opacity:.3;
  }
  .ct-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start}
  .ct-left h2{font-size:clamp(48px,6vw,84px);line-height:1;margin-bottom:32px}
  .ct-left h2 em{display:block;font-style:italic;color:var(--cream);font-weight:500}
  .ct-left .ct-desc{color:var(--ink-2);font-size:16px;line-height:1.8;margin-bottom:50px}

  .ct-info{margin-top:40px}
  .ct-info-row{
    display:grid;grid-template-columns:120px 1fr;gap:24px;
    padding:20px 0;border-bottom:1px solid var(--line);align-items:center;
  }
  .ct-info-row b{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:14px;letter-spacing:.06em;font-weight:500}
  .ct-info-row span{color:var(--ink-1);font-size:16px;font-weight:500}
  .ct-info-row a{color:var(--ink-1);font-size:16px;font-weight:500;transition:color .25s}
  .ct-info-row a:hover{color:var(--gold)}

  /* form */
  .form-block{
    background:linear-gradient(180deg, #141414 0%, #0E0E0E 100%);
    border:1px solid var(--line);
    padding:52px 46px;
    position:relative;
  }
  .form-block::before{
    content:"";position:absolute;top:0;left:0;width:80px;height:1px;background:var(--gold);
  }
  .form-block h3{
    font-family:var(--serif);font-size:30px;color:var(--ink-1);
    margin-bottom:10px;
  }
  .form-block h3 em{font-style:italic;color:var(--gold);font-weight:500}
  .form-block .form-sub{
    color:var(--ink-2);font-size:14px;margin-bottom:36px;line-height:1.7;
  }
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
  .field{display:flex;flex-direction:column;gap:8px}
  .field.full{grid-column:1/-1}
  .field label{
    color:var(--gold);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
    font-weight:600;font-family:var(--sans);
  }
  .field input,.field select,.field textarea{
    background:#0A0A0A;border:1px solid var(--line);color:var(--ink-1);
    padding:14px 16px;font-size:14px;font-family:var(--sans);
    transition:border-color .25s;width:100%;
  }
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
  .field textarea{resize:vertical;min-height:130px;line-height:1.6}
  .field select{cursor:pointer}
  /* 개인정보 동의 영역 */
  .privacy-consent{margin-top:24px;padding-top:24px;border-top:1px solid var(--line)}
  .consent-row{
    display:flex;align-items:flex-start;gap:12px;cursor:pointer;
    user-select:none;line-height:1.5;
  }
  .consent-row input[type=checkbox]{position:absolute;opacity:0;pointer-events:none}
  .consent-check{
    flex-shrink:0;width:20px;height:20px;
    border:1.5px solid var(--ink-3);
    display:inline-flex;align-items:center;justify-content:center;
    transition:all .2s;margin-top:2px;
  }
  .consent-row:hover .consent-check{border-color:#fff}
  .consent-row input:checked + .consent-check{
    background:#fff;border-color:#fff;
  }
  .consent-row input:checked + .consent-check::after{
    content:"✓";color:#0a0a0a;font-weight:700;font-size:14px;line-height:1;
  }
  .consent-text{
    color:var(--ink-1);font-size:13.5px;
  }
  .consent-text b{color:#fff;margin-right:4px;font-weight:600}
  .consent-text a{
    color:var(--ink-2);font-size:12px;margin-left:8px;
    border-bottom:1px solid var(--line);
    transition:all .2s;
  }
  .consent-text a:hover{color:#fff;border-color:#fff}
  .privacy-detail{
    max-height:0;overflow:hidden;
    transition:max-height .4s ease, margin-top .3s ease, padding .3s ease;
    background:rgba(255,255,255,.02);
    border-left:2px solid var(--line);
    padding:0 18px;margin-top:0;
  }
  .privacy-detail.open{
    max-height:400px;
    padding:18px;margin-top:14px;
  }
  .privacy-detail p{
    color:var(--ink-2);font-size:12.5px;line-height:1.8;margin-bottom:6px;
  }
  .privacy-detail p:last-child{margin-bottom:0}
  .privacy-detail b{color:#fff;font-weight:500}

  .form-cta{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
  .form-note{
    margin-top:20px;color:var(--ink-3);font-size:12px;line-height:1.6;
    padding-top:20px;border-top:1px solid var(--line);
  }
  .form-note b{color:var(--gold)}

  /* ----------- FOOTER ----------- */
  footer{
    background:#070707;padding:80px 0 32px;
    border-top:1px solid var(--line);
    position:relative;
  }
  .ft-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:60px;margin-bottom:60px}
  .ft-brand{font-family:var(--serif);font-size:32px;color:var(--gold);font-weight:700;letter-spacing:.04em;margin-bottom:6px}
  .ft-brand em{font-style:italic;color:var(--cream);font-weight:500;display:block;font-size:22px}
  .ft-logo-img{height:80px;width:auto;display:block;margin-bottom:8px}
  .ft-tagline{color:var(--ink-2);font-size:14px;margin-top:20px;line-height:1.8;max-width:380px}
  .ft h5{
    font-size:13px;color:var(--gold);letter-spacing:.16em;text-transform:uppercase;
    font-weight:600;margin-bottom:24px;font-family:var(--sans);
  }
  .ft ul{list-style:none}
  .ft ul li{margin-bottom:12px}
  .ft ul a{color:var(--ink-2);font-size:14px;transition:color .25s}
  .ft ul a:hover{color:var(--gold)}
  .ft p.ft-line{color:var(--ink-2);font-size:13px;line-height:1.85}
  .ft p.ft-line b{color:var(--gold);font-family:var(--serif);font-style:italic;font-weight:500;margin-right:8px}

  .ft-socials{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}
  .ft-soc{
    width:42px;height:42px;border:1px solid var(--line);
    display:flex;align-items:center;justify-content:center;
    color:var(--ink-2);transition:all .25s;
  }
  .ft-soc:hover{border-color:var(--gold);color:var(--gold);background:rgba(232,169,60,.06)}
  .ft-soc.yt:hover{border-color:#FF0000;color:#FF0000;background:rgba(255,0,0,.08)}
  .ft-soc.kk:hover{border-color:var(--kakao);color:var(--kakao);background:rgba(254,229,0,.06)}
  .ft-soc.bl:hover{border-color:#03C75A;color:#03C75A;background:rgba(3,199,90,.08)}

  .ft-bottom{
    border-top:1px solid var(--line);padding-top:32px;
    display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;
    color:var(--ink-3);font-size:12px;letter-spacing:.05em;
  }
  .ft-bottom em{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:14px}

  /* ----------- FLOATING ----------- */
  .floats{
    position:fixed;right:24px;bottom:24px;z-index:90;
    display:flex;flex-direction:column;gap:14px;
  }
  .float-btn{
    width:62px;height:62px;border-radius:50%;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    box-shadow:0 14px 28px -6px rgba(0,0,0,.5);
    transition:all .25s ease;cursor:pointer;border:none;
    font-size:10px;letter-spacing:.05em;font-weight:700;font-family:var(--sans);
    text-decoration:none;
  }
  .float-btn:hover{transform:translateY(-4px) scale(1.05)}
  .fb-kakao{background:var(--kakao);color:var(--kakao-ink);box-shadow:0 14px 28px -6px rgba(254,229,0,.4)}
  .fb-top{background:var(--gold);color:#fff;box-shadow:0 14px 28px -6px rgba(255,255,255,.35)}
  .fb-call{background:#fff;color:#0a0a0a;box-shadow:0 14px 28px -6px rgba(255,255,255,.25)}

  .float-label{
    position:absolute;right:74px;top:50%;transform:translateY(-50%);
    background:#0a0a0a;color:var(--cream);
    padding:8px 14px;font-size:11px;letter-spacing:.12em;
    white-space:nowrap;opacity:0;pointer-events:none;
    border:1px solid var(--gold);transition:opacity .25s;
  }
  .float-btn-wrap{position:relative}
  .float-btn-wrap:hover .float-label{opacity:1}

  /* ----------- ANIMATIONS ----------- */
  .fade-in{opacity:0;transform:translateY(28px);transition:opacity .9s ease, transform .9s ease}
  .fade-in.visible{opacity:1;transform:translateY(0)}

  /* 무대 라이팅 빔 애니메이션 */
  .stage-lights{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}
  .beam{
    position:absolute;top:-10%;width:280px;height:130%;
    background:linear-gradient(180deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.03) 50%, transparent 100%);
    filter:blur(28px);
    transform-origin:top center;
    animation:beam-sway 8s ease-in-out infinite;
    mix-blend-mode:screen;
  }
  .beam.b1{left:10%;animation-delay:0s;transform:rotate(-15deg)}
  .beam.b2{left:38%;animation-delay:2s;transform:rotate(6deg);opacity:.7}
  .beam.b3{left:62%;animation-delay:4s;transform:rotate(-4deg);opacity:.8}
  .beam.b4{left:82%;animation-delay:1s;transform:rotate(14deg);opacity:.6}
  @keyframes beam-sway{
    0%,100%{transform:rotate(-15deg) translateX(0);opacity:.45}
    50%{transform:rotate(15deg) translateX(-30px);opacity:.85}
  }
  .beam.b2{animation-name:beam-sway-2}
  @keyframes beam-sway-2{
    0%,100%{transform:rotate(6deg);opacity:.5}
    50%{transform:rotate(-10deg);opacity:.9}
  }
  .beam.b3{animation-name:beam-sway-3}
  @keyframes beam-sway-3{
    0%,100%{transform:rotate(-4deg);opacity:.6}
    50%{transform:rotate(12deg);opacity:1}
  }
  .beam.b4{animation-name:beam-sway-4}
  @keyframes beam-sway-4{
    0%,100%{transform:rotate(14deg);opacity:.45}
    50%{transform:rotate(-8deg);opacity:.85}
  }

  /* 파티클(반짝임) */
  .sparkle{
    position:absolute;width:4px;height:4px;border-radius:50%;
    background:#FFFFFF;
    box-shadow:0 0 10px #FFFFFF, 0 0 20px #FFFFFF;
    animation:sparkle-pulse 3s ease-in-out infinite;
    pointer-events:none;z-index:2;
  }
  @keyframes sparkle-pulse{
    0%,100%{transform:scale(0);opacity:0}
    50%{transform:scale(1);opacity:1}
  }

  /* 커서 글로우 (데스크탑) */
  @media (hover: hover) and (pointer: fine){
    .cursor-glow{
      position:fixed;width:340px;height:340px;border-radius:50%;
      background:radial-gradient(circle, rgba(255,255,255,.1) 0%, transparent 65%);
      pointer-events:none;z-index:1;
      transform:translate(-50%,-50%);
      mix-blend-mode:screen;
      transition:width .25s, height .25s;
    }
  }

  /* 마퀴 (클라이언트 로고 무한 흐름) */
  .marquee-section{
    background:#08060C;
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    padding:50px 0;overflow:hidden;
  }
  .marquee{
    display:flex;gap:0;
    width:max-content;
    animation:marquee 36s linear infinite;
  }
  .marquee-item{
    padding:0 50px;
    font-family:var(--serif);font-size:32px;font-weight:600;
    color:var(--ink-2);letter-spacing:.04em;
    display:flex;align-items:center;gap:50px;
    white-space:nowrap;
  }
  .marquee-item::after{
    content:"+";color:var(--gold);font-size:18px;opacity:.6;
  }
  .marquee-item:hover{color:var(--gold)}
  @keyframes marquee{
    from{transform:translateX(0)}
    to{transform:translateX(-50%)}
  }

  /* 타임라인 */
  .timeline-section{background:#0B0B0B;border-top:1px solid var(--line)}
  .tl-wrap{position:relative;margin-top:60px;padding-left:40px}
  .tl-wrap::before{
    content:"";position:absolute;left:14px;top:14px;bottom:14px;width:1px;
    background:linear-gradient(180deg, var(--gold) 0%, transparent 100%);
  }
  .tl-row{
    display:grid;grid-template-columns:140px 1fr;gap:40px;
    padding:32px 0;position:relative;border-bottom:1px dashed var(--line);
    transition:background .3s;
  }
  .tl-row:hover{background:rgba(255,255,255,.025)}
  .tl-row::before{
    content:"";position:absolute;left:-32px;top:46px;width:10px;height:10px;border-radius:50%;
    background:var(--gold);box-shadow:0 0 14px var(--gold);
  }
  .tl-year{
    font-family:var(--serif);font-size:42px;font-weight:700;color:var(--gold);
    line-height:1;letter-spacing:-.01em;
    text-shadow:0 0 22px rgba(255,255,255,.2);
  }
  .tl-content h4{font-family:var(--serif);font-size:22px;color:#fff;margin-bottom:8px}
  .tl-content p{color:var(--ink-2);font-size:14px;line-height:1.7}
  .tl-content .tl-tags{margin-top:10px;display:flex;gap:6px;flex-wrap:wrap}
  .tl-content .tl-tags span{
    font-size:10px;letter-spacing:.14em;color:var(--gold);
    border:1px solid rgba(255,255,255,.2);padding:3px 9px;font-weight:600;
  }

  /* 베뉴 갤러리 */
  .venues{background:#0E0E0E;border-top:1px solid var(--line)}
  .venue-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:50px}
  .venue{
    aspect-ratio:3/4;
    background-color:#0a0a0a;
    background-size:cover;background-position:center;
    border:1px solid var(--line);
    padding:32px 24px;
    display:flex;flex-direction:column;justify-content:space-between;
    position:relative;overflow:hidden;
    transition:all .35s;cursor:default;
    filter:grayscale(100%) contrast(1.05) brightness(.85);
  }
  .venue:hover{filter:grayscale(0%) contrast(1.05) brightness(.95)}
  .venue::before{
    content:"";position:absolute;inset:0;
    background:linear-gradient(180deg, rgba(11,11,16,.25) 0%, rgba(11,11,16,.92) 100%);
    transition:all .3s;
  }
  .venue:hover{border-color:var(--gold);transform:translateY(-6px);box-shadow:0 25px 60px -20px rgba(255,255,255,.2)}
  .venue:hover::before{background:linear-gradient(180deg, rgba(11,11,16,.15) 0%, rgba(255,255,255,.2) 100%)}
  .venue-top{position:relative;z-index:2}
  .venue-num{
    font-family:var(--serif);font-style:italic;color:var(--gold);
    font-size:14px;letter-spacing:.1em;margin-bottom:14px;opacity:.8;
  }
  .venue-tag{
    display:inline-block;color:var(--ink-3);font-size:10px;
    letter-spacing:.18em;text-transform:uppercase;
  }
  .venue-bottom{position:relative;z-index:2}
  .venue h4{font-family:var(--serif);font-size:24px;color:#fff;line-height:1.2;margin-bottom:6px}
  .venue p{color:var(--gold);font-size:13px;font-style:italic;font-family:var(--serif)}

  /* 테스티모니얼 */
  .testimonials{background:#0B0B0B;border-top:1px solid var(--line)}
  .tm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:60px}
  .tm-card{
    background:linear-gradient(180deg, #161616, #0A0A0A);
    border:1px solid var(--line);
    padding:40px 32px;
    position:relative;
    transition:all .3s;
  }
  .tm-card:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:0 25px 60px -20px rgba(255,255,255,.12)}
  .tm-quote{
    font-family:var(--serif);font-style:italic;font-size:90px;
    color:var(--gold);line-height:.4;position:absolute;
    top:32px;left:28px;opacity:.4;
  }
  .tm-body{padding-top:38px}
  .tm-body p{
    color:var(--ink-1);font-size:15px;line-height:1.85;margin-bottom:30px;
    font-family:var(--serif);font-style:italic;
  }
  .tm-author{
    display:flex;align-items:center;gap:14px;
    border-top:1px solid var(--line);padding-top:22px;
  }
  .tm-avatar{
    width:46px;height:46px;border-radius:50%;
    background:linear-gradient(135deg, rgba(255,255,255,.15), rgba(255,255,255,.03));
    border:1px solid var(--gold);
    display:flex;align-items:center;justify-content:center;
    font-family:var(--serif);color:var(--gold);font-weight:700;
  }
  .tm-author b{color:#fff;font-family:var(--serif);font-size:16px;display:block;line-height:1.2}
  .tm-author span{color:var(--ink-3);font-size:12px;letter-spacing:.05em;display:block;margin-top:2px}

  /* FAQ */
  .faq-section{background:#0E0E0E;border-top:1px solid var(--line)}
  .faq-wrap{max-width:880px;margin:60px auto 0}
  .faq{
    border:1px solid var(--line);background:#141018;
    margin-bottom:14px;transition:all .3s;
  }
  .faq.open{border-color:var(--gold);background:#1a1a1a}
  .faq summary{
    list-style:none;cursor:pointer;
    padding:26px 30px;display:flex;justify-content:space-between;align-items:center;gap:24px;
    font-family:var(--serif);font-size:18px;color:#fff;font-weight:500;
  }
  .faq summary::-webkit-details-marker{display:none}
  .faq-q-num{color:var(--gold);font-style:italic;font-weight:600;margin-right:18px}
  .faq-toggle{
    width:32px;height:32px;border:1px solid var(--gold);color:var(--gold);
    display:flex;align-items:center;justify-content:center;font-size:18px;
    flex-shrink:0;transition:all .3s;
  }
  .faq[open] .faq-toggle{background:var(--gold);color:#fff;transform:rotate(45deg)}
  .faq-body{padding:0 30px 30px;color:var(--ink-2);line-height:1.85;font-size:15px}
  .faq-body strong{color:var(--gold)}

  /* 카운터 강조 */
  .num.counting b{display:inline-block}

  /* ============ YouTube 메인 영상 섹션 (Hero 바로 아래) ============ */
  .ytsec{
    background:linear-gradient(180deg, #0B0B0B 0%, #0E0E0E 100%);
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    padding:80px 0;
    overflow:hidden;
  }
  .yt-head{text-align:center;margin-bottom:40px}
  .yt-head .eyebrow{margin-bottom:14px;display:inline-flex}
  .yt-head .section-title{margin-bottom:14px}

  /* 영상 본체 — Lazy load 패턴 (썸네일 → 클릭 시 iframe) */
  .yt-video-wrap{
    max-width:980px;margin:0 auto;
  }
  .yt-video{
    position:relative;aspect-ratio:16/9;
    background-color:#000;
    background-size:cover;background-position:center;
    border:1px solid var(--line);
    overflow:hidden;cursor:pointer;
    box-shadow:0 30px 80px -20px rgba(0,0,0,.7);
    transition:transform .3s ease, box-shadow .3s ease;
  }
  .yt-video::before{
    content:"";position:absolute;inset:0;
    background:linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.55) 100%);
    transition:opacity .35s;pointer-events:none;
  }
  .yt-video:hover{transform:translateY(-4px);box-shadow:0 40px 100px -20px rgba(255,0,0,.3)}
  .yt-video:hover::before{opacity:.7}
  .yt-video:focus-visible{outline:2px solid #FF0000;outline-offset:4px}

  /* 큰 재생 버튼 (펄스 애니메이션) */
  .yt-video .yt-play-big{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    width:90px;height:90px;border-radius:50%;
    background:#FF0000;color:#fff;
    display:flex;align-items:center;justify-content:center;
    font-size:32px;transition:all .3s;z-index:2;
    box-shadow:0 0 0 0 rgba(255,0,0,.6);
    animation:pulse-yt 2.5s ease-out infinite;
  }
  @keyframes pulse-yt{
    0%{box-shadow:0 0 0 0 rgba(255,0,0,.6)}
    70%{box-shadow:0 0 0 30px rgba(255,0,0,0)}
    100%{box-shadow:0 0 0 0 rgba(255,0,0,0)}
  }
  .yt-video:hover .yt-play-big{transform:translate(-50%,-50%) scale(1.1);background:#cc0000}

  /* 영상 하단 라벨 (썸네일 위 오버레이) */
  .yt-video-overlay{
    position:absolute;left:24px;right:24px;bottom:24px;z-index:2;color:#fff;
  }
  .yt-badge{
    display:inline-block;background:#FF0000;color:#fff;
    font-size:11px;letter-spacing:.16em;font-weight:700;
    padding:6px 12px;margin-bottom:12px;
  }
  .yt-video-title{
    font-family:var(--serif);font-style:italic;font-weight:500;
    color:#fff;font-size:22px;line-height:1.3;
    text-shadow:0 4px 16px rgba(0,0,0,.7);
  }

  /* 영상 재생 활성화 상태 (iframe 표시) */
  .yt-video.playing .yt-play-big,
  .yt-video.playing .yt-video-overlay,
  .yt-video.playing::before{display:none}
  .yt-video.playing{cursor:default}
  .yt-video iframe{
    position:absolute;inset:0;width:100%;height:100%;border:0;
  }

  /* CTA 버튼 행 */
  .yt-cta-row{
    display:flex;justify-content:center;gap:14px;
    margin-top:36px;flex-wrap:wrap;
  }
  .yt-cta{
    display:inline-flex;align-items:center;gap:10px;
    padding:14px 26px;font-weight:600;font-size:13px;letter-spacing:.05em;
    transition:all .3s;text-decoration:none;
    word-break:keep-all;
  }
  .yt-cta-red{
    background:#FF0000;color:#fff;
    box-shadow:0 14px 32px -10px rgba(255,0,0,.4);
  }
  .yt-cta-red:hover{background:#cc0000;transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(255,0,0,.55)}
  .yt-cta-outline{
    background:transparent;color:#fff;border:1px solid var(--line);
  }
  .yt-cta-outline:hover{border-color:#fff;background:rgba(255,255,255,.04);transform:translateY(-2px)}
  .yt-cta .yt-play{
    width:24px;height:24px;background:#fff;color:#FF0000;
    display:flex;align-items:center;justify-content:center;
    border-radius:4px;font-size:11px;flex-shrink:0;
  }

  /* ========== 태블릿 ========== */
  @media (max-width: 960px){
    .ytsec{padding:64px 0}
    .yt-video .yt-play-big{width:72px;height:72px;font-size:26px}
    .yt-video-title{font-size:18px}
    .yt-video-overlay{left:18px;right:18px;bottom:18px}
  }

  /* ========== 모바일 — 풀폭 영상, 화면 가득 ========== */
  @media (max-width: 720px){
    .ytsec{padding:50px 0}
    .yt-head{margin-bottom:28px}
    .yt-video-wrap{margin:0 -20px} /* 양옆 패딩 무시하고 화면 폭 가득 */
    .yt-video{
      border-left:0;border-right:0;
      box-shadow:0 16px 40px -10px rgba(0,0,0,.7);
    }
    .yt-video .yt-play-big{width:62px;height:62px;font-size:22px}
    .yt-badge{font-size:10px;padding:5px 10px;margin-bottom:8px;letter-spacing:.12em}
    .yt-video-title{font-size:14px;line-height:1.35}
    .yt-video-overlay{left:14px;right:14px;bottom:14px}
    .yt-cta-row{gap:10px;margin-top:24px;padding:0 4px}
    .yt-cta{padding:12px 18px;font-size:12px;flex:1 1 auto;justify-content:center;min-width:0;min-height:46px}
    .yt-cta .yt-play{width:20px;height:20px;font-size:10px}
  }

  /* ========== 초소형 모바일 ========== */
  @media (max-width: 400px){
    .yt-video .yt-play-big{width:54px;height:54px;font-size:20px}
    .yt-cta-row{flex-direction:column}
    .yt-cta{width:100%}
  }

  /* ============ SNS 바로가기 큰 카드 ============ */
  .channels{background:#0B0B0B;border-top:1px solid var(--line)}
  .ch-head{text-align:center;margin-bottom:50px}
  .ch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .ch-card{
    background:linear-gradient(180deg, #161616, #0A0A0A);
    border:1px solid var(--line);
    padding:42px 32px 36px;
    display:flex;flex-direction:column;justify-content:space-between;
    min-height:280px;
    transition:all .35s;
    position:relative;overflow:hidden;
    text-decoration:none;color:inherit;
  }
  .ch-card::before{
    content:"";position:absolute;inset:0;
    opacity:0;transition:opacity .35s;
    pointer-events:none;
  }
  .ch-card.yt::before{background:radial-gradient(circle at 50% 0%, rgba(255,0,0,.22), transparent 65%)}
  .ch-card.bl::before{background:radial-gradient(circle at 50% 0%, rgba(3,199,90,.22), transparent 65%)}
  .ch-card.kk::before{background:radial-gradient(circle at 50% 0%, rgba(254,229,0,.22), transparent 65%)}
  .ch-card:hover{transform:translateY(-6px);box-shadow:0 25px 60px -20px rgba(0,0,0,.6)}
  .ch-card:hover::before{opacity:1}
  .ch-card.yt:hover{border-color:#FF0000}
  .ch-card.bl:hover{border-color:#03C75A}
  .ch-card.kk:hover{border-color:#FEE500}

  .ch-icon-wrap{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}
  .ch-icon{
    width:64px;height:64px;
    display:flex;align-items:center;justify-content:center;
    border-radius:14px;font-size:30px;font-weight:700;
    transition:all .3s;
  }
  .ch-card.yt .ch-icon{background:#FF0000;color:#fff}
  .ch-card.bl .ch-icon{background:#03C75A;color:#fff}
  .ch-card.kk .ch-icon{background:#FEE500;color:#181600}
  .ch-arrow{
    width:36px;height:36px;border-radius:50%;
    border:1px solid var(--line);
    display:flex;align-items:center;justify-content:center;
    color:var(--ink-2);transition:all .3s;font-size:18px;
  }
  .ch-card:hover .ch-arrow{transform:translate(4px,-4px);border-color:#fff;color:#fff}

  .ch-body{position:relative;z-index:2}
  .ch-card .ch-platform{
    font-family:var(--serif);font-style:italic;font-size:14px;
    color:var(--ink-3);letter-spacing:.06em;margin-bottom:8px;
  }
  .ch-card h3{
    font-family:var(--serif);font-size:24px;color:#fff;
    margin-bottom:10px;line-height:1.3;
  }
  .ch-card p{
    color:var(--ink-2);font-size:13px;line-height:1.7;
  }
  .ch-handle{
    margin-top:14px;padding-top:14px;border-top:1px solid var(--line);
    color:#fff;font-family:'Courier New',monospace;font-size:12px;
    letter-spacing:.04em;word-break:break-all;
  }
  .ch-card.yt:hover .ch-handle{color:#FF6B6B}
  .ch-card.bl:hover .ch-handle{color:#03C75A}
  .ch-card.kk:hover .ch-handle{color:#FEE500}

  @media (max-width: 960px){
    .ch-grid{grid-template-columns:1fr;gap:14px}
    .ch-card{min-height:220px;padding:32px 26px 28px}
  }
  @media (max-width: 720px){
    .ch-grid{gap:12px}
    .ch-card{min-height:auto;padding:26px 22px 24px}
    .ch-icon{width:52px;height:52px;font-size:24px}
    .ch-card h3{font-size:19px}
    .ch-card p{font-size:13px}
    .ch-icon-wrap{margin-bottom:22px}
  }

  /* ----------- RESPONSIVE (tablet) ----------- */
  @media (max-width: 960px){
    .menu{display:none}
    .hamburger{display:block}
    section{padding:90px 0}
    h2.section-title{font-size:clamp(34px,5.4vw,52px)}
    .about-grid,.ct-grid{grid-template-columns:1fr;gap:50px}
    /* 좁은 화면·모바일에서 행사 문의 폼을 먼저 노출, 회사 정보는 아래로 이동 */
    .ct-grid .form-block{order:1}
    .ct-grid .ct-left{order:2}
    .values-grid,.svc-grid,.pf-grid,.news-grid,.tm-grid{grid-template-columns:repeat(2,1fr)}
    .proc-grid{grid-template-columns:repeat(2,1fr);gap:40px}
    .proc-grid::before{display:none}
    .art-grid{grid-template-columns:repeat(3,1fr)}
    .num-grid{grid-template-columns:1fr;gap:50px}
    .num+.num::before{display:none}
    .aud-grid{grid-template-columns:1fr}
    .ft-grid{grid-template-columns:1fr 1fr;gap:40px}
    .form-row{grid-template-columns:1fr}
    .form-block{padding:36px 28px}
    .hero-meta{flex-direction:column;align-items:flex-start;gap:18px}
    .hero-meta-r{gap:20px}
    .venue-grid{grid-template-columns:repeat(3,1fr)}
    .pf-grid > .pf-card.feature{grid-column:span 2}
    .hero-dots{bottom:90px}
    .tl-row{grid-template-columns:90px 1fr;gap:24px}
    .tl-year{font-size:30px}
    .marquee-item{font-size:24px;padding:0 32px;gap:32px}
  }

  /* ----------- RESPONSIVE (mobile · 핵심 가독성) ----------- */
  @media (max-width: 720px){
    /* 전체 와이드/패딩 ↓ + 가로 오버플로우 차단 */
    html,body{max-width:100vw;overflow-x:hidden}
    .wrap{padding:0 20px;max-width:100%}
    section{padding:60px 0;overflow:hidden}
    img,svg,video,iframe{max-width:100%;height:auto}

    /* 타이포그래피 — 한국어 가독성 우선 (글 날림 방지) */
    h2.section-title{font-size:28px;line-height:1.25;margin-bottom:18px;word-break:keep-all;overflow-wrap:break-word;letter-spacing:-.003em;hyphens:auto}
    h2.section-title em{display:inline;line-height:1.25}
    h2.section-title br{display:none}
    .eyebrow{font-size:11px;letter-spacing:.16em;margin-bottom:14px}
    .eyebrow::before{width:24px}
    .section-sub{font-size:14px;line-height:1.8;margin-bottom:32px;word-break:keep-all;overflow-wrap:break-word;max-width:100%;padding:0 4px}

    /* NAV — 컴팩트, 클릭 영역 확보 */
    .nav{padding:12px 16px}
    .nav.scrolled{padding:10px 16px}
    .logo-mark{width:34px;height:34px;font-size:14px}
    .logo b{font-size:15px}
    .logo span{font-size:9px;letter-spacing:.16em}

    /* 회사소개서 다운로드 버튼 — 모바일 최적화 */
    .btn-brochure .brochure-icon{font-size:16px}
    .brochure-hint{
      font-size:11px;text-align:center;margin-top:10px;line-height:1.5;
    }

    /* 개인정보 동의 영역 — 모바일 가독성 */
    .privacy-consent{margin-top:20px;padding-top:20px}
    .consent-text{font-size:13px;line-height:1.6}
    .consent-text b{font-size:13px}
    .consent-text a{font-size:11px;margin-left:6px}
    .consent-check{width:18px;height:18px;margin-top:1px}
    .privacy-detail.open{padding:14px;margin-top:12px}
    .privacy-detail p{font-size:11.5px;line-height:1.75}

    /* SNS 채널 카드 — 모바일에서 더 컴팩트 */
    .ch-grid{gap:12px;grid-template-columns:1fr}
    .ch-card{padding:24px 20px}
    .ch-card h3{font-size:18px;line-height:1.35}
    .ch-card p{font-size:13px}
    .ch-handle{font-size:11px;margin-top:12px;padding-top:12px}
    .ch-icon{width:48px;height:48px;font-size:22px;border-radius:12px}
    .ch-icon-wrap{margin-bottom:20px}

    /* Footer 로고 — 모바일에서 살짝 작게 */
    .ft-logo-img{height:64px}

    /* HERO — 핵심: 한 줄에 안 잘리게 + 명확한 줄바꿈 */
    .hero{padding:110px 0 80px;min-height:auto}
    .hero-tag{padding:6px 12px;font-size:10px;letter-spacing:.12em;margin-bottom:22px;word-break:keep-all;white-space:normal}
    .hero h1{
      font-size:34px;line-height:1.2;letter-spacing:-.01em;
      word-break:keep-all;overflow-wrap:break-word;
      max-width:100%;
    }
    .hero h1 em{
      font-size:32px;margin-top:4px;display:block;line-height:1.2;
      word-break:keep-all;
    }
    .hero-line{width:50px;margin:22px 0 14px}
    .hero-sub{font-size:11px;letter-spacing:.12em;margin-bottom:20px;word-break:keep-all;line-height:1.5}
    .hero-desc{
      font-size:14.5px;line-height:1.8;margin-bottom:32px;
      word-break:keep-all;overflow-wrap:break-word;
      max-width:100%;padding:0;
    }
    .hero-desc br{display:none}
    .hero-cta{flex-direction:column;align-items:stretch;gap:10px}
    .btn{padding:14px 20px;font-size:12px;letter-spacing:.08em;justify-content:center;word-break:keep-all;min-height:48px;align-items:center}
    .hero-meta{display:none}
    .hero-dots{bottom:24px;gap:8px;left:50%;transform:translateX(-50%)}
    .hero-dot{width:16px;height:2px}
    .hero-dot.active{width:28px}

    /* 빔/파티클은 모바일에선 숨김 — 가독성 향상 */
    .stage-lights, .sparkle, .hero-cross{display:none}

    /* GRID — 1컬럼으로 깔끔히 */
    .values-grid,.svc-grid,.pf-grid,.news-grid,.tm-grid{grid-template-columns:1fr;gap:1px}
    .pf-grid{gap:18px}
    .proc-grid,.art-grid{grid-template-columns:repeat(2,1fr);gap:24px}
    .ft-grid{grid-template-columns:1fr;gap:36px}
    .venue-grid{grid-template-columns:repeat(2,1fr);gap:10px}

    /* ABOUT — 사진 비율 조정 */
    .about-img-block{aspect-ratio:4/3}
    .about-img-block::after{font-size:20px;bottom:24px;left:20px}
    .about-body p{font-size:14px;line-height:1.85;word-break:keep-all}
    .vision-block{padding:24px 20px;margin-top:30px}
    .vision-block p{font-size:17px;line-height:1.55}

    /* VALUES — 컴팩트 */
    .value{padding:0 0 28px}
    .value-img{aspect-ratio:3/2}
    .value-body{padding:0 24px}
    .value-letter{font-size:48px;margin-bottom:10px}
    .value h3{font-size:20px}
    .value-kr{font-size:12px;margin-bottom:12px}
    .value p{font-size:13px;line-height:1.7}
    .values-foot{font-size:14px;margin-top:36px}

    /* SERVICES */
    .svc{padding:36px 24px;min-height:auto}
    .svc h3{font-size:22px}
    .svc-en{font-size:13px;margin-bottom:14px}
    .svc p{font-size:13px;line-height:1.7}
    .svc-head{margin-bottom:36px}
    .svc-head-r{font-size:14px;line-height:1.75}

    /* NUMBERS */
    .num{padding:20px 12px}
    .num b{font-size:64px}
    .num span{font-size:15px;margin-top:6px}
    .num small{font-size:10px;margin-top:4px}
    .num-head p{font-size:14px}
    .num-note{font-size:11px;margin-top:28px}

    /* PROCESS */
    .proc-step{padding:0 8px}
    .proc-circle{width:60px;height:60px;font-size:22px;margin-bottom:18px}
    .proc-step h4{font-size:16px;margin-bottom:8px}
    .proc-step p{font-size:12px;line-height:1.65}

    /* PORTFOLIO */
    .pf-head{margin-bottom:30px}
    .pf-filters{gap:6px;justify-content:flex-start}
    .pf-filter{padding:7px 13px;font-size:11px;letter-spacing:.06em}
    .pf-thumb{aspect-ratio:16/10}
    .pf-thumb-en{font-size:17px;padding:0 18px 18px;line-height:1.3}
    .pf-thumb-cat{font-size:10px;padding:4px 9px;letter-spacing:.14em}
    .pf-thumb-year{font-size:11px;padding:4px 8px}
    .pf-body{padding:22px 20px 24px}
    .pf-body h4{font-size:18px;line-height:1.4;word-break:keep-all}
    .pf-client{font-size:12px;margin-bottom:10px}
    .pf-info{font-size:11px;line-height:1.6}
    .pf-grid > .pf-card.feature{grid-column:span 1}
    .pf-grid > .pf-card.feature .pf-thumb{aspect-ratio:16/10}
    .pf-grid > .pf-card.feature .pf-thumb-en{font-size:18px;padding:0 18px 18px}
    .pf-grid > .pf-card.feature .pf-body h4{font-size:18px}
    .pf-grid > .pf-card.feature .pf-body{padding:22px 20px 24px}
    .pf-grid > .pf-card.feature::before{right:14px;top:14px;font-size:9px;padding:4px 9px}

    /* VENUES */
    .venue{aspect-ratio:4/5;padding:20px 16px}
    .venue h4{font-size:16px;line-height:1.2}
    .venue p{font-size:11px}
    .venue-num{font-size:12px;margin-bottom:10px}
    .venue-tag{font-size:9px;letter-spacing:.14em}

    /* TIMELINE */
    .tl-wrap{padding-left:22px;margin-top:36px}
    .tl-wrap::before{left:10px}
    .tl-row{grid-template-columns:1fr;gap:6px;padding:22px 0}
    .tl-row::before{left:-19px;top:30px;width:8px;height:8px}
    .tl-year{font-size:24px}
    .tl-content h4{font-size:17px;line-height:1.4;word-break:keep-all}
    .tl-content p{font-size:13px;line-height:1.65}
    .tl-content .tl-tags span{font-size:9px;padding:2px 7px}

    /* MARQUEE — 모바일에선 더 천천히, 작게 */
    .marquee-section{padding:28px 0}
    .marquee{animation-duration:48s}
    .marquee-item{font-size:15px;padding:0 14px;gap:14px;white-space:nowrap}
    .marquee-item::after{font-size:11px}

    /* ARTISTS */
    .artist{padding:24px 14px}
    .artist-avatar{width:60px;height:60px;font-size:22px;margin-bottom:12px}
    .artist b{font-size:15px}
    .artist span{font-size:10px}

    /* NEWS */
    .news-card{padding:32px 22px}
    .news-card h4{font-size:17px;line-height:1.45;margin-bottom:14px;word-break:keep-all}
    .news-card p{font-size:13px;line-height:1.7;margin-bottom:18px}
    .news-meta{font-size:11px}

    /* TESTIMONIALS */
    .tm-card{padding:32px 24px}
    .tm-quote{font-size:64px;top:24px;left:20px}
    .tm-body{padding-top:28px}
    .tm-body p{font-size:14px;line-height:1.8;margin-bottom:22px;word-break:keep-all}
    .tm-author b{font-size:14px}
    .tm-author span{font-size:11px}
    .tm-avatar{width:40px;height:40px}

    /* FAQ */
    .faq-wrap{margin-top:36px}
    .faq summary{padding:20px 22px;font-size:15px;gap:14px}
    .faq-q-num{margin-right:10px;font-size:14px}
    .faq-toggle{width:26px;height:26px;font-size:15px}
    .faq-body{padding:0 22px 22px;font-size:13px;line-height:1.8;word-break:keep-all}

    /* AUDITION */
    .aud-card{padding:36px 24px}
    .aud-card h3{font-size:24px;margin-bottom:14px;line-height:1.3}
    .aud-card p{font-size:14px;line-height:1.75;margin-bottom:22px;word-break:keep-all}
    .aud-list li{font-size:13px;padding:9px 0 9px 20px}
    .aud-eyebrow{font-size:12px;margin-bottom:12px}

    /* CONTACT */
    .contact{padding:80px 0}
    .ct-left h2{font-size:42px;margin-bottom:22px}
    .ct-left .ct-desc{font-size:14px;line-height:1.8;margin-bottom:34px;word-break:keep-all}
    .ct-left .ct-desc br{display:none}
    .ct-info-row{grid-template-columns:84px 1fr;gap:14px;padding:14px 0}
    .ct-info-row b{font-size:12px}
    .ct-info-row span,.ct-info-row a{font-size:14px}
    .form-block{padding:30px 22px}
    .form-block h3{font-size:22px;margin-bottom:6px}
    .form-block .form-sub{font-size:12px;margin-bottom:24px;line-height:1.7}
    .field label{font-size:10px;letter-spacing:.14em}
    .field input,.field select,.field textarea{padding:12px 14px;font-size:14px}
    .form-cta{flex-direction:column}
    .form-cta .btn{width:100%}
    .form-note{font-size:11px;line-height:1.65}

    /* FOOTER */
    footer{padding:60px 0 24px}
    .ft-brand{font-size:26px}
    .ft-brand em{font-size:18px}
    .ft-tagline{font-size:13px;line-height:1.75;word-break:keep-all}
    .ft h5{font-size:11px;letter-spacing:.14em;margin-bottom:18px}
    .ft ul a{font-size:13px}
    .ft p.ft-line{font-size:12px;line-height:1.85}
    .ft-bottom{font-size:11px;flex-direction:column;gap:10px;text-align:left}

    /* FLOATING — 위치 조정 */
    .floats{right:14px;bottom:14px;gap:10px}
    .float-btn{width:50px;height:50px}
    .float-btn span:first-child{font-size:18px !important}
    .float-btn span:last-child{font-size:8px !important;margin-top:1px !important}
    .float-label{display:none}
  }

  /* ----------- 초소형 모바일 (iPhone SE 등) ----------- */
  @media (max-width: 400px){
    .wrap{padding:0 16px}
    .hero{padding:100px 0 70px}
    .hero h1{font-size:28px;line-height:1.22}
    .hero h1 em{font-size:26px}
    .hero-desc{font-size:14px;line-height:1.75}
    .hero-tag{font-size:9px;padding:5px 10px}
    .num b{font-size:50px}
    h2.section-title{font-size:24px;line-height:1.28}
    .section-sub{font-size:13.5px;line-height:1.75}
    .proc-grid,.art-grid{grid-template-columns:1fr}
    .pf-thumb-en{font-size:15px;padding:0 14px 14px}
    .pf-body h4{font-size:16px}
    .news-card h4{font-size:16px}
    .tm-body p{font-size:13.5px}
    .faq summary{font-size:14px;padding:18px 18px}
    .ct-left h2{font-size:34px}
    .aud-card h3{font-size:22px}
    .form-block h3{font-size:20px}
    .btn{font-size:11.5px;padding:13px 18px}
    .num span{font-size:14px}
    .marquee-item{font-size:13.5px;padding:0 12px;gap:12px}
    .proc-circle{width:54px;height:54px;font-size:20px}
    .proc-step h4{font-size:15px}
    .proc-step p{font-size:12px}
    .artist-avatar{width:54px;height:54px;font-size:20px}
    .artist b{font-size:14px}
  }
