/* ===== style.css — 서브페이지 공용 기본 스타일 ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --ink:#050504;--ink-2:#0A0907;--ink-3:#111009;--ink-4:#1A1814;
  --gold:#BFA46A;--gold-b:#D4BA82;
  --ivory:#F2EDE4;--stone:#8C8578;--stone-l:#AFA79D;
  --line:rgba(191,164,106,.1);
  --ff-title:'Black Han Sans',sans-serif;
  --ff-en:'Bebas Neue',sans-serif;
  --ff-body:'Pretendard',sans-serif;
}
html{scroll-behavior:auto;overflow-x:hidden;cursor:none}
body{font-family:var(--ff-body);background:var(--ink);color:var(--ivory);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:none;border:none;background:none;color:inherit}
ul{list-style:none}

/* ===== CURSOR ===== */
#cur{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;mix-blend-mode:difference}
#cur-ring{width:44px;height:44px;border:1.5px solid var(--ivory);border-radius:50%;position:absolute;top:-22px;left:-22px;transition:width .25s,height .25s,top .25s,left .25s,border-color .25s}
#cur-dot{width:5px;height:5px;background:var(--gold);border-radius:50%;position:absolute;top:-2.5px;left:-2.5px}
#cur.hover #cur-ring{width:72px;height:72px;top:-36px;left:-36px;border-color:var(--gold)}

/* ===== SCROLL PROGRESS ===== */
#progressBar{position:fixed;top:0;left:0;height:2px;background:var(--gold);z-index:9997;width:0%}

/* ===== NAVIGATION ===== */
#nav{position:fixed;top:0;left:0;width:100%;z-index:9000;padding:0 clamp(1.5rem,4vw,4rem);height:72px;display:flex;align-items:center;justify-content:space-between;background:rgba(5,5,4,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.nav-logo{font-family:var(--ff-title);font-size:1.3rem;letter-spacing:-0.02em}
.nav-logo span{color:var(--gold)}
.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{font-size:.85rem;letter-spacing:.04em;color:var(--stone-l);transition:color .3s}
.nav-links a:hover{color:var(--ivory)}
.nav-link-drop{position:relative}
.nav-link-drop > a{position:relative;z-index:2;cursor:pointer}
.nav-link-drop .drop{position:absolute;top:100%;left:50%;transform:translateX(-50%);background:var(--ink-4);border:1px solid var(--line);border-radius:8px;padding:.75rem 0;min-width:160px;opacity:0;visibility:hidden;transition:opacity .3s,transform .3s;transform:translateX(-50%) translateY(8px);margin-top:0;z-index:1}
.nav-link-drop .drop::before{content:'';position:absolute;top:-16px;left:0;right:0;height:16px;pointer-events:none}
.nav-link-drop:hover .drop,.nav-link-drop.touch-open .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop a{display:block;padding:.45rem 1.25rem;font-size:.82rem;white-space:nowrap}
.drop a:hover{color:var(--gold)}
.nav-cta{background:var(--gold);color:var(--ink);padding:.55rem 1.5rem;border-radius:100px;font-size:.82rem;font-weight:600;letter-spacing:.03em;transition:background .3s}
.nav-cta:hover{background:var(--gold-b)}
/* ===== NAV MEMBER BUTTON ===== */
.nav-member{display:flex;align-items:center;gap:.6rem;margin-right:.8rem}
.nav-member-btn{display:inline-flex;align-items:center;gap:.4rem;border:1px solid var(--gold);color:var(--gold);padding:.45rem 1.2rem;border-radius:100px;font-size:.78rem;font-weight:500;letter-spacing:.02em;transition:all .3s;white-space:nowrap}
.nav-member-btn:hover{background:var(--gold);color:var(--ink)}
.nav-member-btn i{font-size:.72rem}
.nav-member-name{display:inline-flex;align-items:center;gap:.4rem;color:var(--gold);font-size:.82rem;font-weight:500;white-space:nowrap}
.nav-member-name i{font-size:.9rem}
.nav-member-logout{font-size:.75rem;color:var(--stone-l);transition:color .3s;white-space:nowrap}
.nav-member-logout:hover{color:var(--ivory)}
/* Mobile member */
.mob-member-divider{width:40px;height:1px;background:var(--line);margin:0 auto}
.mob-member{display:flex;flex-direction:column;align-items:center;gap:.8rem}
.mob-member-signup{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--gold);color:var(--gold);padding:.6rem 1.8rem;border-radius:100px;font-family:var(--ff-body);font-size:.9rem;font-weight:500;transition:all .3s}
.mob-member-signup:hover{background:var(--gold);color:var(--ink)}
.mob-member-name{color:var(--gold);font-size:.95rem;font-weight:500}
.mob-member-name i{margin-right:.3rem}
.mob-member-logout{font-size:.82rem;color:var(--stone-l);transition:color .3s}
.mob-member-logout:hover{color:var(--ivory)}

.hamburger{display:none;flex-direction:column;gap:6px;cursor:none;width:28px;z-index:9002}
.hamburger span{display:block;height:2px;background:var(--ivory);transition:transform .4s,opacity .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}
.mob-menu{position:fixed;inset:0;background:var(--ink);z-index:9001;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;clip-path:circle(0% at calc(100% - 3rem) 2.25rem);transition:clip-path .6s cubic-bezier(.77,0,.175,1)}
.mob-menu.open{clip-path:circle(150% at calc(100% - 3rem) 2.25rem)}
.mob-menu a{font-family:var(--ff-title);font-size:clamp(1.5rem,5vw,2.5rem);color:var(--ivory);transition:color .3s}
.mob-menu a:hover{color:var(--gold)}

/* ===== FOOTER ===== */
footer{background:var(--ink);border-top:1px solid var(--line);padding:3rem clamp(1.5rem,4vw,4rem);text-align:center}
.ft-logo{font-family:var(--ff-title);font-size:1.1rem;margin-bottom:.5rem}
.ft-slogan{font-size:.8rem;color:var(--stone);margin-bottom:1rem}
.ft-copy{font-size:.7rem;color:var(--stone)}

/* ===== REVEAL ===== */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .8s,transform .8s}
[data-reveal].revealed{opacity:1;transform:translateY(0)}

/* ===== MOBILE — GLOBAL ===== */
@media(max-width:768px){
  html{cursor:auto}
  body{cursor:auto;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;overflow-x:hidden}
  a,button{cursor:pointer}
  #cur{display:none!important}
  .nav-links{display:none}
  .nav-cta{display:none}
  .hamburger{display:flex}
  #nav{height:60px;padding:0 1rem}
  .nav-logo{font-size:1.15rem}
  footer{padding:2rem 1.25rem}
  .ft-logo{font-size:1rem}
  /* Touch-friendly tap targets — min 44px */
  .mob-menu a{padding:.75rem 1rem;min-height:48px;display:flex;align-items:center;justify-content:center;font-size:clamp(1.3rem,4.5vw,2rem)}
  .faq-q,.notice-q{min-height:48px;padding:1rem 0}
  /* Safe area for bottom-notch devices */
  footer{padding-bottom:max(2rem,env(safe-area-inset-bottom))}
  /* Global overflow protection */
  main,section{overflow-x:hidden}
  img{max-width:100%;height:auto}
  /* Better mobile menu spacing */
  .mob-menu{gap:1rem;padding:0 2rem}
  /* Nav member hide on mobile (pages.js handles mob-member) */
  .nav-member{display:none}
  /* Smooth scrolling for iOS momentum */
  .gen-modal,.faq-container{-webkit-overflow-scrolling:touch}
  /* Prevent text selection on interactive elements */
  button,.gen-card,.faq-page-q,.notice-q,.gm-faq-q{-webkit-user-select:none;user-select:none}
  /* Better touch feedback */
  .gen-card:active,.tx-card-item:active,.ba-card:active,.blog-card:active{transform:scale(.98);transition:transform .1s}
  /* Prevent horizontal scroll from any element */
  *{max-width:100vw}
  pre,code,table{max-width:100%;overflow-x:auto}
}
@media(max-width:480px){
  #nav{height:56px}
  footer{padding:1.5rem 1rem;padding-bottom:max(1.5rem,env(safe-area-inset-bottom))}
  .ft-biz{font-size:.65rem}
  .mob-menu a{font-size:1.2rem;min-height:44px}
}
