/* ============ Taibao Junior High · Bilingual Page Styles ============ */
/* Palette: garnet (the cinnabar-red of an imperial seal — the town is        */
/*          named after a Qing honorary title, 太子太保) + bronze (shared      */
/*          heritage accent with the sister school Taibao Elementary).         */
/*          Pure-white background throughout. Garnet distinguishes the junior  */
/*          high from the elementary's ink-blue and KangLang's coastal teal.   */

:root{
  --garnet:#7A2A3A;
  --garnet-deep:#561B27;
  --garnet-soft:#F6EAEC;
  --bronze:#B07D3C;
  --bronze-deep:#8A5E25;
  --bronze-soft:#F7F0E2;
  --stone:#4a5468;
  --stone-soft:#e7e3ea;
  --ink:#1d1815;
  --ink-soft:#5b544d;
  --line:#e7ddd6;
  --max:1140px;
  --shadow:0 14px 40px -16px rgba(86,27,39,.30);
  --shadow-sm:0 4px 14px -4px rgba(86,27,39,.18);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Lato','PingFang TC','Apple LiGothic Medium','Microsoft JhengHei',sans-serif;
  color:var(--ink);
  background:#fff;
  /* Typography rule: 20px on mobile, 22px on desktop (see media query) */
  font-size:20px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:var(--garnet-deep);text-decoration:none;transition:color .2s;}
a:hover{color:var(--bronze-deep);}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px;}


/* ============ TOPBAR ============ */
.topbar{
  background:rgba(255,255,255,.95);
  border-bottom:1px solid var(--line);
  padding:14px 0;
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(8px);
}
.topbar-inner{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.topbar-brand{display:flex;align-items:center;gap:12px;}
.topbar-name{
  font-family:'Playfair Display','PingFang TC',serif;
  font-size:21px;font-weight:600;
  color:var(--garnet-deep);line-height:1.1;
}
.topbar-name a{color:inherit;}
.topbar-name small{
  display:block;
  font-family:'PingFang TC',sans-serif;
  font-size:13px;font-weight:500;
  color:var(--ink-soft);margin-top:2px;letter-spacing:.04em;
}
.topbar-nav{display:flex;gap:22px;flex-wrap:wrap;justify-content:flex-end;}
.topbar-nav a{
  color:var(--ink);font-size:15.5px;font-weight:600;
  letter-spacing:.03em;
}
.topbar-nav a:hover{color:var(--garnet);}
.topbar-nav a.is-active{color:var(--garnet-deep);font-weight:700;border-bottom:2px solid var(--bronze);}


/* ============ TITLE (home hero) ============ */
/* Pure-gradient hero. To use a real photo of the school gate / building,     */
/* uncomment the url() line below and drop the file in /photos.               */
.title{
  position:relative;
  background:
    /* url("../photos/hero-school.jpg") center 55%/cover no-repeat, */
    linear-gradient(135deg,#3F1019 0%,#561B27 45%,#7A2A3A 100%);
  padding:118px 0 104px;
  text-align:center;color:#fff;
  border-bottom:4px solid var(--bronze);
  overflow:hidden;
}
.title::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 80% 18%,rgba(176,125,60,.24),transparent 55%),
    radial-gradient(circle at 18% 82%,rgba(122,42,58,.34),transparent 55%);
  pointer-events:none;
}
.title > .wrap{position:relative;z-index:1;}
.title__eyebrow{
  display:inline-block;
  font-size:14px;letter-spacing:.26em;
  color:rgba(243,217,178,.96);font-weight:700;
  text-transform:uppercase;margin-bottom:16px;
}
.title h1{
  font-family:'Playfair Display','PingFang TC',serif;
  font-size:clamp(40px,7vw,64px);
  line-height:1.05;font-weight:600;letter-spacing:.005em;
  color:#fff;margin-bottom:6px;
  text-shadow:0 2px 16px rgba(0,0,0,.45);
}
.title .h1-zh{
  font-size:clamp(21px,2.6vw,27px);
  font-weight:500;letter-spacing:.08em;
  color:rgba(255,255,255,.92);margin-top:12px;
  font-family:'PingFang TC','Apple LiGothic Medium',sans-serif;
  text-shadow:0 1px 6px rgba(0,0,0,.35);
}
.title__divider{width:60px;height:2px;background:var(--bronze);margin:24px auto 18px;border:0;}
.title__tagline{
  max-width:680px;margin:0 auto;
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:23px;color:rgba(255,255,255,.96);line-height:1.55;
}
.title__tagline .tagline-zh{
  display:block;font-style:normal;
  font-family:'PingFang TC',sans-serif;
  font-size:17.5px;margin-top:8px;
  color:rgba(255,255,255,.82);letter-spacing:.06em;
}
.title__chips{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap;justify-content:center;}
.title__chips span{
  font-size:14px;font-weight:600;letter-spacing:.05em;
  color:#fff;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  padding:7px 16px;border-radius:99px;
  backdrop-filter:blur(4px);
}


/* ============ Section base ============ */
section{padding:92px 0;}
.section-head{text-align:center;margin-bottom:60px;}
.section-head .eyebrow{
  display:inline-block;
  color:var(--bronze-deep);font-size:15px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;margin-bottom:14px;
}
.section-head h2{
  font-family:'Playfair Display','PingFang TC',serif;
  font-size:clamp(36px,6vw,56px);
  font-weight:600;color:var(--garnet-deep);line-height:1.2;margin-bottom:8px;
}
.section-head .h2-zh{
  font-family:'PingFang TC','Apple LiGothic Medium',sans-serif;
  font-size:23px;color:var(--ink-soft);font-weight:500;letter-spacing:.04em;
}
.section-head .lede{color:var(--ink-soft);font-size:20px;max-width:660px;margin:18px auto 0;}


/* ============ About ============ */
.about{background:#fff;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start;}
.about-text h3{
  font-family:'Playfair Display','PingFang TC',serif;
  font-size:34px;color:var(--garnet-deep);line-height:1.25;margin-bottom:18px;font-weight:600;
}
.about-text .en{font-size:20px;color:var(--ink);margin-bottom:18px;line-height:1.75;}
.about-text .zh-divider{height:1px;background:var(--line);margin:24px 0;position:relative;}
.about-text .zh-divider::before{
  content:"中文";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:#fff;padding:0 14px;font-size:14px;color:var(--ink-soft);
  letter-spacing:.12em;text-transform:uppercase;font-weight:600;
}
.about-text .zh{
  font-family:'PingFang TC','Apple LiGothic Medium',sans-serif;
  font-size:19px;color:var(--ink);line-height:1.9;
}
.about-text .zh p + p{margin-top:14px;}

/* timeline aside */
.lineage{
  background:linear-gradient(180deg,var(--garnet-soft) 0%,#fff 100%);
  border:1px solid var(--line);border-radius:20px;padding:34px 30px;box-shadow:var(--shadow-sm);
}
.lineage__label{
  text-align:center;font-size:13.5px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--garnet-deep);margin-bottom:24px;
}
.lineage__trunk{
  background:#fff;border:2px solid var(--garnet-deep);border-radius:14px;
  padding:18px 20px;text-align:center;margin:0 auto;max-width:320px;box-shadow:var(--shadow-sm);
}
.lineage__trunk .name{font-family:'Playfair Display',serif;font-size:21px;font-weight:600;color:var(--garnet-deep);line-height:1.2;}
.lineage__trunk .name-zh{font-family:'PingFang TC',sans-serif;font-size:15.5px;color:var(--ink-soft);margin-top:4px;}
.lineage__trunk .year{font-size:12.5px;color:var(--bronze-deep);font-weight:700;letter-spacing:.14em;margin-top:6px;}
.lineage__arrow{text-align:center;color:var(--bronze);font-size:22px;line-height:1;margin:10px 0;}
.lineage__branch-step{
  background:#fff;border:1px dashed var(--garnet);border-radius:10px;
  padding:12px 16px;text-align:center;max-width:360px;margin:0 auto;color:var(--ink);
}
.lineage__branch-step .step-label{font-size:12px;font-weight:700;letter-spacing:.16em;color:var(--bronze-deep);margin-bottom:4px;text-transform:uppercase;}
.lineage__branch-step .step-text{font-family:'Playfair Display',serif;font-size:16.5px;color:var(--ink);line-height:1.4;}
.lineage__branch-step .step-text small{display:block;font-family:'PingFang TC',sans-serif;font-size:14px;color:var(--ink-soft);margin-top:2px;}
.lineage__seed{
  background:var(--garnet);color:#fff;border-radius:14px;padding:22px 24px;text-align:center;
  margin:0 auto;max-width:360px;box-shadow:var(--shadow);position:relative;
}
.lineage__seed::before{
  content:"★";position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--bronze);color:#fff;width:26px;height:26px;border-radius:99px;
  display:flex;align-items:center;justify-content:center;font-size:14px;
}
.lineage__seed .name{font-family:'Playfair Display',serif;font-size:23px;font-weight:700;line-height:1.2;}
.lineage__seed .name-zh{font-family:'PingFang TC',sans-serif;font-size:16.5px;margin-top:4px;color:rgba(255,255,255,.92);}
.lineage__seed .year{font-size:13px;color:rgba(255,255,255,.85);font-weight:700;letter-spacing:.14em;margin-top:6px;}
.lineage__caption{margin-top:20px;text-align:center;font-family:'Playfair Display',serif;font-style:italic;font-size:16px;color:var(--ink-soft);line-height:1.6;}
.lineage__caption .zh{display:block;font-style:normal;font-family:'PingFang TC',sans-serif;font-size:14.5px;margin-top:4px;}


/* ============ Identity (vision + 5 powers) ============ */
.identity{background:linear-gradient(180deg,#fff 0%,var(--garnet-soft) 100%);}
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.pillar{
  background:#fff;border-radius:18px;padding:30px 24px 28px;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);
  transition:transform .25s,box-shadow .25s,border-color .25s;position:relative;
}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--garnet);}
.pillar .icon{
  width:54px;height:54px;border-radius:14px;
  background:var(--garnet-soft);color:var(--garnet-deep);
  display:flex;align-items:center;justify-content:center;
  font-size:28px;font-weight:700;font-family:'PingFang TC',serif;margin-bottom:20px;
}
.pillar:nth-child(2) .icon{background:var(--bronze-soft);color:var(--bronze-deep);}
.pillar:nth-child(3) .icon{background:var(--stone-soft);color:var(--stone);}
.pillar:nth-child(4) .icon{background:var(--garnet-soft);color:var(--garnet);}
.pillar h3{
  font-family:'Playfair Display','PingFang TC',serif;
  font-size:23px;color:var(--garnet-deep);line-height:1.25;font-weight:600;margin-bottom:6px;
}
.pillar h3 small{display:block;font-family:'PingFang TC',sans-serif;font-size:15.5px;color:var(--ink-soft);font-weight:500;margin-top:4px;letter-spacing:.04em;}
.pillar .en-body{font-size:16.5px;color:var(--ink);margin:14px 0 8px;line-height:1.7;}
.pillar .divider-tiny{height:1px;background:var(--line);margin:12px 0;}
.pillar .zh-body{font-family:'PingFang TC',sans-serif;font-size:15.5px;color:var(--ink);line-height:1.85;}
.identity__note{
  text-align:center;margin-top:44px;font-size:18px;color:var(--ink-soft);
  max-width:740px;margin-left:auto;margin-right:auto;
}
.identity__note strong{color:var(--garnet-deep);}
.identity__note .zh{display:block;font-family:'PingFang TC',sans-serif;font-size:16.5px;margin-top:8px;}


/* ============ Principal (home card) ============ */
.principal{background:#fff;}
.principal-card{
  display:grid;grid-template-columns:.85fr 1.4fr;gap:50px;align-items:center;
  background:#fff;border-radius:22px;padding:50px;border:1px solid var(--line);
  box-shadow:var(--shadow);max-width:1000px;margin:0 auto;
}
.principal-photo{
  position:relative;border-radius:16px;overflow:hidden;aspect-ratio:1/1;box-shadow:var(--shadow-sm);
  background:linear-gradient(135deg,var(--garnet-soft) 0%,#fff 60%,var(--bronze-soft) 100%);
  display:flex;align-items:center;justify-content:center;color:var(--garnet-deep);
}
.principal-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.principal-photo .placeholder{text-align:center;font-family:'Playfair Display',serif;padding:20px;}
.principal-photo .placeholder .glyph{font-size:46px;line-height:1;font-family:'PingFang TC',serif;}
.principal-photo .placeholder small{display:block;font-family:'PingFang TC',sans-serif;font-size:13.5px;color:var(--ink-soft);margin-top:10px;letter-spacing:.04em;}
.principal-text .role{color:var(--bronze-deep);font-size:14.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin-bottom:10px;}
.principal-text h3{font-family:'Playfair Display',serif;font-size:38px;font-weight:600;color:var(--garnet-deep);line-height:1.15;margin-bottom:6px;}
.principal-text h3 small{display:block;font-family:'PingFang TC',sans-serif;font-size:23px;color:var(--ink-soft);font-weight:500;margin-top:6px;}
.principal-text .since{font-size:15px;color:var(--ink-soft);font-style:italic;margin-top:8px;}
.principal-text blockquote{
  font-family:'Playfair Display',serif;font-style:italic;font-size:23px;color:var(--ink);
  line-height:1.65;margin:26px 0 14px;padding-left:22px;border-left:3px solid var(--bronze);
}
.principal-text .zh-quote{
  font-family:'PingFang TC',sans-serif;font-style:normal;font-size:19px;color:var(--ink);
  line-height:1.85;padding-left:22px;border-left:3px solid var(--garnet);margin-top:18px;
}
.principal-cta{
  margin-top:24px;display:inline-flex;align-items:center;gap:8px;
  padding:12px 24px;border:1.5px solid var(--garnet);border-radius:99px;color:var(--garnet-deep);
  font-weight:600;font-size:16px;letter-spacing:.03em;transition:background .2s,color .2s;
}
.principal-cta:hover{background:var(--garnet);color:#fff;}


/* ============ Student Life / English at Taibao ============ */
.life{background:linear-gradient(180deg,var(--bronze-soft) 0%,#fff 100%);}
.life-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;}
.life-card{
  background:#fff;border-radius:18px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s;
}
.life-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.life-card__img{aspect-ratio:16/10;overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative;}
.life-card__img.bg-garnet{background:linear-gradient(135deg,var(--garnet-soft) 0%,#fff 100%);}
.life-card__img.bg-bronze{background:linear-gradient(135deg,var(--bronze-soft) 0%,#fff 100%);}
.life-card__img.bg-mixed{background:linear-gradient(135deg,var(--garnet-soft) 0%,var(--bronze-soft) 100%);}
.life-card__img.bg-garnet-soft{background:linear-gradient(135deg,#fff 0%,var(--garnet-soft) 100%);}
.life-card__img .glyph{font-family:'Playfair Display',serif;font-size:48px;color:var(--garnet-deep);text-align:center;line-height:1.05;}
.life-card__img .glyph small{display:block;font-family:'PingFang TC',sans-serif;font-size:16px;color:var(--ink);font-weight:500;font-style:normal;margin-top:10px;letter-spacing:.04em;}
.life-card__body{padding:26px 28px 30px;}
.life-card .tag{display:inline-block;font-size:13.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--bronze-deep);font-weight:700;margin-bottom:8px;}
.life-card h3{font-family:'Playfair Display','PingFang TC',serif;font-size:26px;color:var(--garnet-deep);line-height:1.25;font-weight:600;margin-bottom:4px;}
.life-card h3 small{display:block;font-family:'PingFang TC',sans-serif;font-size:16.5px;color:var(--ink-soft);font-weight:500;margin-top:4px;letter-spacing:.04em;}
.life-card .en-text{font-size:17px;color:var(--ink);margin:14px 0 8px;line-height:1.7;}
.life-card .zh-text{font-family:'PingFang TC',sans-serif;font-size:16.5px;color:var(--ink-soft);line-height:1.8;padding-top:10px;border-top:1px dashed var(--line);margin-top:12px;}
.life-cta{text-align:center;margin-top:50px;}
.life-cta-link{display:inline-block;padding:15px 30px;background:var(--garnet);color:#fff;border-radius:99px;font-weight:600;font-size:17px;letter-spacing:.03em;transition:background .2s,transform .2s;}
.life-cta-link:hover{background:var(--garnet-deep);color:#fff;transform:translateY(-2px);}


/* ============ Visit ============ */
.visit{background:var(--garnet-deep);color:#fff;padding:84px 0;}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start;}
.visit h2{font-family:'Playfair Display',serif;font-size:46px;font-weight:600;line-height:1.15;margin-bottom:6px;color:#fff;}
.visit h2 small{display:block;font-family:'PingFang TC',sans-serif;font-size:23px;font-weight:500;color:rgba(255,255,255,.78);margin-top:8px;}
.visit p{font-size:19px;color:rgba(255,255,255,.88);margin-top:20px;line-height:1.75;}
.visit p.zh{font-family:'PingFang TC',sans-serif;margin-top:14px;font-size:18px;}
.contact{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:28px 30px;backdrop-filter:blur(8px);}
.contact dl{display:grid;gap:18px;}
.contact dt{font-size:14px;letter-spacing:.16em;text-transform:uppercase;color:#f3d9b2;font-weight:700;margin-bottom:4px;}
.contact dd{font-size:18.5px;color:#fff;font-family:'PingFang TC',sans-serif;line-height:1.55;}
.contact dd a{color:#fff;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:1px;}
.contact dd a:hover{color:#f3d9b2;border-color:#f3d9b2;}


/* ============ Footer ============ */
footer{background:#2b0f15;color:rgba(255,255,255,.66);padding:38px 0;font-size:15.5px;border-top:1px solid rgba(255,255,255,.08);}
footer .wrap{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;}
footer .partner{color:#f3d9b2;font-weight:600;}
footer .partner a{color:#f3d9b2;border-bottom:1px solid transparent;}
footer .partner a:hover{border-bottom-color:#f3d9b2;}


/* ============ Sub-page shared hero ============ */
.page-hero{
  background:linear-gradient(135deg,#3F1019 0%,#561B27 60%,#7A2A3A 100%);
  padding:66px 0 58px;color:#fff;border-bottom:4px solid var(--bronze);
}
.page-hero .eyebrow{display:inline-block;font-size:13.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(243,217,178,.96);font-weight:700;margin-bottom:14px;}
.page-hero h1{font-family:'Playfair Display','PingFang TC',serif;font-size:clamp(36px,5.5vw,52px);font-weight:600;line-height:1.1;color:#fff;margin-bottom:8px;}
.page-hero h1 .zh{display:block;font-family:'PingFang TC',sans-serif;font-size:clamp(19px,2.2vw,23px);font-weight:500;letter-spacing:.06em;color:rgba(255,255,255,.86);margin-top:10px;}
.page-hero .tagline{margin-top:18px;max-width:680px;font-family:'Playfair Display',serif;font-style:italic;font-size:20px;color:rgba(255,255,255,.93);line-height:1.55;}
.page-hero .tagline .zh{display:block;font-style:normal;font-family:'PingFang TC',sans-serif;font-size:16.5px;color:rgba(255,255,255,.8);margin-top:6px;letter-spacing:.06em;}


/* ============ Prose ============ */
.prose{padding:80px 0;background:#fff;}
.prose-inner{max-width:820px;margin:0 auto;}
.prose h2{font-family:'Playfair Display','PingFang TC',serif;font-size:33px;font-weight:600;color:var(--garnet-deep);line-height:1.25;margin:48px 0 14px;}
.prose h2:first-child{margin-top:0;}
.prose p{font-size:18.5px;color:var(--ink);line-height:1.8;margin:14px 0;}
.prose .zh-block{font-family:'PingFang TC',sans-serif;font-size:17.5px;color:var(--ink-soft);line-height:1.85;border-left:3px solid var(--garnet-soft);padding-left:18px;margin:14px 0 28px;}
.prose .pull-quote{font-family:'Playfair Display',serif;font-style:italic;font-size:23px;color:var(--garnet-deep);line-height:1.5;text-align:center;margin:40px 0;padding:26px 30px;background:var(--garnet-soft);border-radius:14px;}
.prose .pull-quote .zh{display:block;font-family:'PingFang TC',sans-serif;font-style:normal;font-size:17.5px;color:var(--ink-soft);margin-top:10px;}


/* ============ Guide stations (around-taibao) ============ */
.stations-section{padding:80px 0;background:linear-gradient(180deg,#fff 0%,var(--garnet-soft) 100%);}
.stations-wrap{max-width:1000px;margin:0 auto;}
.stations-intro{max-width:720px;margin:0 auto 50px;color:var(--ink-soft);font-size:19px;line-height:1.75;text-align:center;}
.stations-intro .zh{display:block;font-family:'PingFang TC',sans-serif;font-size:17px;margin-top:10px;}
.station{
  background:#fff;border-radius:16px;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);margin-bottom:26px;overflow:hidden;
  transition:box-shadow .2s,transform .2s;
}
.station:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.station-head{
  display:flex;align-items:center;gap:20px;
  padding:24px 30px;background:linear-gradient(135deg,var(--garnet-soft) 0%,#fff 100%);
  border-bottom:1px solid var(--line);
}
.station:nth-child(even) .station-head{background:linear-gradient(135deg,var(--bronze-soft) 0%,#fff 100%);}
.station-num{
  width:58px;height:58px;border-radius:14px;background:var(--garnet);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-size:30px;font-weight:600;flex-shrink:0;
}
.station:nth-child(even) .station-num{background:var(--bronze);}
.station-head h3{font-family:'Playfair Display','PingFang TC',serif;font-size:25px;color:var(--garnet-deep);line-height:1.2;font-weight:600;}
.station-head h3 .zh{display:block;font-family:'PingFang TC',sans-serif;font-size:16.5px;color:var(--ink-soft);font-weight:500;margin-top:3px;letter-spacing:.04em;}
.station-body{padding:26px 30px 30px;}
.station-body .context{font-size:18px;color:var(--ink);line-height:1.75;margin-bottom:6px;}
.station-body .context-zh{font-family:'PingFang TC',sans-serif;font-size:16.5px;color:var(--ink-soft);line-height:1.8;padding-top:8px;margin-top:8px;border-top:1px dashed var(--line);}

/* guide script box */
.guide{margin-top:22px;padding:22px 24px;background:var(--garnet-soft);border-radius:12px;border:1px solid #ecd9dd;}
.guide .label{font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--garnet-deep);margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.guide .script{font-family:'Playfair Display',serif;font-size:19px;color:var(--ink);line-height:1.7;font-style:italic;}
.speak-btn{
  appearance:none;cursor:pointer;border:1.5px solid var(--garnet);background:#fff;color:var(--garnet-deep);
  border-radius:99px;padding:8px 16px;font-size:14.5px;font-weight:600;font-family:'Lato',sans-serif;
  display:inline-flex;align-items:center;gap:7px;margin-top:14px;transition:background .2s,color .2s;letter-spacing:.02em;
}
.speak-btn:hover{background:var(--garnet);color:#fff;}
.speak-btn:active{transform:scale(.97);}
.speak-btn[aria-pressed="true"]{background:var(--garnet);color:#fff;}

/* vocabulary box */
.vocab{margin-top:20px;}
.vocab .label{font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--bronze-deep);margin-bottom:10px;}
.vocab ul{list-style:none;padding:0;margin:0;display:grid;gap:10px;}
.vocab li{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:baseline;font-size:16.5px;color:var(--ink);line-height:1.5;}
.vocab .term{font-weight:700;color:var(--garnet-deep);font-family:'Lato',sans-serif;}
.vocab .pos{font-style:italic;color:var(--ink-soft);font-size:14px;margin-left:4px;}
.vocab .gloss .zh{font-family:'PingFang TC',sans-serif;color:var(--ink-soft);}


/* ============ Quiz ============ */
.quiz-section{padding:84px 0;background:#fff;border-top:1px solid var(--line);}
.quiz-wrap{max-width:760px;margin:0 auto;}
.quiz-head{text-align:center;margin-bottom:44px;}
.quiz-head .eyebrow{display:inline-block;color:var(--bronze-deep);font-size:14px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin-bottom:12px;}
.quiz-head h2{font-family:'Playfair Display','PingFang TC',serif;font-size:38px;font-weight:600;color:var(--garnet-deep);line-height:1.2;margin-bottom:6px;}
.quiz-head .zh{font-family:'PingFang TC',sans-serif;font-size:18px;color:var(--ink-soft);}
.quiz-item{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 30px;margin-bottom:22px;box-shadow:var(--shadow-sm);}
.quiz-item .q{font-size:19px;font-weight:600;color:var(--ink);line-height:1.5;margin-bottom:6px;}
.quiz-item .q-zh{font-family:'PingFang TC',sans-serif;font-size:16px;color:var(--ink-soft);margin-bottom:18px;}
.quiz-options{display:grid;gap:12px;}
.quiz-opt{
  display:flex;align-items:center;gap:12px;width:100%;text-align:left;cursor:pointer;
  background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:14px 18px;
  font-size:17px;color:var(--ink);font-family:'Lato',sans-serif;transition:border-color .15s,background .15s;
}
.quiz-opt:hover{border-color:var(--garnet);background:var(--garnet-soft);}
.quiz-opt .key{
  width:30px;height:30px;border-radius:8px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:15px;background:var(--garnet-soft);color:var(--garnet-deep);
}
.quiz-opt.correct{border-color:#2e7d52;background:#e7f5ee;}
.quiz-opt.correct .key{background:#2e7d52;color:#fff;}
.quiz-opt.wrong{border-color:#c0392b;background:#fbecea;}
.quiz-opt.wrong .key{background:#c0392b;color:#fff;}
.quiz-opt:disabled{cursor:default;}
.quiz-explain{
  margin-top:16px;padding:16px 18px;border-radius:10px;background:var(--bronze-soft);
  font-size:16px;color:var(--ink);line-height:1.7;display:none;
}
.quiz-explain.show{display:block;}
.quiz-explain .en{font-weight:600;color:var(--garnet-deep);}
.quiz-explain .zh{display:block;font-family:'PingFang TC',sans-serif;color:var(--ink-soft);margin-top:6px;font-size:15.5px;}


/* ============ Principal page extras ============ */
.principal-portrait{display:grid;grid-template-columns:.7fr 1.4fr;gap:50px;align-items:center;max-width:1000px;margin:0 auto;padding:60px 0;}
.principal-portrait .photo-box{aspect-ratio:4/5;border-radius:14px;background:linear-gradient(135deg,var(--garnet-soft) 0%,var(--bronze-soft) 100%);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);color:var(--garnet-deep);font-family:'Playfair Display',serif;overflow:hidden;text-align:center;}
.principal-portrait .photo-box img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.principal-portrait .photo-box .placeholder{padding:24px;}
.principal-portrait .photo-box .placeholder .glyph{font-size:44px;line-height:1;font-family:'PingFang TC',serif;}
.principal-portrait .photo-box .placeholder small{display:block;font-family:'PingFang TC',sans-serif;font-size:13.5px;color:var(--ink-soft);margin-top:10px;}
.principal-portrait .text .role{color:var(--bronze-deep);font-size:14.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin-bottom:10px;}
.principal-portrait .text h1{font-family:'Playfair Display',serif;font-size:46px;font-weight:600;color:var(--garnet-deep);line-height:1.1;}
.principal-portrait .text h1 .zh{display:block;font-family:'PingFang TC',sans-serif;font-size:24px;color:var(--ink-soft);font-weight:500;margin-top:8px;}
.principal-portrait .text .credentials{margin-top:18px;font-size:16.5px;color:var(--ink-soft);line-height:1.7;}
.principal-portrait .text .credentials strong{color:var(--garnet-deep);}
.commitments{background:var(--garnet-soft);padding:80px 0;}
.commitments-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1000px;margin:30px auto 0;}
.commit{background:#fff;border-radius:14px;padding:30px 26px;border-top:4px solid var(--garnet);box-shadow:var(--shadow-sm);}
.commit:nth-child(2){border-top-color:var(--bronze);}
.commit:nth-child(3){border-top-color:var(--garnet-deep);}
.commit .num{font-family:'Playfair Display',serif;font-size:36px;color:var(--garnet);line-height:1;font-weight:600;}
.commit:nth-child(2) .num{color:var(--bronze-deep);}
.commit:nth-child(3) .num{color:var(--garnet-deep);}
.commit h3{font-family:'Playfair Display','PingFang TC',serif;font-size:22px;color:var(--garnet-deep);font-weight:600;line-height:1.3;margin:14px 0 6px;}
.commit h3 .zh{display:block;font-family:'PingFang TC',sans-serif;font-size:15.5px;color:var(--ink-soft);font-weight:500;margin-top:2px;}
.commit p{font-size:16px;color:var(--ink);line-height:1.7;margin-top:10px;}
.commit p.zh{font-family:'PingFang TC',sans-serif;color:var(--ink-soft);font-size:15px;line-height:1.8;border-top:1px dashed var(--line);padding-top:10px;margin-top:12px;}


/* ============ News & Highlights ============ */
.news{background:#fff;}
.news-meta{text-align:center;margin:-30px auto 46px;max-width:660px;color:var(--ink-soft);font-size:17px;}
.news-meta a{border-bottom:1px solid var(--garnet-soft);}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.news-card{
  display:flex;flex-direction:column;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  border-top:4px solid var(--garnet);padding:26px 26px 24px;
  box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;
}
.news-card:nth-child(3n+2){border-top-color:var(--bronze);}
.news-card:nth-child(3n){border-top-color:var(--garnet-deep);}
.news-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.news-card .news-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px;}
.news-card .date{font-size:13.5px;font-weight:700;letter-spacing:.06em;color:var(--ink-soft);font-family:'Lato',sans-serif;}
.news-card .cat{
  font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--garnet-deep);background:var(--garnet-soft);
  padding:3px 10px;border-radius:99px;
}
.news-card:nth-child(3n+2) .cat{color:var(--bronze-deep);background:var(--bronze-soft);}
.news-card h3{
  font-family:'Playfair Display','PingFang TC',serif;
  font-size:20px;font-weight:600;color:var(--garnet-deep);
  line-height:1.35;margin-bottom:10px;
}
.news-card .zh-title{
  font-family:'PingFang TC','Apple LiGothic Medium',sans-serif;
  font-size:15.5px;color:var(--ink-soft);line-height:1.6;
  padding-top:10px;border-top:1px dashed var(--line);
}
.news-card .read{
  margin-top:auto;padding-top:16px;
  font-size:14.5px;font-weight:600;color:var(--garnet);letter-spacing:.02em;
  display:inline-flex;align-items:center;gap:6px;
}
.news-card .read:hover{color:var(--bronze-deep);}
.news-cta{text-align:center;margin-top:44px;}


/* ============ Mobile ============ */
@media (min-width: 881px){
  body{font-size:22px;}
}
@media (max-width: 980px){
  .news-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width: 1000px){
  .pillars{grid-template-columns:repeat(2,1fr);}
}
@media (max-width: 880px){
  .title{padding:66px 0 56px;}
  section{padding:64px 0;}
  .about-grid{grid-template-columns:1fr;gap:36px;}
  .pillars{grid-template-columns:1fr;}
  .principal-card{grid-template-columns:1fr;padding:32px 26px;gap:26px;}
  .principal-photo{max-width:240px;margin:0 auto;}
  .life-grid{grid-template-columns:1fr;}
  .visit-grid{grid-template-columns:1fr;gap:30px;}
  .commitments-grid{grid-template-columns:1fr;}
  .principal-portrait{grid-template-columns:1fr;gap:30px;padding:40px 0;}
  .principal-portrait .photo-box{max-width:260px;margin:0 auto;}
  .station-head{padding:20px 22px;gap:16px;}
  .station-num{width:50px;height:50px;font-size:24px;}
  .station-body{padding:22px 22px 26px;}
  .news-grid{grid-template-columns:1fr;}
  footer .wrap{flex-direction:column;text-align:center;}
}
@media (max-width:560px){
  .topbar-inner{flex-direction:column;align-items:flex-start;gap:10px;}
  .topbar-nav{gap:14px;justify-content:flex-start;}
  .topbar-nav a{font-size:14.5px;}
  .vocab li{grid-template-columns:1fr;gap:2px;}
}
