/* ====================
   CORE VARIABLES & GLOBALS
   ==================== */
:root {
    --gold: #FFC857;
    --gold-glow: rgba(255, 200, 87, 0.4);
    --gold-dim: rgba(255, 200, 87, 0.15);
    --red: #FF6B6B;
    --blue: #4ECDC4;
    --purple: #A56CC1;
    --green: #2ecc71;
    
    --bg-glass: rgba(20, 20, 25, 0.95);
    --border-light: rgba(255, 255, 255, 0.1);
    --input-bg: rgba(0, 0, 0, 0.3);
    
    --safe-top: env(safe-area-inset-top, 20px);
    --safe-bottom: env(safe-area-inset-bottom, 20px);
    
    --font-main: 'Nunito', 'Noto Sans TC', sans-serif;
    --font-tech: 'Orbitron', sans-serif;
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; user-select: none; }

body {
    margin: 0; padding: 0;
    background: #050507;
    height: 100vh; width: 100vw;
    overflow: hidden;
    font-family: var(--font-main);
    color: #fff;
    display: flex; justify-content: center; align-items: center;
}

.scene-layer { position: fixed; inset: 0; z-index: 0; pointer-events: none; }

#app-bg { 
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.05);
    filter: brightness(0.6) blur(4px);
    transition: filter 0.8s ease, transform 0.8s ease;
    will-change: filter, transform;
}
.vignette {
    position: absolute;
    inset: 0;
    background: radial-gradient(circle, rgba(0,0,0,0) 22%, rgba(0,0,0,0.78) 120%);
    opacity: 0.72;
}
body[data-view="login"] .vignette { opacity: 0.48; }

body[data-view="login"] #app-bg { filter: brightness(0.58) blur(4px); transform: scale(1.03); }
body[data-view="menu"] #app-bg { filter: brightness(0.6) blur(4px); transform: scale(1.05); }
body[data-view="game"] #app-bg { filter: brightness(0.7) blur(0px); transform: scale(1.0); }


body[data-view="boot"] .view-section { display: none !important; opacity: 0 !important; pointer-events: none !important; }
body[data-view="auth-resolving"] .view-section { display: none !important; opacity: 0 !important; pointer-events: none !important; }
body[data-view="auth-resolving"] .vignette { opacity: 0.5; }
body[data-view="auth-resolving"] #app-bg { filter: brightness(0.58) blur(4px); transform: scale(1.03); }

.login-container { padding: calc(var(--safe-top) + 18px) 16px calc(var(--safe-bottom) + 18px); overflow-y: auto; -webkit-overflow-scrolling: touch; }
.login-card { min-height: fit-content; }

@media (min-width: 900px) {
  .login-container { padding: 40px 24px; }
  .login-card {
    width: min(460px, 92vw);
    max-width: 460px;
    padding: 36px 30px;
    border-radius: 34px;
    box-shadow: 0 28px 80px rgba(0,0,0,0.46);
  }
  .app-title { font-size: 28px; letter-spacing: 1.2px; }
  .app-subtitle { font-size: 13px; }
  .glass-input { font-size: 16px; }
  .btn-submit, .btn-google, .btn-guest { min-height: 54px; }
}

body.blur-mode .scene-layer,
body.blur-mode .card-scroller,
body.blur-mode .drawer-layer,
body.blur-mode .top-nav,
body.blur-mode .weekly-container {
    filter: blur(8px) brightness(0.4);
    transform: scale(0.98);
    transition: all 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.view-section {
    position: absolute; inset: 0;
    display: none;
    flex-direction: column;
    opacity: 0; 
    transition: opacity 0.4s ease-in-out;
    z-index: 10;
    pointer-events: none;
}
.view-section.active { display: flex; opacity: 1; pointer-events: auto; }

/* ====================
   LOGIN VIEW
   ==================== */
.login-container { width: 100%; height: 100%; display: flex; justify-content: center; align-items: center; }
.login-card {
    position: relative; z-index: 10; width: 90%; max-width: 400px;
    background: var(--bg-glass); border: 1px solid var(--border-light);
    border-radius: 32px; padding: 32px 24px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.42); backdrop-filter: blur(16px); background: rgba(17, 20, 28, 0.72);
    display: flex; flex-direction: column; align-items: center;
    animation: floatUp 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.logo-area { margin-bottom: 24px; text-align: center; }
.app-icon { 
    width: 64px; height: 64px; background: linear-gradient(135deg, #2b2b30, #1a1a1f);
    border: 2px solid var(--gold); border-radius: 16px; 
    display: flex; justify-content: center; align-items: center;
    font-size: 32px; color: var(--gold); margin: 0 auto 12px;
    box-shadow: 0 0 20px var(--gold-glow);
}
.app-title { font-family: var(--font-tech); font-size: 24px; font-weight: 700; letter-spacing: 1px; color: #fff; }
.app-subtitle { font-size: 12px; color: rgba(255,255,255,0.4); margin-top: 4px; }

.tab-group { display: flex; background: rgba(255,255,255,0.05); padding: 4px; border-radius: 100px; width: 100%; margin-bottom: 20px; }
.tab-btn { flex: 1; padding: 10px; border-radius: 100px; text-align: center; font-size: 14px; font-weight: 700; color: #888; cursor: pointer; transition: 0.3s; }
.tab-btn.active { background: var(--gold); color: #000; box-shadow: 0 2px 10px rgba(0,0,0,0.3); }

.form-area { width: 100%; display: flex; flex-direction: column; gap: 14px; }
.input-group { position: relative; }
.input-icon { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: rgba(255,255,255,0.4); font-size: 20px; }
.glass-input {
    width: 100%; padding: 14px 16px 14px 48px;
    background: var(--input-bg); border: 1px solid var(--border-light);
    border-radius: 16px; color: #fff; font-size: 15px; outline: none; transition: 0.3s;
}
.glass-input:focus { border-color: var(--gold); background: rgba(0,0,0,0.5); }

.btn-submit {
    width: 100%; padding: 16px; margin-top: 8px;
    background: linear-gradient(135deg, var(--gold), #e6b33e);
    border: none; border-radius: 16px; color: #000; font-size: 14px; font-weight: 800;
    cursor: pointer; display: flex; justify-content: center; align-items: center; gap: 8px;
}
.divider { display: flex; align-items: center; gap: 12px; margin: 20px 0; width: 100%; color: rgba(255,255,255,0.3); font-size: 12px; font-weight: 600; }
.line { flex: 1; height: 1px; background: rgba(255,255,255,0.1); }
.btn-google { width: 100%; padding: 14px; background: #fff; border-radius: 16px; border: none; display: flex; justify-content: center; align-items: center; gap: 12px; cursor: pointer; margin-bottom: 10px; color:#333; font-weight:700; }
.btn-guest { width: 100%; padding: 12px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); border-radius: 16px; color: #aaa; font-size: 13px; font-weight: 700; cursor: pointer; display: flex; justify-content: center; align-items: center; gap: 8px; }

/* ====================
   MENU VIEW STYLES & OVERLAYS
   ==================== */
.top-nav {
    position: absolute; top: 0; left: 0; right: 0; z-index: 20;
    padding: calc(var(--safe-top) + 12px) 16px 10px;
    display: flex; justify-content: space-between; align-items: center;
}
.brand-title {
    font-size: 22px; font-weight: 900;
    background: linear-gradient(180deg, #FFD700 0%, #F39C12 100%);
    -webkit-background-clip: text; color: transparent;
    letter-spacing: 2px; white-space: nowrap;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.8)) drop-shadow(0 0 10px rgba(255, 215, 0, 0.4));
}
.nav-right { display: flex; align-items: center; gap: 8px; }
.premium-res-bar {
    display: flex; gap: 8px; background: rgba(10, 10, 12, 0.8);
    backdrop-filter: blur(15px); padding: 5px 10px; border-radius: 100px; cursor:pointer;
    border: 1px solid rgba(255, 255, 255, 0.05);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 4px 10px rgba(0, 0, 0, 0.4);
}
.res-item { display: flex; align-items: center; gap: 4px; font-size: 12px; font-family: var(--font-tech); font-weight: 800; }
.res-item.gold { color: var(--gold); }
.res-item.dia { color: var(--blue); border-left: 1px solid rgba(255, 255, 255, 0.15); padding-left: 8px; }
.avatar-btn {
    width: 38px; height: 38px; border-radius: 50%; cursor:pointer;
    background: linear-gradient(135deg, #2b2b30, #1a1a1f); border: 2px solid rgba(255, 255, 255, 0.1);
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.8), 0 4px 10px rgba(0,0,0,0.4);
    display: flex; justify-content: center; align-items: center;
}
.avatar-icon { color:#aaa; font-size:18px; }

.card-scroller { position: absolute; top: 18%; left: 0; right: 0; height: 38%; display: flex; gap: 20px; padding: 0 32px; overflow-x: auto; scroll-snap-type: x mandatory; z-index: 20; scrollbar-width: none; align-items: center; transition: 0.5s; }
.subject-card { flex: 0 0 240px; height: 90%; background: linear-gradient(160deg, #2b2b30 0%, #1a1a1f 100%); border: 1px solid var(--border-light); border-radius: 24px; scroll-snap-align: center; position: relative; transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1); box-shadow: 0 10px 30px rgba(0,0,0,0.5); opacity: 0.6; transform: scale(0.92); cursor: pointer; display: flex; flex-direction: column; overflow: hidden; }
.subject-card.active { border-color: var(--gold); opacity: 1; transform: scale(1); box-shadow: 0 15px 50px rgba(0,0,0,0.6), 0 0 20px var(--gold-dim); }
.card-image { height: 55%; width: 100%; display: flex; justify-content: center; align-items: center; font-size: 64px; background: rgba(0,0,0,0.2); }
.card-content { padding: 16px; flex: 1; display: flex; flex-direction: column; }
.card-title { font-size: 20px; font-weight: 700; color: #fff; margin-bottom: 4px; }
.card-meta { font-size: 10px; color: rgba(255,255,255,0.4); }
.boss-tag { margin-top: auto; display: inline-flex; align-items: center; gap: 6px; background: rgba(255,255,255,0.05); padding: 6px 10px; border-radius: 8px; font-size: 11px; color: var(--red); font-weight: 700; border: 1px solid rgba(255,255,255,0.05); }

.drawer-layer { position: absolute; bottom: 0; left: 0; right: 0; height: 42%; background: var(--bg-glass); border-radius: 32px 32px 0 0; border-top: 1px solid rgba(255,255,255,0.15); backdrop-filter: blur(20px); padding: 24px 24px var(--safe-bottom); z-index: 30; display: flex; flex-direction: column; box-shadow: 0 -20px 60px rgba(0,0,0,0.6); transition: 0.5s; }
.drawer-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.sub-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; overflow-y: auto; padding-bottom: 40px; }
.sub-chip { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06); border-radius: 18px; padding: 14px; display: flex; justify-content: space-between; align-items: center; position: relative; overflow: hidden; animation: fadeUp 0.3s backwards; cursor: pointer; transition: all 0.2s; }
.sub-chip.selected { border-color: var(--gold); background: rgba(255, 200, 87, 0.1); box-shadow: 0 0 15px rgba(255, 200, 87, 0.3); transform: scale(1.02); z-index: 2; }
.sub-chip.selected .chip-name { color: var(--gold); text-shadow: 0 2px 4px rgba(0,0,0,0.8); }
.sub-chip.selected .chip-level { color: #fff; }
.sub-chip.is-locked { opacity: 0.5; filter: grayscale(1); border-color: rgba(255,107,107,0.2); pointer-events: auto; } /* 允許點擊以觸發購買提示 */
.chip-name { font-size: 14px; font-weight: 700; color: #e0e0e0; margin-bottom: 4px; display: block; transition: color 0.2s; }
.chip-level { font-size: 10px; font-weight: 700; color: #aaa; font-family: var(--font-tech); letter-spacing: 1px; }
.chip-stat { font-size: 10px; font-weight: 600; color: var(--gold); display: flex; align-items: center; gap: 4px; }
.status-dot { width: 6px; height: 6px; border-radius: 50%; background: #444; }
.lock-icon { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); color: var(--red); opacity: 0.8; font-size: 16px; }

.overlay-container { position: fixed; inset: 0; z-index: 100; display: flex; justify-content: center; align-items: center; opacity: 0; pointer-events: none; transition: 0.4s; }
.overlay-container.active { opacity: 1; pointer-events: auto; }
.overlay-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.6); backdrop-filter: blur(8px); }
.overlay-card { width: 90%; max-width: 380px; max-height: 85vh; background: rgba(15, 15, 20, 0.95); border: 1px solid rgba(255,255,255,0.1); border-radius: 32px; padding: 24px; box-shadow: 0 20px 80px rgba(0,0,0,0.8); transform: translateY(50px) scale(0.9); transition: 0.4s cubic-bezier(0.34, 1.56, 0.64, 1); position: relative; overflow: hidden; display: flex; flex-direction: column; backdrop-filter: blur(20px); }
.overlay-container.active .overlay-card { transform: translateY(0) scale(1); }

/* ====================
   PROFILE & SETTINGS
   ==================== */
.pf-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.pf-avatar-box { width: 80px; height: 80px; background: radial-gradient(circle, rgba(255,255,255,0.1), transparent); border-radius: 50%; border: 1px solid rgba(255,255,255,0.1); display: flex; justify-content: center; align-items: center; }
.pf-hero { transform: scale(0.8); margin-top: 10px; } 
.pf-info { flex: 1; margin-left: 16px; }
.pf-name { font-size: 20px; font-weight: 800; color: #fff; margin-bottom: 4px; }
.pf-rank { font-size: 12px; color: var(--gold); display: inline-block; border: 1px solid var(--gold); padding: 2px 8px; border-radius: 100px; font-weight: 700; margin-bottom: 6px; }

.pf-tabs { display: flex; background: rgba(255,255,255,0.05); border-radius: 12px; padding: 4px; margin-bottom: 20px; }
.pf-tab-btn { flex: 1; text-align: center; padding: 10px; font-size: 13px; font-weight: 800; color: #888; border-radius: 8px; cursor: pointer; transition: 0.2s; border: none; background: transparent; outline: none; }
.pf-tab-btn.active { background: var(--gold); color: #000; box-shadow: 0 2px 10px rgba(0,0,0,0.2); }
.pf-tab-content { animation: fadeUp 0.3s ease-out; }

.setting-row { display: flex; justify-content: space-between; align-items: center; padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.05); }
.setting-row:last-child { border-bottom: none; }
.setting-label { font-size: 14px; font-weight: 700; color: #ccc; }
.segmented-control { display: flex; background: rgba(0,0,0,0.4); border-radius: 12px; padding: 4px; gap: 4px; border: 1px solid rgba(255,255,255,0.1); }
.lang-btn { background: transparent; border: none; color: #888; padding: 8px 16px; border-radius: 8px; font-size: 12px; font-weight: 800; cursor: pointer; transition: 0.2s; outline: none; }
.lang-btn.active { background: rgba(255,255,255,0.15); color: var(--gold); box-shadow: 0 2px 8px rgba(0,0,0,0.3); }

.btn-logout { background: rgba(255, 107, 107, 0.1); border: 1px solid rgba(255, 107, 107, 0.3); color: var(--red); padding: 12px 32px; border-radius: 100px; font-size: 13px; font-weight: 800; cursor: pointer; transition: 0.2s; }
.btn-logout:active { transform: scale(0.95); background: rgba(255, 107, 107, 0.2); }

.radar-container { width: 100%; height: 200px; position: relative; display: flex; justify-content: center; align-items: center; margin-bottom: 24px; }
.radar-svg { width: 200px; height: 200px; transform: rotate(-90deg); }
.radar-bg { fill: none; stroke: rgba(255,255,255,0.1); stroke-width: 1; }
.radar-shape { fill: rgba(78, 205, 196, 0.2); stroke: var(--blue); stroke-width: 2; filter: drop-shadow(0 0 10px rgba(78, 205, 196, 0.4)); transition: all 1s ease-out; }
.stat-float { position: absolute; font-family: var(--font-tech); font-weight: 700; font-size: 14px; text-shadow: 0 0 10px currentColor; }
.career-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.career-box { background: rgba(255,255,255,0.03); border-radius: 16px; padding: 12px; text-align: center; border: 1px solid rgba(255,255,255,0.05); }
.cb-label { font-size: 10px; color: #666; font-weight: 700; margin-bottom: 4px; text-transform: uppercase; }
.cb-val { font-size: 16px; font-weight: 800; color: #eee; font-family: var(--font-tech); }
/* ====================
   MONETIZATION SHOP (DUAL PRICING & LIMITS)
   ==================== */
.shop-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.shop-title { font-size: 20px; font-weight: 900; color: #fff; letter-spacing: 0.5px; }
.shop-tabs { display: flex; background: rgba(255,255,255,0.05); border-radius: 12px; padding: 4px; margin-bottom: 16px; }
.shop-tab { flex: 1; text-align: center; padding: 10px; font-size: 13px; font-weight: 800; color: #888; border-radius: 8px; cursor: pointer; transition: 0.2s; }
.shop-tab.active { background: var(--gold); color: #000; box-shadow: 0 2px 10px rgba(0,0,0,0.2); }

.shop-scroll-area { overflow-y: auto; max-height: 55vh; padding-bottom: 20px; scrollbar-width: none; }
.shop-scroll-area::-webkit-scrollbar { display: none; }

.shop-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 24px; }
.shop-grid[data-filter="sup"] .iap-card:not([data-type="sup"]) { display: none; }
.shop-grid[data-filter="skill"] .iap-card:not([data-type="skill"]) { display: none; }
.shop-grid[data-filter="gem"] .iap-card:not([data-type="gem"]) { display: none; }

.iap-card { 
    position: relative; background: linear-gradient(145deg, rgba(255,255,255,0.06), rgba(0,0,0,0.2)); 
    border: 1px solid rgba(255,255,255,0.1); border-radius: 16px; padding: 24px 12px 16px; 
    text-align: center; cursor: pointer; transition: all 0.2s cubic-bezier(0.2, 0.8, 0.2, 1); 
    overflow: hidden; display: flex; flex-direction: column; align-items: center;
}
.iap-card:active { transform: scale(0.96); background: rgba(255,255,255,0.1); }
.iap-card.disabled { opacity: 0.5; filter: grayscale(1); pointer-events: none; border-color: rgba(255,107,107,0.3); }

.limit-tag {
    position: absolute; top: 0; left: 0; right: 0; background: rgba(0,0,0,0.6);
    color: #aaa; font-size: 10px; font-weight: 800; padding: 4px; letter-spacing: 0.5px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
}
.iap-card.hot { 
    border-color: rgba(241,197,90,0.4); 
    background: linear-gradient(145deg, rgba(241,197,90,0.12), rgba(0,0,0,0.3)); 
    box-shadow: 0 8px 30px rgba(241,197,90,0.15); 
}
.hot .limit-tag { background: linear-gradient(90deg, #f1c55a, #e67e22); color: #000; }
.iap-icon { font-size: 38px; margin-bottom: 12px; filter: drop-shadow(0 0 12px rgba(78, 205, 196, 0.3)); }
.hot .iap-icon { filter: drop-shadow(0 0 15px rgba(241,197,90,0.5)); transform: scale(1.1); }
.iap-amt { font-size: 14px; font-weight: 900; color: #fff; margin-bottom: 10px; }

/* Dual Pricing Display */
.dual-price {
    display: flex; flex-direction: column; gap: 4px; width: 100%;
}
.price-btn {
    width: 100%; background: rgba(255,255,255,0.08); padding: 6px; border-radius: 8px; 
    font-size: 12px; font-weight: 800; border: 1px solid rgba(255,255,255,0.05);
    display: flex; justify-content: center; align-items: center; gap: 4px;
    transition: 0.2s;
}
.price-btn:active { background: rgba(255,255,255,0.2); }
.price-btn.coin { color: var(--gold); }
.price-btn.dia { color: var(--blue); }
.price-btn.fiat { background: var(--gold); color: #000; border: none; font-size: 14px; padding: 8px; }

/* Subscriptions */
.pass-banner { 
    background: linear-gradient(135deg, #1e1e24, #0b0b10); border: 1px solid var(--gold); 
    border-radius: 20px; padding: 20px; margin-bottom: 12px; text-align: left; 
    position: relative; overflow: hidden; cursor: pointer; display: flex; 
    justify-content: space-between; align-items: center; box-shadow: 0 12px 30px rgba(0,0,0,0.5);
}
.pass-banner.lifetime { border-color: #a29bfe; }
.pass-banner:active { transform: scale(0.98); }
.pass-info { flex: 1; z-index: 2; }
.pass-title { color: var(--gold); font-weight: 900; font-size: 18px; margin-bottom: 6px; display: flex; align-items: center; gap: 8px; letter-spacing: 0.5px; }
.lifetime .pass-title { color: #a29bfe; }
.pass-desc { font-size: 12px; color: rgba(255,255,255,0.6); line-height: 1.5; margin-bottom: 12px; padding-right: 10px;}
.pass-price { font-size: 15px; font-weight: 900; color: #000; background: linear-gradient(90deg, #f1c55a, #e6b33e); padding: 6px 14px; border-radius: 10px; display: inline-block; box-shadow: 0 4px 15px rgba(241,197,90,0.3); }
.lifetime .pass-price { background: linear-gradient(90deg, #a29bfe, #6c5ce7); color: #fff; }

/* ====================
   SYSTEM MODAL (GLOBAL ALERTS)
   ==================== */
.sys-modal-overlay {
    position: fixed; inset: 0; z-index: 9999; display: flex; justify-content: center; align-items: center; 
    opacity: 0; pointer-events: none; transition: 0.3s; background: rgba(0,0,0,0.7); backdrop-filter: blur(5px);
}
.sys-modal-overlay.active { opacity: 1; pointer-events: auto; }
.sys-modal-card {
    width: 85%; max-width: 320px; background: rgba(20, 20, 25, 0.95); border: 1px solid rgba(255,255,255,0.1);
    border-radius: 24px; padding: 24px; text-align: center; box-shadow: 0 20px 50px rgba(0,0,0,0.8);
    transform: scale(0.9); transition: 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.sys-modal-overlay.active .sys-modal-card { transform: scale(1); }
.sys-icon { font-size: 40px; margin-bottom: 12px; }
.sys-icon.warning { color: var(--red); text-shadow: 0 0 15px rgba(255, 107, 107, 0.5); }
.sys-icon.success { color: var(--green); text-shadow: 0 0 15px rgba(46, 204, 113, 0.5); }
.sys-title { font-size: 18px; font-weight: 800; color: #fff; margin-bottom: 8px; }
.sys-msg { font-size: 13px; color: rgba(255,255,255,0.7); line-height: 1.5; margin-bottom: 20px; }
.sys-btn-group { display: flex; gap: 10px; }
.sys-btn { flex: 1; padding: 12px; border-radius: 12px; font-size: 14px; font-weight: 800; border: none; cursor: pointer; transition: 0.2s; }
.sys-btn:active { transform: scale(0.95); }
.sys-btn.confirm { background: var(--gold); color: #000; }
.sys-btn.cancel { background: rgba(255,255,255,0.1); color: #fff; }

/* ====================
   INVENTORY INTEGRATED INTO PROFILE
   ==================== */
.inv-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; padding: 10px 0; }
.inv-item { background: rgba(0,0,0,0.4); border: 1px solid rgba(255,255,255,0.05); border-radius: 16px; padding: 12px; display: flex; flex-direction: column; position: relative; }
.inv-item-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.inv-icon { font-size: 24px; filter: drop-shadow(0 0 8px rgba(255,255,255,0.2)); }
.inv-count { font-size: 20px; font-weight: 900; font-family: var(--font-tech); }
.inv-name { font-size: 12px; font-weight: 700; color: #ddd; margin-bottom: 4px; }
.inv-breakdown { font-size: 10px; color: #888; display: flex; justify-content: space-between; }
.inv-breakdown span.temp { color: var(--red); }
.inv-breakdown span.perm { color: var(--blue); }
.inv-progress-track { height: 4px; background: rgba(255,255,255,0.1); border-radius: 4px; margin-top: 8px; overflow: hidden; }
.inv-progress-bar { height: 100%; background: var(--gold); border-radius: 4px; transition: width 0.3s ease;}

/* 讓 Profile 視窗適應 3 個 Tab */
.pf-tabs { display: flex; background: rgba(255,255,255,0.05); border-radius: 12px; padding: 4px; margin-bottom: 20px; }
.pf-tab-btn { flex: 1; text-align: center; padding: 10px 4px; font-size: 12px; font-weight: 800; color: #888; border-radius: 8px; cursor: pointer; transition: 0.2s; border: none; background: transparent; outline: none; white-space: nowrap;}
.pf-tab-btn.active { background: var(--gold); color: #000; box-shadow: 0 2px 10px rgba(0,0,0,0.2); }
/* ====================
   DIFFICULTY PANEL (V3.8 MERGE - HAPPY METER)
   ==================== */
.diff-card { max-width: 420px; background: rgba(15, 15, 20, 0.98); padding: 24px; }
.diff-header { text-align: center; margin-bottom: 24px; }
.diff-header h2 { font-size: 22px; font-weight: 900; margin: 0 0 4px; color: var(--gold); letter-spacing: 1px; }
.diff-header p { font-size: 12px; color: #888; margin: 0; }

.diff-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 24px; }
.diff-option {
    background: linear-gradient(145deg, rgba(255,255,255,0.05), rgba(0,0,0,0.3));
    border: 1px solid rgba(255,255,255,0.1); border-radius: 16px; padding: 16px;
    text-align: center; cursor: pointer; transition: 0.2s; position: relative; overflow: hidden;
}
.diff-option.active { border-color: var(--gold); background: rgba(255,200,87,0.1); box-shadow: 0 0 20px rgba(255, 200, 87, 0.2); transform: scale(1.02); }
.diff-option:active { transform: scale(0.98); }

.diff-name { font-size: 16px; font-weight: 800; margin-bottom: 4px; color: #eee; }
.diff-multi { font-size: 24px; font-family: var(--font-tech); font-weight: 700; color: #fff; letter-spacing: 1px; }
.streak-tag { position: absolute; top: 8px; right: 8px; background: rgba(0,0,0,0.5); font-size: 9px; padding: 2px 6px; border-radius: 8px; color: var(--gold); border: 1px solid rgba(255,200,87,0.3); }
.diff-desc { font-size: 10px; color: #888; margin-top: 4px; }

.diff-info-panel {
    background: rgba(0,0,0,0.5); border-radius: 16px; padding: 16px;
    display: flex; justify-content: space-between; align-items: center;
    border: 1px solid rgba(255,255,255,0.05); margin-bottom: 20px;
}
.info-col { display: flex; flex-direction: column; gap: 4px; align-items: center; }
.info-label { font-size: 11px; color: #666; font-weight: 700; }
.info-val { font-size: 16px; color: #fff; font-weight: 900; font-family: var(--font-tech); }

.btn-start-game {
    width: 100%; padding: 16px; border-radius: 16px; border: none;
    background: linear-gradient(135deg, var(--gold), #e6b33e); color: #000;
    font-size: 16px; font-weight: 900; cursor: pointer; transition: 0.2s; box-shadow: 0 5px 20px rgba(255, 200, 87, 0.3);
}
.btn-start-game:active { transform: scale(0.96); }
/* ====================
   FEATURE DOCK / TRIAL HUB
   ==================== */
.feature-shell {
    position: absolute;
    top: calc(var(--safe-top) + 72px);
    right: 16px;
    z-index: 19;
    display: flex;
    align-items: center;
    gap: 12px;
}
.feature-launcher {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 999px;
    padding: 8px 10px 8px 14px;
    background: linear-gradient(145deg, rgba(24,24,31,0.86), rgba(8,8,14,0.92));
    box-shadow: 0 16px 34px rgba(0,0,0,0.46), inset 0 1px 0 rgba(255,255,255,0.08);
    color: #fff;
    cursor: pointer;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}
.feature-entry-pill {
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .04em;
    color: rgba(255,255,255,0.92);
}
.feature-entry-arrow {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: radial-gradient(circle at 30% 25%, rgba(255,255,255,0.32), rgba(255,200,87,0.18) 32%, rgba(37,37,45,0.98) 80%);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.2), 0 8px 18px rgba(0,0,0,0.38), 0 0 18px rgba(255,200,87,0.16);
    color: var(--gold);
    font-size: 18px;
}
.feature-launcher:active { transform: translateY(1px) scale(0.98); }
.feature-dock {
    position: absolute;
    top: 52px;
    right: 0;
    display: grid;
    gap: 10px;
    padding: 12px;
    width: 92px;
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,0.08);
    background: linear-gradient(180deg, rgba(14,14,22,0.95), rgba(5,5,10,0.98));
    box-shadow: 0 20px 50px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.06);
    transform: translateX(calc(100% + 16px));
    opacity: 0;
    pointer-events: none;
    transition: transform .28s ease, opacity .22s ease;
}
.feature-shell.open .feature-dock {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
}
.feature-dock-btn {
    appearance: none;
    border: 0;
    background: transparent;
    display: grid;
    gap: 6px;
    justify-items: center;
    color: #fff;
    cursor: pointer;
}
.feature-dock-icon {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    border: 1px solid rgba(255,255,255,0.10);
    background: linear-gradient(160deg, rgba(255,255,255,0.10), rgba(255,255,255,0.03));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.18), 0 10px 26px rgba(0,0,0,0.34);
    backdrop-filter: blur(12px);
}
.feature-dock-icon.tone-gold { color: var(--gold); box-shadow: inset 0 1px 0 rgba(255,255,255,0.18), 0 8px 22px rgba(255,200,87,0.18); }
.feature-dock-icon.tone-cyan { color: var(--blue); box-shadow: inset 0 1px 0 rgba(255,255,255,0.18), 0 8px 22px rgba(78,205,196,0.18); }
.feature-dock-icon.tone-violet { color: #b79cff; box-shadow: inset 0 1px 0 rgba(255,255,255,0.18), 0 8px 22px rgba(167,108,193,0.18); }
.feature-dock-label {
    font-size: 11px;
    font-weight: 800;
    color: rgba(255,255,255,0.86);
}
.feature-dock-btn.active .feature-dock-label,
.feature-dock-btn:active .feature-dock-label { color: #fff; }
.feature-workspace {
    position: absolute;
    inset: calc(var(--safe-top) + 118px) 12px calc(var(--safe-bottom) + 12px) 12px;
    z-index: 26;
}
.feature-workspace[hidden] { display: none !important; }
.feature-workspace-backdrop {
    position: absolute;
    inset: 0;
    border-radius: 28px;
    background: rgba(2,2,8,0.32);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.feature-workspace-card {
    position: absolute;
    inset: 0;
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(12,12,18,0.96), rgba(6,6,12,0.98));
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 28px 60px rgba(0,0,0,0.58), inset 0 1px 0 rgba(255,255,255,0.05);
    padding: 20px 18px 18px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.feature-workspace-head {
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap: 12px;
}
.feature-workspace-eyebrow {
    font-size: 11px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.44);
    margin-bottom: 4px;
}
.feature-workspace-title {
    font-size: 22px;
    font-weight: 900;
    color: #fff;
}
.feature-close-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
    color: rgba(255,255,255,0.84);
    display: inline-flex;
    align-items:center;
    justify-content:center;
}
.feature-page {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding-right: 2px;
}
.feature-page::-webkit-scrollbar { display:none; }
.feature-section-title {
    font-size: 15px;
    font-weight: 900;
    color: #fff;
}
.feature-subtitle-inline {
    margin-top: -8px;
    font-size: 12px;
    color: rgba(255,255,255,0.62);
}
.glass-block {
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), 0 12px 26px rgba(0,0,0,0.28);
    padding: 14px;
}
.trial-hero-card {
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap: 12px;
    border-radius: 24px;
    border: 1px solid rgba(255,200,87,0.18);
    background: linear-gradient(140deg, rgba(255,200,87,0.12), rgba(8,8,14,0.82));
    padding: 16px;
}
.trial-hero-title { font-size: 18px; font-weight: 900; color: #fff; }
.trial-hero-sub { font-size: 12px; color: rgba(255,255,255,0.68); margin-top: 4px; }
.trial-cycle-chip {
    padding: 8px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 900;
    color: var(--gold);
    background: rgba(0,0,0,0.34);
    border: 1px solid rgba(255,200,87,0.18);
}
.trial-panel-grid {
    display:grid;
    gap: 14px;
}
.trial-subject-grid,
.trial-sub-grid,
.codex-grid {
    display:grid;
    gap: 12px;
}
.trial-subject-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.trial-sub-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.codex-grid { grid-template-columns: 1fr; }
.trial-subject-card,
.trial-sub-card,
.codex-card {
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
    padding: 14px;
    color: #fff;
    text-align: left;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), 0 10px 20px rgba(0,0,0,0.24);
}
.trial-subject-card.active,
.trial-sub-card.active,
.codex-card.active {
    border-color: rgba(255,200,87,0.50);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 10px 24px rgba(255,200,87,0.12);
}
.trial-subject-card .top,
.trial-sub-card .top,
.codex-card .top {
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap: 10px;
}
.trial-subject-card .icon-badge,
.codex-card .icon-badge {
    width: 40px;
    height: 40px;
    border-radius: 14px;
    display:flex;
    align-items:center;
    justify-content:center;
    background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.22), rgba(255,255,255,0.04));
    color: var(--gold);
    font-size: 22px;
}
.card-title-text { font-size: 15px; font-weight: 900; color: #fff; }
.card-sub-text { font-size: 11px; color: rgba(255,255,255,0.62); margin-top: 3px; }
.stat-chip-row {
    display:flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 10px;
}
.stat-chip {
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 800;
    background: rgba(255,255,255,0.05);
    color: rgba(255,255,255,0.84);
}
.stat-chip.gold { color: var(--gold); }
.stat-chip.cyan { color: var(--blue); }
.stat-chip.violet { color: #b79cff; }
.trial-meta-row {
    display:grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 10px;
}
.trial-meta-box {
    min-height: 74px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    gap: 6px;
}
.meta-label {
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.44);
}
.meta-value {
    font-size: 15px;
    font-weight: 900;
    color: #fff;
}
.trial-rules ul { margin: 10px 0 0 18px; padding: 0; color: rgba(255,255,255,0.76); font-size: 13px; line-height: 1.6; }
.feature-footer-actions {
    display:flex;
    justify-content:flex-end;
    padding-bottom: 4px;
}
.feature-primary-btn {
    min-width: 176px;
    padding: 14px 18px;
    border-radius: 16px;
    border: 0;
    background: linear-gradient(135deg, #ffd97a, #f6b93b);
    color: #121212;
    font-weight: 900;
    box-shadow: 0 12px 24px rgba(255,200,87,0.26);
}
.ranking-toolbar { display:flex; justify-content:space-between; align-items:center; }
.ranking-list {
    display:grid;
    gap: 10px;
}
.ranking-row {
    display:grid;
    grid-template-columns: 42px 1fr auto;
    gap: 12px;
    align-items:center;
    padding: 14px;
    border-radius: 18px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.06);
}
.ranking-rank {
    width: 42px;
    height: 42px;
    border-radius: 16px;
    display:flex;
    align-items:center;
    justify-content:center;
    background: rgba(255,255,255,0.04);
    font-weight: 900;
    color: #fff;
}
.ranking-rank.top3 { background: linear-gradient(135deg, rgba(255,200,87,0.22), rgba(255,255,255,0.06)); color: var(--gold); }
.ranking-name { font-size: 14px; font-weight: 900; color:#fff; }
.ranking-meta { font-size: 11px; color: rgba(255,255,255,0.62); margin-top: 3px; }
.ranking-score { text-align:right; }
.ranking-score .pts { font-size: 16px; font-weight: 900; color: var(--gold); }
.ranking-score .sub { font-size: 11px; color: rgba(255,255,255,0.56); margin-top: 4px; }
.trial-session-banner {
    position: absolute;
    top: calc(var(--safe-top) + 52px);
    right: 16px;
    display:flex;
    gap: 10px;
    align-items:center;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid rgba(255,200,87,0.18);
    background: rgba(5,5,10,0.72);
    box-shadow: 0 12px 26px rgba(0,0,0,0.38);
    z-index: 13;
}
.trial-session-banner[hidden] { display:none !important; }
.trial-session-label { font-size: 11px; font-weight: 800; color: rgba(255,255,255,0.74); }
.trial-session-time { font-size: 13px; font-weight: 900; color: var(--gold); }
@media (max-width: 640px) {
    .feature-shell { top: calc(var(--safe-top) + 62px); right: 14px; }
    .feature-workspace { inset: calc(var(--safe-top) + 106px) 10px calc(var(--safe-bottom) + 10px); }
    .trial-panel-grid, .trial-meta-row { grid-template-columns: 1fr; }
    .trial-subject-grid, .trial-sub-grid { grid-template-columns: 1fr 1fr; }
    .feature-primary-btn { width: 100%; }
}

/* ====================
   GAME VIEW & EFFECTS
   ==================== */
.boss-stage { position: absolute; top: 0; left: 0; right: 0; height: 34%; z-index: 10; display: flex; flex-direction: column; align-items: center; padding-top: calc(var(--safe-top) + 8px); }
.score-board { position:absolute; top: calc(var(--safe-top) + 10px); left: 14px; right: 14px; font-size: 17px; font-weight: 900; color: rgba(255,255,255,0.86); text-shadow: 0 2px 10px rgba(0,0,0,0.55); margin: 0; z-index: 12; }
.battle-topbar { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.score-group { display:flex; align-items:center; gap:6px; min-width:0; }
.score-val { color: var(--gold); }
.combo-group { display:flex; align-items:center; gap:5px; padding:6px 11px; border-radius:999px; background:rgba(5,5,10,0.72); border:1px solid rgba(255,255,255,0.10); box-shadow:0 8px 20px rgba(0,0,0,0.25); min-width: 104px; justify-content:flex-end; }
.combo-value { font-size:11px; font-weight:900; letter-spacing:0.05em; color: rgba(255,255,255,0.9); white-space:nowrap; }
.combo-max-hint { font-size:10px; font-weight:900; color: var(--gold); opacity:0; transform: translateY(4px) scale(0.9); pointer-events:none; }
.combo-group.combo-max-fx { animation: comboPulse 0.5s ease, comboGlowFade 3s ease forwards; }
.combo-group.combo-max-fx .combo-max-hint { animation: comboHintFade 3s ease forwards; }
.boss-container{ width:100%; display:flex; justify-content:center; align-items:center; margin-top: 4px; }
.boss-hud { width:min(92%, 400px); margin-top: 48px; padding: 10px 12px 8px; border-radius: 18px; background: rgba(8,10,16,0.78); border: 1px solid rgba(255,255,255,0.10); box-shadow: 0 14px 24px rgba(0,0,0,0.28); backdrop-filter: blur(10px); }
.boss-hud.is-loading { opacity: 0.88; }
.boss-head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.boss-name-wrap { min-width: 0; }
.boss-name-text { font-size: 14px; font-weight: 900; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.boss-meta-row { display:flex; gap:8px; margin-top:6px; }
.boss-mode-badge, .boss-tier-pill, .boss-defense-pill { display:inline-flex; align-items:center; justify-content:center; padding:4px 8px; border-radius:999px; background: rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.10); font-size:10px; font-weight:800; color: rgba(255,255,255,0.76); }
.boss-mode-badge { color: var(--gold); }
.boss-hp-text { font-size:12px; font-weight:800; color: rgba(255,255,255,0.82); white-space:nowrap; }
.boss-hp-track { position:relative; height: 8px; margin-top: 9px; border-radius: 999px; background: rgba(255,255,255,0.08); overflow:hidden; }
.boss-hp-trail, .boss-hp-bar { position:absolute; inset:0 auto 0 0; width:100%; border-radius:999px; transition: width 0.3s ease; }
.boss-hp-trail { background: rgba(255, 144, 144, 0.28); }
.boss-hp-bar { background: linear-gradient(90deg, #ff6b6b, #f39c12); box-shadow: 0 0 14px rgba(255,107,107,0.40); }
.boss-defense-row { display:flex; gap:6px; margin-top:8px; flex-wrap:wrap; }
.boss-entity { font-size: 58px; filter: drop-shadow(0 0 14px rgba(255, 200, 87, 0.46)); z-index: 2; animation: float 3s ease-in-out infinite; transform-origin: center; will-change: transform; transition: all 0.3s; }
.boss-entity.hurt { filter: drop-shadow(0 0 25px rgba(255, 107, 107, 0.8)); transform: scale(0.9); }

.dialogue-box { background: rgba(30, 30, 35, 0.95); border: 2px solid var(--gold); border-radius: 22px; padding: 14px 18px; width: 88%; max-width: 360px; min-height: 92px; text-align: center; position: relative; box-shadow: 0 8px 22px rgba(0,0,0,0.36); margin-top: 2px; }
.dialogue-box::after { content: ''; position: absolute; top: -10px; left: 50%; transform: translateX(-50%); border-left: 10px solid transparent; border-right: 10px solid transparent; border-bottom: 10px solid var(--gold); }
.q-text { font-size: 15px; line-height: 1.46; font-weight: 700; background: linear-gradient(to bottom, #fff, #ddd); -webkit-background-clip: text; color: transparent; margin: 0; max-height: 148px; overflow-y: auto; scrollbar-width: thin; }
.q-type { font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: rgba(255, 200, 87, 0.82); margin-bottom: 8px; font-weight: 800; }
.q-type.correct { color: #71f2b3; }
.q-type.wrong { color: #ff9b9b; }
.q-iq-band { font-size: 10px; letter-spacing: .08em; color: rgba(255,255,255,0.52); margin-bottom: 10px; font-weight: 700; }
.q-passage { font-size: 12px; line-height: 1.55; color: rgba(255,255,255,0.82); padding: 10px 12px; border-radius: 14px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.08); margin-bottom: 10px; text-align: left; max-height: 96px; overflow-y: auto; }
.q-prompt { line-height: 1.48; font-weight: 700; color: #f7f7fb; word-break: break-word; overflow-wrap: anywhere; }
.q-prompt.q-prompt-size-1 { font-size: 18px; }
.q-prompt.q-prompt-size-2 { font-size: 17px; }
.q-prompt.q-prompt-size-3 { font-size: 16px; }
.q-prompt.q-prompt-size-4 { font-size: 15px; }
.q-explanation { margin-top: 10px; font-size: 12px; line-height: 1.55; color: rgba(255,255,255,0.76); }

.options-stage { position: absolute; top: 47%; left: 0; right: 0; bottom: 24%; z-index: 15; display: flex; flex-direction: column; align-items: center; gap: 10px; }
.opt-btn { width: 88%; max-width: 350px; min-height: 54px; background: var(--bg-glass); border: 1px solid var(--border-light); border-radius: 18px; padding: 0 16px; display: flex; align-items: center; transition: all 0.1s; box-shadow: 0 4px 10px rgba(0,0,0,0.2); backdrop-filter: blur(5px); color: #fff; cursor: pointer; }
.opt-btn:active { transform: scale(0.95); background: rgba(255,255,255,0.2); }
.opt-btn.is-disabled { opacity: 0.9; }
.opt-btn.is-correct { border-color: rgba(113, 242, 179, 0.9); box-shadow: 0 0 0 1px rgba(113, 242, 179, 0.45), 0 6px 16px rgba(33, 150, 83, 0.25); background: rgba(27, 79, 52, 0.42); }
.opt-btn.is-wrong { border-color: rgba(255, 138, 138, 0.95); box-shadow: 0 0 0 1px rgba(255, 138, 138, 0.4), 0 6px 16px rgba(198, 40, 40, 0.22); background: rgba(110, 31, 31, 0.42); }
.opt-key { width: 30px; height: 30px; background: linear-gradient(135deg, #444, #222); color: var(--gold); border: 1px solid rgba(255,255,255,0.2); border-radius: 50%; display: flex; justify-content: center; align-items: center; font-weight: 800; font-size: 14px; margin-right: 14px; flex-shrink: 0;}
.opt-text { font-weight: 600; color: #f0f0f5; text-align: left; line-height: 1.35; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; word-break: break-word; overflow-wrap: anywhere; }
.opt-text.opt-text-size-1 { font-size: 18px; }
.opt-text.opt-text-size-2 { font-size: 17px; }
.opt-text.opt-text-size-3 { font-size: 16px; }
.opt-text.opt-text-size-4 { font-size: 15px; }

.player-stage { position: absolute; bottom: 0; left: 0; right: 0; height: 24%; z-index: 20; display: flex; flex-direction: column; justify-content: flex-end; align-items: center; }
.hero-section-wrapper { position: relative; display: flex; align-items: flex-end; justify-content: center; gap: 15px; margin-bottom: -2px; z-index: 25; padding-bottom: 8px; }
.timer-float { position: absolute; top: -46px; left: 50%; transform: translateX(-50%); width: 44px; height: 44px; background: #111; border: 2px solid var(--gold); border-radius: 50%; display: flex; justify-content: center; align-items: center; font-weight: 800; font-size: 20px; color: #fff; box-shadow: 0 0 20px var(--gold-glow), inset 0 0 10px var(--gold-glow); animation: pulse-time 2s infinite; z-index: 30; }

.hero-avatar { position: relative; width: 60px; height: 80px; transform: scale(1.1); margin: 0 5px; cursor: pointer;}
.h-head, .hero-head { width: 30px; height: 34px; background: #2d3436; margin: 0 auto; border-radius: 12px 12px 6px 6px; border: 1px solid rgba(255,255,255,0.2); position: relative; z-index: 3; }
.h-body, .hero-body { width: 46px; height: 42px; background: linear-gradient(to bottom, #0984e3, #74b9ff); margin: -4px auto 0; border-radius: 10px 10px 0 0; border: 1px solid rgba(255,255,255,0.2); position: relative; z-index: 2; }
.h-pack, .hero-backpack { position: absolute; top: 35px; left: 50%; transform: translateX(-50%); width: 34px; height: 30px; background: #6D4C41; border-radius: 8px; border: 1px solid rgba(0,0,0,0.3); z-index: 4; box-shadow: 0 2px 5px rgba(0,0,0,0.4); transition: 0.2s;}
.hero-avatar:active .h-pack { transform: translateX(-50%) scale(1.1); border-color: var(--gold); box-shadow: 0 0 15px var(--gold-glow); }
.h-pack::before, .hero-backpack::before { content: ''; position: absolute; top: 4px; left: 50%; transform: translateX(-50%); width: 20px; height: 12px; background: #8D6E63; border-radius: 4px; }
.hero-cape { position: absolute; top: 22px; left: 4px; right: 4px; height: 50px; background: #d63031; border-radius: 4px; z-index: 1; }

.skill-btn { width: 48px; height: 48px; background: rgba(45, 52, 54, 0.9); border: 2px solid rgba(255,255,255,0.2); border-radius: 50%; display: flex; justify-content: center; align-items: center; font-size: 22px; color: #fff; box-shadow: 0 4px 10px rgba(0,0,0,0.4); transition: 0.1s; cursor: pointer; position: relative; }
.skill-badge { position: absolute; top: -6px; right: -6px; min-width: 22px; height: 22px; padding: 0 6px; border-radius: 12px; background: var(--red); color: white; border: 2px solid #2d3436; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 900; box-shadow: 0 2px 4px rgba(0,0,0,0.5); z-index: 5; pointer-events: none;}
.skill-btn:active { transform: scale(0.9); }
.skill-btn.empty { opacity: 0.4; filter: grayscale(100%); pointer-events: none; }
.skill-btn.empty .skill-badge { background: #555; }
.skill-btn.cooldown .cd-overlay { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:20px; font-family:var(--font-tech); font-weight:900; color:#fff; z-index:4; text-shadow:0 2px 6px #000; background:rgba(0,0,0,0.5); border-radius: 50%;}

.player-hud { width: 100%; background: linear-gradient(to top, rgba(0,0,0,1), rgba(10,10,10,0.85)); backdrop-filter: blur(10px); border-top: 1px solid rgba(255,255,255,0.1); padding: 12px 20px calc(var(--safe-bottom) + 10px); display: flex !important; flex-wrap: nowrap !important; gap: 6px !important; justify-content: space-between !important; align-items: stretch !important; border-radius: 24px 24px 0 0; box-shadow: 0 -5px 20px rgba(0,0,0,0.5); }
.hud-block { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; padding: 10px 8px !important; display: flex; flex-direction: column; justify-content: center; flex: 1 1 0 !important; min-width: 0 !important; }
.hud-label { font-size: 10px !important; font-weight: 700; color: rgba(255,255,255,0.5); margin-bottom: 4px; text-transform: uppercase; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.val-text { font-size: 14px !important; font-weight: 800; }
.val-int { color: var(--blue); } .val-agi { color: var(--green); } .val-hp { color: var(--red); }
.hud-hp-track { height: 6px; width: 100%; background: rgba(0,0,0,0.3); border-radius: 100px; margin-top: 4px; overflow: hidden; }
.hud-hp-bar { height: 100%; width: 100%; background: var(--red); border-radius: 100px; box-shadow: 0 0 8px rgba(255, 107, 107, 0.4); transition: width 0.3s ease; }

/* REVIVE MODAL */
.revive-card { text-align: center; padding: 32px 24px; border-color: rgba(255, 107, 107, 0.4); box-shadow: 0 0 50px rgba(255, 107, 107, 0.15); }
.revive-header { font-size: 24px; font-weight: 900; color: var(--red); margin-bottom: 8px; }
.revive-desc { font-size: 13px; color: rgba(255,255,255,0.6); margin-bottom: 16px; line-height: 1.5; }
.revive-score { font-size: 16px; font-weight: 800; margin-bottom: 24px; background: rgba(255, 200, 87, 0.08); padding: 10px; border-radius: 12px; border: 1px solid rgba(255, 200, 87, 0.2); }
.revive-actions { display: flex; flex-direction: column; gap: 12px; }
.btn-revive { width: 100%; padding: 16px; border-radius: 16px; font-size: 14px; font-weight: 800; display: flex; justify-content: center; align-items: center; gap: 8px; cursor: pointer; transition: 0.2s; border: none; outline: none; }
.btn-revive:active { transform: scale(0.96); }
.btn-revive.primary { background: linear-gradient(135deg, var(--gold), #e6b33e); color: #000; box-shadow: 0 4px 15px rgba(255, 200, 87, 0.3); }
.btn-revive.item { background: linear-gradient(135deg, var(--red), #c0392b); color: #fff; }
.btn-revive.item:disabled { opacity: 0.5; filter: grayscale(1); pointer-events: none; }
.btn-revive.secondary { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.2); color: #fff; }
.btn-revive.ghost { background: transparent; border: none; color: rgba(255,255,255,0.4); font-size: 13px; font-weight: 600; padding: 10px; }

/* AAA SETTLEMENT OVERLAY */
.settlement-overlay {
    position: fixed; inset: 0; z-index: 200; display: flex; justify-content: center; align-items: center; 
    opacity: 0; pointer-events: none; transition: 0.4s ease-out; backdrop-filter: blur(15px); background: rgba(0,0,0,0.8);
}
.settlement-overlay.active { opacity: 1; pointer-events: auto; }
.settlement-card {
    width: 90%; max-width: 400px; background: linear-gradient(180deg, rgba(30,30,40,0.95) 0%, rgba(15,15,20,0.95) 100%);
    border: 2px solid var(--gold); border-radius: 32px; padding: 32px 24px;
    box-shadow: 0 0 50px rgba(255, 200, 87, 0.2), inset 0 0 20px rgba(255, 200, 87, 0.1);
    text-align: center; transform: translateY(100px) scale(0.9); opacity: 0; transition: all 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.settlement-overlay.active .settlement-card { transform: translateY(0) scale(1); opacity: 1; }
.settlement-title { font-size: 36px; font-weight: 900; font-family: var(--font-tech); margin-bottom: 8px; text-transform: uppercase; letter-spacing: 2px; }
.settlement-title.victory { background: linear-gradient(to bottom, #FFD700, #F39C12); -webkit-background-clip: text; color: transparent; filter: drop-shadow(0 4px 10px rgba(255,215,0,0.4)); }
.settlement-title.defeat { background: linear-gradient(to bottom, #ff6b6b, #c0392b); -webkit-background-clip: text; color: transparent; filter: drop-shadow(0 4px 10px rgba(255,107,107,0.4)); }
.settlement-sub { font-size: 14px; color: #aaa; margin-bottom: 24px; font-weight: 700; }
.settlement-score-label { font-size: 12px; color: var(--gold); font-weight: 800; letter-spacing: 1px; }
.settlement-score-val { font-size: 56px; font-weight: 900; font-family: var(--font-tech); color: #fff; text-shadow: 0 0 20px rgba(255,255,255,0.3); margin-bottom: 24px; line-height: 1; }
.settlement-rewards { display: flex; justify-content: center; gap: 16px; margin-bottom: 32px; padding: 16px; background: rgba(0,0,0,0.4); border-radius: 16px; border: 1px solid rgba(255,255,255,0.05); }
.reward-item { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.reward-icon { font-size: 24px; }
.reward-val { font-size: 16px; font-weight: 800; font-family: var(--font-tech); }
.settlement-actions { display: flex; flex-direction: column; gap: 12px; }
.btn-ad-double { width: 100%; padding: 16px; border-radius: 16px; border: none; background: linear-gradient(135deg, var(--blue), #2980b9); color: #fff; font-size: 15px; font-weight: 800; cursor: pointer; display: flex; justify-content: center; align-items: center; gap: 8px; box-shadow: 0 4px 15px rgba(78, 205, 196, 0.4); }
.btn-return { width: 100%; padding: 16px; border-radius: 16px; border: 1px solid rgba(255,255,255,0.2); background: transparent; color: #fff; font-size: 15px; font-weight: 800; cursor: pointer; transition: 0.2s; }

.float-score { position: absolute; left: 50%; top: 40%; transform: translate(-50%, -50%); font-size: 32px; font-weight: 900; color: var(--gold); text-shadow: 0 0 20px var(--gold); animation: floatUpText 1s ease-out forwards; pointer-events: none; z-index: 100; }
@keyframes floatUpText { 0% { opacity: 0; transform: translate(-50%, 0) scale(0.5); } 20% { opacity: 1; transform: translate(-50%, -50px) scale(1.2); } 100% { opacity: 0; transform: translate(-50%, -100px) scale(1); } }
@keyframes pulse-time { 0% { box-shadow: 0 0 20px var(--gold-glow); transform: translateX(-50%) scale(1); } 50% { box-shadow: 0 0 30px var(--gold-glow); transform: translateX(-50%) scale(1.05); } 100% { box-shadow: 0 0 20px var(--gold-glow); transform: translateX(-50%) scale(1); } }
@keyframes float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@keyframes floatUp { from { opacity: 0; transform: translateY(40px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

@keyframes dodgeTeleport{ 0%{ transform:translateX(0) scale(1); opacity:1; } 20%{ transform:translateX(-30px) scale(0.95); opacity:0; } 60%{ transform:translateX(30px) scale(0.95); opacity:0; } 100%{ transform:translateX(0) scale(1); opacity:1; } }
.hero-avatar.fx-dodge{ animation:dodgeTeleport .45s ease; }
@keyframes shieldBreak{ 0%{ box-shadow:0 0 0 rgba(0,255,255,0); } 30%{ box-shadow:0 0 26px rgba(0,255,255,0.9); } 70%{ box-shadow:0 0 40px rgba(0,255,255,0.95); transform:scale(1.06); } 100%{ box-shadow:0 0 0 rgba(0,255,255,0); transform:scale(1); } }
.hero-avatar.fx-shield-break{ animation:shieldBreak .55s ease; }

@keyframes auraSpin{ 0%{ transform:translate(-50%,-50%) rotate(0deg); opacity:.35; } 50%{ opacity:.75; } 100%{ transform:translate(-50%,-50%) rotate(360deg); opacity:.35; } }
.player-character.shield-aura::after{ content:""; position:absolute; left:50%; top:50%; width:110px; height:110px; border-radius:50%; border:2px solid rgba(120,255,255,0.75); box-shadow:0 0 18px rgba(120,255,255,0.35), inset 0 0 12px rgba(120,255,255,0.15); transform:translate(-50%,-50%); animation:auraSpin 1.2s linear infinite; pointer-events:none; z-index:1; }

@keyframes greenPulse{ 0%{ opacity:.25; transform:translate(-50%,-50%) scale(0.95); } 50%{ opacity:.65; transform:translate(-50%,-50%) scale(1.05); } 100%{ opacity:.25; transform:translate(-50%,-50%) scale(0.95); } }
.player-character.agility-aura::before{ content:""; position:absolute; left:50%; top:50%; width:120px; height:120px; border-radius:50%; background:radial-gradient(circle, rgba(120,255,140,0.0) 40%, rgba(120,255,140,0.25) 70%, rgba(120,255,140,0.0) 100%); box-shadow:0 0 22px rgba(120,255,140,0.25); transform:translate(-50%,-50%); animation:greenPulse .9s ease-in-out infinite; pointer-events:none; z-index:0; }


.subject-card.is-locked {
    opacity: 0.9;
    border-color: rgba(245, 201, 106, 0.28);
}
.subject-card.is-locked::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(7,7,10,0.12), rgba(7,7,10,0.78));
    pointer-events: none;
}
.subject-card.is-locked .card-content,
.subject-card.is-locked .card-image { position: relative; z-index: 1; }
.subject-card .card-lock-shell {
    position: absolute;
    inset: auto 12px 12px 12px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    border-radius: 16px;
    border: 1px solid rgba(245, 201, 106, 0.24);
    background: rgba(10, 10, 14, 0.74);
    backdrop-filter: blur(12px);
    z-index: 2;
}
.subject-card .lock-copy { display:flex; flex-direction:column; gap:2px; }
.subject-card .lock-badge {
    display:inline-flex;
    align-items:center;
    gap:6px;
    width: fit-content;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(245, 201, 106, 0.16);
    color: var(--gold);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.08em;
}
.subject-card .lock-desc { color: rgba(255,255,255,0.72); font-size: 11px; }
.subject-card .lock-arrow { color: var(--gold); font-size: 18px; }

.event-overlay .overlay-card.event-card {
    max-width: 410px;
    gap: 18px;
    border: 1px solid rgba(245, 201, 106, 0.16);
    background:
        radial-gradient(circle at top left, rgba(245, 201, 106, 0.10), transparent 40%),
        rgba(13, 13, 18, 0.96);
}
.event-head { display:flex; gap:14px; align-items:flex-start; }
.event-icon {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display:flex;
    align-items:center;
    justify-content:center;
    color: var(--gold);
    background: rgba(245, 201, 106, 0.12);
    border: 1px solid rgba(245, 201, 106, 0.18);
    box-shadow: 0 12px 30px rgba(0,0,0,0.25);
    font-size: 22px;
    flex: 0 0 auto;
}
.event-copy { display:flex; flex-direction:column; gap:6px; }
.event-eyebrow {
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(245, 201, 106, 0.72);
    font-weight: 800;
}
.event-title { font-size: 24px; font-weight: 900; color:#fff; line-height:1.15; }
.event-subtitle { color: rgba(255,255,255,0.72); font-size: 13px; line-height: 1.6; }
.event-list { display:flex; flex-direction:column; gap:10px; }
.event-list:empty { display:none; }
.event-item {
    display:flex;
    gap:12px;
    align-items:flex-start;
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
}
.event-item-icon { color: var(--gold); font-size: 18px; line-height: 1.2; padding-top: 1px; }
.event-item-main { display:flex; flex-direction:column; gap:3px; }
.event-item-title { color:#fff; font-size: 14px; font-weight: 800; }
.event-item-desc { color: rgba(255,255,255,0.6); font-size: 12px; line-height:1.5; }
.event-footer { display:flex; gap:10px; }
.event-btn {
    flex:1;
    min-height: 48px;
    border-radius: 16px;
    border: none;
    outline: none;
    font-size: 14px;
    font-weight: 800;
    cursor: pointer;
    transition: transform .2s ease, opacity .2s ease, box-shadow .2s ease;
}
.event-btn:active { transform: scale(0.98); }
.event-btn.primary {
    color: #111;
    background: linear-gradient(135deg, #f5c96a, #f0b83f);
    box-shadow: 0 10px 24px rgba(245, 201, 106, 0.18);
}
.event-btn.secondary {
    color: #fff;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.14);
}
.event-card.tone-red .event-icon,
.event-card.tone-red .event-btn.primary {
    background: linear-gradient(135deg, rgba(255, 107, 107, 0.22), rgba(255, 107, 107, 0.10));
    color: #fff;
}
.event-card.tone-red .event-btn.primary {
    background: linear-gradient(135deg, #ff7b7b, #ff5e5e);
}
.event-card.tone-blue .event-icon,
.event-card.tone-blue .event-btn.primary {
    background: linear-gradient(135deg, rgba(78,205,196,0.24), rgba(78,205,196,0.12));
    color: #eaffff;
}
.event-card.tone-blue .event-btn.primary {
    background: linear-gradient(135deg, #65d6cf, #2ea8d8);
    color: #06151f;
}

/* ====================
   PATCH V5.9.9 — MEMBER FLOW / PROFILE HP / SHOP POLISH
   ==================== */
.btn-google {
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-bottom: 12px;
    padding: 14px 18px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.12);
    background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.04));
    color: #f5f6fa;
    font-size: 14px;
    font-weight: 800;
    cursor: pointer;
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.btn-google:active { transform: scale(.985); }
.btn-google:hover { border-color: rgba(255,200,87,0.38); box-shadow: 0 12px 28px rgba(0,0,0,.28), 0 0 0 1px rgba(255,200,87,.08) inset; }
.auth-google-btn { margin-top: 14px; max-width: 100%; }
.setting-auth-card {
    background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.025));
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 18px;
    padding: 16px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.setting-auth-title { color: #fff; font-size: 15px; font-weight: 800; margin-bottom: 6px; }
.setting-auth-sub { color: #9a9aab; font-size: 12px; line-height: 1.55; }

.pf-header { align-items: flex-start; gap: 14px; }
.pf-info { min-width: 0; }
.pf-vitals-inline {
    width: 104px;
    margin-left: auto;
    padding-top: 4px;
    text-align: right;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.pf-vital-label {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .06em;
    color: rgba(255,255,255,0.52);
}
.pf-vital-label.muted { margin-top: 6px; }
.pf-vital-value {
    color: #fff;
    font-family: var(--font-tech);
    font-size: 22px;
    font-weight: 700;
    letter-spacing: .02em;
    text-shadow: 0 0 12px rgba(255,200,87,.12);
}
.pf-vital-time {
    color: var(--gold);
    font-family: var(--font-tech);
    font-size: 16px;
    font-weight: 700;
    text-shadow: 0 0 12px rgba(255,200,87,.18);
}

.shop-subtitle {
    margin-top: 4px;
    color: rgba(255,255,255,0.54);
    font-size: 12px;
    line-height: 1.45;
}
.shop-premium-strip {
    margin: 0 8px 16px;
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid rgba(255,200,87,0.12);
    background: linear-gradient(135deg, rgba(255,200,87,0.12), rgba(255,255,255,0.035));
    box-shadow: 0 14px 34px rgba(0,0,0,0.22);
}
.shop-strip-kicker {
    color: var(--gold);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .16em;
    margin-bottom: 6px;
}
.shop-strip-copy {
    color: rgba(255,255,255,0.76);
    font-size: 12px;
    line-height: 1.5;
}
.iap-card,
.pass-banner {
    box-shadow: 0 18px 38px rgba(0,0,0,.24);
}
.iap-card::after,
.pass-banner::after {
    content: '';
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0));
    opacity: .7;
}
.pass-info { position: relative; z-index: 1; }
.pass-perks {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 10px 0 14px;
}
.pass-perks span {
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.86);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .02em;
}
.pass-banner.lifetime .pass-perks span {
    background: rgba(162,155,254,0.12);
    border-color: rgba(162,155,254,0.2);
}

.cooldown-hint {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin: 14px 0 18px;
    padding: 12px 14px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
    color: rgba(255,255,255,0.74);
    font-size: 12px;
    line-height: 1.5;
}
.cooldown-hint i { font-size: 16px; margin-top: 1px; }
.cooldown-hint.ready { border-color: rgba(46, 204, 113, 0.18); color: rgba(209,255,223,.9); }
.cooldown-hint.ready i { color: #53d77b; }
.cooldown-hint.locked { border-color: rgba(255,200,87,0.2); background: linear-gradient(180deg, rgba(255,200,87,0.08), rgba(255,255,255,0.03)); color: rgba(255,240,208,.92); }
.cooldown-hint.locked i { color: var(--gold); }

.overlay-card.event-card,
.revive-card,
.settlement-card {
    position: relative;
    overflow: hidden;
}
.overlay-card.event-card::before,
.revive-card::before,
.settlement-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top right, rgba(255,200,87,0.15), transparent 42%), linear-gradient(180deg, rgba(255,255,255,0.05), transparent 28%);
    pointer-events: none;
}
.overlay-container.active .overlay-card,
.settlement-overlay.active .settlement-card {
    animation: panelRise .42s cubic-bezier(.22,1,.36,1);
}
@keyframes panelRise {
    0% { opacity: 0; transform: translateY(28px) scale(.94); }
    100% { opacity: 1; transform: translateY(0) scale(1); }
}
.revive-header,
.settlement-title,
.event-title { text-shadow: 0 0 18px rgba(255,200,87,0.12); }
.revive-actions,
.settlement-actions,
.event-footer { position: relative; z-index: 1; }
.reward-item {
    min-width: 120px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}
.event-item {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.btn-revive,
.btn-return,
.btn-ad-double,
.event-btn,
.sys-btn.confirm {
    transition: transform .18s ease, box-shadow .2s ease, filter .2s ease;
}
.btn-revive:active,
.btn-return:active,
.btn-ad-double:active,
.event-btn:active,
.sys-btn.confirm:active { transform: scale(.98); }

@media (max-width: 420px) {
    .pf-header { gap: 10px; }
    .pf-avatar-box { width: 72px; height: 72px; }
    .pf-name { font-size: 18px; }
    .pf-vitals-inline { width: 96px; padding-top: 2px; }
    .pf-vital-value { font-size: 16px; }
    .pf-vital-time { font-size: 12px; }
    .shop-premium-strip { padding: 12px 14px; }
}

.shop-close-btn {
    width: 40px;
    height: 40px;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 14px;
    background: rgba(255,255,255,0.05);
    color: #f3f4f8;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform .18s ease, border-color .18s ease, background .18s ease;
    flex: 0 0 auto;
}
.shop-close-btn i { font-size: 18px; }
.shop-close-btn:active { transform: scale(.96); }
.shop-close-btn:hover {
    border-color: rgba(255,200,87,0.28);
    background: rgba(255,255,255,0.08);
}


/* ===== Subject UI refresh from 001 prototype ===== */
.card-scroller.carousel-stage {
    top: 16.8%;
    height: 40.5%;
    gap: 20px;
    padding: 0 calc(50vw - 110px);
    perspective: 1200px;
    transform-style: preserve-3d;
    scroll-padding-inline: calc(50vw - 110px);
    scroll-snap-stop: normal;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    z-index: 18;
    will-change: scroll-position;
}
.card-scroller.carousel-stage::-webkit-scrollbar,
.tactical-grid::-webkit-scrollbar { display:none; }
.subject-card {
    --subject-rgb: 255,200,87;
    flex: 0 0 220px;
    height: 92%;
    border-radius: 28px;
    border: 2px solid rgba(255,255,255,0.05);
    background: linear-gradient(160deg, rgba(30,30,35,0.65) 0%, rgba(10,10,15,0.85) 100%);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 18px 50px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.05);
    opacity: 0.5;
    transform: scale(0.85) translateZ(-40px) rotateX(5deg);
    -webkit-transform: scale(0.85) translateZ(-40px) rotateX(5deg);
    transform-origin: center center;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.15);
    display: flex;
    flex-direction: column;
    padding: 20px 18px 18px;
    position: relative;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    will-change: transform, opacity;
    contain: layout paint style;
}
.subject-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top left, rgba(var(--subject-rgb),0.18), transparent 38%);
    pointer-events:none;
}
.subject-card.active {
    opacity: 1;
    transform: scale(1.02) translateZ(0px) rotateX(0deg);
    -webkit-transform: scale(1.02) translateZ(0px) rotateX(0deg);
    border-color: rgba(var(--subject-rgb), 0.96);
    box-shadow: 0 24px 65px rgba(0,0,0,0.68), inset 0 0 26px rgba(var(--subject-rgb),0.24), 0 0 28px rgba(var(--subject-rgb),0.18);
}
.subject-card.is-side { opacity: 0.72; transform: scale(0.92) translateZ(-24px) rotateX(4deg); }
.subject-card.active.is-side { transform: scale(1.02) translateZ(0px) rotateX(0deg); }
.subject-card .card-icon-stage {
    width: 100%;
    min-height: 138px;
    display:flex;
    align-items:center;
    justify-content:center;
    margin-bottom: 12px;
    position: relative;
}
.subject-card .card-icon-stage::after {
    content:'';
    position:absolute;
    inset:auto 12% 8px;
    height: 54px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(var(--subject-rgb),0.24), transparent 68%);
    filter: blur(8px);
}
.subject-card .card-icon-glow {
    font-size: 76px;
    line-height: 1;
    filter: drop-shadow(0 8px 24px rgba(var(--subject-rgb),0.32));
    position: relative;
    z-index: 1;
}
.subject-card .card-body, .subject-card .card-content {
    position: relative;
    z-index: 1;
    display:flex;
    flex-direction:column;
    gap: 5px;
    min-height: 0;
    flex: 1;
}
.subject-card .subject-name, .subject-card .card-title {
    font-size: 18px;
    font-weight: 900;
    color: #fff;
    letter-spacing: 0.2px;
}
.subject-card .subject-meta, .subject-card .card-meta {
    font-size: 11px;
    color: rgba(255,255,255,0.62);
    font-weight: 800;
    letter-spacing: 0.6px;
    text-transform: uppercase;
}
.subject-card .boss-tag-danger, .subject-card .boss-tag {
    margin-top: auto;
    display:inline-flex;
    align-items:center;
    gap: 8px;
    align-self: flex-start;
    padding: 8px 12px;
    border-radius: 12px;
    background: rgba(0,0,0,0.42);
    border: 1px solid rgba(255,107,107,0.18);
    box-shadow: inset 0 0 12px rgba(255,107,107,0.08);
    font-size: 12px;
    color: rgba(255,255,255,0.96);
    font-weight: 800;
}
.subject-card .danger-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--red);
    box-shadow: 0 0 12px var(--red);
    animation: pulse-danger 1.6s infinite;
}
.subject-card.is-locked {
    opacity: 0.92;
    filter: none;
}
.subject-card.is-locked::after {
    content:'';
    position:absolute;
    inset:0;
    background: linear-gradient(180deg, rgba(2,2,5,0.02) 0%, rgba(5,5,8,0.44) 48%, rgba(5,5,8,0.76) 100%);
    z-index:2;
}
.subject-card .card-lock-shell {
    position: absolute;
    inset: auto 16px 16px 16px;
    z-index: 3;
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap: 12px;
    padding: 14px 14px 12px;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(22,22,28,0.72) 0%, rgba(10,10,15,0.92) 100%);
    border: 1px solid rgba(255,200,87,0.18);
    backdrop-filter: blur(8px);
}
.subject-card .lock-copy { display:flex; flex-direction:column; gap:4px; }
.subject-card .lock-badge {
    display:inline-flex;
    align-items:center;
    gap: 6px;
    color: var(--gold);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.4px;
}
.subject-card .lock-desc {
    color: rgba(255,255,255,0.74);
    font-size: 11px;
    line-height: 1.35;
}
.subject-card .lock-arrow {
    color: var(--gold);
    font-size: 18px;
    margin-bottom: 2px;
}
.glass-drawer.drawer-layer {
    height: 38%;
    background: rgba(15, 15, 20, 0.78);
    backdrop-filter: blur(25px) saturate(180%);
    -webkit-backdrop-filter: blur(25px) saturate(180%);
    border-top: 1px solid rgba(255,255,255,0.15);
    border-radius: 36px 36px 0 0;
    padding: 12px 24px var(--safe-bottom);
    box-shadow: inset 0 1px 1px rgba(255,255,255,0.22), 0 -10px 50px rgba(0,0,0,0.6);
}
.drawer-pull-indicator {
    width: 40px;
    height: 4px;
    border-radius: 4px;
    background: rgba(255,255,255,0.24);
    margin: 0 auto 16px;
    flex: 0 0 auto;
}
.glass-drawer .drawer-header {
    margin-bottom: 18px;
    align-items: flex-end;
}
.glass-drawer .drawer-title {
    font-size: 16px;
    font-weight: 800;
    color: rgba(255,255,255,0.92);
}
.sub-grid.tactical-grid {
    position: relative;
    display:block;
    flex: 1 1 auto;
    min-height: 0;
    overflow: visible;
    padding-bottom: 0;
}
.subject-subgrid.tactical-grid {
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    overflow-y:auto;
    overflow-x: visible;
    padding: 8px 4px 28px;
    min-height: 100%;
    max-height: 100%;
    align-content: start;
    contain: layout paint;
    -webkit-overflow-scrolling: touch;
}
.subject-subgrid.tactical-grid[hidden] { display: none !important; }
.sub-chip.tactical-chip, .sub-grid.tactical-grid .sub-chip {
    background: rgba(0,0,0,0.30);
    border: 1px solid rgba(255,255,255,0.05);
    border-radius: 16px;
    padding: 14px 16px;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    gap: 8px;
    position:relative;
    overflow:visible;
    box-shadow: inset 0 2px 4px rgba(255,255,255,0.02), 0 4px 10px rgba(0,0,0,0.2);
    transition: transform .18s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
    contain: layout paint style;
}
.sub-chip.tactical-chip:active { transform: scale(0.97); }
.sub-chip.tactical-chip.selected {
    background: rgba(78,205,196,0.10);
    border-color: rgba(78,205,196,0.88);
    box-shadow: inset 0 2px 10px rgba(78,205,196,0.12), 0 6px 18px rgba(0,0,0,0.34), 0 0 0 1px rgba(78,205,196,0.18), 0 0 22px rgba(78,205,196,0.14);
    transform: translateY(-1px);
}
.sub-chip.tactical-chip.selected .chip-name { color: var(--blue); }
.sub-chip.tactical-chip.is-locked {
    opacity: 1;
    filter: none;
    border-color: rgba(255,200,87,0.12);
    background: rgba(0,0,0,0.34);
}
.sub-chip .chip-top {
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap: 10px;
}
.sub-chip .chip-name {
    font-size: 15px;
    font-weight: 800;
    color: #fff;
}
.sub-chip .status-indicator {
    display:flex;
    align-items:center;
    gap: 6px;
    font-size: 10px;
    font-weight: 700;
    color: #888;
    white-space: nowrap;
}
.sub-chip .pulse-blue {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--blue);
    box-shadow: 0 0 8px var(--blue);
    animation: pulse-core 2s infinite;
}
.sub-chip .micro-progress-container {
    width: 100%;
    height: 4px;
    background: rgba(255,255,255,0.1);
    border-radius: 4px;
    overflow: hidden;
}
.sub-chip .micro-progress-bar {
    height: 100%;
    background: var(--gold);
    border-radius: 4px;
}
.sub-chip .chip-bottom-row {
    display:flex;
    justify-content:space-between;
    align-items:center;
    width:100%;
    font-size: 10px;
    font-family: var(--font-tech);
    font-weight: 700;
    color: #aaa;
    margin-top: 4px;
}
.sub-chip .chip-chevron, .sub-chip .lock-icon {
    color: rgba(255,255,255,0.42);
    font-size: 18px;
    align-self: flex-end;
}
.sub-chip.is-locked .lock-icon { color: var(--gold); }
.sub-chip .lock-help {
    font-size: 11px;
    color: rgba(255,255,255,0.72);
    line-height: 1.35;
}
.pass-banner.focused-offer {
    animation: focusedOfferPulse 1.2s ease-in-out infinite alternate;
    border-color: rgba(255,200,87,0.68);
    box-shadow: 0 0 0 1px rgba(255,200,87,0.22), 0 16px 38px rgba(0,0,0,0.5), 0 0 28px rgba(255,200,87,0.22);
}
@keyframes focusedOfferPulse {
    from { transform: translateY(0); }
    to { transform: translateY(-2px); }
}
@keyframes pulse-danger {
    0%,100% { transform: scale(1); opacity: .65; }
    50% { transform: scale(1.28); opacity: 1; box-shadow: 0 0 14px var(--red); }
}
@media (max-width: 430px) {
    .card-scroller.carousel-stage {
        top: 22.4%;
        height: 36%;
        padding: 0 calc(50vw - 104px);
    }
    .subject-card { flex-basis: 208px; }
    .subject-card .card-icon-stage { min-height: 124px; }
    .subject-card .card-icon-glow { font-size: 68px; }
    .glass-drawer.drawer-layer { height: 39%; padding-left: 18px; padding-right: 18px; }
    .sub-grid.tactical-grid { gap: 12px; }
    .sub-chip .chip-name { font-size: 14px; }
}

@media (max-width: 420px) {
  .top-nav { padding: calc(var(--safe-top) + 10px) 14px 8px; }
  .brand-title { font-size: 20px; letter-spacing: 1.5px; }
  .premium-res-bar { gap: 6px; padding: 5px 9px; }
  .res-item { font-size: 11px; }
  .avatar-btn { width: 36px; height: 36px; }
  .weekly-container { top: calc(var(--safe-top) + 62px); left: 14px; right: 14px; }
  .weekly-vip-card { padding: 13px 14px; }
  .weekly-title { font-size: 14px; }
  .weekly-sub { font-size: 10px; }
  .btn-enter-glow { padding: 7px 12px; font-size: 11px; }
}


.session-resume-card{margin-top:14px;padding:14px 14px 12px;border-radius:18px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);box-shadow:0 10px 30px rgba(0,0,0,.18)}
.session-resume-title{font-size:13px;font-weight:700;letter-spacing:.16em;color:var(--gold);margin-bottom:8px;text-transform:uppercase}
.session-resume-text{font-size:13px;line-height:1.55;color:rgba(255,255,255,.78);margin-bottom:12px}
.session-resume-actions{display:flex;gap:10px;flex-direction:column}
.btn-session-switch{height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.05);color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-session-switch:active{transform:scale(.99)}


.sub-chip .chip-metric-label { color: rgba(255,255,255,0.58); font-size: 10px; font-weight: 700; }
.sub-chip .chip-metric-value { color: #fff; font-size: 11px; font-weight: 900; }
.sub-chip .chip-metric-value.gold { color: var(--gold); }


/* === Integrated Weekly Trial workspace (from uploaded 試煉 page) === */
.feature-entry-pill { min-width: 62px; text-align:center; }
.trial-entry-card {
  position: relative;
  padding: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border-color: rgba(255,255,255,.10);
}
.trial-entry-card::before {
  content: "";
  position: absolute; inset: -25% -15% auto -15%; height: 220px;
  background: radial-gradient(circle at 50% 35%, rgba(255,200,87,.18), transparent 60%);
  pointer-events: none;
}
.trial-entry-top {
  position: relative;
  display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
}
.trial-entry-left { display:flex; gap:12px; align-items:flex-start; min-width:0; }
.trial-entry-badge {
  width: 44px; height: 44px; border-radius: 14px; flex-shrink: 0;
  display:grid; place-items:center;
  background: linear-gradient(145deg, rgba(255,200,87,.24), rgba(255,255,255,.05));
  border:1px solid rgba(255,200,87,.32);
  box-shadow: 0 10px 30px rgba(255,200,87,.14);
}
.trial-entry-meta { min-width:0; }
.trial-entry-title { margin:0 0 4px; font-size:16px; font-weight:900; color:#fff; letter-spacing:.2px; }
.trial-entry-desc { margin:0; font-size:12px; color:rgba(255,255,255,.68); line-height:1.5; }
.trial-entry-cta { position:relative; display:flex; flex-direction:column; align-items:flex-end; gap:8px; flex:0 0 auto; }
.trial-entry-btn { min-width: 132px; }
.trial-state-pill {
  font-size:11px; font-weight:800; padding:6px 10px; border-radius:999px;
  border:1px solid rgba(255,255,255,.10); background: rgba(0,0,0,.22); color: rgba(255,255,255,.84);
}
.trial-state-pill.ok { border-color: rgba(53,208,127,.30); background: rgba(53,208,127,.12); color: rgba(205,255,230,.95); }
.trial-state-pill.lock { border-color: rgba(255,90,106,.30); background: rgba(255,90,106,.12); color: rgba(255,210,215,.95); }
.trial-state-pill.done { border-color: rgba(255,200,87,.28); background: rgba(255,200,87,.12); color: rgba(255,235,195,.95); }
.trial-countdown-box {
  position: relative; margin-top: 14px; padding: 12px 16px; border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08); background: rgba(0,0,0,.25);
  display:flex; align-items:center; justify-content:space-between; gap:10px;
}
.trial-countdown-sub { font-size:11px; margin-top:4px; color:rgba(255,255,255,.56); }
.trial-countdown-time { font-variant-numeric: tabular-nums; font-weight: 900; letter-spacing: 1px; color: #fff; font-size: 15px; }
.trial-rule-tags { position:relative; margin-top:12px; display:flex; flex-wrap:wrap; gap:8px; }
.trial-rule-tag {
  font-size:11px; padding:6px 10px; border-radius:999px; border:1px solid rgba(255,200,87,.18);
  background: rgba(255,200,87,.08); color:#ffe7ad; line-height:1; font-weight:600;
}
.trial-rule-tag strong { color:#fff; font-weight:900; }
.trial-subject-card,
.trial-sub-card {
  text-align:left;
  background: linear-gradient(135deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.035) 100%);
  border:1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  box-shadow: 0 8px 24px rgba(0,0,0,.24);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.trial-subject-card:active,
.trial-sub-card:active { transform: scale(.98); }
.trial-subject-card.active,
.trial-sub-card.active {
  border-color: rgba(126, 232, 255, 0.55);
  box-shadow: 0 0 0 1px rgba(126, 232, 255, 0.35), 0 14px 36px rgba(80, 203, 255, 0.16);
  background: linear-gradient(135deg, rgba(126,232,255,.14), rgba(255,255,255,.06));
}
.trial-subject-card .icon-badge {
  width: 44px; height: 44px; border-radius: 14px;
  background: linear-gradient(145deg, rgba(255,200,87,.22), rgba(255,255,255,.05));
  border:1px solid rgba(255,200,87,.22);
}
.trial-sub-card .top .card-sub-text { color: rgba(255,255,255,.76); }
.trial-rules ul li { line-height: 1.55; }
@media (max-width: 760px) {
  .trial-entry-top { flex-direction: column; }
  .trial-entry-cta { width:100%; align-items:stretch; }
  .trial-entry-btn { width: 100%; min-width: 0; }
}

.feature-primary-btn.disabled { opacity: .56; cursor: not-allowed; box-shadow: none; filter: saturate(.7); }


/* ===== Feature scene: full-screen, no-flash integrated trial screen ===== */
.feature-workspace.feature-scene {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: block;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  background: radial-gradient(1200px 700px at 40% 10%, rgba(241,197,90,.12), transparent 55%), radial-gradient(900px 600px at 82% 28%, rgba(120,120,255,.12), transparent 55%), rgba(11,11,16,.76);
  transition: opacity .22s ease, visibility .22s ease;
}
.feature-workspace.feature-scene[hidden] { display: block !important; }
.feature-workspace.feature-scene.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.feature-scene-backdrop {
  position: absolute;
  inset: 0;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.feature-scene-panel {
  position: absolute;
  inset: 0;
  transform: translate3d(28px,0,0);
  opacity: .98;
  transition: transform .26s cubic-bezier(.2,.8,.2,1), opacity .22s ease;
}
.feature-workspace.feature-scene.is-open .feature-scene-panel {
  transform: translate3d(0,0,0);
  opacity: 1;
}
.feature-scene-safe {
  min-height: 100%;
  padding: max(14px, env(safe-area-inset-top)) 14px max(16px, env(safe-area-inset-bottom));
}
.feature-scene-phone {
  max-width: 460px;
  margin: 0 auto;
  min-height: calc(100vh - max(14px, env(safe-area-inset-top)) - max(16px, env(safe-area-inset-bottom)));
  display: flex;
  flex-direction: column;
}
.feature-scene-appbar {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 10px 0 12px;
  background: linear-gradient(to bottom, rgba(11,11,16,.97), rgba(11,11,16,.8), rgba(11,11,16,0));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.feature-scene-row, .feature-scene-heading-row {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.feature-scene-heading-row { align-items:flex-start; margin-top: 12px; }
.feature-scene-back {
  width: 42px; height: 42px; border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  color: #fff; display:inline-flex; align-items:center; justify-content:center;
  box-shadow: 0 12px 28px rgba(0,0,0,.28);
}
.feature-scene-brand {
  min-width: 0; flex: 1 1 auto; display:flex; align-items:center; gap:10px;
  padding: 10px 12px; border:1px solid rgba(255,255,255,.08); border-radius: 999px; background: rgba(255,255,255,.04);
}
.feature-scene-logo {
  width: 28px; height: 28px; border-radius: 10px;
  background: radial-gradient(circle at 30% 30%, rgba(241,197,90,.85), rgba(241,197,90,.18) 55%, rgba(255,255,255,.06) 100%);
  border: 1px solid rgba(241,197,90,.25);
  box-shadow: 0 8px 22px rgba(241,197,90,.14);
}
.feature-scene-brand-title { font-size:14px; font-weight:800; color:#fff; letter-spacing:.2px; }
.feature-scene-brand-sub { font-size:12px; color:rgba(255,255,255,.55); }
.feature-scene-tabs { display:flex; align-items:center; gap:8px; }
.feature-dock-btn.compact {
  width: 44px; height: 44px; padding: 0; border-radius: 14px; gap: 0;
}
.feature-dock-btn.compact .feature-dock-label { display:none; }
.feature-scene-scroll {
  flex: 1 1 auto; overflow-y: auto; min-height: 0; padding: 4px 0 14px;
}
.feature-scene-scroll::-webkit-scrollbar { display:none; }
.feature-page { padding-right: 0; }
.trial-cycle-chip {
  padding:8px 10px; border-radius:999px; border:1px solid rgba(241,197,90,.22); background: rgba(241,197,90,.10); color:#ffe7ad; font-size:12px; font-weight:700; white-space:nowrap;
}
.trial-scene-card {
  position: relative; padding: 16px; background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04)); overflow: hidden;
}
.trial-scene-card::before {
  content: ""; position:absolute; inset:-30% -20% auto -20%; height:220px; background: radial-gradient(circle at 50% 40%, rgba(241,197,90,.18), transparent 60%); pointer-events:none;
}
.trial-scene-top, .trial-scene-left { display:flex; align-items:flex-start; gap:12px; }
.trial-scene-top { justify-content:space-between; }
.trial-scene-left { min-width:0; }
.trial-scene-badge {
  width:44px; height:44px; border-radius:14px; flex-shrink:0; display:grid; place-items:center;
  background: linear-gradient(145deg, rgba(241,197,90,.23), rgba(255,255,255,.05));
  border:1px solid rgba(241,197,90,.28); box-shadow: 0 10px 30px rgba(241,197,90,.12);
}
.trial-scene-meta { min-width:0; }
.trial-scene-title { margin:0 0 4px; font-weight:900; font-size:16px; letter-spacing:.2px; color:#fff; }
.trial-scene-desc { margin:0; font-size:12px; line-height:1.45; color: rgba(255,255,255,.68); }
.trial-scene-cta { display:flex; flex-direction:column; align-items:flex-end; gap:8px; flex:0 0 auto; }
.trial-scene-btn { min-width: 132px; }
.trial-scene-countdown {
  position:relative; margin-top:14px; padding:12px 16px; border-radius:14px; border:1px solid rgba(255,255,255,.08); background: rgba(0,0,0,.25); display:flex; align-items:center; justify-content:space-between; gap:10px;
}
.trial-countdown-label { font-size:12px; color: rgba(255,255,255,.62); font-weight:700; }
.trial-countdown-sub { margin-top:4px; font-size:11px; color: rgba(255,255,255,.5); }
.trial-countdown-time { font-variant-numeric: tabular-nums; font-weight:900; letter-spacing:1px; color:#fff; font-size: 15px; }
.trial-scene-rules { margin-top:12px; display:flex; flex-wrap:wrap; gap:8px; }
.trial-rule-tag {
  font-size:11px; padding:6px 10px; border-radius:999px; border:1px solid rgba(241,197,90,.18); background: rgba(241,197,90,.08); color:#ffe7ad; line-height:1; font-weight:600;
}
.trial-rule-tag strong { color:#fff; font-weight:900; }
.trial-scene-section { margin-top:16px; }
.feature-plain-section, .trial-rules-block { padding:16px; }
.trial-scene-section-title { margin:0 0 12px; display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.trial-scene-section-title h2 { margin:0; font-size:16px; color:#fff; font-weight:800; }
.trial-scene-section-title .sub { font-size:12px; color: var(--gold); font-weight:700; }
.trial-scene-meta-grid {
  margin-top:16px; display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:12px;
}
.trial-rules-list { margin:0; padding-left:18px; display:grid; gap:8px; color:rgba(255,255,255,.76); }
.compact-toolbar { padding: 12px 14px; margin-bottom: 12px; }
@media (max-width: 680px) {
  .feature-scene-tabs { gap: 6px; }
  .trial-scene-top { flex-direction: column; }
  .trial-scene-cta { width:100%; align-items:stretch; }
  .trial-scene-btn { width:100%; min-width:0; }
  .trial-scene-meta-grid { grid-template-columns: 1fr; }
}


/* === uploaded trial page integration === */
.trial-uploaded-page{
      --bg:#0b0b10;
      --card:rgba(255,255,255,.06);
      --stroke:rgba(255,255,255,.10);
      --text:#eaeaf2;
      --muted:#a7a9b8;
      --gold:#f1c55a;
      --shadow:0 18px 60px rgba(0,0,0,.55);
      --radius:18px;
    }.trial-uploaded-page *{box-sizing:border-box; -webkit-tap-highlight-color: transparent;}.trial-uploaded-page{
      margin:0;
      background: radial-gradient(1200px 700px at 40% 10%, rgba(241,197,90,.12), transparent 55%),
                  radial-gradient(900px 600px at 80% 30%, rgba(120,120,255,.12), transparent 55%),
                  var(--bg);
      color:var(--text);
      font-family: system-ui, -apple-system, "Noto Sans TC", "PingFang TC", Segoe UI, Roboto, Arial, sans-serif;
    }.trial-uploaded-page .safe{
      padding: max(14px, env(safe-area-inset-top)) 14px 14px;
      min-height: 100vh;
      display:flex; justify-content:center;
    }.trial-uploaded-page .phone{ width:min(420px, 100%); padding-bottom: max(16px, env(safe-area-inset-bottom)); position: relative;}.trial-uploaded-page /* App bar */
    .appbar{
      position:sticky; top:0; z-index:20;
      padding:10px 0 10px;
      background: linear-gradient(to bottom, rgba(11,11,16,.95), rgba(11,11,16,.55), rgba(11,11,16,0));
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
    }.trial-uploaded-page .appbar .row{ display:flex; align-items:center; justify-content:space-between; gap:10px; width: 100%; }.trial-uploaded-page .brand{
      display:flex; align-items:center; gap:10px;
      padding:10px 12px;
      border:1px solid rgba(255,255,255,.08);
      background: rgba(255,255,255,.04);
      border-radius: 999px;
    }.trial-uploaded-page .logo{
      width:28px; height:28px; border-radius:10px;
      background: radial-gradient(circle at 30% 30%, rgba(241,197,90,.85), rgba(241,197,90,.18) 55%, rgba(255,255,255,.06) 100%);
      border: 1px solid rgba(241,197,90,.25);
      box-shadow: 0 8px 22px rgba(241,197,90,.14);
    }.trial-uploaded-page .brand .t1{font-weight:800; letter-spacing:.2px; font-size:14px}.trial-uploaded-page .brand .t2{font-size:12px; color:var(--muted)}.trial-uploaded-page .chip{
      padding:8px 10px;
      border-radius:999px;
      border:1px solid rgba(241,197,90,.22);
      background: rgba(241,197,90,.10);
      color:#ffe7ad;
      font-size:12px;
      font-weight: 700;
      white-space:nowrap;
    }.trial-uploaded-page /* Card base */
    .glass{
      width: 100%;
      background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04));
      border:1px solid rgba(255,255,255,.10);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      overflow:hidden;
    }.trial-uploaded-page .section-title{
      margin:24px 4px 14px;
      display:flex; align-items:baseline; justify-content:space-between;
      gap:10px;
    }.trial-uploaded-page .section-title h2{ margin:0; font-size:16px; color: rgba(255,255,255,.95); letter-spacing:.5px; font-weight: 800; }.trial-uploaded-page .section-title .sub{ font-size:12px; color:var(--gold); font-weight: 700; }.trial-uploaded-page /* Trial card */
    .trial{ position:relative; padding:16px; }.trial-uploaded-page .trial::before{
      content:"";
      position:absolute; inset:-30% -20% auto -20%;
      height:220px;
      background: radial-gradient(circle at 50% 40%, rgba(241,197,90,.18), transparent 60%);
      pointer-events:none;
    }.trial-uploaded-page .trial .top{ position:relative; display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }.trial-uploaded-page .trial .left{ display:flex; gap:12px; align-items:flex-start; min-width:0; }.trial-uploaded-page .badge{
      width:44px; height:44px; border-radius:14px;
      background: linear-gradient(145deg, rgba(241,197,90,.23), rgba(255,255,255,.05));
      border:1px solid rgba(241,197,90,.28);
      box-shadow: 0 10px 30px rgba(241,197,90,.12);
      display:grid; place-items:center; flex-shrink: 0;
    }.trial-uploaded-page .trial .meta{ min-width:0; }.trial-uploaded-page .trial .meta .title{ font-weight:900; font-size:16px; letter-spacing:.2px; margin:0 0 4px; color:#fff; }.trial-uploaded-page .trial .meta .desc{ margin:0; font-size:12px; color:var(--muted); line-height:1.4; }.trial-uploaded-page .trial .cta{ position:relative; display:flex; flex-direction:column; align-items:flex-end; gap:8px; flex:0 0 auto; }.trial-uploaded-page .btn{
      border:1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.06);
      color: var(--text);
      padding:10px 14px;
      border-radius: 12px;
      font-weight:800;
      font-size:13px;
      letter-spacing:.2px;
      cursor:pointer;
      user-select:none;
      transition: all .15s ease;
      white-space:nowrap;
      outline: none;
    }.trial-uploaded-page .btn:active{transform: scale(.96); filter: brightness(1.1);}.trial-uploaded-page .btn.primary{
      border-color: rgba(241,197,90,.30);
      background: linear-gradient(180deg, rgba(241,197,90,.22), rgba(241,197,90,.08));
      color:#ffeec4;
      box-shadow: 0 4px 15px rgba(241,197,90,.15);
    }.trial-uploaded-page .btn.disabled{ opacity:.55; cursor:not-allowed; box-shadow: none; }.trial-uploaded-page .pill{
      font-size:11px; font-weight: 800;
      padding:6px 10px;
      border-radius:999px;
      border:1px solid rgba(255,255,255,.10);
      background: rgba(0,0,0,.22);
      color: rgba(255,255,255,.84);
      white-space:nowrap;
    }.trial-uploaded-page .pill.ok{border-color: rgba(53,208,127,.3); background: rgba(53,208,127,.12); color: rgba(205,255,230,.95)}.trial-uploaded-page .pill.lock{border-color: rgba(255,90,106,.3); background: rgba(255,90,106,.12); color: rgba(255,210,215,.95)}.trial-uploaded-page .pill.done{border-color: rgba(241,197,90,.3); background: rgba(241,197,90,.12); color: rgba(255,232,190,.95)}.trial-uploaded-page .countdown{
      position:relative;
      margin-top:14px;
      padding:12px 16px;
      border-radius: 14px;
      border:1px solid rgba(255,255,255,.08);
      background: rgba(0,0,0,.25);
      display:flex; align-items:center; justify-content:space-between; gap:10px;
    }.trial-uploaded-page .countdown .label{font-size:12px; color:var(--muted); font-weight: 700;}.trial-uploaded-page .countdown .time{ font-variant-numeric: tabular-nums; font-weight:900; letter-spacing:1px; color:#fff; font-size: 15px;}.trial-uploaded-page .rules{ position:relative; margin-top:12px; display:flex; flex-wrap:wrap; gap:8px; }.trial-uploaded-page .ruleTag{
      font-size:11px; padding:6px 10px; border-radius: 999px;
      border:1px solid rgba(241,197,90,.18);
      background: rgba(241,197,90,.08);
      color:#ffe7ad; line-height:1; font-weight: 600;
    }.trial-uploaded-page .ruleTag strong{color:#fff; font-weight:900}.trial-uploaded-page /* Subjects */
    .subjects{ padding:0; background: transparent; border: none; box-shadow: none; width: 100%; min-width: 0; }.trial-uploaded-page /* 防破圖核心：minmax(0, .trial-uploaded-page 1fr) 鎖死最大寬度 */
    .grid{ display:grid; grid-template-columns: minmax(0, 1fr); gap:12px; width: 100%; min-width: 0; }.trial-uploaded-page .subcard{
      width: 100%; min-width: 0; /* 防破圖：允許內部元件收縮 */
      display:flex; align-items:center; gap:12px;
      padding:16px; border-radius: 20px;
      /* 高階色彩美化：渲染科目專屬動態色光 */
      border: 1px solid rgba(var(--c-rgb), 0.25);
      background: linear-gradient(135deg, rgba(255,255,255,.04) 0%, rgba(var(--c-rgb), 0.12) 100%);
      cursor:pointer; transition: all 0.25s cubic-bezier(0.2, 0.8, 0.2, 1);
      box-shadow: 0 6px 20px rgba(0,0,0,0.25);
    }.trial-uploaded-page .subcard:active{ 
    transform: scale(0.97); 
      background: linear-gradient(135deg, rgba(255,255,255,.05) 0%, rgba(var(--c-rgb), 0.18) 100%); 
      border-color: rgba(var(--c-rgb), 0.4);
    }.trial-uploaded-page /* 防破圖核心：min-width: 0 確保文字過長時自動截斷 */
    .subleft{ display:flex; align-items:center; gap:14px; flex: 1; min-width:0; overflow: hidden; }.trial-uploaded-page .icon{
      width:48px; height:48px; border-radius: 14px;
      border:1px solid rgba(var(--c-rgb), 0.4);
      background: rgba(var(--c-rgb), 0.15);
      color: rgb(var(--c-rgb));
      display:grid; place-items:center;
      font-weight:900; font-size: 18px;
      flex-shrink: 0; box-shadow: 0 4px 12px rgba(var(--c-rgb), 0.25);
    }.trial-uploaded-page .submeta{ flex: 1; min-width:0; overflow: hidden; display: flex; flex-direction: column; justify-content: center; }.trial-uploaded-page .submeta .name{ 
      font-weight:800; margin:0 0 4px; font-size: 16px; color:#fff; letter-spacing: 0.5px;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }.trial-uploaded-page .submeta .hint{ 
      margin:0; color:rgba(255,255,255,0.65); font-size:12px; 
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }.trial-uploaded-page /* 防破圖核心：flex-shrink: 0 保障右側元件永遠完整顯示 */
    .subright{ display:flex; align-items:center; gap:8px; flex-shrink: 0; white-space: nowrap; }.trial-uploaded-page .mini{
      font-size:12px; color:rgb(var(--c-rgb)); font-weight: 800;
      border:1px solid rgba(var(--c-rgb), 0.3);
      background: rgba(var(--c-rgb), 0.15);
      padding:6px 10px; border-radius: 10px;
      white-space:nowrap;
    }.trial-uploaded-page .arrow{
      width:28px; height:28px; border-radius: 10px;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.08);
      display:grid; place-items:center;
      color: #fff; font-size: 16px; font-weight: 800;
      flex-shrink: 0;
    }.trial-uploaded-page /* Demo controls */
    .demo{
      margin-top:14px;
      padding:12px 14px;
      border-radius: 16px;
      border:1px dashed rgba(255,255,255,.15);
      background: rgba(0,0,0,.2);
    }.trial-uploaded-page .demo .row{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; justify-content:space-between; }.trial-uploaded-page .demo .left{ display:flex; gap:8px; flex-wrap:wrap; }.trial-uploaded-page .demo small{color:var(--muted); font-size: 11px;}.trial-uploaded-page .btn.small{padding:8px 12px; font-size:11px; border-radius: 10px;}.trial-uploaded-page .foot{ margin:20px 0 10px; color: rgba(255,255,255,.4); font-size:12px; text-align:center; font-weight: 600;}.trial-uploaded-page /* Custom Beautiful Modal UI */
    .modal-overlay{
      position: fixed; inset: 0; z-index: 100;
      background: rgba(0,0,0,0.65); 
      backdrop-filter: blur(8px);
      -webkit-backdrop-filter: blur(8px);
      display: flex; justify-content: center; align-items: center;
      opacity: 0; pointer-events: none; transition: opacity 0.3s ease;
    }.trial-uploaded-page .modal-overlay.active{ opacity: 1; pointer-events: auto; }.trial-uploaded-page .modal-card{
      width: min(340px, 88%);
      background: linear-gradient(160deg, rgba(30,30,35,0.95), rgba(15,15,20,0.98));
      border: 1px solid rgba(241,197,90,0.25);
      border-radius: 24px;
      padding: 28px 24px;
      text-align: center;
      box-shadow: 0 30px 60px rgba(0,0,0,0.7), inset 0 1px 0 rgba(255,255,255,0.1);
      transform: translateY(20px) scale(0.95);
      transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
    }.trial-uploaded-page .modal-overlay.active .modal-card{
      transform: translateY(0) scale(1);
    }.trial-uploaded-page .modal-icon{
      width: 54px; height: 54px; margin: 0 auto 16px;
      border-radius: 16px; 
      background: linear-gradient(135deg, rgba(241,197,90,0.2), rgba(241,197,90,0.05));
      border: 1px solid rgba(241,197,90,0.4);
      display: flex; justify-content: center; align-items: center;
      color: var(--gold); font-size: 26px;
      box-shadow: 0 8px 20px rgba(241,197,90,0.15);
    }.trial-uploaded-page .modal-title{ margin: 0 0 10px; font-size: 18px; font-weight: 900; color: #fff; letter-spacing: 0.5px; }.trial-uploaded-page .modal-desc{ margin: 0 0 24px; font-size: 14px; color: rgba(255,255,255,0.75); line-height: 1.6; font-weight: 500;}.trial-uploaded-page .modal-btn{ width: 100%; padding: 14px; font-size: 15px; border-radius: 14px; letter-spacing: 1px;}
  

.feature-workspace.trial-shell-mode .feature-scene-appbar {
  display: none;
}
.feature-workspace.trial-shell-mode .feature-scene-brand,
.feature-workspace.trial-shell-mode .feature-scene-heading-row {
  display: none;
}
.feature-workspace.trial-shell-mode .feature-scene-row {
  gap: 8px;
  justify-content: flex-end;
}
.feature-workspace.trial-shell-mode .feature-scene-tabs {
  display: flex;
  align-items: center;
  gap: 8px;
}
.feature-workspace.trial-shell-mode .feature-scene-back {
  width: 42px;
  height: 42px;
}
.feature-workspace.trial-shell-mode .feature-scene-scroll {
  padding-top: 0;
}
.trial-uploaded-page {
  width: 100%;
  min-height: 100%;
}
.trial-uploaded-page .safe {
  padding: 0;
  min-height: auto;
  display: block;
}
.trial-uploaded-page .phone {
  width: min(420px, 100%);
  margin: 0 auto;
  padding-bottom: 0;
  position: relative;
}
.trial-uploaded-page .appbar {
  position: sticky;
  top: 0;
  z-index: 3;
}
.trial-uploaded-page .demo {
  display: none;
}
.trial-uploaded-page .subcard.active {
  border-color: rgba(var(--c-rgb), 0.55);
  background: linear-gradient(135deg, rgba(255,255,255,.06) 0%, rgba(var(--c-rgb), 0.22) 100%);
  box-shadow: 0 10px 26px rgba(var(--c-rgb), 0.22);
}
.trial-uploaded-page .modal-btn.secondary {
  margin-top: 10px;
  background: rgba(255,255,255,.06);
  color: var(--text);
  border-color: rgba(255,255,255,.12);
}
.trial-uploaded-page .modal-actions {
  display:flex;
  flex-direction:column;
  gap:10px;
}


/* v6.2.0 merged subject expansion + trial health id fix */
.trial-uploaded-page .trial-head-row{
  align-items:center;
  gap:12px;
  padding-inline: 2px;
}
.trial-uploaded-page .trial-head-title-pill{
  min-width:0;
  flex:1 1 auto;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  padding:0;
  border:none;
  background:transparent;
  box-shadow:none;
}
.trial-uploaded-page .trial-head-title{
  font-size:22px;
  font-weight:950;
  letter-spacing:.8px;
  color:#fff6d8;
  text-shadow: 0 2px 16px rgba(241,197,90,.18), 0 1px 0 rgba(255,255,255,.08);
}
.trial-uploaded-page .trial-head-back,
.trial-uploaded-page .trial-head-icon{
  position:relative;
  width:50px;
  height:50px;
  border:none;
  border-radius:18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.05)),
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.18), transparent 42%),
    linear-gradient(135deg, rgba(33,36,53,.92), rgba(17,19,29,.86));
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.18),
    inset 0 -1px 0 rgba(255,255,255,.05),
    0 14px 28px rgba(0,0,0,.30),
    0 0 0 1px rgba(255,255,255,.06);
  backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.trial-uploaded-page .trial-head-back::before,
.trial-uploaded-page .trial-head-icon::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:17px;
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,0));
  pointer-events:none;
}
.trial-uploaded-page .trial-head-back{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.18),
    inset 0 -1px 0 rgba(255,255,255,.05),
    0 16px 30px rgba(0,0,0,.32),
    0 0 0 1px rgba(241,197,90,.16),
    0 0 22px rgba(241,197,90,.12);
}
.trial-uploaded-page .trial-head-icon{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.18),
    inset 0 -1px 0 rgba(255,255,255,.05),
    0 14px 28px rgba(0,0,0,.30),
    0 0 0 1px rgba(106,186,255,.10),
    0 0 18px rgba(106,186,255,.08);
}
.trial-uploaded-page .trial-head-back:hover,
.trial-uploaded-page .trial-head-icon:hover{
  transform: translateY(-1px);
  filter: brightness(1.06);
}
.trial-uploaded-page .trial-head-back:active,
.trial-uploaded-page .trial-head-icon:active{
  transform: translateY(1px) scale(.98);
}
.trial-uploaded-page .trial-head-back i,
.trial-uploaded-page .trial-head-icon i{
  font-size:23px;
  text-shadow: 0 1px 8px rgba(0,0,0,.28);
}
.trial-uploaded-page .section-title{
  margin:22px 4px 12px;
}
.trial-uploaded-page .subjects{
  width:100%;
  min-width:0;
  max-height: clamp(320px, 48vh, 560px);
  overflow:auto;
  padding: 2px 4px 10px 0;
  scrollbar-width: thin;
  scrollbar-color: rgba(241,197,90,.28) rgba(255,255,255,.05);
  mask-image: linear-gradient(to bottom, transparent 0, #000 14px, #000 calc(100% - 24px), transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0, #000 14px, #000 calc(100% - 24px), transparent 100%);
}
.trial-uploaded-page .subjects::-webkit-scrollbar{ width: 6px; }
.trial-uploaded-page .subjects::-webkit-scrollbar-track{ background: rgba(255,255,255,.04); border-radius: 999px; }
.trial-uploaded-page .subjects::-webkit-scrollbar-thumb{ background: rgba(241,197,90,.28); border-radius: 999px; }
.trial-uploaded-page .grid{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:12px;
  width:100%;
  min-width:0;
  padding: 4px 2px 16px;
}
.trial-uploaded-page .subcard{
  min-height: 84px;
  padding:14px 15px;
  border-radius:20px;
}
.trial-uploaded-page .icon{
  width:46px;
  height:46px;
  border-radius:15px;
}
.trial-uploaded-page .submeta .name{
  font-size:15px;
}
.trial-uploaded-page .submeta .hint{
  white-space:normal;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  line-height:1.35;
  max-height: calc(1.35em * 2);
}
.trial-uploaded-page .mini{
  font-size:11px;
  padding:6px 9px;
}
@media (min-width: 900px){
  .trial-uploaded-page .subjects{
    max-height: clamp(360px, 50vh, 640px);
  }
  .trial-uploaded-page .grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 430px){
  .trial-uploaded-page .trial-head-row{ gap:8px; }
  .trial-uploaded-page .trial-head-back,
  .trial-uploaded-page .trial-head-icon{ width:46px; height:46px; border-radius:16px; }
  .trial-uploaded-page .trial-head-title{ font-size:20px; letter-spacing:.5px; }
  .trial-uploaded-page .subjects{ max-height: clamp(300px, 46vh, 520px); }
}
.trial-intro-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(5,10,20,.58);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .28s ease;z-index:1800;}
.trial-intro-overlay.active{opacity:1;pointer-events:auto;}
.trial-intro-card{min-width:220px;padding:22px 24px;border-radius:28px;background:linear-gradient(180deg, rgba(18,26,44,.86), rgba(10,14,24,.9));border:1px solid rgba(255,255,255,.10);box-shadow:0 24px 60px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.08);display:flex;flex-direction:column;align-items:center;gap:8px;color:#fff;}
.trial-intro-eyebrow{font-size:11px;letter-spacing:1.4px;color:rgba(245,214,126,.86);font-weight:700;}
.trial-intro-value{font-size:72px;line-height:1;font-weight:900;color:#fff;text-shadow:0 10px 36px rgba(255,255,255,.16);}
.trial-intro-sub{font-size:14px;color:rgba(255,255,255,.76);}
.trial-uploaded-page .modal-overlay{will-change:opacity;backface-visibility:hidden;}
.trial-uploaded-page .modal-card{will-change:transform, opacity;backface-visibility:hidden;}


@keyframes comboPulse { 0% { transform: scale(1); } 35% { transform: scale(1.06); } 100% { transform: scale(1); } }
@keyframes comboHintFade { 0% { opacity:0; transform: translateY(4px) scale(0.92); } 15% { opacity:1; transform: translateY(0) scale(1); } 100% { opacity:0; transform: translateY(-2px) scale(0.96); } }
@keyframes comboGlowFade { 0% { box-shadow:0 8px 20px rgba(0,0,0,0.25), 0 0 0 rgba(255,200,87,0); } 15% { box-shadow:0 8px 20px rgba(0,0,0,0.25), 0 0 18px rgba(255,200,87,0.45); } 100% { box-shadow:0 8px 20px rgba(0,0,0,0.25), 0 0 0 rgba(255,200,87,0); } }
.settlement-extra-grid { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin:-6px 0 20px; }
.settlement-extra-item { background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius: 14px; padding: 10px 12px; display:flex; flex-direction:column; gap:4px; text-align:left; }
.extra-label { font-size:10px; color: rgba(255,255,255,0.56); font-weight:800; letter-spacing:0.08em; }
.extra-val { font-size:13px; color:#fff; font-weight:800; }
.levelup-card{ position:fixed; left:50%; bottom: calc(var(--safe-bottom) + 88px); transform: translateX(-50%); width:min(92vw, 420px); z-index:205; background: linear-gradient(180deg, rgba(24,24,34,0.96), rgba(12,12,18,0.96)); border:1px solid rgba(255,255,255,0.12); box-shadow:0 18px 36px rgba(0,0,0,0.45); border-radius:24px; padding:14px 14px 12px; }
.levelup-card.hidden{ display:none; }
.levelup-card-header{ display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.levelup-title{ font-size:18px; font-weight:900; color:#fff; }
.levelup-close{ width:34px; height:34px; border-radius:50%; border:1px solid rgba(255,255,255,0.14); background:rgba(255,255,255,0.06); color:#fff; cursor:pointer; }
.levelup-meta{ display:flex; gap:10px; justify-content:space-between; margin-bottom:10px; }
.levelup-meta-item{ flex:1 1 0; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius:14px; padding:8px 10px; }
.meta-label{ font-size:10px; color:rgba(255,255,255,0.55); font-weight:800; letter-spacing:0.08em; }
.meta-value{ font-size:15px; color:#fff; font-weight:900; margin-top:4px; }
.levelup-grid{ display:flex; flex-direction:column; gap:8px; }
.lu-row{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:10px; border-radius:14px; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); }
.lu-left{ display:flex; flex-direction:column; gap:4px; min-width:0; }
.lu-stat{ color:var(--gold); font-weight:900; font-size:13px; letter-spacing:0.05em; }
.lu-desc{ color:rgba(255,255,255,0.68); font-size:11px; }
.lu-right{ display:flex; align-items:center; gap:8px; }
.lu-btn{ width:32px; height:32px; border-radius:10px; border:1px solid rgba(255,255,255,0.12); background:rgba(255,255,255,0.06); color:#fff; font-size:18px; font-weight:900; cursor:pointer; }
.lu-btn[disabled]{ opacity:0.45; pointer-events:none; }
.lu-val{ width:48px; text-align:center; color:#fff; font-weight:900; font-size:14px; }
.lu-readonly{ width:auto; min-width:56px; padding:0 8px; color:var(--gold); }
.levelup-actions{ display:flex; gap:10px; justify-content:flex-end; margin-top:10px; }
.levelup-secondary,.levelup-primary{ min-width:96px; height:40px; border-radius:12px; border:none; font-weight:800; cursor:pointer; }
.levelup-secondary{ background:rgba(255,255,255,0.08); color:#fff; border:1px solid rgba(255,255,255,0.12); }
.levelup-primary{ background:linear-gradient(135deg, var(--gold), #e6b33e); color:#000; }
@media (max-width: 640px) {
  .score-board { left: 12px; right: 12px; top: calc(var(--safe-top) + 8px); font-size: 16px; }
  .combo-group { min-width: 92px; padding: 5px 9px; }
  .combo-value { font-size: 10px; }
  .boss-stage { height: 36%; }
  .boss-hud { width: calc(100% - 24px); margin-top: 44px; padding: 9px 10px 8px; }
  .boss-name-text { font-size: 13px; }
  .boss-defense-row { gap:5px; }
  .player-hud { padding: 10px 12px calc(var(--safe-bottom) + 10px); }
  .hud-block { padding: 9px 6px !important; }
  .settlement-extra-grid { grid-template-columns: 1fr 1fr; }
  .levelup-card { width: calc(100vw - 20px); bottom: calc(var(--safe-bottom) + 76px); }
}

@media (max-width: 640px) and (max-height: 780px) {
  .boss-stage { height: 34%; }
  .boss-hud { margin-top: 42px; }
  .boss-entity { font-size: 52px; }
  .dialogue-box { min-height: 84px; padding: 12px 16px; }
  .options-stage { top: 45%; bottom: 24%; }
  .opt-btn { min-height: 52px; }
}
