/* Official site (server-rendered) */
:root{
  --of-bg:#0b1220;
  --of-surface:#0f1a33;
  --of-card:#ffffff;
  --of-text:#0f172a;
  --of-muted:#64748b;
  --of-link:#2563eb;
  --of-primary:#3d7eff;
  --of-shadow:0 14px 40px rgba(2,6,23,.22);
  --of-radius:18px;
}
*{box-sizing:border-box}
html{
  scrollbar-gutter:stable;
  overflow-x:clip;
}
body{
  margin:0;
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,"PingFang SC","Microsoft YaHei",sans-serif;
  color:var(--of-text);
  background:#0b1220;
  overflow-x:clip;
}
img,video,canvas,svg{max-width:100%;height:auto}
.of-wrap{
  width:100%;
  max-width:min(1280px,100%);
  margin:0 auto;
  padding:0 16px;
  min-width:0;
}
.of-nav{
  position:sticky;top:0;z-index:50;
  background:rgba(11,18,32,.82);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid rgba(148,163,184,.18);
}
.of-nav__row{display:flex;align-items:center;gap:clamp(6px,2vw,10px);min-height:58px;min-width:0}
.of-brand{
  color:#fff;text-decoration:none;font-weight:800;letter-spacing:.02em;
  flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.of-nav__links{
  display:flex;gap:8px;flex:1 1 0%;min-width:0;overflow-x:auto;overflow-y:hidden;
  scrollbar-width:none;-ms-overflow-style:none;
  -webkit-overflow-scrolling:touch;
}
.of-nav__links::-webkit-scrollbar{display:none}
.of-nav__a{color:rgba(226,232,240,.86);text-decoration:none;font-weight:650;font-size:14px;padding:8px 9px;border-radius:10px;white-space:nowrap}
.of-nav__a.is-active{background:rgba(61,126,255,.22);color:#fff}
.of-nav__menu-trigger{
  appearance:none;border:none;cursor:pointer;background:transparent;
  color:rgba(226,232,240,.86);font-weight:650;font-size:14px;padding:8px 10px;border-radius:10px;white-space:nowrap;
}
.of-nav__menu-trigger:hover{background:rgba(61,126,255,.12);color:#fff}
.of-nav__menu-trigger.is-active{background:rgba(61,126,255,.22);color:#fff}
.of-colmenu{
  margin:0 0 10px;background:rgba(15,26,51,.95);border:1px solid rgba(148,163,184,.26);
  border-radius:14px;padding:10px;box-shadow:0 18px 36px rgba(2,6,23,.45);
}
.of-colmenu__search input{
  width:100%;height:34px;border-radius:10px;border:1px solid rgba(148,163,184,.28);
  background:#0c1730;color:#e2e8f0;padding:0 10px;font-size:13px;
}
.of-colmenu__body{
  margin-top:10px;max-height:320px;overflow:auto;display:grid;grid-template-columns:repeat(2,1fr);gap:10px;
}
.of-colmenu__group{background:#0b1429;border:1px solid rgba(148,163,184,.18);border-radius:10px;padding:8px}
.of-colmenu__group h4{margin:0 0 6px;color:#cbd5e1;font-size:12px}
.of-colmenu__items{display:flex;flex-wrap:wrap;gap:6px}
.of-colmenu__a{
  display:inline-block;padding:5px 8px;border-radius:999px;font-size:12px;
  color:#bfdbfe;text-decoration:none;background:rgba(37,99,235,.18);border:1px solid rgba(59,130,246,.28);
}
.of-colmenu__a:hover{background:rgba(37,99,235,.3)}
.of-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 12px;border-radius:12px;
  font-weight:750;text-decoration:none;
  color:#e2e8f0;border:1px solid rgba(148,163,184,.22);
  background:rgba(15,26,51,.32);
}
.of-btn--primary{
  color:#fff;border-color:rgba(61,126,255,.45);
  background:linear-gradient(135deg,#3d7eff,#1989fa);
  box-shadow:0 10px 30px rgba(61,126,255,.22);
}
.of-nav__cta{flex:0 0 auto;max-width:100%}
.of-nav__lang{
  display:flex;align-items:center;flex:0 0 auto;min-width:0;
  margin-left:2px;font-size:13px;
}
.of-lang-dd{
  position:relative;
  z-index:52;
}
.of-lang-dd>summary.of-lang-dd__summary{
  list-style:none;
  cursor:pointer;
  user-select:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 13px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,.22);
  background:linear-gradient(165deg,rgba(22,36,72,.88),rgba(12,20,42,.72));
  color:rgba(248,250,252,.96);
  font:inherit;
  font-weight:650;
  letter-spacing:.02em;
  white-space:nowrap;
  box-shadow:0 1px 0 rgba(255,255,255,.06) inset,0 8px 22px rgba(2,6,23,.35);
  transition:background .2s ease,border-color .2s ease,box-shadow .2s ease,color .2s ease,transform .15s ease;
}
.of-lang-dd>summary.of-lang-dd__summary::-webkit-details-marker{display:none}
.of-lang-dd>summary.of-lang-dd__summary::after{
  content:"";
  display:inline-block;
  width:6px;height:6px;
  margin-left:1px;
  border-right:2px solid rgba(203,213,225,.85);
  border-bottom:2px solid rgba(203,213,225,.85);
  transform:rotate(45deg) translateY(-1px);
  transition:transform .22s cubic-bezier(.4,0,.2,1),border-color .2s ease;
  flex-shrink:0;
}
.of-lang-dd[open]>summary.of-lang-dd__summary{
  background:linear-gradient(165deg,rgba(37,78,180,.55),rgba(25,55,140,.38));
  border-color:rgba(96,165,250,.42);
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.1) inset,0 0 0 1px rgba(61,126,255,.25),0 12px 28px rgba(37,99,235,.22);
}
.of-lang-dd[open]>summary.of-lang-dd__summary::after{
  transform:rotate(225deg) translateY(1px);
  border-color:rgba(255,255,255,.9);
}
.of-lang-dd>summary.of-lang-dd__summary:hover{
  border-color:rgba(148,163,184,.38);
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.08) inset,0 10px 26px rgba(2,6,23,.42);
}
.of-lang-dd>summary.of-lang-dd__summary:focus-visible{
  outline:2px solid rgba(96,165,250,.65);
  outline-offset:2px;
}
.of-lang-dd__panel{
  display:flex;
  flex-direction:column;
  gap:3px;
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  min-width:168px;
  padding:5px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(22,34,62,.94),rgba(11,18,35,.92));
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  box-shadow:
    0 0 0 1px rgba(2,6,23,.5),
    0 20px 50px rgba(2,6,23,.65),
    0 8px 16px rgba(2,6,23,.35),
    inset 0 1px 0 rgba(255,255,255,.06);
  animation:of-lang-dd-panel .22s cubic-bezier(.4,0,.2,1) both;
}
@keyframes of-lang-dd-panel{
  from{opacity:0;transform:translateY(-8px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.of-lang-dd__item{
  display:block;
  width:100%;
  box-sizing:border-box;
  margin:0;
  padding:10px 12px 10px 14px;
  border:none;
  border-radius:10px;
  background:transparent;
  color:rgba(226,232,240,.82);
  font:inherit;
  font-size:13px;
  font-weight:600;
  text-align:left;
  text-decoration:none;
  cursor:pointer;
  transition:background .18s ease,color .18s ease,transform .15s ease,box-shadow .18s ease;
}
a.of-lang-dd__item{color:rgba(226,232,240,.82)}
.of-lang-dd__item:hover:not(.is-selected){
  background:rgba(61,126,255,.14);
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset;
}
.of-lang-dd__item:active:not(.is-selected){
  transform:scale(.985);
}
.of-lang-dd__item.is-selected{
  position:relative;
  background:linear-gradient(90deg,rgba(61,126,255,.38),rgba(61,126,255,.14));
  color:#fff;
  font-weight:750;
  cursor:default;
  box-shadow:inset 3px 0 0 #60a5fa,inset 0 1px 0 rgba(255,255,255,.06);
}
.of-lang-dd__item.is-selected[disabled]{
  opacity:1;
  color:#fff;
}
@media (prefers-reduced-motion:reduce){
  .of-lang-dd__panel{animation:none}
  .of-lang-dd>summary.of-lang-dd__summary,
  .of-lang-dd>summary.of-lang-dd__summary::after,
  .of-lang-dd__item{transition:none}
}

.of-hero{
  padding:34px 0 20px;
  background:radial-gradient(1200px 520px at 20% 10%, rgba(61,126,255,.35), transparent 58%),
             radial-gradient(900px 520px at 80% 0%, rgba(25,137,250,.26), transparent 55%),
             linear-gradient(180deg, rgba(11,18,32,1), rgba(11,18,32,.95));
}
.of-hero .of-wrap{display:grid;grid-template-columns:1.08fr .92fr;gap:18px;align-items:center;min-width:0}
.of-pill{
  display:inline-block;margin:0 0 10px;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700;
  color:#dbeafe;background:rgba(37,99,235,.18);border:1px solid rgba(59,130,246,.28);
  width:max-content;max-width:100%;box-sizing:border-box;
  overflow-wrap:break-word;word-break:break-word;
}
.of-hero__txt,.of-hero__img{min-width:0}
.of-hero h1{
  margin:0 0 10px;color:#fff;font-size:40px;line-height:1.12;letter-spacing:.01em;
  overflow-wrap:break-word;word-break:break-word;
}
.of-lead{margin:0 0 14px;color:rgba(226,232,240,.92);font-size:16px;line-height:1.7;overflow-wrap:break-word;word-break:break-word}
.of-cta{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 10px}
.of-tip{margin:0;color:rgba(148,163,184,.92);font-size:13px;line-height:1.6;overflow-wrap:break-word;word-break:break-word}
.of-lead--tight{margin-top:8px;font-size:15px;line-height:1.65;color:rgba(226,232,240,.88);overflow-wrap:break-word;word-break:break-word}
.of-inline-link{color:#bfdbfe;text-decoration:underline;text-underline-offset:3px}
.of-inline-link:hover{color:#fff}
.of-hero-hook{
  margin:12px 0 0;
  padding:10px 14px;
  border-left:3px solid rgba(96,165,250,.65);
  border-radius:0 12px 12px 0;
  background:rgba(15,26,51,.45);
  color:rgba(226,232,240,.95);
  font-size:15px;line-height:1.55;font-weight:650;
  overflow-wrap:break-word;word-break:break-word;
}
.of-home-band{margin-top:4px}
.of-home-band__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  align-items:stretch;
  min-width:0;
}
.of-home-card{
  background:var(--of-card);
  border-radius:var(--of-radius);
  padding:18px 18px 14px;
  box-shadow:var(--of-shadow);
  border:1px solid rgba(148,163,184,.14);
  min-width:0;
  max-width:100%;
  overflow:hidden;
}
.of-home-card h2{margin:0 0 12px;font-size:17px;color:#0f172a}
.of-home-list{margin:0;padding-left:1.15em;color:#334155;line-height:1.65;font-size:14px}
.of-home-list li{margin:0 0 10px}
.of-home-list li:last-child{margin-bottom:0}
.of-home-card__foot{margin:14px 0 0;font-size:13px;color:var(--of-muted);overflow-wrap:break-word;word-break:break-word}
.of-home-muted{margin:0;color:#64748b;font-size:14px;line-height:1.65}
/* 公告列表：subgrid 由整列最宽日期决定第一轨宽度，日期左对齐、标题起点一致，无需写死 rem/px */
.of-announce-list{
  --of-announce-gap:14px;
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  grid-template-columns:max-content minmax(0,1fr);
  column-gap:var(--of-announce-gap);
}
.of-announce-list__item{
  display:grid;
  grid-template-columns:subgrid;
  grid-column:1 / -1;
  padding:10px 0;
  border-bottom:1px solid rgba(148,163,184,.22);
  min-width:0;
}
.of-announce-list__item:last-child{border-bottom:none;padding-bottom:0}
.of-announce-list__link{
  display:grid;
  grid-template-columns:subgrid;
  grid-column:1 / -1;
  align-items:center;
  width:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
  font-size:14px;
  line-height:1.45;
  text-decoration:none;
  color:#1e293b;
}
.of-announce-list__link:hover .of-announce-list__titletext{text-decoration:underline}
.of-announce-list__date{
  text-align:left;
  justify-self:start;
  white-space:nowrap;
  font-size:13px;
  color:#64748b;
  font-variant-numeric:tabular-nums;
  min-width:0;
}
.of-announce-list__date time{font:inherit;color:inherit}
.of-announce-list__titletext{
  min-width:0;
  font-weight:700;
  color:#1d4ed8;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.of-home-card--updates .of-announce-list__titletext{color:#1d4ed8}

/* 无 subgrid：表格布局同级对齐列宽（行为与 subgrid 接近），日期仍左对齐 */
@supports not (grid-template-columns:subgrid){
  .of-announce-list{
    display:table;
    width:100%;
    border-collapse:collapse;
    column-gap:unset;
  }
  .of-announce-list__item{
    display:table-row;
    padding:0;
    border-bottom:none;
  }
  .of-announce-list__link{
    display:contents;
  }
  .of-announce-list__date{
    display:table-cell;
    padding:10px var(--of-announce-gap) 10px 0;
    vertical-align:middle;
    border-bottom:1px solid rgba(148,163,184,.22);
  }
  .of-announce-list__titletext{
    display:table-cell;
    padding:10px 0;
    vertical-align:middle;
    border-bottom:1px solid rgba(148,163,184,.22);
  }
  .of-announce-list__item:last-child .of-announce-list__date,
  .of-announce-list__item:last-child .of-announce-list__titletext{
    border-bottom:none;
    padding-bottom:0;
  }
}
.of-hero__img img{
  width:100%;height:auto;border-radius:var(--of-radius);
  box-shadow:var(--of-shadow);border:1px solid rgba(148,163,184,.18);
}

.of-subhd{
  padding:22px 0 12px;
  background:linear-gradient(180deg, rgba(11,18,32,1), rgba(11,18,32,.98));
}
.of-subhd .of-wrap{min-width:0}
.of-subhd h1{margin:0 0 8px;color:#fff;font-size:28px;overflow-wrap:break-word;word-break:break-word}
.of-subhd p{margin:0;color:rgba(226,232,240,.88);line-height:1.7;overflow-wrap:break-word;word-break:break-word}
.of-subhd__cta{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}
.of-subhd .of-callout{margin-top:14px;padding:12px 14px;border-radius:12px;background:rgba(15,23,42,.42);border:1px solid rgba(148,163,184,.22);max-width:900px}
.of-subhd .of-callout p{margin:0;color:rgba(226,232,240,.9);font-size:14px;line-height:1.65;overflow-wrap:break-word;word-break:break-word}
.of-subhd .of-callout strong{color:#f8fafc}
.of-icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:12px;border:1px solid rgba(148,163,184,.28);
  background:rgba(15,26,51,.38);color:#e2e8f0;cursor:pointer;font-size:18px;
}
.of-icon-btn:hover{background:rgba(61,126,255,.24);border-color:rgba(61,126,255,.45)}

.of-main{background:#f5f7fa;padding:18px 0 28px;min-width:0}
.of-sec{margin:0 0 18px}
.of-sec h2{margin:0 0 10px;font-size:18px}
.of-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.of-card{
  background:#fff;border-radius:16px;padding:14px 14px;
  border:1px solid #ebedf0;box-shadow:0 2px 12px rgba(0,0,0,.06);
}
.of-card h3{margin:0 0 6px;font-size:15px}
.of-card p{margin:0;color:#475569;line-height:1.7;font-size:14px}
.of-muted{color:#64748b}
.of-table{width:100%;border-collapse:collapse;font-size:14px;margin:12px 0;background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}
.of-table th,.of-table td{padding:10px 12px;text-align:left;border-bottom:1px solid #ebedf0;vertical-align:top;line-height:1.55}
.of-table th{background:#f1f5f9;color:#334155;font-weight:600}
.of-table tbody tr:last-child td{border-bottom:0}
.of-table caption{caption-side:bottom;padding:10px 4px 0;font-size:13px;color:#64748b;text-align:left;line-height:1.5}
.of-more{margin:10px 0 0}
.of-link{color:var(--of-link);text-decoration:underline;text-underline-offset:2px}
/* 友情链接：单行文本链，无 pill 底色；间距约 10px */
.of-links-inline{
  margin:10px 0 0;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  max-width:100%;
  overflow-wrap:break-word;
}
.of-guide-list{
  background:#fff;
  border:1px solid #ebedf0;
  border-radius:16px;
  overflow:hidden;
}
.of-guide-item{
  display:grid;
  /* 第三列随英文按钮文案变长而变宽，避免 108px 固定宽把 pill 按钮挤成两行 */
  grid-template-columns:44px minmax(0,1fr) auto;
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid #eef2f7;
  transition:background .15s ease;
  align-items:start;
}
.of-guide-item:last-child{border-bottom:none}
.of-guide-item:hover{background:#f8fbff}
.of-guide-item__idx{
  width:32px;height:32px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  background:#eff6ff;border:1px solid #cfe0ff;color:#1d4ed8;
  font-weight:800;font-size:13px;
}
.of-guide-item__body h3{margin:0 0 6px;font-size:17px;line-height:1.35}
.of-guide-item__tag{
  margin:0 0 4px;font-size:12px;font-weight:650;color:#64748b;letter-spacing:.02em;
}
.of-guide-item__title{
  color:#0f172a;text-decoration:none;
}
.of-guide-item__title:hover{color:#1d4ed8;text-decoration:underline;text-underline-offset:2px}
.of-guide-item__body p{
  margin:0;color:#475569;line-height:1.72;font-size:14px;
}
.of-guide-item__action{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  min-width:0;
}
.of-guide-item__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:92px;
  height:34px;
  padding:0 14px;
  border-radius:999px;
  text-decoration:none;
  color:#1d4ed8;
  border:1px solid #dbeafe;
  background:#eff6ff;
  font-weight:700;
  font-size:13px;
  line-height:1.2;
  white-space:nowrap;
}
.of-guide-item__btn:hover{
  background:#dbeafe;
}

.of-colsearch{
  position:fixed;inset:0;z-index:120;display:flex;align-items:center;justify-content:center;
}
.of-colsearch[hidden]{display:none !important}
.of-colsearch__backdrop{
  position:absolute;inset:0;background:rgba(2,6,23,.52);
}
.of-colsearch__panel{
  position:relative;z-index:1;width:min(760px,92vw);max-height:82vh;overflow:hidden;
  background:#fff;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 24px 60px rgba(2,6,23,.28);
  display:flex;
  flex-direction:column;
}
.of-colsearch__hd{
  display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #eef2f7;
  flex-shrink:0;
}
.of-colsearch__hd h2{margin:0;font-size:18px}
.of-colsearch__close{
  width:32px;height:32px;border:none;border-radius:8px;background:#f1f5f9;color:#334155;cursor:pointer;font-size:20px;line-height:1;
}
.of-colsearch__close:hover{background:#e2e8f0}
.of-colsearch__bd{
  flex:1;
  min-height:0;
  padding:12px 14px 14px;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.of-colsearch__body-main{
  flex-shrink:0;
  width:100%;
  height:min(520px,58vh);
  max-height:min(520px,58vh);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.of-colsearch__lang-hint{
  flex:1;
  min-height:0;
  margin:0;
  padding:18px 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-size:14px;
  line-height:1.65;
  color:#92400e;
  background:linear-gradient(180deg,#fffbeb 0%,#fef3c7 100%);
  border:1px solid #fde68a;
  border-radius:12px;
}
.of-colsearch__lang-hint[hidden]{display:none !important}
.of-colsearch__results{
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  position:relative;
}
.of-colsearch__results[hidden]{display:none !important}
.of-colsearch__placeholder{
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:16px 12px 20px;
  color:#64748b;
}
.of-colsearch__placeholder[hidden]{display:none !important}
.of-colsearch__ph-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 10px;
  width:56px;
  height:56px;
  border-radius:14px;
  background:#f1f5f9;
}
.of-colsearch__ph-title{
  margin:0 0 6px;
  font-size:15px;
  font-weight:600;
  color:#334155;
}
.of-colsearch__ph-desc{
  margin:0 auto;
  max-width:420px;
  font-size:14px;
  line-height:1.55;
  color:#64748b;
}
.of-colsearch__toolbar{
  display:flex;gap:10px;align-items:stretch;margin-bottom:10px;
  flex-shrink:0;
}
.of-colsearch__toolbar .of-colsearch__input{
  flex:1;min-width:0;margin:0;
}
.of-colsearch__submit{
  flex-shrink:0;align-self:stretch;height:40px;padding:0 16px;border-radius:10px;
  border:1px solid #2563eb;background:#2563eb;color:#fff;font-size:14px;font-weight:600;cursor:pointer;
}
.of-colsearch__submit:hover{background:#1d4ed8;border-color:#1d4ed8}
.of-colsearch__input{
  width:100%;height:40px;border:1px solid #cbd5e1;border-radius:10px;padding:0 12px;font-size:14px;
}
.of-colsearch__list{
  flex:1;
  min-height:0;
  margin-top:0;
  overflow:auto;
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
.of-colsearch__emptystate{
  position:absolute;
  inset:0;
  z-index:2;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:20px 16px;
  background:#fff;
  pointer-events:none;
}
.of-colsearch__emptystate[hidden]{display:none !important}
.of-colsearch__empty-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 12px;
  width:56px;
  height:56px;
  border-radius:14px;
  background:#f1f5f9;
}
.of-colsearch__empty-msg{
  margin:0;
  max-width:380px;
  font-size:14px;
  line-height:1.65;
  color:#64748b;
}
.of-colsearch__item[hidden]{display:none !important}
.of-colsearch__item{
  display:block;padding:12px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;text-decoration:none;
}
.of-colsearch__badge{
  display:inline-block;margin:0 0 6px;padding:2px 8px;border-radius:999px;
  background:#f1f5f9;color:#475569;font-size:11px;font-weight:600;letter-spacing:.02em;
}
.of-colsearch__item:hover{border-color:#c7dcff;background:#f8fbff}
.of-colsearch__item h3{margin:0 0 6px;color:#0f172a;font-size:16px}
.of-colsearch__item p{margin:0;color:#475569;font-size:14px;line-height:1.6}

/* Long-form article */
.of-article{
  background:#fff;border-radius:18px;border:1px solid #ebedf0;
  box-shadow:0 2px 16px rgba(0,0,0,.06);
  overflow:hidden;
}
/*
 * Guide/scene/memorial covers (zh + /en): give the figure a bounded box and object-fit:contain
 * so the entire JPEG stays visible. Plain width:100% + max-height on <img> can clip in some engines.
 */
.of-article__cover{
  display:flex;
  align-items:center;
  justify-content:center;
  box-sizing:border-box;
  min-height:min(32vh, 260px);
  height:min(58vh, 520px);
  max-height:58vh;
  padding:12px 14px;
  background:#eef2f7;
}
.of-article__cover img{
  display:block;
  flex:0 1 auto;
  max-width:100%;
  max-height:100%;
  width:auto;
  height:auto;
  object-fit:contain;
  object-position:center;
}
.of-article--side{
  display:grid;
  grid-template-columns:minmax(260px, 38%) 1fr;
  align-items:stretch;
}
.of-article--side .of-article__cover{
  height:100%;
  border-right:1px solid #ebedf0;
}
.of-article--side .of-article__cover img{
  width:100%;
  height:100%;
  min-height:320px;
  object-fit:cover;
  object-position:center;
}
.of-article__cover--aux{
  display:block;
  height:220px;
  min-height:220px;
  max-height:220px;
  padding:0;
  background:#fff;
}
.of-article__cover--aux img{
  display:block;
  width:100%;
  height:100%;
  max-height:none;
  object-fit:cover;
  object-position:center;
}
.of-article__body{padding:16px 16px 18px}
.of-article__body p{margin:0 0 12px;line-height:1.85;color:#334155;font-size:15px}
.of-article__body h2{margin:16px 0 10px;font-size:16px}
.of-article__body ul{margin:0 0 12px;padding-left:18px;color:#334155;line-height:1.85}
.of-article__body li{margin:6px 0}
.of-article__body code{background:#f1f5ff;border:1px solid #dbeafe;border-radius:8px;padding:2px 6px}
/* 长文页：配图左浮动，首段与后续正文同一文档流环绕，避免「图高、首段短」时右侧与下方大块留白 */
.of-article-longform__wrap{
  padding:22px 24px 26px;
  background:linear-gradient(180deg,#f8fafc 0%,#ffffff 46%);
  border-bottom:1px solid #eef2f7;
}
.of-article-longform__wrap::after{
  content:"";
  display:table;
  clear:both;
}
/* 首屏「左图 + 右侧导语」：以图高度为参考，右侧文案垂直居中（无 lead 时仍用下方浮动排版） */
.of-article-longform__lead{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:22px;
  margin:0 0 18px;
}
.of-article-longform__lead .of-article-intro__media{
  float:none;
  width:220px;
  max-width:min(220px,38vw);
  margin:0;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
}
.of-article-longform__lead-text{
  flex:1;
  min-width:0;
}
.of-article-longform__lead-text p{
  line-height:1.82;
  margin:0 0 14px;
  color:#334155;
  font-size:15px;
}
.of-article-longform__lead-text > p:first-of-type{
  font-size:16px;
  line-height:1.78;
  color:#1e293b;
}
.of-article-longform__lead-text p.of-muted{
  font-size:14px;
  line-height:1.75;
  color:#64748b;
}
.of-article-longform__lead-text p:last-child{margin-bottom:0}
.of-article--longform .of-article-intro__media{
  float:left;
  width:220px;
  max-width:min(220px,38vw);
  margin:2px 22px 12px 0;
  display:flex;
  align-items:flex-start;
  justify-content:center;
}
.of-article--longform .of-article-intro__media img{
  display:block;
  width:100%;
  aspect-ratio:1;
  object-fit:contain;
  object-position:center;
  border-radius:12px;
  border:1px solid #e2e8f0;
  background:#fff;
  box-shadow:0 6px 22px rgba(15,23,42,.07);
}
.of-article--longform .of-article__body{padding:0}
.of-article--longform .of-article__body p{
  line-height:1.82;
  margin:0 0 14px;
  color:#334155;
  font-size:15px;
}
.of-article--longform .of-article__body > p:first-of-type{
  font-size:16px;
  line-height:1.78;
  color:#1e293b;
}
.of-article--longform .of-article__body h2{
  margin:22px 0 12px;
  clear:both;
  font-size:17px;
  font-weight:750;
  color:#0f172a;
  letter-spacing:.02em;
}
.of-article--longform .of-article__body ul{
  margin:0 0 16px;
  clear:both;
}
.of-article--longform .of-article__body .of-more{
  clear:both;
  margin-top:18px;
  padding-top:16px;
  border-top:1px dashed #e2e8f0;
}
/* 长文指南详情顶区：与场景页「左浮动 + h2 clear」流式不同，用导读双栏消掉图右侧空白 */
.of-article--guide-detail.of-article--longform .of-article-longform__wrap{
  background:linear-gradient(180deg,#f5f8ff 0%,#ffffff 50%);
  border-bottom:1px solid #e8edf5;
}
.of-gdetail-hero{
  display:grid;
  grid-template-columns:minmax(140px,228px) minmax(0,1fr);
  gap:22px 26px;
  align-items:start;
  margin:0 0 22px;
  padding:18px 20px;
  border-radius:16px;
  border:1px solid #d6e3f5;
  background:linear-gradient(130deg,#ffffff 0%,#f8fafc 40%,#eef4ff 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.85) inset,0 10px 32px rgba(15,23,42,.07);
}
.of-gdetail-hero--figure-only{
  grid-template-columns:1fr;
  justify-items:center;
  padding:16px 18px 20px;
}
.of-gdetail-hero--figure-only .of-gdetail-hero__figure{max-width:220px}
.of-gdetail-hero__figure{margin:0}
.of-gdetail-hero__figure img{
  display:block;
  width:100%;
  aspect-ratio:1;
  object-fit:contain;
  object-position:center;
  border-radius:14px;
  border:1px solid #e2e8f0;
  background:#fff;
  box-shadow:0 6px 22px rgba(15,23,42,.08);
}
.of-gdetail-hero__panel{min-width:0;padding-top:2px}
.of-gdetail-hero__summary{
  margin:0 0 14px;
  font-size:15px;
  line-height:1.82;
  color:#334155;
}
.of-gdetail-hero__panel > .of-gdetail-hero__summary:last-child{margin-bottom:0}
.of-gdetail-hero__steps-title{
  margin:0 0 10px;
  font-size:15px;
  font-weight:750;
  letter-spacing:.02em;
  color:#0f172a;
}
.of-gdetail-quicksteps{
  margin:0;
  padding:0;
  list-style:none;
  counter-reset:gdstep;
}
.of-gdetail-quicksteps li{
  counter-increment:gdstep;
  position:relative;
  margin:0 0 10px;
  padding:8px 12px 8px 40px;
  line-height:1.55;
  font-size:14px;
  color:#1e293b;
  background:rgba(255,255,255,.75);
  border:1px solid #e2e8f0;
  border-radius:10px;
}
.of-gdetail-quicksteps li:last-child{margin-bottom:0}
.of-gdetail-quicksteps li::before{
  content:counter(gdstep);
  position:absolute;
  left:10px;
  top:11px;
  width:22px;
  height:22px;
  border-radius:7px;
  background:linear-gradient(180deg,#eff6ff,#dbeafe);
  border:1px solid #93c5fd;
  color:#1d4ed8;
  font-weight:800;
  font-size:12px;
  line-height:20px;
  text-align:center;
}
.of-article--guide-detail .of-article__body > h2:first-of-type{margin-top:0}
.of-inc,.of-revision{margin:18px 0 0;clear:both}
.of-inc{
  padding:14px 16px;
  border-radius:14px;
  border:1px solid #dbeafe;
  background:linear-gradient(180deg,#f8fafc,#fff);
}
.of-inc h2{margin:0 0 10px;font-size:16px;color:#0f172a}
.of-inc h3{margin:14px 0 8px;font-size:14px;color:#1e40af;font-weight:750}
.of-inc p{margin:0 0 10px;line-height:1.75;color:#334155;font-size:14px}
.of-inc ul{margin:0 0 10px;padding-left:1.2em;color:#334155;font-size:14px;line-height:1.7}
.of-inc li{margin:4px 0}
.of-revision{
  padding:10px 14px;
  border-radius:12px;
  background:#f1f5f9;
  border:1px solid #e2e8f0;
}
.of-revision p{margin:0;font-size:13px;line-height:1.65;color:#64748b}
.of-revision .of-link{color:#2563eb}
.of-home-maint{
  margin:14px 0 0;
  padding:12px 2px 0;
  font-size:13px;
  line-height:1.55;
  color:#64748b;
  border-top:1px solid #e2e8f0;
}
.of-home-maint .of-link{color:#2563eb}
.of-home-maint time{font-variant-numeric:tabular-nums}
/* Space between main article card and following outbound section (matches zh layout) */
.of-main>.of-wrap>.of-article+.of-sec{margin-top:18px}
.of-breed-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:8px 0 12px}
.of-breed-card{
  display:block;text-decoration:none;background:#f8fbff;border:1px solid #dbeafe;border-radius:12px;
  padding:10px 12px;color:#1e293b;
}
.of-breed-card h3{margin:0 0 8px;font-size:15px;color:#1d4ed8}
.of-breed-card p{margin:0 0 6px;font-size:13px;line-height:1.6;color:#334155}
.of-breed-card:hover{background:#eef5ff}

/* Features page (non-card layouts) */
.of-feature-layout{
  background:#fff;border:1px solid #e8edf5;border-radius:14px;padding:14px 14px 12px;
}
.of-feature-layout + .of-feature-layout{margin-top:12px}
.of-feature-layout h2{margin:0 0 10px;font-size:17px}
.of-feature-list{
  margin:0;padding:0;list-style:none;counter-reset:feature;
}
.of-feature-list li{
  counter-increment:feature;
  padding:12px 0 12px 42px;
  border-bottom:1px dashed #dbe4f0;
  position:relative;
}
.of-feature-list li:last-child{border-bottom:none}
.of-feature-list li::before{
  content:counter(feature);
  position:absolute;left:0;top:14px;
  width:28px;height:28px;border-radius:999px;
  background:#eff6ff;color:#1d4ed8;border:1px solid #cfe0ff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;
}
.of-feature-list h3,.of-feature-waterfall h3,.of-feature-flow h3{margin:0 0 6px;font-size:15px}
.of-feature-list p,.of-feature-waterfall p,.of-feature-flow p{margin:0;color:#475569;line-height:1.75;font-size:14px}
.of-feature-waterfall{
  column-count:2;column-gap:12px;
}
.of-feature-waterfall__item{
  break-inside:avoid;
  margin:0 0 12px;padding:10px 0;border-bottom:1px dashed #dbe4f0;
}
.of-feature-flow{
  margin:0;padding:0;list-style:none;
}
.of-feature-flow li{
  display:grid;grid-template-columns:34px 1fr;gap:10px;
  padding:10px 0;border-bottom:1px dashed #dbe4f0;
}
.of-feature-flow li:last-child{border-bottom:none}
.of-feature-flow span{
  width:34px;height:34px;border-radius:8px;
  background:#f1f5ff;color:#1d4ed8;border:1px solid #dbeafe;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;
}
.of-feature-intro{
  display:grid;
  grid-template-columns:200px 1fr;
  gap:14px;
  align-items:center;
  margin:0 0 10px;
}
.of-feature-intro__media{
  display:flex;
  align-items:flex-start;
  justify-content:center;
}
.of-feature-intro__media img{
  width:200px;
  max-width:100%;
  height:auto;
  object-fit:unset;
  border-radius:10px;
  border:1px solid #e2e8f0;
}
.of-feature-intro__text p{margin:0 0 10px}
.of-feature-intro__text p:last-child{margin-bottom:0}

.of-ft{
  background:#0b1220;color:#e2e8f0;border-top:1px solid rgba(148,163,184,.18);
  padding:22px 0;
}
.of-ft__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.of-ft__col{min-width:0}
.of-ft__col--site{min-width:0}
.of-ft h3{margin:0 0 6px;font-size:14px;color:#cbd5e1;font-weight:750}
.of-ft p{margin:0 0 6px}
.of-ft .of-link{color:#93c5fd;text-decoration:none;text-underline-offset:3px}
.of-ft .of-link:hover{color:#e0f2fe;text-decoration:underline}
.of-ft__meta{
  margin-top:14px;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:8px;
}
.of-ft .of-ft__copy{color:#94a3b8}
.of-ft__copy{margin:0;justify-self:start}
.of-ft__beian{margin:0;text-align:center;font-size:12px;line-height:1.5;color:#94a3b8;grid-column:2}
.of-ft__beian-link{color:inherit;text-decoration:none}
.of-ft__beian-link:hover{text-decoration:underline}

@media (max-width: 980px){
  .of-wrap{padding:0 10px}
  .of-grid{grid-template-columns:repeat(2,1fr)}
  .of-home-band__grid{grid-template-columns:1fr}
  .of-hero .of-wrap{grid-template-columns:1fr}
  .of-colmenu__body{grid-template-columns:1fr}
  .of-breed-grid{grid-template-columns:1fr}
  .of-feature-waterfall{column-count:1}
  .of-feature-intro{grid-template-columns:1fr}
  .of-feature-intro__media{justify-content:flex-start}
  .of-feature-intro__media img{width:180px}
  .of-article-longform__wrap{padding:18px 16px 22px}
  .of-article-longform__lead{
    flex-direction:column;
    align-items:stretch;
    gap:14px;
    margin-bottom:16px;
  }
  .of-article-longform__lead .of-article-intro__media{
    width:auto;
    max-width:min(200px,42vw);
    margin:0 auto;
  }
  .of-article--longform .of-article-intro__media{width:200px;max-width:min(200px,42vw);margin-right:18px}
  .of-gdetail-hero{
    grid-template-columns:1fr;
    gap:16px;
    padding:16px 18px 18px;
  }
  .of-gdetail-hero__figure{max-width:200px;justify-self:center}
  .of-gdetail-hero--figure-only .of-gdetail-hero__figure{max-width:200px}
  .of-article--side{grid-template-columns:1fr}
  .of-article--side .of-article__cover{border-right:none;border-bottom:1px solid #ebedf0}
  .of-article--side .of-article__cover img{min-height:180px}
}
@media (max-width: 560px){
  .of-grid{grid-template-columns:1fr}
  .of-hero h1{font-size:clamp(1.25rem,6.5vw,2rem);line-height:1.18}
  /* 手机端保留全部导航入口：第一行品牌/语言/CTA，第二行横向滑动查看「功能…隐私」 */
  .of-nav__row{
    flex-wrap:wrap;
    align-items:center;
    row-gap:6px;
    column-gap:6px;
    padding-top:8px;
    padding-bottom:10px;
    min-height:0;
  }
  .of-brand{order:1;flex:1 1 auto;min-width:0}
  .of-nav__links{
    order:10;
    flex:0 0 100%;
    width:100%;
    max-width:100%;
    min-width:0;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    padding:8px 0 2px;
    margin:0;
    border-top:1px solid rgba(148,163,184,.2);
    gap:6px;
    scroll-padding-inline:4px;
  }
  .of-icon-btn{order:2;flex:0 0 auto}
  .of-nav__lang{order:3;margin-left:auto;margin-right:0}
  .of-nav__cta{order:4}
  .of-nav__a{padding:6px 8px;font-size:13px}
  .of-nav__cta.of-btn--primary{padding:8px 10px;font-size:12px;font-weight:750}
  .of-lang-dd>summary.of-lang-dd__summary{padding:6px 10px;font-size:12px;gap:6px}
  .of-article__cover{
    min-height:min(28vh, 220px);
    height:min(48vh, 440px);
    max-height:48vh;
    padding:10px 12px;
  }
  .of-article-longform__wrap{padding:16px 14px 20px}
  .of-gdetail-hero{padding:14px 12px 16px;margin-bottom:18px}
  .of-gdetail-hero__figure{max-width:min(180px,44vw)}
  .of-gdetail-quicksteps li{font-size:13px;padding:7px 10px 7px 36px}
  .of-gdetail-quicksteps li::before{left:8px;width:20px;height:20px;font-size:11px;line-height:18px}
  .of-article--longform .of-article-intro__media{
    float:none;
    width:auto;
    max-width:168px;
    margin:0 auto 14px;
  }
  .of-article-longform__lead .of-article-intro__media{margin:0 auto}
  .of-announce-list{--of-announce-gap:12px}
  .of-article-longform__lead-text > p:first-of-type{font-size:15px;line-height:1.72}
  .of-article--longform .of-article-intro__media img{border-radius:10px}
  .of-article--longform .of-article__body > p:first-of-type{font-size:15px;line-height:1.72}
  .of-article__cover--aux{
    height:160px;
    min-height:160px;
    max-height:160px;
  }
  .of-article__cover--aux img{height:100%}
  /* 与 PC 相同三列：序号 | 正文 | 按钮，避免按钮被挤到正文下方单独一行 */
  .of-guide-item{
    grid-template-columns:32px minmax(0,1fr) auto;
    gap:10px;
    padding:12px;
    align-items:start;
  }
  .of-guide-item__idx{width:28px;height:28px;font-size:12px}
  .of-guide-item__body{min-width:0}
  .of-guide-item__body h3{font-size:16px}
  .of-guide-item__action{
    justify-content:flex-end;
    align-self:start;
    padding-top:1px;
  }
  .of-guide-item__btn{
    height:30px;
    min-height:30px;
    min-width:0;
    padding:0 10px;
    font-size:12px;
  }
  .of-ft{padding:14px 0 18px}
  .of-ft__grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    column-gap:14px;
    row-gap:12px;
    align-items:start;
  }
  .of-ft__col--site{
    grid-column:1/-1;
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    column-gap:12px;
    row-gap:2px;
    padding-top:12px;
    margin-top:2px;
    border-top:1px solid rgba(148,163,184,.22);
  }
  .of-ft__col--site h3{
    grid-column:1/-1;
    margin:0 0 8px;
    font-size:11px;
    letter-spacing:.08em;
    color:#94a3b8;
    font-weight:750;
  }
  .of-ft__col--site p{margin:0 0 4px}
  .of-ft__col h3{
    font-size:11px;
    letter-spacing:.08em;
    color:#94a3b8;
    margin:0 0 8px;
    font-weight:750;
  }
  .of-ft__col p{font-size:13px;line-height:1.45;margin:0 0 4px}
  .of-ft__meta{
    grid-template-columns:1fr;
    justify-items:center;
    text-align:center;
    gap:8px;
    margin-top:12px;
    padding-top:12px;
    border-top:1px solid rgba(148,163,184,.16);
  }
  .of-ft__copy{justify-self:center;font-size:12px}
  .of-ft__beian{grid-column:1}
  .of-lang-dd__panel{
    right:auto;
    left:0;
    max-width:min(280px,calc(100vw - 24px));
  }
}

