﻿/*
 * =========================================================================
 * 檔案名稱：CaishenOracle.css
 * 系統版本：V0.36 (3D金幣卜卦升級版)
 * 作者宣告：五元網站包租公-Tiger老師 (台灣老站神)
 * 系統說明：五路財神線上抽籤卜卦 (純前端淨化基底版 - 教科書等級註解)
 * 重點說明：
 * 1. 完整保留所有動畫與 RWD 設定，絕對不壓縮任何程式碼。
 * 2. 採用 CSS 變數實作五套主題色系秒切換陣法。
 * 3. 嚴格執行 3 個空白字元的內縮規範，確保教科書等級的排版。
 * 4. 針對 SEO、AEO、GEO 佈局保留語意化與友善的 RWD 響應式空間。
 * 5. 整合行動版摺疊解盤與圖卡完美 RWD 雙欄陣法。
 * 6. 徹底拔除舊有銅錢擲杯，升級為 3D 虛擬金幣投擲陣法。
 * =========================================================================
 */

/* =========================================================================
 * 【一、系統全域變數與多主題色系定義 (CSS Variables)】
 * 說明：利用 :root 宣告預設變數，並透過 body[data-theme="..."] 來覆寫變數，
 * 達到不需修改個別 Class 就能全站一鍵換色的「變色龍陣法」。
 * ========================================================================= */

/* 預設主題：關帝赤紅 (符合天上聖母的忠義火紅) */
:root {
   /* 網頁極深色背景，營造科技武俠感的底層空間 */
   --bg-main: #0a0505;          
   /* 主色調：充滿爆發力的科技紅 */
   --primary: #ff1a1a;          
   /* 主色調的 RGB 數值，專門用於設定 rgba 透明度發光特效 */
   --primary-rgb: 255, 26, 26;  
   /* 點綴色：武財神金，用於強調重點與按鈕視覺焦點 */
   --accent: #ffd700;           
   /* 點綴色的 RGB 數值，用於陰影與外發光透明度 */
   --accent-rgb: 255, 215, 0;   
   /* 玻璃擬態 (Glassmorphism) 的半透明背景，提供層次感 */
   --glass-bg: rgba(20, 10, 10, 0.75);     
   /* 玻璃擬態的半透明邊框，讓區塊邊緣帶有微光 */
   --glass-border: rgba(255, 26, 26, 0.3); 
   /* 警告與凶險提示的專用紅色 (如：叮嚀事項的紅字) */
   --danger: #ff4444;           
}

/* 主題二：科技青藍 (Cyber-Wuxia 駭客任務風) */
body[data-theme="cyan"] {
   --bg-main: #050a10;
   --primary: #00ffff;          
   --primary-rgb: 0, 255, 255;
   --accent: #ffd700;
   --accent-rgb: 255, 215, 0;
   --glass-bg: rgba(5, 10, 16, 0.75);
   --glass-border: rgba(0, 255, 255, 0.3);
}

/* 主題三：武財神金 (求財祈福專用) */
body[data-theme="wealth-gold"] {
   --bg-main: #141100;
   --primary: #ffcc00;          
   --primary-rgb: 255, 204, 0;
   --accent: #ff0033;           
   --accent-rgb: 255, 0, 51;
   --glass-bg: rgba(20, 17, 0, 0.75);
   --glass-border: rgba(255, 204, 0, 0.3);
}

/* 主題四：紫氣東來 (宮廟神聖莊嚴風 - 系統預設) */
body[data-theme="temple-purple"] {
   --bg-main: #12051a;
   --primary: #b266ff;          
   --primary-rgb: 178, 102, 255;
   --accent: #ffd700;
   --accent-rgb: 255, 215, 0;
   --glass-bg: rgba(18, 5, 26, 0.75);
   --glass-border: rgba(178, 102, 255, 0.3);
}

/* 主題五：翡翠靈玉 (寧靜自然風) */
body[data-theme="jade-green"] {
   --bg-main: #05120a;
   --primary: #00e676;          
   --primary-rgb: 0, 230, 118;
   --accent: #ffd700;
   --accent-rgb: 255, 215, 0;
   --glass-bg: rgba(5, 18, 10, 0.75);
   --glass-border: rgba(0, 230, 118, 0.3);
}

/* =========================================================================
 * 【二、全域重置與基礎佈局 (Global Reset & Base Layout)】
 * ========================================================================= */
* {
   box-sizing: border-box; 
   margin: 0;              
   padding: 0;             
}

body {
   background-color: var(--bg-main); 
   font-family: "Microsoft JhengHei", "PingFang TC", sans-serif; 
   color: #ffffff;                   
   overflow-x: hidden;               
   background-image: radial-gradient(circle at center top, rgba(var(--primary-rgb), 0.15) 0%, var(--bg-main) 70%);
}

.main-container {
   max-width: 1000px;                
   margin: 40px auto 20px auto;      
   padding: 0 15px;                  
}

/* =========================================================================
 * 【三、玻璃擬態面板模組 (Glassmorphism UI)】
 * ========================================================================= */
.glass-panel {
   background: var(--glass-bg);      
   border: 1px solid var(--glass-border); 
   border-radius: 8px;               
   padding: 25px;                    
   margin-bottom: 10px;              
   box-shadow: 0 4px 15px rgba(0, 0, 0, 0.5), inset 0 0 10px rgba(var(--primary-rgb), 0.1); 
   backdrop-filter: blur(5px);       
}

/* =========================================================================
 * 【四、右上角下拉導覽列與選單 (Navigation & Dropdown)】
 * ========================================================================= */
.top-right-nav {
   position: absolute; 
   top: 15px;          
   right: 15px;        
   z-index: 1000;      
}

.menu-toggle-btn {
   background: rgba(var(--primary-rgb), 0.1); 
   color: var(--primary); 
   border: 1px solid var(--primary); 
   padding: 10px 15px; 
   border-radius: 4px; 
   cursor: pointer;          
   font-size: 1rem; 
   font-weight: bold; 
   transition: all 0.3s ease; 
   box-shadow: 0 0 10px rgba(var(--primary-rgb), 0.3); 
   display: flex;            
   align-items: center;      
   gap: 8px;                 
   white-space: nowrap;      
}

.menu-toggle-btn:hover {
   background: var(--primary); 
   color: #000;                
}

.dropdown-list {
   visibility: hidden;         
   opacity: 0;                 
   position: absolute;         
   right: 0;                   
   top: 120%;                  
   background: rgba(10, 5, 5, 0.95); 
   border: 1px solid var(--primary); 
   border-radius: 4px; 
   list-style: none;           
   min-width: 240px;           
   box-shadow: 0 5px 20px rgba(0, 0, 0, 0.8); 
   transform: translateY(-15px); 
   transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55); 
}

.dropdown-list.show {
   visibility: visible; 
   opacity: 1; 
   transform: translateY(0); 
}

.dropdown-list li a {
   color: #ddd;
   font-size: 15px; 
   text-decoration: none;    
   display: block;           
   padding: 15px 18px; 
   border-bottom: 1px dashed rgba(var(--primary-rgb), 0.3); 
   transition: 0.3s; 
}

.dropdown-list li a:hover {
   color: var(--accent); 
   background: rgba(var(--accent-rgb), 0.1); 
   padding-left: 25px;
   padding-right: 15px;       
}

/* =========================================================================
 * 【五、左側懸浮選單 (Floating Color Theme Selector)】
 * ========================================================================= */
.floating-menu {
   position: fixed;          
   left: 0;                  
   top: 70%;                 
   transform: translateY(-50%); 
   display: flex;            
   flex-direction: column;   
   gap: 4px;                
   z-index: 999;             
   padding: 10px; 
}

.theme-selector {
   color: #fff; 
   text-decoration: none; 
   text-align: center; 
   border-radius: 50%;       
   width: 40px;              
   height: 40px; 
   line-height: 36px;        
   font-weight: bold; 
   border: 2px solid var(--btn-color); 
   box-shadow: 0 0 10px var(--btn-color); 
   backdrop-filter: blur(3px); 
   transition: 0.3s; 
}

.theme-selector:hover, 
.theme-selector.active {
   background: var(--btn-color); 
   color: #000;                  
}

/* =========================================================================
 * 【六、標題與基礎按鈕元件 (Headers, Selects, Buttons)】
 * ========================================================================= */
.header-title-area {
   text-align: center; 
}

.glow-title {
   font-size: 1.8rem; 
   color: var(--primary); 
   text-shadow: 0 0 15px var(--primary); 
   margin-bottom: 10px; 
   letter-spacing: 3px;                  
}

.header-subtitle {
   font-size: 1.1rem; 
   color: var(--accent); 
}

.cyber-select {
   background: linear-gradient(180deg, rgba(var(--primary-rgb), 0.15) 0%, rgba(10, 5, 5, 0.9) 100%); 
   color: var(--primary); 
   border: 1px solid var(--primary); 
   border-radius: 4px; 
   outline: none;            
   cursor: pointer; 
   text-shadow: 0 0 5px rgba(var(--primary-rgb), 0.5); 
   box-shadow: 0 0 10px rgba(var(--primary-rgb), 0.2); 
   transition: all 0.3s ease; 
}

.cyber-select:hover, 
.cyber-select:focus {
   border-color: var(--accent); 
   color: var(--accent); 
   box-shadow: 0 0 15px rgba(var(--accent-rgb), 0.4); 
}

.cyber-select option {
   background-color: #0a0505; 
   color: #ffffff; 
}

.system-prompt {
   background: rgba(0, 0, 0, 0.75); 
   backdrop-filter: blur(25px);
   border: 1px solid rgba(var(--primary-rgb), 0.3);
   border-left: 4px solid var(--primary); 
   color: #fff; 
   padding: 15px; 
   text-align: center; 
   font-size: 1.1rem; 
   border-radius: 4px; 
   box-shadow: 0 4px 15px rgba(0, 0, 0, 0.6);
}

.cyber-btn {
   background: rgba(var(--primary-rgb), 0.15); 
   color: #fff; 
   border: 2px solid var(--primary); 
   padding: 12px 30px;       
   font-size: 1.2rem; 
   cursor: pointer; 
   border-radius: 4px; 
   transition: 0.3s; 
   text-shadow: 0 0 5px var(--primary); 
   box-shadow: 0 0 10px rgba(var(--primary-rgb), 0.4); 
   margin: 5px; 
}

.cyber-btn:hover {
   background: var(--primary); 
   color: #000; 
   box-shadow: 0 0 20px var(--primary); 
}

.cyber-btn.accent {
   border-color: var(--accent);
   color: var(--accent);
   text-shadow: 0 0 5px var(--accent);
   box-shadow: 0 0 10px rgba(var(--accent-rgb), 0.4);
}

.cyber-btn.accent:hover {
   background: var(--accent);
   color: #000; 
   box-shadow: 0 0 20px var(--accent);
}

/* =========================================================================
 * 【七、求籤互動區廟宇專屬陣法底紋 (Temple Diamond Lattice)】
 * ========================================================================= */
#lottery-action-area {
   background-color: var(--glass-bg);
   background-image: 
      repeating-linear-gradient(45deg, transparent, transparent 20px, rgba(var(--primary-rgb), 0.18) 20px, rgba(var(--primary-rgb), 0.18) 21px),
      repeating-linear-gradient(-45deg, transparent, transparent 20px, rgba(var(--primary-rgb), 0.18) 20px, rgba(var(--primary-rgb), 0.18) 21px);
   border-radius: 8px;
}

/* =========================================================================
 * 【八、神機妙算滿版主視覺陣法 (V0.13 升級重構版)】
 * ========================================================================= */
#taichi-array-module {
   text-align: center;
   margin-bottom: 20px;
}

#Caishen-main-vision {
   width: 95%;
   max-width: 800px;
   display: block;
   margin: 15px auto;
   border-radius: 12px;
   border: 2px solid var(--primary);
   transition: all 0.5s ease-in-out;
}

.Caishen-vision-idle {
   animation: CaishenBreathe 4s infinite ease-in-out;
}

.Caishen-vision-active {
   animation: CaishenDivine 2.5s ease-in-out forwards;
}

/* =========================================================================
 * 【九、籤詩解盤區塊佈局 (Lottery Result Architecture)】
 * ========================================================================= */
.card-area.wide-card {
   background: rgba(5, 5, 5, 0.9); 
   border: 2px solid var(--primary); 
   padding: 30px; 
   border-radius: 8px; 
   width: 100%; 
   max-width: 1000px; 
   margin: 0 auto; 
   position: relative; 
   overflow: hidden; 
}

.lot-header {
   display: flex;                
   justify-content: flex-start; 
   align-items: center;          
   gap: 15px;
   border-bottom: 1px solid var(--glass-border); 
   padding-bottom: 15px; 
   margin-bottom: 20px; 
}

.lot-badge {
   background: linear-gradient(135deg, var(--danger), var(--primary)); 
   color: #fff; 
   padding: 8px 15px; 
   border-radius: 4px; 
   font-weight: bold; 
   border: 1px solid var(--accent); 
}

.lot-title {
   font-size: 2rem; 
   color: var(--accent); 
}

.lot-hexagram-box {
   text-align: center;
   font-size: 1.15rem;
   color: #fff;
   background: linear-gradient(90deg, transparent, rgba(var(--primary-rgb), 0.3), transparent);
   padding: 8px 15px;
   margin-bottom: 15px;
   border-top: 1px solid rgba(var(--primary-rgb), 0.5);
   border-bottom: 1px solid rgba(var(--primary-rgb), 0.5);
   letter-spacing: 2px;
   text-shadow: 0 0 5px var(--primary);
}

.lot-story-detail-box {
   background: rgba(var(--primary-rgb), 0.08);
   border-left: 4px solid var(--primary);
   padding: 15px 20px;
   margin-bottom: 20px;
   border-radius: 0 8px 8px 0;
   color: #eee;
   font-size: 1.1rem;
   line-height: 1.8;
   letter-spacing: 1px;
   text-shadow: 0 1px 2px rgba(0, 0, 0, 0.8);
}

.lot-poem-box {
   text-align: center; 
   padding: 20px; 
   background: rgba(0, 0, 0, 0.4); 
   border-top: 1px dashed var(--primary);    
   border-bottom: 1px dashed var(--primary); 
   margin-bottom: 25px; 
}

.lot-poem-box p {
   font-size: 1.6rem; 
   color: #fff; 
   letter-spacing: 4px; 
   line-height: 1.8; 
}

/* =========================================================================
 * 【十、傳統解籤網格佈局陣法 (CSS Grid System)】
 * 說明：利用現代 CSS Grid 技術，將聖意、東坡解等區塊漂亮地分割為三欄。
 * 整合 V0.21 (三欄網格) 與 V0.22 (同行顯示) 升級陣法。
 * ========================================================================= */
.lot-grid-dimensions {
   display: grid;                     
   grid-template-columns: repeat(3, 1fr);    
   gap: 15px;                         
   margin-bottom: 25px; 
}

.dim-item {
   background: rgba(var(--primary-rgb), 0.05); 
   border-left: 3px solid var(--primary); 
   padding: 15px; 
}

.dim-item.full-width {
   grid-column: 1 / -1 !important;               
}

.dim-label {
   color: var(--primary); 
   font-size: 1.1rem; 
   display: inline-block !important;                    
   margin-bottom: 0 !important; 
   font-weight: normal; 
   text-shadow: 0.5px 0 0 var(--primary), -0.5px 0 0 var(--primary); 
}

.dim-text { 
   color: #ddd; 
   line-height: 1.6; 
   display: inline !important; 
}

/* =========================================================================
 * 【十一、天璣居士獨家解盤與行動版摺疊陣法 (Master Analysis & Accordion UI)】
 * ========================================================================= */
.lot-master-box {
   background: rgba(var(--accent-rgb), 0.05); 
   border: 1px solid rgba(var(--accent-rgb), 0.3); 
   padding: 20px; 
   border-radius: 8px; 
}

.master-title { 
   color: var(--accent); 
   border-bottom: 1px dashed var(--accent); 
   padding-bottom: 10px; 
   margin-bottom: 15px; 
}

.master-label { 
   color: var(--accent); 
   font-weight: bold; 
   display: block; 
   margin-bottom: 8px; 
   font-size: 1.15rem; 
}

.master-text { 
   color: #fff; 
   line-height: 1.8; 
   font-size: 1.05rem; 
}

.master-section.highlight { 
   margin-top: 25px; 
}

.master-divider {
   border-top: 1px dashed rgba(var(--accent-rgb), 0.4); 
   margin: 25px 0; 
}

.master-sub-label {
   color: var(--accent); 
   font-weight: bold; 
   display: block; 
   margin-top: 20px; 
   margin-bottom: 8px; 
   font-size: 1.1rem; 
   text-shadow: 0 0 5px rgba(var(--accent-rgb), 0.5); 
}

.master-warning {
   color: var(--danger) !important;  
   font-weight: bold; 
   display: block; 
   margin-top: 25px; 
   margin-bottom: 8px; 
   font-size: 1.1rem; 
   text-shadow: 0 0 8px rgba(255, 68, 68, 0.4); 
}

/* =========================================================================
 * 【十二、圖卡匯出與 RWD 雙欄堆疊陣法 (Canvas Export & RWD Layout)】
 * ========================================================================= */
.card-qrcode { 
   text-align: center; 
   margin-top: 25px; 
   display: none; 
}

.card-qr-wrapper {
   display: flex;
   justify-content: center;
   align-items: center;
   gap: 40px; 
   padding-top: 25px;
   margin-top: 25px;
   border-top: 1px dashed rgba(var(--primary-rgb), 0.5);
}

.card-qrcode img { 
   border: 2px solid var(--accent); 
   border-radius: 4px; 
   padding: 5px; 
   background: #fff; 
   box-shadow: 0 0 15px rgba(var(--accent-rgb), 0.5); 
   max-width: 120px; 
   height: auto; 
}

.card-watermark-title {
   color: var(--accent); 
   font-size: 1.3rem; 
   font-weight: bold; 
   letter-spacing: 3px; 
   text-shadow: 0 0 8px rgba(var(--accent-rgb), 0.8); 
   border-bottom: 1px dashed var(--primary); 
   padding-bottom: 5px; 
   margin-top: 5px; 
}

.card-watermark-url {
   color: #ddd; 
   font-size: 0.85rem; 
   font-family: monospace;    
   letter-spacing: 1px; 
   opacity: 0.8;              
}

/* =========================================================================
 * 【十三、廠商贊助與廣告區塊 (Ad Grid & Carousel)】
 * ========================================================================= */
aside h2 {
   color: var(--accent); 
   text-align: center; 
   margin-bottom: 20px; 
}

.ad-grid {
   display: grid; 
   grid-template-columns: repeat(3, 1fr); 
   gap: 15px; 
}

.text-ad {
   display: flex; 
   align-items: center; 
   color: #fff; 
   text-decoration: none; 
   background: rgba(0, 0, 0, 0.5); 
   padding: 12px 15px; 
   border-radius: 4px; 
   border: 1px solid rgba(var(--primary-rgb), 0.3); 
   transition: all 0.3s ease; 
}

.text-ad:hover {
   color: var(--accent); 
   border-color: var(--accent); 
   transform: translateY(-2px); 
   box-shadow: 0 4px 10px rgba(var(--accent-rgb), 0.2); 
}

.red-icon {
   color: var(--primary); 
   margin-right: 10px; 
}

.ad-carousel-wrapper {
   width: 100%; 
   aspect-ratio: 16 / 9;      
   position: relative;        
   overflow: hidden;          
   border: 2px solid var(--primary); 
   border-radius: 8px; 
}

.ad-slider-track {
   display: flex;             
   width: 500%;               
   height: 100%; 
   transition: transform 0.5s ease-in-out; 
}

.ad-slide {
   width: 20%;                
   position: relative; 
}

.ad-slide img {
   width: 100%; 
   height: 100%; 
   object-fit: cover;         
   opacity: 0.7;              
   transition: 0.3s; 
}

.ad-slide:hover img { 
   opacity: 1;                
}

.ad-slide-title {
   position: absolute; 
   top: 20px; 
   left: 20px; 
   background: rgba(0, 0, 0, 0.8); 
   color: #fff; 
   padding: 10px 20px; 
   border-left: 4px solid var(--accent); 
   font-size: 1.2rem; 
}

.ad-slide-link {
   position: absolute; 
   bottom: 20px; 
   right: 20px; 
   background: rgba(var(--primary-rgb), 0.8); 
   color: #fff; 
   padding: 10px 20px; 
   text-decoration: none; 
   border: 1px solid var(--primary); 
   border-radius: 4px; 
   transition: 0.3s; 
}

.ad-slide-link:hover {
   background: var(--accent); 
   color: #000; 
}

.ad-arrow {
   position: absolute; 
   top: 50%;                  
   transform: translateY(-50%); 
   background: rgba(0, 0, 0, 0.6); 
   color: var(--primary); 
   border: none; 
   font-size: 2rem; 
   padding: 15px 10px; 
   cursor: pointer; 
   z-index: 10;               
}

.ad-arrow-prev { left: 0; }
.ad-arrow-next { right: 0; }

.ad-dots-container {
   position: absolute;
   bottom: 15px;
   left: 0;
   width: 100%;
   display: flex;
   justify-content: center;
   z-index: 10;
}

.ad-dot {
   width: 10px;
   height: 10px;
   margin: 0 5px;
   background-color: rgba(255, 255, 255, 0.5);
   border-radius: 50%;
   cursor: pointer;
   transition: background-color 0.3s ease;
}

.ad-dot.active {
   background-color: var(--accent, #00ffff);
   box-shadow: 0 0 8px var(--accent, #00ffff);
}

/* =========================================================================
 * 【十四、頁腳資訊與流量計數器 (Footer & Counters)】
 * ========================================================================= */
.cyber-footer-info {
   text-align: center; 
   padding: 40px 20px; 
   background: rgba(0, 0, 0, 0.8); 
   border-top: 2px solid var(--primary); 
   color: #ccc; 
   line-height: 1.8; 
}

.cyber-footer-info h3 { 
   color: var(--primary); 
   margin-bottom: 15px; 
}

.cyber-footer-info strong { 
   color: var(--accent); 
}

.info-content-box {
   display: inline-block; 
   text-align: left; 
   border: 1px dashed var(--accent); 
   padding: 20px 30px; 
   border-radius: 8px; 
   background: rgba(var(--accent-rgb), 0.05); 
   margin-bottom: 25px; 
}

.info-content-box p { 
   margin-bottom: 10px; 
   font-size: 1.1rem; 
   color: #ccc; 
}

.info-content-box p:last-child { 
   margin-bottom: 0;          
}

.footer-action-buttons {
   display: flex; 
   justify-content: center; 
   gap: 15px; 
   margin: 25px 0; 
}

.cyber-action-btn {
   background: transparent; 
   border: 1px solid var(--accent); 
   color: var(--accent); 
   padding: 8px 20px; 
   text-decoration: none; 
   border-radius: 4px; 
   transition: 0.3s; 
   cursor: pointer; 
}

.cyber-action-btn:hover {
   background: var(--accent); 
   color: #000; 
}

.cyber-footer-copyright { 
   margin-top: 20px; 
   font-size: 0.9rem; 
   color: #777; 
}

.counter-footer {
   width: 100%; 
   background: #000; 
   padding: 12px 0; 
   border-top: 1px solid var(--primary); 
}

.counter-group { 
   display: flex; 
   justify-content: center; 
   gap: 20px; 
}

.counter-item {
   display: flex; 
   flex-direction: column;    
   align-items: center; 
   color: #aaa; 
   font-size: 0.9rem; 
   background: rgba(255, 255, 255, 0.05); 
   padding: 8px 25px; 
   border-radius: 4px; 
   border: 1px solid #333; 
   min-width: 120px; 
}

.count-val {
   color: var(--accent); 
   font-weight: bold; 
   font-size: 1.3rem; 
   margin-top: 5px; 
   text-shadow: 0 0 5px rgba(var(--accent-rgb), 0.5); 
}

/* =========================================================================
 * 【十五、專屬 QRCode 彈跳視窗陣法 (Modal UI)】
 * ========================================================================= */
.qr-modal { 
   position: fixed; 
   top: 0; 
   left: 0; 
   width: 100%; 
   height: 100%; 
   background: rgba(0,0,0,0.85); 
   z-index: 1001;             
   display: none;             
   justify-content: center; 
   align-items: center; 
}

.qr-modal-content { 
   background: var(--bg-main); 
   border: 2px solid var(--primary); 
   padding: 30px; 
   border-radius: 8px; 
   text-align: center; 
   position: relative; 
   width: 90%; 
   max-width: 350px; 
}

.qr-close-btn { 
   position: absolute; 
   top: 10px; 
   right: 15px; 
   color: #fff; 
   font-size: 1.5rem; 
   cursor: pointer; 
}

.qr-modal-content h3 { 
   margin-bottom: 20px; 
}

#qrImage, #qrPlaceholder { 
   margin-top: 20px !important; 
   margin-bottom: 20px !important; 
}

/* =========================================================================
 * 【十六、神機妙算特效動畫引擎陣法 (CSS Animations)】
 * ========================================================================= */

/* --- 16.1 滿版主視覺特效動畫 --- */
@keyframes CaishenBreathe {
   0%, 100% {
      transform: translateY(0);
      box-shadow: 0 0 10px rgba(var(--primary-rgb), 0.3);
   }
   50% {
      transform: translateY(-5px);
      box-shadow: 0 0 25px rgba(var(--primary-rgb), 0.7);
   }
}

@keyframes CaishenDivine {
   0% {
      transform: scale(1);
      box-shadow: 0 0 30px rgba(var(--accent-rgb), 0.8);
      filter: brightness(1);
   }
   50% {
      transform: scale(1.05);
      box-shadow: 0 0 60px rgba(var(--accent-rgb), 1);
      filter: brightness(1.3);
   }
   100% {
      transform: scale(1);
      box-shadow: 0 0 20px rgba(var(--accent-rgb), 0.5);
      filter: brightness(1);
   }
}

/* --- 16.2 3D 虛擬金幣卜卦模組 (V0.36 全新升級陣法) --- */

/* [金幣容器] 修正為兩幣並排陣法 */
.coin-grid-2 {
   display: grid;
   /* 強制設定為 2 欄，平分空間 */
   grid-template-columns: repeat(2, 1fr); 
   gap: 20px;
   /* 縮小最大寬度，讓兩枚金幣靠攏更霸氣 */
   max-width: 320px;
   margin: 0 auto;
}

/* [單一金幣外框] 設定專屬的 3D 透視深度，強化單幣獨立旋轉的立體感 */
.coin-unit {
   position: relative;
   width: 100%;
   aspect-ratio: 1;
   margin: 0 auto;
   perspective: 1000px;
}

/* [立體核心] 乘載正反兩面的旋轉軸心 */
.coin-core {
   width: 100%; height: 100%;
   position: absolute;
   top: 0; left: 0;
   /* 3D 陣法神兵：保留子元素的 3D 空間深度 */
   transform-style: preserve-3d;
   transition: transform 1.5s ease-out;
}

/* [金幣圖片共通樣式] 絕對定位並隱藏背面 */
.coin-side {
   position: absolute;
   top: 0; left: 0;
   width: 100%; height: 100%;
   border-radius: 50%;
   /* 背對使用者時隱藏，杜絕反字假象 */
   backface-visibility: hidden;
}

/* [光影特效] 配合科技論運武俠風的發光外框 */
.coin-unit.normal-lot .coin-side { 
   border: 2px solid rgba(255, 204, 0, 0.6); 
   box-shadow: 0 0 15px rgba(255, 204, 0, 0.4); 
}
.coin-unit.special-lot .coin-side { 
   border: 2px solid #9d4edd; 
   box-shadow: 0 0 25px rgba(157, 78, 221, 0.7); 
}

/* [正面與反面初始角度] */
.coin-head { transform: rotateY(0deg); z-index: 2; }
.coin-tail { transform: rotateY(180deg); z-index: 1; }

/* [核心動畫關鍵影格：真實物理拋物線陣法] */
/* 說明：加入 translateY (向上拋) 與 scale (視覺放大)，搭配 ease-in-out 模擬重力減速與加速 */

/* [第一枚金幣] 向上拋高 120px，放大 1.3 倍，並劇烈沿 Y 軸翻轉 10 圈 (3600度) */
@keyframes toss-physics-1 {
   /* 起點：靜止在神桌上 */
   0%   { transform: translateY(0) rotateY(0deg) scale(1); }
   /* 頂點：被用力拋向空中，高度達到 -120px，離眼睛更近所以放大 1.3 倍 */
   50%  { transform: translateY(-120px) rotateY(1800deg) scale(1.3); } 
   /* 落地：重力加速度落下，回到原點，完成翻滾 */
   100% { transform: translateY(0) rotateY(3600deg) scale(1); } 
}

/* [第二枚金幣] 向上拋高 160px (產生高低落差)，放大 1.4 倍，沿 X 軸與 Y 軸不規則交錯翻轉 */
@keyframes toss-physics-2 {
   /* 起點：靜止 */
   0%   { transform: translateY(0) rotateX(0deg) rotateY(0deg) scale(1); }
   /* 頂點：這枚拋得更高 (-160px)，且帶有不規則的立體翻轉，增加真實隨機感 */
   50%  { transform: translateY(-160px) rotateX(1080deg) rotateY(900deg) scale(1.4); } 
   /* 落地：精準落回原點 */
   100% { transform: translateY(0) rotateX(2160deg) rotateY(1800deg) scale(1); } 
}

/* [觸發旋轉類別] */
/* 配合 JS 的 1.8 秒延遲，將動畫時間精準設定為 1.8s，forwards 讓它停留在落地狀態 */
.is-tossing-1 { animation: toss-physics-1 1.8s ease-in-out forwards; }
.is-tossing-2 { animation: toss-physics-2 1.8s ease-in-out forwards; }

/* [結果鎖定類別] 動畫結束後強制顯示正面或反面 */
.force-head { transform: rotateY(0deg) !important; animation: none !important; }
.force-tail { transform: rotateY(180deg) !important; animation: none !important; }

/* =========================================================================
 * 【十七、全域 RWD 響應式優化模組 (Media Queries)】
 * ========================================================================= */

/* --- 17.1 平板版響應式優化 (max-width: 1024px) --- */
@media (max-width: 1024px) {
   .main-container { padding: 0 8px; }          
   .glass-panel { padding: 6px 3px; }         
   .menu-toggle-btn { padding: 8px 12px; gap: 0; }
   .dropdown-list li a { padding: 15px 20px; font-size: 1rem; line-height: normal; }
   .system-prompt { font-size: 1rem; padding: 12px; }
   aside h2 { font-size: 1.3rem; margin-bottom: 15px; }
   .card-area.wide-card { padding: 15px 10px; }
   
   .lot-header { flex-direction: column; gap: 12px; text-align: center; justify-content: center; align-items: center; }
   .lot-title { font-size: 1.6rem; }
   .lot-story-detail-box { padding: 12px 15px; font-size: 1.05rem; }
   
   .lot-master-box { padding: 15px 12px; }
   .master-label { font-size: 1.05rem; }
   .master-text { font-size: 1rem; }
   .master-sub-label { font-size: 1.05rem; }
   .master-warning { font-size: 1.05rem; }

   #btn-draw-lot, #btn-toss-coin { padding: 10px 20px; font-size: 1.05rem; }
   .action-group { display: flex; justify-content: center; gap: 10px; }
   .action-group .cyber-btn { font-size: 0.95rem; padding: 10px 5px; margin: 0; flex: 1; white-space: nowrap; }

   .ad-grid { grid-template-columns: 1fr; gap: 10px; }
   .text-ad { padding: 15px 10px; font-size: 0.95rem; justify-content: flex-start; }
   
   .ad-section.glass-panel { padding: 6px; margin-left: 0; margin-right: 0; border: 1px solid var(--glass-border); border-radius: 8px; }
   .ad-carousel-wrapper { border-width: 1px; border-radius: 8px; }
   .ad-slide-title { font-size: 0.95rem; top: 10px; left: 10px; padding: 5px 10px; }
   .ad-slide-link { bottom: 10px; right: 10px; padding: 6px 15px; font-size: 0.85rem; }
   .ad-arrow { font-size: 1.5rem; padding: 10px 5px; }

   .lot-poem-box { padding: 15px 10px; }
   .cyber-footer-info { padding: 30px 10px; }
   .info-content-box { padding: 15px 12px; width: 100%; margin-bottom: 20px; }
   .info-content-box p { font-size: 0.95rem; }
   
   .footer-action-buttons { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; width: 100%; margin: 0; }
   .cyber-action-btn { width: 100%; padding: 12px 0; text-align: center; font-size: 0.95rem; }
   
   .glow-title { font-size: 1.6rem; }
   .header-subtitle { font-size: 0.9rem; }
   
   .menu-text { display: inline-block; max-width: 0; opacity: 0; overflow: hidden; vertical-align: middle; margin: 0; transition: max-width 0.4s ease, opacity 0.4s ease, margin 0.4s ease; }
   .menu-toggle-btn.expanded .menu-text { max-width: 150px; opacity: 1; margin-left: 8px; }
   
   .dropdown-list { position: fixed; top: 60px; right: 15px; width: calc(100% - 30px); max-width: 320px; max-height: 0; overflow: hidden; visibility: hidden; opacity: 0; transform: none; transition: max-height 0.5s ease-in-out, opacity 0.4s ease, visibility 0.5s; }
   .dropdown-list.show { max-height: 400px; visibility: visible; opacity: 1; }
   
   .counter-group { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; padding: 0 8px; }
   .counter-item { min-width: 0; padding: 5px 10px; }
   .count-val { font-size: 1.1rem; }

   .mobile-toggle-text { display: inline-block; font-size: 0.85rem; color: #aaa; margin-left: 10px; font-weight: normal; }
   .toggle-content { display: none; }
   .toggle-content.expanded { display: block; margin-top: 10px; }
   .toggle-label { cursor: pointer; padding: 5px 0; display: block; }
}

/* --- 17.2 手機版終極響應式優化 (max-width: 767px) --- */
@media (max-width: 767px) {
   .lot-grid-dimensions { grid-template-columns: repeat(2, 1fr); gap: 10px; }
   
   .card-qr-wrapper {
      flex-direction: column;
      gap: 20px;
   }
}

/* =========================================================================
 * 樣式名稱：開運六要訣 (lucky_elements) 視覺陣法修正
 * 系統版本：V0.36
 * 作者宣告：五元網站包租公-Tiger老師
 * ========================================================================= */
.lucky-elements-grid {
   display: grid;
   grid-template-columns: repeat(2, 1fr);
   gap: 10px;
   margin-top: 15px;
   padding: 0;
   border: none;
   background: transparent;
   box-shadow: none;
}

.lucky-item {
   display: flex;
   align-items: center;
   background: rgba(var(--primary-rgb), 0.05);
   padding: 8px 10px;
   border-radius: 4px;
   border: 1px solid rgba(var(--primary-rgb), 0.15);
}

.lucky-label {
   font-size: 0.9em;
   color: var(--primary);
   font-weight: bold;
   margin-right: 8px;
   flex-shrink: 0;
}

.lucky-value {
   font-size: 0.95em;
   color: #ffffff;
   font-weight: bold;
   flex-grow: 1;
   word-break: break-word;
}

/* =========================================================================
 * 樣式名稱：行動版文字響應式修正陣法
 * 系統版本：V0.36
 * 作者宣告：五元網站包租公-Tiger老師
 * ========================================================================= */
@media (min-width: 1025px) {
   .mobile-toggle-text {
      display: none !important;
   }
}

@media (max-width: 1024px) {
   .mobile-toggle-text {
      display: inline-block;
      font-size: 0.85em;
      color: rgba(var(--primary-rgb), 0.7);
      margin-left: 10px;
      font-weight: normal;
   }
}

/* =========================================================================
 * 樣式名稱：行動版 3D 金幣拋擲修正陣法 (Mobile RWD)
 * 系統版本：V0.38
 * 作者宣告：五元網站包租公-Tiger老師
 * 說明：針對手機窄螢幕，縮小金幣間距，並調降拋物線高度，避免金幣飛出畫面。
 * ========================================================================= */
@media (max-width: 767px) {
   
   /* [縮小陣眼] 手機版將間距從 40px 縮小到 20px，總寬度限制在 260px，讓雙金幣緊湊霸氣 */
   .coin-grid-2 {
      gap: 20px;
      max-width: 260px;
   }

   /* [重新定義第一枚金幣物理] 拋高高度降為 -80px，放大比例降為 1.15 倍 */
   @keyframes toss-physics-1 {
      0%   { transform: translateY(0) rotateY(0deg) scale(1); }
      50%  { transform: translateY(-80px) rotateY(1800deg) scale(1.15); } 
      100% { transform: translateY(0) rotateY(3600deg) scale(1); } 
   }

   /* [重新定義第二枚金幣物理] 拋高高度降為 -100px (維持微小落差)，放大比例降為 1.2 倍 */
   @keyframes toss-physics-2 {
      0%   { transform: translateY(0) rotateX(0deg) rotateY(0deg) scale(1); }
      50%  { transform: translateY(-100px) rotateX(1080deg) rotateY(900deg) scale(1.2); } 
      100% { transform: translateY(0) rotateX(2160deg) rotateY(1800deg) scale(1); } 
   }
   
}