﻿/* ===== DASHBOARD THEME ===== */

body {
    margin: 0;
    background: linear-gradient(180deg, #0B1220 0%, #0E1628 100%);
    color: #D0D7E2;
    font-family: 'Inter', 'Pretendard', sans-serif;
}

.dashboard {
    padding: 24px 40px;
}

/* 상단 바 */
.top-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #1E2A4A;
    padding-bottom: 12px;
    margin-bottom: 32px;
}


.logo {
    font-size: 22px;
    letter-spacing: 2px;
    color: #E6ECF5;
}

.new-signal-btn {
    background: none; /* 배경 제거 */
    border: none; /* 테두리 제거 */
    padding: 0; /* 여백 제거 */

    font-size: 12px;
    color: #FF4D4D;
    font-family: 'JetBrains Mono', monospace;
    cursor: pointer;
}

.hero-image {
    width: 50%;
    height: auto;
    margin: 0 auto;
    margin-bottom: 10px;
    display: block;
}

    .hero-image img {
        width: 100%;
        height: auto;
        display: block;
    }



@media (max-width: 768px) {

    /* 시세표 보기 버튼(Accordion 헤더) 키우기 */
    .accordion-button {
        padding: 18px 20px;
        font-size: 16px;
        letter-spacing: 1px;
    }

    /* 펼쳐진 영역 여백 조정 */
    .accordion-body {
        padding: 16px 12px;
    }

    /* 시세표 이미지 모바일 최적화 */
    .hero-image {
        width: 100%;
        margin-bottom: 16px;
    }

        .hero-image img {
            width: 100%;
            height: auto;
            max-height: none; /* ❗ 깨짐 방지 */
        }
}

.tier-header {
    margin-top: 80px;
}

.accordion-item {
    background-color: #121C35; /* price-card랑 동일 */
    border: 1px solid #1E2A4A;
}

.accordion-button {
    background-color: #0F1A30; /* top-bar 계열 */
    color: #D0D7E2;
    font-family: 'JetBrains Mono', monospace;
    font-size: 14px;
    letter-spacing: 1px;
}

    .accordion-button:not(.collapsed) {
        background-color: #121C35;
        color: #E6ECF5;
    }

/* 계산기 박스 확장 */
.tier-calc-box {
    margin: 0 auto;
    max-width: 420px;
    padding: 28px;
}

/* 계산기 제목 */
.tier-title {
    text-align: center;
    margin-bottom: 24px;
    font-size: 18px;
    color: #E6ECF5;
}

/* 라벨 */
.tier-calc-box label {
    display: block;
    margin-top: 14px;
    margin-bottom: 6px;
    font-size: 13px;
    color: #8FA3C8;
}

/* input / select */
.tier-calc-box input,
.tier-calc-box select {
    width: 100%;
    background: #0F1A30;
    border: 1px solid #1E2A4A;
    color: #D0D7E2;
    padding: 10px 12px;
    border-radius: 6px;
    font-size: 14px;
}

/* 체크박스 줄 */
.check-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 16px;
    font-size: 13px;
    color: #D0D7E2;
    display: flex !important;
}

    .check-row input[type="checkbox"] {
        width: 18px;
        height: 18px;
        margin: 0; /* 🔥 이게 위치 튀는 원인 제거 */
        accent-color: #4DA6FF; /* 색 통일 */
        flex-shrink: 0;
    }

.check-row input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 0;              /* 🔥 이게 위치 튀는 원인 제거 */
    accent-color: #4DA6FF;  /* 색 통일 */
    flex-shrink: 0;
}

/* 버튼 영역 */
.tier-calc-box .buttons {
    display: flex;
    gap: 10px;
    margin-top: 20px;
}

.tier-calc-box button {
    flex: 1;
    background: #162447;
    border: 1px solid #1E2A4A;
    color: #E6ECF5;
    padding: 10px;
    border-radius: 6px;
    cursor: pointer;
}

    .tier-calc-box button:hover {
        background: #1E2A4A;
    }

/* 결과 */
.tier-calc-box .result {
    display: none;
    margin-top: 20px;
    background: #0B1220;
    border: 1px solid #1E2A4A;
    padding: 14px;
    border-radius: 6px;
    font-size: 13px;
}


/* 시세 카드 */
.price-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 20px;
}

.price-card {
    background: #121C35;
    border: 1px solid #1E2A4A;
    padding: 20px;
    border-radius: 6px;
}

    .price-card .item {
        font-size: 13px;
        color: #8FA3C8;
        margin-bottom: 8px;
    }

    .price-card .price {
        font-size: 15px;
        font-family: 'Inter', 'Pretendard', sans-serif; /* 본문용 */
        line-height: 1.7; /* 핵심 */
        letter-spacing: -0.01em; /* 한글 보정 */
        color: #E6ECF5;
    }


    .price-card .change {
        font-size: 14px;
        font-family: 'JetBrains Mono', monospace;
    }

    /* 상승 / 하락 */
    .price-card.up .change {
        color: #FF4D4D;
    }

    .price-card.down .change {
        color: #4DA6FF;
    }


    /*시세 변동*/
.market-summary {
    display: flex;
    gap: 16px;
    margin-bottom: 32px;
    margin-top: 20px;
}

.summary {
    flex: 1;
    padding: 14px;
    border-radius: 8px;
    text-align: center;
    font-family: 'JetBrains Mono', monospace;
    font-size: 14px;
    border: 1px solid #1E2A4A;
}

    .summary.up {
        background: rgba(255,77,77,0.12);
        color: #FF4D4D;
    }

    .summary.down {
        background: rgba(77,166,255,0.12);
        color: #4DA6FF;
    }

    .summary.flat {
        background: rgba(160,160,160,0.12);
        color: #A0A0A0;
    }

.market-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 18px;
}

.market-card {
    background: #121C35;
    border: 1px solid #1E2A4A;
    border-radius: 8px;
    padding: 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.card-name {
    font-size: 14px;
    color: #E6ECF5;
}

.card-change {
    font-family: 'JetBrains Mono', monospace;
    font-size: 14px;
}

.market-card.up .card-change {
    color: #FF4D4D;
}

.market-card.down .card-change {
    color: #4DA6FF;
}

.market-card.flat .card-change {
    color: #A0A0A0;
}

@media (max-width: 768px) {
    .market-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }
}

/*공지사항*/
/* ===== 공지사항 ===== */

.notice-doc {
    max-width: 900px;
    margin: 0 auto;
}

.notice-section {
    margin-bottom: 32px;
}

    .notice-section h2 {
        font-size: 25px;
        margin-bottom: 14px;
        color: #E6ECF5;
    }

    .notice-section p,
    .notice-section li {
        line-height: 1.7;
        font-size: 20px;
        color: #D0D7E2;
    }

    .notice-section ul,
    .notice-section ol {
        padding-left: 20px;
    }

/* 펼치기 버튼 */
.notice-toggle {
    width: 100%;
    text-align: left;
    background: #0F1A30;
    border: 1px solid #1E2A4A;
    color: #E6ECF5;
    padding: 14px 16px;
    border-radius: 6px;
    margin-bottom: 12px;
    cursor: pointer;
    font-size: 14px;
}

    .notice-toggle.warning {
        border-color: #FF4D4D;
    }

    .notice-toggle:hover {
        background: #121C35;
    }

/* 주의 대상 테이블 */
.warning-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    margin-top: 10px;
}

    .warning-table th,
    .warning-table td {
        border: 1px solid #1E2A4A;
        padding: 8px;
    }

    .warning-table th {
        background: #0F1A30;
        color: #E6ECF5;
    }

.notice-foot {
    margin-top: 10px;
    font-size: 12px;
    color: #8FA3C8;
}


/* 📱 모바일 전용 텍스트 크기 조정 */
/* 📱 모바일 전용 텍스트 크기 조정 */
@media (max-width: 768px) {

    /* 사기예방법 */
    .notice-section h2 {
        font-size: 20px;
    }

    .notice-section p,
    .notice-section li {
        font-size: 13px;
        line-height: 1.6;
    }

    /* 🔽 운영공지(아코디언 내부 텍스트) */
    .accordion-body p,
    .accordion-body li {
        font-size: 13px;
        line-height: 1.6;
    }

    .accordion-button {
        font-size: 13px;
    }

    .notice-toggle {
        font-size: 13px;
    }

    .warning-table {
        font-size: 12px;
    }

    .notice-foot {
        font-size: 11px;
    }
}

.delete-btn {
    display: none;
    position: absolute;
    top: 6px;
    right: 8px;
    background: none;
    border: none;
    color: #7F8FB5;
    font-size: 14px;
    cursor: pointer;
}

    .delete-btn.enabled {
        display: block;
    }

.market-grid {
    margin-bottom: 50px;
}


.price-card {
    opacity: 0;
    transform: translateY(20px);
    animation: cardIn 0.45s ease-out forwards;
}

@keyframes cardIn {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.market-card {
    opacity: 0;
    transform: translateY(16px) scale(0.98);
    animation: marketIn 0.5s ease-out forwards;
}

@keyframes marketIn {
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/**/
.chart-section {
    margin-top: -10px;
    padding: 20px;
    background: #0f172a;
    border-radius: 12px;
}

.chart-title {
    margin-bottom: 14px;
    font-size: 18px;
}

.chart-summary {
    display: flex;
    gap: 20px;
    margin-top: 14px;
    font-size: 14px;
    color: #cbd5f5;
}

.new-signal-select {
    background: #0F1A30;
    border: 1px solid #1E2A4A;
    color: #D0D7E2;
    font-size: 12px;
    font-family: 'JetBrains Mono', monospace;
    padding: 6px 10px;
    border-radius: 6px;
    cursor: pointer;
}

.new-signal-selects {
    background: #0F1A30;
    border: 1px solid #1E2A4A;
    color: #D0D7E2;
    font-size: 12px;
    font-family: 'JetBrains Mono', monospace;
    padding: 6px 10px;
    border-radius: 6px;
    cursor: pointer;
    margin-left: auto;
    margin-right: 6px;
}

.chart-wrapper {
    height: auto; /* PC 기본 */
}

@media (max-width: 768px) {
    #mafiaChart {
        height: 300px !important;
        max-height: 300px !important;
    }
}

#mafiaChart {
    max-width: 100%;
    display: block;
}

.top-bar {
    display: flex;
    flex-direction: column; /* 세로 정렬 */
    align-items: flex-start;
    gap: 12px;
    border-bottom: 1px solid #1E2A4A;
    padding-bottom: 12px;
    margin-bottom: 32px;
}

.select-row {
    display: flex;
    gap: 10px;
    justify-content: flex-end; /* 👉 오른쪽 정렬 */
    width: 100%; /* 👉 전체 너비 차지 */
}
.new-signal-btn {
    margin-left: auto;
}

