
:root{
  color-scheme: only light;
  --navy:#0d1e2e;--slate:#1e3a52;
  --teal:#38c9b8;--teal-d:#20a090;--teal-l:#e0f8f5;--teal-m:#90ddd6;
  --gold:#e8a020;--gold-l:#fdf3dc;--gold-m:#f5d490;
  --purple:#7b5ea7;--purple-l:#f0eaf8;
  --coral:#e05c3a;--coral-l:#fdf0ec;
  --green:#2a9d6e;--green-l:#e4f7ef;
  --sky:#2980c0;--sky-l:#e8f2fc;
  --rose:#d63460;--rose-l:#fce8ef;
  --fog:#f4f8fc;--white:#fff;--muted:#557080;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
html.sz-md{font-size:18px}
html.sz-lg{font-size:20px}
body{font-family:'Outfit',sans-serif;background:var(--fog);color:var(--navy);min-height:100vh;font-size:1rem}
.zh{display:block}.en{display:none}span.zh{display:inline}span.en{display:none}
body.en-mode .zh{display:none}body.en-mode .en{display:block}
body.en-mode span.zh{display:none}body.en-mode span.en{display:inline}
.watermark{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-20deg);pointer-events:none;z-index:0;opacity:.032;width:60vw;max-width:480px}
/* LANG BAR */
.lang-bar{background:var(--navy);padding:6px 24px;display:flex;justify-content:flex-end;align-items:center;gap:8px;border-bottom:1px solid rgba(255,255,255,.08)}
.lang-label{font-size:11px;color:rgba(255,255,255,.4);letter-spacing:.07em;text-transform:uppercase;margin-right:4px}
.lang-btn{padding:4px 14px;font-size:12px;font-weight:600;border-radius:20px;border:1.5px solid rgba(255,255,255,.22);background:transparent;color:rgba(255,255,255,.6);cursor:pointer;transition:all .2s}
.lang-btn:hover{background:rgba(255,255,255,.1);color:#fff}
.lang-btn.active{background:var(--teal);color:var(--navy);border-color:var(--teal)}
.fsz-group{display:flex;align-items:center;gap:4px;margin-left:10px;padding-left:10px;border-left:1px solid rgba(255,255,255,.15)}
.fsz-label{font-size:11px;color:rgba(255,255,255,.4);letter-spacing:.07em;text-transform:uppercase;margin-right:2px}
.fsz-btn{padding:3px 10px;font-size:11px;font-weight:700;border-radius:20px;border:1.5px solid rgba(255,255,255,.22);background:transparent;color:rgba(255,255,255,.55);cursor:pointer;transition:all .2s;font-family:'Outfit',sans-serif;letter-spacing:.03em}
.fsz-btn:hover{background:rgba(255,255,255,.1);color:#fff}
.fsz-btn.active{background:var(--teal);color:var(--navy);border-color:var(--teal)}
/* HEADER */
header{background:linear-gradient(135deg,var(--navy) 0%,var(--slate) 100%);position:sticky;top:0;z-index:100;box-shadow:0 2px 24px rgba(0,0,0,.22)}
.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:12px 24px;gap:16px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0}
.brand-logo{width:38px;height:38px;border-radius:10px;object-fit:cover}
.brand-name{font-family:'Playfair Display',serif;color:#fff;font-size:16px;line-height:1.1}
.brand-tag{color:var(--teal-m);font-size:10px;font-weight:300;letter-spacing:.08em;text-transform:uppercase}
.header-nav{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}
.nav-btn{padding:5px 11px;font-size:11px;font-weight:500;color:rgba(255,255,255,.7);background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:20px;cursor:pointer;transition:all .2s;white-space:nowrap;font-family:'Outfit',sans-serif}
.nav-btn:hover{background:rgba(255,255,255,.1);color:#fff}
.nav-btn.active{background:var(--teal);color:var(--navy);border-color:var(--teal);font-weight:600}
.nav-btn.cta-nav{background:var(--gold);color:var(--navy);border-color:var(--gold);font-weight:700}
/* HAMBURGER */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:10px;cursor:pointer;padding:8px;flex-shrink:0}
.hamburger span{display:block;width:100%;height:2px;background:#fff;border-radius:2px;transition:all .25s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* MOBILE MENU */
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:200;background:rgba(8,18,28,.6);backdrop-filter:blur(3px)}
.mobile-menu.open{display:block}
.mm-panel{position:absolute;top:0;right:0;width:min(320px,88vw);height:100%;background:var(--navy);box-shadow:-4px 0 30px rgba(0,0,0,.4);display:flex;flex-direction:column;overflow-y:auto;animation:slideIn .25s ease}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
.mm-hdr{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.1)}
.mm-title{font-family:'Playfair Display',serif;color:#fff;font-size:16px}
.mm-close{width:36px;height:36px;background:rgba(255,255,255,.1);border:none;border-radius:8px;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.mm-lang{display:flex;gap:8px;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.08)}
.mm-lb{flex:1;padding:8px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:transparent;color:rgba(255,255,255,.6);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.mm-lb.active{background:var(--teal);color:var(--navy);border-color:var(--teal)}
.mm-list{flex:1;padding:10px 12px}
.mm-btn{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;margin-bottom:3px;border:none;border-radius:10px;background:transparent;color:rgba(255,255,255,.75);font-size:14px;font-family:'Outfit',sans-serif;cursor:pointer;text-align:left;transition:all .15s}
.mm-btn:hover{background:rgba(255,255,255,.08);color:#fff}
.mm-btn.active{background:rgba(56,201,184,.15);color:var(--teal);font-weight:600}
.mm-btn.cta-mm{background:var(--gold);color:var(--navy);font-weight:700;margin-top:8px}
.mm-icon{font-size:17px;width:22px;text-align:center;flex-shrink:0}
.mm-foot{padding:14px 20px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:rgba(255,255,255,.35);text-align:center}
.mm-fsz{padding:10px 20px;border-bottom:1px solid rgba(255,255,255,.08)}
.mm-fsz-label{font-size:11px;color:rgba(255,255,255,.4);letter-spacing:.07em;text-transform:uppercase;margin-bottom:7px}
.mm-fsz-row{display:flex;gap:7px}
.mm-fz-btn{flex:1;padding:8px 0;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:transparent;color:rgba(255,255,255,.6);font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;font-family:'Outfit',sans-serif}
.mm-fz-btn:hover{background:rgba(255,255,255,.08);color:#fff}
.mm-fz-btn.active{background:var(--teal);color:var(--navy);border-color:var(--teal)}
/* HERO */
.hero{background:linear-gradient(135deg,var(--navy) 0%,#1a3550 55%,#0c1e2e 100%);padding:52px 28px 48px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 0%,rgba(56,201,184,.13) 0%,transparent 70%)}
.hero-eye{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:12px;position:relative}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(26px,5vw,52px);color:#fff;line-height:1.12;margin-bottom:14px;position:relative}
.hero h1 em{color:var(--teal);font-style:normal}
.hero h1 strong{color:var(--gold)}
.hero-sub{font-size:0.9375rem;color:rgba(255,255,255,.7);max-width:620px;margin:0 auto 28px;line-height:1.8;position:relative}
.hero-cta{display:inline-block;padding:15px 38px;background:var(--teal);color:var(--navy);border-radius:50px;font-size:15px;font-weight:700;cursor:pointer;border:none;font-family:'Outfit',sans-serif;transition:all .2s;box-shadow:0 4px 24px rgba(56,201,184,.35);position:relative}
.hero-cta:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(56,201,184,.45);background:#2dbdad}
/* MAIN */
main{max-width:1200px;margin:0 auto;padding:36px 24px 80px;position:relative}
.section{display:none;animation:fadeIn .35s ease}
.section.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
/* GANTT TEASER */
.gantt-teaser{background:#fff;border-radius:18px;padding:28px 24px 22px;margin-bottom:32px;box-shadow:0 3px 16px rgba(13,30,46,.09);border:2px solid var(--teal-m);position:relative;overflow:hidden}
.gantt-teaser::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--teal),var(--gold),var(--purple),var(--coral))}
.gt-headline{font-family:'Playfair Display',serif;font-size:clamp(16px,2.5vw,22px);color:var(--navy);margin-bottom:6px}
.gt-sub{font-size:0.8125rem;color:var(--muted);margin-bottom:18px;line-height:1.6}
.gantt-scroll{width:100%;overflow-x:auto}
.gantt-tbl{width:100%;border-collapse:collapse;min-width:560px}
.gantt-tbl th{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:5px 8px;text-align:center;color:#fff;white-space:nowrap;background:var(--navy)}
.gantt-tbl th.lh{text-align:left;min-width:100px}
.gantt-tbl td.lbl{font-size:11px;font-weight:600;color:var(--navy);padding:4px 8px;background:#fafcff;border-right:2px solid var(--fog);white-space:nowrap}
.gantt-tbl td.cell{padding:3px 3px;border:1px solid rgba(255,255,255,.5);background:#fafcff}
.gbar{border-radius:4px;height:17px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;white-space:nowrap;overflow:hidden;padding:0 4px;transition:opacity .2s}
.row-physics .gbar{background:#3050c8;color:#fff}
.row-aisys .gbar{background:#5080c0;color:#fff}
.row-music .gbar{background:#8040c0;color:#fff}
.gantt-tbl:hover .gbar{opacity:.3}
.gantt-tbl:hover tr:hover .gbar{opacity:1}
.gt-note{font-size:11px;color:var(--muted);margin-top:8px;text-align:center}
.gt-cta-wrap{display:flex;gap:10px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.gt-cta-btn{padding:11px 32px;background:var(--teal);color:var(--navy);border:none;border-radius:30px;font-size:14px;font-weight:700;cursor:pointer;font-family:'Outfit',sans-serif;transition:all .2s}
.gt-cta-btn:hover{background:var(--teal-d);transform:translateY(-1px)}
/* legend */
.leg{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;font-size:11px;color:var(--muted)}
.leg-item{display:flex;align-items:center;gap:4px}
.leg-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}
/* QUIZ */
.quiz-wrap{max-width:700px;margin:0 auto;padding-bottom:40px}
.qprog{height:5px;background:rgba(56,201,184,.18);border-radius:3px;margin-bottom:28px;overflow:hidden}
.qbar{height:100%;background:var(--teal);border-radius:3px;transition:width .4s ease}
.qstep{display:none}
.qstep.active{display:block;animation:fadeIn .3s ease}
.qlabel{font-size:11px;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}
.qtitle{font-family:'Playfair Display',serif;font-size:clamp(17px,3vw,26px);color:var(--navy);line-height:1.3;margin-bottom:22px}
.qgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px;margin-bottom:26px}
.qopt{padding:13px 15px;border:2px solid #d0dde8;border-radius:14px;background:#fff;cursor:pointer;transition:all .18s;text-align:left;font-family:'Outfit',sans-serif}
.qopt:hover{border-color:var(--teal);background:var(--teal-l);transform:translateY(-2px);box-shadow:0 4px 14px rgba(56,201,184,.15)}
.qopt.selected{border-color:var(--teal);background:var(--teal-l);box-shadow:0 0 0 3px rgba(56,201,184,.18)}
.qopt .oi{font-size:22px;margin-bottom:6px;display:block}
.qopt .ot{font-size:0.8125rem;font-weight:600;color:var(--navy);display:block;margin-bottom:2px}
.qopt .os{font-size:0.6875rem;color:var(--muted);line-height:1.4;display:block}
.qnext{padding:11px 32px;background:var(--teal);color:var(--navy);border:none;border-radius:50px;font-size:14px;font-weight:700;cursor:pointer;font-family:'Outfit',sans-serif;transition:all .2s;opacity:.4;pointer-events:none}
.qnext.on{opacity:1;pointer-events:all}
.qnext.on:hover{background:var(--teal-d);transform:translateY(-1px)}
.qnext{display:none!important}
.qback{padding:9px 22px;background:transparent;color:var(--muted);border:1.5px solid #d0dde8;border-radius:50px;font-size:13px;cursor:pointer;font-family:'Outfit',sans-serif;margin-right:10px;transition:all .2s}
.qback:hover{border-color:var(--teal);color:var(--teal)}
/* RESULT */
.res-hero{background:linear-gradient(135deg,var(--navy),var(--slate));border-radius:20px;padding:30px 26px;margin-bottom:22px;color:#fff;position:relative;overflow:hidden}
.res-hero::after{content:'';position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:50%;background:rgba(56,201,184,.08)}
.res-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(56,201,184,.18);border:1px solid rgba(56,201,184,.35);border-radius:30px;padding:5px 13px;font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--teal);margin-bottom:12px}
.res-title{font-family:'Playfair Display',serif;font-size:clamp(19px,3.5vw,32px);margin-bottom:5px;position:relative}
.res-title em{color:var(--teal);font-style:normal}
.res-desc{font-size:0.8125rem;color:rgba(255,255,255,.7);line-height:1.75;max-width:560px;position:relative}
/* personalised gantt */
.res-gantt{background:#fff;border-radius:14px;padding:20px 18px;margin:18px 0;box-shadow:0 2px 10px rgba(13,30,46,.07);overflow-x:auto}
.rg-title{font-size:0.875rem;font-weight:600;color:var(--navy);margin-bottom:14px;display:flex;align-items:center;gap:7px}
.rgt{width:100%;border-collapse:collapse;min-width:460px}
.rgt th{background:var(--navy);color:#fff;font-size:11px;font-weight:600;padding:6px 10px;text-align:center;letter-spacing:.04em}
.rgt th.lh{text-align:left;padding-left:10px}
.rgt td.rl{font-size:11px;font-weight:600;color:var(--navy);padding:4px 10px 4px 8px;background:#fafcff;border-right:2px solid var(--fog);white-space:nowrap}
.rgt td.rc{padding:3px 3px;border:1px solid rgba(255,255,255,.5);background:#fafcff}
.rg-bar{border-radius:5px;height:19px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;white-space:nowrap;overflow:hidden;padding:0 4px}
.rg-bar.e{opacity:0}
.rc.now{background:rgba(56,201,184,.1);border-left:2px solid var(--teal)}
/* result detail grid */
.res-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin:16px 0}
.rc-card{background:#fff;border-radius:13px;border:1px solid rgba(13,30,46,.08);box-shadow:0 2px 10px rgba(13,30,46,.05);overflow:hidden;transition:transform .18s}
.rc-card:hover{transform:translateY(-2px)}
.rct{padding:13px 15px 9px;border-top-width:4px;border-top-style:solid}
.rct.teal{border-top-color:var(--teal)}.rct.gold{border-top-color:var(--gold)}.rct.purple{border-top-color:var(--purple)}.rct.coral{border-top-color:var(--coral)}.rct.green{border-top-color:var(--green)}.rct.sky{border-top-color:var(--sky)}.rct.rose{border-top-color:var(--rose)}
.rct-lbl{font-size:0.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:3px}
.rct-ttl{font-size:0.875rem;font-weight:700;color:var(--navy)}
.rcb{padding:0 15px 13px}
.ri{display:flex;gap:7px;padding:5px 0;border-bottom:1px solid var(--fog);font-size:0.75rem;align-items:flex-start}
.ri:last-child{border-bottom:none}
.rid{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:4px}
.rid.teal{background:var(--teal)}.rid.gold{background:var(--gold)}.rid.purple{background:var(--purple)}.rid.coral{background:var(--coral)}.rid.green{background:var(--green)}.rid.sky{background:var(--sky)}.rid.rose{background:var(--rose)}
.ri-txt{color:var(--navy);line-height:1.5;flex:1}
.ri-txt small{display:block;color:var(--muted);font-size:0.625rem;margin-top:1px}
/* career pills */
.career-section{background:#fff;border-radius:14px;padding:18px;margin:14px 0;box-shadow:0 2px 10px rgba(13,30,46,.06);border-left:4px solid var(--gold)}
.career-title{font-size:14px;font-weight:600;color:var(--navy);margin-bottom:12px}
.career-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.career-card{background:var(--fog);border-radius:10px;padding:12px 14px;border:1px solid rgba(13,30,46,.07)}
.career-name{font-size:0.8125rem;font-weight:600;color:var(--navy);margin-bottom:3px}
.career-sal{font-size:0.6875rem;color:var(--green);font-weight:600;margin-bottom:2px}
.career-grow{font-size:0.625rem;color:var(--muted)}
/* ALL MAJORS */
.mfilt{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.fb{padding:6px 13px;font-size:12px;border:1.5px solid #c8d8e8;border-radius:20px;background:#fff;color:var(--muted);cursor:pointer;font-family:'Outfit',sans-serif;transition:all .15s}
.fb:hover{background:var(--teal-l);border-color:var(--teal);color:var(--teal-d)}
.fb.active{background:var(--teal);color:var(--navy);border-color:var(--teal);font-weight:600}
.mgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px}
.mc{background:#fff;border-radius:13px;padding:15px;border:1px solid rgba(13,30,46,.08);cursor:pointer;transition:all .18s;box-shadow:0 2px 6px rgba(13,30,46,.04)}
.mc:hover{transform:translateY(-2px);box-shadow:0 5px 16px rgba(13,30,46,.1);border-color:var(--teal)}
.mc-cat{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.mc-name{font-size:0.8125rem;font-weight:700;color:var(--navy);margin-bottom:2px}
.mc-sub{font-size:0.6875rem;color:var(--muted);line-height:1.4;margin-bottom:7px}
.mc-tags{display:flex;gap:4px;flex-wrap:wrap}
.mc-tag{padding:2px 7px;border-radius:10px;font-size:9px;font-weight:600}
.cat-stem .mc-cat{color:var(--sky)}.cat-stem .mc-tag{background:var(--sky-l);color:var(--sky)}
.cat-biz  .mc-cat{color:var(--gold)}.cat-biz  .mc-tag{background:var(--gold-l);color:#7a5010}
.cat-hum  .mc-cat{color:var(--purple)}.cat-hum  .mc-tag{background:var(--purple-l);color:var(--purple)}
.cat-art  .mc-cat{color:var(--coral)}.cat-art  .mc-tag{background:var(--coral-l);color:var(--coral)}
.mc[data-cat].hidden{display:none}
/* COMPARE */
.tbl-wrap{overflow-x:auto;margin:12px 0}
table{width:100%;border-collapse:collapse;font-size:0.75rem}
th{background:var(--navy);color:#fff;padding:9px 11px;text-align:left;font-weight:500;font-size:11px}
td{padding:8px 11px;border-bottom:1px solid var(--fog);color:var(--muted);vertical-align:top;line-height:1.5}
tr:hover td{background:#fafcff}tr:last-child td{border-bottom:none}
.thl{font-weight:600;color:var(--navy)}
/* CONTACT */
.ct-hero{background:linear-gradient(135deg,var(--navy),var(--slate));border-radius:22px;padding:42px 30px;text-align:center;margin-bottom:24px;position:relative;overflow:hidden}
.ct-hero::before{content:'';position:absolute;top:-50px;right:-50px;width:200px;height:200px;border-radius:50%;background:rgba(56,201,184,.07)}
.ct-hero h2{font-family:'Playfair Display',serif;font-size:clamp(19px,3.5vw,32px);color:#fff;margin-bottom:10px;position:relative;z-index:1}
.ct-hero p{font-size:0.875rem;color:rgba(255,255,255,.72);max-width:500px;margin:0 auto 22px;line-height:1.75;position:relative;z-index:1}
.bgrp{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.bl{display:inline-block;padding:11px 26px;background:#06c755;color:#fff;border-radius:50px;font-weight:700;font-size:13px;text-decoration:none;transition:all .2s}
.bl:hover{background:#05b04a;transform:translateY(-2px)}
.bw{display:inline-block;padding:11px 26px;background:#fff;color:var(--navy);border-radius:50px;font-weight:700;font-size:13px;text-decoration:none;transition:all .2s}
.bw:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.12)}
.cg2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.qrc{background:#fff;border-radius:14px;padding:24px;text-align:center;border:2px solid var(--teal-m);box-shadow:0 4px 12px rgba(56,201,184,.1)}
.qrc img{width:155px;height:155px;object-fit:contain;margin-bottom:12px;border-radius:8px}
.qrc h3{font-size:14px;font-weight:600;color:var(--navy);margin-bottom:5px}
.qrc p{font-size:12px;color:var(--muted);line-height:1.55;margin-bottom:12px}
.bls{display:block;padding:10px 20px;background:#06c755;color:#fff;border-radius:50px;font-weight:600;font-size:13px;text-decoration:none;text-align:center;transition:all .2s}
.bls:hover{background:#05b04a}
.svc{background:#fff;border-radius:14px;padding:24px;border:2px solid var(--teal-m);display:flex;flex-direction:column;justify-content:space-between}
.svc h3{font-size:14px;font-weight:600;color:var(--navy);margin-bottom:11px}
.svl{list-style:none;margin:0 0 16px}
.svl li{padding:7px 0;border-bottom:1px solid var(--fog);font-size:0.75rem;color:var(--muted);display:flex;align-items:flex-start;gap:7px}
.svl li:last-child{border-bottom:none}
.ck{width:16px;height:16px;background:var(--teal);border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--navy);font-size:9px;font-weight:900;margin-top:1px}
.bws{display:block;padding:10px 20px;background:var(--navy);color:#fff;border-radius:50px;font-weight:600;font-size:13px;text-decoration:none;text-align:center}
.bws:hover{background:var(--slate)}
.cs{background:linear-gradient(135deg,var(--teal-l),#fff);border:2px solid var(--teal-m);border-radius:18px;padding:26px;text-align:center;margin-bottom:18px}
.cs h3{font-family:'Playfair Display',serif;font-size:20px;color:var(--navy);margin-bottom:6px}
.cs p{color:var(--muted);font-size:0.8125rem;margin-bottom:16px;line-height:1.65}
.tip{background:linear-gradient(135deg,var(--teal-l),#fff);border-left:4px solid var(--teal);border-radius:0 12px 12px 0;padding:13px 17px;font-size:0.8125rem;color:var(--muted);margin:14px 0;line-height:1.75}
.tip strong{color:var(--navy)}
/* RESPONSIVE */
@media(max-width:760px){
  .hamburger{display:flex}.header-nav{display:none!important}
  .header-inner{padding:10px 16px}.brand-tag{display:none}
  /* lang-bar: 手機上隱藏字體組，改放到 hamburger menu */
  .lang-bar{padding:5px 14px;gap:6px;flex-wrap:nowrap}
  .fsz-group{display:none}
  main{padding:18px 12px 64px}.hero{padding:32px 14px 28px}
  /* 加大觸控區域 */
  .qopt{padding:14px 14px;min-height:64px}
  .mc{padding:14px 12px}
  .nav-btn,.lang-btn{min-height:34px}
  /* 卡片文字 */
  .mc-name{font-size:0.9rem}
  .mc-sub{font-size:0.75rem}
}
@media(max-width:600px){
  .cg2{grid-template-columns:1fr}
  .res-grid{grid-template-columns:1fr}
  .qgrid{grid-template-columns:1fr 1fr}
  .career-grid{grid-template-columns:1fr 1fr}
  /* 手機卡片內容可讀性 */
  .ri{font-size:0.82rem;padding:6px 0}
  .career-name{font-size:0.875rem}
  .rct-ttl{font-size:0.9375rem}
  .tip{font-size:0.875rem;padding:12px 14px}
  .hero-sub{font-size:1rem}
  /* 比較表格可捲動 */
  .tbl-wrap{-webkit-overflow-scrolling:touch}
  table{font-size:0.8125rem}
  td{padding:7px 9px}
}
@media(max-width:380px){
  .qgrid{grid-template-columns:1fr}
  .lang-bar{padding:4px 10px;gap:4px}
  main{padding:14px 10px 60px}
}


/* ── Bottom Announcement Banner ── */
.bottom-banner {
  background: linear-gradient(135deg, #0d1e2e 0%, #1e3a52 100%);
  border-top: 1.5px solid rgba(56,201,184,.35);
  padding: 9px 20px 10px;
  text-align: center;
  font-family: 'Outfit', sans-serif;
  font-size: 11.5px;
  line-height: 1.6;
  color: rgba(255,255,255,.6);
}
.bottom-banner strong { color: var(--teal-m); }
@media(max-width:600px){
  .bottom-banner { font-size: 11px; padding: 8px 14px 9px; }
}

/* ── Tier Toggle Buttons ── */
.summer-toggle-wrap{display:flex;gap:8px;padding:10px 14px 0;background:#fff}
.summer-tier-btn{flex:1;padding:6px 0;font-size:11.5px;font-weight:600;border-radius:20px;border:1.5px solid #d0dde8;background:#fff;color:var(--muted);cursor:pointer;font-family:'Outfit',sans-serif;transition:all .18s;letter-spacing:.01em}
.summer-tier-btn.active{background:var(--purple);color:#fff;border-color:var(--purple)}
.summer-tier-btn:hover:not(.active){background:var(--purple-l);color:var(--purple);border-color:var(--purple)}
.comp-toggle-wrap .summer-tier-btn.active{background:var(--gold)!important;color:#fff!important;border-color:var(--gold)!important}
.comp-toggle-wrap .summer-tier-btn:hover:not(.active){background:var(--gold-l)!important;color:#7a5010!important;border-color:var(--gold)!important}
/* ── 強制鎖定 Light Mode：不跟隨系統深色模式 ── */
@media(prefers-color-scheme:dark){

  html,body{
    background-color:#f4f8fc!important;
    color:#0d1e2e!important;
  }
  /* 覆蓋所有可能被深色模式染色的白色/淺色背景 */
  td{background-color:#fff!important;color:#557080!important}
  tr:hover td{background:#fafcff!important}
  th{background:#0d1e2e!important;color:#fff!important}
  .gantt-teaser,.res-gantt,.rc-card,.career-section,.mc,
  .qopt,.qrc,.svc,.ct-hero{background:#fff!important}
  .gantt-tbl td.lbl,.gantt-tbl td.cell,
  .rgt td.rl,.rgt td.rc{background:#fafcff!important}
  .thl{color:#0d1e2e!important}
  /* 分隔線 */
  td{border-bottom-color:#f4f8fc!important}
  .svl li{border-bottom-color:#f4f8fc!important}
  /* input / select 防止系統覆蓋 */
  input,select,textarea{
    background-color:#fff!important;
    color:#0d1e2e!important;
    border-color:#d0dde8!important;
  }
}
