
/* =============================================================
   RAKUEN tokens — rakuen_spa_no_gli.html 원본과 동일
   ============================================================= */
:root{
  --rakuen-pink:#ff2d84; --rakuen-pink-dark:#c81a6b;
  --rakuen-gold:#ffb627; --rakuen-gold-hot:#ff8c00; --rakuen-gold-lite:#ffd60a;
  --rakuen-rose:#ff6ba8; --tropic-green:#22c55e; --tropic-green-dp:#0e9f47;
  --hibiscus-red:#e63946;
  --cab-wine:#1a0b1a; --cab-wine-2:#2a1530; --cab-gold-trim:#d4af37; --cab-chrome:#6b4870;
  --bg-page-1:#ffe9f3; --bg-page-2:#fff3d6; --bg-card:#fff9f0; --bg-card-2:#ffecf2;
  --ink-0:#3d1a3d; --ink-1:#5a2748; --ink-2:#8b4a6b; --ink-3:#b07a92; --ink-gold:#8b5a00;
  --border:#ffc6dd; --border-deep:#ff8fb8; --border-gold:#ffd78a;
  --rainbow:linear-gradient(90deg,#ff2d84 0%,#ff8c00 18%,#ffd60a 36%,#22c55e 54%,#00b4d8 72%,#7b2cbf 90%,#ff2d84 100%);
  --shadow-soft:0 6px 20px rgba(255,45,132,.15);
  --shadow-gold:0 0 24px rgba(255,182,39,.45);
  --shadow-cabinet:0 12px 30px rgba(26,11,26,.4);

  --sidebar-w:248px; --rail-w:344px; --container:1920px; --header-h:62px;
}
*,*::before,*::after{box-sizing:border-box;}
body.rakuen-shell{margin:0;padding:0;}
body.rakuen-shell {
  font-family:"Noto Sans KR","Malgun Gothic","맑은 고딕",-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Segoe UI",sans-serif;
  color:var(--ink-0);
  background-color:var(--bg-page-1);
  background-image:
    radial-gradient(ellipse 80% 50% at 50% 0%,rgba(255,214,10,.32),transparent 60%),
    radial-gradient(ellipse 50% 40% at 10% 90%,rgba(127,212,255,.28),transparent 70%),
    radial-gradient(ellipse 50% 40% at 90% 85%,rgba(255,45,132,.22),transparent 70%),
    linear-gradient(180deg,var(--bg-page-1),var(--bg-page-2));
  background-attachment:fixed;min-height:100vh;overflow-x:hidden;
}
body.rakuen-shell::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:
    radial-gradient(circle at 15% 25%,rgba(255,255,255,.85) 0,transparent 2px),
    radial-gradient(circle at 82% 12%,rgba(255,255,255,.65) 0,transparent 2px),
    radial-gradient(circle at 30% 75%,rgba(255,255,255,.55) 0,transparent 1.5px),
    radial-gradient(circle at 68% 45%,rgba(255,255,255,.7) 0,transparent 2px),
    radial-gradient(circle at 92% 78%,rgba(255,255,255,.55) 0,transparent 1.5px);
  animation:sparkle 8s ease-in-out infinite;
}
@keyframes sparkle{0%,100%{opacity:.65;}50%{opacity:1;}}

/* =============================================================
   TOP BAR
   ============================================================= */
body.rakuen-shell .topbar {
  display:flex;align-items:center;gap:14px;padding:10px 24px;height:var(--header-h);
  background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(255,243,214,.75));
  border-bottom:1px solid var(--border);backdrop-filter:blur(8px);
  position:sticky;top:0;z-index:100;box-shadow:var(--shadow-soft);
}
body.rakuen-shell .topbar .logo {
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:radial-gradient(circle at 35% 30%,#ff6ba8,#c81a6b 70%);
  display:flex;align-items:center;justify-content:center;color:#fff;
  font-family:"Zen Old Mincho",serif;font-weight:900;font-size:18px;
  filter:drop-shadow(0 2px 8px rgba(255,45,132,.4));
}
.topbar .brand{display:flex;flex-direction:column;}
.topbar .brand .name{font-family:"Zen Old Mincho","바탕",serif;font-weight:900;font-size:18px;color:var(--rakuen-pink-dark);letter-spacing:.12em;line-height:1;}
.topbar .brand .platform{font-family:"Bebas Neue","Impact",sans-serif;font-size:9px;letter-spacing:.25em;color:var(--ink-3);margin-top:3px;}
body.rakuen-shell .hall-selector{display:flex;align-items:center;gap:8px;padding:7px 14px;border:1.5px solid var(--border-deep);border-radius:999px;font-size:13px;color:var(--ink-1);cursor:pointer;background:rgba(255,255,255,.8);transition:all .25s;font-weight:500;}
.hall-selector:hover{border-color:var(--rakuen-pink);box-shadow:0 0 12px rgba(255,45,132,.25);}
body.rakuen-shell .hall-dot{width:7px;height:7px;border-radius:50%;background:var(--tropic-green);box-shadow:0 0 8px var(--tropic-green);animation:live-pulse 1.4s infinite;}
@keyframes live-pulse{0%,100%{opacity:1;}50%{opacity:.5;}}
body.rakuen-shell .gnav{display:flex;gap:4px;margin-left:6px;}
.gnav a{padding:8px 15px;border-radius:9px;font-size:14px;font-weight:700;color:var(--ink-2);text-decoration:none;cursor:pointer;transition:.15s;font-family:"Mochiy Pop One",sans-serif;letter-spacing:.02em;}
.gnav a:hover{background:var(--bg-card-2);color:var(--rakuen-pink-dark);}
.gnav a.on{background:linear-gradient(135deg,var(--rakuen-pink),var(--rakuen-pink-dark));color:#fff;box-shadow:0 3px 12px rgba(255,45,132,.4);}
.gnav a{position:relative;}
.gnav a .shell-nav-badge{margin-left:6px;display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;font-size:10px;font-weight:700;background:var(--rakuen-pink);color:#fff;font-family:"JetBrains Mono",monospace;vertical-align:middle;line-height:1;}
.gnav a.on .shell-nav-badge{background:rgba(255,255,255,.28);}
body.rakuen-shell .topbar-spacer{flex:1;}
body.rakuen-shell .top-stat{display:flex;flex-direction:column;padding:0 14px;border-right:1px dashed var(--border);min-width:104px;}
.top-stat:last-of-type{border:none;}
body.rakuen-shell .top-stat-label{font-size:9px;color:var(--ink-3);letter-spacing:.2em;font-family:"Bebas Neue","Impact",sans-serif;}
body.rakuen-shell .top-stat-value{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:15px;color:var(--ink-0);margin-top:2px;}
.top-stat-value.gold{color:var(--rakuen-gold-hot);}
.top-stat-value.pink{color:var(--rakuen-pink-dark);}
body.rakuen-shell .gh-icon{width:40px;height:40px;border-radius:11px;border:1.5px solid var(--border);background:#fff;cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center;position:relative;}
.gh-icon .dot{position:absolute;top:6px;right:7px;width:8px;height:8px;border-radius:50%;background:var(--rakuen-pink);border:1.5px solid #fff;}
.gh-icon .shell-unread-count{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--rakuen-pink);color:#fff;font-size:9px;font-weight:700;font-family:"JetBrains Mono",monospace;display:flex;align-items:center;justify-content:center;border:1.5px solid #fff;line-height:1;}
body.rakuen-shell .topbar-logout{padding:8px 14px;border-radius:10px;border:1.5px solid var(--border);background:rgba(255,255,255,.92);color:var(--ink-1);font-size:12px;font-weight:700;text-decoration:none;font-family:"Mochiy Pop One",sans-serif;transition:.12s;white-space:nowrap;}
body.rakuen-shell .topbar-logout:hover{border-color:var(--hibiscus-red);color:var(--hibiscus-red);background:rgba(230,57,70,.08);}
body.rakuen-shell .topbar-menu-btn{display:none;width:40px;height:40px;border-radius:11px;border:1.5px solid var(--border);background:#fff;cursor:pointer;padding:0;flex-shrink:0;align-items:center;justify-content:center;flex-direction:column;gap:5px;}
body.rakuen-shell .topbar-menu-btn span{display:block;width:18px;height:2px;border-radius:2px;background:var(--ink-1);transition:.15s;}
body.rakuen-shell .topbar-menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
body.rakuen-shell .topbar-menu-btn.open span:nth-child(2){opacity:0;}
body.rakuen-shell .topbar-menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
body.rakuen-shell .shell-drawer-bg{position:fixed;inset:0;z-index:350;background:rgba(26,11,26,.45);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:.2s;}
body.rakuen-shell .shell-drawer-bg.open{opacity:1;visibility:visible;}
body.rakuen-shell .shell-drawer{position:fixed;top:0;right:0;bottom:0;z-index:351;width:min(300px,88vw);background:linear-gradient(180deg,var(--bg-card),var(--bg-card-2));border-left:1.5px solid var(--border-deep);box-shadow:-12px 0 40px rgba(26,11,26,.25);transform:translateX(100%);transition:transform .25s ease;display:flex;flex-direction:column;padding:16px 12px 24px;overflow-y:auto;}
body.rakuen-shell .shell-drawer.open{transform:translateX(0);}
body.rakuen-shell .shell-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:6px 8px 14px;border-bottom:1px dashed var(--border);margin-bottom:8px;}
body.rakuen-shell .shell-drawer-title{font-family:"Bebas Neue","Impact",sans-serif;font-size:12px;letter-spacing:.22em;color:var(--ink-3);}
body.rakuen-shell .shell-drawer-close{width:34px;height:34px;border-radius:9px;border:1.5px solid var(--border);background:#fff;color:var(--ink-2);font-size:16px;cursor:pointer;}
body.rakuen-shell .shell-drawer-link{display:flex;align-items:center;gap:12px;padding:12px;border-radius:11px;text-decoration:none;color:var(--ink-1);font-size:14px;font-weight:600;font-family:"Mochiy Pop One",sans-serif;transition:.12s;}
body.rakuen-shell .shell-drawer-link .si{width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;background:rgba(255,182,39,.15);}
body.rakuen-shell .shell-drawer-link:hover{background:var(--bg-card-2);}
body.rakuen-shell .shell-drawer-link.on{background:linear-gradient(135deg,var(--rakuen-pink),var(--rakuen-pink-dark));color:#fff;box-shadow:0 3px 12px rgba(255,45,132,.35);}
body.rakuen-shell .shell-drawer-link.on .si{background:rgba(255,255,255,.22);}
body.rakuen-shell .shell-drawer-link .badge{margin-left:auto;font-size:10px;font-weight:700;background:var(--rakuen-pink);color:#fff;padding:2px 8px;border-radius:8px;font-family:"JetBrains Mono",monospace;}
body.rakuen-shell .shell-drawer-link.on .badge{background:rgba(255,255,255,.25);}
body.rakuen-shell .shell-drawer-link--logout{margin-top:8px;padding-top:14px;border-top:1px dashed var(--border);color:var(--ink-2);}
body.rakuen-shell .shell-drawer-link--logout .si{background:rgba(230,57,70,.12);}
body.rakuen-shell .shell-drawer-link--logout:hover{background:rgba(230,57,70,.1);color:var(--hibiscus-red);}
body.rakuen-shell.shell-drawer-open{overflow:hidden;}

/* =============================================================
   3분할 셸
   ============================================================= */
body.rakuen-shell .shell {
  display:grid;grid-template-columns:var(--sidebar-w) minmax(0,1fr) var(--rail-w);
  gap:24px;max-width:var(--container);margin:0 auto;padding:22px 28px 48px;
  align-items:start;position:relative;z-index:2;
}

/* 좌측 사이드바 */
body.rakuen-shell .sidebar{position:sticky;top:calc(var(--header-h) + 22px);display:flex;flex-direction:column;gap:16px;}
body.rakuen-shell .side-card{background:linear-gradient(180deg,var(--bg-card),var(--bg-card-2));border:1.5px solid var(--border-deep);border-radius:14px;padding:10px;box-shadow:var(--shadow-soft);}
body.rakuen-shell .side-title{font-size:9px;font-weight:700;letter-spacing:.2em;color:var(--ink-3);padding:8px 12px 7px;font-family:"Bebas Neue","Impact",sans-serif;}
body.rakuen-shell .side-link{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:11px;cursor:pointer;color:var(--ink-1);font-size:14px;font-weight:600;transition:.12s;font-family:"Mochiy Pop One",sans-serif;}
.side-link .si{width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;background:rgba(255,182,39,.15);}
.side-link:hover{background:var(--bg-card-2);transform:translateX(2px);}
.side-link.on{background:linear-gradient(135deg,var(--rakuen-pink),var(--rakuen-pink-dark));color:#fff;box-shadow:0 3px 12px rgba(255,45,132,.35);}
.side-link.on .si{background:rgba(255,255,255,.22);}
.side-link .badge{margin-left:auto;font-size:10px;font-weight:700;background:var(--rakuen-pink);color:#fff;padding:2px 8px;border-radius:8px;font-family:"JetBrains Mono",monospace;}
.side-link.on .badge{background:rgba(255,255,255,.25);}
body.rakuen-shell .side-link--logout{margin-top:8px;padding-top:14px;border-top:1px dashed var(--border);color:var(--ink-2);}
body.rakuen-shell .side-link--logout .si{background:rgba(230,57,70,.12);}
body.rakuen-shell .side-link--logout:hover{background:rgba(230,57,70,.1);color:var(--hibiscus-red);}
.rate-mini .rm{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;cursor:pointer;transition:.12s;}
.rate-mini .rm:hover{background:var(--bg-card-2);}
.rate-mini .rm .chip{width:42px;text-align:center;padding:5px 0;border-radius:7px;background:linear-gradient(180deg,var(--cab-wine-2),var(--cab-wine));color:var(--rakuen-gold-lite);font-family:"Zen Old Mincho",serif;font-weight:900;font-size:13px;flex-shrink:0;box-shadow:var(--shadow-cabinet);}
.rate-mini .rm .rl{flex:1;}
.rate-mini .rm .rl .a{font-size:12px;font-weight:700;color:var(--ink-1);}
.rate-mini .rm .rl .b{font-size:10px;color:var(--tropic-green-dp);font-weight:700;font-family:"JetBrains Mono",monospace;}

/* 중앙 콘텐츠 */
body.rakuen-shell .main{display:flex;flex-direction:column;gap:14px;min-width:0;}
.ts-hero{text-align:center;padding:6px 8px 4px;}
.ts-hero-line1{font-family:"Zen Old Mincho","바탕",serif;font-weight:900;font-size:34px;letter-spacing:.12em;background:linear-gradient(180deg,#fff,var(--rakuen-rose),var(--rakuen-pink));-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 3px 8px rgba(255,45,132,.35));line-height:1;}
.ts-hero-line2{font-family:"Bebas Neue","Impact",sans-serif;font-size:14px;letter-spacing:.35em;color:var(--ink-gold);margin-top:6px;}
.ts-hero-line2 .em{background:linear-gradient(90deg,var(--rakuen-pink),var(--rakuen-gold));-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700;}
.ts-hero-sub{font-size:12px;color:var(--ink-2);margin-top:8px;}
.rainbow-line{height:3px;background:var(--rainbow);background-size:200% 100%;animation:rainbow 5s linear infinite;max-width:520px;margin:14px auto 6px;border-radius:2px;}
@keyframes rainbow{0%{background-position:0 50%;}100%{background-position:200% 50%;}}

body.rakuen-shell .section{margin-top:18px;}
body.rakuen-shell .section-head{display:flex;align-items:center;gap:10px;margin-bottom:13px;}
.section-head .bi{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;background:linear-gradient(135deg,var(--rakuen-rose),var(--rakuen-pink-dark));color:#fff;}
.section-head .ko{font-family:"Zen Old Mincho","바탕",serif;font-weight:900;font-size:19px;color:var(--ink-0);letter-spacing:.04em;}
.section-head .en{font-family:"Bebas Neue","Impact",sans-serif;font-size:13px;color:var(--ink-3);letter-spacing:.18em;}

/* 충/환전 — 최상단 와이드 패널 */
body.rakuen-shell .money-card{background:linear-gradient(180deg,var(--bg-card),var(--bg-card-2));border:1.5px solid var(--border-deep);border-radius:18px;padding:18px;box-shadow:var(--shadow-soft);}
body.rakuen-shell .money-tabs{display:flex;gap:10px;margin-bottom:14px;}
body.rakuen-shell .money-tab{flex:1;padding:12px;border-radius:11px;border:1.5px solid var(--border);background:#fff;cursor:pointer;text-align:center;font-weight:700;font-size:14px;color:var(--ink-2);font-family:"Mochiy Pop One",sans-serif;}
.money-tab.on.charge{background:linear-gradient(135deg,#22c55e,#0e9f47);color:#fff;border-color:transparent;}
.money-tab.on.exch{background:linear-gradient(135deg,#ffb627,#ff8c00);color:#fff;border-color:transparent;}
.money-tab.on.convert{background:linear-gradient(135deg,#4361ee,#7b2cbf);color:#fff;border-color:transparent;}
body.rakuen-shell .money-tabs--4 .money-tab{font-size:12px;padding:10px 6px;}
body.rakuen-shell .bal-rows{display:flex;flex-direction:column;gap:8px;margin-bottom:13px;}
body.rakuen-shell .bal-rows .bal-row{margin-bottom:0;}
body.rakuen-shell .money-paypw{margin-bottom:10px;}
body.rakuen-shell .money-fee-hint{font-size:12px;color:var(--ink-2);margin:0 0 10px;line-height:1.4;}
body.rakuen-shell .cta.convert{background:linear-gradient(135deg,#4361ee,#7b2cbf);color:#fff;}
body.rakuen-shell .settings-page-card,
body.rakuen-shell .inquiry-page-card{background:linear-gradient(180deg,var(--bg-card),var(--bg-card-2));border:1.5px solid var(--border-deep);border-radius:18px;padding:22px;box-shadow:var(--shadow-soft);}
body.rakuen-shell .settings-autofill-trap{position:absolute;width:0;height:0;overflow:hidden;opacity:0;pointer-events:none;}
body.rakuen-shell .settings-form{position:relative;}
body.rakuen-shell .inquiry-textarea{min-height:120px;resize:vertical;}
body.rakuen-shell .inquiry-faq{margin-top:20px;border:1.5px solid var(--border);border-radius:11px;overflow:hidden;background:#fff;}
body.rakuen-shell .inquiry-faq-q{padding:13px 15px;border-bottom:1px dashed var(--border);font-size:13px;font-weight:700;color:var(--ink-1);}
body.rakuen-shell .inquiry-faq-q:last-child{border-bottom:none;}
body.rakuen-shell .inquiry-faq-q .q-mark{color:var(--rakuen-pink-dark);font-weight:900;margin-right:6px;}
body.rakuen-shell .inquiry-hours{font-size:11px;color:var(--ink-3);text-align:center;margin-top:14px;line-height:1.7;}
body.rakuen-shell .inquiry-hours b{color:var(--rakuen-pink-dark);}
body.rakuen-shell .inquiry-history{margin-top:24px;border-top:1px dashed var(--border);padding-top:18px;}
body.rakuen-shell .inquiry-history-head{font-family:"Mochiy Pop One",sans-serif;font-size:14px;font-weight:700;color:var(--ink-0);margin-bottom:12px;display:flex;align-items:center;gap:8px;}
body.rakuen-shell .inquiry-history-head .badge{font-size:10px;font-weight:700;background:var(--rakuen-pink);color:#fff;padding:2px 8px;border-radius:8px;font-family:"JetBrains Mono",monospace;}
body.rakuen-shell .inquiry-thread-list{display:flex;flex-direction:column;gap:8px;}
body.rakuen-shell .inquiry-thread-item{width:100%;text-align:left;border:1.5px solid var(--border);border-radius:12px;background:#fff;padding:12px 14px;cursor:pointer;transition:.12s;font-family:inherit;}
body.rakuen-shell .inquiry-thread-item:hover{border-color:var(--rakuen-pink);background:var(--bg-card-2);}
body.rakuen-shell .inquiry-thread-head{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
body.rakuen-shell .inquiry-thread-type{font-size:11px;font-weight:700;color:var(--rakuen-pink-dark);}
body.rakuen-shell .inquiry-thread-status{margin-left:auto;font-size:11px;color:var(--ink-3);}
body.rakuen-shell .inquiry-unread{font-size:10px;font-weight:700;color:#fff;background:var(--rakuen-pink);padding:2px 7px;border-radius:999px;}
body.rakuen-shell .inquiry-thread-subject{font-size:14px;font-weight:700;color:var(--ink-0);}
body.rakuen-shell .inquiry-thread-meta{font-size:11px;color:var(--ink-3);margin-top:4px;}
body.rakuen-shell .inquiry-empty{font-size:13px;color:var(--ink-3);text-align:center;padding:16px 0;}
body.rakuen-shell .inquiry-modal-card{max-width:560px;}
body.rakuen-shell .inquiry-modal-root,body.rakuen-shell .inquiry-modal-reply{margin-bottom:16px;padding-bottom:16px;border-bottom:1px dashed var(--border);}
body.rakuen-shell .inquiry-modal-reply:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0;}
body.rakuen-shell .inquiry-modal-meta{font-size:11px;color:var(--ink-3);margin-bottom:6px;}
body.rakuen-shell .inquiry-modal-subject{font-size:16px;font-weight:700;color:var(--ink-0);margin-bottom:8px;}
body.rakuen-shell .inquiry-modal-text{font-size:14px;color:var(--ink-1);line-height:1.7;white-space:pre-wrap;}
body.rakuen-shell .panel-hint.ok{color:var(--tropic-green-dp);}
body.rakuen-shell .panel-hint.err{color:var(--hibiscus-red);}
body.rakuen-shell .acct-paypw{margin:12px 0;}
body.rakuen-shell .acct-paypw-label{display:block;font-size:11px;color:var(--ink-2);margin-bottom:6px;font-weight:700;}
.money-row{display:grid;grid-template-columns:1.1fr 1fr;gap:18px;align-items:start;}
body.rakuen-shell .bal-row{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:linear-gradient(135deg,#fff9f0,#ffecf2);border:1px dashed var(--border-gold);border-radius:12px;margin-bottom:13px;}
.bal-row .l{font-size:11px;color:var(--ink-gold);font-weight:700;letter-spacing:.1em;}
.bal-row .v{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:20px;color:var(--rakuen-gold-hot);}
body.rakuen-shell .amt-input{width:100%;padding:14px 16px;border:1.5px solid var(--border);border-radius:12px;font-family:"JetBrains Mono",monospace;font-size:19px;font-weight:700;color:var(--ink-0);text-align:right;background:#fff;outline:none;}
.amt-input:focus{border-color:var(--rakuen-pink);}
.amt-input::placeholder{color:var(--ink-3);}
body.rakuen-shell .chip-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:11px;}
body.rakuen-shell .amt-chip{padding:10px 4px;border:1.5px solid var(--border);border-radius:9px;background:#fff;cursor:pointer;font-size:12px;font-weight:700;color:var(--ink-1);text-align:center;transition:.12s;}
.amt-chip:hover{background:var(--bg-card-2);border-color:var(--rakuen-pink);}
body.rakuen-shell .cta{width:100%;margin-top:14px;padding:15px;border:none;border-radius:12px;cursor:pointer;font-family:"Bebas Neue","Impact",sans-serif;font-size:19px;letter-spacing:.12em;color:#fff;box-shadow:var(--shadow-soft);}
.cta.charge{background:linear-gradient(135deg,#22c55e,#0e9f47);}
.cta.exch{background:linear-gradient(135deg,#ffb627,#ff8c00);}
.money-side{display:flex;flex-direction:column;gap:11px;height:100%;}
body.rakuen-shell .money-note{font-size:11px;color:var(--ink-3);line-height:1.7;margin-top:10px;}

/* 배너 */
body.rakuen-shell .banner{position:relative;border-radius:18px;overflow:hidden;min-height:240px;border:3px solid var(--cab-gold-trim);background:linear-gradient(120deg,var(--cab-wine) 0%,var(--cab-wine-2) 45%,#3d1530 100%);box-shadow:var(--shadow-cabinet);display:flex;flex-direction:column;justify-content:center;padding:38px 50px;color:#fff;}
.banner::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 85% 50%,rgba(255,45,132,.35),transparent 60%),radial-gradient(ellipse 50% 60% at 100% 100%,rgba(255,182,39,.3),transparent 70%);}
.banner::after{content:"楽";position:absolute;right:46px;bottom:-26px;font-family:"Zen Old Mincho",serif;font-size:190px;font-weight:900;color:rgba(255,214,10,.1);line-height:1;}
.banner .tag{position:relative;font-family:"Bebas Neue","Impact",sans-serif;font-size:15px;letter-spacing:.28em;color:var(--rakuen-gold-lite);}
.banner .ttl{position:relative;font-family:"Zen Old Mincho","바탕",serif;font-weight:900;font-size:42px;line-height:1.14;margin-top:10px;text-shadow:0 3px 16px rgba(0,0,0,.5);max-width:540px;background:linear-gradient(180deg,#fff,var(--rakuen-rose));-webkit-background-clip:text;background-clip:text;}
.banner .desc{position:relative;font-size:14px;color:rgba(255,198,221,.9);margin-top:14px;max-width:460px;line-height:1.6;}
.banner .bbtn{position:relative;margin-top:22px;align-self:flex-start;padding:13px 30px;background:linear-gradient(135deg,var(--rakuen-gold),var(--rakuen-gold-hot));color:var(--cab-wine);border:none;border-radius:10px;font-weight:900;font-size:15px;cursor:pointer;box-shadow:var(--shadow-gold);font-family:"Mochiy Pop One",sans-serif;}
.banner-dots{position:absolute;bottom:18px;left:50px;display:flex;gap:7px;z-index:2;}
.banner-dots span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.35);}
.banner-dots span.on{width:24px;border-radius:5px;background:var(--rakuen-gold-lite);}
.money-banner-wrap{position:relative;padding:0;min-height:240px;display:block;}
.money-banner-slides{position:absolute;inset:0;z-index:2;}
.money-banner-slide{position:absolute;inset:0;background-size:cover;background-position:center;cursor:pointer;border-radius:15px;}
.money-banner-slide[hidden]{display:none;}
.money-banner-wrap.has-slides .money-banner-slides{display:block;}
.money-banner-wrap.has-slides .banner-dots{z-index:3;}
.money-banner-section[hidden]{display:none;}

/* 빠른 액션 */
body.rakuen-shell .quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
body.rakuen-shell .quick-btn{display:flex;align-items:center;gap:14px;background:linear-gradient(180deg,var(--bg-card),var(--bg-card-2));border:1.5px solid var(--border-deep);border-radius:14px;padding:16px;cursor:pointer;box-shadow:var(--shadow-soft);transition:transform .15s,border-color .15s;}
.quick-btn:hover{transform:translateY(-3px);border-color:var(--rakuen-pink);}
.quick-btn .ic{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:23px;flex-shrink:0;box-shadow:0 4px 12px rgba(0,0,0,.12);}
.quick-btn .qt{font-size:15px;font-weight:700;color:var(--ink-0);font-family:"Mochiy Pop One",sans-serif;}
.quick-btn .qs{font-size:11px;color:var(--ink-3);margin-top:3px;}
.ic-charge{background:linear-gradient(135deg,#22c55e,#0e9f47);color:#fff;}
.ic-exch{background:linear-gradient(135deg,#ffb627,#ff8c00);color:#fff;}
.ic-event{background:linear-gradient(135deg,#ff2d84,#c81a6b);color:#fff;}
.ic-game{background:linear-gradient(180deg,var(--cab-wine-2),var(--cab-wine));color:var(--rakuen-gold-lite);border:1.5px solid var(--cab-gold-trim);}

/* 우측 레일 */
body.rakuen-shell .rail{position:sticky;top:calc(var(--header-h) + 22px);display:flex;flex-direction:column;gap:16px;}
body.rakuen-shell .mypage-card{background:linear-gradient(180deg,var(--cab-wine-2),var(--cab-wine));border:1.5px solid var(--cab-gold-trim);border-radius:16px;padding:18px;color:#fff;box-shadow:var(--shadow-cabinet);position:relative;overflow:hidden;}
.mypage-card::before{content:"";position:absolute;top:-40px;right:-40px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(255,182,39,.35),transparent 70%);}
body.rakuen-shell .mp-top{display:flex;align-items:center;gap:13px;position:relative;}
body.rakuen-shell .mp-ava{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--rakuen-rose),var(--rakuen-pink-dark));display:flex;align-items:center;justify-content:center;font-size:25px;flex-shrink:0;box-shadow:0 4px 14px rgba(255,45,132,.4);}
body.rakuen-shell .mp-name{font-family:"Zen Old Mincho",serif;font-weight:900;font-size:17px;}
body.rakuen-shell .mp-grade{display:inline-block;margin-top:6px;font-family:"Bebas Neue","Impact",sans-serif;font-size:11px;letter-spacing:.12em;background:linear-gradient(135deg,var(--rakuen-gold-lite),var(--rakuen-gold-hot));color:var(--cab-wine);padding:3px 11px;border-radius:6px;font-weight:700;}
body.rakuen-shell .mp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:16px;background:rgba(255,255,255,.1);border-radius:11px;overflow:hidden;position:relative;}
body.rakuen-shell .mp-stat{background:rgba(255,255,255,.04);padding:12px 6px;text-align:center;}
.mp-stat .v{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:15px;color:var(--rakuen-gold-lite);}
.mp-stat .l{font-size:9.5px;color:rgba(255,198,221,.8);margin-top:3px;}
body.rakuen-shell .mp-menu{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:14px;position:relative;}
body.rakuen-shell .mp-mi{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:11px 4px;text-align:center;cursor:pointer;transition:.12s;}
.mp-mi:hover{background:rgba(255,255,255,.14);}
.mp-mi .mic{font-size:18px;}
.mp-mi .mil{font-size:10px;color:rgba(255,255,255,.85);margin-top:5px;}

/* 우측 레일 카테고리 바로가기 (이벤트/공지 → 카테고리 이동) */
body.rakuen-shell .cat-card{background:linear-gradient(180deg,var(--bg-card),var(--bg-card-2));border:1.5px solid var(--border-deep);border-radius:16px;padding:10px;box-shadow:var(--shadow-soft);}
body.rakuen-shell .cat-link{display:flex;align-items:center;gap:12px;padding:13px 12px;border-radius:11px;cursor:pointer;transition:.12s;}
.cat-link:hover{background:var(--bg-card-2);}
.cat-link .ci{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;background:rgba(255,45,132,.12);}
.cat-link .ct{font-size:14px;font-weight:700;color:var(--ink-0);font-family:"Mochiy Pop One",sans-serif;}
.cat-link .cs{font-size:10.5px;color:var(--ink-3);margin-top:2px;}
.cat-link .badge{margin-left:auto;font-size:10px;font-weight:700;background:var(--rakuen-pink);color:#fff;padding:2px 8px;border-radius:8px;font-family:"JetBrains Mono",monospace;}
.cat-link .arr{margin-left:auto;color:var(--ink-3);font-size:16px;}

body.rakuen-shell .spec-note{max-width:var(--container);margin:6px auto 0;padding:16px 28px;font-size:12px;color:var(--ink-2);line-height:1.7;position:relative;z-index:2;}
.spec-note b{color:var(--rakuen-pink-dark);}

/* =============================================================
   계좌 노출 모달
   ============================================================= */
body.rakuen-shell .modal-backdrop{position:fixed;inset:0;z-index:500;background:rgba(26,11,26,.55);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:20px;}
body.rakuen-shell .modal-backdrop.open{display:flex;}
body.rakuen-shell .acct-modal{width:100%;max-width:440px;background:linear-gradient(180deg,var(--bg-card),var(--bg-card-2));border:1.5px solid var(--border-deep);border-radius:18px;box-shadow:0 20px 60px rgba(26,11,26,.5);overflow:hidden;animation:pop .2s ease;}
@keyframes pop{from{transform:scale(.94);opacity:0;}to{transform:scale(1);opacity:1;}}
body.rakuen-shell .acct-head{padding:18px 22px;color:#fff;position:relative;}
.acct-head.charge{background:linear-gradient(135deg,#22c55e,#0e9f47);}
.acct-head.exch{background:linear-gradient(135deg,#ffb627,#ff8c00);}
.acct-head .ah-t{font-family:"Zen Old Mincho",serif;font-weight:900;font-size:20px;}
.acct-head .ah-s{font-size:12px;opacity:.92;margin-top:4px;}
body.rakuen-shell .acct-close{position:absolute;top:16px;right:18px;width:30px;height:30px;border-radius:9px;border:none;background:rgba(255,255,255,.25);color:#fff;font-size:17px;cursor:pointer;}
body.rakuen-shell .acct-body{padding:22px;}
body.rakuen-shell .acct-amt{text-align:center;margin-bottom:18px;}
.acct-amt .l{font-size:11px;color:var(--ink-gold);letter-spacing:.1em;font-weight:700;}
.acct-amt .v{font-family:"JetBrains Mono",monospace;font-weight:700;font-size:30px;color:var(--rakuen-gold-hot);margin-top:4px;}
body.rakuen-shell .acct-field{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:11px;display:flex;align-items:center;gap:12px;}
.acct-field .af-l{font-size:11px;color:var(--ink-3);letter-spacing:.08em;min-width:54px;}
.acct-field .af-v{flex:1;font-family:"JetBrains Mono",monospace;font-weight:700;font-size:16px;color:var(--ink-0);}
.acct-field .af-copy{padding:7px 12px;border:1.5px solid var(--border-deep);background:#fff;border-radius:8px;color:var(--rakuen-pink-dark);font-size:12px;font-weight:700;cursor:pointer;}
.acct-field .af-copy:active{background:var(--bg-card-2);}
body.rakuen-shell .acct-warn{background:rgba(255,45,132,.08);border:1px dashed var(--border-deep);border-radius:11px;padding:13px 15px;font-size:11.5px;color:var(--ink-2);line-height:1.7;margin-top:6px;}
.acct-warn b{color:var(--rakuen-pink-dark);}
body.rakuen-shell .acct-done{width:100%;margin-top:16px;padding:15px;border:none;border-radius:12px;cursor:pointer;font-family:"Bebas Neue","Impact",sans-serif;font-size:18px;letter-spacing:.1em;color:#fff;background:linear-gradient(135deg,var(--rakuen-pink),var(--rakuen-pink-dark));box-shadow:var(--shadow-soft);}

body.rakuen-shell .tabbar{display:none;}

/* =============================================================
   웹앱 하이브리드
   ============================================================= */
@media (max-width:1366px){:root{--rail-w:312px;--sidebar-w:220px;}.banner .ttl{font-size:36px;}}
@media (max-width:1100px){
  .shell{grid-template-columns:var(--sidebar-w) minmax(0,1fr);}
  .rail{grid-column:1 / -1;position:static;display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start;}
}
@media (max-width:768px){
  body.rakuen-shell{background-attachment:scroll;}
  body.rakuen-shell{--rakuen-tabbar-height:58px;}
  body.rakuen-shell .gnav,body.rakuen-shell .hall-selector,body.rakuen-shell .top-stat{display:none;}
  body.rakuen-shell .topbar{padding:8px 16px;gap:10px;}
  body.rakuen-shell .topbar-menu-btn{display:inline-flex;}
  body.rakuen-shell .topbar-logout{display:none;}
  body.rakuen-shell .shell{grid-template-columns:1fr;padding:14px 14px 92px;gap:16px;}
  body.rakuen-shell .sidebar{display:none;}
  body.rakuen-shell .page-shell{grid-template-columns:1fr;padding:14px 14px 92px;}
  body.rakuen-shell .rail{grid-template-columns:1fr;}
  body.rakuen-shell .money-row{grid-template-columns:1fr;}
  body.rakuen-shell .ts-hero-line1{font-size:26px;}
  body.rakuen-shell .banner{min-height:180px;padding:26px 22px;border-width:2px;}
  body.rakuen-shell .banner .ttl{font-size:28px;}
  body.rakuen-shell .banner::after{font-size:120px;right:20px;}
  body.rakuen-shell .quick-grid{grid-template-columns:repeat(2,1fr);}
  body.rakuen-shell .tabbar{display:flex !important;position:fixed;left:0;right:0;bottom:0;z-index:300;max-width:560px;margin:0 auto;padding-bottom:env(safe-area-inset-bottom,0);background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-top:1.5px solid var(--border);box-shadow:0 -4px 20px rgba(255,45,132,.12);}
  body.rakuen-shell .tab{flex:1;padding:9px 0 11px;text-align:center;cursor:pointer;color:var(--ink-3);position:relative;}
  body.rakuen-shell .tab .ti{font-size:21px;line-height:1;}
  body.rakuen-shell .tab .tl{font-size:10px;font-weight:700;margin-top:4px;}
  body.rakuen-shell .tab.on{color:var(--rakuen-pink-dark);}
  body.rakuen-shell .tab.on::after{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:32px;height:3px;border-radius:0 0 4px 4px;background:var(--rakuen-pink);}
  body.rakuen-shell .tab-center .ti{width:50px;height:50px;margin:-14px auto 0;border-radius:15px;background:linear-gradient(180deg,var(--cab-wine-2),var(--cab-wine));border:1.5px solid var(--cab-gold-trim);color:var(--rakuen-gold-lite);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-cabinet);font-size:23px;}
}
@media (max-width:430px){.quick-grid{grid-template-columns:1fr 1fr;}.banner .ttl{font-size:24px;}}


/* ===== 서브 페이지 공통 ===== */
body.rakuen-shell .page-shell{max-width:var(--container);margin:0 auto;padding:22px 28px 60px;position:relative;z-index:2;display:grid;grid-template-columns:var(--sidebar-w) minmax(0,1fr);gap:24px;align-items:start;}
body.rakuen-shell .page-main{min-width:0;}
body.rakuen-shell .page-title{display:flex;align-items:center;gap:12px;margin-bottom:4px;}
.page-title .bi{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;background:linear-gradient(135deg,var(--rakuen-rose),var(--rakuen-pink-dark));color:#fff;}
.page-title .ko{font-family:"Zen Old Mincho","바탕",serif;font-weight:900;font-size:26px;color:var(--ink-0);letter-spacing:.04em;}
.page-title .en{font-family:"Bebas Neue","Impact",sans-serif;font-size:14px;color:var(--ink-3);letter-spacing:.2em;}
body.rakuen-shell .page-sub{font-size:13px;color:var(--ink-2);margin:2px 0 18px;}
body.rakuen-shell .page-rainbow{height:3px;background:var(--rainbow);background-size:200% 100%;animation:rainbow 5s linear infinite;border-radius:2px;margin-bottom:22px;}

/* 필터 칩 */
body.rakuen-shell .pfilter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;}
body.rakuen-shell .pchip{padding:8px 16px;border:1.5px solid var(--border);border-radius:999px;background:rgba(255,255,255,.7);color:var(--ink-1);font-size:13px;cursor:pointer;transition:.2s;font-family:"Mochiy Pop One",sans-serif;}
body.rakuen-shell .pchip:hover{border-color:var(--rakuen-pink);}
body.rakuen-shell .pchip.on{background:linear-gradient(135deg,var(--rakuen-pink),var(--rakuen-pink-dark));color:#fff;border-color:transparent;box-shadow:0 3px 12px rgba(255,45,132,.4);}

/* ===== 공지 리스트 ===== */
body.rakuen-shell .nlist{background:linear-gradient(180deg,var(--bg-card),var(--bg-card-2));border:1.5px solid var(--border-deep);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-soft);}
body.rakuen-shell .nrow{display:flex;align-items:center;gap:16px;padding:18px 22px;border-bottom:1px dashed var(--border);cursor:pointer;transition:.12s;}
.nrow:last-child{border-bottom:none;}
.nrow:hover{background:var(--bg-card-2);}
.nrow .nt-tag{font-family:"Bebas Neue","Impact",sans-serif;font-size:11px;font-weight:700;padding:5px 11px;border-radius:5px;flex-shrink:0;letter-spacing:.1em;}
.nt-notice{background:rgba(255,45,132,.15);color:var(--rakuen-pink-dark);}
.nt-event{background:rgba(255,182,39,.18);color:var(--rakuen-gold-hot);}
.nt-update{background:rgba(34,197,94,.15);color:var(--tropic-green-dp);}
.nrow .nbody{flex:1;min-width:0;}
.nrow .nbody .ntt{font-size:15px;font-weight:700;color:var(--ink-0);font-family:"Mochiy Pop One",sans-serif;}
.nrow .nbody .npv{font-size:12px;color:var(--ink-3);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.nrow .ndd{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--ink-3);flex-shrink:0;}
.nrow .narr{color:var(--ink-3);font-size:17px;}
.nrow.pinned .nbody .ntt::before{content:"📌 ";}

/* ===== 이벤트 카드 (전체) ===== */
body.rakuen-shell .egrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
body.rakuen-shell .ecard{background:linear-gradient(180deg,var(--bg-card),var(--bg-card-2));border:1.5px solid var(--border-deep);border-radius:16px;padding:12px;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-soft);overflow:hidden;}
.ecard:hover{transform:translateY(-4px);border-color:var(--rakuen-pink);box-shadow:0 10px 30px rgba(255,45,132,.3);}
body.rakuen-shell .eart{height:160px;border-radius:12px;border:2px solid var(--cab-gold-trim);overflow:hidden;position:relative;box-shadow:inset 0 0 20px rgba(0,0,0,.4);padding:16px;display:flex;flex-direction:column;justify-content:space-between;color:#fff;}
body.rakuen-shell .eart.has-img::after{background:linear-gradient(180deg,rgba(0,0,0,.15) 40%,rgba(0,0,0,.65));}
body.rakuen-shell .eart.has-img .ettl{display:none;}
.eart::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.45));pointer-events:none;}
.eart .ebadge{position:relative;z-index:1;align-self:flex-start;font-family:"Bebas Neue","Impact",sans-serif;font-size:11px;letter-spacing:.15em;background:rgba(0,0,0,.42);padding:4px 10px;border-radius:5px;}
.eart .ebadge.chip-hot{background:linear-gradient(135deg,#e63946,#ff2d84);}
.eart .ebadge.chip-weekly{background:linear-gradient(135deg,#4361ee,#7b2cbf);}
.eart .ebadge.chip-season{background:linear-gradient(135deg,#ffb627,#ff8c00);}
.eart .ebadge.chip-new{background:linear-gradient(135deg,#22c55e,#00b4d8);}
.eart .ebadge.chip-vip{background:linear-gradient(135deg,#ffd60a,#ff8c00);color:#1a1028;}
.eart .ebadge.chip-forced{background:#fff;color:#e63946;}
.eart .ettl{position:relative;z-index:1;font-family:"Zen Old Mincho",serif;font-weight:900;font-size:24px;line-height:1.14;text-shadow:0 2px 8px rgba(0,0,0,.45);}
.e1{background:linear-gradient(135deg,#ff2d84,#7b2cbf);}
.e2{background:linear-gradient(135deg,#22c55e,#00b4d8);}
.e3{background:linear-gradient(135deg,#ffb627,#ff8c00);}
.e4{background:linear-gradient(135deg,#7b2cbf,#4361ee);}
.e5{background:linear-gradient(135deg,#e63946,#ff2d84);}
.e6{background:linear-gradient(135deg,#0e9f47,#ffd60a);}
body.rakuen-shell .emeta{padding:13px 4px 4px;}
.emeta .et{font-family:"Zen Old Mincho",serif;font-weight:700;font-size:16px;color:var(--ink-0);}
.emeta .ep{font-size:12.5px;color:var(--ink-2);margin-top:6px;line-height:1.55;}
.emeta .ed{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink-3);margin-top:11px;display:flex;align-items:center;gap:6px;}
.emeta .ed .live{width:7px;height:7px;border-radius:50%;background:var(--tropic-green);box-shadow:0 0 8px var(--tropic-green);animation:live-pulse 1.4s infinite;}

/* 상세 모달 */
body.rakuen-shell .dmodal-bg{position:fixed;inset:0;z-index:500;background:rgba(26,11,26,.55);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:20px;}
body.rakuen-shell .dmodal-bg.open{display:flex;}
body.rakuen-shell .dmodal{width:100%;max-width:560px;max-height:86vh;overflow:auto;background:linear-gradient(180deg,var(--bg-card),var(--bg-card-2));border:1.5px solid var(--border-deep);border-radius:18px;box-shadow:0 20px 60px rgba(26,11,26,.5);animation:pop .2s ease;}
@keyframes pop{from{transform:scale(.94);opacity:0;}to{transform:scale(1);opacity:1;}}
body.rakuen-shell .dm-hero{min-height:120px;padding:22px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;position:relative;}
.dm-hero .dm-tag{font-family:"Bebas Neue","Impact",sans-serif;font-size:12px;letter-spacing:.18em;}
.dm-hero .dm-t{font-family:"Zen Old Mincho",serif;font-weight:900;font-size:24px;margin-top:6px;text-shadow:0 2px 8px rgba(0,0,0,.4);}
body.rakuen-shell .dm-close{position:absolute;top:16px;right:18px;width:32px;height:32px;border-radius:9px;border:none;background:rgba(255,255,255,.25);color:#fff;font-size:18px;cursor:pointer;}
body.rakuen-shell .dm-body{padding:22px;}
body.rakuen-shell .dm-meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;}
.dm-meta .dm-m{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--ink-2);background:rgba(255,182,39,.12);border:1px dashed var(--border-gold);border-radius:8px;padding:6px 12px;}
body.rakuen-shell .dm-text{font-size:14px;color:var(--ink-1);line-height:1.8;}
body.rakuen-shell .notice-rich-body img{max-width:100%;height:auto;border-radius:8px;margin:10px 0;display:block;}
body.rakuen-shell .notice-rich-body p{margin:0 0 12px;}
body.rakuen-shell .notice-rich-body ul,
body.rakuen-shell .notice-rich-body ol{margin:8px 0 12px;padding-left:22px;}
body.rakuen-shell .notice-rich-body li{margin:4px 0;}
body.rakuen-shell .notice-rich-body a{color:var(--rakuen-pink-dark);text-decoration:underline;}
body.rakuen-shell .notice-rich-body blockquote{margin:12px 0;padding:10px 14px;border-left:3px solid var(--rakuen-pink);background:rgba(255,45,132,.06);border-radius:0 8px 8px 0;}
.dm-text h4{font-family:"Mochiy Pop One",sans-serif;font-size:15px;color:var(--rakuen-pink-dark);margin:18px 0 8px;}
.dm-text ul{margin:8px 0;padding-left:20px;}
.dm-text li{margin:5px 0;}
body.rakuen-shell .dm-cta{width:100%;margin-top:20px;padding:15px;border:none;border-radius:12px;cursor:pointer;font-family:"Bebas Neue","Impact",sans-serif;font-size:18px;letter-spacing:.1em;color:#fff;background:linear-gradient(135deg,var(--rakuen-pink),var(--rakuen-pink-dark));box-shadow:var(--shadow-soft);}

body.rakuen-shell .empty{padding:60px 20px;text-align:center;color:var(--ink-3);font-size:14px;}

/* 공지 팝업 */
body.rakuen-shell .notice-popup-bg{z-index:600;}
body.rakuen-shell .notice-popup-card{border:1.5px solid var(--rakuen-pink);box-shadow:0 20px 60px rgba(255,45,132,.35);}
body.rakuen-shell .notice-popup-body{max-height:50vh;overflow-y:auto;margin-bottom:4px;}
body.rakuen-shell .notice-popup-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:18px;flex-wrap:wrap;}
body.rakuen-shell .notice-popup-btn{padding:12px 18px;border-radius:10px;border:1.5px solid var(--border-deep);background:rgba(255,255,255,.85);color:var(--ink-1);font-size:13px;font-family:"Mochiy Pop One",sans-serif;cursor:pointer;transition:.15s;}
body.rakuen-shell .notice-popup-btn:hover{border-color:var(--rakuen-pink);}
body.rakuen-shell .notice-popup-btn.primary{color:#fff;border-color:transparent;background:linear-gradient(135deg,var(--rakuen-pink),var(--rakuen-pink-dark));box-shadow:0 3px 12px rgba(255,45,132,.35);}
body.rakuen-shell .notice-popup-btn.ghost{background:rgba(255,255,255,.7);}

@media (max-width:1100px){.egrid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:768px){
  body.rakuen-shell .gnav,body.rakuen-shell .hall-selector,body.rakuen-shell .top-stat{display:none;}
  body.rakuen-shell .topbar{padding:8px 16px;gap:10px;}
  body.rakuen-shell .topbar-menu-btn{display:inline-flex;}
  body.rakuen-shell .topbar-logout{display:none;}
  body.rakuen-shell .page-shell{grid-template-columns:1fr;padding:14px 14px 92px;}
  body.rakuen-shell .sidebar{display:none;}
  body.rakuen-shell .page-title .ko{font-size:22px;}
  body.rakuen-shell .egrid{grid-template-columns:1fr;}
  body.rakuen-shell .nrow .npv{display:none;}
}

body.rakuen-shell .tabbar{display:none;}


body.rakuen-shell .side-link{text-decoration:none;color:inherit;}
body.rakuen-shell .gnav a{text-decoration:none;}
body.rakuen-shell .tab{text-decoration:none;color:inherit;display:block;}
body.rakuen-shell .money-tab{text-decoration:none;display:block;cursor:pointer;}
body.rakuen-shell .amt-chip{border:none;font-family:inherit;cursor:pointer;background:#fff;}
body.rakuen-shell .shell-msg{font-size:13px;margin-bottom:14px;padding:10px 14px;border-radius:10px;background:rgba(255,45,132,.08);color:var(--ink-1);}
body.rakuen-shell .shell-msg.ok{background:rgba(34,197,94,.12);color:var(--tropic-green-dp);}
body.rakuen-shell .shell-msg.err{background:rgba(230,57,70,.1);color:var(--hibiscus-red);}
body.rakuen-shell .dm-cta:disabled{opacity:.55;cursor:not-allowed;}
body.rakuen-shell .mp-mi a{text-decoration:none;color:inherit;display:block;}
body.rakuen-shell .quick-btn{text-decoration:none;color:inherit;}
body.rakuen-shell .banner .bbtn{cursor:pointer;}

/* Language dropdown */
.lang-dropdown{position:relative;flex-shrink:0;z-index:120;}
.lang-dropdown__toggle{display:flex;align-items:center;gap:7px;padding:6px 12px;border:1.5px solid var(--border-deep,#e8e0f0);border-radius:999px;background:rgba(255,255,255,.88);cursor:pointer;font-size:13px;font-weight:500;color:var(--ink-1,#1a1025);font-family:inherit;transition:border-color .2s,box-shadow .2s;}
.lang-dropdown__toggle:hover{border-color:var(--rakuen-pink,#ff2d84);box-shadow:0 0 10px rgba(255,45,132,.2);}
.lang-dropdown__caret{font-size:9px;color:var(--ink-3,#9b8fad);margin-left:2px;}
.lang-dropdown__menu{position:absolute;top:calc(100% + 6px);right:0;min-width:148px;padding:6px;border-radius:12px;border:1.5px solid var(--border-deep,#e8e0f0);background:#fff;box-shadow:0 12px 32px rgba(26,16,37,.14);z-index:200;}
.lang-dropdown__menu[hidden]{display:none;}
.lang-dropdown__option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;border-radius:8px;background:transparent;cursor:pointer;font-size:13px;color:var(--ink-1,#1a1025);font-family:inherit;text-align:left;}
.lang-dropdown__option:hover{background:rgba(255,45,132,.08);}
.lang-dropdown__option.on{background:rgba(255,45,132,.12);font-weight:700;}
.lang-flag{display:inline-flex;width:20px;height:20px;border-radius:50%;overflow:hidden;flex-shrink:0;box-shadow:0 0 0 1px rgba(0,0,0,.08);}
.lang-flag svg{width:100%;height:100%;display:block;}
body.rakuen-shell .topbar .lang-dropdown{margin-left:4px;}
.lang-dropdown--login .lang-dropdown__toggle{background:rgba(255,255,255,.92);backdrop-filter:blur(8px);}
.login-lang-fixed{position:fixed;top:16px;right:16px;z-index:200;}
.shell-drawer-lang{padding:8px 16px 12px;border-bottom:1px solid var(--border,#f0e8f8);}
.shell-drawer-lang-title{font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--ink-3,#9b8fad);margin-bottom:8px;}
.shell-drawer-lang-opt{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;margin-bottom:4px;border:1.5px solid transparent;border-radius:10px;background:rgba(255,255,255,.6);cursor:pointer;font-size:14px;color:var(--ink-1,#1a1025);font-family:inherit;text-align:left;}
.shell-drawer-lang-opt.on{border-color:var(--rakuen-pink,#ff2d84);background:rgba(255,45,132,.08);font-weight:700;}
.shell-drawer-lang-opt .lang-flag{width:22px;height:22px;}
body.rakuen-shell .lang-dropdown--compact .lang-dropdown__toggle{padding:6px 10px;}
@media (max-width:768px){
  body.rakuen-shell .lang-dropdown--compact .lang-dropdown__label,
  body.rakuen-shell .lang-dropdown--compact .lang-dropdown__caret{display:none;}
  body.rakuen-shell .topbar .lang-dropdown{margin-left:auto;}
}