/* =========================================================================
   GoEducation — 共用課程內頁元件樣式（搭配 site.css 使用）
   ========================================================================= */
/* hero */
.shero{position:relative;color:#fff;min-height:60vh;display:flex;align-items:center;overflow:hidden}
.shero .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.shero .scrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(25,12,22,.88),rgba(25,12,22,.5) 58%,rgba(25,12,22,.22))}
.shero .wrap{position:relative;width:100%;padding:80px 24px}
.shero .crumb{font-size:13px;color:rgba(255,255,255,.85);margin-bottom:14px}.shero .crumb a:hover{color:#fff}
.shero .badge{display:inline-block;background:var(--grad);color:#fff;font-family:var(--hd);font-weight:700;font-size:12px;padding:6px 14px;border-radius:var(--pill);margin-bottom:14px}
.shero h1{font-family:var(--hd);font-weight:800;font-size:clamp(32px,5vw,54px);line-height:1.1;margin:0 0 14px;letter-spacing:-.02em}
.shero h1 .em{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.shero p{font-size:17px;color:rgba(255,255,255,.92);max-width:560px;margin:0 0 26px}
.shero .ctas{display:flex;gap:12px;flex-wrap:wrap}
/* quick facts */
.qfacts{background:var(--cream);border-bottom:1px solid var(--line)}
.qfacts .wrap{display:grid;grid-template-columns:repeat(5,1fr)}
.qfacts .f{padding:20px 16px;text-align:center;border-right:1px solid var(--line)}.qfacts .f:last-child{border-right:0}
.qfacts .l{font-size:12px;color:var(--ink2);margin-bottom:5px}.qfacts .v{font-family:var(--hd);font-weight:700;font-size:16px}.qfacts .v.pri{color:var(--brand-d)}
/* shared text */
.lead2{font-size:16px;color:var(--ink2);max-width:680px;line-height:1.85}
/* highlight cards */
.hl{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.hl .c{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--sh1)}
.hl .c .ic{width:46px;height:46px;border-radius:13px;background:var(--cream);display:grid;place-items:center;font-size:22px;margin-bottom:12px}
.hl .c h3{font-family:var(--hd);font-size:16px;margin:0 0 6px}.hl .c p{margin:0;font-size:13.5px;color:var(--ink2)}
/* AI overview */
.ai-ov{background:linear-gradient(135deg,#fdeef5,#fff);border:1px solid #f3c7dd;border-radius:var(--r-lg);padding:24px 26px}
.ai-ov .h{display:flex;align-items:center;gap:9px;font-family:var(--hd);font-weight:700;font-size:16px;color:var(--brand-d);margin-bottom:12px}
.ai-ov .h .pill{font-size:11px;background:var(--grad);color:#fff;padding:3px 10px;border-radius:var(--pill)}
.ai-ov ul{margin:0;padding-left:20px;columns:2;column-gap:30px}.ai-ov li{font-size:14.5px;color:#3a3a42;margin-bottom:8px;line-height:1.6;break-inside:avoid}
.ai-ov .note{font-size:11.5px;color:var(--ink2);margin-top:12px;border-top:1px dashed #f0cfdf;padding-top:10px}
/* course rows / tiers */
.tier{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tier .c{border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;padding:24px;box-shadow:var(--sh1)}
.tier .c.feat{border-color:var(--brand);box-shadow:var(--sh2)}
.tier .c .tag{display:inline-block;background:#fdeef5;color:var(--brand-d);border:1px solid #f3c7dd;border-radius:var(--pill);padding:4px 12px;font-size:12px;font-weight:600;margin-bottom:10px}
.tier .c h3{font-family:var(--hd);font-size:19px;margin:0 0 6px}.tier .c .meta{font-size:13px;color:var(--brand);font-weight:600;margin-bottom:10px}
.tier .c p{font-size:13.5px;color:#3a3a42;margin:0}
/* phase list */
.phase{display:grid;grid-template-columns:84px 1fr;gap:18px;padding:20px 0;border-bottom:1px solid var(--line)}
.phase .no{font-family:var(--hd);font-weight:800;font-size:14px;color:#fff;background:var(--grad);width:68px;height:68px;border-radius:16px;display:grid;place-items:center;text-align:center;line-height:1.2}
.phase h3{font-family:var(--hd);font-size:18px;margin:0 0 5px}.phase p{margin:0;font-size:14px;color:#3a3a42}
/* gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:150px;gap:10px}
.gal a{border-radius:14px;overflow:hidden}.gal a:first-child{grid-column:span 2;grid-row:span 2}
.gal img{width:100%;height:100%;object-fit:cover;transition:.4s}.gal a:hover img{transform:scale(1.05)}
/* activities */
.acts{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.acts .a{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3}
.acts .a img{width:100%;height:100%;object-fit:cover;transition:.4s}.acts .a:hover img{transform:scale(1.06)}
.acts .a .cap{position:absolute;left:0;right:0;bottom:0;padding:30px 16px 14px;color:#fff;background:linear-gradient(0deg,rgba(0,0,0,.75),transparent);font-family:var(--hd);font-weight:700;font-size:15px}
.acts .a .cap small{display:block;font-weight:400;font-size:12px;opacity:.85;margin-top:2px}
/* videos */
.video-embed{position:relative;padding-top:56.25%;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh2)}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vids{display:grid;grid-template-columns:1fr 1fr;gap:20px}
/* team */
.cred{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:30px}
.cred span{background:#fff;border:1px solid #f3c7dd;color:var(--brand-d);border-radius:var(--pill);padding:9px 16px;font-family:var(--hd);font-weight:600;font-size:13.5px}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:var(--sh1)}
.tcard .av{width:46px;height:46px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-family:var(--hd);font-weight:800;margin-bottom:10px}
.tcard h3{font-family:var(--hd);font-size:16px;margin:0 0 3px}.tcard .role{font-size:12px;color:var(--brand);font-weight:600;margin-bottom:7px}.tcard p{margin:0;font-size:13px;color:var(--ink2)}
/* includes + price */
.inc{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.inc h3{font-family:var(--hd);font-size:17px;margin:0 0 12px}.inc ul{margin:0;padding:0;list-style:none}
.inc li{padding:7px 0;font-size:14.5px;color:#3a3a42;display:flex;gap:9px}.inc li::before{content:"";width:7px;height:7px;border-radius:50%;margin-top:8px;flex:0 0 auto}
.inc .yes li::before{background:#1f9d57}.inc .no li::before{background:#cbb}
.pricewrap{display:grid;grid-template-columns:1.3fr 1fr;gap:30px;align-items:center;background:var(--cream);border:1px solid #f3c7dd;border-radius:var(--r-lg);padding:30px}
.pricewrap .big{font-family:var(--hd);font-weight:800;font-size:40px;color:var(--brand-d);line-height:1}
.pricewrap .orig{color:var(--ink2);text-decoration:line-through;font-size:16px;margin-left:8px}
/* faq */
.faq .q{border:1px solid var(--line);border-radius:14px;margin-bottom:10px;background:#fff}
.faq summary{padding:16px 18px;font-family:var(--hd);font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between}
.faq summary::-webkit-details-marker{display:none}.faq summary::after{content:"+";color:var(--brand);font-size:22px}.faq .q[open] summary::after{content:"−"}
.faq .a{padding:0 18px 16px;color:#3a3a42;font-size:14.5px;line-height:1.8}
@media(max-width:900px){.qfacts .wrap{grid-template-columns:repeat(2,1fr)}.hl{grid-template-columns:repeat(2,1fr)}.tier,.acts,.team-grid,.inc,.pricewrap,.vids{grid-template-columns:1fr}.gal{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.hl{grid-template-columns:1fr}.qfacts .wrap{grid-template-columns:1fr 1fr}.phase{grid-template-columns:1fr}}

/* ── 追加：校區切換 / 比較 / 成果數據 / 重點帶 ── */
.camptabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:22px}
.camptab{padding:10px 20px;border-radius:var(--pill);border:1px solid var(--line);background:#fff;font-family:var(--hd);font-weight:600;font-size:14.5px;cursor:pointer;transition:.18s}
.camptab.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.camppanel{display:none}.camppanel.on{display:block;animation:gofade .25s ease}
@keyframes gofade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.cpgrid{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
.cpgrid .im{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--sh2)}
.cpgrid .im img{width:100%;height:100%;object-fit:cover}
.cpgrid .facts{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:14px 0}
.cpgrid .fact{background:var(--mist);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.cpgrid .fact .l{font-size:12px;color:var(--ink2)}.cpgrid .fact .v{font-family:var(--hd);font-weight:700;font-size:15px}
/* low season band */
.lband{background:linear-gradient(120deg,#fdeef5,#fff);border:1px solid #f3c7dd;border-radius:var(--r-lg);padding:30px 32px}
.lband h3{font-family:var(--hd);font-weight:800;font-size:22px;margin:0 0 8px}
.lband .pts{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.lband .pts div{font-size:13.5px;color:#3a3a42}.lband .pts b{display:block;font-family:var(--hd);color:var(--brand-d);font-size:18px;margin-bottom:2px}
/* comparison (vs) */
.vstable{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh1)}
.vstable .r{display:grid;grid-template-columns:1fr 1.3fr 1.3fr}
.vstable .r>div{padding:14px 16px;border-bottom:1px solid var(--line);font-size:14px}
.vstable .h>div{background:#faf0f5;font-family:var(--hd);font-weight:700}
.vstable .h .win{color:var(--brand-d)}
.vstable .r>div:first-child{font-weight:600;background:var(--mist)}
.vstable .win{background:#fff8fb}
.vstable .r:last-child>div{border-bottom:0}
/* results stats */
.results{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;text-align:center}
.results .c{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--sh1)}
.results .c .n{font-family:var(--hd);font-weight:800;font-size:30px;color:var(--brand-d);line-height:1}
.results .c small{display:block;color:var(--ink2);font-size:12.5px;margin-top:6px}
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.case{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--sh1)}
.case .jump{font-family:var(--hd);font-weight:800;color:var(--brand);font-size:18px}
.case p{margin:6px 0 0;font-size:13px;color:#3a3a42}.case .nm{font-size:12px;color:var(--ink2);margin-top:6px}
@media(max-width:900px){.cpgrid,.vstable .r{grid-template-columns:1fr}.lband .pts,.results{grid-template-columns:1fr 1fr}.cases{grid-template-columns:1fr}}
