:root {
  --blue:#1565C0; --blue-light:#1E88E5; --blue-pale:#E3F2FD;
  --green:#2E7D32; --green-light:#43A047; --green-pale:#E8F5E9;
  --dark:#0D1B2A; --mid:#37474F; --light:#F5F7FA;
  --white:#FFFFFF; --border:#E0E6ED;
  --shadow:0 4px 24px rgba(21,101,192,0.10);
  --red:#C62828; --red-pale:#FFEBEE;
}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{font-family:'Noto Sans TC',sans-serif;background:var(--white);color:var(--dark);overflow-x:hidden;}

/* NAV */
nav{
  position:sticky;top:0;z-index:200;
  background:transparent;border-bottom:3px solid transparent;box-shadow:none;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 40px;height:68px;
  transition:background .35s,border-color .35s,box-shadow .35s;
}
nav.nav-solid{
  background:var(--white);
  border-bottom:3px solid var(--blue);
  box-shadow:0 2px 16px rgba(21,101,192,0.10);
}
.nav-logo{display:flex;align-items:center;gap:14px;text-decoration:none;cursor:pointer;}
.nav-logo-hr{
  font-family:'Oswald',sans-serif;font-size:2rem;font-weight:700;letter-spacing:-1px;
  background:linear-gradient(135deg,#64B5F6 50%,#81C784 50%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
nav.nav-solid .nav-logo-hr{
  background:linear-gradient(135deg,var(--blue) 50%,var(--green) 50%);
  -webkit-background-clip:text;background-clip:text;
}
.nav-logo-text{font-size:1rem;font-weight:700;color:#fff;line-height:1.2;transition:color .35s;text-shadow:0 1px 4px rgba(0,0,0,0.6);}
.nav-logo-sub{font-size:0.7rem;color:rgba(255,255,255,.75);font-weight:400;transition:color .35s;text-shadow:0 1px 3px rgba(0,0,0,0.5);}
nav.nav-solid .nav-logo-text{color:var(--dark);text-shadow:none;}
nav.nav-solid .nav-logo-sub{color:var(--mid);text-shadow:none;}
.nav-links{display:flex;gap:4px;}
.nav-links button{
  padding:8px 20px;border-radius:6px;border:none;background:none;
  font-size:0.95rem;font-weight:500;color:rgba(255,255,255,.9);cursor:pointer;
  font-family:'Noto Sans TC',sans-serif;transition:background 0.2s,color 0.2s;
  text-shadow:0 1px 4px rgba(0,0,0,0.6);
}
nav.nav-solid .nav-links button{color:var(--mid);text-shadow:none;}
nav.nav-solid .nav-ext-link{color:var(--mid);text-shadow:none;}
.nav-links button:hover,.nav-links button.active{background:var(--blue);color:var(--white);}
.nav-cta{background:var(--green)!important;color:var(--white)!important;font-weight:700!important;}
.nav-cta:hover{background:var(--green-light)!important;}
.nav-ext-link{
  padding:8px 20px;border-radius:6px;border:none;background:none;
  font-size:0.95rem;font-weight:500;color:rgba(255,255,255,.9);cursor:pointer;
  font-family:'Noto Sans TC',sans-serif;transition:background 0.2s,color 0.2s;
  text-decoration:none;display:inline-flex;align-items:center;
  text-shadow:0 1px 4px rgba(0,0,0,0.6);
}
nav.nav-solid .nav-ext-link{color:var(--mid);}
.nav-ext-link:hover{background:var(--blue);color:var(--white)!important;}
/* hero-wrap：單張全幅圖，延伸至導覽列後方 */
.hero-wrap{
  width:100%;margin-top:-68px;position:relative;z-index:1;line-height:0;
  height:clamp(244px,32.6vw,544px);overflow:hidden;
}
.hero-wrap img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
/* A：頂部深色漸層遮罩，讓導覽列文字清晰可見 */
.hero-wrap::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:110px;z-index:2;pointer-events:none;
  background:linear-gradient(to bottom, rgba(0,0,0,0.52) 0%, transparent 100%);
}
/* 換圖只需把 hero-main.jpg 換掉即可（同名覆蓋） */

/* PAGES */
.page{display:none;}
.page.active{display:block;}

/* ===== HOME ===== */
.hero{
  display:grid;grid-template-columns:50% 50%;
  background:linear-gradient(135deg,#0D1B2A 0%,#1a2f45 100%);
  height:clamp(200px, 28vw, 420px);
  width:100%;
}
.hero-img-wrap{overflow:hidden;height:100%;}

.hero-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.hero-text{
  display:flex;flex-direction:column;justify-content:center;
  padding:24px 28px;gap:10px;
}
.hero-company{font-size:1.25rem;font-weight:900;color:#FFFFFF;line-height:1.3;}
.hero-company span{color:#64B5F6;}
.hero-tagline{font-size:0.88rem;color:#78909C;font-weight:400;}
.hero-pills-v{display:flex;flex-direction:column;gap:8px;margin-top:4px;}
.hero-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.14);
  color:#B0BEC5;padding:7px 14px;border-radius:8px;font-size:0.82rem;
  width:fit-content;
}
.hero-pill-icon{font-size:0.9rem;}
/* info bar below hero */
.hero-infobar{
  background:linear-gradient(135deg,var(--dark) 0%,#1a2f45 100%);
  display:flex;align-items:stretch;flex-wrap:wrap;
}
.hero-infobar-item{
  flex:1;min-width:160px;display:flex;align-items:center;gap:10px;
  padding:7px 24px;border-right:1px solid rgba(255,255,255,0.08);
}
.hero-infobar-item:last-child{border-right:none;}
.hib-icon{
  width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;flex-shrink:0;background:rgba(255,255,255,0.08);
}
.hib-label{font-size:0.62rem;color:#78909C;margin-bottom:1px;font-weight:500;letter-spacing:0.5px;}
.hib-value{font-size:0.82rem;font-weight:700;color:var(--white);}
.hib-value a{color:#64B5F6;text-decoration:none;}
.hib-value a:hover{color:var(--white);}
.home-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;max-width:1100px;margin:40px auto;padding:0 40px;}
.home-card{
  background:var(--white);border:1.5px solid var(--border);border-radius:14px;
  padding:28px 22px;box-shadow:var(--shadow);cursor:pointer;
  transition:transform 0.2s,box-shadow 0.2s;text-align:center;position:relative;overflow:hidden;
}
.home-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--green));}
.home-card:hover{transform:translateY(-4px);box-shadow:0 10px 32px rgba(21,101,192,0.15);}
.home-card-icon{font-size:2.2rem;margin-bottom:14px;}
.home-card h3{font-size:1.05rem;font-weight:800;color:var(--dark);margin-bottom:6px;}
.home-card p{font-size:0.8rem;color:var(--mid);line-height:1.6;}
.home-card-arrow{display:inline-block;margin-top:12px;font-size:0.78rem;color:var(--blue);font-weight:700;}
.home-strip{background:var(--dark);color:var(--white);display:flex;align-items:center;justify-content:center;gap:60px;padding:24px 40px;flex-wrap:wrap;}
.strip-item{display:flex;align-items:center;gap:12px;}
.strip-icon{font-size:1.4rem;}
.strip-label{font-size:0.75rem;color:#90A4AE;margin-bottom:2px;}
.strip-value{font-size:1rem;font-weight:700;}
.strip-value a{color:var(--white);text-decoration:none;}

/* ===== INNER PAGE SHELL ===== */
.page-shell{max-width:1100px;margin:0 auto;padding:56px 40px 80px;}
.page-header{margin-bottom:44px;}
.page-header-bar{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap;}
.btn-home{
  display:inline-flex;align-items:center;gap:6px;
  background:none;border:1.5px solid var(--border);border-radius:8px;
  padding:7px 16px;font-size:0.82rem;font-weight:600;color:var(--mid);
  cursor:pointer;font-family:'Noto Sans TC',sans-serif;
  transition:background 0.2s,color 0.2s,border-color 0.2s;
  text-decoration:none;
}
.btn-home:hover{background:var(--blue);color:var(--white);border-color:var(--blue);}
.page-header-bar .bar{width:5px;height:36px;border-radius:3px;background:var(--blue);}
.page-header h1{font-size:2rem;font-weight:900;}
.page-header p{color:var(--mid);font-size:0.9rem;margin-top:4px;}

/* ===== PRICE TABLE ===== */
.price-notice{background:var(--blue-pale);border-left:4px solid var(--blue);padding:12px 18px;border-radius:6px;font-size:0.85rem;color:var(--mid);margin-bottom:24px;}
.price-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:18px;}
.price-toolbar-left{font-size:0.85rem;color:var(--mid);}
.price-toolbar-left strong{color:var(--blue);}
.price-toolbar-right{display:flex;gap:10px;align-items:center;}
.btn-admin{
  background:var(--blue);color:var(--white);border:none;padding:9px 20px;
  border-radius:8px;font-size:0.88rem;font-weight:700;cursor:pointer;
  font-family:'Noto Sans TC',sans-serif;transition:background 0.2s;display:inline-flex;align-items:center;gap:7px;
}
.btn-admin:hover{background:var(--blue-light);}
.btn-logout{
  background:none;border:1.5px solid var(--border);color:var(--mid);padding:9px 16px;
  border-radius:8px;font-size:0.82rem;cursor:pointer;font-family:'Noto Sans TC',sans-serif;
  display:none;
}
.admin-active .btn-logout{display:inline-block;}
.admin-badge{
  display:none;background:var(--green-pale);color:var(--green);
  font-size:0.78rem;font-weight:700;padding:4px 12px;border-radius:20px;
}
.admin-active .admin-badge{display:inline-block;}
.price-table-wrap{overflow-x:auto;border-radius:12px;border:1.5px solid var(--border);box-shadow:var(--shadow);}
.visit-stats-box{margin-bottom:24px;padding:18px 22px;border-radius:12px;border:1.5px solid var(--border);background:var(--green-pale);}
.visit-stats-title{font-weight:700;color:var(--green);font-size:0.9rem;margin-bottom:12px;}
.visit-stats-list{display:flex;flex-direction:column;gap:6px;}
.visit-stats-row{display:flex;justify-content:space-between;font-size:0.85rem;color:var(--dark);padding:6px 12px;background:var(--white);border-radius:6px;}
.visit-stats-row strong{color:var(--green);}
.visit-stats-empty{font-size:0.85rem;color:var(--mid);}
table{width:100%;border-collapse:collapse;font-size:0.92rem;}
thead tr{background:var(--blue);color:var(--white);}
thead th{padding:13px 18px;text-align:left;font-weight:700;font-size:0.88rem;letter-spacing:0.5px;cursor:pointer;user-select:none;white-space:nowrap;}
thead th:hover{background:var(--blue-light);}
tbody tr{border-bottom:1px solid var(--border);transition:background 0.15s;}
tbody tr:last-child{border-bottom:none;}
tbody tr:hover{background:var(--blue-pale);}
tbody td{padding:12px 18px;color:var(--dark);}
.td-date{font-weight:600;color:var(--mid);font-family:'Oswald',sans-serif;letter-spacing:1px;}
.td-base{font-weight:700;font-size:1rem;}
.td-up{color:var(--red);font-weight:700;}
.td-down{color:var(--green);font-weight:700;}
.td-days{color:var(--mid);}
.del-btn{background:none;border:1px solid #EF9A9A;color:var(--red);padding:3px 10px;border-radius:6px;cursor:pointer;font-size:0.78rem;font-family:'Noto Sans TC',sans-serif;transition:background 0.2s;}
.del-btn:hover{background:var(--red-pale);}

/* ===== SERVICES ===== */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;}
.service-card{background:var(--white);border-radius:12px;padding:28px 24px;box-shadow:var(--shadow);border:1.5px solid var(--border);transition:transform 0.2s,box-shadow 0.2s;}
.service-card:hover{transform:translateY(-4px);box-shadow:0 10px 36px rgba(21,101,192,0.13);}
.service-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:16px;}
.service-icon.blue{background:var(--blue-pale);}
.service-icon.green{background:var(--green-pale);}
.service-card h3{font-size:1rem;font-weight:700;margin-bottom:8px;}
.service-card p{font-size:0.85rem;color:var(--mid);line-height:1.7;}
.tags{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px;}
.tag{font-size:0.75rem;padding:3px 10px;border-radius:20px;font-weight:500;background:var(--blue-pale);color:var(--blue);}
.tag.green{background:var(--green-pale);color:var(--green);}
.photo-strip{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-top:36px;}
.photo-strip img{width:100%;height:200px;object-fit:cover;border-radius:10px;}

/* ===== CONTACT ===== */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;}
.contact-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:28px;}
.contact-item-icon{width:46px;height:46px;border-radius:10px;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;}
.contact-item-icon.green{background:var(--green-pale);}
.contact-item h4{font-size:0.82rem;color:var(--mid);margin-bottom:4px;font-weight:500;}
.contact-item p{font-size:1.05rem;font-weight:700;}
.contact-item a{text-decoration:none;color:var(--blue);font-size:1.05rem;font-weight:700;}
.hours-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px;}
.hours-item{background:var(--light);border-radius:8px;padding:10px 14px;}
.hours-day{font-size:0.75rem;color:var(--mid);font-weight:500;}
.hours-time{font-size:0.95rem;font-weight:700;color:var(--green);}
.contact-map{border-radius:14px;overflow:hidden;min-height:320px;}
.map-placeholder{text-align:center;padding:40px;}
.map-icon{font-size:2.5rem;margin-bottom:12px;}
.map-btn{display:inline-block;background:var(--blue);color:var(--white);padding:10px 22px;border-radius:8px;text-decoration:none;font-size:0.9rem;font-weight:700;margin-top:12px;transition:background 0.2s;}
.map-btn:hover{background:var(--blue-light);}

/* ===== CAREERS ===== */
.careers-intro{background:linear-gradient(135deg,var(--blue) 0%,#0D47A1 100%);border-radius:14px;padding:36px 40px;margin-bottom:32px;color:var(--white);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;}
.careers-intro h3{font-size:1.4rem;font-weight:900;margin-bottom:6px;}
.careers-intro p{font-size:0.9rem;opacity:0.85;max-width:460px;line-height:1.7;}
.careers-cta{background:var(--white);color:var(--blue);padding:12px 26px;border-radius:8px;text-decoration:none;font-weight:700;font-size:0.95rem;white-space:nowrap;}
.job-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;}
.job-card{background:var(--white);border-radius:12px;padding:26px 24px;border:1.5px solid var(--border);box-shadow:var(--shadow);transition:transform 0.2s,box-shadow 0.2s;}
.job-card:hover{transform:translateY(-3px);box-shadow:0 10px 32px rgba(21,101,192,0.13);}
.job-badge{display:inline-block;font-size:0.72rem;font-weight:700;padding:3px 10px;border-radius:20px;background:var(--green-pale);color:var(--green);margin-bottom:12px;}
.job-badge.blue{background:var(--blue-pale);color:var(--blue);}
.job-card h3{font-size:1.05rem;font-weight:800;margin-bottom:10px;}
.salary-wrap{display:flex;align-items:center;gap:6px;margin:2px 0;}
.salary-label{font-size:0.82rem;color:var(--mid);}
.salary-display{font-size:0.88rem;font-weight:700;color:var(--blue);}
.admin-sal-input{
  border:1.5px solid var(--border);border-radius:6px;padding:5px 10px;
  font-size:0.88rem;font-family:'Noto Sans TC',sans-serif;color:var(--dark);
  width:150px;background:var(--white);
}
.admin-sal-input:focus{outline:none;border-color:var(--blue);}
.status-btn{
  border:none;border-radius:6px;padding:5px 14px;font-size:0.78rem;font-weight:700;
  cursor:pointer;font-family:'Noto Sans TC',sans-serif;transition:all 0.15s;
}
.status-btn.urgent{background:#FFEBEE;color:var(--red);}
.status-btn.recruiting{background:var(--blue-pale);color:var(--blue);}
.status-btn.active-u{background:var(--red);color:#fff;}
.status-btn.active-r{background:var(--blue);color:#fff;}
.job-meta{display:flex;flex-direction:column;gap:5px;margin-bottom:14px;}
.job-meta span{font-size:0.82rem;color:var(--mid);}
.job-card p{font-size:0.83rem;color:var(--mid);line-height:1.7;}
.welfare-section{margin-top:36px;}
.welfare-section h3{font-size:1rem;font-weight:700;margin-bottom:16px;}
.welfare-list{display:flex;flex-wrap:wrap;gap:10px;}
.welfare-item{background:var(--white);border:1.5px solid var(--border);border-radius:8px;padding:8px 16px;font-size:0.83rem;font-weight:500;}

/* FOOTER */
footer{background:var(--dark);color:#90A4AE;padding:28px 40px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;}
.footer-logo{color:var(--white);font-weight:900;font-size:1.1rem;}
.footer-logo span{color:#64B5F6;}
footer p{font-size:0.8rem;}

/* MODALS */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(13,27,42,0.6);z-index:999;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal{background:var(--white);border-radius:14px;padding:36px;width:460px;max-width:95vw;box-shadow:0 20px 60px rgba(0,0,0,0.25);max-height:85vh;overflow-y:auto;}
.modal h3{font-size:1.15rem;font-weight:900;margin-bottom:6px;}
.modal-sub{font-size:0.82rem;color:var(--mid);margin-bottom:22px;}
.field{margin-bottom:14px;}
.field label{display:block;font-size:0.78rem;font-weight:700;color:var(--mid);margin-bottom:5px;}
.field input{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:7px;font-size:0.95rem;font-family:'Noto Sans TC',sans-serif;color:var(--dark);transition:border-color 0.2s;}
.field input:focus{outline:none;border-color:var(--blue);}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.modal-actions{display:flex;gap:10px;margin-top:20px;justify-content:flex-end;}
.btn-cancel{background:none;border:1.5px solid var(--border);border-radius:7px;padding:9px 20px;cursor:pointer;font-family:'Noto Sans TC',sans-serif;font-size:0.9rem;color:var(--mid);}
.btn-ok{background:var(--blue);color:var(--white);border:none;border-radius:7px;padding:9px 22px;cursor:pointer;font-family:'Noto Sans TC',sans-serif;font-size:0.9rem;font-weight:700;}
.btn-ok:hover{background:var(--blue-light);}
.modal-error{color:var(--red);font-size:0.82rem;margin-top:8px;display:none;}

@media(max-width:768px){
  nav{padding:0 14px;}
  .nav-links button{padding:7px 10px;font-size:0.8rem;}
  .hero{grid-template-columns:1fr;height:auto;}
  .hero-img-wrap{height:220px;}
  .hero-content{padding:0 20px;}
  .hero-title{font-size:1.8rem;}
  .home-cards{grid-template-columns:1fr 1fr;padding:0 16px;}
  #latestJournalList{grid-template-columns:1fr !important;}
  #latest-journal-section{padding:0 16px !important;}
  .page-shell{padding:36px 16px 60px;}
  .contact-layout{grid-template-columns:1fr;}
  .photo-strip{grid-template-columns:1fr 1fr;}
  .careers-intro{padding:24px 20px;}
  .home-strip{gap:28px;}
  .field-row{grid-template-columns:1fr;}
}

/* Job toggle */
.toggle-row{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--white);border:1.5px solid var(--border);border-radius:8px;
  padding:10px 14px;cursor:pointer;font-size:0.85rem;font-weight:500;color:var(--dark);
}
.toggle-row input{display:none;}
.toggle-slider{
  position:relative;width:42px;height:24px;background:#ccc;border-radius:12px;
  transition:background 0.2s;flex-shrink:0;
}
.toggle-slider::after{
  content:'';position:absolute;top:3px;left:3px;
  width:18px;height:18px;background:white;border-radius:50%;
  transition:transform 0.2s;
}
.toggle-row input:checked + .toggle-slider{background:var(--green);}
.toggle-row input:checked + .toggle-slider::after{transform:translateX(18px);}
.job-card.hidden{display:none;}

/* ── TICKER ── */
.ticker-wrap{
  background:#0D1B2A;
  border-top:2px solid #1565C0;
  border-bottom:2px solid #1565C0;
  display:flex;align-items:stretch;
  height:44px;overflow:hidden;position:relative;
}
.ticker-tab{
  background:#1565C0;color:#fff;
  font-size:12px;font-weight:700;letter-spacing:1.5px;
  padding:0 18px;display:flex;align-items:center;
  white-space:nowrap;flex-shrink:0;z-index:2;
  font-family:'Noto Sans TC',sans-serif;
}
.ticker-scroll-outer{flex:1;overflow:hidden;position:relative;}
.ticker-scroll-inner{
  display:inline-flex;align-items:center;
  white-space:nowrap;height:44px;
  animation:ticker-move var(--ticker-dur, 20s) linear infinite;
  will-change:transform;
}
.ticker-scroll-inner:hover{animation-play-state:paused;}
.ticker-item{
  display:inline-flex;align-items:center;gap:10px;
  padding:0 36px;border-right:1px solid rgba(255,255,255,0.1);
  height:100%;
}
.ticker-change{font-size:16px;font-weight:700;display:flex;align-items:center;gap:6px;font-family:'Oswald',sans-serif;}
.ticker-change.up{color:#F44336;}
.ticker-change.down{color:#4CAF50;}
.ticker-arrow{display:inline-block;width:0;height:0;flex-shrink:0;}
.ticker-arrow.up{border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:9px solid #F44336;}
.ticker-arrow.down{border-left:6px solid transparent;border-right:6px solid transparent;border-top:9px solid #4CAF50;}
.ticker-time{font-size:11px;color:#546E7A;font-family:'Noto Sans TC',sans-serif;}
.ticker-edit-btn{
  background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);
  color:#90A4AE;padding:0 14px;font-size:11px;cursor:pointer;
  font-family:'Noto Sans TC',sans-serif;height:100%;flex-shrink:0;
  transition:background 0.2s,color 0.2s;
}
.ticker-edit-btn:hover{background:rgba(255,255,255,0.18);color:#fff;}
@keyframes ticker-move{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}
.ticker-scroll-inner{animation-delay:0s;}

/* 年度切換 */
.year-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;}
.year-tab{
  padding:7px 20px;border-radius:8px;border:1.5px solid var(--border);
  font-size:0.88rem;font-weight:600;cursor:pointer;
  font-family:'Noto Sans TC',sans-serif;background:var(--white);color:var(--mid);
  transition:all 0.15s;
}
.year-tab:hover{border-color:var(--blue);color:var(--blue);}
.year-tab.active{background:var(--blue);color:var(--white);border-color:var(--blue);}
.year-label{
  display:inline-block;background:var(--blue-pale);color:var(--blue);
  font-size:0.78rem;font-weight:700;padding:3px 10px;border-radius:20px;margin-left:10px;
}

/* ===== 浮動聯絡按鈕 ===== */
.float-btns{
  position:fixed;bottom:28px;right:24px;z-index:999;
  display:flex;flex-direction:column;gap:12px;align-items:flex-end;
}
.float-btn{
  display:flex;align-items:center;gap:10px;
  padding:12px 18px;border-radius:50px;
  font-size:0.92rem;font-weight:700;
  text-decoration:none;color:#fff;
  box-shadow:0 4px 20px rgba(0,0,0,0.22);
  transition:transform 0.2s,box-shadow 0.2s;
  white-space:nowrap;
}
.float-btn:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,0.28);}
.float-btn-line{background:#06C755;}
.float-btn-tel{background:var(--blue);}
.float-btn svg{width:22px;height:22px;flex-shrink:0;}
.float-btn-label{font-size:0.88rem;}
@media(max-width:600px){
  .float-btns{bottom:18px;right:14px;gap:10px;}
  .float-btn{padding:11px 15px;}
  .float-btn-label{display:none;}
  .float-btn svg{width:24px;height:24px;}
}