﻿/* Rank.css — 新增日/夜主題變數並以變數替換顏色
   切換深色：<html data-theme="dark"> 或 document.documentElement.setAttribute('data-theme','dark')
*/

/* ----------------------------- Theme variables ----------------------------- */
:root{
    --text-color: #000000;
    --link-color: #0366d6;
    --white: #ffffff;
    --black: #000000;

    /* accents */
    --accent-green: #198754; /* 原檔 #198754 */
    --success-color: #28a745;
    --danger-color: #dc3545;
    --warning-color: #f59e0b;
    --yellow: #ffeb3b;
    --active-color: crimson;

    /* backgrounds / panels */
    --panel-bg: #ffffff;
    --panel-alt-bg: #f2f2f2;
    --card-bg: #ffffff;
    --aliceblue: aliceblue;

    /* borders / shadows / muted */
    --border-color: #ccc;
    --border-2: rgba(0,0,0,0.125);
    --muted: #999999;
    --muted-gray: gray;
    --box-shadow-color: rgba(0,0,0,0.3);

    /* special */
    --highlight: #f9ff70;      /* hover highlight */
    --card-hover: #fff4b0;
    --readmore-gradient-to: var(--white);
    --modal-overlay: rgba(0,0,0,0.4);
    --box-shadow-10: 0 0 10px var(--border-color);

    /* helper backgrounds */
    --success-bg: var(--success-color);
    --danger-bg: var(--danger-color);
}

/* Dark theme 覆寫 */
[data-theme="dark"]{
    --text-color: #e5e5e5;
    --link-color: #66b2ff;
    --white: #ffffff;
    --black: #000000;

    --accent-green: #9fcfff;
    --success-color: #4caf50;
    --danger-color: #ff6b6b;
    --warning-color: #ffb74d;
    --yellow: rgba(249,255,112,0.12);
    --active-color: #ff7b7b;

    --panel-bg: #232323;
    --panel-alt-bg: #2b2b2b;
    --card-bg: #232323;
    --aliceblue: #1b1b1f;

    --border-color: #444444;
    --border-2: rgba(255,255,255,0.06);
    --muted: #aaaaaa;
    --muted-gray: #999;
    --box-shadow-color: rgba(0,0,0,0.5);

    --highlight: rgba(249,255,112,0.12);
    --card-hover: #343434;
    --readmore-gradient-to: var(--panel-bg);
    --modal-overlay: rgba(0,0,0,0.7);
    --box-shadow-10: 0 0 10px var(--border-color);

    --success-bg: var(--success-color);
    --danger-bg: var(--danger-color);
}

/* ----------------------------- Original rules (colors replaced with variables) ----------------------------- */
body {
    color: var(--text-color);
}


td {
    padding-left: 5px !important;
    height: 30px;
}

th {
    min-width: 50px;
    padding: 0px !important;
}

.selected {
    background-color: var(--selected-bg, var(--yellow));
}

.create-icon-img {
    width: 50px;
    height: 50px;
}

.personalStockTable td {
    min-width: 170px;
}

.labelA { min-width: 70px; }
.labelB { min-width: 70px; }

.textRed { color: var(--danger-color); }
.textGreen { color: var(--success-color); }
.textOrange { color: var(--warning-color); }
.textYellow { color: var(--yellow); }
.textWhite { color: var(--white); }

.text-bcolor-green { background-color: var(--success-bg); }
.text-bcolor-red { background-color: var(--danger-bg); }

a.monthly-revenue {
    padding-left: 5px;
    text-align: right;
    display: block;
    max-width: 80px;
    min-width: 85px;
}

a.monthly-revenue2 {
    padding-left: 5px;
    text-align: right;
    display: block;
    max-width: 80px;
    font-size: 8px;
    color: var(--text-color);
}

a.monthly-revenue-header {
    max-width: 85px;
    display: block;
    color: var(--accent-green);
    padding-left: 5px;
    padding-bottom: 5px;
    text-align: right;
}

a.monthly-revenue-header2 {
    color: var(--success-color);
    display: block;
    text-align: right;
    max-width: 80px;
}

a.income-statement {
    margin: 0px !important;
    padding-left: 5px;
    text-align: right;
    display: block;
    min-width: 85px;
}

a.income-statement-header {
    max-width: 90px;
    display: block;
    color: var(--accent-green);
    padding-left: 5px;
    padding-bottom: 5px;
    text-align: right;
}

a.income-statement-header2 {
    max-width: 85px;
    display: flex;
    color: var(--accent-green);
}

.stockDataChart {
    max-width: 390px !important;
    max-height: 390px !important;
}

.create-icon-div { }

.header-div2.active {
    text-decoration: underline;
    color: var(--active-color);
    font-weight: bold;
}

a.borrowings {
    padding-left: 5px;
    text-align: right;
    display: block;
    min-width: 80px;
}

a.borrowings-header,
a.borrowings-header2 {
    max-width: 85px;
    display: block;
    color: var(--accent-green);
    padding-left: 5px;
    padding-bottom: 5px;
    text-align: right;
}

.ask-price { max-width: 390px; margin: 3px; min-width: 340px; }
.ask-price a { font-size: 25px; }

.card-body {
    padding: 3px !important;
    height: 600px;
    overflow: hidden;
}

.popularity-img { width: 20px; height: 20px; margin-bottom: 5px; }
.popularity-img-area { }

.personal-stock-area {
    position: relative;
    max-width: 1280px;
    margin-right: auto;
    margin-left: auto;
}

.display-text,
.display-text2 {
    color: inherit;
    min-width: 50px;
    display: block;
    text-align: right;
    font-size: 13px;
}

.display-header-text {
    min-width: 50px;
    display: block;
    font-size: 15px;
}

table { min-width: 100%; }

.border-success { border-color: var(--border-success) !important; }

.read-more {
    background-color: var(--panel-alt-bg);
    font-size: 20px;
    text-align: center;
}
.read-more:hover { background-color: var(--highlight); }

.read-more-area {
    position: absolute;
    bottom: 30px;
    left: 0px;
    z-index: 99;
    background: linear-gradient(180deg, rgba(255,255,255,0), var(--readmore-gradient-to));
    width: 100%;
}
.read-more-area:hover { cursor: pointer; }

.read-more-text {
    display: block;
    font-size: 20px;
    text-align: center;
    font-weight: bold;
}

.card-header { padding: 0.5rem 0.5rem !important; }

.traning-chart-img, .info-img { width: 15px; height: 15px; }

.ai-chart-contain {
    position: relative;
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
    background-color: var(--panel-bg);
}

.ai-chart-window {
    display: none;
    width: 300px;
    height: 300px;
    border: 1px solid var(--border-color);
    box-shadow: var(--box-shadow-10);
    position: absolute;
    z-index: 99;
    background-color: var(--panel-bg);
}
.ai-chart-header {
    background-color: var(--panel-alt-bg);
    padding: 10px;
    border-bottom: 1px solid var(--border-color);
}
.close-ai-chart-btn { float: right; border: none; background-color: transparent; cursor: pointer; }
.ai-chart-body { background-color: var(--panel-bg); }

.chain-window, .esg-window, .news-window, .video-window, .FIIs-window {
    display: none;
    width: 360px;
    height: auto;
    border: 1px solid var(--border-color);
    box-shadow: var(--box-shadow-10);
    position: absolute;
    z-index: 99;
    background-color: var(--panel-bg);
}

.chain-header, .esg-header, .news-header, .video-header, .FIIs-header, .market-header {
    background-color: var(--panel-alt-bg);
    padding: 10px;
    border-bottom: 1px solid var(--border-color);
}

.chain-body, .news-body, .video-body, .FIIs-body {
    background-color: var(--panel-bg);
    overflow: auto;
    height: 500px;
    border: solid;
    border-width: 1px;
    border-color: var(--muted-gray);
}

.esg-wrapper { display: grid; grid-template-rows: 30px auto auto auto auto; grid-template-columns: auto auto; }
.esg-label { color: coral; }
.esg-text { color: var(--text-color); }

.news-wrapper { display: grid; grid-template-columns: 1fr; grid-template-rows: auto auto 25px; grid-auto-rows: 60px; }
.news-wrapper .box2 p { overflow: hidden; display: -webkit-box; text-overflow: ellipsis; -webkit-line-clamp: 3; -webkit-box-orient: vertical; white-space: normal; }

.option-img { width: 20px; height: 20px; }
.option-img-area { position: absolute; right: 0px; }

.market-window {
    position: fixed;
    top: 135px;
    left: 6px;
    background-color: var(--panel-bg);
    border: 1px solid var(--border-color);
    box-shadow: 2px 2px 5px var(--box-shadow-color);
    width: 300px;
    height: 200px;
    z-index: 99;
}
.market-header { background-color: var(--panel-alt-bg); padding: 10px; border-bottom: 1px solid var(--border-color); }
.close-market-btn{float:right;}
.close-market-btn:hover {
    color: var(--danger-color);
}
.close-market-img { width: 15px; height: 15px; }

.market-body { overflow: auto; height: 150px; scrollbar-width: thin; }

.rank-loading-img { width: 100px; height: 100px; }

@media screen and (min-width: 575px) {
    .rank-area { display: flex; justify-content: center; max-width: 366px; }
    .card {
        margin: 3px;
        min-width: 340px;
        max-width: 366px;
        overflow-y: hidden;
        border-color: var(--card-bg);
    }
}

@media screen and (max-width: 575px) {
    .rank-area { display: flex; justify-content: center; }
    .card {
        margin: 3px;
        min-width: 340px;
        width: 100%;
        overflow-y: hidden;
        border-color: var(--card-bg);
    }
}

.display-header-text { min-width: 50px; display: block; font-size: 15px; }
.display-header-text2 { min-width: 50px; display: block; text-align: right; font-size: 15px; }
.displayUpDown, .displayUpDownPercentage { color: inherit !important; display: block; text-align: right; font-size: 13px; }