/* ============================================================
   Google Chrome Download · Paper Aurora / Editorial Type Theme
   - White + off-white base
   - Ink black + jet sections
   - Electric magenta + cyber yellow duotone
   - Serif display (Georgia) + sans body (system-ui)
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans SC", sans-serif;
  color: #0f172a;
  background: #ffffff;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* ----- Layout ----- */
.wrap { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.sec { padding: 90px 0; }
.sec-cream { background: #fafaf9; }
.sec-jet { background: #09090b; color: #f4f4f5; }
.sec-ink { background: #0f172a; color: #f4f4f5; }
.sec-magenta { background: linear-gradient(135deg, #e11d48 0%, #be185d 100%); color: #fff; }

/* ----- Topbar / Navigation ----- */
.ed-nav {
  position: sticky; top: 0; z-index: 60;
  background: rgba(255,255,255,0.94);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid #e5e5e5;
}
.ed-nav-inner {
  max-width: 1200px; margin: 0 auto; padding: 16px 24px;
  display: flex; align-items: center; justify-content: space-between;
}
.ed-nav-brand {
  display: flex; align-items: center; gap: 11px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 22px; font-weight: 700;
  color: #0f172a; letter-spacing: -0.2px;
}
.ed-nav-brand-mark {
  width: 34px; height: 34px; border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  background: #0f172a;
  color: #facc15;
}
.ed-nav-brand-sub {
  font-family: Georgia, serif; font-size: 11px; font-weight: 400;
  color: #64748b; font-style: italic; letter-spacing: 1px;
  text-transform: uppercase;
}
.ed-nav-menu {
  display: flex; align-items: center; gap: 6px;
}
.ed-nav-link {
  padding: 10px 18px; border-radius: 999px;
  font-size: 14.5px; font-weight: 500; color: #334155;
  transition: all .2s ease;
  position: relative;
}
.ed-nav-link:hover { background: #f4f4f5; color: #0f172a; }
.ed-nav-link.current {
  background: #0f172a; color: #facc15;
  font-weight: 600;
}
.ed-nav-link.current::after {
  content: ""; position: absolute;
  right: 12px; top: 50%; width: 5px; height: 5px;
  background: #facc15; border-radius: 50%;
  transform: translateY(-50%);
}
.ed-nav-cta {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 10px 18px; border-radius: 999px;
  background: #e11d48; color: #fff; font-weight: 600; font-size: 14px;
  transition: all .2s ease;
  box-shadow: 0 6px 18px rgba(225,29,72,0.25);
  border: none; cursor: pointer;
}
.ed-nav-cta:hover { background: #be185d; transform: translateY(-1px); }
.ed-nav-mob { display: none; padding: 8px; }

/* ----- Buttons ----- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 26px; border-radius: 10px; font-weight: 600; font-size: 15px;
  transition: all .2s ease; border: 2px solid transparent; cursor: pointer;
  font-family: inherit;
}
.btn-ink { background: #0f172a; color: #fff; }
.btn-ink:hover { background: #1e293b; transform: translateY(-2px); box-shadow: 0 10px 28px rgba(15,23,42,0.25); }
.btn-magenta { background: #e11d48; color: #fff; }
.btn-magenta:hover { background: #be185d; transform: translateY(-2px); box-shadow: 0 10px 28px rgba(225,29,72,0.35); }
.btn-yellow { background: #facc15; color: #0f172a; }
.btn-yellow:hover { background: #eab308; transform: translateY(-2px); }
.btn-outline { background: transparent; color: #0f172a; border-color: #0f172a; }
.btn-outline:hover { background: #0f172a; color: #facc15; }
.btn-outline-w { background: transparent; color: #fff; border-color: rgba(255,255,255,0.5); }
.btn-outline-w:hover { background: #fff; color: #0f172a; }
.btn-white { background: #fff; color: #0f172a; }
.btn-white:hover { background: #facc15; transform: translateY(-2px); }
.btn-ghost { background: transparent; color: #0f172a; }
.btn-ghost:hover { color: #e11d48; }
.btn-lg { padding: 16px 34px; font-size: 16px; }
.btn-sm { padding: 9px 18px; font-size: 13.5px; }
.btn-full { width: 100%; }

/* ----- Section Headers ----- */
.sec-head { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.sec-head.left { text-align: left; margin-left: 0; }
.sec-tape {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 16px; background: #facc15; color: #0f172a;
  font-size: 11.5px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; margin-bottom: 20px;
  transform: rotate(-1deg);
  box-shadow: 0 3px 10px rgba(250,204,21,0.3);
}
.sec-tape.magenta { background: #e11d48; color: #fff; box-shadow: 0 3px 10px rgba(225,29,72,0.3); }
.sec-tape.ink { background: #0f172a; color: #facc15; box-shadow: 0 3px 10px rgba(15,23,42,0.2); }
.sec-tape.white { background: #fff; color: #0f172a; }
.sec-tape-dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.sec-title {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(32px, 4vw, 44px);
  font-weight: 700; line-height: 1.2; color: #0f172a;
  margin: 0 0 18px; letter-spacing: -0.8px;
}
.sec-title.light { color: #ffffff; }
.sec-title .u { display: inline-block; border-bottom: 4px solid #facc15; padding: 0 3px; }
.sec-title .u-m { display: inline-block; border-bottom: 4px solid #e11d48; padding: 0 3px; }
.sec-sub {
  font-size: 17px; color: #64748b; line-height: 1.7; margin: 0;
}
.sec-sub.light { color: #cbd5e1; }

/* ----- Hero ----- */
.hero {
  position: relative;
  padding: 80px 0 110px;
  background: #ffffff;
  overflow: hidden;
}
.hero::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 15%, rgba(250,204,21,0.10), transparent 50%),
    radial-gradient(circle at 85% 80%, rgba(225,29,72,0.08), transparent 55%);
  pointer-events: none;
}
.hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1.15fr 1fr; gap: 60px; align-items: center; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 16px; border-radius: 999px;
  background: #fef3c7; color: #b45309;
  font-size: 12.5px; font-weight: 600;
  letter-spacing: 0.5px; text-transform: uppercase;
  margin-bottom: 24px;
}
.hero-eyebrow-dot { width: 6px; height: 6px; border-radius: 50%; background: #f59e0b; animation: pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.5; transform: scale(1.3); } }
.hero-h1 {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(40px, 5.2vw, 62px);
  font-weight: 700; line-height: 1.08; letter-spacing: -1.5px;
  color: #0f172a; margin: 0 0 24px;
}
.hero-h1 .accent-m { color: #e11d48; font-style: italic; }
.hero-h1 .accent-y {
  background: linear-gradient(120deg, transparent 0 3%, #facc15 3% 97%, transparent 97%);
  background-size: 100% 38%;
  background-repeat: no-repeat;
  background-position: 0 82%;
  padding: 0 4px;
}
.hero-lead {
  font-size: 19px; color: #475569; line-height: 1.7;
  margin: 0 0 36px; max-width: 560px;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.hero-meta {
  margin-top: 32px;
  display: flex; flex-wrap: wrap; gap: 28px; align-items: center;
  padding-top: 26px; border-top: 1px solid #e5e5e5;
}
.hero-meta-item { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: #475569; }
.hero-meta-ico { color: #0d9488; display: inline-flex; }

/* Hero visual — editorial "magazine cover" card stack */
.hero-visual { position: relative; height: 520px; }
.hero-cover {
  position: absolute; left: 50%; top: 50%; width: 340px; height: 460px;
  transform: translate(-50%, -50%) rotate(-3deg);
  background: #ffffff;
  border: 1px solid #e5e5e5;
  border-radius: 4px;
  box-shadow: 0 30px 60px rgba(15,23,42,0.15);
  padding: 28px 26px;
  display: flex; flex-direction: column; justify-content: space-between;
  overflow: hidden;
}
.hero-cover::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 6px;
  background: linear-gradient(90deg, #e11d48 0%, #facc15 50%, #0d9488 100%);
}
.hc-issue {
  font-family: Georgia, serif; font-size: 11px; color: #94a3b8;
  letter-spacing: 3px; text-transform: uppercase;
  display: flex; justify-content: space-between;
}
.hc-title {
  font-family: Georgia, serif; font-size: 48px; font-weight: 700;
  line-height: 1; color: #0f172a;
  margin: 28px 0 8px;
}
.hc-title-sub { font-family: Georgia, serif; font-size: 28px; font-style: italic; color: #e11d48; line-height: 1; }
.hc-divider { height: 2px; background: #0f172a; margin: 18px 0; }
.hc-lead-lines { display: flex; flex-direction: column; gap: 9px; }
.hc-lead-line { height: 7px; border-radius: 2px; background: #e5e5e5; }
.hc-lead-line.w-80 { width: 80%; } .hc-lead-line.w-95 { width: 95%; } .hc-lead-line.w-70 { width: 70%; }
.hc-lead-line.w-60 { width: 60%; } .hc-lead-line.w-85 { width: 85%; }
.hc-chart {
  margin-top: 22px; padding-top: 18px; border-top: 1px dashed #cbd5e1;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
}
.hc-chart-bar {
  height: 60px; border-radius: 2px;
  background: linear-gradient(to top, #0f172a var(--h, 60%), #f4f4f5 var(--h, 60%));
  position: relative;
}
.hc-chart-lbl { font-size: 9px; color: #94a3b8; text-align: center; margin-top: 4px; letter-spacing: 0.5px; }
.hc-foot { display: flex; justify-content: space-between; align-items: center; font-size: 10px; color: #94a3b8; letter-spacing: 1.5px; text-transform: uppercase; }
.hc-foot-swatch { display: flex; gap: 6px; }
.hc-swatch { width: 12px; height: 12px; border-radius: 2px; }

/* Hero cover secondary (decorative) */
.hero-card-b {
  position: absolute; right: 0; top: 50%;
  width: 200px; background: #0f172a; color: #facc15;
  padding: 22px 22px; border-radius: 12px;
  transform: translate(10%, -30%) rotate(4deg);
  box-shadow: 0 18px 44px rgba(15,23,42,0.3);
  z-index: 2;
}
.hero-card-b-label { font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; opacity: 0.7; }
.hero-card-b-val { font-family: Georgia, serif; font-size: 38px; font-weight: 700; line-height: 1; margin: 8px 0 4px; color: #facc15; }
.hero-card-b-sub { font-size: 12px; opacity: 0.8; }

.hero-card-c {
  position: absolute; left: -10px; bottom: 20px;
  width: 200px; background: #e11d48; color: #fff;
  padding: 20px 22px; border-radius: 12px;
  transform: rotate(-5deg);
  box-shadow: 0 18px 44px rgba(225,29,72,0.3);
  z-index: 3;
}
.hero-card-c-ico { width: 34px; height: 34px; border-radius: 8px; background: rgba(255,255,255,0.2); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 10px; }
.hero-card-c-title { font-family: Georgia, serif; font-size: 18px; font-weight: 700; line-height: 1.2; margin: 0 0 4px; }
.hero-card-c-sub { font-size: 11.5px; opacity: 0.9; }

/* ----- Marquee Ticker ----- */
.marquee-bar {
  background: #0f172a; color: #f4f4f5;
  padding: 14px 0; overflow: hidden; position: relative;
  border-top: 2px solid #facc15;
  border-bottom: 2px solid #facc15;
}
.marquee-track {
  display: flex; gap: 60px;
  animation: marquee 40s linear infinite;
  white-space: nowrap;
}
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.marquee-item {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: Georgia, serif; font-size: 16px;
  letter-spacing: 0.5px;
}
.marquee-sep {
  width: 6px; height: 6px; border-radius: 50%;
  background: #facc15; flex-shrink: 0;
}

/* ----- Stats Ribbon ----- */
.stats-ribbon {
  background: #fff;
  padding: 48px 0;
  border-bottom: 1px solid #e5e5e5;
}
.stats-row {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px;
}
.stat-item { text-align: center; padding: 0 14px; border-right: 1px solid #e5e5e5; }
.stat-item:last-child { border-right: none; }
.stat-num {
  font-family: Georgia, serif; font-size: clamp(32px, 3.5vw, 44px); font-weight: 700;
  line-height: 1; margin-bottom: 10px; color: #0f172a; letter-spacing: -1px;
}
.stat-num.m { color: #e11d48; }
.stat-num.y {
  background: linear-gradient(120deg, transparent 0 10%, #facc15 10% 90%, transparent 90%);
  background-size: 100% 42%; background-repeat: no-repeat; background-position: 0 72%;
  padding: 0 6px;
}
.stat-num.t { color: #0d9488; }
.stat-lbl { font-size: 13.5px; color: #64748b; font-weight: 500; letter-spacing: 0.3px; text-transform: uppercase; }

/* ----- Feature Editorial Grid (8 cards with mixed layout) ----- */
.feat-edit-grid {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 20px;
}
.feat-card {
  grid-column: span 3;
  background: #ffffff; border: 1.5px solid #e5e5e5;
  padding: 30px 26px; border-radius: 4px;
  transition: all .3s ease;
  position: relative; overflow: hidden;
}
.feat-card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--fb, #e11d48);
  transform: scaleX(0); transform-origin: left;
  transition: transform .35s ease;
}
.feat-card:hover::before, .feat-card.hover::before { transform: scaleX(1); }
.feat-card:hover { border-color: #0f172a; transform: translateY(-4px); box-shadow: 0 18px 38px rgba(15,23,42,0.08); }
.feat-card.wide { grid-column: span 6; }
.feat-card.span4 { grid-column: span 4; }
.feat-card.tall { grid-row: span 2; }
.fc-m { --fb: #e11d48; }
.fc-y { --fb: #facc15; }
.fc-t { --fb: #0d9488; }
.fc-i { --fb: #0f172a; }
.fc-v { --fb: #7c3aed; }
.fc-o { --fb: #f97316; }
.fc-s { --fb: #0284c7; }
.fc-r { --fb: #fb7185; }
.feat-num {
  font-family: Georgia, serif; font-size: 13px; color: #94a3b8;
  letter-spacing: 2px; text-transform: uppercase; margin-bottom: 14px;
}
.feat-ico {
  width: 48px; height: 48px; border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
  color: var(--fb, #e11d48);
  background: color-mix(in srgb, var(--fb, #e11d48) 10%, white);
}
.feat-name {
  font-family: Georgia, serif; font-size: 20px; font-weight: 700;
  color: #0f172a; margin: 0 0 10px; line-height: 1.3;
}
.feat-desc { font-size: 14px; color: #64748b; line-height: 1.7; margin: 0; }
.feat-card.wide .feat-name { font-size: 24px; }
.feat-card.wide .feat-desc { font-size: 15px; }
.feat-tags { margin-top: 16px; display: flex; flex-wrap: wrap; gap: 6px; }
.feat-tag {
  padding: 4px 10px; border-radius: 999px;
  background: #f4f4f5; color: #475569; font-size: 11.5px; font-weight: 500;
}

/* ----- Platforms Section (editorial strip) ----- */
.plat-strip {
  display: grid; grid-template-columns: 1.2fr 1fr 1fr 1fr; gap: 0;
  background: #0f172a; border-radius: 6px; overflow: hidden;
}
.plat-tile {
  padding: 36px 30px;
  border-right: 1px solid #1e293b;
  transition: background .3s ease;
  position: relative;
}
.plat-tile:last-child { border-right: none; }
.plat-tile:hover { background: #1e293b; }
.plat-tile.main { background: #e11d48; color: #fff; }
.plat-tile.main:hover { background: #be185d; }
.plat-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px; background: #facc15; color: #0f172a;
  border-radius: 999px; font-size: 10.5px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  margin-bottom: 16px;
}
.plat-ico {
  width: 54px; height: 54px; border-radius: 12px;
  background: rgba(255,255,255,0.1);
  display: inline-flex; align-items: center; justify-content: center;
  color: #facc15;
  margin-bottom: 20px;
}
.plat-tile.main .plat-ico { background: rgba(255,255,255,0.15); color: #fff; }
.plat-name {
  font-family: Georgia, serif; font-size: 22px; font-weight: 700;
  color: #fff; margin: 0 0 6px;
}
.plat-ver { font-size: 13px; color: rgba(255,255,255,0.65); margin-bottom: 18px; }
.plat-tile.main .plat-ver { color: rgba(255,255,255,0.85); }
.plat-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 18px; border-radius: 8px;
  background: #facc15; color: #0f172a; font-weight: 600; font-size: 13.5px;
  border: none; cursor: pointer; transition: all .2s ease;
}
.plat-btn:hover { background: #fff; transform: translateY(-2px); }
.plat-tile.main .plat-btn { background: #fff; color: #e11d48; }
.plat-tile.main .plat-btn:hover { background: #facc15; color: #0f172a; }
.plat-hint { margin-top: 12px; font-size: 12px; color: rgba(255,255,255,0.5); }
.plat-tile.main .plat-hint { color: rgba(255,255,255,0.75); }

/* ----- Spotlight Rows (alternating column layout) ----- */
.spot-row {
  display: grid; grid-template-columns: 1fr 1.1fr; gap: 70px; align-items: center;
  padding: 60px 0; border-bottom: 1px solid #e5e5e5;
}
.spot-row:last-child { border-bottom: none; }
.spot-row.flip { grid-template-columns: 1.1fr 1fr; }
.spot-row.flip .spot-info { order: 2; }
.spot-row.flip .spot-visual { order: 1; }
.spot-num {
  font-family: Georgia, serif; font-size: 68px; font-weight: 700;
  line-height: 1; color: #f4f4f5; margin-bottom: 10px;
  letter-spacing: -2px;
}
.spot-num.m { color: rgba(225,29,72,0.12); }
.spot-num.y { color: rgba(250,204,21,0.3); }
.spot-num.t { color: rgba(13,148,136,0.12); }
.spot-num.v { color: rgba(124,58,237,0.12); }
.spot-chip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 13px; border-radius: 999px;
  font-size: 11.5px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  margin-bottom: 18px;
}
.spot-chip.m { background: #fef2f4; color: #e11d48; }
.spot-chip.y { background: #fef3c7; color: #b45309; }
.spot-chip.t { background: #ccfbf1; color: #0d9488; }
.spot-chip.v { background: #ede9fe; color: #7c3aed; }
.spot-chip-dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.spot-title {
  font-family: Georgia, serif; font-size: clamp(28px, 3.3vw, 38px); font-weight: 700;
  line-height: 1.2; color: #0f172a; margin: 0 0 18px; letter-spacing: -0.6px;
}
.spot-desc { font-size: 16px; color: #475569; line-height: 1.8; margin: 0 0 24px; }
.spot-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.spot-list li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 14.5px; color: #334155; line-height: 1.6;
}
.spot-list li strong { display: block; color: #0f172a; font-weight: 700; margin-bottom: 3px; }
.spot-check {
  flex-shrink: 0; width: 22px; height: 22px; border-radius: 6px;
  background: #0f172a; color: #facc15;
  display: inline-flex; align-items: center; justify-content: center;
  margin-top: 2px;
}
.spot-check.m { background: #e11d48; color: #fff; }
.spot-check.y { background: #facc15; color: #0f172a; }
.spot-check.t { background: #0d9488; color: #fff; }
.spot-check.v { background: #7c3aed; color: #fff; }

/* Spot visual (data panel) */
.spot-visual {
  position: relative;
  background: #fafaf9;
  border-radius: 14px;
  padding: 32px;
  border: 1px solid #e5e5e5;
}
.sv-head {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 16px; border-bottom: 1px solid #e5e5e5; margin-bottom: 22px;
}
.sv-head-title { font-family: Georgia, serif; font-size: 15px; font-weight: 700; color: #0f172a; }
.sv-head-tag {
  font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase;
  padding: 3px 10px; border-radius: 999px;
  background: #0f172a; color: #facc15; font-weight: 600;
}
.sv-bars { display: flex; flex-direction: column; gap: 16px; }
.sv-bar-row { display: flex; align-items: center; gap: 14px; }
.sv-bar-lbl { flex-basis: 120px; font-size: 13px; color: #475569; font-weight: 500; }
.sv-bar-track { flex: 1; height: 10px; background: #e5e5e5; border-radius: 999px; overflow: hidden; }
.sv-bar-fill { height: 100%; border-radius: 999px; }
.sv-bar-fill.m { background: linear-gradient(90deg, #e11d48, #f43f5e); }
.sv-bar-fill.y { background: linear-gradient(90deg, #facc15, #eab308); }
.sv-bar-fill.t { background: linear-gradient(90deg, #0d9488, #14b8a6); }
.sv-bar-fill.v { background: linear-gradient(90deg, #7c3aed, #a78bfa); }
.sv-bar-fill.i { background: linear-gradient(90deg, #0f172a, #334155); }
.sv-bar-val { flex-basis: 55px; text-align: right; font-family: Georgia, serif; font-size: 15px; font-weight: 700; color: #0f172a; }
.sv-stats { margin-top: 24px; padding-top: 20px; border-top: 1px solid #e5e5e5; display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.sv-stat { text-align: center; }
.sv-stat-num { font-family: Georgia, serif; font-size: 24px; font-weight: 700; color: #0f172a; line-height: 1; }
.sv-stat-num.m { color: #e11d48; }
.sv-stat-num.y { color: #eab308; }
.sv-stat-num.t { color: #0d9488; }
.sv-stat-num.v { color: #7c3aed; }
.sv-stat-lbl { font-size: 11px; color: #64748b; margin-top: 6px; letter-spacing: 0.5px; text-transform: uppercase; }

.sv-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
.sv-chip {
  padding: 5px 12px; border-radius: 6px;
  background: #fff; border: 1px solid #e5e5e5;
  font-size: 12px; color: #334155; font-weight: 500;
}
.sv-chip.on { background: #0f172a; color: #facc15; border-color: #0f172a; }
.sv-chip.m { background: #fef2f4; color: #e11d48; border-color: #fce7ec; }

/* ----- Reviews Grid ----- */
.rev-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.rev-card {
  background: #fff; border: 1.5px solid #e5e5e5;
  padding: 28px 26px; border-radius: 4px;
  transition: all .3s ease;
  position: relative;
}
.rev-card::before {
  content: "\201C"; position: absolute; top: -10px; right: 20px;
  font-family: Georgia, serif; font-size: 80px; line-height: 1;
  color: #facc15;
}
.rev-card:hover { border-color: #0f172a; transform: translateY(-3px); }
.rev-stars { display: inline-flex; gap: 2px; margin-bottom: 14px; color: #eab308; }
.rev-text {
  font-family: Georgia, serif; font-size: 16px; color: #1e293b;
  line-height: 1.7; margin: 0 0 22px; font-style: italic;
}
.rev-footer { display: flex; align-items: center; gap: 12px; padding-top: 18px; border-top: 1px solid #f4f4f5; }
.rev-avatar {
  width: 42px; height: 42px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: Georgia, serif; font-weight: 700; font-size: 17px; color: #fff;
  flex-shrink: 0;
}
.av-m { background: linear-gradient(135deg, #e11d48, #be185d); }
.av-y { background: linear-gradient(135deg, #facc15, #ca8a04); color: #0f172a; }
.av-t { background: linear-gradient(135deg, #0d9488, #0f766e); }
.av-v { background: linear-gradient(135deg, #7c3aed, #6d28d9); }
.av-o { background: linear-gradient(135deg, #f97316, #c2410c); }
.av-s { background: linear-gradient(135deg, #0284c7, #075985); }
.rev-name { font-weight: 700; color: #0f172a; font-size: 14.5px; }
.rev-role { font-size: 12.5px; color: #64748b; margin-top: 2px; }

/* ----- Comparison Table ----- */
.cmp-wrap {
  background: #fff; border: 1.5px solid #e5e5e5;
  border-radius: 6px; overflow: hidden;
}
.cmp-table { width: 100%; border-collapse: collapse; }
.cmp-table thead { background: #0f172a; color: #facc15; }
.cmp-table th {
  padding: 18px 16px; text-align: center; font-weight: 700; font-size: 14px;
  font-family: Georgia, serif; letter-spacing: 0.3px;
  border-right: 1px solid #1e293b;
}
.cmp-table th:last-child { border-right: none; }
.cmp-table th:first-child { text-align: left; padding-left: 24px; color: #fff; }
.cmp-table .hl { background: #e11d48; color: #fff; position: relative; }
.cmp-table .hl::before {
  content: "Chrome"; display: block; font-size: 10px; letter-spacing: 2px;
  text-transform: uppercase; font-weight: 500; opacity: 0.85;
}
.cmp-table td {
  padding: 16px; text-align: center; font-size: 14px; color: #334155;
  border-bottom: 1px solid #f4f4f5; border-right: 1px solid #f4f4f5;
}
.cmp-table td:last-child { border-right: none; }
.cmp-table td:first-child {
  text-align: left; padding-left: 24px; font-weight: 600; color: #0f172a;
}
.cmp-table tr:last-child td { border-bottom: none; }
.cmp-table tr:nth-child(even) { background: #fafaf9; }
.cmp-hl-col { background: #fef2f4 !important; color: #0f172a; font-weight: 600; }
.yes { color: #0d9488; font-weight: 700; }
.no { color: #94a3b8; }
.part { color: #b45309; font-weight: 600; }

/* ----- FAQ Accordion (2-column grid) ----- */
.faq-wrap { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.faq-item {
  background: #fff; border: 1.5px solid #e5e5e5;
  border-radius: 4px; overflow: hidden;
  transition: all .2s ease;
}
.faq-item.open { border-color: #0f172a; box-shadow: 0 12px 28px rgba(15,23,42,0.08); }
.faq-q {
  padding: 22px 24px; width: 100%;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  font-family: Georgia, serif; font-size: 16px; font-weight: 700; text-align: left;
  color: #0f172a; cursor: pointer; background: transparent; border: none;
}
.faq-chevron {
  flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%;
  background: #f4f4f5; color: #0f172a;
  display: inline-flex; align-items: center; justify-content: center;
  transition: all .3s ease;
}
.faq-item.open .faq-chevron { transform: rotate(180deg); background: #facc15; }
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height .35s ease;
}
.faq-item.open .faq-a { max-height: 600px; }
.faq-a-inner {
  padding: 4px 24px 22px;
  color: #475569; font-size: 14.5px; line-height: 1.75;
  border-top: 1px dashed #e5e5e5; padding-top: 18px;
}
.faq-a-inner p { margin: 0 0 10px; }
.faq-a-inner p:last-child { margin-bottom: 0; }

/* ----- CTA Banner ----- */
.cta-block {
  background: #0f172a; color: #fff;
  padding: 72px 50px; border-radius: 14px;
  position: relative; overflow: hidden;
  text-align: center;
}
.cta-block::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 15% 20%, rgba(250,204,21,0.15), transparent 40%),
    radial-gradient(circle at 85% 80%, rgba(225,29,72,0.18), transparent 45%);
}
.cta-block > * { position: relative; z-index: 2; }
.cta-tape {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px; background: #facc15; color: #0f172a;
  font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  margin-bottom: 20px;
}
.cta-h2 {
  font-family: Georgia, serif; font-size: clamp(30px, 3.5vw, 40px);
  font-weight: 700; line-height: 1.2; margin: 0 0 16px; letter-spacing: -0.6px;
}
.cta-h2 .y {
  background: linear-gradient(120deg, transparent 0 10%, #facc15 10% 90%, transparent 90%);
  background-size: 100% 45%; background-repeat: no-repeat; background-position: 0 72%;
  padding: 0 6px; color: #0f172a;
}
.cta-p { font-size: 17px; color: #cbd5e1; margin: 0 auto 32px; max-width: 620px; line-height: 1.7; }
.cta-btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ==================== DOWNLOAD PAGE ==================== */

.dl-hero {
  padding: 70px 0 80px; background: #fafaf9;
  border-bottom: 1px solid #e5e5e5;
}
.dl-hero-inner { max-width: 860px; margin: 0 auto; text-align: center; }
.dl-hero-tape {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 16px; background: #e11d48; color: #fff;
  font-size: 11.5px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  margin-bottom: 22px;
  transform: rotate(-1deg);
}
.dl-hero-title {
  font-family: Georgia, serif; font-size: clamp(36px, 4.5vw, 54px);
  font-weight: 700; line-height: 1.1; color: #0f172a; margin: 0 0 18px;
  letter-spacing: -1px;
}
.dl-hero-title .y {
  background: linear-gradient(120deg, transparent 0 3%, #facc15 3% 97%, transparent 97%);
  background-size: 100% 42%; background-repeat: no-repeat; background-position: 0 80%;
  padding: 0 4px;
}
.dl-hero-sub { font-size: 18px; color: #475569; line-height: 1.7; margin: 0 0 30px; }
.dl-hero-meta {
  display: flex; justify-content: center; flex-wrap: wrap; gap: 28px;
  font-size: 14px; color: #475569;
}
.dl-hero-meta-item { display: flex; align-items: center; gap: 8px; }
.dl-hero-meta-ico { color: #0d9488; }

/* Windows main card */
.dl-win-wrap { max-width: 820px; margin: 0 auto; }
.dl-win-card {
  background: #ffffff; border: 2px solid #0f172a;
  border-radius: 8px; overflow: hidden;
  box-shadow: 0 30px 70px rgba(15,23,42,0.1);
  position: relative;
}
.dl-win-top {
  height: 8px;
  background: linear-gradient(90deg, #e11d48 0%, #facc15 50%, #0d9488 100%);
}
.dl-win-body { padding: 40px; }
.dl-win-head { display: flex; gap: 22px; align-items: center; margin-bottom: 32px; padding-bottom: 26px; border-bottom: 1px dashed #e5e5e5; }
.dl-win-ico {
  width: 74px; height: 74px; border-radius: 14px;
  background: #0f172a; color: #facc15;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.dl-win-info { flex: 1; }
.dl-win-name { font-family: Georgia, serif; font-size: 26px; font-weight: 700; color: #0f172a; margin: 0 0 6px; }
.dl-win-meta { font-size: 13.5px; color: #64748b; }
.dl-win-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 11px; background: #fef3c7; color: #b45309;
  border-radius: 999px; font-size: 11.5px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  margin-bottom: 8px;
}
.dl-specs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 28px; }
.dl-spec { padding: 16px 18px; background: #fafaf9; border-radius: 8px; }
.dl-spec-lbl { font-size: 11.5px; color: #64748b; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 7px; font-weight: 600; }
.dl-spec-val { font-family: Georgia, serif; font-size: 17px; font-weight: 700; color: #0f172a; }
.dl-sec-note {
  display: flex; gap: 14px; align-items: flex-start;
  padding: 16px 18px; background: #ccfbf1; border-radius: 8px; margin-bottom: 24px;
  border-left: 3px solid #0d9488;
}
.dl-sec-ico { color: #0d9488; flex-shrink: 0; }
.dl-sec-text { font-size: 13.5px; color: #115e59; line-height: 1.6; }
.dl-sec-text strong { color: #0f766e; font-weight: 700; }
.dl-win-btns { display: flex; gap: 12px; flex-wrap: wrap; }

/* Other platform cards */
.op-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.op-card {
  background: #fff; border: 1.5px solid #e5e5e5;
  padding: 30px 26px; border-radius: 8px;
  transition: all .3s ease;
}
.op-card:hover { border-color: #0f172a; transform: translateY(-3px); box-shadow: 0 18px 38px rgba(15,23,42,0.08); }
.op-head { display: flex; gap: 14px; align-items: center; margin-bottom: 20px; padding-bottom: 18px; border-bottom: 1px dashed #e5e5e5; }
.op-ico {
  width: 54px; height: 54px; border-radius: 12px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: #fff;
}
.op-ico.mac { background: #0f172a; color: #facc15; }
.op-ico.ios { background: #e11d48; }
.op-ico.and { background: #0d9488; }
.op-info { flex: 1; }
.op-name { font-family: Georgia, serif; font-size: 20px; font-weight: 700; color: #0f172a; margin: 0 0 3px; }
.op-ver { font-size: 12.5px; color: #64748b; }
.op-steps { list-style: none; padding: 0; margin: 0 0 20px; display: flex; flex-direction: column; gap: 10px; }
.op-steps li { display: flex; align-items: flex-start; gap: 10px; font-size: 13.5px; color: #334155; line-height: 1.6; }
.op-step-num {
  flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%;
  background: #fef2f4; color: #e11d48;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11.5px; font-weight: 700; margin-top: 1px;
}

/* Install guide (2-column) */
.guide-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.guide-col {
  background: #fafaf9; border: 1.5px solid #e5e5e5;
  padding: 34px 30px; border-radius: 8px;
}
.guide-col-head { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; padding-bottom: 18px; border-bottom: 2px solid #0f172a; }
.guide-col-dot { width: 12px; height: 12px; border-radius: 50%; }
.guide-col-dot.m { background: #e11d48; }
.guide-col-dot.y { background: #facc15; }
.guide-col-title { font-family: Georgia, serif; font-size: 20px; font-weight: 700; color: #0f172a; margin: 0; }
.guide-col-tag { margin-left: auto; font-size: 11.5px; padding: 3px 10px; border-radius: 999px; background: #0f172a; color: #facc15; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
.guide-steps { display: flex; flex-direction: column; gap: 16px; }
.gstep { display: flex; gap: 14px; align-items: flex-start; }
.gstep-num {
  flex-shrink: 0; width: 34px; height: 34px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: Georgia, serif; font-weight: 700; font-size: 15px;
}
.gn-m { background: #e11d48; color: #fff; }
.gn-y { background: #facc15; color: #0f172a; }
.gstep-body { flex: 1; }
.gstep-title { font-family: Georgia, serif; font-size: 15.5px; font-weight: 700; color: #0f172a; margin: 0 0 4px; }
.gstep-desc { font-size: 13.5px; color: #64748b; line-height: 1.7; margin: 0; }

/* Requirements grid */
.req-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.req-card {
  background: #fff; border: 1.5px solid #e5e5e5;
  padding: 26px 22px; border-radius: 8px;
  text-align: center; transition: all .25s ease;
}
.req-card:hover { border-color: #0f172a; transform: translateY(-2px); }
.req-ico {
  width: 46px; height: 46px; border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  margin: 0 auto 14px;
  color: #e11d48; background: #fef2f4;
}
.req-title { font-family: Georgia, serif; font-size: 15px; font-weight: 700; color: #0f172a; margin: 0 0 8px; }
.req-val { font-size: 13.5px; color: #475569; line-height: 1.6; }

/* Version timeline */
.ver-list { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; }
.ver-item { display: flex; gap: 20px; }
.ver-dot-col { display: flex; flex-direction: column; align-items: center; flex-shrink: 0; width: 40px; }
.ver-dot {
  width: 14px; height: 14px; border-radius: 50%;
  border: 3px solid #fff; box-shadow: 0 0 0 2px #0f172a;
  margin-top: 8px;
}
.vd-m { background: #e11d48; }
.vd-y { background: #facc15; }
.vd-t { background: #0d9488; }
.vd-v { background: #7c3aed; }
.vd-o { background: #f97316; }
.ver-line { flex: 1; width: 2px; background: #e5e5e5; margin-top: 4px; }
.ver-item:last-child .ver-line { display: none; }
.ver-body {
  flex: 1; padding: 0 0 36px;
}
.ver-head { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 10px; }
.ver-num { font-family: Georgia, serif; font-size: 20px; font-weight: 700; color: #0f172a; }
.ver-tag { padding: 3px 10px; border-radius: 999px; font-size: 10.5px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
.vt-stable { background: #ccfbf1; color: #0d9488; }
.vt-lts { background: #ede9fe; color: #7c3aed; }
.vt-beta { background: #fef3c7; color: #b45309; }
.ver-date { font-size: 13px; color: #64748b; }
.ver-desc { font-size: 14.5px; color: #475569; line-height: 1.75; margin: 0; }

/* Security banner */
.sec-banner {
  background: #0f172a; color: #fff;
  padding: 36px 40px; border-radius: 12px;
  display: flex; gap: 22px; align-items: center;
  position: relative; overflow: hidden;
}
.sec-banner::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 6px;
  background: linear-gradient(to bottom, #e11d48, #facc15, #0d9488);
}
.sec-banner-ico {
  width: 62px; height: 62px; border-radius: 14px;
  background: rgba(250,204,21,0.15); color: #facc15;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.sec-banner-body { flex: 1; }
.sec-banner-title { font-family: Georgia, serif; font-size: 20px; font-weight: 700; margin: 0 0 6px; }
.sec-banner-desc { font-size: 14px; color: #cbd5e1; line-height: 1.7; margin: 0; }

/* ==================== ARTICLE PAGE (zh-cn) ==================== */

.art-hero {
  padding: 60px 0 70px; background: #fafaf9;
  border-bottom: 1px solid #e5e5e5;
  position: relative; overflow: hidden;
}
.art-hero::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, #e11d48, #facc15, #0d9488);
}
.art-hero-inner { max-width: 880px; }
.art-hero-crumb {
  display: flex; gap: 8px; align-items: center; font-size: 13px; color: #64748b;
  margin-bottom: 18px;
}
.art-hero-crumb a:hover { color: #e11d48; }
.art-hero-crumb-sep { opacity: 0.5; }
.art-hero-title {
  font-family: Georgia, serif; font-size: clamp(32px, 4vw, 46px);
  font-weight: 700; line-height: 1.15; letter-spacing: -0.8px;
  color: #0f172a; margin: 0 0 16px;
}
.art-hero-title .m { color: #e11d48; font-style: italic; }
.art-hero-title .y {
  background: linear-gradient(120deg, transparent 0 5%, #facc15 5% 95%, transparent 95%);
  background-size: 100% 45%; background-repeat: no-repeat; background-position: 0 80%;
  padding: 0 4px;
}
.art-hero-sub { font-size: 17px; color: #475569; line-height: 1.7; margin: 0 0 24px; max-width: 720px; }
.art-hero-meta { display: flex; gap: 24px; flex-wrap: wrap; font-size: 13.5px; color: #64748b; padding-top: 20px; border-top: 1px dashed #cbd5e1; }

/* Keyword strip */
.kw-bar {
  background: #ffffff; padding: 26px 0; border-bottom: 1px solid #e5e5e5;
}
.kw-strip { display: flex; flex-wrap: wrap; gap: 10px; }
.kw {
  padding: 6px 14px; border-radius: 999px;
  background: #fafaf9; border: 1px solid #e5e5e5;
  font-size: 13px; color: #475569; font-weight: 500;
  transition: all .2s ease; cursor: default;
}
.kw:hover { background: #0f172a; color: #facc15; border-color: #0f172a; }

/* Article Layout */
.art-layout {
  display: grid; grid-template-columns: minmax(0, 1fr) 300px; gap: 50px;
  max-width: 1200px; margin: 0 auto; padding: 70px 24px;
}
.art-body { min-width: 0; }
.art-sec { margin-bottom: 48px; padding-bottom: 30px; border-bottom: 1px dashed #e5e5e5; }
.art-sec:last-child { border-bottom: none; }
.art-sec-tag {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 11.5px; font-weight: 700; color: #e11d48;
  letter-spacing: 2px; text-transform: uppercase; margin-bottom: 14px;
}
.art-sec-tag-num {
  font-family: Georgia, serif; font-size: 14px; font-weight: 700;
  color: #0f172a;
}
.art-sec-title {
  font-family: Georgia, serif; font-size: 28px; font-weight: 700;
  line-height: 1.3; color: #0f172a; margin: 0 0 18px; letter-spacing: -0.4px;
}
.art-body p {
  font-size: 15.5px; color: #334155; line-height: 1.9; margin: 0 0 16px;
}
.art-body p strong { color: #0f172a; font-weight: 700; background: linear-gradient(120deg, transparent 0 3%, rgba(250,204,21,0.4) 3% 97%, transparent 97%); background-size: 100% 45%; background-repeat: no-repeat; background-position: 0 80%; padding: 0 2px; }
.art-body p em { color: #e11d48; font-style: italic; font-weight: 600; }
.art-body ul { padding-left: 22px; margin: 0 0 16px; }
.art-body ul li { font-size: 15.5px; color: #334155; line-height: 1.9; margin-bottom: 8px; }
.art-body ul li::marker { color: #e11d48; }

/* Article comparison table */
.art-cmp { margin: 20px 0; border-radius: 6px; overflow: hidden; border: 1px solid #e5e5e5; }
.art-cmp-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.art-cmp-table thead { background: #0f172a; color: #facc15; }
.art-cmp-table th { padding: 14px 12px; text-align: left; font-family: Georgia, serif; font-weight: 700; font-size: 13.5px; border-right: 1px solid #1e293b; }
.art-cmp-table th:last-child { border-right: none; }
.art-cmp-table td { padding: 12px; color: #334155; border-bottom: 1px solid #f4f4f5; border-right: 1px solid #f4f4f5; }
.art-cmp-table td:last-child { border-right: none; }
.art-cmp-table td:first-child { color: #0f172a; font-weight: 600; background: #fafaf9; }
.art-cmp-table .hl { background: #fef2f4; color: #0f172a; font-weight: 700; }

/* Tips grid */
.tips-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin: 20px 0; }
.tip-card {
  background: #fafaf9; border: 1.5px solid #e5e5e5;
  padding: 22px 20px; border-radius: 6px;
  display: flex; gap: 14px; align-items: flex-start;
}
.tip-num {
  flex-shrink: 0;
  font-family: Georgia, serif; font-size: 28px; font-weight: 700;
  color: #e11d48; line-height: 1; width: 40px;
}
.tip-body { flex: 1; }
.tip-title { font-family: Georgia, serif; font-size: 15.5px; font-weight: 700; color: #0f172a; margin: 0 0 6px; }
.tip-desc { font-size: 13.5px; color: #475569; line-height: 1.7; margin: 0; }

/* Inline CTA */
.inline-cta {
  margin: 28px 0; padding: 26px 28px; border-radius: 8px;
  display: flex; gap: 18px; align-items: center;
  color: #fff; position: relative; overflow: hidden;
}
.ic-m { background: linear-gradient(135deg, #e11d48, #be185d); }
.ic-y { background: linear-gradient(135deg, #facc15, #ca8a04); color: #0f172a; }
.ic-t { background: linear-gradient(135deg, #0d9488, #0f766e); }
.ic-i { background: #0f172a; }
.inline-cta-ico {
  flex-shrink: 0; width: 52px; height: 52px; border-radius: 12px;
  background: rgba(255,255,255,0.2); display: inline-flex; align-items: center; justify-content: center;
}
.ic-y .inline-cta-ico { background: rgba(15,23,42,0.15); }
.inline-cta-body { flex: 1; }
.inline-cta-title { font-family: Georgia, serif; font-size: 17px; font-weight: 700; margin: 0 0 4px; }
.inline-cta-desc { font-size: 13.5px; opacity: 0.9; margin: 0; line-height: 1.6; }
.inline-cta-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 20px; border-radius: 8px;
  background: #fff; color: #0f172a;
  font-weight: 700; font-size: 13.5px; flex-shrink: 0;
  transition: all .2s ease;
}
.ic-y .inline-cta-btn { background: #0f172a; color: #facc15; }
.inline-cta-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 18px rgba(0,0,0,0.15); }

/* Sidebar */
.sidebar { position: sticky; top: 90px; display: flex; flex-direction: column; gap: 22px; align-self: start; }
.sbox {
  background: #fafaf9; border: 1.5px solid #e5e5e5;
  padding: 22px 22px; border-radius: 8px;
}
.sbox-title {
  font-family: Georgia, serif; font-size: 15.5px; font-weight: 700;
  color: #0f172a; margin: 0 0 16px; padding-bottom: 10px;
  border-bottom: 2px solid #facc15;
  display: flex; align-items: center; gap: 8px;
}
.sbox-title-dot { width: 6px; height: 6px; border-radius: 50%; background: #e11d48; }
.sdl-btn {
  display: flex; align-items: center; gap: 12px;
  width: 100%; padding: 12px 14px; border-radius: 8px;
  border: 1.5px solid #e5e5e5; background: #fff;
  transition: all .2s ease; margin-bottom: 10px; text-align: left;
  cursor: pointer; font-family: inherit;
}
.sdl-btn:last-child { margin-bottom: 0; }
.sdl-btn:hover { border-color: #0f172a; transform: translateX(3px); }
.sdl-btn.primary { background: #0f172a; color: #facc15; border-color: #0f172a; }
.sdl-btn-ico {
  flex-shrink: 0; width: 30px; height: 30px; border-radius: 6px;
  display: inline-flex; align-items: center; justify-content: center;
  background: #fef2f4; color: #e11d48;
}
.sdl-btn.primary .sdl-btn-ico { background: rgba(250,204,21,0.15); color: #facc15; }
.sdl-btn-info { flex: 1; min-width: 0; }
.sdl-btn-name { font-family: Georgia, serif; font-size: 13.5px; font-weight: 700; color: #0f172a; }
.sdl-btn.primary .sdl-btn-name { color: #fff; }
.sdl-btn-ver { font-size: 11px; color: #64748b; margin-top: 2px; }
.sdl-btn.primary .sdl-btn-ver { color: rgba(250,204,21,0.8); }
.stoc { list-style: none; padding: 0; margin: 0; }
.stoc li { margin-bottom: 9px; font-size: 13.5px; line-height: 1.5; }
.stoc li a { color: #334155; display: flex; align-items: flex-start; gap: 7px; transition: color .2s ease; }
.stoc li a::before { content: "§"; color: #e11d48; font-weight: 700; flex-shrink: 0; }
.stoc li a:hover { color: #e11d48; }
.sstat { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.sstat-item { text-align: center; padding: 14px 10px; background: #fff; border-radius: 6px; border: 1px solid #e5e5e5; }
.sstat-num { font-family: Georgia, serif; font-size: 20px; font-weight: 700; color: #e11d48; line-height: 1; }
.sstat-lbl { font-size: 11px; color: #64748b; margin-top: 4px; letter-spacing: 0.3px; }
.side-security {
  padding: 16px 18px; background: #ccfbf1; border-radius: 8px;
  border-left: 3px solid #0d9488;
  font-size: 13px; color: #115e59; line-height: 1.6;
}
.side-security strong { display: block; color: #0f766e; font-weight: 700; margin-bottom: 4px; }

/* ----- Footer ----- */
.site-footer {
  background: #09090b; color: #cbd5e1;
  padding: 56px 0 36px;
  border-top: 3px solid #facc15;
}
.footer-inner { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.footer-brand { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.footer-brand-mark {
  width: 38px; height: 38px; border-radius: 10px;
  background: #facc15; color: #0f172a;
  display: inline-flex; align-items: center; justify-content: center;
}
.footer-brand-text {
  font-family: Georgia, serif; font-size: 22px; font-weight: 700; color: #fff;
}
.footer-brand-sub {
  font-family: Georgia, serif; font-size: 11px; color: #94a3b8; font-style: italic;
  letter-spacing: 1.5px; text-transform: uppercase;
}
.footer-security {
  padding: 16px 20px; background: rgba(250,204,21,0.05);
  border-radius: 8px; border-left: 3px solid #facc15;
  color: #facc15; font-weight: 500; font-size: 14px;
  margin-bottom: 20px;
  display: flex; align-items: center; gap: 10px;
}
.footer-note { font-size: 12.5px; color: #64748b; line-height: 1.7; margin: 0; }

/* ----- Responsive ----- */
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-visual { height: 460px; margin-top: 10px; }
  .spot-row, .spot-row.flip { grid-template-columns: 1fr; gap: 36px; }
  .spot-row.flip .spot-info { order: 1; }
  .spot-row.flip .spot-visual { order: 2; }
  .plat-strip { grid-template-columns: 1fr; }
  .plat-tile { border-right: none; border-bottom: 1px solid #1e293b; }
  .rev-grid { grid-template-columns: repeat(2, 1fr); }
  .faq-wrap { grid-template-columns: 1fr; }
  .feat-edit-grid { grid-template-columns: repeat(6, 1fr); }
  .feat-card { grid-column: span 3; }
  .feat-card.wide, .feat-card.span4 { grid-column: span 6; }
  .dl-specs { grid-template-columns: repeat(2, 1fr); }
  .op-grid { grid-template-columns: 1fr; }
  .guide-grid { grid-template-columns: 1fr; }
  .req-grid { grid-template-columns: repeat(2, 1fr); }
  .art-layout { grid-template-columns: 1fr; padding: 50px 20px; }
  .sidebar { position: static; }
  .tips-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .ed-nav-menu { display: none; }
  .ed-nav-menu.show {
    display: flex; flex-direction: column; align-items: stretch;
    position: absolute; top: 100%; left: 0; right: 0;
    background: #fff; padding: 16px; gap: 6px;
    border-top: 1px solid #e5e5e5;
    box-shadow: 0 12px 28px rgba(0,0,0,0.08);
  }
  .ed-nav-mob { display: inline-flex; }
  .ed-nav-cta { display: none; }
  .sec { padding: 60px 0; }
  .stats-row { grid-template-columns: repeat(2, 1fr); }
  .stat-item { border-right: none; }
  .rev-grid { grid-template-columns: 1fr; }
  .feat-edit-grid { grid-template-columns: 1fr; }
  .feat-card, .feat-card.wide, .feat-card.span4 { grid-column: span 1; }
  .dl-specs { grid-template-columns: 1fr; }
  .req-grid { grid-template-columns: 1fr; }
  .sec-banner { flex-direction: column; text-align: center; padding: 28px 24px; }
  .sec-banner::before { left: 0; right: 0; top: 0; bottom: auto; width: auto; height: 6px; }
  .cta-block { padding: 50px 28px; }
  .inline-cta { flex-direction: column; text-align: center; }
  .dl-win-body { padding: 28px 22px; }
  .dl-win-head { flex-direction: column; text-align: center; }
  .hero-cover { width: 280px; height: 400px; }
  .hero-card-b, .hero-card-c { display: none; }
  .hero-h1 { font-size: 36px; }
}
