/* ==============================================================
   华宸智域 · 公开前台样式
   -------------------------------------------------------------- */

:root{
  --gold:#d8b65a;
  --gold-2:#f4dc8a;
  --gold-3:#a88433;
  --gold-soft:rgba(216,182,90,.18);
  --black:#0b0b0d;
  --black-2:#141418;
  --black-3:#1c1c22;
  --blue-hero-a:#0d2a5b;
  --blue-hero-b:#0a1e46;
  --blue-hero-c:#0c224e;
  --text:#1f2328;
  --muted:#5c6370;
  --line:#e7e8ec;
  --bg:#f7f7fa;
  --primary:#0d2a5b;
  --primary-2:#0f3671;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
[hidden]{display:none !important}
body{
  font-family:"Noto Sans SC","PingFang SC","Microsoft YaHei",-apple-system,Segoe UI,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-2)}

.container{
  width:min(100% - 32px, 1400px);
  margin-inline:auto;
}

/* ==============================================================
   Sticky black-gold header
   -------------------------------------------------------------- */
.site-header{
  position:sticky;
  top:0;
  z-index:90;
  background:
    radial-gradient(1200px 240px at 50% -40%, rgba(216,182,90,.25), transparent 60%),
    linear-gradient(180deg, #0a0a0c 0%, #141417 100%);
  border-bottom:1px solid rgba(216,182,90,.35);
  box-shadow:0 12px 36px rgba(0,0,0,.35), inset 0 -1px 0 rgba(216,182,90,.15);
}
.site-header::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-1px;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--gold) 25%, var(--gold-2) 50%, var(--gold) 75%, transparent);
  opacity:.85;
}

.header-inner{
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center;
  gap:20px;
  padding:14px 0;
}

.brand{
  display:flex;align-items:center;gap:12px;
  color:#fff;
}
.brand-logo{
  width:44px;height:44px;object-fit:contain;
  filter:drop-shadow(0 4px 10px rgba(216,182,90,.35));
  transition:transform .3s ease, filter .3s ease;
}
.brand:hover .brand-logo{
  transform:scale(1.05);
  filter:drop-shadow(0 6px 14px rgba(244,220,138,.55));
}
.brand-text{
  display:flex;flex-direction:column;line-height:1.15;
  max-width:clamp(220px, 36vw, 420px);
}
.brand-cn{
  font-size:clamp(13px, 1.25vw, 16px);font-weight:700;letter-spacing:.2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  background:linear-gradient(180deg, #f8ecbc 0%, var(--gold-2) 45%, var(--gold) 75%, var(--gold-3) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 1px 0 rgba(0,0,0,.25);
}
.brand-slogan{
  margin-top:4px;
  font-size:12px;color:rgba(255,255,255,.62);letter-spacing:.5px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
@media (max-width:900px){
  .brand-slogan{display:none}
}
@media (max-width:640px){
  .brand-text{max-width:calc(100vw - 130px)}
  .brand-cn{font-size:13px}
}

/* main nav */
.main-nav > ul{
  display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap;
  list-style:none;margin:0;padding:0;
}
.main-nav > ul > li{position:relative}
.main-nav > ul > li > a{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 14px;border-radius:10px;
  color:rgba(255,255,255,.82);font-size:15px;
  transition:all .2s ease;
}
.main-nav > ul > li > a:hover,
.main-nav > ul > li > a.active{
  color:#fff7e0;
  background:linear-gradient(180deg, rgba(216,182,90,.22), rgba(216,182,90,.06));
}
.main-nav .bi-chevron-down{font-size:11px;opacity:.75}

/* dropdown menu — black-gold, width matches the button above */
.has-dropdown .dropdown{
  position:absolute;top:calc(100% + 8px);left:0;right:0;
  width:100%;min-width:0;padding:6px;
  list-style:none;margin:0;
  background:
    radial-gradient(240px 120px at 0% 0%, rgba(216,182,90,.16), transparent 60%),
    linear-gradient(180deg, #131317 0%, #0b0b0d 100%);
  border:1px solid rgba(216,182,90,.42);
  border-radius:10px;
  box-shadow:0 18px 44px rgba(0,0,0,.48), inset 0 1px 0 rgba(216,182,90,.18);
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s ease, transform .18s ease, visibility 0s linear .18s;
  z-index:101;
  box-sizing:border-box;
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown{
  opacity:1;visibility:visible;transform:translateY(0);
  transition:opacity .18s ease, transform .18s ease;
}
.has-dropdown .dropdown::before{
  content:"";position:absolute;left:50%;margin-left:-6px;top:-6px;width:12px;height:12px;
  background:linear-gradient(135deg, #131317 50%, transparent 50%);
  border-left:1px solid rgba(216,182,90,.42);
  border-top:1px solid rgba(216,182,90,.42);
  transform:rotate(45deg);
  border-top-left-radius:2px;
}
.has-dropdown .dropdown li + li{
  border-top:1px dashed rgba(216,182,90,.2);
}
.has-dropdown .dropdown a{
  display:block;padding:8px 10px;border-radius:6px;
  color:rgba(255,255,255,.82);font-size:13px;line-height:1.4;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  text-align:center;
  transition:all .18s ease;
}
.has-dropdown .dropdown a:hover{
  color:#fff7de;
  background:linear-gradient(90deg, rgba(216,182,90,.14), rgba(216,182,90,.04));
  box-shadow:inset 0 0 0 1px rgba(216,182,90,.35);
}

/* header search */
.header-search{
  display:flex;align-items:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(216,182,90,.3);
  border-radius:999px;
  padding:2px 4px 2px 14px;
  min-width:240px;
}
.header-search input{
  border:0;outline:0;background:transparent;color:#fff;
  font-size:13.5px;padding:8px 6px;width:100%;
}
.header-search input::placeholder{color:rgba(255,255,255,.5)}
.header-search button{
  background:linear-gradient(180deg, var(--gold-2), var(--gold));
  border:0;color:#211b08;
  width:34px;height:34px;border-radius:50%;
  cursor:pointer;display:grid;place-items:center;
  box-shadow:0 4px 12px rgba(216,182,90,.4);
  transition:transform .2s ease;
}
.header-search button:hover{transform:scale(1.06)}

.nav-toggle{
  display:none;background:transparent;border:0;color:#fff;
  font-size:26px;cursor:pointer;
}

/* ==============================================================
   Hero first screen
   -------------------------------------------------------------- */
.site-main{min-height:calc(100vh - 220px)}

.hero-full{position:relative}
.slide-inner{
  position:relative;
  width:100%;
  margin:0;
  height:560px;
  border-radius:0;
  overflow:hidden;
  box-shadow:0 14px 36px rgba(10,20,60,.20);
  background:#0a1e46;
}
.carousel{position:absolute;inset:0}
.carousel-slide{
  position:absolute;inset:0;
  background-position:center;background-size:cover;background-repeat:no-repeat;
  opacity:0;transition:opacity .7s ease;
  background-color:#0d2a5b;
}
.carousel-slide.is-active{opacity:1}
.slide-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.1) 0%, rgba(0,0,0,.55) 100%);
}
.slide-text{
  position:absolute;left:0;right:0;bottom:80px;
  width:min(100% - 48px, 1400px);
  margin-inline:auto;
  padding:0 24px;
  color:#fff;
}
.slide-title{
  margin:0 0 12px;
  font-family:"Noto Serif SC", "Noto Sans SC", serif;
  font-size:clamp(28px, 3.4vw, 44px);
  font-weight:700;
  line-height:1.25;
  letter-spacing:.5px;
  text-shadow:0 3px 14px rgba(0,0,0,.55);
  white-space:normal;
  max-width:min(1200px, 94%);
}
.slide-sub{
  margin:0;font-size:16px;opacity:.92;
  text-shadow:0 2px 10px rgba(0,0,0,.55);
  max-width:min(1100px, 92%);
}

/* carousel nav */
.carousel-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:42px;height:42px;border-radius:50%;
  border:1px solid rgba(216,182,90,.55);
  background:rgba(10,10,12,.55);color:#f4dc8a;
  cursor:pointer;display:grid;place-items:center;
  z-index:2;transition:all .18s ease;
}
.carousel-nav:hover{background:rgba(10,10,12,.85);transform:translateY(-50%) scale(1.06)}
.carousel-nav.prev{left:14px}
.carousel-nav.next{right:14px}

.carousel-dots{
  position:absolute;left:0;right:0;bottom:16px;
  display:flex;justify-content:center;gap:8px;z-index:4;
}
.carousel-dots span{
  width:22px;height:4px;border-radius:4px;
  background:rgba(255,255,255,.38);cursor:pointer;
  transition:background .2s ease, width .2s ease;
}
.carousel-dots span.is-active{
  background:linear-gradient(90deg, var(--gold), var(--gold-2));
  width:32px;
}

/* ---- First-screen fixed stats bar (solid black-gold, fades on scroll) ---- */
.hero-stats-overlay{
  position:fixed;left:0;right:0;bottom:0;
  z-index:40;
  pointer-events:none;
  padding:20px 0 18px;
  background:
    radial-gradient(900px 200px at 20% 120%, rgba(216,182,90,.20), transparent 60%),
    radial-gradient(900px 200px at 80% -20%, rgba(216,182,90,.16), transparent 60%),
    linear-gradient(90deg, #0b0b0d 0%, #141418 50%, #0b0b0d 100%);
  border-top:1px solid rgba(216,182,90,.55);
  box-shadow:0 -10px 30px rgba(0,0,0,.45), 0 -1px 0 rgba(216,182,90,.25) inset;
  opacity:1;
  will-change:opacity, transform;
  transition:opacity .25s ease, transform .25s ease;
}
.hero-stats-overlay::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(244,220,138,.75) 50%, transparent 100%);
  pointer-events:none;
}
.hero-stats-overlay .stats-strip-inner{
  width:min(100% - 64px, 1400px);
  margin-inline:auto;
  display:grid;grid-template-columns:repeat(4, 1fr);
  gap:24px;
  padding:0 8px;
  position:relative;z-index:1;
}
.hero-stats-overlay .stat{
  text-align:center;color:#fff;
}
.hero-stats-overlay .stat .n{
  display:block;
  font-family:"Noto Serif SC", serif;
  font-weight:700;
  font-size:clamp(28px, 3vw, 40px);
  letter-spacing:1px;
  background:linear-gradient(180deg, #f8ecbc 0%, var(--gold-2) 50%, var(--gold) 80%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 4px 16px rgba(216,182,90,.25);
}
.hero-stats-overlay .stat .l{
  display:block;margin-top:2px;
  font-size:13.5px;letter-spacing:1px;
  color:rgba(255,255,255,.88);
}

/* ==============================================================
   Hero quickbar (blue background, black-gold elements)
   -------------------------------------------------------------- */
.hero-quickbar{
  position:relative;
  padding:38px 0 34px;
  margin-top:0;
  background:
    radial-gradient(600px 180px at 12% 0%, rgba(216,182,90,.16), transparent 60%),
    radial-gradient(500px 180px at 90% 100%, rgba(30,80,190,.3), transparent 60%),
    linear-gradient(135deg, var(--blue-hero-a) 0%, var(--blue-hero-b) 60%, var(--blue-hero-c) 100%);
  border-top:none;
  border-bottom:1px solid rgba(216,182,90,.28);
  box-shadow:0 10px 28px rgba(10,20,60,.25);
}
/* Gold divider band between carousel and quickbar */
.hero-quickbar::before{
  content:"";position:absolute;left:0;right:0;top:0;height:3px;z-index:2;
  background:linear-gradient(90deg,
    var(--gold-3) 0%, var(--gold) 18%, var(--gold-2) 50%, var(--gold) 82%, var(--gold-3) 100%);
  box-shadow:0 0 14px rgba(244,220,138,.55), inset 0 1px 0 rgba(255,243,195,.65);
}
.hero-quickbar::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold) 25%, var(--gold-2) 50%, var(--gold) 75%, transparent);
  opacity:.75;
}

/* ---- Hero scroll-down hint (fills the gap under the AI input) ---- */
.hero-scroll-hint{
  display:flex;align-items:center;justify-content:center;gap:16px;
  padding:4px 16px;border-radius:12px;
  color:rgba(255,243,210,.88);
  font-size:16.5px;letter-spacing:3px;font-weight:600;line-height:1;
  cursor:pointer;user-select:none;
  transition:color .2s ease, transform .15s ease, background .2s ease;
  animation:heroHintPulse 2.6s ease-in-out infinite;
}
.hero-scroll-hint:hover{
  color:#fff7e0;
  background:linear-gradient(90deg, transparent, rgba(216,182,90,.14) 30%, rgba(216,182,90,.14) 70%, transparent);
}
.hero-scroll-hint:active{transform:scale(.99)}

.hero-scroll-hint .hsh-text{
  background:linear-gradient(90deg, #fff3c3 0%, var(--gold-2) 50%, var(--gold) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 1px 6px rgba(0,0,0,.35);
}
.hero-scroll-hint .hsh-arrow{
  font-size:19px;line-height:1;
  background:linear-gradient(180deg, #fff3c3 0%, var(--gold-2) 60%, var(--gold) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 2px 6px rgba(244,220,138,.55));
  animation:heroHintArrow 1.6s ease-in-out infinite;
}
.hero-scroll-hint .hsh-arrow-r{animation-delay:-.8s} /* opposite phase */

@keyframes heroHintPulse{
  0%,100% { opacity:.82 }
  50%     { opacity:1 }
}
@keyframes heroHintArrow{
  0%   { transform:translateY(-2.5px); opacity:.6 }
  50%  { transform:translateY(2.5px);  opacity:1 }
  100% { transform:translateY(-2.5px); opacity:.6 }
}
@media (prefers-reduced-motion: reduce){
  .hero-scroll-hint,.hero-scroll-hint .hsh-arrow{animation:none}
}
@media (max-width:640px){
  .hero-scroll-hint{letter-spacing:2px;font-size:14px;gap:11px}
  .hero-scroll-hint .hsh-arrow{font-size:15.5px}
}
.hq-row{
  display:grid;
  grid-template-columns:minmax(320px, 1.05fr) minmax(360px, 2fr);
  gap:22px;
  align-items:stretch;
}

/* product entry — black-gold, attention-grabbing */
.hq-product{
  position:relative;isolation:isolate;
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;
  border-radius:14px;
  color:#fff7de;
  background:
    radial-gradient(260px 80px at 10% 0%, rgba(216,182,90,.28), transparent 60%),
    linear-gradient(180deg, #15151a 0%, #0a0a0c 100%);
  border:1px solid rgba(216,182,90,.55);
  box-shadow:
    0 10px 28px rgba(0,0,0,.45),
    inset 0 1px 0 rgba(216,182,90,.25),
    0 0 0 1px rgba(216,182,90,.12),
    0 0 0 0 rgba(244,220,138,0);
  transition:transform .25s cubic-bezier(.2,.9,.25,1.1),
             box-shadow .25s ease,
             border-color .25s ease;
  animation:hqProductBreath 3.6s ease-in-out infinite;
}
/* continuous ambient shine sweep — strictly constant linear speed,
   tight start/end offsets so the visible part dominates the cycle */
.hq-product::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  border-radius:inherit;overflow:hidden;
  background:linear-gradient(
    110deg,
    transparent 0%,
    transparent 38%,
    rgba(255,243,195,.10) 46%,
    rgba(255,243,195,.55) 50%,
    rgba(255,243,195,.10) 54%,
    transparent 62%,
    transparent 100%
  );
  background-size:260% 100%;
  background-position:-15% 0;
  mix-blend-mode:screen;
  animation:hqProductShine 2.4s linear infinite;
}
/* radar-style pulsing ring orbiting outside the border (higher cadence now) */
.hq-product::after{
  content:"";position:absolute;inset:-3px;z-index:0;pointer-events:none;
  border-radius:17px; /* button radius 14 + 3 outset */
  border:1.5px solid rgba(244,220,138,.6);
  box-shadow:
    0 0 14px rgba(244,220,138,.25),
    inset 0 0 6px rgba(244,220,138,.12);
  transform-origin:center;
  animation:hqProductRing 1.3s cubic-bezier(.33,.1,.34,1) infinite;
}
/* keep content above the ambient layers */
.hq-product > *{position:relative;z-index:3}

.hq-product:hover{
  transform:translateY(-3px) scale(1.012);
  color:#fff;
  border-color:rgba(255,243,195,.95);
  box-shadow:
    0 18px 38px rgba(0,0,0,.55),
    inset 0 1px 0 rgba(255,243,195,.55),
    0 0 0 1px rgba(255,243,195,.45),
    0 0 26px 2px rgba(244,220,138,.35);
}
.hq-product:active{transform:translateY(-1px) scale(1.004)}

.hq-product-icon{
  width:48px;height:48px;border-radius:12px;
  background:linear-gradient(180deg, var(--gold-2), var(--gold) 60%, var(--gold-3));
  color:#211b08;font-size:22px;
  display:grid;place-items:center;flex:0 0 auto;
  box-shadow:0 6px 14px rgba(216,182,90,.45), inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .3s ease, box-shadow .3s ease;
}
.hq-product:hover .hq-product-icon{
  transform:rotate(-6deg) scale(1.06);
  box-shadow:0 10px 22px rgba(216,182,90,.65), inset 0 1px 0 rgba(255,255,255,.65);
}
.hq-product-text{display:flex;flex-direction:column;line-height:1.25;flex:1;min-width:0}
.hq-product-title{
  font-size:17.5px;font-weight:800;letter-spacing:1px;
  background:linear-gradient(180deg, #fff4c4, var(--gold-2) 55%, var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 1px 0 rgba(0,0,0,.2);
}
.hq-product-sub{font-size:12.5px;color:rgba(255,255,255,.72);margin-top:3px}
.hq-product-arrow{
  font-size:20px;color:var(--gold-2);flex:0 0 auto;
  transition:transform .25s ease, color .25s ease, text-shadow .25s ease;
}
.hq-product:hover .hq-product-arrow{
  transform:translateX(6px);
  color:#fff7d0;
  text-shadow:0 0 10px rgba(255,243,195,.75);
}

@keyframes hqProductBreath{
  0%,100%{
    box-shadow:
      0 10px 28px rgba(0,0,0,.45),
      inset 0 1px 0 rgba(216,182,90,.25),
      0 0 0 1px rgba(216,182,90,.12),
      0 0 0 0 rgba(244,220,138,0);
  }
  50%{
    box-shadow:
      0 12px 32px rgba(0,0,0,.5),
      inset 0 1px 0 rgba(244,220,138,.4),
      0 0 0 1px rgba(244,220,138,.3),
      0 0 22px 2px rgba(244,220,138,.28);
  }
}
@keyframes hqProductShine{
  0%   { background-position: -15% 0 }
  100% { background-position: 115% 0 }
}
@keyframes hqProductRing{
  0%   { transform:scale(.985); opacity:.9 }
  70%  { transform:scale(1.04); opacity:0  }
  100% { transform:scale(1.045); opacity:0 }
}
@media (prefers-reduced-motion: reduce){
  .hq-product,
  .hq-product::before,
  .hq-product::after{animation:none}
}

/* chat input + expanding drawer */
.hq-form-wrap{
  position:relative;
  display:flex;flex-direction:column;min-height:100%;
}
/* form stays top, hint fills the left-right height gap */
.hq-form-wrap > .hq-form{flex:0 0 auto}
.hq-form-wrap > .hero-scroll-hint{
  flex:1 1 auto;align-self:stretch;
  margin:6px 0 0;width:auto;
}
.hq-form{
  display:flex;align-items:center;gap:10px;
  padding:6px 6px 6px 16px;
  border-radius:14px;
  background:
    radial-gradient(260px 80px at 100% 0%, rgba(216,182,90,.22), transparent 60%),
    linear-gradient(180deg, #15151a 0%, #0a0a0c 100%);
  border:1px solid rgba(216,182,90,.55);
  box-shadow:
    0 10px 28px rgba(0,0,0,.45),
    inset 0 1px 0 rgba(216,182,90,.22);
  transition:border-color .2s ease, box-shadow .2s ease;
}
.hq-form-wrap.is-open .hq-form,
.hq-form:focus-within{
  border-color:rgba(244,220,138,.85);
  box-shadow:
    0 14px 32px rgba(0,0,0,.55),
    0 0 0 3px rgba(216,182,90,.18),
    inset 0 1px 0 rgba(244,220,138,.35);
}
.hq-form-icon{
  color:var(--gold-2);font-size:18px;flex:0 0 auto;
}
.hq-form input{
  flex:1;border:0;outline:0;background:transparent;
  color:#fff;font-size:15px;padding:12px 0;
}
.hq-form input::placeholder{color:rgba(255,255,255,.55)}
.hq-form button{
  background:linear-gradient(180deg, var(--gold-2), var(--gold) 55%, var(--gold-3));
  color:#211b08;border:0;
  width:40px;height:40px;border-radius:50%;
  cursor:pointer;display:grid;place-items:center;
  font-size:18px;
  box-shadow:0 6px 14px rgba(216,182,90,.45), inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .18s ease;
}
.hq-form button:hover{transform:scale(1.06)}

/* chat drawer (slides up above the input) */
.hq-chat{
  position:absolute;left:0;right:0;bottom:calc(100% + 10px);
  max-height:360px;display:flex;flex-direction:column;
  background:
    radial-gradient(240px 120px at 0% 0%, rgba(216,182,90,.16), transparent 60%),
    linear-gradient(180deg, #141419 0%, #0b0b0d 100%);
  border:1px solid rgba(216,182,90,.45);
  border-radius:14px;
  box-shadow:0 20px 48px rgba(0,0,0,.55), inset 0 1px 0 rgba(216,182,90,.22);
  z-index:5;
  overflow:hidden;
  animation:hqChatIn .25s ease;
}
@keyframes hqChatIn{
  from{opacity:0;transform:translateY(8px)}
  to  {opacity:1;transform:translateY(0)}
}
.hq-chat-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;
  border-bottom:1px solid rgba(216,182,90,.22);
  color:var(--gold-2);font-size:13px;letter-spacing:.5px;
}
.hq-chat-head .bi-stars{margin-right:6px}
.hq-chat-close{
  background:transparent;color:rgba(255,255,255,.7);border:0;cursor:pointer;
  width:28px;height:28px;border-radius:8px;
}
.hq-chat-close:hover{color:#fff;background:rgba(255,255,255,.06)}
.hq-chat-body{
  padding:12px 14px;overflow-y:auto;max-height:260px;
  scrollbar-width:none;-ms-overflow-style:none;
}
.hq-chat-body::-webkit-scrollbar{width:0;height:0;display:none}
.hq-msg{margin-bottom:10px;display:flex}
.hq-msg .bubble{
  max-width:88%;padding:9px 12px;border-radius:12px;
  font-size:14px;line-height:1.55;white-space:pre-wrap;word-break:break-word;
}
.hq-msg.from-bot .bubble{
  background:linear-gradient(180deg, rgba(216,182,90,.12), rgba(216,182,90,.04));
  color:rgba(255,255,255,.92);
  border:1px solid rgba(216,182,90,.28);
}
.hq-msg.from-user{justify-content:flex-end}
.hq-msg.from-user .bubble{
  background:linear-gradient(180deg, var(--gold-2), var(--gold));
  color:#211b08;
}
.hq-msg .actions{
  margin-top:8px;display:flex;flex-wrap:wrap;gap:6px;
}
.hq-msg .actions a{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 10px;border-radius:999px;
  background:rgba(216,182,90,.14);
  color:var(--gold-2);
  border:1px solid rgba(216,182,90,.35);
  font-size:12.5px;
}
.hq-msg .actions a:hover{background:rgba(216,182,90,.22);color:#fff7de}

.hq-typing .bubble{font-style:italic;color:rgba(255,255,255,.65)}

/* Suggested-question chips (shown under the bot's welcome bubble) */
.suggest-chips{
  margin-top:10px;display:flex;flex-wrap:wrap;gap:6px;
}
.suggest-chips .chip{
  appearance:none;border:0;cursor:pointer;
  padding:5px 11px;border-radius:999px;
  font-size:12.5px;line-height:1.4;letter-spacing:.2px;
  background:
    linear-gradient(180deg, rgba(244,220,138,.16) 0%, rgba(216,182,90,.08) 100%);
  color:var(--gold-2);
  border:1px solid rgba(216,182,90,.45);
  transition:background .18s ease, color .18s ease, border-color .18s ease, transform .18s ease;
}
.suggest-chips .chip:hover{
  background:linear-gradient(180deg, rgba(244,220,138,.28) 0%, rgba(216,182,90,.14) 100%);
  color:#fff7de;border-color:rgba(244,220,138,.8);
  transform:translateY(-1px);
}
.suggest-chips .chip:active{transform:translateY(0);filter:brightness(.95)}
.suggest-chips .chip[disabled]{opacity:.55;cursor:default;transform:none}

/* ==============================================================
   Homepage main grid
   -------------------------------------------------------------- */
.headline-wrap{margin:24px auto 0}
.headline-wrap .block{margin-bottom:0}  /* collapse gap; .main-grid handles spacing */
.main-grid{
  display:grid;grid-template-columns:minmax(0, 2.3fr) minmax(280px, 1fr);
  gap:20px;
  margin:20px auto 30px;
}

/* Inside the main column, tile sections into two sub-columns.
   minmax(0,1fr) forces both columns to truly be 50/50 even when a child
   has long, unshrinkable content (titles/urls/tables) that would otherwise
   stretch one track wider than the other. */
.main-col{
  display:grid;grid-template-columns:minmax(0, 1fr) minmax(0, 1fr);
  gap:14px;align-content:start;
}
.main-col > .block{min-width:0}

/* ----- Academic/formal content blocks (square corners, navy accents) ----- */
.block{
  background:#fff;border:1px solid #dde3ec;border-radius:0;
  border-top:3px solid var(--primary);
  padding:14px 18px 10px;margin-bottom:0; /* grid gap handles spacing */
  box-shadow:none;
}
/* headline-wrap lives outside .main-col; keep legacy margin behaviour */
.headline-wrap .block,
.side-card{margin-bottom:0}
.block-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:10px;padding-bottom:8px;
  border-bottom:1px solid #e5ebf3;position:relative;
}
.block-head::after{
  content:"";position:absolute;left:0;bottom:-1px;width:72px;height:2px;
  background:var(--primary);
}
.block-head h3{
  margin:0;font-size:16.5px;font-weight:700;color:var(--primary);
  letter-spacing:.5px;
  display:flex;align-items:center;gap:8px;
}
.block-head h3 .bi{color:var(--primary);font-size:17px}
.block-head .more{color:#5c6b80;font-size:12.5px;letter-spacing:.3px}
.block-head .more:hover{color:var(--primary-2)}

/* headline grid (top banner cards — kept navy/gold but squared & tighter) */
.headline-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr;grid-auto-rows:132px;gap:10px;
}
.headline-card{
  position:relative;overflow:hidden;
  border-radius:0;color:#fff;
  background:
    radial-gradient(420px 220px at 110% -20%, rgba(216,182,90,.20), transparent 60%),
    radial-gradient(420px 260px at -10% 120%, rgba(216,182,90,.16), transparent 60%),
    linear-gradient(135deg, #0d2a5b 0%, #0a1e46 48%, #0a1125 100%);
  background-size:cover;background-position:center;background-repeat:no-repeat;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:12px;min-height:132px;
  border:1px solid #1c3a74;
  border-left:3px solid var(--gold);
  box-shadow:none;
  transition:transform .18s ease, border-color .18s ease;
}
.headline-card:hover{
  transform:translateY(-2px);
  border-color:var(--gold);
}
.headline-card.large{grid-row:span 2}
.headline-card .hc-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(0,0,0,.70) 100%);
}
.headline-card::before{
  content:"";position:absolute;inset:auto -30% -40% auto;
  width:60%;height:120%;
  background:radial-gradient(closest-side, rgba(216,182,90,.12), transparent 70%);
  pointer-events:none;
}
.headline-card > *{position:relative;z-index:1}
.hc-cat{
  display:inline-block;align-self:flex-start;
  padding:2px 8px;border-radius:0;font-size:11px;font-weight:600;
  background:var(--gold);color:#211b08;
  border:1px solid rgba(216,182,90,.9);
  margin-bottom:6px;letter-spacing:.4px;
}
.hc-title{font-size:14px;font-weight:700;line-height:1.45;color:#fff}
.headline-card.large .hc-title{font-size:19px;letter-spacing:.3px}
.hc-date{margin-top:4px;font-size:11.5px;color:rgba(248,236,188,.85)}

/* simple news list */
.news-list{list-style:none;margin:0;padding:0}
.news-list li{
  display:flex;align-items:center;gap:10px;
  padding:6px 0;border-bottom:1px dotted #dfe4ec;
}
.news-list li:last-child{border-bottom:0}
.pin-tag,
.news-list li .pin-tag{
  display:inline-block;
  background:var(--primary);color:#fff;font-size:10.5px;font-weight:600;
  border-radius:0;padding:1px 6px;flex:0 0 auto;
  margin-right:2px;letter-spacing:.3px;
}
.news-list li > a{
  flex:1;min-width:0;color:#202733;font-size:14px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  position:relative;padding-left:12px;
}
.news-list li > a::before{
  content:"";position:absolute;left:0;top:50%;width:4px;height:4px;
  transform:translateY(-50%);
  background:var(--primary);
}
.news-list li > a:hover{color:var(--primary-2)}
.news-list li > a:hover::before{background:var(--gold)}
.news-list li .date{color:#7c869a;font-size:12px;flex:0 0 auto;font-variant-numeric:tabular-nums}

/* sidebar cards */
.side-card{
  background:#fff;border:1px solid #dde3ec;border-radius:0;
  border-top:2px solid var(--primary);
  padding:12px 14px 10px;margin-bottom:14px;
  box-shadow:none;
}
.side-card h4{
  margin:0 0 10px;font-size:14.5px;color:var(--primary);font-weight:700;
  padding-bottom:6px;letter-spacing:.4px;
  border-bottom:1px solid #e5ebf3;position:relative;
  display:flex;align-items:center;gap:8px;
}
.side-card h4::after{
  content:"";position:absolute;left:0;bottom:-1px;width:40px;height:2px;
  background:var(--primary);
}
.side-card h4 .bi{color:var(--primary);font-size:15px}
.side-news{list-style:none;margin:0;padding:0}
.side-news li{padding:4px 0;border-bottom:1px dotted #dfe4ec}
.side-news li:last-child{border-bottom:0}
.side-news a{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.side-news .t{
  flex:1;min-width:0;color:#202733;font-size:13px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.side-news .d{color:#7c869a;font-size:11.5px;flex:0 0 auto;font-variant-numeric:tabular-nums}
.quick-links{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:6px}
.quick-links a{
  display:flex;align-items:center;gap:6px;
  padding:6px 10px;border:1px solid #dde3ec;border-radius:0;
  font-size:12.5px;color:#26324a;
  background:#f4f7fc;
  transition:all .15s ease;
}
.quick-links a:hover{
  border-color:var(--primary);color:var(--primary);
  background:#e9eff8;
}
.quick-links a .bi{color:var(--primary)}

/* ==============================================================
   Page-bottom stats strip (full-width, black-gold luxe)
   -------------------------------------------------------------- */
.stats-strip{
  margin-top:0;
  padding:44px 0;
  background:
    radial-gradient(900px 260px at 20% 120%, rgba(216,182,90,.22), transparent 60%),
    radial-gradient(900px 260px at 80% -20%, rgba(216,182,90,.16), transparent 60%),
    linear-gradient(135deg, #0b0b0d 0%, #141418 50%, #0b0b0d 100%);
  border-top:1px solid rgba(216,182,90,.55);
  border-bottom:1px solid rgba(216,182,90,.55);
  position:relative;
  box-shadow:0 -8px 30px rgba(0,0,0,.25) inset;
}
.stats-strip::before,
.stats-strip::after{
  content:"";position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold) 25%, var(--gold-2) 50%, var(--gold) 75%, transparent);
  opacity:.9;
  pointer-events:none;
}
.stats-strip::before{top:-1px}
.stats-strip::after{bottom:-1px}
.stats-strip .container,
.stats-strip .stats-strip-inner{
  width:min(100% - 64px, 1600px);
  margin-inline:auto;
  display:grid;grid-template-columns:repeat(4, 1fr);gap:36px;
  padding:0 8px;
  position:relative;z-index:1;
}
.stats-strip .stat{text-align:center;color:#fff}
.stats-strip .stat .n{
  display:block;
  font-family:"Noto Serif SC", serif;font-weight:700;
  font-size:clamp(34px, 3.8vw, 48px);
  letter-spacing:1px;
  background:linear-gradient(180deg, #f8ecbc 0%, var(--gold-2) 50%, var(--gold) 80%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 4px 16px rgba(216,182,90,.25);
}
.stats-strip .stat .l{
  display:block;margin-top:6px;
  font-size:15px;letter-spacing:1.5px;
  color:rgba(255,255,255,.88);
}

/* ==============================================================
   Footer
   -------------------------------------------------------------- */
.site-footer{
  background:linear-gradient(180deg, #0e1020 0%, #0a0c1a 100%);
  color:rgba(255,255,255,.75);
  padding:40px 0 0;
  margin-top:0;
  border-top:1px solid rgba(216,182,90,.22);
}
.footer-grid{
  display:grid;grid-template-columns:1.9fr 1fr 1fr;gap:36px;
  padding-bottom:30px;
}
.foot-brand-col{display:flex;flex-direction:column;gap:14px;min-width:0}
.foot-brand{display:flex;align-items:center;gap:14px}
.foot-logo{width:50px;height:50px;object-fit:contain;filter:drop-shadow(0 4px 10px rgba(216,182,90,.35))}
.foot-about{
  margin:0;color:rgba(255,255,255,.72);font-size:13px;line-height:1.85;
  text-align:justify;max-width:560px;
  border-top:1px solid rgba(216,182,90,.18);
  padding-top:12px;
}
.foot-cn{
  font-weight:700;font-size:18px;
  background:linear-gradient(180deg, #f8ecbc 0%, var(--gold-2) 60%, var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.foot-en{font-size:12px;color:rgba(255,255,255,.55);margin-top:2px}
.foot-slogan{font-size:13px;margin-top:6px;color:rgba(255,255,255,.8)}
.foot-col h5{
  margin:0 0 12px;color:var(--gold-2);font-size:15px;letter-spacing:.5px;font-weight:600;
}
.foot-col ul{list-style:none;margin:0;padding:0}
.foot-col li{padding:4px 0;font-size:13.5px}
.foot-col a{color:rgba(255,255,255,.75)}
.foot-col a:hover{color:var(--gold-2)}
.foot-contact .bi{color:var(--gold);margin-right:6px}
.footer-bar{
  border-top:1px solid rgba(216,182,90,.18);
  padding:14px 0;font-size:13px;color:rgba(255,255,255,.55);
  text-align:center;
}
.footer-bar .sep{margin:0 6px}

/* ==============================================================
   Floating AI chat (bottom-right)
   -------------------------------------------------------------- */
.chat-fab{
  position:fixed;right:24px;bottom:24px;z-index:80;
  width:62px;height:62px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:
    radial-gradient(120px 60px at 30% 20%, rgba(244,220,138,.45), transparent 60%),
    linear-gradient(180deg, #18181d 0%, #08080a 100%);
  color:var(--gold-2);
  border:1px solid rgba(216,182,90,.7);
  box-shadow:
    0 18px 40px rgba(0,0,0,.50),
    0 0 0 1px rgba(216,182,90,.18),
    inset 0 1px 0 rgba(244,220,138,.35),
    inset 0 -8px 18px rgba(0,0,0,.35);
  cursor:pointer;user-select:none;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  animation:fabFloat 3.8s ease-in-out infinite;
}
.chat-fab:hover{
  transform:translateY(-4px) scale(1.04);
  border-color:rgba(244,220,138,.95);
  box-shadow:
    0 26px 52px rgba(0,0,0,.58),
    0 0 0 1px rgba(244,220,138,.4),
    inset 0 1px 0 rgba(244,220,138,.45),
    inset 0 -8px 18px rgba(0,0,0,.30),
    0 0 24px rgba(244,220,138,.35);
  animation-play-state:paused;
}
.chat-fab:active{transform:translateY(-2px) scale(1.00)}
.chat-fab .fab-robot{
  font-size:30px;
  background:linear-gradient(180deg, #fff3c3 0%, var(--gold-2) 55%, var(--gold) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.55));
  transition:transform .35s cubic-bezier(.2,.8,.2,1.4);
}
.chat-fab:hover .fab-robot{transform:rotate(-8deg) scale(1.06)}
.chat-fab .fab-pulse{
  position:absolute;inset:-6px;border-radius:50%;
  border:1px solid rgba(244,220,138,.55);
  pointer-events:none;
  animation:fabPulse 2.4s ease-out infinite;
}
@keyframes fabFloat{
  0%,100% { transform:translateY(0) }
  50%     { transform:translateY(-6px) }
}
@keyframes fabPulse{
  0%   { transform:scale(.9);  opacity:.85 }
  70%  { transform:scale(1.35);opacity:0   }
  100% { transform:scale(1.4); opacity:0   }
}
@media (prefers-reduced-motion: reduce){
  .chat-fab{animation:none}
  .chat-fab .fab-pulse{animation:none;opacity:0}
}

/* ==============================================================
   Floating product entry (bottom-left, reveal on scroll)
   -------------------------------------------------------------- */
.product-fab{
  position:fixed;left:24px;bottom:24px;z-index:80;
  display:inline-flex;align-items:center;gap:12px;
  padding:10px 16px 10px 12px;
  border-radius:999px;
  color:#fff7de;text-decoration:none;
  background:
    radial-gradient(180px 70px at 15% 10%, rgba(216,182,90,.30), transparent 62%),
    linear-gradient(180deg, #16161b 0%, #09090c 100%);
  border:1px solid rgba(216,182,90,.62);
  box-shadow:
    0 16px 36px rgba(0,0,0,.50),
    0 0 0 1px rgba(216,182,90,.14),
    inset 0 1px 0 rgba(244,220,138,.28),
    inset 0 -6px 14px rgba(0,0,0,.30);
  opacity:0;transform:translateY(14px) scale(.96);pointer-events:none;
  transition:opacity .35s ease, transform .35s cubic-bezier(.2,.9,.25,1.1),
             box-shadow .25s ease, border-color .25s ease;
  cursor:pointer;isolation:isolate;
}
.product-fab.visible{
  opacity:1;transform:translateY(0) scale(1);pointer-events:auto;
  animation:pfabFloat 3.8s ease-in-out infinite;
}
.product-fab:hover{
  transform:translateY(-3px) scale(1.02);
  border-color:rgba(255,243,195,.95);
  color:#fff;
  box-shadow:
    0 24px 48px rgba(0,0,0,.58),
    0 0 0 1px rgba(255,243,195,.42),
    inset 0 1px 0 rgba(255,243,195,.45),
    inset 0 -6px 14px rgba(0,0,0,.28),
    0 0 26px rgba(244,220,138,.35);
  animation-play-state:paused;
}
.product-fab:active{transform:translateY(-1px) scale(1.005)}

.product-fab > *{position:relative;z-index:2}

.pfab-ring{
  position:absolute;inset:-3px;border-radius:999px;z-index:0;pointer-events:none;
  border:1.5px solid rgba(244,220,138,.55);
  box-shadow:
    0 0 14px rgba(244,220,138,.22),
    inset 0 0 6px rgba(244,220,138,.10);
  animation:pfabRing 1.6s cubic-bezier(.33,.1,.34,1) infinite;
}
.product-fab:hover .pfab-ring{animation-duration:1.1s}

.pfab-icon{
  flex:0 0 auto;
  width:34px;height:34px;border-radius:50%;
  display:grid;place-items:center;font-size:16px;
  background:linear-gradient(180deg, var(--gold-2), var(--gold) 60%, var(--gold-3));
  color:#211b08;
  box-shadow:0 4px 10px rgba(216,182,90,.45), inset 0 1px 0 rgba(255,255,255,.55);
  transition:transform .3s ease, box-shadow .3s ease;
}
.product-fab:hover .pfab-icon{
  transform:rotate(-8deg) scale(1.06);
  box-shadow:0 8px 16px rgba(216,182,90,.6), inset 0 1px 0 rgba(255,255,255,.65);
}
.pfab-text{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.pfab-title{
  font-size:14.5px;font-weight:800;letter-spacing:1px;
  background:linear-gradient(180deg, #fff4c4, var(--gold-2) 55%, var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  white-space:nowrap;
}
.pfab-sub{
  font-size:11px;color:rgba(255,255,255,.68);margin-top:2px;
  white-space:nowrap;letter-spacing:.3px;
}
.pfab-arrow{
  font-size:16px;color:var(--gold-2);flex:0 0 auto;margin-left:2px;
  transition:transform .25s ease, color .25s ease, text-shadow .25s ease;
}
.product-fab:hover .pfab-arrow{
  transform:translate(3px,-3px);
  color:#fff7d0;
  text-shadow:0 0 10px rgba(255,243,195,.75);
}

@keyframes pfabFloat{
  0%,100% { transform:translateY(0) scale(1) }
  50%     { transform:translateY(-5px) scale(1) }
}
@keyframes pfabRing{
  0%   { opacity:.0; transform:scale(.94) }
  40%  { opacity:.75; transform:scale(1.02) }
  100% { opacity:0;  transform:scale(1.12) }
}
@media (prefers-reduced-motion: reduce){
  .product-fab, .product-fab.visible{animation:none}
  .product-fab .pfab-ring{animation:none;opacity:0}
}
@media (max-width:720px){
  .product-fab{
    left:14px;bottom:14px;padding:8px 12px 8px 8px;gap:8px;
  }
  .pfab-icon{width:28px;height:28px;font-size:14px}
  .pfab-title{font-size:12.5px;letter-spacing:.6px}
  .pfab-sub{display:none}
  .pfab-arrow{font-size:14px}
}

/* --- Proactive hint bubble next to the FAB --- */
.fab-hint{
  position:fixed;right:22px;bottom:98px;z-index:82;
  max-width:260px;min-width:200px;
  padding:12px 34px 12px 16px;
  border-radius:16px 16px 4px 16px;
  color:#fff7e0;cursor:pointer;user-select:none;
  background:
    radial-gradient(180px 100px at 0% 0%, rgba(244,220,138,.22), transparent 60%),
    linear-gradient(180deg, #1b1b22 0%, #09090c 100%);
  border:1px solid rgba(244,220,138,.6);
  box-shadow:
    0 22px 48px rgba(0,0,0,.55),
    0 0 0 1px rgba(216,182,90,.2),
    inset 0 1px 0 rgba(244,220,138,.35);
  transform-origin:100% 100%;
  animation:fabHintIn .35s cubic-bezier(.2,.9,.25,1.2) both, fabHintFloat 3.4s ease-in-out .4s infinite;
}
.fab-hint::after{
  content:"";position:absolute;right:22px;bottom:-9px;width:14px;height:14px;
  background:linear-gradient(135deg, transparent 50%, #09090c 50%);
  border-right:1px solid rgba(244,220,138,.6);
  border-bottom:1px solid rgba(244,220,138,.6);
  transform:rotate(45deg);
  border-bottom-right-radius:3px;
}
.fab-hint-title{
  font-size:14px;font-weight:600;line-height:1.35;
  background:linear-gradient(90deg,#fff3c3 0%,var(--gold-2) 60%,var(--gold) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:.3px;
}
.fab-hint-sub{
  margin-top:4px;font-size:13px;line-height:1.4;
  color:rgba(255,247,222,.9);
}
.fab-hint-sub .bi{margin-left:4px;color:var(--gold-2)}
.fab-hint-close{
  position:absolute;top:4px;right:4px;
  width:22px;height:22px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(244,220,138,.35);
  color:rgba(255,247,222,.8);
  font-size:14px;cursor:pointer;
  transition:all .15s ease;
}
.fab-hint-close:hover{
  background:rgba(244,220,138,.2);color:#fff;
  border-color:rgba(244,220,138,.8);
}
.fab-hint:hover{
  border-color:rgba(244,220,138,.95);
  box-shadow:
    0 28px 56px rgba(0,0,0,.6),
    0 0 0 1px rgba(244,220,138,.35),
    inset 0 1px 0 rgba(244,220,138,.45),
    0 0 22px rgba(244,220,138,.3);
}
@keyframes fabHintIn{
  0%   { opacity:0; transform:translateY(6px) scale(.92) }
  100% { opacity:1; transform:translateY(0) scale(1) }
}
@keyframes fabHintFloat{
  0%,100% { transform:translateY(0) }
  50%     { transform:translateY(-3px) }
}
@media (prefers-reduced-motion: reduce){
  .fab-hint{animation:fabHintIn .25s ease both}
}
@media (max-width:640px){
  .fab-hint{
    right:16px;bottom:86px;max-width:220px;min-width:180px;
    padding:10px 28px 10px 12px;
  }
  .fab-hint-title{font-size:13px}
  .fab-hint-sub{font-size:12px}
}
.chat-panel{
  position:fixed;right:22px;bottom:82px;z-index:81;
  width:min(380px, calc(100vw - 40px));height:min(520px, calc(100vh - 160px));
  display:flex;flex-direction:column;
  background:
    radial-gradient(240px 120px at 0% 0%, rgba(216,182,90,.16), transparent 60%),
    linear-gradient(180deg, #141419 0%, #0b0b0d 100%);
  border:1px solid rgba(216,182,90,.55);
  border-radius:18px;
  box-shadow:0 26px 60px rgba(0,0,0,.55), inset 0 1px 0 rgba(216,182,90,.25);
  overflow:hidden;
}
.chat-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-bottom:1px solid rgba(216,182,90,.25);
  color:var(--gold-2);font-size:14px;letter-spacing:.5px;
}
.chat-close{
  background:transparent;border:0;color:rgba(255,255,255,.7);cursor:pointer;
  width:30px;height:30px;border-radius:8px;
}
.chat-close:hover{color:#fff;background:rgba(255,255,255,.06)}
.chat-body{
  flex:1;padding:14px 16px;overflow-y:auto;
  scrollbar-width:none;-ms-overflow-style:none;
}
.chat-body::-webkit-scrollbar{width:0;height:0;display:none}
.chat-msg{margin-bottom:10px;display:flex}
.chat-msg .bubble{
  max-width:86%;padding:10px 12px;border-radius:12px;
  font-size:14px;line-height:1.55;white-space:pre-wrap;word-break:break-word;
}
.chat-msg.from-bot .bubble{
  background:linear-gradient(180deg, rgba(216,182,90,.12), rgba(216,182,90,.04));
  color:rgba(255,255,255,.92);
  border:1px solid rgba(216,182,90,.28);
}
.chat-msg.from-user{justify-content:flex-end}
.chat-msg.from-user .bubble{
  background:linear-gradient(180deg, var(--gold-2), var(--gold));
  color:#211b08;
}
.chat-msg .actions{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}
.chat-msg .actions a{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 10px;border-radius:999px;
  background:rgba(216,182,90,.14);
  color:var(--gold-2);
  border:1px solid rgba(216,182,90,.35);
  font-size:12.5px;
}
.chat-msg .actions a:hover{background:rgba(216,182,90,.22);color:#fff7de}
.chat-input{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;border-top:1px solid rgba(216,182,90,.22);
}
.chat-input input{
  flex:1;border:0;outline:0;background:rgba(255,255,255,.06);
  padding:10px 12px;border-radius:999px;color:#fff;font-size:14px;
  border:1px solid rgba(216,182,90,.3);
}
.chat-input input::placeholder{color:rgba(255,255,255,.5)}
.chat-input button{
  background:linear-gradient(180deg, var(--gold-2), var(--gold));
  color:#211b08;border:0;width:38px;height:38px;border-radius:50%;
  cursor:pointer;display:grid;place-items:center;
}

/* ==============================================================
   Content pages (category / news / search / about / errors)
   -------------------------------------------------------------- */
.page-hero{
  padding:36px 0 24px;margin-top:10px;
  background:
    radial-gradient(600px 180px at 20% 0%, rgba(216,182,90,.18), transparent 60%),
    linear-gradient(135deg, var(--blue-hero-a) 0%, var(--blue-hero-b) 60%, var(--blue-hero-c) 100%);
  color:#fff;border-bottom:1px solid rgba(216,182,90,.35);
}
.page-hero.slim{padding:22px 0 16px}
.page-hero h1{margin:0 0 8px;font-size:28px;font-weight:700}
.page-hero p{margin:0;color:rgba(255,255,255,.78)}
.page-hero .breadcrumb{
  font-size:13px;color:rgba(255,255,255,.78);
  display:flex;align-items:center;gap:6px;margin-top:10px;
}
.page-hero .breadcrumb a{color:rgba(255,255,255,.88)}
.page-hero .breadcrumb a:hover{color:var(--gold-2)}

.page-layout{
  display:grid;grid-template-columns:minmax(0, 2.4fr) minmax(260px, 1fr);
  gap:28px;margin:30px auto 40px;
}
.page-layout.single{grid-template-columns:minmax(0, 1fr)}
.page-main{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px}
.page-side .side-card{margin-bottom:18px}

.article-list{list-style:none;margin:0;padding:0}
.article-item{
  display:flex;gap:14px;padding:14px 0;border-bottom:1px dashed var(--line);
}
.article-thumb{
  flex:0 0 160px;height:96px;border-radius:10px;
  background:#eaecf3 center/cover no-repeat;
}
.article-body{flex:1;min-width:0}
.article-body h3{
  margin:0 0 6px;font-size:17px;
  display:flex;align-items:center;gap:8px;
}
.article-body h3 a{color:#1e2631}
.article-body h3 a:hover{color:var(--primary)}
.article-body p{margin:0 0 8px;color:var(--muted);font-size:13.5px}
.article-meta{color:var(--muted);font-size:12.5px;display:flex;gap:14px;flex-wrap:wrap}
.article-meta .bi{margin-right:4px;color:var(--gold)}
.empty{color:var(--muted);padding:14px 0;text-align:center}

.article-detail .article-title{margin:0 0 6px;font-size:26px;line-height:1.4}
.article-detail .article-subtitle{margin:0 0 10px;color:var(--muted);font-size:15px}
.article-detail .article-info{color:var(--muted);font-size:13px;display:flex;gap:16px;flex-wrap:wrap;margin-bottom:14px}
.article-detail .article-info .bi{margin-right:4px;color:var(--gold)}
.article-detail .article-cover{width:100%;border-radius:12px;margin:10px 0 18px}
.article-detail .article-content{font-size:15.5px}
.article-detail .article-content h2,
.article-detail .article-content h3{margin:18px 0 8px}
.article-detail .article-content blockquote{
  margin:14px 0;padding:8px 14px;
  background:#fbf6e5;border-left:3px solid var(--gold);color:#4a3d12;
  border-radius:0 8px 8px 0;
}
.article-detail .article-content img{border-radius:8px;margin:10px 0}
.article-detail .article-content code{background:#f3f3f7;padding:1px 6px;border-radius:4px}
.article-detail .article-nav{
  margin-top:28px;display:grid;grid-template-columns:1fr 1fr;gap:12px;
}
.article-detail .article-nav a{
  background:#fafbfd;border:1px solid var(--line);border-radius:10px;
  padding:10px 14px;color:#1e2631;
  display:flex;flex-direction:column;
}
.article-detail .article-nav a:hover{border-color:var(--gold)}
.article-detail .article-nav .lbl{font-size:12px;color:var(--muted)}
.article-detail .article-nav .next{text-align:right}

.pagination{display:flex;gap:6px;margin-top:18px;flex-wrap:wrap;justify-content:center}
.pagination a{
  padding:6px 11px;border:1px solid var(--line);border-radius:8px;
  font-size:13px;color:#2a313c;background:#fff;
}
.pagination a.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.pagination span{padding:6px 8px;color:var(--muted);font-size:13px}

.side-card h4 .bi{color:var(--gold)}
.side-cats{list-style:none;margin:0;padding:0}
.side-cats li{padding:6px 0;border-bottom:1px dashed var(--line)}
.side-cats li:last-child{border-bottom:0}
.side-cats a{color:#2a313c;font-size:14px;display:flex;align-items:center;gap:6px}
.side-cats a:hover{color:var(--primary)}
.side-cats .bi{color:var(--gold)}

.err-page{padding:90px 0;text-align:center}
.err-page h1{font-size:80px;margin:0;color:var(--gold)}
.err-page p{color:var(--muted);margin:8px 0 20px}
.btn-primary{
  display:inline-block;padding:10px 18px;border-radius:10px;
  background:linear-gradient(180deg, var(--gold-2), var(--gold));color:#211b08;font-weight:600;
}
.btn-primary:hover{transform:translateY(-1px)}

/* ==============================================================
   Responsive
   -------------------------------------------------------------- */
@media (max-width: 1100px){
  .header-search{min-width:180px}
  .slide-inner{height:514px}
  .slide-text{bottom:72px}
  .carousel-dots{bottom:14px}
}
@media (max-width: 980px){
  .header-inner{grid-template-columns:auto 1fr auto;gap:12px}
  .nav-toggle{display:block}
  .main-nav,.header-search{display:none}
  .main-nav.is-open{
    display:block;position:absolute;top:100%;left:0;right:0;
    background:linear-gradient(180deg, #141418 0%, #0b0b0d 100%);
    border-top:1px solid rgba(216,182,90,.35);
    padding:10px 16px;
  }
  .main-nav.is-open > ul{flex-direction:column;align-items:stretch;gap:0}
  .main-nav.is-open .has-dropdown .dropdown{
    position:static;opacity:1;visibility:visible;transform:none;
    margin:6px 0 8px 10px;box-shadow:none;
  }
  .has-dropdown .dropdown::before{display:none}

  .slide-inner{height:446px}
  .slide-text{bottom:68px;padding:0 20px}

  .hq-row{grid-template-columns:1fr}
  .hero-stats-overlay{padding:14px 0 12px}
  .hero-stats-overlay .stats-strip-inner{gap:12px;grid-template-columns:repeat(4, 1fr)}
  .hero-stats-overlay .stat .n{font-size:clamp(22px, 5vw, 30px)}
  .hero-stats-overlay .stat .l{font-size:12px;letter-spacing:.5px}
  .carousel-dots{bottom:12px}

  .main-grid{grid-template-columns:1fr}
  .main-col{grid-template-columns:1fr}
  .headline-grid{grid-template-columns:1fr 1fr;grid-auto-rows:120px}
  .headline-card.large{grid-row:auto}

  .page-layout{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}

  .stats-strip .container,.stats-strip .stats-strip-inner{gap:18px;padding:0}
}
@media (max-width: 540px){
  .slide-inner{height:378px}
  .slide-text{bottom:58px}
  .slide-title{font-size:22px}
  .hero-stats-overlay{padding:10px 0 10px}
  .hero-stats-overlay .stats-strip-inner{grid-template-columns:repeat(2,1fr);gap:6px 10px}
  .hero-stats-overlay .stat .n{font-size:22px}
  .hero-stats-overlay .stat .l{font-size:11px}
  .stats-strip{padding:28px 0}
  .stats-strip .container,.stats-strip .stats-strip-inner{grid-template-columns:repeat(2,1fr);gap:18px}
  .headline-grid{grid-template-columns:1fr}
  .quick-links{grid-template-columns:1fr}
  .hero-quickbar{padding:24px 0 22px}
  .hq-product{padding:12px 14px}
  .hq-product-icon{width:42px;height:42px;font-size:18px;border-radius:10px}
  .hq-product-title{font-size:15.5px}
  .hq-form{padding:4px 4px 4px 14px}
  .hq-form input{padding:10px 0;font-size:14px}
  .hq-form button{width:36px;height:36px;font-size:16px}
  .chat-fab{width:56px;height:56px;right:18px;bottom:18px}
  .chat-fab .fab-robot{font-size:26px}
}

/* ============================================================
   Contact page (联系我们 + 问卷)
   ============================================================ */
.contact-wrap{
  padding:32px 0 64px;
  display:flex;flex-direction:column;gap:28px;
}
.contact-info-grid{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:14px;
}
.ci-card{
  border:1px solid #e6e4df;background:#fff;border-radius:0;
  padding:18px 18px 16px;position:relative;
  border-top:3px solid #1f4fb5;
  transition:box-shadow .18s ease, transform .18s ease, border-color .18s ease;
}
.ci-card:hover{box-shadow:0 6px 18px rgba(31,79,181,.08);transform:translateY(-1px);border-top-color:#1a3e90}
.ci-card i{font-size:22px;color:#1f4fb5;display:inline-block;margin-bottom:6px}
.ci-card h4{margin:0 0 4px;font-size:14px;font-weight:600;color:#6a6a6a;letter-spacing:.5px}
.ci-card p{margin:0;font-size:15px;font-weight:600;color:#1c1c1c;word-break:break-word}
.ci-card a{color:#1f4fb5;text-decoration:none}
.ci-card a:hover{text-decoration:underline}

.survey-block{
  background:#fff;border:1px solid #e6e4df;border-top:3px solid #1f4fb5;
  padding:28px 28px 26px;
}
.survey-head{margin-bottom:18px}
.survey-head h2{
  margin:0 0 6px;font-size:22px;font-weight:700;color:#1c1c1c;
  padding-left:12px;position:relative;
}
.survey-head h2::before{
  content:"";position:absolute;left:0;top:6px;bottom:6px;width:4px;background:#1f4fb5;
}
.survey-sub{margin:0;color:#6a6a6a;font-size:14px}

.survey-success,
.survey-error{
  display:flex;align-items:center;gap:12px;
  padding:12px 16px;margin:0 0 16px;border-radius:0;
  font-size:14px;
}
.survey-success{background:#e8f4ec;border:1px solid #b7dcc4;color:#1d6b3b}
.survey-success i{font-size:20px;color:#2a8c56}
.survey-success strong{display:block;font-size:15px;margin-bottom:2px}
.survey-success span{color:#355a44}
.survey-error{background:#fdecec;border:1px solid #f2c2c2;color:#8a2222}
.survey-error i{font-size:18px;color:#c33}

.survey-form{display:flex;flex-direction:column;gap:22px}
.survey-section{
  border-top:1px dashed #d9d6cf;padding-top:18px;
}
.survey-section:first-child{border-top:none;padding-top:0}
.survey-section h3{
  margin:0 0 12px;font-size:16px;font-weight:700;color:#1f4fb5;
  letter-spacing:.4px;
}

.form-grid-2{
  display:grid;grid-template-columns:1fr 1fr;gap:12px 16px;
}
.form-grid-2 label,
.block-label{
  display:flex;flex-direction:column;gap:6px;font-size:13px;color:#4a4a4a;
}
.block-label{margin-top:12px}
.form-grid-2 label span,
.block-label span{font-weight:600;color:#2a2a2a}
.survey-form input[type=text],
.survey-form input[type=email],
.survey-form input[type=tel],
.survey-form textarea{
  border:1px solid #d6d3cd;border-radius:0;background:#fafaf7;
  padding:10px 12px;font-size:14px;font-family:inherit;color:#1c1c1c;
  transition:border-color .15s ease, background .15s ease, box-shadow .15s ease;
  width:100%;box-sizing:border-box;
}
.survey-form input[type=text]:focus,
.survey-form input[type=email]:focus,
.survey-form input[type=tel]:focus,
.survey-form textarea:focus{
  outline:none;border-color:#1f4fb5;background:#fff;
  box-shadow:0 0 0 3px rgba(31,79,181,.12);
}
.survey-form textarea{resize:vertical;min-height:72px}

.survey-q{
  padding:12px 0;border-bottom:1px dashed #ecebe6;
}
.survey-q:last-child{border-bottom:none}
.sq-label{margin-bottom:8px}
.sq-title{font-size:15px;font-weight:600;color:#1c1c1c;line-height:1.6}
.sq-title .req{color:#c93030;font-style:normal;margin-right:4px}
.sq-help{display:block;font-size:12.5px;color:#888;margin-top:2px}

.sq-options{display:flex;flex-wrap:wrap;gap:8px 12px}
.sq-opt{
  display:inline-flex;align-items:center;gap:8px;
  background:#fafaf7;border:1px solid #d6d3cd;
  padding:8px 14px;cursor:pointer;font-size:14px;color:#2a2a2a;
  transition:border-color .15s ease, background .15s ease, color .15s ease;
}
.sq-opt:hover{border-color:#1f4fb5;color:#1f4fb5}
.sq-opt input{accent-color:#1f4fb5;margin:0}
.sq-opt input:checked + span{color:#1f4fb5;font-weight:600}

.sq-rating{display:inline-flex;gap:6px}
.sq-star{cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.sq-star input{position:absolute;opacity:0;pointer-events:none}
.sq-star i{font-size:26px;color:#d4bb55;transition:transform .12s ease}
.sq-star:hover i{transform:scale(1.15)}

.survey-actions{display:flex;justify-content:flex-end;margin-top:6px}
.btn-submit{
  background:linear-gradient(135deg,#1f4fb5,#1a3e90);
  color:#fff;border:none;border-radius:0;
  padding:12px 32px;font-size:15px;font-weight:600;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
  box-shadow:0 4px 14px rgba(31,79,181,.25);
  transition:transform .12s ease, box-shadow .15s ease, background .2s ease;
}
.btn-submit:hover{
  background:linear-gradient(135deg,#1a3e90,#142f73);
  box-shadow:0 6px 18px rgba(31,79,181,.32);
  transform:translateY(-1px);
}
.btn-submit:active{transform:translateY(0)}

@media (max-width:820px){
  .contact-info-grid{grid-template-columns:repeat(2,1fr)}
  .form-grid-2{grid-template-columns:1fr}
  .survey-block{padding:20px 18px 20px}
  .survey-head h2{font-size:19px}
}
@media (max-width:520px){
  .contact-info-grid{grid-template-columns:1fr}
}

/* ============================================================
   Team page
   ============================================================ */
.team-wrap{padding:32px 0 64px;display:flex;flex-direction:column;gap:32px}

.team-empty{
  background:#fff;border:1px solid #e6e4df;border-top:3px solid #1f4fb5;
  padding:36px 28px;text-align:center;color:#4a4a4a;
}
.team-empty i{font-size:38px;color:#1f4fb5;margin-bottom:10px}
.team-empty h3{margin:0 0 6px;font-size:18px;font-weight:700;color:#1c1c1c}
.team-empty p{margin:0;font-size:14.5px}
.team-empty a{color:#1f4fb5;font-weight:600}

.team-anchor-bar{
  display:flex;flex-wrap:wrap;gap:10px;
  padding:14px 18px;background:#fff;border:1px solid #e6e4df;
  border-top:3px solid #1f4fb5;
}
.team-anchor-bar a{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;background:#f6f7fb;border:1px solid #dfe3ee;
  color:#1c1c1c;font-size:14px;font-weight:600;
  text-decoration:none;transition:all .15s ease;
}
.team-anchor-bar a:hover{
  background:#1f4fb5;border-color:#1f4fb5;color:#fff;
}
.team-anchor-bar a i{color:#1f4fb5}
.team-anchor-bar a:hover i{color:#fff}
.team-anchor-bar .tcnt{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:20px;padding:0 6px;
  background:#e7ecf9;color:#1f4fb5;font-size:12px;font-weight:700;
  border-radius:10px;
}
.team-anchor-bar a:hover .tcnt{background:rgba(255,255,255,.22);color:#fff}

.team-section{scroll-margin-top:90px}
.team-section-head{margin-bottom:14px}
.team-section-head .ts-title{
  display:flex;align-items:center;gap:10px;
  padding-left:12px;position:relative;
}
.team-section-head .ts-title::before{
  content:"";position:absolute;left:0;top:4px;bottom:4px;width:4px;background:#1f4fb5;
}
.team-section-head .ts-title i{font-size:22px;color:#1f4fb5}
.team-section-head h2{
  margin:0;font-size:22px;font-weight:700;color:#1c1c1c;letter-spacing:.4px;
}
.team-section-head .ts-desc{
  margin:8px 0 0;padding-left:12px;color:#6a6a6a;font-size:14px;line-height:1.7;
}

.team-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}

.team-card{
  display:flex;gap:16px;
  background:#fff;border:1px solid #e6e4df;border-top:3px solid #1f4fb5;
  padding:18px 18px 16px;text-decoration:none;color:inherit;
  transition:box-shadow .18s ease, transform .18s ease, border-color .18s ease;
  min-height:148px;
}
.team-card:hover{
  box-shadow:0 8px 22px rgba(31,79,181,.12);
  transform:translateY(-2px);
  border-top-color:#1a3e90;
}

.tc-photo{
  flex:0 0 96px;width:96px;height:96px;
  border:1px solid #e6e4df;overflow:hidden;background:#f6f7fb;
  display:flex;align-items:center;justify-content:center;
}
.tc-photo img{width:100%;height:100%;object-fit:cover;display:block}
.tc-photo-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  color:#b6bbc9;font-size:36px;background:#f1f3f9;
}

.tc-body{flex:1;min-width:0;display:flex;flex-direction:column}
.tc-name{
  margin:0 0 2px;font-size:17px;font-weight:700;color:#1c1c1c;letter-spacing:.3px;
}
.tc-title{
  margin:0 0 6px;font-size:13px;font-weight:600;color:#1f4fb5;line-height:1.5;
}
.tc-brief{
  margin:0 0 8px;font-size:13.5px;color:#55585f;line-height:1.65;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.tc-more{
  margin-top:auto;display:inline-flex;align-items:center;gap:4px;
  font-size:12.5px;color:#1f4fb5;font-weight:600;letter-spacing:.4px;
}
.team-card:hover .tc-more{color:#1a3e90}
.team-card:hover .tc-more i{transform:translateX(3px)}
.tc-more i{transition:transform .2s ease}

@media (max-width:900px){
  .team-grid{grid-template-columns:1fr}
  .team-card{min-height:0}
}

/* Team member detail page */
.team-member-wrap{
  padding:28px 0 64px;
  display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:28px;
}
.team-member-main{
  background:#fff;border:1px solid #e6e4df;border-top:3px solid #1f4fb5;
  padding:28px 28px 24px;
}
.tm-hero{
  display:flex;gap:24px;align-items:flex-start;
  padding-bottom:20px;margin-bottom:20px;border-bottom:1px dashed #d9d6cf;
}
.tm-photo{
  flex:0 0 160px;width:160px;height:160px;
  border:1px solid #e6e4df;overflow:hidden;background:#f6f7fb;
  display:flex;align-items:center;justify-content:center;
}
.tm-photo img{width:100%;height:100%;object-fit:cover;display:block}

.tm-meta{flex:1;min-width:0}
.tm-group{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12.5px;color:#1f4fb5;font-weight:600;letter-spacing:.4px;
  background:#eef2fb;padding:4px 10px;border:1px solid #cfd9f0;margin-bottom:10px;
}
.tm-name{
  margin:0 0 6px;font-size:26px;font-weight:700;color:#1c1c1c;letter-spacing:.5px;
}
.tm-title{
  margin:0 0 10px;font-size:15px;font-weight:600;color:#1f4fb5;line-height:1.5;
}
.tm-brief{
  margin:0 0 14px;font-size:15px;color:#3a3a3a;line-height:1.75;
}
.tm-links{display:flex;flex-wrap:wrap;gap:10px}
.tm-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13.5px;color:#1f4fb5;text-decoration:none;
  padding:6px 12px;border:1px solid #cfd9f0;background:#f6f7fb;
  transition:background .15s ease, color .15s ease, border-color .15s ease;
}
.tm-link:hover{background:#1f4fb5;color:#fff;border-color:#1f4fb5}

.tm-bio{margin-top:8px}
.tm-bio h2{
  margin:0 0 12px;font-size:18px;font-weight:700;color:#1c1c1c;
  padding-left:12px;position:relative;letter-spacing:.4px;
}
.tm-bio h2::before{
  content:"";position:absolute;left:0;top:4px;bottom:4px;width:4px;background:#1f4fb5;
}

.tm-back{margin-top:24px;padding-top:16px;border-top:1px dashed #d9d6cf}
.tm-back a{
  display:inline-flex;align-items:center;gap:6px;
  color:#1f4fb5;font-weight:600;text-decoration:none;font-size:14px;
}
.tm-back a:hover{text-decoration:underline}

.team-member-side .side-card h4{
  display:flex;align-items:center;gap:8px;
}

.tm-siblings{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.tm-siblings a{
  display:flex;gap:10px;align-items:center;
  padding:8px;border:1px solid #ecebe6;background:#fff;
  text-decoration:none;color:inherit;
  transition:border-color .15s ease, background .15s ease;
}
.tm-siblings a:hover{border-color:#1f4fb5;background:#f6f7fb}
.tm-siblings .ts-photo{
  flex:0 0 40px;width:40px;height:40px;overflow:hidden;background:#f1f3f9;
  display:flex;align-items:center;justify-content:center;color:#b6bbc9;font-size:20px;
  border:1px solid #e6e4df;
}
.tm-siblings .ts-photo img{width:100%;height:100%;object-fit:cover;display:block}
.tm-siblings .ts-body{display:flex;flex-direction:column;min-width:0;flex:1}
.tm-siblings .ts-body .n{font-size:14px;font-weight:700;color:#1c1c1c;line-height:1.3}
.tm-siblings .ts-body .t{
  font-size:12px;color:#6a6a6a;line-height:1.4;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

@media (max-width:980px){
  .team-member-wrap{grid-template-columns:1fr}
  .tm-hero{flex-direction:column;align-items:center;text-align:center}
  .tm-photo{width:150px;height:150px;flex-basis:auto}
  .tm-meta{text-align:center}
  .tm-links{justify-content:center}
}

