/* ===== RESET & VARS ===== */
:root {
    --bg: #f4f5f7;
    --surf: #ffffff;
    --surf2: #f9fafb;
    --border: #d1d5db;
    --border2: #9ca3af;
    --txt: #111827;
    --muted: #4b5563;
    --accent: #b91c1c; /* 党建红 / 政务红 */
    --gold: #d97706;
    --gold2: #92400e;
    --green: #059669;
    --red: #dc2626;
    --purple: #1e3a8a; /* 深海蓝 */
    --orange: #ea580c;
    --danger-border: rgba(220,38,38,0.4);
    --warn-border: rgba(217,119,6,0.35);
    /* 彻底移除圆角，体现严肃正式感 */
    --rad: 2px; 
    --rad-sm: 2px;
    --tr: 0.15s ease;
    --shadow: 0 2px 6px rgba(0,0,0,0.08);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
/* 字体：优先宋体/仿宋，用于大标题、正式文档，备用雅黑用于正文清晰度 */
body{font-family:'SimSun','FangSong','Microsoft YaHei','PingFang SC',system-ui,sans-serif;background:var(--bg);color:var(--txt);min-height:100vh;overflow-y:auto;-webkit-tap-highlight-color:transparent;}
input,select,button{font-family:'Microsoft YaHei','PingFang SC',sans-serif;}

/* ===== BACKGROUND ===== */
.app-bg{position:fixed;inset:0;z-index:0;background:var(--bg);border-top: 4px solid var(--accent);}
.orb{display:none !important;}

/* ===== SCREENS ===== */
.screen{position:absolute;inset:0;z-index:10;overflow-y:auto;display:flex;flex-direction:column;}
.screen.hidden{display:none!important;}
.screen.active{display:flex;}

/* ===== GLASS (Renamed mentally but keeping class to avoid html refactors) ===== */
.glass-card{background:var(--surf);border:1px solid var(--border);border-radius:var(--rad);box-shadow:var(--shadow);}

/* ===== LOGIN SCREEN ===== */
#screen-login{align-items:center;padding:40px 20px;}
.login-wrap{width:100%;max-width:420px;display:flex;flex-direction:column;gap:16px;align-items:stretch;}
.game-logo{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid var(--accent);}
.logo-seal{width:64px;height:64px;border:3px solid var(--accent);border-radius:50%;color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:900;font-family:'SimSun';letter-spacing:2px;}
.logo-text{text-align:center;}
.logo-text h1{font-size:2rem;font-weight:900;color:var(--accent);font-family:'SimSun',serif;letter-spacing:4px;}
.logo-text p{font-size:0.9rem;color:var(--txt);margin-top:6px;letter-spacing:2px;font-family:'FangSong',serif;}

.btn-entry{width:100%;background:var(--surf);border:1px solid var(--border);border-radius:var(--rad);padding:16px 20px;cursor:pointer;display:flex;align-items:center;gap:14px;transition:background var(--tr),border-color var(--tr);box-shadow:0 1px 3px rgba(0,0,0,0.05);}
.btn-entry:hover{background:var(--surf2);border-color:var(--accent);}
.btn-entry:active{background:#e5e7eb;}
.entry-icon{font-size:1.8rem;flex-shrink:0;}
.entry-text{flex:1;text-align:left;}
.entry-title{font-size:1.1rem;font-weight:700;color:var(--txt);}
.entry-sub{font-size:0.8rem;color:var(--muted);margin-top:2px;}
.entry-arrow{font-size:1.8rem;color:var(--muted);font-weight:300;}

.save-slots-title{text-align:center;font-size:0.8rem;color:var(--muted);letter-spacing:2px;margin-bottom:10px;font-weight:bold;}
.save-slot{width:100%;background:var(--surf);border:1px solid var(--border);border-radius:var(--rad);padding:12px 16px;cursor:pointer;display:flex;align-items:center;gap:14px;transition:background var(--tr),border-color var(--tr);margin-bottom:10px;}
.save-slot:hover{background:var(--surf2);border-color:var(--accent);}
.slot-avatar{font-size:1.5rem;width:40px;height:40px;background:#f3f4f6;border-radius:var(--rad);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--border);}
.slot-info{flex:1;text-align:left;}
.slot-name{font-size:1rem;font-weight:700;color:var(--txt);}
.slot-meta{font-size:0.75rem;color:var(--muted);margin-top:2px;}
.slot-delete{font-size:0.9rem;color:var(--muted);padding:4px 8px;cursor:pointer;background:#f3f4f6;border:1px solid var(--border);border-radius:var(--rad);transition:all var(--tr);}
.slot-delete:hover{color:#fff;background:var(--red);border-color:var(--red);}

.login-footer{text-align:center;font-size:0.75rem;color:var(--muted);margin-top:10px;}

/* ===== FORM ELEMENTS ===== */
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-group label{font-size:0.82rem;color:var(--txt);font-weight:700;}
.form-row{display:flex;gap:12px;}
.form-group.half{flex:1;}

.form-group input[type="text"],
.form-group input[type="password"] {
    width:100%; background:var(--surf); border:1px solid var(--border2);
    border-radius:var(--rad); padding:10px 12px; color:var(--txt);
    font-size:0.95rem; font-weight:500; outline:none; transition:border-color var(--tr);
}
.form-group input:focus{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent);}

.form-group select {
    width:100%; background:var(--surf); border:1px solid var(--border2);
    border-radius:var(--rad); padding:10px 32px 10px 12px; color:var(--txt);
    font-size:0.95rem; font-weight:500; outline:none; cursor:pointer;
}
.form-group select:focus{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent);}
.form-group select option { background:var(--surf); color:var(--txt); font-weight:normal; }

.radio-group{display:flex;gap:8px;}
.radio-opt{position:relative;flex:1;}
.radio-opt input{position:absolute;opacity:0;}
.radio-opt span{
    display:flex;align-items:center;justify-content:center;
    padding:8px 0; background:var(--surf2); border:1px solid var(--border2);
    border-radius:var(--rad); font-size:0.9rem; font-weight:600; color:var(--muted);
    cursor:pointer; transition:all var(--tr); width:100%;
}
.radio-opt input:checked + span {
    background:var(--accent); border-color:var(--accent); color:#fff;
}

.btn-primary{width:100%;background:var(--accent);color:white;border:1px solid #991b1b;border-radius:var(--rad);padding:12px;font-size:1.05rem;font-weight:700;cursor:pointer;transition:background var(--tr);letter-spacing:2px;font-family:'SimSun',serif;}
.btn-primary:hover{background:#991b1b;}
.btn-primary:active{background:#7f1d1d;}
.btn-ghost{background:var(--surf);border:1px solid var(--border2);color:var(--txt);border-radius:var(--rad);padding:8px 20px;font-size:0.85rem;font-weight:600;cursor:pointer;transition:background var(--tr);}
.btn-ghost:hover{background:var(--surf2);}

/* ===== CREATE SCREEN ===== */
#screen-create{align-items:center;padding:20px 16px 80px;}
.create-wrap{width:100%;max-width:480px;display:flex;flex-direction:column;gap:16px;}
.create-header{text-align:center;border-bottom:2px solid var(--accent);padding-bottom:10px;}
.doc-stamp{display:inline-block;border:2px solid var(--accent);color:var(--accent);font-size:0.9rem;font-weight:800;padding:2px 12px;border-radius:2px;letter-spacing:4px;margin-bottom:8px;font-family:'SimSun',serif;}
.create-header h2{font-size:1.4rem;font-weight:800;color:var(--txt);font-family:'SimSun',serif;}
.hint-text{font-size:0.8rem;color:var(--muted);margin-top:6px;}
.create-form{padding:20px;display:flex;flex-direction:column;gap:14px;background:#fff;}
.track-options{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.track-opt{background:var(--surf);border:1px solid var(--border2);border-radius:var(--rad);padding:10px;cursor:pointer;transition:all var(--tr);}
.track-opt.active{border-color:var(--accent);background:rgba(185,28,28,0.05);box-shadow:inset 0 0 0 1px var(--accent);}
.track-title{font-size:0.9rem;font-weight:700;color:var(--txt);margin-bottom:4px;}
.track-desc{font-size:0.75rem;color:var(--muted);line-height:1.4;}
.create-preview{padding:12px;background:#f9fafb!important;margin-top:6px;border:1px dashed var(--border2);}
.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.prev-item{text-align:center;}
.prev-label{font-size:0.75rem;color:var(--muted);font-weight:600;}
.prev-val{font-size:1.05rem;font-weight:800;color:var(--accent);margin-top:2px;}

/* ===== MAIN SCREEN ===== */
#screen-main{background:var(--bg);overflow-y:auto;padding-bottom:72px;}

/* Official Header Banner */
.status-bar{background:var(--accent);color:#fff;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px rgba(0,0,0,0.2);}
.char-info{display:flex;align-items:center;gap:12px;}
.char-avatar{font-size:2.2rem;width:48px;height:48px;background:#fff;border:2px solid #fff;border-radius:2px;display:flex;align-items:center;justify-content:center;color:var(--txt);}
.char-name-role{font-size:1.05rem;font-weight:700;color:#fff;}
.char-sub{font-size:0.75rem;color:rgba(255,255,255,0.85);margin-top:4px;}

.hdr-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;}
.time-info{text-align:right;}
.year-txt{font-size:1rem;font-weight:800;color:#fff;letter-spacing:1px;font-family:'SimSun',serif;}
.season-chip{font-size:0.75rem;color:#fde047;font-weight:bold;}

.hdr-actions{display:flex;gap:6px;}
.hdr-btn{display:flex;align-items:center;gap:4px;background:#991b1b;border:1px solid #7f1d1d;border-radius:2px;padding:4px 8px;color:#fff;font-size:0.75rem;font-weight:600;cursor:pointer;transition:background var(--tr);}
.hdr-btn:hover{background:#7f1d1d;}
.hdr-btn-exit{background:#fff;color:var(--accent);border-color:#fff;}
.hdr-btn-exit:hover{background:#f3f4f6;}

/* Mini Stats Row */
.mini-stats-row{display:flex;align-items:center;gap:8px;padding:12px 14px;background:#fff;border-bottom:1px solid var(--border);}
.ms-item{display:flex;align-items:center;gap:6px;flex:1;}
.ms-icon{font-size:0.95rem;}
.ms-bar-wrap{flex:1;height:6px;background:#e5e7eb;border-radius:2px;overflow:hidden;}
.ms-bar{height:100%;transition:width 0.4s ease,background 0.4s;}
.health-bar{background:var(--green);}
.mind-bar{background:var(--purple);}
.int-bar{background:var(--gold);}
.ms-val{font-size:0.75rem;font-weight:700;color:var(--txt);min-width:26px;text-align:right;}
.ms-money{font-size:0.85rem;font-weight:800;color:var(--gold2);white-space:nowrap;margin-left:6px;}

/* Phase Progress (Study / Performance) */
.phase-bar-wrap{margin:12px 14px;padding:12px 14px;background:#fff;border:1px solid var(--border);border-radius:2px;}
.phase-bar-label{display:flex;justify-content:space-between;font-size:0.8rem;color:var(--txt);font-weight:700;margin-bottom:6px;}
.phase-track{height:10px;background:#e5e7eb;border-radius:2px;overflow:hidden;margin-bottom:6px;border:1px solid #d1d5db;}
.phase-fill{height:100%;background:var(--accent);transition:width 0.5s;}
.phase-hint{font-size:0.75rem;color:var(--muted);line-height:1.4;}

/* Tabs */
.tab-content-area{padding:0 14px;}
.tab-section{display:none;flex-direction:column;gap:12px;}
.tab-section.active{display:flex;}
.section-header{display:flex;justify-content:space-between;align-items:baseline;border-bottom:2px solid var(--accent);padding-bottom:6px;margin-bottom:4px;}
.section-header>span:first-child{font-size:1.1rem;font-weight:800;color:var(--txt);font-family:'SimSun',serif;}
.section-sub{font-size:0.75rem;color:var(--muted);}
.tab-note{font-size:0.8rem;color:var(--gold2);background:#fffbeb;border:1px solid #fcd34d;padding:8px 10px;font-weight:600;}

/* Action Grid */
.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.act-btn{background:#fff;border:1px solid var(--border);border-radius:2px;padding:12px;cursor:pointer;display:flex;align-items:stretch;gap:10px;text-align:left;transition:all var(--tr);box-shadow:0 1px 2px rgba(0,0,0,0.05);min-height:100px;box-sizing:border-box;}
.act-btn:hover{border-color:var(--accent);background:#fef2f2;}
.act-btn:active{background:#fee2e2;}
.act-btn.disabled{opacity:0.5;pointer-events:none;background:#f3f4f6;}
.btn-emoji{font-size:1.8rem;flex-shrink:0;margin-top:2px;}
.btn-body{display:flex;flex-direction:column;flex:1;}
.btn-name{font-size:0.95rem;font-weight:700;color:var(--txt);}
.btn-cost-tag{font-size:0.75rem;color:var(--gold2);font-weight:700;margin-top:4px;}
.btn-effs{margin-top:auto;padding-top:6px;}

/* News Tab */
.news-list{list-style:none;display:flex;flex-direction:column;gap:8px;}
.lb-type-tabs{display:flex;justify-content:center;gap:16px;margin-bottom:12px;border-bottom:1px solid var(--border2);padding-bottom:8px;}
.lb-type-btn{background:none;border:none;font-size:1rem;font-weight:800;color:var(--muted);cursor:pointer;padding:4px 8px;transition:color var(--tr);font-family:'SimSun',serif;border-bottom:2px solid transparent;}
.lb-type-btn.active{color:var(--accent);border-bottom-color:var(--accent);}

.lb-tabs{display:flex;gap:4px;margin-bottom:12px;background:var(--surf2);border-radius:4px;padding:4px;border:1px solid var(--border);}
.lb-tab{flex:1;padding:8px 0;border:none;background:transparent;font-size:0.85rem;font-weight:700;color:var(--muted);cursor:pointer;border-radius:4px;transition:all var(--tr);font-family:'Microsoft YaHei', sans-serif;}
.lb-tab.active{background:#fff;color:var(--txt);box-shadow:0 1px 3px rgba(0,0,0,0.1);border:1px solid var(--border2);}

.lb-my-rank{margin:10px 0 12px;padding:10px 12px;border:1px solid rgba(185,28,28,.18);background:linear-gradient(180deg, rgba(255,251,235,.95), rgba(254,242,242,.95));border-radius:10px;box-shadow:0 4px 14px rgba(127,29,29,.06);}
.lb-my-rank.hidden{display:none;}
.lb-my-rank-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px;}
.lb-my-rank-title{font-size:.82rem;font-weight:800;color:#991b1b;letter-spacing:1px;}
.lb-my-rank-badge{font-size:.95rem;font-weight:900;color:#111827;}
.lb-my-rank-meta{font-size:.78rem;color:#6b7280;line-height:1.6;}
.lb-my-rank-strong{font-weight:800;color:#111827;}

.news-item{background:#fff;border:1px solid var(--border);border-radius:2px;padding:10px 12px;display:flex;gap:10px;align-items:flex-start;}
.news-item-emoji{font-size:1.4rem;}
.news-item-title{font-size:0.9rem;font-weight:800;color:var(--txt);margin-bottom:2px;}
.news-item-desc{font-size:0.8rem;color:var(--muted);line-height:1.5;}
.news-item-time{font-size:0.75rem;color:var(--border2);margin-top:4px;font-style:italic;}
.news-item.n-good{border-left:4px solid var(--green);}
.news-item.n-bad{border-left:4px solid var(--red);}
.news-item.n-warn{border-left:4px solid #f59e0b;}
.news-item.n-info{border-left:4px solid var(--purple);}
.news-item.n-event{border-left:4px solid var(--accent);}

/* Dossier - Totally rewritten to look like an official paper file */
.dossier{background:#fff;border:1px solid #ccc;padding:20px 16px;box-shadow:0 0 10px rgba(0,0,0,0.05);position:relative;min-height:500px;}
.dossier::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--accent);}
.dossier-header{text-align:center;margin-bottom:24px;}
.dossier-top-line{font-size:0.8rem;color:var(--accent);letter-spacing:10px;margin-bottom:8px;}
.dossier-subtitle{font-size:1.6rem;font-weight:900;color:var(--accent);font-family:'SimSun',serif;letter-spacing:4px;}
.dossier-emblem{font-size:3rem;color:var(--accent);margin:10px 0;}

.dossier-photo-row{display:flex;gap:16px;margin-bottom:20px;}
.dossier-photo{width:90px;height:120px;background:#f3f4f6;border:2px solid #ccc;display:flex;align-items:center;justify-content:center;font-size:3rem;flex-shrink:0;}
.dossier-basic{flex:1;border-top:2px solid var(--txt);border-bottom:2px solid var(--txt);padding:8px 0;}
.dos-row{display:flex;align-items:stretch;border-bottom:1px solid #eee;font-size:0.85rem;}
.dos-row:last-child{border-bottom:none;}
.dos-lbl{color:var(--txt);width:80px;flex-shrink:0;font-weight:700;padding:6px 0;letter-spacing:2px;border-right:1px solid #eee;margin-right:12px;}
.dos-val{color:var(--txt);font-weight:600;padding:6px 0;flex:1;}
.dos-val.highlight{color:var(--accent);font-weight:800;font-size:0.9rem;}

.dossier-divider{text-align:center;font-size:1rem;color:var(--txt);font-weight:800;letter-spacing:4px;margin:20px 0 12px;border-bottom:2px solid #ccc;padding-bottom:4px;font-family:'SimSun',serif;}
.stat-rows{display:flex;flex-direction:column;gap:8px;}
.dos-stat-row{display:flex;align-items:center;gap:12px;}
.dos-stat-lbl{font-size:0.85rem;color:var(--txt);width:80px;font-weight:700;letter-spacing:1px;}
.dos-stat-track{flex:1;height:8px;background:#e5e7eb;border:1px solid #ccc;border-radius:0;}
.dos-stat-fill{height:100%;background:var(--txt);transition:width 0.5s;}
.dos-stat-val{font-size:0.85rem;font-weight:800;min-width:30px;text-align:right;}

.history-list{list-style:none;display:flex;flex-direction:column;gap:10px;}
.history-item{font-size:0.85rem;color:var(--txt);line-height:1.5;position:relative;padding-left:14px;}
.history-item::before{content:'■';position:absolute;left:0;top:2px;color:var(--accent);font-size:0.7rem;}
.history-item .hi-year{font-weight:800;margin-right:8px;}

/* ===== WEALTH DASHBOARD ===== */
.wealth-dashboard {background:linear-gradient(145deg, #1e293b, #0f172a);color:#fff;padding:24px;border:1px solid #334155;border-radius:12px;margin-bottom:20px;box-shadow:0 8px 24px rgba(0,0,0,0.2);position:relative;overflow:hidden;}
.wealth-dashboard::after{content:'';position:absolute;top:0;right:0;width:150px;height:150px;background:radial-gradient(circle, rgba(245,158,11,0.15) 0%, transparent 70%);border-radius:50%;pointer-events:none;transform:translate(30%, -30%);}
.wd-title{font-size:0.85rem;color:#94a3b8;font-weight:600;letter-spacing:1px;}
.wd-total{font-size:2.8rem;font-weight:900;margin:8px 0 20px;font-family:'Courier New', monospace;color:#fcd34d;text-shadow:0 2px 4px rgba(0,0,0,0.5);}
.wd-split{display:flex;justify-content:space-between;border-top:1px solid rgba(255,255,255,0.1);padding-top:16px;}
.wd-item{display:flex;flex-direction:column;gap:4px;}
.wd-item .wd-label{font-size:0.75rem;color:#94a3b8;}
.wd-item .wd-val{font-size:1.1rem;font-weight:700;}
.stock-panel{border-left:4px solid var(--accent);margin-bottom:24px;padding:16px;background:var(--surf);}
.loan-panel{border-left:4px solid var(--red);margin-bottom:24px;padding:16px;background:var(--surf);}
.sp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.sp-header h3{margin:0;font-size:1.1rem;color:var(--txt);}
.sp-tag{font-size:0.7rem;background:#dcfce7;color:#166534;padding:2px 8px;border-radius:12px;font-weight:bold;}
.sp-desc{font-size:0.85rem;color:var(--muted);line-height:1.5;margin-bottom:16px;}
.sp-actions{display:grid;grid-template-columns:1fr;gap:12px;}
.sp-btn{padding:12px 0;background:#f3f4f6;border:1px solid var(--border);border-radius:8px;font-size:0.95rem;font-weight:700;color:var(--txt);cursor:pointer;transition:all 0.2s;}
.sp-btn:hover{background:#e5e7eb;}
.sp-btn.sp-sell{background:rgb(254, 242, 242);border-color:#fca5a5;color:#b91c1c;grid-column: span 2;}
.sp-btn.disabled{opacity:0.4;cursor:not-allowed;}

/* ===== WEALTH / TRADE LAYOUT OPTIMIZATION ===== */
.market-card{background:linear-gradient(180deg,#fff,#fafafa);border:1px solid #e5e7eb;border-radius:14px;padding:14px 14px 10px;margin-bottom:14px;box-shadow:0 6px 18px rgba(15,23,42,.05)}
.market-card__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}
.market-card__title{font-size:1rem;font-weight:800;color:var(--txt)}
.market-card__sub{font-size:.78rem;color:var(--muted);margin-top:4px;line-height:1.4}
.market-trend{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;font-weight:800;white-space:nowrap}
.market-trend.up{background:#fef2f2;color:#b91c1c}
.market-trend.down{background:#ecfdf5;color:#047857}
.market-trend__icon{font-size:1rem;line-height:1}
.market-trend__value{font-size:1rem;line-height:1.1}
.market-trend__diff{font-size:.75rem;opacity:.85;margin-top:2px}
.market-chart-wrap{overflow-x:auto;padding-bottom:2px;-webkit-overflow-scrolling:touch}
.market-chart{width:max(100%, 720px);height:170px;display:block;overflow:visible}
.market-gridline{stroke:#e5e7eb;stroke-dasharray:4 4;stroke-width:1}
.market-axis-label{font-size:9px;fill:#94a3b8;text-anchor:middle}
.wealth-stack{display:grid;grid-template-columns:1fr;gap:12px}
.wealth-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:stretch}
.wealth-form-grid-stock{grid-template-columns:1fr 1fr}
.wealth-form-grid-loan{grid-template-columns:1fr 1fr;margin-top:4px}
.trade-box{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:10px;box-shadow:0 4px 14px rgba(15,23,42,.04)}
.trade-box.is-disabled{opacity:.58}
.trade-box__title{font-size:1rem;font-weight:800;color:var(--txt)}
.trade-box__meta{font-size:.82rem;color:var(--muted);line-height:1.4}
.trade-box__meta strong{color:var(--txt)}
.trade-input,.sp-actions input[type="number"]{width:100%;box-sizing:border-box;padding:13px 14px;border-radius:12px;border:1px solid #d1d5db;font-size:16px;outline:none;background:#fff;transition:border-color .2s, box-shadow .2s}
.trade-input:focus,.sp-actions input[type="number"]:focus{border-color:#9ca3af;box-shadow:0 0 0 3px rgba(156,163,175,.18)}
.trade-input:disabled{background:#f9fafb;color:#9ca3af}
.trade-btn-row{display:grid;gap:10px}
.trade-btn-row.two-cols{grid-template-columns:1fr 1fr}
.sp-btn{min-height:46px;padding:12px 14px;background:#f3f4f6;border:1px solid var(--border);border-radius:12px;font-size:.95rem;font-weight:800;color:var(--txt);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;text-align:center}
.sp-btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(0,0,0,.06)}
.sp-btn:disabled,.sp-btn.disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.sp-btn-muted{background:#f3f4f6;color:#374151}
.sp-btn-buy{background:#ef4444;border-color:#ef4444;color:#fff}
.sp-btn-sell{background:#10b981;border-color:#10b981;color:#fff}
.sp-btn-outline{background:#fff5f5;border-color:#fca5a5;color:#dc2626}
.sp-btn-loan{background:#3b82f6;border-color:#3b82f6;color:#fff}
.sp-btn-warn{background:#f59e0b;border-color:#f59e0b;color:#fff}
.sp-btn-warn-outline{background:#fffbeb;border-color:#fcd34d;color:#b45309}
@media (max-width: 640px){
  .wealth-dashboard{padding:18px}
  .wd-total{font-size:2.2rem}
  .wd-split{display:grid;grid-template-columns:1fr;gap:10px}
  .sp-header{align-items:flex-start;gap:8px;flex-wrap:wrap}
  .sp-header h3{font-size:1rem}
  .wealth-form-grid-stock{grid-template-columns:1fr}
  .wealth-form-grid-loan{grid-template-columns:1fr 1fr}
  .trade-btn-row.two-cols{grid-template-columns:1fr}
  .market-card__head{flex-direction:column;align-items:stretch}
  .market-trend{justify-content:space-between}
  .market-chart{width:720px;height:160px}
}
@media (max-width: 420px){
  .wealth-form-grid-loan{grid-template-columns:1fr}
}

.dossier-seal{position:absolute;bottom:30px;right:30px;transform:rotate(-15deg);opacity:0.8;}
.seal-circle{width:110px;height:110px;border:4px solid var(--accent);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--accent);}
.seal-text{font-size:0.8rem;font-weight:900;letter-spacing:2px;font-family:'SimSun';text-align:center;line-height:1.2;}
.seal-star{font-size:1.6rem;margin-top:4px;}

/* ===== BOTTOM NAV ===== */
.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;background:#fff;border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(5,1fr);z-index:50;padding:0;box-shadow:0 -2px 10px rgba(0,0,0,0.05);}
.nav-btn{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:12px 4px;color:var(--muted);font-size:0.75rem;font-weight:700;border-bottom:3px solid transparent;position:relative;}
.nav-btn span:first-child{font-size:1.4rem;}
.nav-btn.active{color:var(--accent);border-bottom-color:var(--accent);background:#fef2f2;}
.nav-badge{position:absolute;top:10px;right:calc(50% - 16px);width:8px;height:8px;background:var(--red);border-radius:50%;}

/* ===== MODALS (White, formal) ===== */
.modal-overlay{
    position:fixed;
    inset:0;
    z-index:800;
    background:rgba(0,0,0,0.5);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
    transition:opacity 0.2s;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
}

.modal-overlay.hidden{
    opacity:0;
    pointer-events:none;
}

.modal-box{
    width:100%;
    max-width:400px;
    background:#fff;
    border:2px solid var(--accent);
    padding:24px;
    text-align:center;
    box-shadow:0 8px 24px rgba(0,0,0,0.2);
    max-height:calc(100vh - 40px);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
}
.modal-overlay.hidden .modal-box{transform:scale(0.95);}
.modal-emoji{font-size:3rem;margin-bottom:12px;}
.modal-ttl{font-size:1.4rem;font-weight:900;color:var(--txt);margin-bottom:12px;font-family:'SimSun',serif;}
.modal-desc{font-size:0.95rem;color:var(--txt);line-height:1.6;margin-bottom:20px;text-align:left;}

.modal-choices{display:flex;flex-direction:column;gap:12px;}
.choice-btn{background:#fff;border:1px solid var(--border2);padding:14px;font-size:1rem;font-weight:700;color:var(--txt);cursor:pointer;transition:all var(--tr);}
.choice-btn:hover{background:#f3f4f6;}
.choice-btn.primary{background:var(--accent);color:#fff;border-color:#991b1b;}
.choice-btn.primary:hover{background:#991b1b;}
.choice-btn.secondary{background:#fff;border:1px solid var(--accent);color:var(--accent);}
.choice-btn.danger{background:var(--txt);color:#fff;}

.exam-result-block{margin:-8px 0 20px;padding:12px;background:#f9fafb;border:1px dashed #ccc;text-align:left;font-size:0.9rem;line-height:1.7;color:var(--txt);font-family:'FangSong',serif;}
.exam-result-block .pass{color:var(--accent);font-weight:800;}
.exam-result-block .fail{color:var(--txt);font-weight:800;text-decoration:line-through;}

.promo-box{border-color:#d97706;}
.promo-fireworks{font-size:2rem;margin-bottom:10px;}
.new-role-chip{display:inline-block;margin:12px 0 24px;padding:12px 30px;background:#d97706;color:#fff;font-size:1.5rem;font-weight:900;letter-spacing:2px;font-family:'SimSun',serif;}

.summary-box{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;text-align:left;}
.sum-item{background:#f9fafb;border:1px solid #e5e7eb;padding:10px;}
.sum-k{font-size:0.75rem;color:var(--muted);margin-bottom:4px;font-weight:700;}
.sum-v{font-size:1.1rem;font-weight:900;color:var(--txt);}

/* ===== LEADERBOARD ===== */
.leaderboard-list{max-height:400px;overflow-y:auto;margin-top:16px;display:flex;flex-direction:column;gap:8px;text-align:left;background:#f9fafb;padding:12px;border:1px solid #ccc;}
.lb-item{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #eee;padding:10px;font-size:0.9rem;}
.lb-rank{width:36px;font-weight:800;color:var(--muted);font-size:1rem;}
.lb-rank.r-1{color:var(--accent);font-size:1.4rem;}
.lb-rank.r-2{color:#d97706;font-size:1.2rem;}
.lb-rank.r-3{color:#b45309;font-size:1.1rem;}
.lb-info{flex:1;display:flex;flex-direction:column;gap:4px;}
.lb-name{font-weight:900;color:var(--txt);}
.lb-sub{font-size:0.75rem;color:var(--muted);}
.lb-score{font-weight:900;color:var(--accent);font-size:1.05rem;}
.leaderboard-modal-box{
    max-width:420px;
    padding:20px;
    max-height:calc(100vh - 32px);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
}

.lb-desc-center{
    text-align:center;
    margin-bottom:5px;
}

.leaderboard-list{
    max-height:min(400px, 45vh);
    overflow-y:auto;
    margin-top:16px;
    display:flex;
    flex-direction:column;
    gap:8px;
    text-align:left;
    background:#f9fafb;
    padding:12px;
    border:1px solid #ccc;
    -webkit-overflow-scrolling:touch;
}

.lb-close-btn{
    width:100%;
    margin-top:15px;
    margin-bottom:calc(env(safe-area-inset-bottom, 0px) + 2px);
    position:sticky;
    bottom:0;
    background:#fff;
}

/* ===== FLOAT & TOAST ===== */
#float-layer{position:fixed;inset:0;pointer-events:none;z-index:900;}
.float-t{position:fixed;font-weight:900;font-size:1.2rem;text-shadow:0 1px 2px #fff,0 0 10px rgba(255,255,255,0.8);animation:floatUp 1.2s ease-out forwards;}
.ft-pos{color:var(--accent);}
.ft-neg{color:var(--bg); background:var(--txt); padding:2px 8px;}
@keyframes floatUp{0%{opacity:0;transform:translateY(0);}15%{opacity:1;transform:translateY(-10px);}100%{opacity:0;transform:translateY(-50px);}}

.toast{position:fixed;top:20px;left:50%;transform:translateX(-50%);background:#fff;border:2px solid var(--accent);color:var(--accent);padding:12px 24px;font-size:0.95rem;font-weight:800;z-index:950;box-shadow:0 4px 12px rgba(185,28,28,0.2);transition:opacity 0.2s,transform 0.2s;text-align:center;}
.toast.hidden{opacity:0;transform:translateX(-50%)translateY(-10px);}

/* ===== AI LOADING ===== */
#ai-loading-overlay {
    position: fixed; inset: 0; z-index: 2000;
    background: rgba(255,255,255, 0.9);
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    transition: opacity 0.2s;
}
#ai-loading-overlay.hidden { opacity: 0; pointer-events: none; }
.spinner {
    width: 60px; height: 60px;
    border: 6px solid #e5e7eb;
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin-bottom: 24px;
}
.loading-txt { font-size: 1.1rem; font-weight: 800; color: var(--txt); letter-spacing: 2px; }

/* Utilities added for code overrides */
.hidden { display: none !important; }


/* ===== K线图最终修复：避免整卡横向撑爆（2026-04-10） ===== */
#tab-hustle,
#tab-hustle * {
  box-sizing: border-box;
}

#tab-hustle {
  overflow-x: hidden;
}

#tab-hustle .wealth-stack,
#tab-hustle .wealth-form-grid,
#tab-hustle .wealth-form-grid-stock,
#tab-hustle .wealth-form-grid-loan,
#tab-hustle .market-card,
#tab-hustle .trade-box {
  min-width: 0;
  width: 100%;
  max-width: 100%;
}

#tab-hustle .market-card {
  overflow: hidden;
}

#tab-hustle .market-card__head {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  margin-bottom: 10px;
}

#tab-hustle .market-trend {
  width: 100%;
  min-height: 52px;
  padding: 8px 12px;
  border-radius: 10px;
}

#tab-hustle .market-chart-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  padding: 4px 0 2px;
}

#tab-hustle .market-chart {
  display: block;
  width: 720px;
  min-width: 720px;
  max-width: none;
  height: 190px;
}

#tab-hustle .trade-input,
#tab-hustle .sp-actions input[type="number"],
#tab-hustle #loan-actions input[type="number"] {
  width: 100%;
  min-width: 0;
}

#tab-hustle .sp-btn {
  width: 100%;
  min-width: 0;
  white-space: nowrap;
}

@media (max-width: 640px) {
  #tab-hustle .market-chart {
    width: 680px;
    min-width: 680px;
    height: 180px;
  }
}

@media (max-width: 420px) {
  #tab-hustle .market-chart {
    width: 640px;
    min-width: 640px;
    height: 170px;
  }
}

/* ===== DOSSIER MOBILE TYPOGRAPHY FIX ===== */
.dossier-top-line{
  letter-spacing:4px;
  word-spacing:0;
  line-height:1.5;
}
.dossier-subtitle{
  letter-spacing:1px;
  line-height:1.35;
  max-width:100%;
  word-break:keep-all;
  overflow-wrap:break-word;
}
.dossier-photo-row{
  display:grid;
  grid-template-columns:90px 1fr;
  gap:14px;
  align-items:start;
}
.dossier-photo{
  width:90px;
  height:120px;
}
.dossier-basic{
  min-width:0;
}
.dos-row{
  min-height:46px;
  font-size:0.9rem;
}
.dos-lbl{
  width:98px;
  margin-right:0;
  padding:10px 10px 10px 0;
  letter-spacing:0;
  display:flex;
  align-items:center;
}
.dos-val{
  min-width:0;
  padding:10px 0 10px 12px;
  line-height:1.45;
  word-break:break-word;
}
.dossier-divider{
  letter-spacing:2px;
  line-height:1.4;
}

@media (max-width: 640px){
  .dossier{
    padding:16px 12px 18px;
  }
  .dossier-top-line{
    font-size:0.68rem;
    letter-spacing:2px;
    margin-bottom:6px;
  }
  .dossier-subtitle{
    font-size:1.15rem;
    letter-spacing:0.5px;
    line-height:1.45;
  }
  .dossier-emblem{
    font-size:2.4rem;
    margin:8px 0 10px;
  }
  .dossier-photo-row{
    grid-template-columns:74px 1fr;
    gap:10px;
    margin-bottom:14px;
  }
  .dossier-photo{
    width:74px;
    height:100px;
    font-size:2.3rem;
  }
  .dos-row{
    min-height:40px;
    font-size:0.82rem;
  }
  .dos-lbl{
    width:86px;
    padding:8px 8px 8px 0;
    font-size:0.82rem;
  }
  .dos-val{
    padding:8px 0 8px 10px;
    font-size:0.82rem;
  }
  .dos-val.highlight{
    font-size:0.9rem;
  }
  .dossier-divider{
    font-size:0.95rem;
    letter-spacing:1px;
    margin:14px 0 10px;
  }
  .dossier-seal{
    right:14px;
    bottom:18px;
    transform:rotate(-12deg) scale(0.82);
    transform-origin:bottom right;
  }
}

@media (max-width: 420px){
  .dossier-top-line{
    font-size:0.62rem;
    letter-spacing:1px;
  }
  .dossier-subtitle{
    font-size:1rem;
    line-height:1.5;
  }
  .dossier-photo-row{
    grid-template-columns:66px 1fr;
  }
  .dossier-photo{
    width:66px;
    height:92px;
    font-size:2rem;
  }
  .dos-row{
    min-height:38px;
    font-size:0.78rem;
  }
  .dos-lbl{
    width:78px;
    font-size:0.78rem;
  }
  .dos-val{
    font-size:0.78rem;
  }
}
@media (max-width: 768px){
    .modal-overlay{
        padding:10px;
        align-items:flex-start;
    }

    .modal-box{
        margin-top: max(10px, env(safe-area-inset-top, 0px));
        max-height:calc(100vh - 20px);
        padding:16px;
    }

    .leaderboard-modal-box{
        max-height:calc(100vh - 20px);
        padding:16px;
    }

    .leaderboard-list{
        max-height:38vh;
    }
}