/* =====================================================
   AURORA DEEP v7.0
   Concept : Deep-space navy + aurora teal / violet
   Nav     : 64px left icon rail + horizontal top info bar
   Mobile  : Full-screen overlay with 3-col menu grid
   Login   : Diagonal clip-path split layout
===================================================== */

/* ─── RESET & ROOT ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
    font-family: 'Noto Sans KR', sans-serif;
    background: var(--bg);
    color: var(--text);
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

/* ─── VARIABLES ─── */
:root {
    /* surfaces */
    --bg:       #060a14;
    --bg2:      #0b1120;
    --surf:     #0f172a;
    --surf2:    #1e293b;

    /* aurora teal */
    --teal:      #2dd4bf;
    --teal-lt:   rgba(45,212,191,.08);
    --teal-md:   rgba(45,212,191,.20);
    --teal-glow: rgba(45,212,191,.35);

    /* aurora violet */
    --violet:    #818cf8;
    --violet-lt: rgba(129,140,248,.08);
    --violet-md: rgba(129,140,248,.20);

    /* red / danger */
    --red:    #f43f5e;
    --red-lt: rgba(244,63,94,.10);

    /* text */
    --text:  #f1f5f9;
    --text2: #94a3b8;
    --muted: #475569;

    /* borders */
    --border:  rgba(45,212,191,.14);
    --border2: rgba(255,255,255,.06);

    /* layout */
    --rail-w:    64px;
    --topbar-h:  52px;
    --notice-h:  32px;
    --container: 1100px;

    /* shape */
    --radius:    8px;
    --radius-lg: 14px;
    --radius-xl: 20px;
}

/* =====================================================
   LEFT ICON RAIL
===================================================== */
.navRail {
    position: fixed;
    left: 0; top: 0; bottom: 0;
    width: var(--rail-w);
    background: var(--surf);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    align-items: center;
    z-index: 200;
    padding-bottom: 16px;
}

.railLogo {
    width: 100%;
    height: var(--topbar-h);
    display: flex;
    align-items: center;
    justify-content: center;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.railLogo img {
    width: 28px; height: 28px;
    object-fit: contain;
    filter: brightness(0) invert(1);
    opacity: .8;
}

.railLinks {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 14px 0;
    width: 100%;
    overflow-y: auto;
    scrollbar-width: none;
}
.railLinks::-webkit-scrollbar { display: none; }

.railLink {
    position: relative;
    width: 44px; height: 44px;
    border-radius: var(--radius);
    display: flex; align-items: center; justify-content: center;
    color: var(--muted);
    font-size: 19px;
    transition: background .15s, color .15s;
}
.railLink:hover { background: var(--teal-lt); color: var(--teal); }
.railLink.active { background: var(--teal-lt); color: var(--teal); }
.railLink.active::after {
    content: '';
    position: absolute;
    left: -10px; top: 8px; bottom: 8px;
    width: 3px;
    background: var(--teal);
    border-radius: 0 3px 3px 0;
}

.railTip {
    position: absolute;
    left: calc(100% + 10px);
    top: 50%; transform: translateY(-50%);
    background: var(--surf2);
    color: var(--text);
    font-size: 11px; font-weight: 700;
    white-space: nowrap;
    padding: 5px 10px;
    border-radius: 6px;
    border: 1px solid var(--border);
    pointer-events: none;
    opacity: 0; transition: opacity .12s;
    z-index: 9999;
    box-shadow: 0 4px 16px rgba(0,0,0,.5);
}
.railLink:hover .railTip { opacity: 1; }

.railBadge {
    position: absolute;
    top: 5px; right: 5px;
    min-width: 15px; height: 15px;
    background: var(--red); color: #fff;
    font-size: 9px; font-weight: 800;
    border-radius: 99px;
    display: flex; align-items: center; justify-content: center;
    padding: 0 3px; line-height: 1;
}

.railBottom {
    display: flex; flex-direction: column; align-items: center;
    width: 100%; padding: 0 10px;
}
.railLogout {
    width: 44px; height: 44px;
    border-radius: var(--radius);
    display: flex; align-items: center; justify-content: center;
    color: var(--muted); font-size: 18px;
    transition: background .15s, color .15s;
}
.railLogout:hover { background: var(--red-lt); color: var(--red); }

/* =====================================================
   TOP INFO BAR
===================================================== */
.topBar {
    position: fixed;
    top: 0;
    left: var(--rail-w); right: 0;
    height: var(--topbar-h);
    background: var(--surf);
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center;
    padding: 0 24px;
    gap: 16px;
    z-index: 190;
}

.topBarSite {
    font-size: 12px; font-weight: 800;
    color: var(--text2);
    letter-spacing: .08em; text-transform: uppercase;
    margin-right: auto;
    display: flex; align-items: center; gap: 6px;
}
.topBarSite::before { content: '◈'; color: var(--teal); font-size: 14px; }

.topBarMoney { display: flex; align-items: center; gap: 16px; }
.topBarMoneyItem { display: flex; align-items: center; gap: 6px; }
.topBarMoneyLabel {
    font-size: 10px; font-weight: 700; color: var(--muted);
    text-transform: uppercase; letter-spacing: .5px;
}
.topBarMoneyVal {
    font-size: 14px; font-weight: 800;
    color: var(--teal);
    font-variant-numeric: tabular-nums;
}
.topBarMoneySep { width: 1px; height: 20px; background: var(--border2); }

.topBarUser {
    display: flex; align-items: center; gap: 8px;
    background: var(--surf2);
    border: 1px solid var(--border);
    border-radius: 99px;
    padding: 4px 14px 4px 6px;
}
.topBarAvatar {
    width: 26px; height: 26px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--teal), var(--violet));
    color: #000;
    font-size: 11px; font-weight: 900;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.topBarUsername { font-size: 12px; font-weight: 700; color: var(--text); }

.topBarLangWrap { position: relative; }
.topBarLangBtn {
    display: flex; align-items: center; gap: 4px;
    padding: 5px 10px;
    background: var(--surf2); border: 1px solid var(--border);
    border-radius: var(--radius);
    font-size: 12px; font-weight: 600; color: var(--text2);
    transition: border-color .15s, color .15s;
}
.topBarLangBtn:hover { border-color: var(--teal); color: var(--teal); }

.topBarHamburger {
    display: none;
    background: none;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text);
    font-size: 18px;
    padding: 6px 10px;
    margin-right: 4px;
}

/* =====================================================
   NOTICE BAR
===================================================== */
.noticeBar {
    position: fixed;
    top: var(--topbar-h);
    left: var(--rail-w); right: 0;
    height: var(--notice-h);
    background: var(--teal-lt);
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center;
    z-index: 180; overflow: hidden;
}
.noticeBarInner {
    display: flex; align-items: center; gap: 12px;
    padding: 0 20px; width: 100%;
    font-size: 12px; color: var(--text2);
    overflow: hidden;
}
.noticeBadge {
    flex-shrink: 0;
    font-size: 9px; font-weight: 800;
    letter-spacing: 1.5px; text-transform: uppercase;
    color: var(--teal);
    background: var(--teal-md);
    border-radius: 4px;
    padding: 2px 7px;
    border: 1px solid var(--border);
}

/* =====================================================
   PAGE WRAP
===================================================== */
.pageWrap {
    margin-left: var(--rail-w);
    padding-top: calc(var(--topbar-h) + var(--notice-h) + 32px);
    padding-bottom: 64px;
    min-height: 100vh;
}
.container { max-width: var(--container); margin: 0 auto; padding: 0 24px; }

/* =====================================================
   CARDS
===================================================== */
.gCard {
    background: var(--surf);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden; position: relative;
}
.gCard::before {
    content: '';
    position: absolute; top: 0; left: 0;
    width: 48px; height: 2px;
    background: linear-gradient(90deg, var(--teal), transparent);
}
.gCardHead {
    padding: 14px 20px;
    border-bottom: 1px solid var(--border);
    background: var(--bg2);
    display: flex; align-items: center; gap: 10px;
}
.gCardHeadTitle {
    font-size: 13px; font-weight: 700; color: var(--text);
    display: flex; align-items: center; gap: 8px;
}
.gCardHeadTitle::before { content: '◈'; color: var(--teal); font-size: 12px; }
.gCardBody { padding: 20px; }

/* =====================================================
   BUTTONS
===================================================== */
.gBtn-primary {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 22px;
    background: var(--teal); color: #000;
    border: none; border-radius: var(--radius);
    font-size: 13px; font-weight: 800;
    cursor: pointer; transition: .15s; text-decoration: none;
}
.gBtn-primary:hover { background: #5eead4; box-shadow: 0 0 20px var(--teal-glow); }

.gBtn-outline {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 22px;
    background: transparent; color: var(--teal);
    border: 1px solid var(--teal); border-radius: var(--radius);
    font-size: 13px; font-weight: 700;
    cursor: pointer; transition: .15s; text-decoration: none;
}
.gBtn-outline:hover { background: var(--teal-lt); }

.gBtn-danger {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 22px;
    background: var(--red-lt); color: var(--red);
    border: 1px solid rgba(244,63,94,.25); border-radius: var(--radius);
    font-size: 13px; font-weight: 700;
    cursor: pointer; transition: .15s; text-decoration: none;
}
.gBtn-danger:hover { background: var(--red); color: #fff; }

/* =====================================================
   TABLES
===================================================== */
.gTable { width: 100%; border-collapse: collapse; }
.gThead .gTh {
    padding: 10px 14px;
    font-size: 11px; font-weight: 700; color: var(--text2);
    text-transform: uppercase; letter-spacing: .5px;
    background: var(--bg2);
    border-bottom: 1px solid var(--border);
    white-space: nowrap;
}
.gTbody .gTr { border-bottom: 1px solid var(--border2); }
.gTbody .gTr:last-child { border-bottom: none; }
.gTbody .gTr:hover { background: var(--teal-lt); }
.gTd { padding: 13px 14px; font-size: 13px; color: var(--text); vertical-align: middle; }

/* =====================================================
   CHIPS
===================================================== */
.chip {
    display: inline-flex; align-items: center;
    padding: 3px 10px; border-radius: 4px;
    font-size: 11px; font-weight: 700; letter-spacing: .3px;
}
.chip-ok  { background: rgba(34,197,94,.12);  color: #4ade80; border: 1px solid rgba(34,197,94,.25); }
.chip-pnd { background: var(--teal-lt); color: var(--teal); border: 1px solid var(--teal-md); }
.chip-err { background: var(--red-lt);  color: var(--red);  border: 1px solid rgba(244,63,94,.25); }

/* =====================================================
   PAGINATION
===================================================== */
.pagination { display: flex; gap: 4px; justify-content: center; padding: 24px 0 4px; flex-wrap: wrap; }
.pageBtn {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 34px; height: 34px; padding: 0 8px;
    border-radius: 6px;
    background: var(--surf); border: 1px solid var(--border);
    color: var(--text2); font-size: 12px; font-weight: 600;
    text-decoration: none; transition: .15s;
}
.pageBtn:hover { border-color: var(--teal); color: var(--teal); }
.pageBtn.active { background: var(--teal); border-color: var(--teal); color: #000; font-weight: 800; }

/* =====================================================
   FORM ELEMENTS
===================================================== */
.formField { margin-bottom: 18px; }
.formLabel {
    display: block;
    font-size: 11px; font-weight: 700; color: var(--text2);
    margin-bottom: 6px; text-transform: uppercase; letter-spacing: .5px;
}
.formInput, .formTextarea, .formSelect {
    width: 100%;
    background: var(--bg2); border: 1px solid var(--border);
    border-radius: var(--radius); color: var(--text);
    padding: 10px 14px; font-size: 14px; outline: none;
    transition: border-color .15s, box-shadow .15s;
    font-family: inherit; box-sizing: border-box;
}
.formInput:focus, .formTextarea:focus, .formSelect:focus {
    border-color: var(--teal);
    box-shadow: 0 0 0 3px var(--teal-lt);
}
.formInput::placeholder, .formTextarea::placeholder { color: var(--muted); }
.formTextarea { resize: vertical; min-height: 180px; line-height: 1.7; }
.formSelect option { background: var(--surf2); color: var(--text); }
.formActions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 8px; }

/* =====================================================
   LANGUAGE DROPDOWN
===================================================== */
.langDropdown {
    display: none;
    position: absolute; top: calc(100% + 8px); right: 0;
    background: var(--surf2); border: 1px solid var(--border);
    border-radius: 12px; min-width: 160px;
    overflow: hidden; z-index: 9999;
    box-shadow: 0 8px 32px rgba(0,0,0,.7);
}
.langDropdown.open { display: block; }
.langOption {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px; font-size: 13px; color: var(--text2);
    cursor: pointer; transition: .12s;
}
.langOption:hover, .langOption.active { background: var(--teal-lt); color: var(--teal); }
.optFlag { font-size: 16px; }

/* =====================================================
   BADGES
===================================================== */
.navBadge, .msgBadge {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 16px; height: 16px;
    background: var(--red); color: #fff;
    font-size: 9px; font-weight: 800;
    border-radius: 99px; padding: 0 3px;
    vertical-align: middle; line-height: 1;
}

/* =====================================================
   PROVIDER CARDS & SECTIONS
===================================================== */
.providerWrap { margin-bottom: 40px; }
.providerSectionHead { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.providerTitle {
    font-size: 13px; font-weight: 800; color: var(--text);
    text-transform: uppercase; letter-spacing: .05em;
    display: flex; align-items: center; gap: 8px;
}
.providerTitle::before { content: '◈'; color: var(--teal); font-size: 11px; }
.sectionBadge {
    display: inline-block; padding: 2px 10px; border-radius: 4px;
    font-size: 10px; font-weight: 800; letter-spacing: .08em;
    background: var(--teal); color: #000;
}
.sectionBadge.slot { background: var(--violet); color: #fff; }

.providerCard {
    background: var(--surf); border: 1px solid var(--border);
    border-radius: var(--radius-lg); overflow: hidden;
    cursor: pointer; position: relative;
    transition: transform .18s, border-color .18s, box-shadow .18s;
}
.providerCard:hover {
    transform: translateY(-4px);
    border-color: var(--teal);
    box-shadow: 0 8px 28px rgba(45,212,191,.18);
}
.providerImage {
    width: 100%; aspect-ratio: 16/9;
    background-size: cover; background-position: center;
    background-color: var(--bg2);
}
.providerName {
    padding: 8px 10px; font-size: 11px; font-weight: 600;
    color: var(--text2); text-align: center;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    border-top: 1px solid var(--border);
}
.providerOverlay {
    position: absolute; inset: 0;
    background: rgba(45,212,191,.88);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; transition: opacity .18s;
}
.providerCard:hover .providerOverlay { opacity: 1; }
.providerPlayBtn {
    font-size: 11px; font-weight: 800; letter-spacing: .1em;
    color: #000; border: 2px solid rgba(0,0,0,.25);
    padding: 6px 18px; border-radius: 4px;
}

/* =====================================================
   MOBILE FULL-SCREEN OVERLAY
===================================================== */
.mobileFullOverlay {
    display: none;
    position: fixed; inset: 0;
    background: rgba(6,10,20,.97);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    z-index: 500;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 32px 24px;
}
.mobileFullOverlay.open { display: flex; }

.mobileCloseBtn {
    position: absolute; top: 20px; right: 20px;
    width: 40px; height: 40px; border-radius: 50%;
    background: var(--surf2); border: 1px solid var(--border);
    color: var(--text2); font-size: 18px;
    display: flex; align-items: center; justify-content: center;
    transition: .15s;
}
.mobileCloseBtn:hover { border-color: var(--red); color: var(--red); }

.mobileOverlayUser { text-align: center; margin-bottom: 28px; }
.mobileOverlayAvatar {
    width: 52px; height: 52px; border-radius: 50%;
    background: linear-gradient(135deg, var(--teal), var(--violet));
    color: #000; font-size: 18px; font-weight: 900;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 10px;
}
.mobileOverlayName { font-size: 15px; font-weight: 800; color: var(--text); margin-bottom: 4px; }
.mobileOverlayMoney {
    font-size: 12px; color: var(--text2);
    display: flex; align-items: center; justify-content: center; gap: 12px;
}
.mobileOverlayMoney strong { color: var(--teal); font-weight: 800; }

.mobileMenuGrid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    width: 100%; max-width: 340px;
}
.mobileMenuItem {
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 8px; padding: 18px 10px;
    background: var(--surf); border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    color: var(--text2); font-size: 11px; font-weight: 700;
    cursor: pointer; transition: .15s; text-decoration: none;
    position: relative;
}
.mobileMenuItem:hover { border-color: var(--teal); color: var(--teal); background: var(--teal-lt); }
.mobileMenuItem.danger { color: var(--red); border-color: rgba(244,63,94,.2); }
.mobileMenuItem.danger:hover { background: var(--red-lt); border-color: var(--red); }
.mobileMenuIcon { font-size: 22px; }

/* =====================================================
   RESPONSIVE
===================================================== */
@media (max-width: 768px) {
    .navRail { display: none; }
    .topBar { left: 0; padding: 0 16px; gap: 10px; }
    .topBarHamburger { display: flex; }
    .topBarMoney { display: none; }
    .topBarUser { display: none; }
    .topBarLangWrap { display: none; }
    .noticeBar { left: 0; }
    .pageWrap { margin-left: 0; }
    .container { padding: 0 16px; }
}
@media (max-width: 480px) {
    .mobileMenuGrid { gap: 8px; }
    .mobileMenuItem { padding: 14px 8px; }
}
