/* ======================= styles.css (FULL / CLEAN) ======================= */
/* 목표:
   - 섹션 순서: 변수/리셋/탑바/레이아웃/좌측/메인/우측/오버레이/반응형/하단바/모달/시트/접근성
   - bottomNav(하단 고정바) 때문에 좌측 하단(텔레배너) 가려지는 문제 해결 (safe-area 포함)
   - authOnly/guestOnly 표시 로직 정상화
   - MY 텍스트 대비(다크/라이트) 정리
   - THEBET 배지 라이트 모드 가독성 보강
*/

/* ======================= TOKENS (DARK DEFAULT) ======================= */
:root{
  /* ===== Base colors (Dark) ===== */
  --bg:#0b0d12;
  --text:#e8eefc;
  --muted:rgba(232,238,252,.68);
  --line:rgba(255,255,255,.10);

  --panel:rgba(255,255,255,.03);
  --shadow:0 22px 70px rgba(0,0,0,.55);

  --brand:#c8a15a;   /* gold */
  --brand2:#e50914;  /* red */

  /* ===== Layout ===== */
  --sideW:260px;
  --rightW:260px;
  --topH:64px;
  --maxW:1440px;

  /* ===== Side look ===== */
  --side-bg:linear-gradient(180deg, rgba(18,19,24,.92), rgba(12,13,18,.82));
  --side-text:var(--text);
  --side-muted:rgba(232,238,252,.68);
  --side-item-bg:rgba(255,255,255,.04);
  --side-item-active:rgba(200,161,90,.14);

  /* ===== Fonts ===== */
  --font: system-ui,-apple-system,"Noto Sans KR","Segoe UI",Roboto,Arial,sans-serif;

  /* ===== Bottom nav (single source of truth) ===== */
  --bottomNavH: 86px;                   /* 필요시 78~96 조절 */
  --safeB: env(safe-area-inset-bottom, 0px);
}

/* ======================= LIGHT THEME OVERRIDES ======================= */
[data-theme="light"]{
  --bg:#f7f5f0;

  --text:#0b1220;
  --muted:rgba(11,18,32,.65);
  --line:rgba(2,6,23,.12);

  --panel:rgba(255,255,255,.88);
  --shadow:0 18px 60px rgba(2,6,23,.10);

  --brand:#b08a3c;
  --brand2:#e50914;

  --side-bg:linear-gradient(180deg, rgba(255,255,255,.94), rgba(246,244,238,.92));
  --side-text:#0b1220;
  --side-muted:rgba(11,18,32,.62);
  --side-item-bg:rgba(2,6,23,.04);
  --side-item-active:rgba(176,138,60,.14);
}

/* ======================= RESET / BASE ======================= */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
img{max-width:100%;display:block}
.muted{color:var(--muted)}
.grow{flex:1}

/* ======================= TOPBAR ======================= */
.topbar{
  position:sticky; top:0; z-index:50;
  height:var(--topH);
  border-bottom:1px solid var(--line);
  backdrop-filter: blur(10px);
  background:rgba(10,10,12,.66);
}
[data-theme="light"] .topbar{background:rgba(255,255,255,.78)}

.topbar .inner{
  max-width:var(--maxW);
  margin:0 auto;
  height:100%;
  padding:0 12px;
  display:flex;
  align-items:center;
  gap:10px;
}



/* top tabs */
.tabs{
  display:flex; gap:6px;
  padding:6px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  overflow:auto;
  scrollbar-width:none;
}
.tabs::-webkit-scrollbar{display:none}
.tab{
  padding:10px 12px;border-radius:999px;
  color:var(--muted);
  font-weight:900;
  white-space:nowrap;
}
.tab.is-active{
  color:var(--text);
  background:rgba(200,161,90,.18);
  border:1px solid rgba(200,161,90,.30);
}

/* right actions */
.rightActions{display:flex;align-items:center;gap:10px}
.btn{
  padding:10px 12px;border-radius:12px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--text);
  font-weight:900;
  cursor:pointer;
}

/* theme toggle */
.modeToggle{
  width:44px;height:44px;
  display:grid;place-items:center;
  padding:0;border-radius:14px;

  /* ❌ 기존 두꺼운 테두리 제거 */
  border:1px solid rgba(255,255,255,.15);
  background:transparent;

  box-shadow:none;
}

/* hover / active 시 종 버튼과 동일하게 */
.modeToggle:hover{
  background:rgba(255,255,255,.06);
}

[data-theme="light"] .modeToggle{
  border:1px solid rgba(0,0,0,.15);
}

.modeIcon{font-size:18px;line-height:1}

/* icon button */
.iconBtn{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--text);
  border-radius:12px;
  padding:10px 12px;
  cursor:pointer;
}

/* hamburger */
.hamburger{
  display:none;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  width:44px;height:44px;
  padding:0;
}
.hamburger span{
  display:block;
  width:18px;height:2px;
  background:var(--text);
  margin:2px 0;
  border-radius:2px;
  transition:transform .2s ease, opacity .2s ease;
}
.hamburger.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.hamburger.is-open span:nth-child(2){opacity:0}
.hamburger.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ✅ 로그인 전/후 표시 제어 (정상화) */
.authOnly{display:none}
body.is-auth .authOnly{display:block}
body.is-auth #guestOnly{display:none}

/* MY orb */
.userOrb{
  position:relative;
  width:42px;height:42px;border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  display:grid;place-items:center;
  cursor:pointer;
  overflow:hidden;
}
[data-theme="light"] .userOrb{
  border-color:rgba(2,6,23,.14);
  background:rgba(2,6,23,.03);
}
.userOrbRing{
  position:absolute;inset:-3px;
  border-radius:50%;
  background:conic-gradient(from 0deg,
    rgba(200,161,90,.0),
    rgba(200,161,90,.65),
    rgba(229,9,20,.35),
    rgba(200,161,90,.0)
  );
  filter:blur(.2px);
  animation:orbSpin 2.8s linear infinite;
  opacity:.95;
}
@keyframes orbSpin{to{transform:rotate(360deg)}}

.userOrbText{
  position:relative;
  z-index:2;
  font-weight:1000;
  font-size:13px;
  letter-spacing:.08em;
  pointer-events:none;
  opacity:.88;
  color:rgba(232,238,252,.85);
}
.userOrb:hover .userOrbText{opacity:1}
[data-theme="light"] .userOrbText{
  color:#0b1220;
  opacity:.92;
}

/* 1400px 이상: 우측 내정보 패널이 보이므로 MY 버튼 숨김 */
@media (min-width: 1400px){
  body.is-auth .userOrb{display:none;}
}

/* 1400px 이상: 우측 패널에서만 처리(상단 로그인/회원가입 & MY 숨김) */
@media (min-width: 1400px){
  #guestOnly{display:none !important;}
  #authOnly{display:none !important;}
}

/* ======================= LAYOUT ======================= */
/* ✅ 핵심: bottomNav가 fixed로 떠도 컨텐츠/사이드바가 안 가리도록 "공통 하단 여백"을 확보 */
.content{
  max-width:var(--maxW);
  margin:0 auto;
  padding:14px;
  padding-bottom: calc(14px + var(--bottomNavH) + var(--safeB));
  display:grid;
  grid-template-columns: var(--sideW) minmax(0, 1fr) var(--rightW);
  gap:14px;
}

/* ======================= SIDEBAR ======================= */
.sidebar{
  position:sticky;
  top:calc(var(--topH) + 14px);

  /* ✅ bottomNav 공간만큼 빼서 "텔레 배너" 절대 안 가려지게 */
  height: calc(100vh - var(--topH) - 28px - var(--bottomNavH) - var(--safeB));

  border:1px solid var(--line);
  border-radius:18px;
  background:var(--side-bg);
  box-shadow:var(--shadow);
  overflow:hidden;
  color:var(--side-text);

  display:flex;
  flex-direction:column;
}

/* 사이드바 내부 스크롤 영역 */
.tree{
  padding:12px;
  overflow:auto;
  flex:1;
}

/* 사이드바 하단 고정 영역(텔레 배너 등) */
.sideBottom{
  padding:10px 12px 12px;
  border-top:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.16));
}
[data-theme="light"] .sideBottom{
  border-top-color:rgba(2,6,23,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.0), rgba(2,6,23,.04));
}

/* 텔레그램 배너 버튼 */
.tgBanner{
  display:block;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 14px 34px rgba(0,0,0,.22);
  transform:translateY(0);
  transition:transform .15s ease, filter .15s ease, border-color .15s ease;
}
[data-theme="light"] .tgBanner{
  border-color:rgba(2,6,23,.12);
  box-shadow:0 14px 30px rgba(2,6,23,.10);
}
.tgBanner:hover{
  transform:translateY(-1px);
  border-color:rgba(200,161,90,.28);
  filter:saturate(1.05);
}
.tgBanner img{width:100%;height:auto;display:block}

/* Collapsible Groups */
.menuGroup{margin:8px 0}
.menuHead{
  width:100%;
  display:flex;align-items:center;gap:10px;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.03);
  cursor:pointer;
  color:var(--side-text);
}
[data-theme="light"] .menuHead{
  border-color:rgba(2,6,23,.10);
  background:rgba(2,6,23,.02);
}
.menuHead:hover{
  background:var(--side-item-bg);
  border-color:rgba(200,161,90,.22);
}
.menuTitle{font-weight:1000}
.menuBadge{
  margin-left:auto;
  font-size:11px;
  padding:5px 8px;
  border-radius:999px;
  border:1px solid rgba(200,161,90,.35);
  color:rgba(200,161,90,.95);
  background:rgba(200,161,90,.10);
}
.menuChevron{
  width:10px;height:10px;
  border-right:2px solid var(--side-muted);
  border-bottom:2px solid var(--side-muted);
  transform:rotate(45deg);
  transition:transform .18s ease;
  margin-left:4px;
}
.menuGroup:not(.is-open) .menuChevron{transform:rotate(-45deg)}
.menuBody{padding:6px 6px 10px 6px;display:none}
.menuGroup.is-open .menuBody{display:block}

/* items */
.item{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 10px;
  border-radius:12px;
  background:transparent;
  border:1px solid transparent;
  cursor:pointer;
  color:var(--side-text);
}
.item span:first-child{font-weight:900}
.item .mini{
  font-size:12px;
  padding:4px 8px;border-radius:999px;
  border:1px solid var(--line);
  color:var(--side-muted);
  background:rgba(255,255,255,.03);
}
.item:hover{
  background:var(--side-item-bg);
  border-color:rgba(200,161,90,.22);
}
.item.red span:first-child{color:rgba(255,80,80,.95)}
.item.is-active{
  background:var(--side-item-active);
  border-color:rgba(200,161,90,.30);
}

/* ======================= MAIN ======================= */
.main{min-width:0;display:flex;flex-direction:column;gap:14px}

/* hero slider */
.heroSlider{
  position:relative;
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  background:rgba(255,255,255,.02);
}
.heroTrack{display:flex;transition:transform .35s ease}
.heroSlide{min-width:100%}
.heroSlide img{width:100%;height:auto;display:block}
.heroArrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.25);
  color:var(--text);
  cursor:pointer;
  font-weight:1000;
}
.heroArrow.prev{left:10px}
.heroArrow.next{right:10px}
.heroDots{
  position:absolute;left:50%;bottom:10px;transform:translateX(-50%);
  display:flex;gap:8px;
  padding:6px 10px;border-radius:999px;
  background:rgba(0,0,0,.24);
  border:1px solid rgba(255,255,255,.12);
}
.heroDot{
  width:8px;height:8px;border-radius:50%;
  border:0;background:rgba(255,255,255,.38);
  cursor:pointer;
}
.heroDot.is-active{background:rgba(200,161,90,.95)}

/* corner cards */
.corner3{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.cornerCard{
  border:1px solid var(--line);
  border-radius:16px;
  background:var(--panel);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.cornerHead{padding:12px 12px 6px;font-weight:1000}
.cornerImg{padding:0 12px 10px}
.cornerDesc{padding:0 12px 14px;color:var(--muted);font-weight:800;line-height:1.45}

/* panels */
.panel{
  border:1px solid var(--line);
  border-radius:18px;
  background:var(--panel);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.panel.pad{padding:14px}
.panelTop{
  padding:14px;
  display:flex;align-items:center;gap:10px;
  border-bottom:1px solid var(--line);
}
.panelTitle{margin:0;font-size:20px}
.desc{color:var(--muted);font-weight:800;font-size:13px;margin-top:4px}
.panelArrows{margin-left:auto;display:flex;gap:8px}
.arrow{
  width:40px;height:40px;border-radius:12px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--text);
  cursor:pointer;
  font-weight:900;
}

/* verify slider base */
.verifyWrap{padding:14px}
.verifyTrack{
  display:flex;gap:10px;
  overflow:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  cursor:grab;
  user-select:none;
  padding-bottom:6px;
}
.verifyTrack::-webkit-scrollbar{display:none}
.verifyTrack.is-dragging{cursor:grabbing}

/* verify v2 */
.verifyTrackV2 .verifyCard.v2{
  flex:0 0 144px;
  scroll-snap-align:start;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  overflow:hidden;
  box-shadow:0 18px 50px rgba(0,0,0,.45);
  padding:10px 2px;
  position:relative;
}
[data-theme="light"] .verifyTrackV2 .verifyCard.v2{
  border-color:rgba(2,6,23,.12);
  background:rgba(255,255,255,.86);
  box-shadow:0 16px 40px rgba(2,6,23,.10);
}
.verifyCard.v2::before{
  content:"";
  position:absolute;inset:-2px;
  background:conic-gradient(from 0deg,
    rgba(200,161,90,.0),
    rgba(200,161,90,.65),
    rgba(229,9,20,.35),
    rgba(200,161,90,.0)
  );
  filter:blur(10px);
  opacity:.22;
  pointer-events:none;
}
.verifyCard.v2:hover::before{opacity:.32}

/* logo circle */
.v2Top{display:flex;justify-content:center;margin-top:6px}
.v2Logo{
  width:86px;height:86px;border-radius:50%;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.14);
  display:grid;place-items:center;
  overflow:hidden;
}
[data-theme="light"] .v2Logo{
  background:rgba(2,6,23,.04);
  border-color:rgba(2,6,23,.12);
}
.v2Logo img{width:100%;height:100%;object-fit:cover}
.v2Name{margin-top:12px;text-align:center;font-weight:1100}
.v2Review{
  display:block;text-align:center;margin-top:8px;
  color:#60a5fa;font-weight:900;text-decoration:underline;
  text-underline-offset:3px;
}
.v2Btn{
  display:block;text-align:center;margin:10px 20px;
  padding:12px 12px;border-radius:12px;
  background:linear-gradient(180deg, rgba(200,161,90,.92), rgba(176,138,60,.88));
  color:#0b0d12;font-weight:1100;
  border:1px solid rgba(200,161,90,.40);
  position:relative;overflow:hidden;
}
.v2Btn::after{
  content:"";
  position:absolute;top:-40%;left:-30%;
  width:40%;height:180%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
  transform:rotate(18deg);
  animation:shine 2.8s ease-in-out infinite;
  opacity:.55;
}
@keyframes shine{
  0%{transform:translateX(-180%) rotate(18deg);opacity:0}
  35%{opacity:.65}
  60%{opacity:.65}
  100%{transform:translateX(280%) rotate(18deg);opacity:0}
}
.v2Note{margin-top:10px;text-align:center;font-size:12px;color:var(--muted);font-weight:900}
.v2Plus{
  display:inline-block;margin-left:6px;
  padding:4px 8px;border-radius:999px;
  border:1px solid rgba(200,161,90,.35);
  background:rgba(200,161,90,.10);
  color:rgba(200,161,90,.95);
}

/* THEBET badge */
.is-thebet .thebetBadge{
  position:absolute;top:10px;right:10px;
  font-size:11px;font-weight:1100;
  padding:6px 10px;border-radius:999px;
  border:1px solid rgba(229,9,20,.35);
  background:rgba(229,9,20,.12);
  color:rgba(255,210,210,.95);
  z-index:2;
}
[data-theme="light"] .is-thebet .thebetBadge{
  color:#b91c1c;
  background:rgba(229,9,20,.18);
  border-color:rgba(229,9,20,.45);
  box-shadow:0 2px 8px rgba(229,9,20,.25);
}
.is-thebet{border-color:rgba(229,9,20,.22) !important}
.is-thebet::before{opacity:.30}

/* ======================= RIGHTBAR (PC 1400↑) ======================= */
.rightbar{
  position:sticky;top:calc(var(--topH) + 14px);
  /* ✅ bottomNav 공간만큼 빼서 하단 잘림 방지 */
  height: calc(100vh - var(--topH) - 28px - var(--bottomNavH) - var(--safeB));

  overflow:auto;
  display:flex;flex-direction:column;gap:12px;
}
.rbox{
  border:1px solid var(--line);
  border-radius:18px;
  background:var(--panel);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.rboxTop{
  padding:12px 12px;
  display:flex;align-items:center;gap:10px;
  border-bottom:1px solid var(--line);
}
.rboxTop .t{font-weight:1000}
.more{margin-left:auto;color:var(--muted);font-weight:900;font-size:12px}
.rlist{padding:10px 12px;display:flex;flex-direction:column;gap:10px}
.rli{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 10px;border-radius:14px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(0,0,0,.10);
}
[data-theme="light"] .rli{background:rgba(2,6,23,.04)}
.rli .title{font-weight:1000}
.rli .sub{font-size:12px;color:var(--muted);margin-top:2px}
.rtag{
  font-size:12px;font-weight:1000;
  padding:6px 10px;border-radius:999px;
  border:1px solid var(--line);
  color:var(--muted);
}
.rtag.good{color:#22c55e;border-color:rgba(34,197,94,.35)}

/* 우측 내정보 접기/펼치기 */
.rbox.is-collapsed .rlist{display:none}
.rbox.is-collapsed .rboxTop{border-bottom:0}

/* (우측 유저카드 등) */
.userCard{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.10);
  border-radius:16px;
  padding:12px;
}
[data-theme="light"] .userCard{
  border-color:rgba(2,6,23,.10);
  background:rgba(2,6,23,.03);
}
.userHead{display:flex;gap:10px;align-items:center}
.userAva{
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.14);
}
[data-theme="light"] .userAva{
  background:rgba(2,6,23,.08);
  border-color:rgba(2,6,23,.12);
}
.userName{font-weight:1100}
.userMeta{font-size:12px;color:var(--muted);margin-top:2px}

.walletBox{
  margin-top:10px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px;
  overflow:hidden;
}
[data-theme="light"] .walletBox{border-color:rgba(2,6,23,.10)}
.walletRow{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 10px;
  border-top:1px solid rgba(255,255,255,.08);
}
.walletRow:first-child{border-top:0}
[data-theme="light"] .walletRow{border-top-color:rgba(2,6,23,.08)}
.walletRow .k{font-size:13px;color:var(--muted);font-weight:900}
.walletRow .v{font-weight:1100}

.statGrid{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.stat{
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px;
  padding:10px;
  background:rgba(255,255,255,.03);
}
[data-theme="light"] .stat{
  border-color:rgba(2,6,23,.10);
  background:rgba(2,6,23,.02);
}
.stat .k{font-size:12px;color:var(--muted);font-weight:900}
.stat .v{margin-top:4px;font-weight:1100}

.quickGrid{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.qbtn{
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:var(--text);
  font-weight:1100;
  cursor:pointer;
}
[data-theme="light"] .qbtn{
  border-color:rgba(2,6,23,.10);
  background:rgba(2,6,23,.03);
  color:var(--text);
}
.qbtn:hover{
  border-color:rgba(200,161,90,.30);
  background:rgba(200,161,90,.10);
}

.userActions{margin-top:10px;display:flex;gap:8px}
.uBtn{
  flex:1;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:var(--text);
  font-weight:1100;
  cursor:pointer;
}
[data-theme="light"] .uBtn{
  border-color:rgba(2,6,23,.14);
  background:rgba(2,6,23,.02);
  color:var(--text);
}
[data-theme="light"] .uBtn:hover{
  border-color:rgba(2,6,23,.22);
  background:rgba(2,6,23,.04);
}
.uBtn.ghost{background:transparent}
.uBtn.logout{
  border-color:rgba(229,9,20,.28);
  background:rgba(229,9,20,.10);
}

/* ======================= ✅ RIGHT LOGIN PANEL (ADD) ======================= */
/* 우측 "내 정보" 로그인/회원가입 탭 + 폼 + 소셜 버튼(디자인만) */
.loginPanel{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  border-radius:14px;
  overflow:hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}

.lpTabs{
  display:flex;
  background:rgba(0,0,0,.14);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.lpTab{
  flex:1;
  height:44px;
  border:0;
  background:transparent;
  color:rgba(232,238,252,.70);
  font-weight:1100;
  cursor:pointer;
}
.lpTab.is-active{
  color:var(--text);
  background:rgba(255,255,255,.04);
}

.lpBody{padding:12px}

.lpField{margin-top:10px}
.lpField:first-child{margin-top:0}

.lpInput{
  width:100%;
  height:42px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:var(--text);
  padding:0 12px;
  outline:none;
}
.lpInput::placeholder{color:rgba(232,238,252,.45)}
.lpInput:focus{
  border-color:rgba(200,161,90,.35);
  box-shadow:0 0 0 3px rgba(200,161,90,.10);
}

.lpPrimary{
  width:100%;
  height:44px;
  margin-top:10px;
  border-radius:10px;
  border:1px solid rgba(59,130,246,.35);
  background:rgba(59,130,246,.88);
  color:#fff;
  font-weight:1200;
  cursor:pointer;
}
.lpPrimary:hover{filter:brightness(1.05)}
.lpPrimary.ghost{
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:var(--text);
}

.lpRow{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:10px;
  gap:10px;
  font-size:12px;
  color:rgba(232,238,252,.70);
}
.lpChk{display:flex;align-items:center;gap:8px;user-select:none}
.lpChk input{width:14px;height:14px;accent-color: rgba(59,130,246,1)}

.lpLink{
  color:rgba(96,165,250,.95);
  text-decoration:none;
  font-weight:900;
}
.lpLink:hover{text-decoration:underline}

.lpSocial{
  margin-top:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.lpSBtn{
  height:42px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.10);
  font-weight:1100;
  cursor:pointer;
  color:#0b0d12;
}

.lpSBtn.naver{background:#1ec800;border-color:rgba(30,200,0,.35)}
.lpSBtn.kakao{background:#fee500;border-color:rgba(254,229,0,.40)}
.lpSBtn.facebook{background:#1877f2;border-color:rgba(24,119,242,.40);color:#fff}
.lpSBtn.google{background:#ffffff;border-color:rgba(0,0,0,.10);color:#111}

.lpJoinHint{
  color:rgba(232,238,252,.70);
  font-size:12px;
  line-height:1.5;
  margin-bottom:10px;
}

/* light theme */
[data-theme="light"] .loginPanel{
  border-color:rgba(2,6,23,.12);
  background:rgba(2,6,23,.03);
  box-shadow: inset 0 1px 0 rgba(2,6,23,.06);
}
[data-theme="light"] .lpTabs{
  background:rgba(2,6,23,.05);
  border-bottom-color:rgba(2,6,23,.10);
}
[data-theme="light"] .lpTab{color:rgba(2,6,23,.55)}
[data-theme="light"] .lpTab.is-active{color:rgba(2,6,23,.90);background:rgba(2,6,23,.03)}
[data-theme="light"] .lpInput{
  border-color:rgba(2,6,23,.12);
  background:rgba(255,255,255,.70);
  color:rgba(2,6,23,.92);
}
[data-theme="light"] .lpInput::placeholder{color:rgba(2,6,23,.35)}

/* poll */
.poll{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.10);
  border-radius:16px;
  padding:12px;
}
[data-theme="light"] .poll{
  border-color:rgba(2,6,23,.10);
  background:rgba(2,6,23,.03);
}
.pollQ{font-weight:1100;margin-bottom:10px}
.pollOpt{display:flex;gap:10px;align-items:center;margin:8px 0;color:var(--muted);font-weight:900}
.pollBtn{
  width:100%;
  margin-top:10px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(200,161,90,.35);
  background:rgba(200,161,90,.18);
  color:var(--text);
  font-weight:1100;
  cursor:pointer;
}

/* ======================= OVERLAY ======================= */
.overlay{
  position:fixed; inset:0; z-index:60;
  background:rgba(0,0,0,.55);
  display:none;
}
.overlay.is-open{display:block}

/* ======================= RESPONSIVE ======================= */
/* 1400↓ : 우측 숨김 */
@media (max-width: 1399px){
  .content{grid-template-columns: var(--sideW) minmax(0,1fr)}
  .rightbar{display:none}
}

/* 1100↓ : 좌측 오프캔버스 + 햄버거 표시 */
@media (max-width: 1099px){
  .content{grid-template-columns: minmax(0,1fr)}
  .hamburger{display:flex}
  .tabs{display:none}

  .sidebar{
    position:fixed;
    z-index:70;
    top:var(--topH);
    left:0;
    width:min(320px, 86vw);

    /* ✅ bottomNav 공간만큼 빼서 오프캔버스에서도 하단 안 가림 */
    height: calc(100vh - var(--topH) - var(--bottomNavH) - var(--safeB));

    transform:translateX(-110%);
    transition:transform .25s ease;
  }
  .sidebar.is-open{transform:translateX(0)}
}

/* 980↓ : 코너 2열 */
@media (max-width: 980px){
  .corner3{grid-template-columns: repeat(2, minmax(0, 1fr))}
}
/* 560↓ : (현재 의도 유지: 2열) */
@media (max-width: 560px){
  .corner3{grid-template-columns: repeat(2, minmax(0, 1fr))}
}

/* ======================= BOTTOM NAV (FIXED = 가장 안정적) ======================= */
.bottomNav{
  position:fixed;
  left:0; right:0;
  bottom:0;
  z-index:40;

  border-top:1px solid var(--line);
  background:rgba(10,10,12,.70);
  backdrop-filter: blur(10px);

  /* safe-area */
  padding-bottom: var(--safeB);
}
[data-theme="light"] .bottomNav{background:rgba(255,255,255,.84)}

.bottomNav .inner{
  max-width:var(--maxW);
  margin:0 auto;
  padding:10px 12px;
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap:8px;
}
.navBtn{
  border:1px solid var(--line);
  border-radius:14px;
  background:rgba(255,255,255,.03);
  color:var(--text);
  padding:10px 8px;
  cursor:pointer;
}
.navBtn strong{display:block;font-weight:1000}
.navBtn span{display:block;color:var(--muted);font-size:12px;margin-top:2px}

/* ======================= INTRO MODAL ======================= */
.introModal{position:fixed;inset:0;z-index:90;display:none}
.introModal.is-open{display:block}
.introBackdrop{position:absolute;inset:0;background:rgba(0,0,0,.65);backdrop-filter: blur(6px)}
.introBox{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:min(520px, calc(100vw - 32px));
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(900px 260px at 30% 10%, rgba(200,161,90,.22), transparent 55%),
    linear-gradient(180deg, rgba(17,18,22,.92), rgba(10,10,12,.82));
  box-shadow:0 30px 90px rgba(0,0,0,.65);
  overflow:hidden;
}
[data-theme="light"] .introBox{
  background:rgba(255,255,255,.92);
  border-color:rgba(2,6,23,.12);
}
.introTop{
  padding:14px;
  display:flex;align-items:center;gap:10px;
  border-bottom:1px solid var(--line);
}
.introTitle{display:flex;align-items:center;gap:10px;font-weight:1000;letter-spacing:.12em}
.dot{width:10px;height:10px;border-radius:50%;background:var(--brand);box-shadow:0 0 18px rgba(200,161,90,.55)}
.closeX{margin-left:auto}
.introBody{padding:18px}
.introLogo{text-align:center;font-size:34px;font-weight:1000;letter-spacing:.10em;margin:6px 0}
.introDesc{text-align:center;color:var(--muted);font-weight:800;margin:0 0 14px}
.introActions{display:flex;gap:10px;justify-content:center}
.primaryBtn{
  padding:12px 14px;border-radius:14px;
  border:1px solid rgba(200,161,90,.35);
  background:rgba(200,161,90,.18);
  color:var(--text);
  font-weight:1100;cursor:pointer;min-width:140px
}
.ghostBtn{
  padding:12px 14px;border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--text);
  font-weight:1100;cursor:pointer;min-width:140px
}
.introHint{text-align:center;color:var(--muted);font-size:12px;margin-top:12px}

/* ======================= USER SHEET (1400↓) ======================= */
.userSheet{position:fixed;inset:0;z-index:95;display:none}
.userSheet.is-open{display:block}
.userSheetBackdrop{position:absolute;inset:0;background:rgba(0,0,0,.62);backdrop-filter: blur(6px)}
.userSheetPanel{
  position:absolute;
  right:14px;
  top:calc(var(--topH) + 12px);

  width:min(420px, calc(100vw - 28px));
  border-radius:18px;
  border:1px solid #c8a15a;

  background:
    radial-gradient(800px 220px at 70% 0%, rgba(200,161,90,.18), transparent 55%),
    linear-gradient(180deg, rgba(16,16,20,.92), rgba(10,10,12,.86));
  box-shadow:0 30px 90px rgba(0,0,0,.65);
  overflow:hidden;

  /* ✅ 하단바 겹침 대비 */
  max-height: calc(100vh - var(--topH) - 24px - var(--bottomNavH) - var(--safeB));
}
[data-theme="light"] .userSheetPanel{
  background:rgba(255,255,255,.94);
  border-color:rgba(2,6,23,.12);
}
.userSheetTop{
  padding:12px 12px;
  display:flex;align-items:center;gap:10px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
[data-theme="light"] .userSheetTop{border-bottom-color:rgba(2,6,23,.10)}
.userSheetTitle{font-weight:1100}
.userSheetBody{padding:12px;overflow:auto}

/* ======================= ACCESSIBILITY ======================= */
:focus-visible{
  outline:2px solid rgba(200,161,90,.55);
  outline-offset:2px
}
/* ✅ PC(오른쪽 패널 보이는 구간)에서는 높이 제한을 풀어서 아래로 쭉 늘어나게 */
@media (min-width: 1400px){
  .rightbar{
    height: auto !important;
    overflow: visible !important; /* 내부 스크롤 제거 */
  }
}
/* ===== PATCH: lpTab이 <a>여도 버튼처럼 보이게 ===== */
.lpTab{display:flex;align-items:center;justify-content:center;text-decoration:none;}
.lpTabLink{cursor:pointer;}

/* ===== topbar bell ===== */
.bellBtn{
  position:relative;
  width:44px;height:44px;
  display:grid;place-items:center;
  padding:0;
  border-radius:14px;
}

.bellDot{
  position:absolute;
  top:10px; right:10px;
  width:8px;height:8px;border-radius:50%;
  background:#ff3344;
  box-shadow:0 0 12px rgba(255,51,68,.7);
  display:none; /* 기본 숨김 */
}

/* 알림 점이 켜졌을 때 */
.bellDot.is-on{display:block}

/* 깜빡임 */
@keyframes bellPulse{
  0%,100%{transform:scale(1); opacity:1}
  50%{transform:scale(1.35); opacity:.55}
}
.bellDot.is-blink{animation:bellPulse .9s ease-in-out infinite}



/* ===== theme icon button (달/해 테두리 두께 보정) ===== */
.modeToggle{
  width:44px;height:44px;
  padding:0;
  display:grid;place-items:center;
  border-radius:12px;
  border:1px solid var(--line); /* ✅ 굵기 줄이기(기존보다 얇게 보이게) */
  background:rgba(255,255,255,.03);
}
.modeIcon{font-size:18px; line-height:1;}

/* ===== bell ===== */
.bellBtn{
  position:relative;
  width:44px;height:44px;
  padding:0;
  display:grid;place-items:center;
  border-radius:12px;
}
.bellIcon{font-size:18px; line-height:1;}
.bellDot{
  position:absolute;
  top:10px; right:10px;
  width:8px;height:8px;
  border-radius:50%;
  background:transparent;
  box-shadow:none;
  opacity:0;
  transform:scale(.9);
}
.bellDot.is-on{
  opacity:1;
  background:var(--brand2);
  box-shadow:0 0 14px rgba(229,9,20,.55);
}
.bellDot.is-blink{
  animation: bellBlink 1s ease-in-out infinite;
}
@keyframes bellBlink{
  0%, 100%{ transform:scale(.9); opacity:.55; }
  50%{ transform:scale(1.15); opacity:1; }
}

/* ===== user orb caret ===== */
.userOrb{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:0 10px;
  width:auto;              /* ✅ 글자 + caret 들어가면 자동 폭 */
  min-width:72px;
  border-radius:999px;
}
.userOrbText{margin-right:2px;}
.userOrbCaret{
  position:relative;
  z-index:2;
  opacity:.75;
  font-size:12px;
  transform:translateY(1px);
}

/* ===== footer ===== */
.siteFooter{
  border-top:1px solid var(--line);
  background:rgba(10,10,12,.60);
  backdrop-filter: blur(10px);
}
[data-theme="light"] .siteFooter{ background:rgba(255,255,255,.86); }

.footerInner{
  max-width:var(--maxW);
  margin:0 auto;
  padding:22px 14px calc(22px + var(--bottomNavH) + var(--safeB)); /* 하단바에 안 가리게 */
}
.footerCols{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap:16px;
}
.fTitle{font-weight:1100; margin-bottom:10px;}
.fStats{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px;}
.fStats li{display:flex; justify-content:space-between; gap:10px; color:var(--muted); font-weight:900;}
.fStats .v{color:var(--text); font-weight:1100;}
.fLinks{display:flex; flex-direction:column; gap:10px;}
.fLinks a{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  font-weight:1000;
  color:var(--text);
}
.fLinks a:hover{border-color:rgba(200,161,90,.28); background:rgba(200,161,90,.10);}

.footerBottom{
  margin-top:18px;
  padding-top:14px;
  border-top:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  color:var(--muted);
  font-weight:900;
}
.footerMini{display:flex; align-items:center; gap:8px;}
.footerMini a{color:var(--muted);}
.footerMini a:hover{color:var(--text);}
.sep{opacity:.6}

/* 반응형 */
@media (max-width: 980px){
  .footerCols{grid-template-columns: 1fr; }
  .footerBottom{flex-direction:column; align-items:flex-start;}
}


/* =========================
   USER ORB (FIXED CIRCLE)
========================= */

/* 버튼 자체 */
.userOrb{
  width:44px;
  height:44px;
  min-width:44px;
  padding:0;

  display:flex;
  align-items:center;
  justify-content:center;
  gap:4px;

  border-radius:50% !important;   /* ✅ 완전 원 */
  border:1px solid var(--line);
  background:linear-gradient(
    135deg,
    rgba(255,255,255,.22),
    rgba(255,255,255,.06)
  );

  position:relative;
}

/* 이름 첫 글자 */
.userOrbText{
  font-weight:1200;
  font-size:14px;
  line-height:1;
  color:var(--text);

  position:relative;
  z-index:2;
}

/* ▼ 드롭다운 표시 */
.userOrbCaret{
  position:absolute;
  right:6px;
  bottom:6px;

  font-size:10px;
  line-height:1;
  opacity:.7;
}

/* 호버 */
.userOrb:hover{
  border-color:rgba(200,161,90,.45);
  background:linear-gradient(
    135deg,
    rgba(200,161,90,.25),
    rgba(200,161,90,.10)
  );
}

/* 라이트 테마 대응 */
[data-theme="light"] .userOrb{
  background:linear-gradient(
    135deg,
    rgba(0,0,0,.04),
    rgba(0,0,0,.02)
  );
}
/* ✅ 라이트 모드에서 자동로그인/IDPW찾기 텍스트 가독성 보정 */
[data-theme="light"] .lpRow{
  color: rgba(2,6,23,.70);  /* 글씨 진하게 */
}

[data-theme="light"] .lpChk span{
  color: rgba(2,6,23,.78);
}

[data-theme="light"] .lpLink{
  color: rgba(37,99,235,.95); /* 링크는 파란색 유지 */
}

/* 체크박스 테두리/표시도 라이트에서 또렷하게 */
[data-theme="light"] .lpChk input{
  accent-color: rgba(37,99,235,1);
}
@media (min-width: 1024px){
  .bottomNav{ display:none; }
}


/* ======================= BRAND LOGO ======================= */
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}

/* 빨간 박스 BETFLIX */
.logo-box{
  font-family:'Noto Sans KR','Noto Sans',system-ui,sans-serif;
  font-weight:900;
  letter-spacing:-0.04em;
  font-size:26px;

  padding:6px 12px;
  line-height:1;
  background:#e50914;
  color:#fff;

  border-radius:2px; /* 0으로 하면 완전 넷플릭스 느낌 */
  box-shadow:0 2px 8px rgba(229,9,20,.35);
}

/* 모바일 사이즈 조정 */
@media (max-width: 768px){
  .logo-box{
    font-size:22px;
    padding:5px 10px;
  }
}
.introBoxIframe{padding:0 !important; overflow:hidden;}

/* ✅ intro iframe */
.introBox--frame{
  padding:0;
  overflow:hidden;
  position:relative;
}
.introFrameClose{
  position:absolute;
  right:10px; top:10px;
  z-index:5;
}
.introFrame{
  width:100%;
  height:70vh;            /* JS가 메시지로 자동 조절해주지만, 기본값 */
  border:0;
  display:block;
  background:#000;
  border-radius:18px;
}
@media (max-width:520px){
  .introFrame{ height:78vh; }
}
