/* ===== 中華民國道教會 — 站點二風格套版設計系統 ===== */
:root{
  --purple:#4A3C5E; --purple-d:#3E3251; --purple-l:#6E5C86; --purple-veil:#2E2440;
  --seal:#A63A2B; --sealink:#8F3020;
  --paper:#FFFFFF; --beige:#EFE8D8; --beige2:#F4EFE4; --card:#FBF9F3;
  --ink:#33302E; --ink2:#544F49; --ink3:#8A857D; --line:#DFD7C6;
  --serif:"Songti TC","Noto Serif TC",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang TC","Noto Sans TC","Microsoft JhengHei",sans-serif;
}
:root[data-theme="light"],:root[data-theme="dark"]{color-scheme:light}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);line-height:1.8;background:var(--paper);
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ===== header ===== */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:saturate(120%) blur(8px);border-bottom:1px solid var(--line)}
.bar{max-width:1120px;margin:0 auto;display:flex;align-items:center;gap:16px;padding:11px 20px}
.brand{display:flex;align-items:center;gap:11px;min-height:44px}
.marklogo{width:44px;height:44px;flex:none;display:block}
.brand b{font-family:var(--serif);font-size:16px;letter-spacing:.06em;line-height:1.15;font-weight:700}
.brand b span{display:block;font-size:11px;color:var(--ink3);letter-spacing:.14em;font-weight:400}
nav{margin-left:auto;display:flex;align-items:center;gap:2px}
nav a{font-size:14.5px;padding:10px 13px;min-height:44px;display:inline-flex;align-items:center;color:var(--ink2);letter-spacing:.03em;transition:color .2s}
nav a:hover,nav a.on{color:var(--purple)}
nav a.on{font-weight:700}
nav a.caret::after{content:"▾";font-size:10px;margin-left:4px;color:var(--ink3)}
.login{margin-left:6px;display:inline-flex;align-items:center;gap:6px;color:var(--purple);font-size:14px;border:1px solid var(--line);border-radius:999px;padding:7px 14px;min-height:40px}
.login::before{content:"";width:15px;height:15px;border-radius:50%;border:1.5px solid var(--purple)}
.burger{display:none;margin-left:auto;width:44px;height:44px;border:1px solid var(--line);border-radius:8px;background:none;flex-direction:column;gap:4px;align-items:center;justify-content:center;cursor:pointer}
.burger span{width:20px;height:2px;background:var(--purple)}
.nav-t{position:absolute;left:-9999px}
.mobile-menu{display:none}

/* ===== hero (home) ===== */
.hero{position:relative;background:linear-gradient(115deg,#372B4C 0%,#4A3C5E 34%,#5A4A70 52%,#3F3255 72%,#2E2440 100%);overflow:hidden;padding:78px 20px 0;text-align:center}
.hero::before{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;background:radial-gradient(60% 42% at 68% 24%,rgba(255,255,255,.16),transparent 62%),radial-gradient(50% 40% at 24% 74%,rgba(20,12,32,.5),transparent 60%),repeating-linear-gradient(118deg,rgba(255,255,255,.03) 0 10px,rgba(0,0,0,.03) 10px 22px)}
.hero-in{position:relative;z-index:2;max-width:900px;margin:0 auto;padding-bottom:96px}
.seal{display:inline-block;vertical-align:middle;width:52px;height:52px;background:var(--seal);border-radius:5px;box-shadow:0 2px 10px rgba(0,0,0,.25);margin-right:6px;transform:translateY(-14px)}
.htitle{display:inline-block;font-family:var(--serif);color:#fff;font-weight:700;font-size:clamp(46px,12vw,96px);letter-spacing:.18em;text-shadow:0 3px 20px rgba(0,0,0,.35);line-height:1}
.hsub{color:rgba(255,255,255,.92);font-family:var(--serif);font-size:clamp(18px,4.4vw,30px);letter-spacing:.3em;margin-top:26px;text-shadow:0 2px 12px rgba(0,0,0,.35)}
.brush{position:absolute;left:0;right:0;bottom:-1px;z-index:1;width:100%;display:block}

/* ===== page hero (slim, inner pages) ===== */
.phero{position:relative;background:linear-gradient(115deg,#372B4C,#4A3C5E 48%,#3F3255);color:#fff;padding:38px 20px 44px;overflow:hidden;text-align:center}
.phero::before{content:"";position:absolute;inset:0;opacity:.4;background:radial-gradient(50% 60% at 72% 20%,rgba(255,255,255,.14),transparent 60%),repeating-linear-gradient(118deg,rgba(255,255,255,.03) 0 10px,rgba(0,0,0,.03) 10px 22px)}
.phero .crumb{position:relative;z-index:2;font-size:12.5px;color:rgba(255,255,255,.75);letter-spacing:.08em}
.phero .crumb a:hover{color:#fff}
.phero .kb{position:relative;z-index:2;display:inline-block;font-size:12px;letter-spacing:.28em;color:#D8C89A;margin:12px 0 8px;border:1px solid rgba(216,200,154,.5);border-radius:999px;padding:4px 14px}
.phero h1{position:relative;z-index:2;font-family:var(--serif);font-size:clamp(30px,6.6vw,44px);letter-spacing:.13em;font-weight:700;margin-top:8px}
.phero .en{position:relative;z-index:2;color:rgba(255,255,255,.7);font-size:13px;letter-spacing:.28em;margin-top:8px}

/* ===== watermark ===== */
.wm{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;user-select:none}
.wm span{position:absolute;font-family:var(--serif);color:rgba(74,60,94,.05);font-weight:700;white-space:nowrap;writing-mode:vertical-rl;letter-spacing:.3em}

/* ===== sections ===== */
section{position:relative}
.sec-in{max-width:1120px;margin:0 auto;padding:64px 20px;position:relative;z-index:2}
.stitle{text-align:center;margin-bottom:38px}
.stitle h2{font-family:var(--serif);font-size:clamp(26px,5vw,34px);font-weight:700;letter-spacing:.08em}
.stitle .sub{font-family:var(--serif);color:var(--purple-l);font-size:16px;letter-spacing:.2em;margin-top:6px}
.btn{display:inline-block;background:var(--purple-d);color:#fff;font-size:15px;letter-spacing:.16em;padding:13px 30px;border-radius:2px;transition:background .2s,transform .1s}
.btn:hover{background:var(--purple)}
.btn:active{transform:translateY(1px)}
.btn.sm{font-size:14px;padding:11px 22px;letter-spacing:.14em}
.btn.gold{background:#C79A3C;color:#2E2440}.btn.gold:hover{background:#d6ab4d}

/* 本會簡介 */
.intro{background:var(--paper)}
.intro .body{max-width:760px;margin:0 auto;text-align:justify;color:var(--ink2);font-size:16px}
.intro .body p+p{margin-top:18px}
.intro .more{text-align:right;max-width:760px;margin:26px auto 0}

/* 三欄卡片 */
.feeds{background:var(--beige)}
.feed-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.feed h3{font-family:var(--serif);font-size:20px;font-weight:700;letter-spacing:.06em;padding-bottom:12px;border-bottom:2px solid var(--purple);display:inline-block}
.feed .date{display:flex;align-items:baseline;gap:8px;margin:16px 0 12px}
.feed .d{font-family:var(--serif);font-size:34px;font-weight:700;color:var(--purple);line-height:1}
.feed .ym{font-size:12px;color:var(--ink3);line-height:1.3}
.feed p{color:var(--ink2);font-size:14px;line-height:1.85}
.feed .link{display:inline-flex;align-items:center;gap:8px;color:var(--purple);font-size:14px;margin:14px 0 18px}
.feed .link .yy{width:17px;height:17px;border-radius:50%;background:conic-gradient(from 90deg,var(--purple) 0 50%,#cfc7dd 50% 100%);flex:none}

/* deity gallery (home + list) */
.dgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px 22px;max-width:960px;margin:0 auto}
.dcard,.g{text-align:center}
.dcard .ph,.g .ph{width:100%;aspect-ratio:1;border-radius:50%;position:relative;overflow:hidden;background:linear-gradient(150deg,#5A4A70,#3E3251);box-shadow:0 6px 18px rgba(62,50,81,.25);display:grid;place-items:center;transition:transform .2s,box-shadow .2s}
.g:hover .ph{transform:translateY(-4px);box-shadow:0 12px 28px rgba(62,50,81,.4)}
.dcard .ph .glyph,.g .ph .glyph{font-family:var(--serif);font-size:clamp(28px,4vw,36px);color:rgba(255,255,255,.92);font-weight:700}
.dcard .ph::after,.g .ph::after{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid rgba(255,255,255,.22)}
.dcard .nm,.g .nm{font-family:var(--serif);font-size:16px;margin-top:13px;font-weight:700}
.g:hover .nm{color:var(--purple)}
.dcard .en,.g .en{font-size:10.5px;color:var(--ink3);letter-spacing:.08em;margin-top:2px}

/* toolbar (list) */
.toolbar{background:var(--beige2);border-bottom:1px solid var(--line)}
.toolbar .in{max-width:1120px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.toolbar .cnt{font-size:13.5px;color:var(--ink3)}
.toolbar .cnt b{color:var(--purple);font-family:var(--serif);font-size:17px}
.chips{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.chips a{font-size:13px;padding:6px 14px;border-radius:999px;border:1px solid var(--line);color:var(--ink2);transition:all .2s}
.chips a.on,.chips a:hover{background:var(--purple);color:#fff;border-color:var(--purple)}

/* article list (knowledge/events text list) */
.alist{max-width:820px;margin:0 auto}
.arow{display:block;padding:20px 4px;border-bottom:1px solid var(--line);transition:background .15s}
.arow:hover{background:var(--beige2)}
.arow .at{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--ink)}
.arow:hover .at{color:var(--purple)}
.arow .ax{color:var(--ink2);font-size:14px;margin-top:6px;line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.arow .am{font-size:12px;color:var(--ink3);letter-spacing:.06em;margin-top:8px}

/* grid wrapper for list pages */
.gridwrap{max-width:1120px;margin:0 auto;padding:40px 20px 20px;display:grid;grid-template-columns:repeat(4,1fr);gap:26px 22px}

/* pager */
.pager{max-width:1120px;margin:0 auto;padding:24px 20px 40px;display:flex;justify-content:center;align-items:center;gap:6px}
.pager a,.pager span{min-width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:8px;font-size:14px;color:var(--ink2)}
.pager .on{background:var(--purple);color:#fff;border-color:var(--purple)}
.pager a:hover{border-color:var(--purple);color:var(--purple)}

/* article (content page) */
.wrap{max-width:1080px;margin:0 auto;padding:52px 20px 20px;display:grid;grid-template-columns:1fr 250px;gap:48px}
article{position:relative;min-width:0}
article .lead-in{position:relative;z-index:1;color:var(--ink2);font-size:15px;border-left:3px solid var(--purple);padding:2px 0 2px 16px;margin-bottom:26px;line-height:1.7}
article p{position:relative;z-index:1;font-size:16.5px;color:var(--ink);margin-bottom:20px;text-align:justify;line-height:2}
article p.first::first-letter{font-family:var(--serif);font-size:3.4em;float:left;line-height:.86;color:var(--purple);font-weight:700;margin:6px 12px 0 0}
article h2.sub{font-family:var(--serif);font-size:22px;color:var(--purple-d);margin:34px 0 14px;letter-spacing:.05em;padding-left:14px;border-left:4px solid var(--seal)}
.source{position:relative;z-index:1;margin-top:30px;padding:14px 16px;background:var(--beige2);border-radius:8px;font-size:13px;color:var(--ink3);border:1px solid var(--line)}
aside{position:relative}
.side-box{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px 16px;margin-bottom:20px}
.side-box h3{font-family:var(--serif);font-size:16px;font-weight:700;padding-bottom:10px;border-bottom:2px solid var(--purple);margin-bottom:12px}
.side-box .dlink{display:flex;align-items:center;gap:11px;padding:8px 0;border-bottom:1px dashed var(--line)}
.side-box .dlink:last-child{border-bottom:0}
.side-box .dot{width:34px;height:34px;border-radius:50%;background:linear-gradient(150deg,#5A4A70,#3E3251);flex:none;display:grid;place-items:center;font-family:var(--serif);font-size:13px;color:#fff}
.side-box .dlink .t{font-size:14.5px}
.side-box .dlink .t small{display:block;color:var(--ink3);font-size:11px;letter-spacing:.06em}
.side-box .dlink:hover .t{color:var(--purple)}
.side-cta{text-align:center}
.side-cta p{font-size:13.5px;color:var(--ink2);margin-bottom:14px;line-height:1.75}

/* simple prose (about/school/contact) */
.prose{max-width:800px;margin:0 auto;padding:52px 20px}
.prose h2{font-family:var(--serif);font-size:24px;color:var(--purple-d);margin:32px 0 14px;letter-spacing:.05em;padding-left:14px;border-left:4px solid var(--seal)}
.prose h2:first-child{margin-top:0}
.prose p{font-size:16px;color:var(--ink2);margin-bottom:18px;text-align:justify;line-height:2}
.prose .card-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:20px 0}
.prose .icard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:20px 18px}
.prose .icard h3{font-family:var(--serif);font-size:18px;color:var(--purple);margin-bottom:8px}
.prose .icard p{font-size:14px;margin:0;color:var(--ink2)}
.contact-info{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:22px;margin-top:20px}
.contact-info .row{display:flex;gap:12px;padding:10px 0;border-bottom:1px dashed var(--line);font-size:15px}
.contact-info .row:last-child{border-bottom:0}
.contact-info .row b{font-family:var(--serif);color:var(--purple);min-width:80px}
.contact-info a{color:var(--seal);text-decoration:underline;text-underline-offset:3px}

/* academy CTA band */
.academy{background:linear-gradient(120deg,#3E3251,#4A3C5E);color:#fff;text-align:center}
.academy .sec-in{padding-top:58px;padding-bottom:58px}
.academy h2{font-family:var(--serif);font-size:clamp(24px,5vw,32px);letter-spacing:.1em}
.academy p{color:rgba(255,255,255,.82);max-width:600px;margin:16px auto 0;font-size:15.5px}
.academy .courses{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:26px 0 30px}
.academy .courses span{border:1px solid rgba(255,255,255,.35);border-radius:999px;padding:8px 18px;font-size:14px;letter-spacing:.06em}

/* footer */
footer{background:#2A2338;color:#CFC7DD;text-align:center;padding:40px 20px 46px}
footer .footmark{width:66px;height:66px;margin:0 auto 14px;display:block}
footer .flogo{font-family:var(--serif);font-size:19px;color:#fff;font-weight:700;letter-spacing:.08em}
footer .fsub{font-size:12px;color:#9C93B4;letter-spacing:.14em;margin-top:4px}
footer .finfo{font-size:13px;line-height:2;margin-top:18px}
footer .finfo b{color:#fff;font-weight:400;margin-right:6px}
footer .finfo a{color:#CFC7DD}
footer .foot-legal{border-top:1px solid rgba(255,255,255,.12);margin-top:22px;padding-top:16px;font-size:11.5px;color:#877E9C}

/* ===== responsive ===== */
@media(max-width:820px){
  nav,.login{display:none}
  .burger{display:flex}
  .nav-t:checked~.mobile-menu{display:block;position:fixed;inset:56px 0 0;background:var(--paper);z-index:60;overflow-y:auto;padding:10px 0}
  .mobile-menu a{display:block;padding:15px 24px;font-size:16px;border-bottom:1px solid var(--line);color:var(--ink)}
  .mobile-menu a:active{background:var(--beige)}
  .feed-grid{grid-template-columns:1fr;gap:34px}
  .dgrid,.gridwrap{grid-template-columns:repeat(2,1fr);gap:26px 18px}
  .gridwrap{padding:32px 20px 12px}
  .sec-in{padding:48px 20px}
  .hero{padding-top:52px}.hero-in{padding-bottom:70px}
  .brand b span{display:none}
  .wrap{grid-template-columns:1fr;gap:36px;padding-top:38px}
  aside{order:2}
}
@media(max-width:400px){.dgrid,.gridwrap{gap:20px 14px}.htitle{letter-spacing:.12em}}
