/* ===== 全域重置與變數 ===== */
*{margin:0;padding:0;box-sizing:border-box;user-select:none}
:root{
    --gold:#FFD700;
    --gold-light:#FFF3B0;
    --gold-dark:#B8860B;
    --red:#DC143C;
    --red-dark:#8B0000;
    --blue:#1E90FF;
    --blue-dark:#004080;
    --green:#32CD32;
    --green-dark:#228B22;
    --purple:#9370DB;
    --dark:#0a0e1a;
    --dark2:#121828;
    --dark3:#1a2340;
    --panel-bg:rgba(10,14,26,0.88);
    --border-glow:rgba(255,215,0,0.25);
    --text-shadow:0 2px 8px rgba(0,0,0,0.8);
    --radius:12px;
    --radius-sm:8px;
}
body{
    font-family:'Segoe UI','Noto Sans TC','Microsoft YaHei',sans-serif;
    background:var(--dark);
    color:#e8e8e8;
    overflow:hidden;
    height:100vh;
    width:100vw;
}
#app{width:100%;height:100%;position:relative;-webkit-tap-highlight-color:transparent}

/* ===== 捲軸美化 ===== */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,215,0,0.3);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,215,0,0.5)}

/* ===== LOADING 畫面 ===== */
#loading{
    position:fixed;inset:0;z-index:9999;
    background:radial-gradient(ellipse at center,#1a2340 0%,#0a0e1a 70%);
    display:flex;flex-direction:column;justify-content:center;align-items:center;
    transition:opacity .8s,transform .8s;
}
#loading.hide{opacity:0;transform:scale(1.15);pointer-events:none}
.load-logo{
    font-size:clamp(2.2rem,7vw,4.5rem);font-weight:900;
    background:linear-gradient(135deg,#FFD700,#FF8C00,#FFD700);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
    letter-spacing:6px;margin-bottom:.5rem;
}
.load-sub{color:#888;font-size:clamp(.8rem,2vw,1.1rem);letter-spacing:8px;margin-bottom:2rem}
.load-bar{width:clamp(200px,50vw,360px);height:4px;background:rgba(255,255,255,0.08);border-radius:4px;overflow:hidden}
.load-fill{height:100%;width:0;background:linear-gradient(90deg,#FFD700,#FF8C00);border-radius:4px;animation:loadBar 2.8s ease-in-out forwards}
.load-tip{color:#666;font-size:.85rem;margin-top:1.5rem}
@keyframes loadBar{0%{width:0}50%{width:70%}100%{width:100%}}

/* ===== 主選單 ===== */
#menu{
    position:fixed;inset:0;z-index:100;
    background:radial-gradient(ellipse at 30% 40%,#1a2340 0%,#0a0e1a 60%);
    display:none;flex-direction:column;justify-content:center;align-items:center;
}
#menu.show{display:flex}
#menu.hide{display:none}
.menu-title{
    font-size:clamp(2rem,6vw,3.8rem);font-weight:900;
    background:linear-gradient(135deg,#FFD700,#FF8C00);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
    letter-spacing:6px;margin-bottom:.3rem;
}
.menu-sub{color:#887;font-size:clamp(.75rem,1.5vw,1rem);letter-spacing:12px;margin-bottom:2.5rem}
.menu-btns{display:flex;flex-direction:column;gap:14px;width:clamp(200px,60vw,320px)}
.m-btn{
    padding:14px 28px;border:1px solid var(--border-glow);border-radius:var(--radius-sm);
    background:linear-gradient(135deg,rgba(255,215,0,0.08),rgba(255,215,0,0.02));
    color:var(--gold-light);font-size:1.05rem;cursor:pointer;transition:all .3s;
    text-align:center;letter-spacing:4px;
}
.m-btn:hover{background:linear-gradient(135deg,rgba(255,215,0,0.18),rgba(255,215,0,0.06));transform:translateY(-2px);box-shadow:0 8px 30px rgba(255,215,0,0.15)}
.m-btn:active{transform:scale(.97)}
.m-btn .fa{margin-right:10px;font-size:1.1rem}

/* ===== 遊戲畫面 ===== */
#game{
    width:100%;height:100%;display:none;flex-direction:column;
    background:linear-gradient(135deg,#0a0e1a 0%,#121828 50%,#0f1422 100%);
}
#game.show{display:flex}

/* ===== 資源欄 ===== */
#resBar{
    display:flex;align-items:center;gap:clamp(6px,2vw,20px);
    padding:clamp(6px,1.2vh,12px) clamp(10px,2vw,24px);
    background:linear-gradient(180deg,rgba(26,35,64,.95),rgba(10,14,26,.9));
    border-bottom:1px solid rgba(255,215,0,.12);
    flex-wrap:wrap;min-height:48px;position:relative;z-index:50;
    backdrop-filter:blur(10px);
}
.res-item{
    display:flex;align-items:center;gap:5px;
    font-size:clamp(.72rem,1.4vw,.9rem);color:#ccc;
    padding:4px 10px;background:rgba(255,255,255,.03);border-radius:20px;
    white-space:nowrap;
}
.res-item .fa{font-size:clamp(.75rem,1.2vw,.9rem)}
.res-item.gold .fa{color:var(--gold)}
.res-item.food .fa{color:#8BC34A}
.res-item.wood .fa{color:#A1887F}
.res-item.iron .fa{color:#90A4AE}
.res-item.pop .fa{color:#4FC3F7}
.res-item.turn .fa{color:#CE93D8}
.res-val{color:#fff;font-weight:600}
#turnBtn{
    margin-left:auto;padding:6px 18px;border:1px solid var(--gold);border-radius:20px;
    background:linear-gradient(135deg,rgba(255,215,0,.15),rgba(255,215,0,.05));
    color:#FFD700;font-size:clamp(.75rem,1.3vw,.85rem);cursor:pointer;transition:all .3s;
    white-space:nowrap;letter-spacing:2px;font-weight:600;
}
#turnBtn:hover{background:linear-gradient(135deg,rgba(255,215,0,.3),rgba(255,215,0,.1));box-shadow:0 0 20px rgba(255,215,0,.15);transform:translateY(-1px)}
#turnBtn:active{transform:scale(.96)}

/* ===== 主內容 ===== */
#main{
    display:flex;flex:1;overflow:hidden;
    background:
        radial-gradient(circle at top right,rgba(255,215,0,.05),transparent 28%),
        linear-gradient(135deg,rgba(255,255,255,.015),rgba(255,255,255,0));
}

/* ===== 左側導航 ===== */
#nav{
    display:flex;flex-direction:column;gap:4px;
    padding:clamp(6px,1vh,12px) 6px;
    background:rgba(26,35,64,.5);
    border-right:1px solid rgba(255,215,0,.08);
    width:clamp(60px,7vw,90px);flex-shrink:0;
}
.nav-item{
    padding:clamp(8px,1.2vh,14px) 4px;
    border:none;border-radius:var(--radius-sm);
    background:transparent;color:#888;cursor:pointer;
    display:flex;flex-direction:column;align-items:center;gap:4px;
    font-size:clamp(.6rem,.9vw,.75rem);transition:all .3s;
    position:relative;
}
.nav-item .fa{font-size:clamp(1rem,1.6vw,1.3rem)}
.nav-item:hover{color:#ddd;background:rgba(255,255,255,.04)}
.nav-item.active{color:var(--gold);background:rgba(255,215,0,.08)}
.nav-item.active::before{
    content:'';position:absolute;left:0;top:20%;height:60%;width:3px;
    background:var(--gold);border-radius:0 3px 3px 0;
}

/* ===== 內容面板 ===== */
#panels{
    flex:1;overflow:hidden;position:relative;
}
.panel{
    display:none;height:100%;overflow-y:auto;overflow-x:hidden;
    padding:clamp(10px,2vw,20px);
    animation:fadeIn .3s ease;
}
.panel.show{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.panel-title{
    font-size:clamp(1rem,2vw,1.4rem);color:var(--gold);margin-bottom:16px;
    display:flex;align-items:center;gap:10px;
    flex-shrink:0;
    position:sticky;top:0;z-index:8;
    padding:10px 0 12px;
    background:linear-gradient(180deg,rgba(10,14,26,.94),rgba(10,14,26,.72),transparent);
    backdrop-filter:blur(6px);
}
.panel-title .fa{font-size:1.2em}
/* 地圖面板專用：flex佈局讓地圖填滿剩餘空間 */
#tab-map.panel{
    display:none;overflow:hidden;
}
#tab-map.panel.show{
    display:flex;flex-direction:column;
}
#tab-map .panel-title{
    margin-bottom:8px;
}
#tab-map #mapWrap{
    flex:1;min-height:0;
}

/* ===== 城池面板 ===== */
.city-grid{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(140px,18vw,200px),1fr));
    gap:clamp(8px,1.5vw,14px);
}
.b-card{
    background:rgba(26,35,64,.6);border:1px solid rgba(255,215,0,.08);
    border-radius:var(--radius);padding:14px;transition:all .3s;
    cursor:pointer;
    box-shadow:0 10px 24px rgba(0,0,0,.18);
}
.b-card:hover{background:rgba(26,35,64,.8);border-color:rgba(255,215,0,.2);transform:translateY(-2px)}
.b-card .b-icon{font-size:1.6rem;margin-bottom:6px}
.b-card .b-name{color:#fff;font-weight:600;font-size:.95rem}
.b-card .b-lvl{color:var(--gold);font-size:.8rem;margin:4px 0}
.b-card .b-desc{color:#999;font-size:.75rem;line-height:1.4}
.b-card .b-cost{color:#aaa;font-size:.72rem;margin-top:6px}
.b-card .b-btn{
    margin-top:8px;padding:6px 14px;border:none;border-radius:6px;
    background:linear-gradient(135deg,rgba(255,215,0,.2),rgba(255,215,0,.05));
    color:var(--gold);font-size:.78rem;cursor:pointer;transition:all .3s;width:100%;
}
.b-card .b-btn:hover{background:linear-gradient(135deg,rgba(255,215,0,.35),rgba(255,215,0,.1))}
.b-card .b-btn:disabled{opacity:.3;cursor:not-allowed}
.b-card .b-btn:disabled:hover{background:linear-gradient(135deg,rgba(255,215,0,.2),rgba(255,215,0,.05));transform:none}

/* ===== 武將面板 ===== */
.gen-grid{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(150px,20vw,220px),1fr));
    gap:clamp(8px,1.5vw,14px);
}
.gen-card{
    background:rgba(26,35,64,.6);border:1px solid rgba(255,215,0,.08);
    border-radius:var(--radius);padding:14px;transition:all .3s;
    box-shadow:0 10px 24px rgba(0,0,0,.16);
}
.gen-card:hover{border-color:rgba(255,215,0,.2);transform:translateY(-2px)}
.gen-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.gen-avatar{
    width:44px;height:44px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:1.3rem;font-weight:700;color:#fff;flex-shrink:0;
}
.gen-name{color:#fff;font-weight:600;font-size:.95rem}
.gen-lvl{color:var(--gold);font-size:.75rem}
.gen-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px;margin-bottom:8px}
.gen-stat{text-align:center;padding:4px;background:rgba(0,0,0,.2);border-radius:6px}
.gen-stat .label{color:#888;font-size:.65rem}
.gen-stat .val{color:#fff;font-weight:600;font-size:.85rem}
.gen-stat .val.f{color:#FF6B6B}
.gen-stat .val.i{color:#64B5F6}
.gen-stat .val.l{color:#81C784}
.gen-exp{height:4px;background:rgba(255,255,255,.1);border-radius:4px;margin-bottom:8px;overflow:hidden}
.gen-exp-fill{height:100%;background:linear-gradient(90deg,var(--gold),#FF8C00);border-radius:4px;transition:width .5s}
.gen-btn{
    padding:6px 12px;border:1px solid rgba(255,215,0,.2);border-radius:6px;
    background:transparent;color:var(--gold);font-size:.75rem;cursor:pointer;
    transition:all .3s;width:100%;
}
.gen-btn:hover{background:rgba(255,215,0,.12)}

/* ===== 軍隊面板 ===== */
.army-grid{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(140px,18vw,190px),1fr));
    gap:clamp(8px,1.5vw,14px);
}
.army-card{
    background:rgba(26,35,64,.6);border:1px solid rgba(255,215,0,.08);
    border-radius:var(--radius);padding:16px;text-align:center;transition:all .3s;
    box-shadow:0 10px 24px rgba(0,0,0,.16);
}
.army-card:hover{border-color:rgba(255,215,0,.2);transform:translateY(-2px)}
.army-icon{font-size:2rem;margin-bottom:6px}
.army-name{color:#fff;font-weight:600;font-size:.9rem}
.army-count{font-size:1.6rem;color:var(--gold);font-weight:700;margin:8px 0}
.army-btn{
    padding:8px 16px;border:none;border-radius:6px;
    background:linear-gradient(135deg,rgba(220,20,60,.3),rgba(220,20,60,.1));
    color:#FF6B6B;font-size:.78rem;cursor:pointer;transition:all .3s;width:100%;
}
.army-btn:hover{background:linear-gradient(135deg,rgba(220,20,60,.5),rgba(220,20,60,.2))}
.army-btn:disabled{opacity:.3;cursor:not-allowed}

/* ===== 地圖 Canvas ===== */
#mapWrap{
    position:relative;width:100%;height:100%;
    border-radius:var(--radius);overflow:hidden;
    background:rgba(10,14,26,.6);border:1px solid rgba(255,215,0,.08);
}
#mapCanvas{width:100%;height:100%;display:block;cursor:pointer}
#mapTooltip{
    position:absolute;display:none;
    background:rgba(10,14,26,.95);border:1px solid rgba(255,215,0,.3);
    border-radius:var(--radius-sm);padding:10px 14px;pointer-events:none;
    z-index:20;min-width:140px;box-shadow:0 8px 32px rgba(0,0,0,.6);
}
#mapTooltip .tt-name{color:#fff;font-weight:600;font-size:.85rem;margin-bottom:4px}
#mapTooltip .tt-info{color:#aaa;font-size:.75rem;line-height:1.5}
#mapTooltip .tt-info .c-gold{color:var(--gold)}
#mapTooltip .tt-info .c-red{color:#FF6B6B}
#mapTooltip .tt-info .c-green{color:#81C784}

/* ===== 事件紀錄 ===== */
.event-list{display:flex;flex-direction:column;gap:6px}
.event-item{
    padding:10px 14px;background:rgba(26,35,64,.4);border-radius:var(--radius-sm);
    border-left:3px solid var(--gold);font-size:.82rem;color:#ccc;line-height:1.5;
}
.event-item .time{color:#666;font-size:.7rem;margin-right:8px}

/* ===== 模態框 ===== */
#modal{
    position:fixed;inset:0;z-index:200;
    display:none;align-items:center;justify-content:center;
    background:rgba(0,0,0,.7);backdrop-filter:blur(4px);
}
#modal.show{display:flex}
#modalBox{
    background:linear-gradient(135deg,#1a2340,#0f1a30);
    border:1px solid rgba(255,215,0,.2);border-radius:var(--radius);
    width:clamp(300px,80vw,520px);max-height:80vh;overflow-y:auto;
    box-shadow:0 20px 60px rgba(0,0,0,.8);animation:modalIn .3s ease;
}
@keyframes modalIn{from{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
#modalHead{
    padding:16px 20px;border-bottom:1px solid rgba(255,215,0,.1);
    display:flex;justify-content:space-between;align-items:center;
}
#modalTitle{font-size:1.05rem;color:var(--gold);font-weight:600}
#modalClose{
    width:32px;height:32px;border:none;border-radius:50%;
    background:rgba(255,255,255,.05);color:#888;cursor:pointer;
    display:flex;align-items:center;justify-content:center;transition:all .3s;
    font-size:.9rem;
}
#modalClose:hover{background:rgba(255,255,255,.1);color:#fff}
#modalBody{padding:20px;color:#ccc;font-size:.88rem;line-height:1.7}
#modalFoot{padding:14px 20px;border-top:1px solid rgba(255,215,0,.08);display:flex;gap:10px;justify-content:flex-end}
#modalFoot button{
    padding:8px 20px;border-radius:6px;border:none;cursor:pointer;
    font-size:.82rem;transition:all .3s;
}
.btn-gold{background:linear-gradient(135deg,rgba(255,215,0,.2),rgba(255,215,0,.05));color:var(--gold);border:1px solid rgba(255,215,0,.2)!important}
.btn-gold:hover{background:linear-gradient(135deg,rgba(255,215,0,.35),rgba(255,215,0,.1))}
.btn-red{background:linear-gradient(135deg,rgba(220,20,60,.2),rgba(220,20,60,.05));color:#FF6B6B;border:1px solid rgba(220,20,60,.2)!important}
.btn-red:hover{background:linear-gradient(135deg,rgba(220,20,60,.4),rgba(220,20,60,.1))}
.btn-gray{background:rgba(255,255,255,.06);color:#aaa;border:1px solid rgba(255,255,255,.08)!important}
.btn-gray:hover{background:rgba(255,255,255,.1)}

/* ===== Toast 通知 ===== */
#toastBox{
    position:fixed;top:20px;right:20px;z-index:300;
    display:flex;flex-direction:column;gap:8px;pointer-events:none;
}
.toast{
    padding:12px 20px;border-radius:var(--radius-sm);
    background:rgba(10,14,26,.95);border:1px solid rgba(255,215,0,.2);
    color:#e8e8e8;font-size:.85rem;animation:slideIn .3s ease;
    display:flex;align-items:center;gap:10px;
    backdrop-filter:blur(8px);pointer-events:auto;min-width:200px;
}
.toast .fa{font-size:1rem}
.toast.success{border-left:3px solid #4CAF50}
.toast.success .fa{color:#4CAF50}
.toast.error{border-left:3px solid #F44336}
.toast.error .fa{color:#F44336}
.toast.warning{border-left:3px solid #FF9800}
.toast.warning .fa{color:#FF9800}
.toast.info{border-left:3px solid #2196F3}
.toast.info .fa{color:#2196F3}
.toast.remove{animation:slideOut .4s ease forwards}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes slideOut{from{transform:translateX(0);opacity:1}to{transform:translateX(100%);opacity:0}}

/* ===== 響應式 ===== */
@media(max-width:900px){
    #nav{width:clamp(52px,8vw,68px)}
    .nav-item{padding:8px 2px;font-size:.55rem}
    .nav-item .fa{font-size:1rem}
    #resBar{gap:4px;padding:6px 8px;min-height:40px}
    .res-item{padding:3px 8px;font-size:.65rem}
    #tab-map.panel{padding:6px 8px}
}
@media(max-width:600px){
    #main{flex-direction:column}
    #nav{
        width:100%;flex-direction:row;overflow-x:auto;overflow-y:hidden;
        border-right:none;border-bottom:1px solid rgba(255,215,0,.08);padding:6px;
    }
    .nav-item{min-width:64px;padding:6px 2px;font-size:.5rem}
    .nav-item .fa{font-size:.85rem}
    .city-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
    .gen-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
    .army-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
    #resBar{gap:3px;padding:4px 6px;min-height:36px}
    .res-item{padding:2px 6px;font-size:.6rem;gap:3px}
    .res-item .fa{font-size:.65rem}
    #turnBtn{padding:4px 12px;font-size:.7rem}
    #modalBox{width:92vw}
    .panel{padding:10px}
    #tab-map.panel{padding:4px 6px}
}
@media(max-width:400px){
    #nav{width:42px}
    .nav-item{padding:4px 1px;font-size:.45rem}
    .nav-item .fa{font-size:.7rem}
    .res-item{font-size:.52rem;padding:2px 4px}
    .city-grid{grid-template-columns:1fr 1fr}
    .gen-grid{grid-template-columns:1fr 1fr}
    #tab-map.panel{padding:2px 4px}
}

/* ===== scroll fix ===== */
.panel::-webkit-scrollbar{width:4px}

/* ===== 單人版控制台重構覆寫 ===== */
#game{
    background:linear-gradient(135deg,#0a0e1a 0%,#121828 48%,#0f1422 100%);
}
#resBar{
    display:flex;align-items:center;justify-content:space-between;gap:16px;
    padding:12px 16px;
    background:
        radial-gradient(circle at top left,rgba(255,215,0,.08),transparent 22%),
        linear-gradient(180deg,rgba(17,24,42,.98),rgba(8,12,22,.94));
    border-bottom:1px solid rgba(255,215,0,.12);min-height:66px;
    box-shadow:0 18px 36px rgba(0,0,0,.22);
}
.res-left,.res-right{
    display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0;
}
.res-right{justify-content:flex-end}
.res-item{
    display:flex;align-items:center;gap:7px;
    font-size:clamp(.68rem,1.3vw,.82rem);color:#c8d1e3;
    padding:8px 12px;
    background:linear-gradient(160deg,rgba(255,255,255,.04),rgba(255,255,255,.015));
    border:1px solid rgba(255,255,255,.05);
    border-radius:14px;white-space:nowrap;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.res-item.turn{
    background:linear-gradient(160deg,rgba(186,104,200,.12),rgba(255,255,255,.015));
    border-color:rgba(206,147,216,.18);
}
#turnBtn,#saveBtn.res-aux-btn{
    padding:10px 16px;border-radius:14px;cursor:pointer;font-weight:700;
    font-size:clamp(.72rem,1.3vw,.82rem);white-space:nowrap;letter-spacing:.04em;
    transition:all .22s ease;box-shadow:0 12px 24px rgba(0,0,0,.16);
}
#turnBtn{
    border:1px solid var(--gold);
    background:linear-gradient(135deg,rgba(255,215,0,.16),rgba(255,215,0,.04));
    color:#FFD700;
}
#turnBtn:hover{
    background:linear-gradient(135deg,rgba(255,215,0,.3),rgba(255,215,0,.08));
    box-shadow:0 0 16px rgba(255,215,0,.1);transform:translateY(-1px);
}
#saveBtn.res-aux-btn{
    border:1px solid rgba(100,180,255,.22);
    background:linear-gradient(135deg,rgba(100,180,255,.12),rgba(100,180,255,.03));
    color:#8ec8ff;
}
#saveBtn.res-aux-btn:hover{
    background:linear-gradient(135deg,rgba(100,180,255,.22),rgba(100,180,255,.07));
    transform:translateY(-1px);
}
#main{
    flex:1;display:grid;
    grid-template-columns:minmax(220px,248px) minmax(0,1fr) minmax(244px,292px);
    gap:12px;overflow:hidden;min-height:0;padding:12px;
    background:
        radial-gradient(circle at top right,rgba(255,215,0,.05),transparent 28%),
        linear-gradient(135deg,rgba(255,255,255,.015),rgba(255,255,255,0));
}
#sidebar,#intelRail{
    min-height:0;border:1px solid rgba(255,215,0,.06);border-radius:24px;
    background:
        radial-gradient(circle at top,rgba(255,215,0,.05),transparent 22%),
        linear-gradient(180deg,rgba(12,18,32,.98),rgba(9,14,24,.97));
    box-shadow:inset -1px 0 0 rgba(255,255,255,.02),0 18px 34px rgba(0,0,0,.2);
}
#sidebar{
    display:flex;flex-direction:column;padding:12px;gap:12px;overflow-y:auto;
}
#intelRail{
    display:flex;flex-direction:column;padding:12px;gap:12px;overflow-y:auto;
}
#content{
    display:flex;flex-direction:column;overflow:hidden;min-width:0;min-height:0;
    border:1px solid rgba(255,215,0,.05);border-radius:24px;
    background:linear-gradient(180deg,rgba(10,14,26,.9),rgba(7,11,22,.96));
    box-shadow:0 18px 34px rgba(0,0,0,.22);
}
#content > #nav{
    width:auto;display:grid;grid-auto-flow:column;grid-auto-columns:max-content;align-items:center;
    justify-content:start;gap:8px;padding:10px 14px;overflow-x:auto;overflow-y:hidden;
    background:linear-gradient(180deg,rgba(20,28,48,.95),rgba(10,14,26,.92));
    border-bottom:1px solid rgba(255,215,0,.08);scrollbar-width:thin;
}
#content > #nav .nav-item{
    width:auto !important;min-width:88px;max-width:none;padding:9px 16px;border:1px solid rgba(255,255,255,.05);
    border-radius:12px;background:rgba(255,255,255,.02);color:#93a2bf;cursor:pointer;
    font-size:.78rem;display:inline-flex !important;align-items:center;justify-content:center;gap:8px;flex:none !important;flex-direction:row !important;
    transition:all .2s;margin-right:0;white-space:nowrap;
}
#content > #nav .nav-item span{display:inline-block;white-space:nowrap}
#content > #nav .nav-item .fa{font-size:.92rem}
#content > #nav .nav-item:hover:not(.active){
    color:#d7ddeb;border-color:rgba(255,255,255,.09);background:rgba(255,255,255,.04);
}
#content > #nav .nav-item.active{
    color:var(--gold);font-weight:700;border-color:rgba(255,215,0,.22);
    background:linear-gradient(135deg,rgba(255,215,0,.18),rgba(255,215,0,.06));
    box-shadow:0 8px 20px rgba(255,215,0,.08);
}
#content > #nav .nav-item.active::before{display:none}
#panels{
    flex:1;overflow:hidden;position:relative;min-height:0;
}
.panel{
    display:none;height:100%;overflow-y:auto;overflow-x:hidden;min-height:0;
    padding:14px 16px 28px;
    background:
        radial-gradient(circle at top right,rgba(255,215,0,.04),transparent 26%),
        linear-gradient(180deg,rgba(8,12,22,.92),rgba(10,14,26,.98));
}
.panel.show{display:block}
.panel-title{
    font-size:clamp(1rem,1.8vw,1.3rem);color:#f6dc86;margin-bottom:16px;
    display:flex;align-items:center;gap:10px;padding:10px 0 12px;
    position:sticky;top:0;z-index:8;
    background:linear-gradient(180deg,rgba(10,14,26,.94),rgba(10,14,26,.75),transparent);
}
.panel-tip{
    font-size:.72rem;color:#8f9cb7;margin-left:8px;font-weight:400;
}
#tab-map.panel.show{display:flex;flex-direction:column}
#mapWrap{
    flex:1;min-height:clamp(420px,60vh,700px);
    border-radius:22px;overflow:hidden;
    background:
        radial-gradient(circle at center,rgba(255,215,0,.05),transparent 30%),
        rgba(10,14,26,.6);
    border:1px solid rgba(255,215,0,.08);
    box-shadow:0 18px 34px rgba(0,0,0,.22);
}
#mapTooltip{
    background:rgba(7,10,18,.95);border:1px solid rgba(255,215,0,.18);
    border-radius:12px;padding:10px 12px;box-shadow:0 12px 28px rgba(0,0,0,.35);
}
.sidebar-overview,.rail-overview{
    padding:16px;border-radius:22px;
    background:linear-gradient(160deg,rgba(14,22,38,.98),rgba(20,30,52,.92));
    border:1px solid rgba(255,215,0,.08);
    box-shadow:0 20px 40px rgba(0,0,0,.24);position:relative;overflow:hidden;
}
.sidebar-overview::before,.rail-overview::before{
    content:'';position:absolute;inset:-40px auto auto -30px;width:140px;height:140px;
    background:radial-gradient(circle,rgba(255,215,0,.1),transparent 72%);
}
.sidebar-kicker{
    position:relative;font-size:.66rem;letter-spacing:.2em;color:#8d9bb7;text-transform:uppercase;
}
.sidebar-title{
    position:relative;font-size:1.08rem;color:#f5f8fe;font-weight:900;margin-top:6px;
}
.sidebar-desc,.rail-overview span{
    position:relative;margin-top:8px;color:#9aa7c1;font-size:.72rem;line-height:1.7;display:block;
}
.rail-overview strong{
    position:relative;display:block;font-size:.9rem;color:#fff;
}
.sidebar-chips{
    position:relative;display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;
}
.sidebar-chip{
    padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.05);font-size:.68rem;color:#dce4f2;
}
.sidebar-chip strong{color:#fff}
.side-card{
    display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.05);
    border-radius:22px;background:linear-gradient(160deg,rgba(17,25,42,.96),rgba(10,16,28,.9));
    box-shadow:0 18px 32px rgba(0,0,0,.22);overflow:hidden;min-height:0;
}
.side-card-head{
    display:flex;align-items:flex-start;justify-content:space-between;gap:10px;
    padding:14px 14px 12px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));
    border-bottom:1px solid rgba(255,255,255,.05);flex-wrap:wrap;
}
.side-head-main{display:flex;gap:10px;align-items:flex-start;min-width:0}
.side-head-icon{
    width:34px;height:34px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,rgba(255,215,0,.16),rgba(255,255,255,.04));
    border:1px solid rgba(255,215,0,.12);color:var(--gold);
}
.side-head-text{display:flex;flex-direction:column;gap:4px;min-width:0}
.side-head-text h4{color:#f5f8fe;font-size:.82rem;letter-spacing:.04em;font-weight:800}
.side-head-text span{color:#91a0bd;font-size:.66rem;line-height:1.5}
.side-head-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-left:auto}
.side-badge{
    padding:5px 8px;border-radius:999px;background:rgba(255,255,255,.05);
    color:#aeb9d1;font-size:.64rem;border:1px solid rgba(255,255,255,.05);white-space:nowrap;
}
.side-card-body{display:flex;flex-direction:column;min-height:0;flex:1}
.side-summary{
    padding:12px 14px;color:#95a3bf;font-size:.7rem;line-height:1.8;
}
.intel-list{
    display:flex;flex-direction:column;gap:10px;padding:12px;min-height:0;
}
.intel-item{
    display:flex;flex-direction:column;gap:6px;padding:11px 12px;border-radius:14px;
    background:linear-gradient(160deg,rgba(255,255,255,.03),rgba(255,255,255,.015));
    border:1px solid rgba(255,255,255,.05);
}
.intel-item strong{color:#eef2fb;font-size:.8rem}
.intel-item span{color:#8fa0bd;font-size:.69rem;line-height:1.6}
.intel-item.warning{border-color:rgba(255,152,0,.18)}
.intel-item.danger{border-color:rgba(239,83,80,.18)}
.intel-item.success{border-color:rgba(129,199,132,.18)}
.notice-item{position:relative}
.notice-item.important{
    background:linear-gradient(160deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
    box-shadow:0 10px 22px rgba(0,0,0,.18);
}
.notice-meta{
    display:flex;align-items:flex-start;justify-content:space-between;gap:8px;flex-wrap:wrap;
}
.notice-turn{
    display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;
    background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05);
    color:#8fa0bd;font-size:.62rem;white-space:nowrap;
}
.city-grid,.gen-grid,.army-grid{
    gap:10px;
}
.b-card,.gen-card,.army-card{
    background:linear-gradient(160deg,rgba(20,29,50,.95),rgba(11,17,31,.94));
    border:1px solid rgba(255,215,0,.08);border-radius:18px;
    box-shadow:0 18px 34px rgba(0,0,0,.26);
}
.b-card:hover,.gen-card:hover,.army-card:hover{
    border-color:rgba(255,215,0,.18);
    background:linear-gradient(160deg,rgba(31,43,80,.96),rgba(16,23,39,.95));
}
.event-list{display:flex;flex-direction:column;gap:8px}
.single-filter-summary{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-bottom:12px;
}
.single-filter-card{
    padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.05);
}
.single-filter-card strong{display:block;color:#fff;font-size:.95rem}
.single-filter-card span{display:block;color:#8fa0bd;font-size:.68rem;line-height:1.6;margin-top:6px}
.single-filter-bar{
    display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px;
}
.single-filter-chip{
    padding:7px 11px;border-radius:999px;border:1px solid rgba(255,255,255,.06);
    background:rgba(255,255,255,.03);color:#b9c6de;font-size:.7rem;cursor:pointer;transition:all .2s ease;
}
.single-filter-chip:hover{background:rgba(255,255,255,.06);color:#eef2fb}
.single-filter-chip.active{
    background:linear-gradient(135deg,rgba(255,215,0,.18),rgba(255,215,0,.06));
    border-color:rgba(255,215,0,.2);color:#f6dc86;
}
.event-item{
    padding:10px 12px;border-radius:14px;border-left:none;
    border:1px solid rgba(255,255,255,.05);
    background:linear-gradient(160deg,rgba(255,255,255,.03),rgba(255,255,255,.015));
}
.event-item.battle{border-color:rgba(239,83,80,.18)}
.event-item.city{border-color:rgba(255,215,0,.16)}
.event-item.diplomacy{border-color:rgba(129,199,132,.18)}
.event-item.alert{border-color:rgba(255,152,0,.18)}
.event-item.compact{padding:8px 10px}
.event-item-head{
    display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-bottom:6px;
}
.event-badge{
    display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.05);
    font-size:.63rem;color:#dce4f2;border:1px solid rgba(255,255,255,.05);
}
.event-extra{
    display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.event-action-link{
    border:none;background:transparent;color:#8ec8ff;font-size:.68rem;cursor:pointer;padding:0;
}
.event-action-link:hover{text-decoration:underline}
.event-turn-badge{
    color:#8fa0bd;font-size:.64rem;padding:4px 8px;border-radius:999px;
    background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05);
}
.map-route-note{
    color:#8fa0bd;font-size:.66rem;margin-top:6px;display:block;line-height:1.6;
}
.single-hero{
    display:grid;grid-template-columns:minmax(0,1.35fr) minmax(220px,.85fr);
    gap:12px;margin-bottom:14px;
}
.single-hero-main,.single-hero-side,.single-section,.single-note{
    border:1px solid rgba(255,255,255,.05);border-radius:20px;
    background:linear-gradient(160deg,rgba(17,25,42,.96),rgba(10,16,28,.9));
    box-shadow:0 18px 32px rgba(0,0,0,.22);
}
.single-hero-main,.single-hero-side,.single-section{padding:14px}
.single-kicker{
    color:#91a0bd;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;
}
.single-hero-title{
    color:#f7fbff;font-size:1.18rem;font-weight:900;margin-top:8px;
}
.single-hero-desc{
    color:#9aa7c1;font-size:.73rem;line-height:1.8;margin-top:8px;
}
.single-chip-row{
    display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;
}
.single-chip{
    display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;
    background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05);
    color:#dce4f2;font-size:.68rem;
}
.single-hero-side{
    display:grid;grid-template-columns:1fr 1fr;gap:10px;align-content:start;
}
.single-hero-stat{
    padding:12px;border-radius:16px;background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.05);
}
.single-hero-stat .label{
    color:#8d9bb7;font-size:.66rem;letter-spacing:.08em;
}
.single-hero-stat .value{
    color:#fff;font-size:1.15rem;font-weight:800;margin-top:8px;
}
.single-section{margin-top:14px}
.single-section:first-child{margin-top:0}
.single-section-head{
    display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-bottom:12px;
}
.single-section-title{
    color:#f5f8fe;font-size:.92rem;font-weight:800;display:flex;align-items:center;gap:8px;
}
.single-section-sub{
    color:#8fa0bd;font-size:.68rem;
}
.single-metric-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;
}
.single-metric-card{
    padding:14px;border-radius:18px;background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.05);
}
.single-metric-card strong{
    display:block;color:#fff;font-size:1.05rem;margin-top:10px;
}
.single-metric-card span{
    display:block;color:#8fa0bd;font-size:.69rem;line-height:1.6;margin-top:6px;
}
.single-toolbar{
    display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px;
}
.single-select{
    padding:9px 12px;border-radius:12px;background:rgba(17,25,42,.95);
    color:#f6dc86;border:1px solid rgba(255,215,0,.18);font-size:.82rem;min-width:140px;
}
.single-inline-stats{
    display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.single-inline-badge{
    padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.05);color:#cfd8ea;font-size:.68rem;
}
.single-pill-row{
    display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;
}
.single-tax-btn{
    padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.06);
    background:rgba(255,255,255,.03);color:#cfd8ea;font-size:.72rem;cursor:pointer;transition:all .2s ease;
}
.single-tax-btn:hover:not(:disabled){background:rgba(255,215,0,.1);color:#f6dc86}
.single-tax-btn:disabled{opacity:.45;cursor:not-allowed}
.single-note{
    padding:12px 14px;margin-top:14px;color:#9aa7c1;font-size:.72rem;line-height:1.9;
}
.single-note b{color:#f6dc86}
.single-table-wrap{
    overflow:auto;border-radius:18px;border:1px solid rgba(255,255,255,.05);
    background:rgba(255,255,255,.02);
}
.single-table{
    width:100%;border-collapse:collapse;font-size:.78rem;min-width:620px;
}
.single-table thead tr{
    color:#f6dc86;background:rgba(255,215,0,.04);
}
.single-table th,.single-table td{
    padding:10px 12px;text-align:left;border-bottom:1px solid rgba(255,255,255,.04);
}
.single-table tbody tr:hover{background:rgba(255,255,255,.02)}
.single-action-card{
    display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;
}
.single-action-card.centered{
    align-items:center;justify-content:center;text-align:center;border-style:dashed;
}
.single-action-card .action-icon{
    font-size:2rem;margin-bottom:8px;
}
.single-action-card .action-title{
    color:#fff;font-weight:800;font-size:.95rem;
}
.single-action-card .action-sub{
    color:#8fa0bd;font-size:.71rem;line-height:1.6;margin-top:6px;
}
.single-mini-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;
}
.single-mini-card{
    padding:12px;border-radius:18px;background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.05);
}
.single-mini-card .title{color:#f0f4fd;font-size:.82rem;font-weight:800}
.single-mini-card .sub{color:#8fa0bd;font-size:.69rem;line-height:1.7;margin-top:6px}
.map-hud-top{
    position:absolute;left:14px;right:14px;top:14px;z-index:12;
    display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;pointer-events:none;
}
.map-hud-card,.map-hud-bottom{
    background:rgba(7,10,18,.82);border:1px solid rgba(255,215,0,.14);
    border-radius:16px;backdrop-filter:blur(8px);box-shadow:0 14px 30px rgba(0,0,0,.22);
    color:#dde6f7;
}
.map-hud-card{
    padding:12px 14px;font-size:.72rem;line-height:1.7;
}
.map-hud-card strong{display:block;color:#fff;font-size:.86rem}
.map-hud-bottom{
    position:absolute;left:14px;right:14px;bottom:14px;z-index:12;
    padding:10px 12px;font-size:.72rem;text-align:center;pointer-events:none;
}
.progress-track{
    width:100%;height:8px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;margin-top:10px;
}
.progress-fill{
    height:100%;border-radius:999px;background:linear-gradient(90deg,#ffd54f,#ffb300);
}
@media(max-width:1480px){
    #main{
        grid-template-columns:minmax(208px,228px) minmax(0,1fr);
        grid-template-rows:minmax(0,1fr) auto;
    }
    #sidebar{grid-column:1;grid-row:1 / span 2}
    #content{grid-column:2;grid-row:1}
    #intelRail{
        grid-column:2;grid-row:2;display:grid;
        grid-template-columns:repeat(2,minmax(0,1fr));overflow:visible;
    }
    .rail-overview{display:none}
    .side-card#singleEventPanel{grid-column:1 / -1}
}
@media(max-width:980px){
    body{overflow:auto;height:auto;min-height:100vh}
    #app{height:auto;min-height:100vh}
    #game{min-height:100vh;height:auto}
    #main{
        display:flex;flex-direction:column;padding:10px;overflow:visible;
    }
    #sidebar,#content,#intelRail{
        max-height:none;overflow:visible;
    }
    #content > #nav{padding:8px 10px}
    .panel{padding:12px}
    #intelRail{
        display:flex;padding:0;background:transparent;border:none;box-shadow:none;
    }
    .single-hero{grid-template-columns:1fr}
    .map-hud-top{grid-template-columns:1fr}
}
@media(max-width:800px){
    #resBar{flex-direction:column;align-items:stretch}
    .res-right{justify-content:flex-start}
    #main{padding:8px}
    #sidebar,#content{border-radius:20px}
    #content > #nav{gap:6px}
    #content > #nav .nav-item{padding:8px 12px;font-size:.72rem;min-width:78px}
    #mapWrap{min-height:360px}
    .single-hero-side,.single-metric-grid,.single-mini-grid{grid-template-columns:1fr 1fr}
    .single-filter-summary{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
    #sidebar,#content,.side-card,.sidebar-overview{border-radius:18px}
    .panel{padding:10px}
    .panel-title{font-size:1.02rem}
    .panel-tip{display:none}
    #content > #nav{grid-auto-columns:max-content;padding:8px 10px}
    #content > #nav .nav-item{min-width:70px;padding:8px 10px;font-size:.68rem}
    .res-item{padding:6px 8px;font-size:.62rem}
    #turnBtn,#saveBtn.res-aux-btn{padding:8px 12px;font-size:.72rem}
    #mapWrap{min-height:300px}
    .single-hero-side,.single-metric-grid,.single-mini-grid{grid-template-columns:1fr}
    .single-filter-summary{grid-template-columns:1fr}
    .map-hud-top{left:10px;right:10px;top:10px}
    .map-hud-bottom{left:10px;right:10px;bottom:10px}
}
