/* 新思惟線上課程 — 編輯/期刊風（"圖與圖說" 視覺語言）
   襯線大標 + 紙感底色 + 細線分隔 + mono 數字/圖說；刻意不用漸層 hero、膠囊、三欄卡片模板 */
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+TC:wght@500;700;900&family=Noto+Sans+TC:wght@300;400;500;700&family=Roboto+Mono:wght@400;500&display=swap');

:root{
  --paper:#faf8f3; --paper-2:#f2eee4; --card:#ffffff;
  --ink:#181a1f; --ink-soft:#3a3d45; --muted:#71727a;
  --line:#e3ddd0; --line-strong:#c9c2b2;
  --brand:#14514a; --brand-2:#0e3b35; --accent:#b0642a; --ok:#2f7d5b; --danger:#b23a2e;
  --serif:"Noto Serif TC",Georgia,serif;
  --sans:"Noto Sans TC","PingFang TC","Microsoft JhengHei",system-ui,sans-serif;
  --mono:"Roboto Mono",ui-monospace,monospace;
  --maxw:1080px; --read:660px;
}
*{box-sizing:border-box}
html{scroll-padding-top:84px}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  line-height:1.85;font-size:17px;font-weight:400;-webkit-font-smoothing:antialiased}
a{color:var(--brand)}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.read{max-width:var(--read);margin-left:auto;margin-right:auto}

/* 通用「圖說」小標：mono、字距、細線前綴 —— 全站的識別語彙 */
.kicker{font-family:var(--mono);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brand);display:inline-flex;align-items:center;gap:10px;margin:0 0 18px}
.kicker::before{content:"";width:30px;height:1px;background:var(--brand)}
.caption{font-family:var(--mono);font-size:.8rem;color:var(--muted);letter-spacing:.02em}

/* nav：細、克制、無膠囊 */
.nav{position:sticky;top:0;z-index:50;background:rgba(250,248,243,.9);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;gap:22px;height:68px;max-width:var(--maxw);margin:0 auto;padding:0 26px}
.brand{font-family:var(--serif);font-weight:900;color:var(--ink);text-decoration:none;font-size:1.12rem;letter-spacing:.02em}
.brand small{display:block;font-family:var(--mono);font-weight:400;color:var(--muted);font-size:.62rem;letter-spacing:.32em;margin-top:1px}
.nav-sp{flex:1}
.nav a.link{color:var(--ink-soft);text-decoration:none;font-size:.92rem;letter-spacing:.02em}
.nav a.link:hover{color:var(--brand)}

/* 按鈕：方正(6px)、實色、克制 —— 不用膠囊(膠囊=模板味) */
.btn{display:inline-block;border:1px solid transparent;border-radius:6px;padding:12px 24px;
  font-size:.96rem;font-weight:700;font-family:var(--sans);cursor:pointer;text-decoration:none;transition:.16s;letter-spacing:.02em}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--brand)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--ink);color:var(--brand)}
.btn-block{display:block;width:100%;text-align:center}
.btn-lg{padding:15px 32px;font-size:1.02rem}
.nav a.link+.btn{margin-left:6px}

/* hero：紙感、無漸層、大襯線標題 + 圖說 */
.hero{background:var(--paper);border-bottom:1px solid var(--line);position:relative}
.hero-in{padding:84px 0 72px;max-width:820px}
.hero h1{font-family:var(--serif);font-weight:900;font-size:3rem;line-height:1.24;margin:0 0 22px;letter-spacing:.01em;color:var(--ink)}
.hero .fig-cap{border-left:2px solid var(--brand);padding-left:16px;margin:0 0 34px}
.hero .fig-cap .caption{display:block;margin-bottom:4px}
.hero .fig-cap p{font-size:1.16rem;color:var(--ink-soft);margin:0;max-width:600px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero .signoff{font-family:var(--mono);font-size:.8rem;color:var(--muted);margin-top:26px;letter-spacing:.03em}
.pill{display:none} /* 廢除膠囊；改用 .kicker */
.hero .status{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);margin:0 0 20px;display:flex;align-items:center;gap:8px}
.hero .status::before{content:"●";font-size:.6rem}

/* sections：編號「圖 0X」+ 細線 */
section{padding:64px 0;border-bottom:1px solid var(--line)}
.section-soft{background:var(--paper-2)}
.sec-head{margin:0 0 40px;max-width:640px}
.sec-head h2{font-family:var(--serif);font-weight:700;font-size:1.9rem;margin:6px 0 8px;letter-spacing:.01em}
.sec-head .sub{color:var(--muted);margin:0;font-size:1.02rem}

/* 課程：編輯型目錄列（非 SaaS 卡片） */
.catalog{border-top:1px solid var(--line-strong)}
.entry{display:grid;grid-template-columns:auto 1fr auto;gap:26px;align-items:start;
  padding:30px 0;border-bottom:1px solid var(--line)}
.entry .idx{font-family:var(--mono);font-size:.82rem;color:var(--muted);padding-top:6px;letter-spacing:.05em}
.entry .main .tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);display:block;margin:0 0 8px}
.entry .main .tag.free{color:var(--accent)}
.entry h3{font-family:var(--serif);font-weight:700;font-size:1.5rem;margin:0 0 6px;line-height:1.35}
.entry .desc{color:var(--ink-soft);font-size:1rem;margin:8px 0 0;max-width:560px}
.entry .side{text-align:right;white-space:nowrap;padding-top:4px}
.entry .price{font-family:var(--mono);font-size:1.28rem;font-weight:500;color:var(--ink)}
.entry .price small{display:block;font-size:.7rem;color:var(--muted);letter-spacing:.05em;margin-bottom:12px}
.entry .side .btn{margin-top:6px}
.entry .dur{font-family:var(--mono);font-size:.78rem;color:var(--muted);margin-top:10px}

/* 怎麼上課：編號清單（非盒狀卡片） */
.numlist{border-top:1px solid var(--line)}
.numlist .row{display:grid;grid-template-columns:56px 1fr;gap:20px;padding:26px 0;border-bottom:1px solid var(--line);align-items:baseline}
.numlist .n{font-family:var(--mono);font-size:1.05rem;color:var(--brand);font-weight:500}
.numlist h4{font-family:var(--serif);font-weight:700;font-size:1.22rem;margin:0 0 6px}
.numlist p{margin:0;color:var(--ink-soft);font-size:.98rem;max-width:560px}

/* 我的課程：進度環 + 目錄式列 */
.mycourse{background:var(--card);border:1px solid var(--line-strong);border-radius:10px;padding:28px;margin-bottom:24px}
.mc-head{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.ring-wrap{position:relative;width:84px;height:84px;flex:0 0 auto}
.ring{width:84px;height:84px;border-radius:50%;
  background:conic-gradient(var(--brand) calc(var(--p,0)*1%),#e6e0d3 0)}
.ring::before{content:"";position:absolute;top:11px;left:11px;width:62px;height:62px;background:var(--card);border-radius:50%}
.ring-wrap b{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--mono);font-size:1rem;color:var(--brand);font-weight:500}
.mc-head h3{font-family:var(--serif);font-weight:700;margin:0 0 4px;font-size:1.34rem}
.mc-head .expire{font-family:var(--mono);font-size:.8rem;color:var(--muted);letter-spacing:.02em}
.mc-head .expire.soon{color:var(--accent);font-weight:500}
.mc-list{margin-top:20px;border-top:1px solid var(--line)}
.vrow{display:flex;align-items:center;gap:15px;padding:14px 0;border-bottom:1px solid var(--line)}
.vrow .chk{width:22px;height:22px;border-radius:50%;flex:0 0 auto;border:1.5px solid var(--line-strong);display:grid;place-items:center;font-size:.78rem;color:#fff}
.vrow .chk.done{background:var(--ok);border-color:var(--ok)}
.vrow .vt{flex:1;font-size:.98rem}
.vrow .vt small{display:block;color:var(--muted);font-family:var(--mono);font-size:.76rem;margin-top:1px}
.bar{height:5px;background:#e6e0d3;border-radius:99px;overflow:hidden;margin-top:6px;max-width:240px}
.bar i{display:block;height:100%;background:var(--brand)}
.vrow a.play{font-size:.86rem;white-space:nowrap;font-weight:700}
.banner-soon{background:#fbf1e4;border:1px solid #ecd7b8;color:#8a531c;border-radius:8px;
  padding:11px 16px;font-family:var(--mono);font-size:.84rem;margin-bottom:20px;letter-spacing:.01em}

/* 表單：紙感、細框、方正 */
.card{background:var(--card);border:1px solid var(--line-strong);border-radius:10px;padding:38px;max-width:480px;margin:0 auto}
.card h1{font-family:var(--serif);font-weight:900;font-size:1.7rem;margin:0 0 6px}
.card p.hint{color:var(--muted);font-size:.95rem;margin:0 0 26px}
label{display:block;font-weight:700;font-size:.86rem;margin:18px 0 7px;letter-spacing:.02em}
input[type=text],input[type=tel],input[type=email]{width:100%;padding:13px 15px;border:1px solid var(--line-strong);
  border-radius:6px;font-size:1rem;font-family:inherit;background:var(--paper)}
input:focus{outline:none;border-color:var(--brand);background:#fff}
.checkline{display:flex;gap:11px;align-items:flex-start;margin:20px 0;font-size:.9rem;color:var(--ink-soft)}
.checkline input{margin-top:4px}
.form-note{font-size:.82rem;color:var(--muted);margin-top:15px;line-height:1.7;font-family:var(--mono);letter-spacing:.01em}
.otp-row{display:flex;gap:10px}
.otp-row input{letter-spacing:8px;text-align:center;font-size:1.35rem;font-family:var(--mono)}

/* 價格卡（結帳） */
.buybox{background:var(--paper-2);border:1px solid var(--line);border-radius:8px;padding:18px;margin:8px 0}
.buybox strong{font-family:var(--serif);font-size:1.1rem}
.buybox .price{font-family:var(--mono);font-size:1.5rem;margin-top:8px;color:var(--ink)}

/* player */
.player-wrap{background:#111;border:1px solid var(--line-strong);border-radius:10px;overflow:hidden;aspect-ratio:16/9;display:grid;place-items:center;color:#fff}
.player-ph{text-align:center;color:#a9a196;padding:40px;font-family:var(--mono);font-size:.9rem;line-height:1.9}
.wm{position:absolute;color:rgba(255,255,255,.5);font-family:var(--mono);font-size:.85rem;pointer-events:none;text-shadow:0 1px 3px rgba(0,0,0,.6)}

/* footer */
.foot-site{border-top:1px solid var(--line-strong);background:var(--paper-2);padding:48px 0;margin-top:0;color:var(--muted);font-size:.9rem}
.foot-site a{color:var(--muted);text-decoration:none}
.foot-site a:hover{color:var(--brand)}
.foot-site .cols{display:flex;gap:56px;flex-wrap:wrap;margin-bottom:26px}
.foot-site h5{font-family:var(--mono);color:var(--ink);margin:0 0 12px;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500}
.foot-site ul{list-style:none;padding:0;margin:0}
.foot-site li{margin:7px 0}
.foot-site .copy{font-family:var(--mono);font-size:.78rem;letter-spacing:.03em}

/* 私訊：編輯風單欄對話（自己的訊息以品牌色左線標示） */
.msg-list{border-top:1px solid var(--line-strong);max-height:56vh;overflow-y:auto}
.msg{padding:16px 0 16px 14px;border-bottom:1px solid var(--line);border-left:2px solid transparent}
.msg.mine{border-left-color:var(--brand);background:linear-gradient(to right,rgba(20,81,74,.045),transparent 60%)}
.msg .who{font-family:var(--mono);font-size:.76rem;color:var(--muted);letter-spacing:.03em;margin-bottom:5px}
.msg.mine .who{color:var(--brand)}
.msg .mbody{white-space:pre-wrap;font-size:.98rem;color:var(--ink);line-height:1.8}
.composer{margin-top:22px}
.composer textarea{width:100%;padding:13px 15px;border:1px solid var(--line-strong);border-radius:6px;
  font-size:1rem;font-family:inherit;background:var(--paper);line-height:1.7;resize:vertical}
.composer textarea:focus{outline:none;border-color:var(--brand);background:#fff}
/* 私訊：對話列表（工作人員） */
.tlist{border-top:1px solid var(--line-strong)}
.trow{display:flex;align-items:baseline;gap:14px;padding:17px 2px;border-bottom:1px solid var(--line);
  text-decoration:none;color:var(--ink)}
.trow:hover{background:rgba(20,81,74,.03)}
.trow .tname{font-weight:700;white-space:nowrap}
.trow .tlast{flex:1;color:var(--muted);font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.trow .ttime{white-space:nowrap}
.ubadge{font-family:var(--mono);font-size:.74rem;background:var(--brand);color:#fff;border-radius:99px;
  padding:1px 9px;align-self:center}

/* legal */
.legal{max-width:var(--read);margin:0 auto;padding:48px 0}
.legal h1{font-family:var(--serif);font-weight:900;font-size:1.9rem}
.legal h2{font-family:var(--serif);font-weight:700;font-size:1.24rem;margin-top:34px}
.legal p,.legal li{color:var(--ink-soft);font-size:.99rem}

@media(min-width:720px){ .hero h1{font-size:3.4rem} }
@media(max-width:640px){
  .hero h1{font-size:2.15rem}.hero-in{padding:56px 0 48px}
  .entry{grid-template-columns:1fr;gap:10px}.entry .idx{display:none}
  .entry .side{text-align:left}.entry .side .btn{margin-top:12px}
  .nav a.link{display:none}
  .numlist .row{grid-template-columns:40px 1fr;gap:14px}
}

/* 向後相容別名（讓各頁 inline/JS 舊變數名仍可用） */
:root{--bg:var(--paper);--bg-soft:var(--paper-2);--warn:var(--accent);--brand-soft:var(--paper-2);--brand-dark:var(--brand-2)}
.sub{color:var(--muted)}
