/* ===== Lufeng Elementary 陸豐國小（田尾） — shared site styles =====
   Type system referenced from yangming-jhs (Playfair Display + Inter, 20/23px).
   Garden palette (田尾花鄉): 花園綠 garden green + 暖金 sun gold + 花卉玫瑰 blossom rose.
   var names kept (rice/ember/leaf) for the nth-child accent rotation; values remapped. */
:root{
  --rice:#d99a2b;--rice-deep:#9a6a10;--rice-soft:#f8eccb;
  --ember:#2f8056;--ember-deep:#1c5537;--ember-soft:#d9efe2;
  --leaf:#cf4f7c;--leaf-deep:#9c3358;--leaf-soft:#f8dde8;
  --ink:#23201d;--ink-soft:#6a635c;--line:#ece7df;--cream:#fbf7f0;
  --shadow:0 14px 38px -16px rgba(29,85,55,.30);
  --shadow-sm:0 6px 16px -6px rgba(29,85,55,.18);
  --max:1080px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;}
body{background:#fff;color:var(--ink);font-family:'Inter','PingFang TC','Apple LiGothic Medium','Microsoft JhengHei',sans-serif;font-size:20px;line-height:1.65;-webkit-font-smoothing:antialiased;}
@media(min-width:720px){body{font-size:23px;}}
img{max-width:100%;display:block;}
a{color:var(--ember-deep);text-decoration:none;transition:color .2s;}
a:hover{color:var(--rice-deep);}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px;}
.serif{font-family:'Playfair Display','PingFang TC',serif;}

/* ===== Topbar ===== */
.tb{background:rgba(255,255,255,.94);border-bottom:1px solid var(--line);padding:11px 0;position:sticky;top:0;z-index:50;backdrop-filter:blur(8px);}
.tb__inner{max-width:var(--max);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;}
.tb__brand{display:flex;align-items:center;gap:12px;text-decoration:none;}
.tb__logo{width:44px;height:44px;border-radius:50%;background:#fff;object-fit:contain;padding:2px;box-shadow:0 4px 10px -2px rgba(29,85,55,.20);border:1px solid var(--line);flex-shrink:0;}
.tb__name{font-family:'Playfair Display','PingFang TC',serif;font-size:18px;font-weight:700;color:var(--ember-deep);line-height:1.1;}
.tb__name small{display:block;font-family:'PingFang TC',sans-serif;font-size:12px;font-weight:500;color:var(--ink-soft);margin-top:3px;letter-spacing:.04em;}
.tb__nav{display:flex;gap:20px;flex-wrap:wrap;justify-content:flex-end;}
.tb__nav a{color:var(--ink);font-size:15px;font-weight:500;letter-spacing:.04em;}
.tb__nav a:hover{color:var(--ember);}
.tb__nav a.is-active{color:var(--ember);font-weight:700;}
@media(max-width:640px){.tb__inner{flex-direction:column;align-items:flex-start;gap:10px;}.tb__nav{gap:14px;justify-content:flex-start;}.tb__nav a{font-size:14px;}}

/* ===== Photo banner (NO full overlay — bottom scrim + text shadow only) ===== */
.hero{position:relative;min-height:300px;display:flex;align-items:flex-end;background-size:cover;background-position:center;color:#fff;}
@media(min-width:720px){.hero{min-height:420px;}}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(18,40,28,.62) 0%,rgba(18,40,28,.22) 34%,rgba(18,40,28,0) 60%);}
.hero__inner{position:relative;z-index:1;max-width:var(--max);margin:0 auto;width:100%;padding:0 24px 30px;}
.hero .eyebrow{display:inline-block;font-size:12px;letter-spacing:.3em;text-transform:uppercase;font-weight:700;color:#fff;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.35);border-radius:99px;padding:5px 14px;margin-bottom:12px;backdrop-filter:blur(2px);}
.hero h1{font-family:'Playfair Display','PingFang TC',serif;font-size:clamp(34px,6vw,58px);font-weight:800;line-height:1.05;text-shadow:0 2px 14px rgba(0,0,0,.55),0 1px 3px rgba(0,0,0,.5);}
.hero .h1-zh{font-family:'PingFang TC',sans-serif;font-size:clamp(17px,2.2vw,23px);font-weight:600;margin-top:8px;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.6);}
.hero .back{display:inline-flex;margin-top:18px;padding:9px 18px;border-radius:22px;background:rgba(255,255,255,.22);color:#fff;font-size:16px;font-weight:600;backdrop-filter:blur(3px);}

/* ===== Sections ===== */
section{padding:52px 0;border-bottom:1px solid var(--line);}
@media(min-width:720px){section{padding:76px 0;}}
section:last-of-type{border-bottom:none;}
.sec__no{font-family:'Playfair Display',serif;color:var(--ember);font-size:21px;font-weight:700;letter-spacing:5px;}
@media(min-width:720px){.sec__no{font-size:24px;}}
.sec__title{font-family:'Playfair Display',serif;font-size:40px;font-weight:700;color:var(--ember-deep);line-height:1.15;margin-top:6px;letter-spacing:.5px;}
@media(min-width:720px){.sec__title{font-size:56px;}}
.sec__title-zh{font-size:20px;color:var(--ink-soft);font-weight:500;margin-top:10px;letter-spacing:1px;}
@media(min-width:720px){.sec__title-zh{font-size:24px;}}
.sec__rule{width:92px;height:6px;background:var(--rice);border-radius:3px;margin:20px 0 34px;}

/* ===== About / lead / body ===== */
.lead{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:var(--ember-deep);line-height:1.4;}
@media(min-width:720px){.lead{font-size:34px;}}
.lead-zh{margin-top:14px;font-size:19px;color:var(--ink-soft);font-weight:500;line-height:1.65;}
@media(min-width:720px){.lead-zh{font-size:22px;}}
.body p{margin-top:16px;font-size:20px;line-height:1.78;}
@media(min-width:720px){.body p{font-size:22px;}}
.body .zh{color:var(--ink-soft);font-size:18px;line-height:1.7;}
@media(min-width:720px){.body .zh{font-size:20px;}}
.body strong{color:var(--ember-deep);font-weight:700;}
.figure{margin-top:30px;background:#fff;border-radius:18px;border:1px solid var(--line);padding:14px;box-shadow:var(--shadow);}
.figure img{width:100%;border-radius:10px;}
.figure figcaption{margin-top:12px;text-align:center;font-style:italic;font-size:16px;color:var(--ink-soft);}
@media(min-width:720px){.figure figcaption{font-size:18px;}}
.quote{margin-top:32px;background:var(--rice-soft);border-left:6px solid var(--rice);padding:24px 28px;border-radius:0 12px 12px 0;}
.quote__text{font-family:'Playfair Display',serif;font-size:25px;font-weight:700;color:var(--ember-deep);line-height:1.4;font-style:italic;}
@media(min-width:720px){.quote__text{font-size:30px;}}
.quote__zh{font-size:17px;color:var(--ink-soft);margin-top:10px;line-height:1.6;}
@media(min-width:720px){.quote__zh{font-size:20px;}}

/* ===== Card grids (lessons / category) ===== */
.cards{display:grid;grid-template-columns:1fr;gap:24px;}
@media(min-width:680px){.cards{grid-template-columns:repeat(2,1fr);}}
@media(min-width:980px){.cards.three{grid-template-columns:repeat(3,1fr);}}
.lcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s;color:inherit;border-top:8px solid var(--rice);}
.lcard:nth-child(2){border-top-color:var(--ember);}.lcard:nth-child(3){border-top-color:var(--leaf);}.lcard:nth-child(4){border-top-color:var(--rice);}
.lcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);color:inherit;}
.lcard .cover{aspect-ratio:16/10;overflow:hidden;background:var(--rice-soft);}
.lcard .cover img{width:100%;height:100%;object-fit:cover;}
.lcard .body{padding:22px 24px 26px;}
.lcard h3{font-family:'Playfair Display',serif;font-size:26px;color:var(--ember-deep);font-weight:700;line-height:1.15;}
.lcard .zh{font-family:'PingFang TC',sans-serif;font-size:18px;color:var(--ink);font-weight:600;margin-top:5px;}
.lcard .meta{margin-top:12px;font-size:14px;font-weight:700;letter-spacing:.08em;color:var(--rice-deep);text-transform:uppercase;}
.lcard .cover.vid{position:relative;}
.lcard .cover.vid::after{content:"\25B6";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:62px;height:62px;border-radius:50%;background:rgba(29,85,55,.82);color:#fff;font-size:23px;display:flex;align-items:center;justify-content:center;padding-left:4px;box-shadow:0 6px 18px rgba(0,0,0,.4);transition:transform .2s,background .2s;}
.lcard:hover .cover.vid::after{transform:translate(-50%,-50%) scale(1.12);background:var(--ember);}
.lcard.soon{opacity:.74;}
.lcard.soon .cover{background:linear-gradient(135deg,var(--ember-soft),var(--rice-soft));display:flex;align-items:center;justify-content:center;font-size:54px;}

/* big feature card (festivals) */
.feature{display:grid;grid-template-columns:1fr;gap:0;background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow-sm);color:inherit;transition:transform .18s,box-shadow .18s;}
@media(min-width:760px){.feature{grid-template-columns:1.1fr 1fr;}}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow);color:inherit;}
.feature .cover{min-height:220px;background-size:cover;background-position:center;}
.feature .body{padding:30px 32px 34px;display:flex;flex-direction:column;justify-content:center;}
.feature .body h3{font-family:'Playfair Display',serif;font-size:32px;color:var(--ember-deep);font-weight:700;line-height:1.12;}
.feature .body .zh{font-family:'PingFang TC',sans-serif;font-size:19px;color:var(--ink);font-weight:600;margin-top:6px;}
.feature .body p{font-size:18px;color:var(--ink-soft);margin-top:14px;line-height:1.65;}
.feature .cta{margin-top:18px;font-family:'Playfair Display',serif;color:var(--ember);font-weight:700;font-size:18px;letter-spacing:.5px;}
.feature .cta::after{content:" →";}

/* ===== News cards (self-contained, no outbound link) ===== */
.news-grid{display:grid;grid-template-columns:1fr;gap:28px;}
@media(min-width:880px){.news-grid{grid-template-columns:1fr 1fr;gap:32px;}}
.news-card{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-sm);border-top:8px solid var(--rice);display:flex;flex-direction:column;}
.news-card:nth-child(2){border-top-color:var(--ember);}.news-card:nth-child(3){border-top-color:var(--leaf);}.news-card:nth-child(4){border-top-color:var(--rice);}
.news-card__img{aspect-ratio:16/10;background:var(--rice-soft);overflow:hidden;}
.news-card__img img{width:100%;height:100%;object-fit:cover;}
.news-card__body{padding:26px 28px 30px;}
.news-card__tag{font-family:'Playfair Display',serif;color:var(--ember);font-size:14px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;}
.news-card h3{font-family:'Playfair Display',serif;font-size:25px;font-weight:700;color:var(--ember-deep);line-height:1.2;}
.news-card h3 .zh{display:block;font-family:'PingFang TC',sans-serif;font-size:18px;color:var(--ink);font-weight:600;margin-top:6px;line-height:1.4;}
.news-card__date{font-size:14px;color:var(--ink-soft);letter-spacing:.5px;margin-top:12px;font-weight:600;}
.news-card__hook{font-size:18px;color:var(--ink);margin-top:14px;line-height:1.65;}
.news-card__hook-zh{font-size:16px;color:var(--ink-soft);margin-top:12px;padding-top:12px;border-top:1px dashed var(--line);line-height:1.7;}

/* ===== Official-site mini news cards ===== */
.ofeed{display:grid;grid-template-columns:1fr;gap:14px;}
@media(min-width:720px){.ofeed{grid-template-columns:1fr 1fr;}}
.ocard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 22px;box-shadow:var(--shadow-sm);border-left:6px solid var(--rice);}
.ocard:nth-child(3n+2){border-left-color:var(--ember);}.ocard:nth-child(3n){border-left-color:var(--leaf);}
.ocard .tag{font:700 13px/1 'Inter';letter-spacing:.1em;text-transform:uppercase;color:var(--rice-deep);}
.ocard h3{font-family:'Playfair Display',serif;font-size:21px;color:var(--ember-deep);font-weight:700;margin-top:8px;line-height:1.25;}
.ocard h3 .zh{display:block;font-family:'PingFang TC',sans-serif;font-size:16px;color:var(--ink);font-weight:600;margin-top:3px;}
.ocard .date{font-size:14px;color:var(--ink-soft);margin-top:8px;}
.ncard{cursor:pointer;}
.ncard .news-card__cta{margin-top:14px;font-family:'Playfair Display',serif;color:var(--ember);font-weight:700;font-size:16px;}
.ncard .news-card__cta::after{content:" →";}

/* ===== Classroom English / Announcements (yangming pattern) ===== */
.credits{margin-top:26px;display:flex;flex-wrap:wrap;gap:14px 28px;padding:18px 24px;border-radius:12px;background:var(--rice-soft);border-left:6px solid var(--rice);max-width:820px;}
.credits.is-broadcast{background:var(--ember-soft);border-left-color:var(--ember);}
.credits__cell{display:flex;flex-direction:column;}
.credits__label{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--rice-deep);}
.credits.is-broadcast .credits__label{color:var(--ember-deep);}
.credits__value{font-size:17px;color:var(--ink);font-weight:600;margin-top:2px;}
@media(min-width:720px){.credits__label{font-size:13px;}.credits__value{font-size:19px;}}
.player{margin-top:30px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:var(--shadow);}
@media(min-width:720px){.player{padding:18px;}}
.player__ratio{position:relative;width:100%;padding-top:56.25%;border-radius:10px;overflow:hidden;background:#000;}
.player__ratio iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.player-link{margin-top:14px;display:flex;align-items:center;gap:14px;padding:16px 22px;background:#fff;border:1.5px solid var(--line);border-radius:14px;color:var(--ember-deep);transition:transform .2s,box-shadow .2s,border-color .2s;}
.player-link:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--rice);color:var(--ember-deep);}
.player-link__icon{flex-shrink:0;width:42px;height:30px;border-radius:6px;background:#FF0000;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;}
.player-link__text{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0;}
.player-link__text strong{font-family:'Playfair Display',serif;font-size:18px;color:var(--ember-deep);font-weight:700;line-height:1.3;}
.player-link__text span{font-family:'PingFang TC',sans-serif;font-size:14px;color:var(--ink-soft);line-height:1.45;}
.player-link__arrow{font-size:22px;color:var(--ember);flex-shrink:0;}
.topics{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:32px;}
@media(min-width:720px){.topics{grid-template-columns:repeat(3,1fr);gap:16px;}}
@media(min-width:1000px){.topics{grid-template-columns:repeat(5,1fr);}}
.topic{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow-sm);border-top:4px solid var(--rice);}
.topic:nth-child(2n){border-top-color:var(--ember);}.topic:nth-child(3n){border-top-color:var(--leaf);}
.topic__no{font-family:'Playfair Display',serif;color:var(--ember);font-weight:800;font-size:14px;letter-spacing:2px;}
.topic__en{margin-top:4px;font-size:15px;font-weight:700;color:var(--ember-deep);line-height:1.35;}
.topic__zh{margin-top:3px;font-size:13px;color:var(--ink-soft);line-height:1.4;}
.offices{display:grid;grid-template-columns:1fr;gap:18px;margin-top:32px;}
@media(min-width:720px){.offices{grid-template-columns:1fr 1fr;gap:24px;}}
.office{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 26px 26px;box-shadow:var(--shadow-sm);border-left:6px solid var(--rice);}
.office:nth-child(2){border-left-color:var(--ember);}.office:nth-child(3){border-left-color:var(--leaf);}.office:nth-child(4){border-left-color:var(--rice-deep);}
.office__title{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;color:var(--ember-deep);line-height:1.2;}
.office__title-zh{font-size:17px;color:var(--ink);font-weight:600;margin-top:6px;}
.office__list{list-style:none;margin-top:14px;}
.office__list li{padding:10px 0;border-bottom:1px dashed var(--line);font-size:16px;color:var(--ink);line-height:1.5;display:flex;gap:10px;align-items:baseline;}
.office__list li:last-child{border-bottom:none;}
.office__list .ep{flex:0 0 auto;font-family:'Playfair Display',serif;color:var(--ember);font-weight:700;font-size:13px;letter-spacing:1.5px;}

/* ===== Photo-essay (photo lessons) ===== */
.intro{max-width:880px;margin:40px auto 6px;text-align:center;}
.intro .en{font-size:clamp(19px,2vw,22px);color:var(--ink);}
.intro .zh{font-family:'PingFang TC',sans-serif;font-size:clamp(17px,1.8vw,19px);color:var(--ink-soft);margin-top:8px;}
.story{display:grid;gap:26px;padding:30px 0 10px;}
.srow{display:grid;grid-template-columns:1fr;gap:18px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px;box-shadow:var(--shadow-sm);}
@media(min-width:760px){.srow{grid-template-columns:minmax(0,500px) 1fr;gap:34px;padding:22px 28px;}.srow.alt{grid-template-columns:1fr minmax(0,500px);}.srow.alt .scap{order:-1;}}
.srow img{width:100%;border-radius:13px;box-shadow:0 8px 22px -12px rgba(0,0,0,.3);}
.scap .num{font:700 15px/1 'Inter';color:var(--rice-deep);letter-spacing:.14em;}
.scap .en{font-size:clamp(20px,2.1vw,24px);font-weight:600;color:var(--ink);margin-top:10px;line-height:1.5;}
.scap .zh{font-family:'PingFang TC','Apple LiGothic Medium','Microsoft JhengHei',sans-serif;font-size:clamp(17px,1.8vw,19px);color:var(--ink-soft);margin-top:8px;line-height:1.7;}
.sec-h{font-family:'Playfair Display',serif;font-size:clamp(28px,4vw,40px);color:var(--ember-deep);font-weight:700;text-align:center;margin:54px 0 4px;}
.sec-h small{display:block;font-family:'PingFang TC',sans-serif;font-size:19px;color:var(--ink-soft);font-weight:500;margin-top:6px;letter-spacing:.04em;}
.events{display:grid;grid-template-columns:1fr;gap:18px;margin-top:26px;}
@media(min-width:680px){.events{grid-template-columns:1fr 1fr;}}
.events img{width:100%;border-radius:14px;border:1px solid var(--line);box-shadow:var(--shadow-sm);}
.reading{max-width:900px;margin:26px auto 0;padding:30px 32px;background:var(--cream);border:1px solid var(--line);border-radius:18px;border-left:7px solid var(--rice);}
.reading .en{font-size:clamp(19px,2vw,21px);color:var(--ink);line-height:1.8;}
.reading .zh{font-family:'PingFang TC',sans-serif;font-size:clamp(17px,1.8vw,19px);color:var(--ink-soft);line-height:1.85;margin-top:16px;}
.vocab{max-width:900px;margin:26px auto 0;display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
@media(min-width:620px){.vocab{grid-template-columns:repeat(3,1fr);}}
.vchip{background:#fff;border:1px solid var(--line);border-radius:13px;padding:14px 16px;box-shadow:var(--shadow-sm);border-top:5px solid var(--rice);}
.vchip:nth-child(3n+2){border-top-color:var(--ember);}.vchip:nth-child(3n){border-top-color:var(--leaf);}
.vchip b{font-family:'Playfair Display',serif;font-size:21px;color:var(--ink);font-weight:700;display:block;line-height:1.2;}
.vchip span{font-family:'PingFang TC',sans-serif;font-size:16px;color:var(--ink-soft);}
.lnav{display:flex;justify-content:center;gap:14px;padding:46px 0 0;flex-wrap:wrap;}
.lnav a{padding:13px 26px;border-radius:11px;background:var(--ember-deep);color:#fff;font-weight:700;font-size:19px;}
.lnav a:hover{background:var(--rice);}

/* ===== Word of the Day (大莊 dajuang layout) ===== */
.vocabs{display:grid;grid-template-columns:1fr;gap:26px;padding:8px 0 4px;}
@media(min-width:880px){.vocabs{grid-template-columns:repeat(2,1fr);}}
.vc{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-sm);border-top:7px solid var(--rice);}
.vc:nth-child(2n){border-top-color:var(--ember);}
.vc__head{padding:24px 26px 18px;}
.vc__num{font:700 14px/1 'Inter';color:var(--rice-deep);letter-spacing:.16em;}
.vc__term{font-family:'Playfair Display',serif;font-size:32px;font-weight:700;color:var(--ember-deep);line-height:1.12;margin-top:8px;}
.vc__pos{font-family:'Inter';font-size:18px;font-style:italic;color:var(--ink-soft);font-weight:500;margin-left:6px;}
.vc__zh{font-family:'PingFang TC',sans-serif;font-size:20px;color:var(--ink);font-weight:600;margin-top:4px;}
.vc__video{position:relative;width:100%;padding-bottom:56.25%;background:#000;}
.vc__video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.vc__body{padding:20px 26px 26px;}
.vc__exs{display:flex;flex-direction:column;gap:14px;}
.vc__ex .en{font-size:18px;color:var(--ink);line-height:1.55;}
.vc__ex .en b{color:var(--ember-deep);}
.vc__ex .zh{font-family:'PingFang TC',sans-serif;font-size:16px;color:var(--ink-soft);line-height:1.6;margin-top:3px;}

/* ===== Campus gallery + lightbox ===== */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
@media(min-width:680px){.gallery{grid-template-columns:repeat(3,1fr);gap:16px;}}
@media(min-width:1000px){.gallery{grid-template-columns:repeat(4,1fr);}}
.gallery figure{position:relative;margin:0;border-radius:14px;overflow:hidden;cursor:zoom-in;box-shadow:var(--shadow-sm);aspect-ratio:4/3;}
.gallery img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s cubic-bezier(.2,.7,.2,1);}
.gallery figure:hover img{transform:scale(1.08);}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:26px 14px 11px;color:#fff;font-family:'Playfair Display',serif;font-size:17px;font-weight:700;background:linear-gradient(to top,rgba(0,0,0,.66),transparent);opacity:0;transform:translateY(6px);transition:opacity .25s,transform .25s;}
.gallery figure:hover figcaption{opacity:1;transform:none;}
.gallery figcaption small{display:block;font-family:'PingFang TC',sans-serif;font-size:14px;font-weight:500;opacity:.92;margin-top:2px;}
.lb{position:fixed;inset:0;background:rgba(18,40,28,.93);display:none;align-items:center;justify-content:center;z-index:200;padding:24px;cursor:zoom-out;}
.lb.open{display:flex;}
.lb img{max-width:96vw;max-height:86vh;border-radius:10px;box-shadow:0 24px 64px rgba(0,0,0,.6);}
.lb__cap{position:absolute;bottom:18px;left:0;right:0;text-align:center;color:#fff;font-size:17px;font-family:'Playfair Display',serif;}
.lb__cap small{font-family:'PingFang TC',sans-serif;opacity:.85;margin-left:8px;}

/* ===== Interactive CTA buttons (official site / facebook) ===== */
.ctas{display:grid;grid-template-columns:1fr;gap:16px;max-width:780px;}
@media(min-width:640px){.ctas{grid-template-columns:1fr 1fr;}}
.cta-btn{background:var(--ember);color:#fff;border-radius:16px;padding:22px 26px;display:flex;align-items:center;gap:16px;box-shadow:0 10px 26px -10px rgba(29,85,55,.55);transition:transform .18s,background .18s,color .18s,box-shadow .18s;}
.cta-btn:hover{background:#fff;color:var(--ember-deep);transform:translateY(-4px);box-shadow:var(--shadow);}
.cta-btn--fb{background:#1877f2;box-shadow:0 10px 26px -10px rgba(24,119,242,.55);}
.cta-btn--fb:hover{background:#fff;color:#0c63d4;}
.cta-btn__ico{flex-shrink:0;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;transition:background .18s,color .18s;}
.cta-btn:hover .cta-btn__ico{background:var(--ember-soft);}
.cta-btn--fb:hover .cta-btn__ico{background:#e7f0ff;}
.cta-btn__tx{flex:1;min-width:0;}
.cta-btn__t{font-family:'Playfair Display',serif;font-size:21px;font-weight:700;line-height:1.2;}
.cta-btn__zh{font-size:15px;margin-top:3px;font-weight:600;opacity:.94;}
.cta-btn__arrow{font-size:24px;font-weight:700;flex-shrink:0;transition:transform .18s;}
.cta-btn:hover .cta-btn__arrow{transform:translate(3px,-3px);}

/* footer button stack (compact) */
.ft-ctas{display:flex;flex-direction:column;gap:12px;margin-top:2px;}
.cta-btn--sm{padding:13px 18px;border-radius:12px;gap:12px;box-shadow:0 6px 16px -8px rgba(0,0,0,.4);}
.cta-btn--sm .cta-btn__ico{width:36px;height:36px;font-size:19px;}
.cta-btn--sm .cta-btn__t{font-size:17px;}
.cta-btn--sm .cta-btn__zh{font-size:13px;}
.cta-btn--sm .cta-btn__arrow{font-size:20px;}

/* ===== Hero entrance animation ===== */
.hero .eyebrow,.hero h1,.hero .h1-zh{opacity:0;transform:translateY(20px);animation:heroIn .85s cubic-bezier(.2,.7,.2,1) forwards;}
.hero h1{animation-delay:.12s;}.hero .h1-zh{animation-delay:.26s;}
@keyframes heroIn{to{opacity:1;transform:none;}}
@media(prefers-reduced-motion:reduce){.hero .eyebrow,.hero h1,.hero .h1-zh{animation:none;opacity:1;transform:none;}}

/* ===== Home extras: ken-burns hero, pillars, spotlight, scroll cue ===== */
.hero.kb{animation:kb 20s ease-in-out infinite alternate;}
@keyframes kb{from{background-size:100%;}to{background-size:113%;}}
@media(prefers-reduced-motion:reduce){.hero.kb{animation:none;}}
.hero::before{content:"";position:absolute;bottom:0;left:0;right:0;height:5px;z-index:2;background:linear-gradient(90deg,var(--leaf) 0%,var(--rice) 38%,var(--ember) 72%,var(--rice) 100%);}
.scrollcue{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);z-index:3;color:#fff;font-size:26px;opacity:.85;animation:bob 1.8s ease-in-out infinite;text-shadow:0 2px 8px rgba(0,0,0,.5);}
@keyframes bob{0%,100%{transform:translate(-50%,0);}50%{transform:translate(-50%,8px);}}
@media(prefers-reduced-motion:reduce){.scrollcue{animation:none;}}
.pillars{display:grid;grid-template-columns:1fr;gap:22px;}
@media(min-width:720px){.pillars{grid-template-columns:1fr 1fr;gap:26px;}}
.pillar{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px 28px;box-shadow:var(--shadow-sm);border-top:8px solid var(--rice);transition:transform .2s,box-shadow .2s;}
.pillar:nth-child(2){border-top-color:var(--ember);}.pillar:nth-child(3){border-top-color:var(--leaf);}.pillar:nth-child(4){border-top-color:var(--rice-deep);}
.pillar:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.pillar__icon{font-size:52px;line-height:1;margin-bottom:10px;transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.pillar:hover .pillar__icon{transform:scale(1.18) rotate(-7deg);}
.pillar__t{font-family:'Playfair Display',serif;font-size:27px;font-weight:700;color:var(--ember-deep);line-height:1.15;}
.pillar__zh{font-family:'PingFang TC',sans-serif;font-size:19px;color:var(--ink);font-weight:600;margin-top:4px;}
.pillar__b{font-size:18px;color:var(--ink-soft);margin-top:12px;line-height:1.65;}
.spotlight{background:linear-gradient(135deg,var(--rice-soft) 0%,var(--ember-soft) 100%);border:2px solid var(--rice);border-radius:24px;padding:44px 30px;text-align:center;box-shadow:var(--shadow);}
@media(min-width:720px){.spotlight{padding:60px 48px;}}
.spotlight__big{font-family:'Playfair Display',serif;font-size:84px;font-weight:800;color:var(--ember);line-height:1;letter-spacing:-2px;}
@media(min-width:720px){.spotlight__big{font-size:128px;}}
.spotlight__t{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;color:var(--ember-deep);margin-top:8px;}
@media(min-width:720px){.spotlight__t{font-size:34px;}}
.spotlight__zh{font-size:19px;color:var(--ink);font-weight:600;margin-top:6px;}
.spotlight__b{font-size:18px;color:var(--ink-soft);max-width:680px;margin:14px auto 0;line-height:1.7;}

/* ===== Video grid (English Life self-intros) ===== */
.vidgrid{display:grid;grid-template-columns:1fr;gap:20px;margin-top:26px;}
@media(min-width:600px){.vidgrid{grid-template-columns:1fr 1fr;}}
@media(min-width:960px){.vidgrid{grid-template-columns:repeat(3,1fr);}}
.vcard{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);}
.vthumb{position:relative;width:100%;padding-bottom:56.25%;background:#000;}
.vthumb iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.vcard h4{font-family:'Playfair Display',serif;font-size:19px;color:var(--ember-deep);font-weight:700;padding:14px 18px 4px;line-height:1.2;}
.vcard .zh{font-family:'PingFang TC',sans-serif;font-size:15px;color:var(--ink-soft);padding:0 18px 16px;}
.feat-video{position:relative;width:100%;padding-bottom:56.25%;background:#000;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);margin-top:8px;}
.feat-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}

/* ===== Principal experience table ===== */
.exp{width:100%;border-collapse:collapse;margin-top:8px;font-size:18px;}
.exp td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:top;line-height:1.5;}
.exp tr td:first-child{font-weight:700;color:var(--ember-deep);white-space:nowrap;font-size:16px;}
.exp tr td:nth-child(2){font-weight:700;color:var(--ink);width:34%;}
.exp tr td:last-child{color:var(--ink-soft);}
@media(max-width:600px){.exp,.exp tbody,.exp tr,.exp td{display:block;}.exp td{border:0;padding:2px 0;}.exp tr{border-bottom:1px solid var(--line);padding:12px 0;}}
.portrait{width:100%;max-width:340px;border-radius:16px;box-shadow:var(--shadow);margin:0 auto;}

/* ===== Footer ===== */
.ft{background:var(--ember-deep);color:rgba(255,255,255,.80);padding:44px 0 34px;margin-top:0;}
.ft__inner{max-width:var(--max);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr;gap:26px;}
@media(min-width:760px){.ft__inner{grid-template-columns:1.6fr 1fr 1.1fr;gap:40px;}}
.ft__brand{display:flex;gap:14px;align-items:flex-start;}
.ft__brand img{width:56px;height:56px;border-radius:50%;background:#fff;padding:4px;object-fit:contain;flex-shrink:0;}
.ft__brand h4{font-family:'Playfair Display',serif;font-size:21px;color:#fff;font-weight:700;line-height:1.15;}
.ft__brand .zh{font-size:14px;color:rgba(255,255,255,.78);margin-top:3px;}
.ft__addr{margin-top:10px;font-size:14px;color:rgba(255,255,255,.7);line-height:1.65;}
.ft__col h5{font-family:'Playfair Display',serif;font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--rice-soft);margin-bottom:12px;}
.ft__col ul{list-style:none;}
.ft__col li{margin-bottom:8px;font-size:15px;color:rgba(255,255,255,.85);}
.ft__col a{color:rgba(255,255,255,.85);border-bottom:1px dashed rgba(246,235,207,.5);}
.ft__col a:hover{color:var(--rice-soft);}
.ft__bottom{max-width:var(--max);margin:30px auto 0;padding:18px 24px 0;border-top:1px solid rgba(255,255,255,.16);font-size:13px;color:rgba(255,255,255,.62);text-align:center;line-height:1.7;}
.ft__bottom a{color:var(--rice-soft);border-bottom:1px dashed rgba(246,235,207,.5);}
.ft__bottom a:hover{color:#fff;}

/* ===== reveal-fx ===== */
.rvl{opacity:0;transform:translateY(24px);transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1);}
.rvl.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.rvl{opacity:1!important;transform:none!important;}}

/* ===== Speaker / text-to-speech buttons (learning content) ===== */
.say{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border:none;border-radius:50%;background:var(--ember-soft);color:var(--ember-deep);font-size:15px;line-height:1;cursor:pointer;vertical-align:middle;margin-left:8px;flex:0 0 auto;transition:transform .15s,background .15s,color .15s;-webkit-tap-highlight-color:transparent;}
.say:hover{background:var(--ember);color:#fff;transform:scale(1.12);}
.say:active{transform:scale(.95);}
.say.saying{background:var(--rice);color:#fff;animation:saypulse 1s ease-in-out infinite;}
@keyframes saypulse{0%,100%{box-shadow:0 0 0 0 rgba(200,146,47,.5);}50%{box-shadow:0 0 0 6px rgba(200,146,47,0);}}
@media(prefers-reduced-motion:reduce){.say.saying{animation:none;}}
.vc__term .say{width:32px;height:32px;font-size:16px;}
.vc__ex .say{width:26px;height:26px;font-size:13px;background:var(--leaf-soft);color:var(--leaf-deep);}
.vc__ex .say:hover{background:var(--leaf);color:#fff;}
.vchip{position:relative;padding-right:46px;}
.vchip .say{position:absolute;top:12px;right:12px;margin:0;}
.scap .en .say{width:28px;height:28px;font-size:14px;}
.reading .en .say{width:30px;height:30px;}


/* ===== Color banner (NO photo) — animated garden gradient + falling petals ===== */
.hero.col{background:linear-gradient(120deg,var(--c1,#2f8056) 0%,var(--c2,#d99a2b) 50%,var(--c3,#cf4f7c) 100%);background-size:200% 200%;animation:gradShift 16s ease infinite;}
@keyframes gradShift{0%{background-position:0% 50%;}50%{background-position:100% 50%;}100%{background-position:0% 50%;}}
@media(prefers-reduced-motion:reduce){.hero.col{animation:none;}}
.hero.col::after{background:linear-gradient(to top,rgba(18,40,28,.34) 0%,rgba(18,40,28,.10) 40%,rgba(18,40,28,0) 64%);}
.hero.col .petals{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none;}
.hero.col .petals span{position:absolute;top:-8%;font-size:24px;line-height:1;opacity:0;animation:fall linear infinite;will-change:transform;}
@keyframes fall{0%{transform:translateY(-10%) rotate(0deg);opacity:0;}12%{opacity:.85;}100%{transform:translateY(560px) rotate(260deg);opacity:0;}}
@media(prefers-reduced-motion:reduce){.hero.col .petals{display:none;}}
.hero.col .hero__inner{z-index:1;}

/* small color-banner variant for sub-pages */
.hero.col.sm{min-height:230px;}
@media(min-width:720px){.hero.col.sm{min-height:300px;}}

/* placeholder note (principal 留白) */
.note{max-width:820px;margin:30px auto 0;background:var(--rice-soft);border:1px dashed var(--rice);border-radius:16px;padding:24px 28px;color:var(--ink-soft);font-size:18px;line-height:1.7;text-align:center;}
@media(min-width:720px){.note{font-size:19px;}}

/* ===== Placeholder (gradient + emoji) covers for cards without photos ===== */
.lcard .cover.ph,.feature .cover.ph{display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,var(--cc1,#2f8056),var(--cc2,#cf4f7c));}
.lcard .cover.ph{font-size:62px;}
.feature .cover.ph{font-size:88px;min-height:220px;text-shadow:0 6px 18px rgba(0,0,0,.22);}
.lcard .cover.ph .em,.feature .cover.ph .em{filter:drop-shadow(0 4px 10px rgba(0,0,0,.25));transition:transform .3s cubic-bezier(.2,.7,.2,1);}
.lcard:hover .cover.ph .em,.feature:hover .cover.ph .em{transform:scale(1.14) rotate(-6deg);}
