/* ============================================================
   紫微八字 網站版 — 寬版水墨設計
   配色：深墨藍 + 宣紙米 + 月白 + 命宮硃紅
   字體：Noto Serif TC（標題）/ Noto Sans TC（內文）
   ============================================================ */

:root{
  --ink:#141d30;          /* 深墨藍底 */
  --ink2:#1e2c47;
  --ink3:#24324f;
  --paper:#ece6d6;        /* 宣紙米 */
  --paper2:#e6dfcc;
  --paper3:#dcd3bd;
  --moon:#9fb4dd;         /* 月白藍 */
  --moon-d:#6f86b4;
  --gold:#c9a86a;         /* 鎏金 */
  --red:#d98a86;          /* 命宮硃紅 */
  --line:#3a4a6a;
  --txt:#dce4f2;
  --txt2:#aebdd8;
  --txt3:#7e8caa;
  --ink-on-paper:#2a3340;
  --paper-sub:#6a6353;
  --lu:#7fc8a9;           /* 化祿 綠 */
  --quan:#7fa6e8;         /* 化權 藍 */
  --ke:#d8c074;           /* 化科 金 */
  --ji:#e08b86;           /* 化忌 紅 */
  --maxw:1240px;
}

*{box-sizing:border-box; margin:0; padding:0; -webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;}
body{
  font-family:"Noto Sans TC",sans-serif;
  background:var(--ink);
  color:var(--txt);
  line-height:1.7;
  min-height:100vh;
}
.serif{font-family:"Noto Serif TC",serif;}
.en{font-family:"Cinzel",serif; letter-spacing:.28em;}
a{color:inherit; text-decoration:none;}
.hidden{display:none !important;}

/* ===== 頂部導覽 ===== */
.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:18px;
  padding:16px clamp(20px,5vw,48px);
  background:rgba(20,29,48,.82);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(159,180,221,.12);
}
.nav .brand{display:flex; align-items:center; gap:12px; cursor:pointer;}
.nav .taiji{width:30px; height:30px; animation:spin 90s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.nav .brand b{font-family:"Noto Serif TC",serif; font-weight:900; font-size:19px; letter-spacing:.18em; color:var(--paper); padding-left:.18em;}
.nav .brand span{font-family:"Cinzel",serif; font-size:10px; letter-spacing:.4em; color:var(--moon);}
.nav .spacer{flex:1;}
.navlink{cursor:pointer; transition:color .2s;}
.nav .navlink{font-size:13px; letter-spacing:.12em; color:var(--txt3);}
.navlink:hover{color:var(--txt);}

/* ============================================================
   起盤頁（HERO） — 宣紙水墨
   ============================================================ */
.hero{
  position:relative; overflow:hidden;
  background:linear-gradient(180deg,#ece6d6 0%, #e7e0cd 45%, #dcd3bd 100%);
  color:var(--ink-on-paper);
  min-height:calc(100vh - 63px);
}
.hero .moon{position:absolute; top:-90px; right:6vw; width:340px; height:340px; border-radius:50%;
  background:radial-gradient(circle at 50% 60%, #fbf8ef 0%, #f2ecdd 58%, transparent 74%);}
.hero .mtn{position:absolute; left:0; right:0; bottom:0; height:42vh; min-height:240px; pointer-events:none;}
.hero .grain{position:absolute; inset:0; opacity:.3; mix-blend-mode:multiply;
  background-image:radial-gradient(#0000000a 1px, transparent 1px); background-size:3px 3px; pointer-events:none;}

.hero-inner{
  position:relative; z-index:3;
  max-width:var(--maxw); margin:0 auto;
  padding:clamp(40px,7vh,90px) clamp(20px,5vw,48px) 80px;
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,5vw,70px); align-items:center;
}
.hero-copy h1{font-family:"Noto Serif TC",serif; font-weight:900;
  font-size:clamp(34px,4.6vw,58px); line-height:1.18; letter-spacing:.06em; color:#23303f; margin-bottom:22px;}
.hero-copy h1 .hl{color:#6b5a3a; position:relative; white-space:nowrap;}
.hero-copy h1 .hl::after{content:""; position:absolute; left:0; right:0; bottom:.08em; height:.32em;
  background:linear-gradient(90deg,rgba(201,168,106,.42),rgba(201,168,106,0)); z-index:-1;}
.hero-copy .lead{font-size:clamp(15px,1.5vw,17px); color:#5a5446; letter-spacing:.04em; line-height:2; max-width:30em; margin-bottom:30px;}
.hero-copy .feats{display:flex; flex-wrap:wrap; gap:10px 14px; margin-bottom:8px;}
.hero-copy .feat{display:flex; align-items:center; gap:7px; font-size:13.5px; color:#4a4434; letter-spacing:.03em;}
.hero-copy .feat .dot{width:6px; height:6px; border-radius:50%; background:var(--gold);}

/* 起盤表單卡 */
.card{
  background:rgba(255,255,255,.42);
  border:1px solid rgba(170,150,110,.4);
  border-radius:18px;
  padding:clamp(22px,2.4vw,32px);
  box-shadow:0 20px 50px -24px rgba(60,48,20,.4), 0 2px 0 rgba(255,255,255,.5) inset;
  backdrop-filter:blur(3px);
}
/* 深色頁上的輸入卡：改實心宣紙底，文字才清楚 */
.card.card-solid{background:linear-gradient(180deg,#efe9da 0%, #e4dbc6 100%); border:1px solid rgba(170,150,110,.6); box-shadow:0 26px 64px -28px rgba(0,0,0,.7);}
.card.card-solid .seg{background:rgba(42,51,64,.10);}
.card.card-solid .seg .o{color:#5a5446;}
.card.card-solid .seg .o.on{color:#ffffff;}
.card.card-solid .inp, .card.card-solid .sel{background:#fbf8ef; border-color:#bfb59d;}
.card .ctitle{font-family:"Noto Serif TC",serif; font-size:19px; font-weight:700; letter-spacing:.18em; color:#2a3340; margin-bottom:4px;}
.card .csub{font-size:12px; color:#8a7f68; letter-spacing:.05em; margin-bottom:20px;}

.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:15px 16px;}
.field{display:flex; flex-direction:column; gap:8px;}
.field.col2{grid-column:1 / -1;}
.flabel{font-family:"Noto Serif TC",serif; font-size:13px; color:#3a4250; letter-spacing:.12em;}

.seg{display:flex; gap:6px; background:rgba(42,51,64,.07); border-radius:11px; padding:4px;}
.seg .o{flex:1; text-align:center; padding:10px 0; border-radius:8px; font-size:14px; color:#7a7264; cursor:pointer; transition:.18s; user-select:none;}
.seg .o.on{background:#2a3340; color:var(--paper); box-shadow:0 4px 12px -4px rgba(42,51,64,.6);}

.inp, .sel{width:100%; background:rgba(255,255,255,.6); border:1px solid #c3b9a3; border-radius:11px;
  padding:12px 13px; color:#2a3340; font-size:15px; font-family:inherit; transition:.18s;}
.inp:focus, .sel:focus{outline:none; border-color:var(--gold); background:#fff;}
.inp::placeholder{color:#9a9080;}
.sel{appearance:none; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%239a9080' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:34px;}
.date-row{display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:8px;}
.date-conv{min-height:18px; margin-top:9px; font-size:12.5px; letter-spacing:.04em; color:#6b5a3a;}
.date-conv .cv{display:inline-flex; align-items:center; gap:7px; padding:5px 11px; border-radius:8px;
  background:rgba(201,168,106,.14); border:1px solid rgba(201,168,106,.4);}
.date-conv .cv b{color:#5a4a2a; font-weight:700;}
.date-conv.loading-conv{color:#9a9080;}

.check{display:flex; align-items:flex-start; gap:10px; cursor:pointer; padding:2px 0;}
.check .box{width:18px; height:18px; border-radius:6px; border:1.6px solid #9a9080; flex-shrink:0; margin-top:2px; transition:.15s; position:relative;}
.check.on .box{background:#2a3340; border-color:#2a3340;}
.check.on .box::after{content:"✓"; position:absolute; inset:0; color:var(--paper); font-size:12px; display:flex; align-items:center; justify-content:center;}
.check .ct{font-size:13px; color:#3a4250;} .check .cd{font-size:11px; color:#8a7f68; margin-top:1px;}

.gobtn{margin-top:6px; width:100%; padding:15px; border:none; border-radius:12px; cursor:pointer;
  background:linear-gradient(135deg,#2a3340,#1a2230); color:var(--paper);
  font-family:"Noto Serif TC",serif; font-size:16px; letter-spacing:.4em; padding-left:.4em;
  transition:.2s; box-shadow:0 14px 30px -14px rgba(42,51,64,.8);}
.gobtn:hover{transform:translateY(-1px); box-shadow:0 18px 36px -14px rgba(42,51,64,.9);}
.gobtn:disabled{opacity:.6; cursor:wait;}
.formerr{color:#b4524c; font-size:13px; min-height:18px; letter-spacing:.03em;}

/* ============================================================
   結果頁 — 深墨命盤
   ============================================================ */
.result{max-width:var(--maxw); margin:0 auto; padding:clamp(22px,3vw,38px) clamp(16px,4vw,40px) 80px;}
.result-head{display:flex; align-items:flex-end; flex-wrap:wrap; gap:14px 20px; margin-bottom:22px;}
.result-head h2{font-family:"Noto Serif TC",serif; font-size:clamp(22px,2.6vw,30px); letter-spacing:.14em; color:var(--paper);}
.chips{display:flex; flex-wrap:wrap; gap:8px;}
.chip{font-size:12.5px; letter-spacing:.06em; color:var(--txt2); padding:6px 12px; border:1px solid var(--line); border-radius:20px; background:rgba(159,180,221,.06);}
.chip b{color:var(--moon); font-weight:500;}
.backbtn{font-size:13px; color:var(--txt3); cursor:pointer; padding:6px 0;}
.backbtn:hover{color:var(--txt);}

.result-grid{display:grid; grid-template-columns:minmax(0,1.5fr) minmax(300px,1fr); gap:clamp(18px,2.4vw,34px); align-items:start;}

.panel{background:rgba(255,255,255,.035); border:1px solid var(--line); border-radius:16px; padding:clamp(14px,1.6vw,22px);}
.panel-title{display:flex; align-items:center; gap:10px; font-family:"Noto Serif TC",serif; font-size:16px; letter-spacing:.2em; color:var(--txt); margin-bottom:16px;}
.panel-title::before{content:""; width:4px; height:16px; border-radius:2px; background:linear-gradient(var(--moon),var(--moon-d));}

/* 紫微方陣 */
.ziwei-grid{display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:1fr; gap:6px; aspect-ratio:1/1;}
.pcell{position:relative; background:rgba(159,180,221,.05); border:1px solid var(--line); border-radius:10px;
  padding:8px 9px; display:flex; flex-direction:column; gap:3px; overflow:hidden; min-height:0;}
.pcell .phead{display:flex; justify-content:space-between; align-items:baseline; gap:6px;}
.pcell .pname{font-family:"Noto Serif TC",serif; font-size:12.5px; color:var(--txt3); letter-spacing:.08em;}
.pcell .pgz{font-size:11px; color:#5d6c8c; letter-spacing:.04em;}
.pcell .pmajor{display:flex; flex-wrap:wrap; gap:3px 6px; margin-top:2px;}
.pcell .star{font-family:"Noto Serif TC",serif; font-size:14px; color:var(--paper); letter-spacing:.04em; line-height:1.3; display:inline-flex; align-items:center; gap:2px;}
.pcell .star .br{font-size:9px; color:var(--txt3); transform:translateY(-1px);}
.pcell .pminor{display:flex; flex-wrap:wrap; gap:2px 7px; margin-top:auto;}
.pcell .mstar{font-size:11px; color:var(--moon); letter-spacing:.03em; display:inline-flex; align-items:center; gap:2px;}
.pcell .pdecadal{font-size:10px; color:#5d6c8c; letter-spacing:.04em; margin-top:3px;}
.pcell.ming{border-color:var(--red); box-shadow:0 0 0 1px rgba(217,138,134,.3) inset;}
.pcell.ming .pname{color:var(--red);}
.pcell.shen::after{content:"身"; position:absolute; top:6px; right:7px; font-size:9px; color:var(--gold); border:1px solid rgba(201,168,106,.5); border-radius:4px; padding:0 3px;}

/* 四化 badge */
.hua{font-size:9px; font-weight:700; border-radius:3px; padding:0 2px; line-height:1.5; transform:translateY(-1px);}
.hua-lu{color:#0d3a28; background:var(--lu);}
.hua-quan{color:#0c2444; background:var(--quan);}
.hua-ke{color:#3a3208; background:var(--ke);}
.hua-ji{color:#3a0c0a; background:var(--ji);}

/* 中宮 */
.pcenter{grid-area:2/2 / span 2 / span 2; background:linear-gradient(160deg,rgba(159,180,221,.12),rgba(159,180,221,.04));
  border:1px solid #46598022; border-radius:12px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:9px; text-align:center; padding:14px;}
.pcenter .ctt{font-family:"Noto Serif TC",serif; font-size:17px; letter-spacing:.3em; color:var(--paper); padding-left:.3em;}
.pcenter .cmeta{display:flex; flex-direction:column; gap:5px; font-size:12.5px; color:var(--txt2); letter-spacing:.05em;}
.pcenter .cmeta b{color:var(--moon); font-weight:500;}
.pcenter .cdivider{width:40px; height:1px; background:var(--line);}

/* 八字四柱 */
.bazi-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:8px;}
.pillar{background:rgba(159,180,221,.05); border:1px solid var(--line); border-radius:12px; padding:12px 8px; text-align:center; display:flex; flex-direction:column; gap:7px;}
.pillar .plabel{font-size:11px; color:var(--txt3); letter-spacing:.18em;}
.pillar .pgod{font-size:11.5px; color:var(--moon); letter-spacing:.04em; min-height:16px;}
.pillar .pgan, .pillar .pzhi{font-family:"Noto Serif TC",serif; font-size:30px; line-height:1.1; color:var(--paper);}
.pillar .pzhi{color:#cdd6e8;}
.pillar .phidden{font-size:11px; color:var(--txt3); letter-spacing:.06em; min-height:16px;}
.pillar .pnayin{font-size:10.5px; color:#5d6c8c; letter-spacing:.04em;}
.pillar.day{border-color:var(--gold); box-shadow:0 0 0 1px rgba(201,168,106,.25) inset;}
.pillar.day .plabel{color:var(--gold);}

.kv{display:flex; justify-content:space-between; gap:12px; padding:9px 2px; border-bottom:1px dashed rgba(159,180,221,.14); font-size:13.5px;}
.kv:last-child{border-bottom:none;}
.kv .k{color:var(--txt3); letter-spacing:.06em;}
.kv .v{color:var(--txt); text-align:right;}
.kv .v b{color:var(--moon); font-weight:500;}

/* 完整命盤資料（一頁攤開，依資料型態分塊、非生活分類） */
#r-extra{display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:18px; margin-top:18px; align-items:start;}
#r-extra .panel.full{grid-column:1 / -1;}
.dayun-row{display:flex; gap:8px; overflow-x:auto; padding-bottom:6px; scrollbar-width:thin;}
.dayun-card{flex:0 0 auto; min-width:74px; text-align:center; padding:10px 8px; border-radius:10px; border:1px solid var(--line); background:rgba(159,180,221,.05);}
.dayun-card .dage{font-size:10.5px; color:var(--txt3); letter-spacing:.02em;}
.dayun-card .dgz{font-family:"Noto Serif TC",serif; font-size:18px; color:var(--paper); margin:4px 0; letter-spacing:.04em;}
.dayun-card .dyear{font-size:10px; color:#5d6c8c;}
.dayun-card .dtag{font-size:10px; margin-top:5px; padding:2px 0; border-radius:5px; letter-spacing:.02em;}
.dayun-card.good .dtag{background:rgba(127,200,169,.18); color:var(--lu);}
.dayun-card.bad .dtag{background:rgba(224,139,134,.18); color:var(--ji);}
.dayun-card.neutral .dtag{background:rgba(159,180,221,.12); color:var(--txt3);}
.wx-list{display:flex; flex-direction:column; gap:9px;}
.wx-item{display:flex; align-items:center; gap:10px;}
.wx-item .wxn{width:20px; font-family:"Noto Serif TC",serif; font-size:15px; color:var(--paper);}
.wx-item .wxbar{flex:1; height:9px; border-radius:5px; background:rgba(159,180,221,.1); overflow:hidden;}
.wx-item .wxbar i{display:block; height:100%; border-radius:5px;}
.wx-item .wxc{width:24px; text-align:right; font-size:12.5px; color:var(--txt2);}
.wx-木 i{background:#7fc8a9;} .wx-火 i{background:#e0908a;} .wx-土 i{background:#d8be7a;} .wx-金 i{background:#cdd6e8;} .wx-水 i{background:#7fa6e8;}
.ss-list{display:flex; flex-wrap:wrap; gap:8px;}
.ss-chip{font-size:12.5px; color:var(--txt); padding:6px 11px; border-radius:20px; background:rgba(201,168,106,.12); border:1px solid rgba(201,168,106,.34); letter-spacing:.03em;}
.ss-chip b{color:var(--gold); font-weight:500;} .ss-chip span{color:var(--txt3); font-size:11px;}
.ss-empty{font-size:12.5px; color:var(--txt3);}
.sihua-list{display:flex; flex-wrap:wrap; gap:8px; margin-top:4px;}
.sihua-chip{font-size:12.5px; padding:5px 10px; border-radius:8px; letter-spacing:.02em; background:rgba(255,255,255,.04); border:1px solid var(--line);}
.sihua-chip .hh{font-weight:700; margin-right:4px;}
.extra-cta{text-align:center; margin-top:30px; padding-top:26px; border-top:1px solid rgba(159,180,221,.12);}
.extra-cta .cta{max-width:420px; margin:0 auto 0;}
.extra-cta.destiny{margin-top:36px; padding:40px 24px 34px; border:1px solid rgba(201,168,106,.34); border-top:1px solid rgba(201,168,106,.34); border-radius:18px;
  background:linear-gradient(170deg,rgba(201,168,106,.1),rgba(159,180,221,.04));}
.extra-cta.destiny .en{font-family:"Cinzel",serif; font-size:11px; letter-spacing:.4em; color:var(--gold); display:block; margin-bottom:12px;}
.extra-cta.destiny h3{font-family:"Noto Serif TC",serif; font-size:clamp(24px,3vw,32px); letter-spacing:.14em; color:var(--paper); margin-bottom:14px;}
.extra-cta.destiny p{color:var(--txt2); font-size:14.5px; line-height:1.95; margin-bottom:8px;}
.extra-cta.destiny .cta{background:linear-gradient(135deg,var(--gold),#b08f50); color:#241c08;}
.extra-cta.destiny .navlink{color:var(--moon); text-decoration:underline; text-underline-offset:3px;}
.cta{margin-top:18px; width:100%; padding:16px; border:none; border-radius:13px; cursor:pointer;
  background:linear-gradient(135deg,var(--moon),var(--moon-d)); color:#16223a;
  font-family:"Noto Serif TC",serif; font-size:16px; letter-spacing:.32em; padding-left:.32em; font-weight:700;
  transition:.2s; box-shadow:0 16px 34px -16px rgba(111,134,180,.9);}
.cta:hover{transform:translateY(-1px); box-shadow:0 20px 40px -16px rgba(111,134,180,1);}
.hint{text-align:center; font-size:11.5px; color:var(--txt3); margin-top:12px; letter-spacing:.04em;}

/* ============================================================
   試閱頁
   ============================================================ */
.preview{max-width:980px; margin:0 auto; padding:clamp(26px,4vw,54px) clamp(18px,4vw,40px) 90px;}
.tool-back{margin:0 0 14px;} .tool-back a{color:var(--txt3); font-size:13px; letter-spacing:.06em;} .tool-back a:hover{color:var(--txt);}
.preview-head{text-align:center; margin-bottom:8px;}
.preview-head .en{font-size:11px; color:var(--moon); display:block; margin-bottom:14px;}
.preview-head h2{font-family:"Noto Serif TC",serif; font-size:clamp(26px,3.4vw,38px); letter-spacing:.1em; color:var(--paper); margin-bottom:14px;}
.preview-head p{color:var(--txt2); font-size:15px; letter-spacing:.03em; max-width:34em; margin:0 auto;}
.group-title{display:flex; align-items:baseline; gap:14px; margin:38px 0 4px; padding-bottom:10px; border-bottom:1px solid rgba(159,180,221,.14);}
.group-title span{font-family:"Noto Serif TC",serif; font-size:20px; letter-spacing:.16em; color:var(--paper);}
.group-title i{font-style:normal; font-size:12.5px; color:var(--txt3); letter-spacing:.06em;}
.topics{display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; margin:18px 0 8px;}
.product{display:flex; flex-direction:column; background:rgba(255,255,255,.04); border:1px solid var(--line); border-radius:14px; padding:22px 22px 18px; transition:.2s;}
.product:hover{border-color:#4a5d82; background:rgba(159,180,221,.06); transform:translateY(-2px);}
.product.feature{border-color:rgba(201,168,106,.5); background:linear-gradient(160deg,rgba(201,168,106,.08),rgba(159,180,221,.04));}
.product .ptag{font-family:"Cinzel",serif; font-size:11px; letter-spacing:.18em; color:var(--gold);}
.product h3{font-family:"Noto Serif TC",serif; font-size:20px; color:var(--paper); letter-spacing:.06em; margin:7px 0 10px;}
.product .pdesc{font-size:13.5px; color:var(--txt2); line-height:1.95; flex:1;}
.product .pincl{font-size:12px; color:var(--txt3); margin-top:12px; letter-spacing:.03em; line-height:1.8;}
.product .pmeta{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:18px; padding-top:14px; border-top:1px dashed rgba(159,180,221,.16);}
.product .price{font-family:"Noto Serif TC",serif; font-size:15px; color:var(--moon); letter-spacing:.04em;}
.price.free, .uprice.free{color:#e0605a !important; font-weight:700;}
.price.free{border:1px solid rgba(224,96,90,.5); border-radius:20px; padding:2px 12px; font-size:13.5px;}
.product .price small{font-size:11px; color:var(--txt3); letter-spacing:.02em;}
.product .buy{border:none; cursor:pointer; padding:10px 22px; border-radius:9px; font-family:"Noto Serif TC",serif; font-size:14px; letter-spacing:.14em; padding-left:.14em;
  background:linear-gradient(135deg,var(--moon),var(--moon-d)); color:#16223a; font-weight:700; transition:.18s;}
.product .buy:hover{transform:translateY(-1px);}
.product.feature .buy{background:linear-gradient(135deg,var(--gold),#b08f50);}
.topic{position:relative; background:rgba(255,255,255,.04); border:1px solid var(--line); border-radius:14px; padding:20px 20px 18px; overflow:hidden;}
.topic .tnum{font-family:"Cinzel",serif; font-size:12px; color:var(--gold); letter-spacing:.2em;}
.topic h3{font-family:"Noto Serif TC",serif; font-size:18px; color:var(--paper); letter-spacing:.08em; margin:6px 0 10px;}
.topic .ttease{font-size:13.5px; color:var(--txt2); line-height:1.9;}
.topic .blur{filter:blur(4px); opacity:.55; user-select:none; pointer-events:none;}
.topic .lock{display:inline-flex; align-items:center; gap:6px; margin-top:12px; font-size:12px; color:var(--txt3); letter-spacing:.06em;}
.unlock-card{max-width:460px; margin:24px auto 0; padding:26px 26px 22px; text-align:center;
  background:linear-gradient(160deg,rgba(201,168,106,.1),rgba(159,180,221,.05));
  border:1px solid rgba(201,168,106,.4); border-radius:16px;}
.unlock-card .ulock{font-size:13px; color:var(--txt2); letter-spacing:.04em; margin-bottom:14px;}
.unlock-card .uprice{font-family:"Noto Serif TC",serif; font-size:22px; color:var(--gold); letter-spacing:.06em; margin-bottom:16px;}
.unlock-card .cta{background:linear-gradient(135deg,var(--gold),#b08f50); color:#241c08; max-width:340px; margin:0 auto;}
.preview-cta{text-align:center; margin-top:14px;}
/* AI 完整報告 */
.report-body{display:flex; flex-direction:column; gap:20px;}
.report-body .rsec{background:rgba(255,255,255,.035); border:1px solid var(--line); border-radius:14px; padding:22px 24px;}
.report-body .rsec h3{font-family:"Noto Serif TC",serif; font-size:19px; letter-spacing:.1em; color:var(--paper); margin-bottom:12px; padding-bottom:10px; border-bottom:1px solid rgba(159,180,221,.16);}
.report-body .rtext{font-size:15px; line-height:2.05; color:var(--txt); letter-spacing:.02em;}
#pv-report-status{font-style:normal; color:var(--moon); font-size:13px;}
.report-head{text-align:center; margin-bottom:24px; padding-bottom:20px; border-bottom:1px solid rgba(159,180,221,.16);}
.report-head .rh-banner{max-width:420px; width:80%; height:auto; margin:0 auto 10px; display:block;}
.report-head .rh-brand{font-family:"Cinzel",serif; font-size:11px; letter-spacing:.4em; color:var(--gold);}
.report-head h2{font-family:"Noto Serif TC",serif; font-size:clamp(22px,2.6vw,28px); letter-spacing:.12em; color:var(--paper); margin:10px 0 8px;}
.report-head .rh-meta{font-size:13px; color:var(--txt3); letter-spacing:.05em;}
.report-link{margin-top:22px; text-align:center; font-size:12.5px; color:var(--txt3); letter-spacing:.03em; line-height:2;}
.report-link .rlink{display:inline-block; max-width:100%; overflow-wrap:anywhere; color:var(--moon); background:rgba(159,180,221,.08); border:1px solid var(--line); border-radius:8px; padding:4px 10px; font-size:11.5px;}
.report-link .rlink-copy{margin-left:8px; cursor:pointer; border:1px solid var(--line); background:rgba(255,255,255,.05); color:var(--txt2); border-radius:7px; padding:4px 12px; font-size:12px;}
.report-link .rlink-copy:hover{color:var(--txt);}
.report-actions{text-align:center; margin-top:26px;}
.report-actions .cta{max-width:340px; margin:0 auto;}
.report-head .rh-banner{display:none;}   /* 螢幕上不顯示 banner，只在列印 PDF 顯示 */

/* ============================================================
   列印 / 另存 PDF — 比照 App 水墨 PDF 版面
   象牙米底 #ECE6D6・墨藍字 #26344C・tan 線 #C3B9A3・硃紅 #A23B2E・封面紫 #4E2E7A
   ============================================================ */
@media print {
  @page { margin: 14mm 13mm; }
  html, body {
    background:#ECE6D6 !important; color:#26344C !important;
    -webkit-print-color-adjust:exact; print-color-adjust:exact;
  }
  .nav, .foot, .loading, .no-print,
  #view-input, #view-result, #view-products,
  #pv-tag, #pv-title, #pv-desc, #pv-sections, #pv-cta { display:none !important; }
  #view-preview, #pv-report-wrap, .preview { display:block !important; }
  .preview { max-width:none; padding:0; }

  /* 封面式抬頭（含 banner）：自成一頁 */
  .report-head { text-align:center; padding:0 0 22px; margin-bottom:24px;
    border-bottom:2px solid #C3B9A3; page-break-after:auto; }
  .report-head .rh-banner { display:block !important; width:100%; max-width:none; margin:0 0 22px; }
  .report-head .rh-brand { font-family:"Cinzel",serif; color:#9A86BE; letter-spacing:.4em; font-size:11px; }
  .report-head h2 { font-family:"Noto Serif TC",serif; color:#4E2E7A; font-size:24px; letter-spacing:.2em; margin:12px 0 10px; }
  .report-head .rh-meta { color:#26344C; font-size:13px; letter-spacing:.08em; }

  /* 內文章節：紅左槓 + 墨藍粗標題 + tan 底線（比照 _sectionTitle）*/
  .report-body { gap:0; }
  .report-body .rsec { background:transparent !important; border:none !important;
    border-radius:0; padding:12px 0 18px; page-break-inside:avoid; }
  .report-body .rsec h3 { font-family:"Noto Serif TC",serif; color:#26344C !important;
    font-size:16px; font-weight:700; letter-spacing:.22em; padding:0 0 8px 12px; margin-bottom:12px;
    border-bottom:1px solid #C3B9A3; position:relative; }
  .report-body .rsec h3::before { content:""; position:absolute; left:0; top:1px;
    width:4px; height:17px; background:#A23B2E; }
  .report-body .rtext { color:#26344C !important; font-size:12.5px; line-height:1.95;
    letter-spacing:.02em; text-align:justify; }

  /* 姓名學資料區（八字＋五格三才）列印：象牙底、墨藍字 */
  #pv-namedata { gap:14px; margin-bottom:16px; }
  .nd-sec { background:transparent !important; border:none !important; border-radius:0; padding:8px 0 14px; page-break-inside:avoid; }
  .nd-sec h3 { font-family:"Noto Serif TC",serif; color:#26344C !important; font-size:15px; font-weight:700; letter-spacing:.2em; padding:0 0 8px 12px; border-bottom:1px solid #C3B9A3; position:relative; }
  .nd-sec h3::before { content:""; position:absolute; left:0; top:1px; width:4px; height:16px; background:#A23B2E; }
  .nd-pillar { background:#e7e0cd !important; border:1px solid #C3B9A3 !important; }
  .nd-pillar .ndp-l { color:#8A7F68; } .nd-pillar .ndp-gz { color:#26344C; } .nd-pillar .ndp-g { color:#8a6a2a; }
  .nd-kv span, .nd-ge .ndg-l, .nd-sancai { color:#8A7F68 !important; }
  .nd-kv b { color:#4E2E7A !important; }
  .nd-char .ndc-c, .nd-ge .ndg-n, .nd-ge .ndg-wx, .nd-sancai b, .nd-det .ndd-h { color:#26344C !important; }
  .nd-char .ndc-n, .nd-det .ndd-d { color:#8A7F68 !important; }
  .lv-good { color:#2e7d44 !important; } .lv-mid { color:#cc8e26 !important; } .lv-bad { color:#A23B2E !important; }

  /* 八字四柱 列印 */
  #pv-namedata .bazi-grid .pillar { background:#e7e0cd !important; border:1px solid #C3B9A3 !important; }
  #pv-namedata .pillar .plabel { color:#8A7F68 !important; }
  #pv-namedata .pillar .pgod { color:#8a6a2a !important; }
  #pv-namedata .pillar .pgan, #pv-namedata .pillar .pzhi { color:#26344C !important; }
  #pv-namedata .pillar .phidden, #pv-namedata .pillar .pnayin { color:#8A7F68 !important; }
  #pv-namedata .pillar.day { border-color:#A23B2E !important; }
  /* 流年四化 chip 列印 */
  #pv-namedata .sihua-chip { background:#efe9da !important; border:1px solid #C3B9A3 !important; color:#26344C !important; }
  /* 紫微方陣 列印：自成一頁、象牙底墨藍字 */
  .nd-ziwei { page-break-before:always; }
  #pv-namedata .ziwei-grid .pcell { background:#f1ead9 !important; border:1px solid #C3B9A3 !important; }
  #pv-namedata .pcell .pname { color:#8A7F68 !important; }
  #pv-namedata .pcell .pgz { color:#9a8455 !important; }
  #pv-namedata .pcell .star { color:#26344C !important; }
  #pv-namedata .pcell .star .br { color:#8A7F68 !important; }
  #pv-namedata .pcell .mstar { color:#4E2E7A !important; }
  #pv-namedata .pcell .pdecadal { color:#8A7F68 !important; }
  #pv-namedata .pcell.ming { border-color:#A23B2E !important; }
  #pv-namedata .pcell.ming .pname { color:#A23B2E !important; }
  #pv-namedata .pcenter { background:#e7e0cd !important; border:1px solid #C3B9A3 !important; }
  #pv-namedata .pcenter .ctt { color:#26344C !important; }
  #pv-namedata .pcenter .cmeta { color:#5a5446 !important; }
  #pv-namedata .pcenter .cmeta b { color:#4E2E7A !important; }
}
.preview-cta .note{font-size:12.5px; color:var(--txt3); margin-top:14px; letter-spacing:.04em;}
.preview-cta .cta{max-width:380px; margin:0 auto;}

/* 確認框（姓名學分析前）*/
.modal{position:fixed; inset:0; z-index:120; display:flex; align-items:center; justify-content:center; padding:20px; background:rgba(10,14,22,.72); backdrop-filter:blur(4px);}
.modal-card{width:100%; max-width:440px; background:linear-gradient(180deg,#1e2c47,#172238); border:1px solid var(--line); border-radius:18px; padding:28px 26px 22px; box-shadow:0 30px 70px -20px #000;}
.modal-title{font-family:"Noto Serif TC",serif; font-size:20px; letter-spacing:.1em; color:var(--paper); margin-bottom:8px;}
.modal-sub{font-size:13px; color:var(--txt3); line-height:1.8; margin-bottom:18px;}
.modal-kv{display:flex; gap:12px; padding:9px 0; border-bottom:1px dashed rgba(159,180,221,.14); font-size:14px;}
.modal-kv span{color:var(--txt3); min-width:42px;} .modal-kv b{color:var(--txt); font-weight:500;}
.modal-field{margin-top:16px;}
.modal-field .flabel{display:block; color:#cdd6e8; margin-bottom:8px;}
.modal-field .inp{background:#fbf8ef; border-color:#bfb59d;}
.modal-hint{font-size:11.5px; color:var(--txt3); margin-top:7px; letter-spacing:.02em;}
.modal-actions{display:flex; gap:10px; margin-top:20px;}
.modal-actions .mbtn{flex:1; margin-top:0;}
.modal-actions .mbtn-ghost{flex:0 0 auto; padding:0 22px; border-radius:12px; border:1px solid var(--line); background:transparent; color:var(--txt2); cursor:pointer; font-family:"Noto Serif TC",serif; letter-spacing:.1em;}
.modal-actions .mbtn-ghost:hover{color:var(--txt);}

/* 姓名學資料區（八字命局 + 五格三才）：螢幕 */
#pv-namedata{display:flex; flex-direction:column; gap:18px; margin-bottom:20px;}
.nd-sec{background:rgba(255,255,255,.035); border:1px solid var(--line); border-radius:14px; padding:18px 20px;}
.nd-sec h3{font-family:"Noto Serif TC",serif; font-size:16px; letter-spacing:.14em; color:var(--paper); padding-bottom:10px; margin-bottom:14px; border-bottom:1px solid rgba(159,180,221,.16);}
.nd-pillars{display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-bottom:12px;}
.nd-pillar{text-align:center; background:rgba(159,180,221,.05); border:1px solid var(--line); border-radius:10px; padding:10px 4px;}
.nd-pillar .ndp-l{font-size:11px; color:var(--txt3); letter-spacing:.1em;}
.nd-pillar .ndp-gz{font-family:"Noto Serif TC",serif; font-size:22px; color:var(--paper); margin:4px 0;}
.nd-pillar .ndp-g{font-size:11px; color:var(--gold);}
.nd-kv{display:flex; justify-content:space-between; gap:12px; padding:7px 2px; border-bottom:1px dashed rgba(159,180,221,.12); font-size:13.5px;}
.nd-kv span{color:var(--txt3);} .nd-kv b{color:var(--moon); font-weight:500; text-align:right;}
.nd-chars{display:flex; gap:6px; justify-content:center; margin-bottom:14px;}
.nd-char{flex:0 0 auto; text-align:center; padding:0 10px;}
.nd-char .ndc-c{font-family:"Noto Serif TC",serif; font-size:30px; color:var(--paper);}
.nd-char .ndc-n{font-size:11px; color:var(--txt3); margin-top:2px;}
.nd-ges{display:flex; flex-direction:column; gap:7px; border-top:1px solid rgba(159,180,221,.12); padding-top:12px;}
.nd-ge{display:flex; align-items:center; gap:12px;}
.nd-ge .ndg-l{width:44px; color:var(--txt3); font-size:13px;}
.nd-ge .ndg-n{width:40px; font-family:"Noto Serif TC",serif; font-size:17px; color:var(--paper);}
.nd-ge .ndg-wx{width:24px; font-size:14px; color:var(--txt);}
.nd-sancai{margin-top:12px; padding-top:12px; border-top:1px solid rgba(159,180,221,.12); font-size:14px; color:var(--txt3);}
.nd-sancai b{font-family:"Noto Serif TC",serif; font-size:18px; color:var(--paper); letter-spacing:.18em; margin:0 8px;}
.nd-lv{font-size:10.5px; padding:1px 8px; border-radius:9px; border:1px solid currentColor; margin-left:8px;}
.lv-good{color:var(--lu);} .lv-mid{color:#d8be7a;} .lv-bad{color:var(--ji);}
.nd-details{margin-top:14px; display:flex; flex-direction:column; gap:9px;}
.nd-det .ndd-h{font-size:13.5px; color:var(--paper);}
.nd-det .ndd-d{font-size:12px; color:var(--txt3); line-height:1.7; margin-top:3px;}

/* 載入動畫 */
.loading{position:fixed; inset:0; z-index:99; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:22px; background:rgba(20,29,48,.9); backdrop-filter:blur(4px);}
.loading .taiji{width:56px; height:56px; animation:spin 4s linear infinite;}
.loading .ltxt{font-family:"Noto Serif TC",serif; letter-spacing:.4em; color:var(--txt2); font-size:14px; padding-left:.4em;}

/* 頁尾 */
.foot{border-top:1px solid rgba(159,180,221,.1); padding:30px clamp(20px,5vw,48px); text-align:center; color:var(--txt3); font-size:12px; letter-spacing:.05em;}
.foot a{color:var(--txt3); text-decoration:underline; text-underline-offset:3px;}

/* ============================================================
   響應式
   ============================================================ */
@media (max-width:920px){
  .hero-inner{grid-template-columns:1fr; gap:34px;}
  .hero .moon{width:240px; height:240px; top:-60px;}
  .result-grid{grid-template-columns:1fr;}
  .ziwei-grid{max-width:560px; margin:0 auto;}
}
@media (max-width:560px){
  .form-grid{grid-template-columns:1fr;}
  .pillar .pgan, .pillar .pzhi{font-size:24px;}
  .pcell .star{font-size:12.5px;}
  .pcell .pname{font-size:11px;}
}
